class Subjects::CourseUsedInfoService < ApplicationService attr_reader :subject def initialize(subject) @subject = subject @shixun_ids = subject.shixuns.pluck(:id) end def call return if subject.blank? homework_commons = HomeworkCommon.joins(:homework_commons_shixun) .where(homework_type: %i[practice]) .where(homework_commons_shixuns: {shixun_id: @shixun_ids}) course_ids = homework_commons.pluck(:course_id) homework_common_ids = homework_commons.pluck("homework_commons.id") schools = School.joins(courses: [:course_members, :homework_commons]) # name:将该课程使用到课堂的单位 # course_count: 将该课程使用到课堂的数量 # student_count: 课堂的学生总数(去掉重复) # choice_shixun_num: 选用该课程实训的个数(去重) # choice_shixun_frequency: 选用该课程实训的次数 course_info = schools.map do |school| name = school.name course_count = school.where(courses: {id: course_ids}).count student_count = school.where(course_members: {role: 4}).select("course_members.user_id").distinct.size homework_commons = school.where(homework_commons: {id: homework_common_ids}) .select("homework_commons.id") choice_shixun_num = homework_commons.distinct.size choice_shixun_frequency = homework_commons.size {name: name, course_count: course_count, student_count: student_count, choice_shixun_num: choice_shixun_num, choice_shixun_frequency: choice_shixun_frequency} end # 默认按照选用实训的次数作为排序 course_info.sort{|x,y| y['choice_shixun_frequency'] <=> x['choice_shixun_frequency']} end end