class CoursesController < ApplicationController include MessagesHelper include ExportHelper # model validation error rescue_from ActiveRecord::RecordInvalid do |ex| render_error(ex.record.errors.full_messages.join(',')) end # form validation error rescue_from ActiveModel::ValidationError do |ex| render_error(ex.model.errors.full_messages.join(',')) end before_action :require_login, except: [:index, :show, :students, :teachers, :board_list, :mine, :all_course_groups, :left_banner, :top_banner, :informs, :online_learning] before_action :check_account, only: [:new, :create, :apply_to_join_course, :join_excellent_course] before_action :check_auth, except: [:index, :show, :students, :teachers, :board_list, :mine, :all_course_groups, :left_banner, :top_banner, :apply_to_join_course, :exit_course] before_action :set_course, only: [:show, :update, :destroy, :settings, :set_invite_code_halt, :set_public_or_private, :search_teacher_candidate, :teachers, :apply_teachers, :top_banner, :left_banner, :add_teacher_popup, :add_teacher, :graduation_group_list, :create_graduation_group, :join_graduation_group, :course_group_list, :set_course_group, :change_course_admin, :change_course_teacher, :delete_course_teacher, :teacher_application_review, :students, :all_course_groups, :transfer_to_course_group, :delete_from_course, :search_users, :add_students_by_search, :base_info, :get_historical_courses, :create_group_by_importing_file, :attahcment_category_list,:export_member_scores_excel, :duplicate_course, :switch_to_teacher, :switch_to_assistant, :switch_to_student, :exit_course, :informs, :update_informs, :online_learning, :update_task_position, :tasks_list, :join_excellent_course, :export_couser_info, :export_member_act_score, :new_informs, :delete_informs] before_action :user_course_identity, except: [:join_excellent_course, :index, :create, :new, :apply_to_join_course, :search_course_list, :get_historical_course_students, :mine, :search_slim, :board_list] before_action :teacher_allowed, only: [:update, :destroy, :settings, :search_teacher_candidate, :transfer_to_course_group, :delete_from_course, :export_member_scores_excel, :search_users, :add_students_by_search, :get_historical_courses, :add_teacher_popup, :add_teacher, :export_couser_info, :export_member_act_score] before_action :admin_allowed, only: [:set_invite_code_halt, :set_public_or_private, :change_course_admin, :set_course_group, :create_group_by_importing_file, :update_informs, :new_informs, :update_task_position, :tasks_list, :delete_informs] before_action :teacher_or_admin_allowed, only: [:graduation_group_list, :create_graduation_group, :join_graduation_group, :change_course_teacher, :course_group_list, :teacher_application_review, :apply_teachers, :delete_course_teacher] before_action :validate_course_name, only: [:create, :update] before_action :find_board, only: :board_list before_action :validate_page_size, only: :mine before_action :course_tasks, only: [:tasks_list, :update_task_position] before_action :validate_inform_params, only: [:update_informs, :new_informs] if RUBY_PLATFORM =~ /linux/ require 'simple_xlsx_reader' require 'roo-xls' end # GET /courses # GET /courses.json def index @user = current_user # 根据分类查询课堂(全部,我的,最新,最热) @order = params[:order].present? ? params[:order] : "all" if @order == "visits" order_str = "courses.id = 1309 DESC, courses.visits DESC" @courses = Course.where(is_delete: 0, is_hidden: 0) else order_str = "courses.id = 1309 DESC, courses.homepage_show DESC, courses.created_at desc" @courses = Course.where(is_delete: 0, is_hidden: 0, is_end: 0) end # 金课未开课的不显示在首页 @courses = @courses.where("start_date is null or start_date <= '#{Date.today}'") # 根据搜索关键字进一步筛选 if params[:search].present? # REDO:Extension #user_ids = User.includes(user_extension: :school).where("schools.name like ?", "%#{params[:search]}%").pluck(:id) #course_ids = CourseMember.includes(:user, :course).where("course_members.course_id in (?) and course_members.role in (1,2,3) # and CONCAT(users.lastname, users.firstname) like ?", @courses.map(&:id), "%#{params[:search]}%") # .pluck(:course_id) #@courses = @courses.where("name like ?", "%#{params[:search]}%").or(@courses.where(tea_id: user_ids)).or(@courses.where(id: course_ids)) # 6:21 daiao sql = %Q{ (course_members.role in(1,2,3) and CONCAT(users.lastname, users.firstname) like :keyword) or courses.name like :keyword or schools.name like :keyword } @courses = @courses.joins(:school, course_members: :user) .where("#{sql}", keyword: "%#{params[:search]}%").distinct end @courses_count = @courses.count("courses.id") @courses = @courses.order(order_str) # 分页 page = params[:page] || 1 limit = params[:limit] || 16 @courses = @courses.page(page).per(limit) @courses = @courses.preload(:school, :none_hidden_course_modules, teacher: :user_extension) end def visits_plus_one new_visits = @course.visits + 1 @course.update_visits(new_visits) normal_status("成功") end # GET /courses/1 # GET /courses/1.json def show # render :json => {first_category_url: module_url(course.course_modules.where.not(module_type: "activity").where(hidden: 0).first, course)} end # GET /courses/new def new @course = Course.new unless params[:subject_id].blank? subject = Subject.find_by(id: params[:subject_id], excellent: 1) render :json => {status: 0, course_name: "#{subject&.name}第#{subject&.courses&.count.to_i + 1}期"} else normal_status("成功") end end # Get /courses/:id/settings # Edit Page def settings @course_modules = @course.course_modules.where.not(module_type: 'activity') end # POST /courses # POST /courses.json def create ActiveRecord::Base.transaction do begin @course = Course.new(name: params[:name], class_period: params[:class_period], credit: params[:credit], end_date: params[:end_date], is_public: params[:is_public], school_id: @school.id, authentication: params[:authentication], professional_certification: params[:professional_certification]) @course.tea_id = current_user.id if params[:subject_id].blank? @course_list_name = params[:course_list_name].strip @course_list = CourseList.find_by(name: @course_list_name) if @course_list @course.course_list_id = @course_list.id else new_course_list = CourseList.create!(name: @course_list_name, user_id: current_user.id, is_admin: 0) @course.course_list_id = new_course_list.id end else subject = Subject.find_by!(id: params[:subject_id]) @course.start_date = params[:start_date] @course.subject_id = subject.id @course.excellent = true course_list = CourseList.find_by(name: subject.name) || CourseList.create!(name: subject.name, user_id: current_user.id, is_admin: 0) @course.course_list_id = course_list.id end @course.is_end = @course.end_date.present? && @course.end_date < Date.today if @course.save! @course.generate_invite_code CourseInfo.create!(user_id: current_user.id, course_id: @course.id) CourseMember.create!(course_id: @course.id, user_id: current_user.id, role: 1) # 将实践课程的教学团队成员以教师身份加入课堂 if @course.subject @course.subject.subject_members.where.not(user_id: current_user.id).each do |s_member| CourseMember.create!(course_id: @course.id, user_id: s_member.user_id, role: 2) end Inform.create(container: @course, description: @subject.learning_notes, name: "学习须知") end course_module_types = params[:course_module_types] @course.create_course_modules(course_module_types) end rescue => e uid_logger_error(e.message) tip_exception(e.message) raise ActiveRecord::Rollback end end end # PATCH/PUT /courses/1 # PATCH/PUT /courses/1.json def update ActiveRecord::Base.transaction do begin extra_params = Hash.new extra_params[:school_id] = @school.id if @course.is_end && (course_params[:end_date].blank? || course_params[:end_date].to_date >= Date.today) extra_params[:is_end] = 0 elsif !@course.is_end && !course_params[:end_date].blank? && course_params[:end_date].to_date < Date.today extra_params[:is_end] = 1 end extra_params[:authentication] = params[:authentication] extra_params[:professional_certification] = params[:professional_certification] if @course.subject @course.start_date = params[:start_date] else extra_params[:is_public] = params[:is_public].present? ? params[:is_public] : 0 @course_list_name = params[:course_list_name].strip @course_list = CourseList.find_by(name: @course_list_name) if @course_list extra_params[:course_list_id] = @course_list.id else new_course_list = CourseList.create(name: @course_list_name, user_id: current_user.id, is_admin: 0) extra_params[:course_list_id] = new_course_list.id end end @course.update_attributes!(course_params.merge(extra_params)) @course.update_course_modules(params[:course_module_types]) Rails.logger.info("###############course_update_end") normal_status(0, "成功") rescue => e uid_logger_error(e.message) tip_exception("课堂更新失败") raise ActiveRecord::Rollback end end end def join_excellent_course tip_exception("您已是课堂成员") if current_user.member_of_course?(@course) tip_exception("请通过邀请码加入课堂") unless @course.excellent tip_exception("该课堂已结束") if @course.is_end begin new_student = CourseMember.new(user_id: current_user.id, course_id: @course.id, role: 4) new_student.save! CourseAddStudentCreateWorksJob.perform_later(@course.id, [current_user.id]) StudentJoinCourseNotifyJob.perform_later(current_user.id, @course.id) normal_status(0, "加入成功") rescue => e uid_logger_error(e.message) tip_exception(e.message) end end def informs @informs = @course.informs end def new_informs inform = Inform.new(container: @course) inform.name = params[:name] inform.description = params[:description] inform.save! normal_status("创建成功") end def update_informs inform = @course.informs.find_by(id: params[:inform_id]) inform.update_attributes!(name: params[:name], description: params[:description]) normal_status("更新成功") end def delete_informs inform = @course.informs.find_by(id: params[:inform_id]) inform.destroy! normal_status("删除成功") end def online_learning @subject = @course.subject @stages = @subject&.stages @user = current_user @start_learning = @user_course_identity == Course::STUDENT && @subject&.learning?(current_user.id) end def search_course_list search = params[:search] ? "%#{params[:search].strip}%" : "%%" @course_lists = CourseList.where("name like ?", "#{search}") @search_count = @course_lists.size end # 邀请码停用/启用 def set_invite_code_halt begin @course.update_attribute('invite_code_halt', @course.invite_code_halt == 0 ? 1 : 0) normal_status(0, "成功") rescue => e uid_logger_error(e.message) tip_exception("停用/启用课堂失败") end end # 设置课堂私有/公有 def set_public_or_private begin @course.update_attribute('is_public', @course.is_public == 1 ? 0 : 1) normal_status(0, "成功") rescue => e uid_logger_error(e.message) tip_exception("设置课堂公有/私有失败") end end # DELETE /courses/1 # DELETE /courses/1.json def destroy if @course.is_delete == 0 @course.delete! Tiding.create!(user_id: @course.tea_id, trigger_user_id: 1, container_id: @course.id, container_type: 'Course', tiding_type: 'Delete', extra: @course.name) normal_status(0, "成功") else normal_status(-1, "课堂已删除,无需重复操作") end end # 课堂的基本信息 def base_info end # --- 教师列表相关API --- START # 教师列表以及教师搜索 def teachers @search_str = params[:search].present? ? params[:search].strip : "" if @course.try(:id) != 1309 || current_user.admin? || current_user.try(:id) == 15582 @teacher_list = @course.course_members.joins(:user).where("course_members.role in (1, 2, 3) and LOWER(concat(users.lastname, users.firstname)) LIKE ?", "%#{@search_str}%") else @teacher_list = @course.course_members.joins(:user).where("(course_members.role in (1, 3) or (course_members.user_id = #{current_user.id} and course_members.role = 2)) and LOWER(concat(users.lastname, users.firstname)) LIKE ?", "%#{@search_str}%") end @teacher_list_size = @teacher_list.size @has_graduation_design = @course.course_modules.graduation_module_not_hidden.any? sort = params[:sort] || "desc" @order = params[:order].to_i if @order.present? case @order when 1 @teacher_list = @teacher_list.order("role #{sort}") when 2 @teacher_list = @teacher_list.includes(:user).order("CONVERT(CONCAT(users.lastname, users.firstname) USING gbk) COLLATE gbk_chinese_ci #{sort}") when 3 @teacher_list = @teacher_list.includes(:course, :graduation_group).order("graduation_groups.name #{sort}") else @teacher_list = @teacher_list.order("role #{sort}") end else @teacher_list = @teacher_list.order("role #{sort}") end @is_admin = @user_course_identity < Course::PROFESSOR @applications_size = CourseMessage.unhandled_join_course_requests_by_course(@course).size page = params[:page] || 1 limit = params[:limit] || 20 @teacher_list = @teacher_list.page(page).per(limit) @teacher_list = @teacher_list.preload(:graduation_group, :user, :teacher_course_groups) end def apply_teachers search_str = params[:search].present? ? params[:search].strip : "" @applications = CourseMessage.unhandled_join_course_requests_by_course(@course). joins("join users on course_messages.course_message_id=users.id"). where("LOWER(concat(users.lastname, users.firstname)) LIKE ?", "%#{search_str}%") if @course.try(:id) != 1309 || current_user.admin? || current_user.try(:id) == 15582 teacher_list = @course.course_members.where("course_members.role in (1, 2, 3)") else teacher_list = @course.course_members.where("(course_members.role in (1, 3) or (course_members.user_id = #{current_user.id} and course_members.role = 2))") end @teacher_list_size = teacher_list.size @applications_size = CourseMessage.unhandled_join_course_requests_by_course(@course).size @is_admin = @user_course_identity < Course::PROFESSOR end # 打开添加教师或助教弹窗时访问的接口(需要返回该课堂所有答辩组和所有) def add_teacher_popup @graduation_groups = @course.graduation_groups @course_groups = @course.course_groups @school_name = School.find(current_user.school_id).try(:name) end # 添加教师或助教弹窗中的搜索接口 def search_teacher_candidate name = params[:name] school_name = params[:school_name] # user_ids_of_course_members = @course.course_members.where(role: [1,2,3]).pluck(:user_id) # @users = User.where.not(id: user_ids_of_course_members) @users = User.where(status: User::STATUS_ACTIVE) @users = @users.where("concat(users.lastname, users.firstname) like '%#{name}%'") if name.present? # REDO:Extension @users = @users.joins(user_extension: :school).where("schools.name like '%#{school_name}%'") if school_name.present? @users_size = @users.size page = params[:page] || 1 limit = params[:limit] || 10 @users = @users.page(page).per(limit) end # 添加教师或者助教 def add_teacher ActiveRecord::Base.transaction do begin @user_list = params[:user_list].present? ? params[:user_list] : [] return tip_exception("请先选择成员") if @user_list.blank? @graduation_group_id = params[:graduation_group_id].present? ? GraduationGroup.find(params[:graduation_group_id]).id : 0 @course_group_id = params[:course_group_id].present? ? CourseGroup.find(params[:course_group_id]).id : 0 role = params[:role].to_i teacher_ids = [] @user_list.each do |user| active_student_exist = CourseMember.where(user_id: user[:user_id], role: 4, course_id: @course.id, is_active: 1).any? is_active = active_student_exist ? 0 : 1 user_id = User.find(user[:user_id]).id existing_teacher = CourseMember.find_by(course_id: @course.id, user_id: user_id, role: role) if existing_teacher.blank? teacher_ids << user_id member = CourseMember.create(course_id: @course.id, graduation_group_id: @graduation_group_id, user_id: user_id, role: role, is_active: is_active) member.teacher_course_groups << TeacherCourseGroup.new(course_group_id: @course_group_id, user_id: user_id, course_id: @course.id) if @course_group_id != 0 end end TeacherInviteJoinCourseNotifyJob.perform_later(current_user.id, @course.id, role, teacher_ids) if teacher_ids.present? normal_status(0, "添加成功") rescue => e uid_logger_error(e.message) tip_exception(-1, "添加失败") raise ActiveRecord::Rollback end end end # 获取当前课堂的所有答辩组 def graduation_group_list @graduation_group_list = @course.graduation_groups end # 给当前课堂增加答辩组 def create_graduation_group begin if params[:name].present? identical_exist = GraduationGroup.where(course_id: @course.id, name: params[:name]).any? if identical_exist normal_status(-1, "已存在同名答辩组") else GraduationGroup.create(course_id: @course.id, user_id: current_user.id, name: params[:name]) normal_status(0, "成功") end else tip_exception(-1, "答辩组名称不能为空") end rescue => e uid_logger_error(e.message) tip_exception(-1, "添加失败") raise ActiveRecord::Rollback end end # 将教师加入答辩组 def join_graduation_group ActiveRecord::Base.transaction do begin @course_member_list = params[:course_member_list].present? ? params[:course_member_list] : [] graduation_group_id = GraduationGroup.find(params[:graduation_group_id].to_i).id @course_member_list.each do |course_member| course_member = CourseMember.find(course_member[:course_member_id].to_i) course_member.update_attributes(graduation_group_id: graduation_group_id) end normal_status(0, "成功") rescue => e uid_logger_error(e.message) tip_exception(-1, "加入失败") raise ActiveRecord::Rollback end end end # 获取当前课堂的所有分班, 以及当前教师是否对分班具有管理权限的状态 def course_group_list course_member_id = params[:course_member_id] user_id = params[:user_id] @existed_course_group_ids = TeacherCourseGroup.where(course_id: @course.id, course_member_id: course_member_id, user_id: user_id) .pluck(:course_group_id) @all_course_groups = CourseGroup.where(course_id: @course.id) end # 设置教师的管理权限(即设置该教师所能管理的分班) def set_course_group ActiveRecord::Base.transaction do begin course_group_ids = params[:course_group_ids] user_id = User.find(params[:user_id].to_i).id course_member_id = CourseMember.find(params[:course_member_id]).id teacher_course_groups = TeacherCourseGroup.where(course_id: @course.id, user_id: user_id, course_member_id: course_member_id) teacher_course_groups.destroy_all course_group_ids.each do |course_group_id| course_group_id = CourseGroup.where(id: course_group_id.to_i, course_id: @course.id).first.id TeacherCourseGroup.create(course_id: @course.id, user_id: user_id, course_member_id: course_member_id, course_group_id: course_group_id) end normal_status(0, "成功") rescue => e uid_logger_error(e.message) tip_exception( "分配管理权限失败") raise ActiveRecord::Rollback end end end # 变更管理员 def change_course_admin ActiveRecord::Base.transaction do begin new_admin_user = User.find(params[:user_id].to_i) new_admin = CourseMember.find_by!(id: params[:course_member_id].to_i, course_id: @course.id, user_id: new_admin_user.id) current_admin = CourseMember.find_by!(course_id: @course.id, role: 1) new_admin.CREATOR! current_admin.PROFESSOR! @course.update_attributes!(tea_id: new_admin_user.id) normal_status(0, "变更管理员成功") rescue => e uid_logger_error(e.message) tip_exception( "变更管理员失败") raise ActiveRecord::Rollback end end end # 教师和助教角色转换的接口 def change_course_teacher begin course_member = CourseMember.find_by!(id: params[:course_member_id].to_i, course_id: @course.id) if course_member.PROFESSOR? course_member.ASSISTANT_PROFESSOR! elsif course_member.ASSISTANT_PROFESSOR? course_member.PROFESSOR! else tip_exception( "变更教师/助教失败") end course_member.save! normal_status(0, "变更教师/助教成功") rescue => e uid_logger_error(e.message) tip_exception( "变更教师/助教失败") end end # 删除教师或助教 def delete_course_teacher begin course_member = CourseMember.find_by!(id: params[:course_member_id].to_i, course_id: @course.id) tip_exception("删除失败") if course_member.CREATOR? or course_member.STUDENT? course_student = CourseMember.find_by(user_id: course_member.user_id, course_id: @course.id, role: %i[STUDENT]) course_member.destroy! course_student.update_attributes(is_active: 1) if course_student.present? && !course_student.is_active normal_status(0, "删除成功") rescue => e uid_logger_error(e.message) tip_exception("删除失败") end end # 切换为教师 def switch_to_teacher begin course_member = @course.course_members.find_by!(user_id: current_user.id, is_active: 1) tip_exception("切换失败") unless course_member.STUDENT? course_teacher = CourseMember.find_by!(user_id: current_user.id, role: %i[CREATOR PROFESSOR], course_id: @course.id) course_member.update_attributes(is_active: 0) course_teacher.update_attributes(is_active: 1) normal_status(0, "切换成功") rescue => e uid_logger_error(e.message) tip_exception("切换失败") end end # 切换为助教 def switch_to_assistant begin course_member = @course.course_members.find_by!(user_id: current_user.id, is_active: 1) tip_exception("切换失败") unless course_member.STUDENT? course_teacher = CourseMember.find_by!(user_id: current_user.id, role: %i[ASSISTANT_PROFESSOR], course_id: @course.id) course_member.update_attributes(is_active: 0) course_teacher.update_attributes(is_active: 1) normal_status(0, "切换成功") rescue => e uid_logger_error(e.message) tip_exception("切换失败") end end # 切换为学生 def switch_to_student ActiveRecord::Base.transaction do begin course_member = @course.course_members.find_by!(user_id: current_user.id, is_active: 1) tip_exception("切换失败") if course_member.STUDENT? course_student = CourseMember.find_by!(user_id: current_user.id, role: %i[STUDENT], course_id: @course.id) course_member.update_attributes(is_active: 0) course_student.update_attributes(is_active: 1) normal_status(0, "切换成功") rescue => e uid_logger_error("switch_to_student error: #{e.message}") tip_exception("切换失败") raise ActiveRecord::Rollback end end end def exit_course course_student = CourseMember.find_by!(user_id: current_user.id, role: %i[STUDENT], course_id: @course.id) tip_exception("非课堂学生无法退出课堂") unless course_student.STUDENT? # 课堂如果还有其他身份的用户则更新is_active course_teacher = CourseMember.find_by(user_id: current_user.id, role: %i[CREATOR PROFESSOR ASSISTANT_PROFESSOR], course_id: @course.id) course_student.destroy! course_teacher.update_attributes(is_active: 1) if course_teacher.present? && !course_teacher.is_active CourseDeleteStudentDeleteWorksJob.perform_later(@course.id, [current_user.id]) normal_status(0, "退出成功") end # 教师申请加入课堂的审批 def teacher_application_review ActiveRecord::Base.transaction do begin course_message = CourseMessage.find_by!(id: params[:application_id].to_i, course_id: @course.id) course_message.apply_user_id = current_user.id applier_user = User.find_by!(id: params[:user_id].to_i) approval = params[:approval].to_i if approval == 1 course_message.pass! new_teacher = CourseMember.new(course_id: @course.id, user_id: applier_user.id) content = course_message.content.to_i if content == 3 || content == 7 tip_exception("已存在教师/助教身份") if CourseMember.where(course_id: @course.id, user_id: applier_user.id, role: 3).any? new_teacher.ASSISTANT_PROFESSOR! elsif content == 2 || content == 9 tip_exception("已存在教师/助教身份") if CourseMember.where(course_id: @course.id, user_id: applier_user.id, role: 2).any? new_teacher.PROFESSOR! else tip_exception("申请角色错误") end new_teacher.save! # 课堂管理员才有分配权限,且课堂分班数大于0 if @user_course_identity < Course::PROFESSOR && @course.course_groups_count > 0 && params[:group_id] && params[:group_id].size > 0 # 分班全选则是不限,不需要做处理 unless @course.course_groups.where(id: params[:group_id]).size == @course.course_groups_count @course.course_groups.where(id: params[:group_id]).each do |group| unless TeacherCourseGroup.where(course_id: @course.id, user_id: applier_user.id, course_group_id: group.id, course_member_id: new_teacher.id).exists? TeacherCourseGroup.create(course_id: @course.id, user_id: applier_user.id, course_member_id: new_teacher.id, course_group_id: group.id) end end end end elsif approval == 2 course_message.reject! else tip_exception("参数错误") end course_message.save! normal_status(0, "操作成功") rescue => e uid_logger_error(e.message) tip_exception("操作失败") raise ActiveRecord::Rollback end end end # 已通过职业认证的教师复制课堂 def duplicate_course return tip_exception("没有复制权限") unless current_user.admin? || current_user.is_teacher? || current_user.teacher_of_course?(@course) return tip_exception("教师职业认证未通过") unless current_user.pro_certification? new_course = @course.self_duplicate render json: {new_course_id: new_course.id} end # --- 教师列表相关API --- END # --- 学生列表相关API --- START # 学生列表(包括各个子分班的学生列表)及搜索 def students search = params[:search].present? ? params[:search].strip : nil order = params[:order].present? ? params[:order].to_i : 0 course_group_id = params[:course_group_id].present? ? params[:course_group_id].to_i : nil @students = CourseMember.students(@course) if search.present? # REDO:Extension @students = @students.joins(user: :user_extension).where("LOWER(CONCAT(users.lastname, users.firstname)) like ? or user_extensions.student_id like ?", "%#{search}%", "%#{search}%") end if order == 1 # REDO:Extension @students = @students.includes(user: :user_extension).order("user_extensions.student_id, users.login") elsif order == 2 @students = @students.includes(:course_group).order("course_groups.position, users.login") else # REDO:Extension @students = @students.includes(user: :user_extension).order("user_extensions.student_id, users.login") end if course_group_id.present? @students = @students.where(course_group_id: course_group_id) @course_group = CourseGroup.find(course_group_id) if course_group_id != 0 end @students_count = @students.size page = params[:page] || 1 limit = params[:limit] || 20 @students= @students.page(page).per(limit) @students = @students.includes(:course_group, user: :user_extension) end # 获取当前课程所有分班 def all_course_groups if params[:all] # 返回所有分班 @course_groups_array = @course.course_groups.to_a else # 返回权限下的分班 charge_group_ids = @course.charge_group_ids(current_user) @course_groups_array = @course.course_groups.where(id: charge_group_ids).to_a end current_course_group_id = params[:course_group_id] if current_course_group_id.present? current_course_group = CourseGroup.find(current_course_group_id) @course_groups_array.delete(current_course_group) end end # 将学生批量移动到某个分班 def transfer_to_course_group ActiveRecord::Base.transaction do begin course_group_id = params[:course_group_id].to_i # course_group_id为0意味着移动学生到未分班 if course_group_id != 0 course_group = CourseGroup.find_by!(id: course_group_id, course_id: @course.id) course_group_id = course_group.id end @course.students.where(id: params[:students].pluck(:course_member_id)).each do |student| student.update_attributes!(course_group_id: course_group_id) end normal_status(0, "操作成功") rescue => e uid_logger(e.message) tip_exception("操作失败") raise ActiveRecord::Rollback end end end # 从当前课堂删除学生 def delete_from_course ActiveRecord::Base.transaction do begin students = params[:students] student_ids = [] students.each do |student| course_member = CourseMember.find_by(id: student[:course_member_id].to_i, course_id: @course.id) if course_member.present? member_teacher = CourseMember.find_by(user_id: course_member.user_id, course_id: @course.id, role: %i[CREATOR PROFESSOR ASSISTANT_PROFESSOR]) student_ids << course_member.user_id course_member.destroy! member_teacher.update_attributes(is_active: 1) if member_teacher.present? end end CourseDeleteStudentDeleteWorksJob.perform_later(@course.id, student_ids) if student_ids.present? normal_status(0, "操作成功") rescue => e uid_logger(e.message) tip_exception("操作失败") raise ActiveRecord::Rollback end end end # 搜索添加学生 def add_students_by_search ActiveRecord::Base.transaction do begin user_ids = params[:user_ids] course_group_id = params[:course_group_id].to_i if course_group_id != 0 course_group = CourseGroup.find(course_group_id) course_group_id = course_group.id end student_ids = [] user_ids.each do |user_id| existing_course_member = @course.course_members.find_by(user_id: user_id.to_i) new_student = CourseMember.new(user_id: user_id.to_i, course_id: @course.id, course_group_id: course_group_id, role: 4) if existing_course_member.present? if existing_course_member.STUDENT? existing_course_member.update_attributes(course_group_id: course_group_id) else new_student.is_active = 0 if existing_course_member.is_active new_student.save! student_ids << user_id end else new_student.save! student_ids << user_id end end CourseAddStudentCreateWorksJob.perform_later(@course.id, student_ids) if student_ids.present? TeacherInviteJoinCourseNotifyJob.perform_later(current_user.id, @course.id, 10, student_ids) if student_ids.present? normal_status(0, "添加成功") rescue => e uid_logger(e.message) tip_exception("添加失败") raise ActiveRecord::Rollback end end end # 获取历史课堂,即用户管理的所有课堂以及课堂下的分班(去除当前课堂) def get_historical_courses @courses = Course.where.not(id: @course.id).joins(:course_members). where(is_delete: 0, course_members: {user_id: current_user.id, role: %i[CREATOR PROFESSOR ASSISTANT_PROFESSOR]}).includes(:course_groups) # @courses = Course.includes(:course_groups).where(id: current_user.course_members, is_delete: 0) end # 根据历史课堂的课堂id和分班id获取所有学生 def get_historical_course_students course_id = params[:course_id] course_group_id = params[:course_group_id] @students = CourseMember.where(course_id: course_id, role: %i[STUDENT]) if course_group_id.present? @students = @students.where(course_group_id: course_group_id) end @students = @students.includes(user: [user_extension: :school]) @students_count = @students.size end # 导入创建分班 def create_group_by_importing_file attachment_ids = [] params[:attachment_ids].each do |id| attachment = Attachment.find(id.to_i) attachment_ids << attachment.id end associate_result = Attachment.associate_container(attachment_ids, @course.id, @course.class) return normal_status("参数错误") unless associate_result attachment_ids.each do |attachment_id| attachment = Attachment.find attachment_id path = attachment.disk_directory name = attachment.disk_filename if name.split(".").last == "xls" begin attachment_folder = edu_setting('attachment_folder') full_path = "#{attachment_folder}/#{path}/#{name}" xls = Roo::Spreadsheet.open(full_path, extension: :xls) worksheet = xls.sheet(0) rows = worksheet.last_row.to_i #最后一行数 if rows < 2 return normal_status(-1, "请按照模板格式导入") else group_count = 0 (2..rows).each do |row| name = worksheet.cell(row, 1).to_s if @course.course_groups.where(:name => name).blank? @course.course_groups << CourseGroup.new(:name => name, :position => @course.course_groups_count + 1) group_count += 1 end end return normal_status("已导入#{group_count}个分班") end rescue => e uid_logger_error(e.message) normal_status(-1, "无法完成导入,原因:文件内容无法读取") end else normal_status(-1, "只支持xls文件的导入") end end end # --- 学生列表相关API --- END # 根据姓名和单位搜索用户 def search_users name = params[:name] school_name = params[:school_name] # REDO:Extension @users = User.joins(user_extension: :school) .where("CONCAT(users.lastname, users.firstname) like ? and schools.name like ?", "%#{name}%", "%#{school_name}%") @users_count = @users.size limit = params[:limit] || 20 page = params[:page] || 1 @users = @users.page(page).per(limit) end # 申请加入课堂 def apply_to_join_course ActiveRecord::Base.transaction do begin # 邀请码验证 return normal_status(-1, "邀请码不能为空") if params[:invite_code].blank? invite_code = params[:invite_code] course = Course.find_by(invite_code: invite_code, is_delete: 0, invite_code_halt: 0) course_group = CourseGroup.find_by(invite_code: invite_code) if course.blank? return normal_status(-1, "邀请码无效") if course_group.blank? course = Course.find_by(id: course_group.course_id, is_delete: 0, invite_code_halt: 0) return normal_status(-1, "邀请码无效") if course.blank? end return normal_status(-1, "课堂已结束,无法加入") if course.is_end # 实名认证和职业认证的身份判断 return normal_status(-2, "该课堂要求成员完成实名和职业认证") if course.authentication && course.professional_certification && (!current_user.authentication && !current_user.professional_certification) return normal_status(-2, "该课堂要求成员完成实名认证") if course.authentication && !current_user.authentication return normal_status(-2, "该课堂要求成员完成职业认证") if course.professional_certification && !current_user.professional_certification # 身份验证 if params[:professor].blank? && params[:assistant_professor].blank? && params[:student].blank? return normal_status(-1, "请先选择身份") end if params[:professor].present? && params[:assistant_professor].present? return normal_status(-1, "同一课堂不允许申请多个教师身份") end # 验证是否存在同学号的学生 # u_extension = current_user.user_extension # if params[:student].present? && u_extension.student? # same_student_id_users = UserExtension.where.not(user_id: current_user.id).where(student_id: u_extension.student_id, identity: %i[student], school_id: u_extension.school_id).pluck(:user_id) # tip_exception("该课堂已存在同学号的学生,暂时无法加入,请联系老师") if course.students.exists?(user_id: same_student_id_users) # end # 创建学生身份 if params[:student].present? && params[:student].to_i == 1 existing_student = CourseMember.find_by(course_id: course.id, role: %i[STUDENT], user_id: current_user.id) if existing_student.present? # 如果在该课堂已经存在学生身份,且邀请码为分班邀请码,则将其直接加入分班 existing_student.update_attributes(course_group_id: course_group.id) if course_group.present? else correspond_teacher_exist = current_user.teacher_of_course? course new_student = CourseMember.new(user_id: current_user.id, course_id: course.id, role: 4) new_student.is_active = 0 if correspond_teacher_exist new_student.course_group_id = course_group.id if course_group.present? new_student.save! CourseAddStudentCreateWorksJob.perform_later(course.id, [current_user.id]) StudentJoinCourseNotifyJob.perform_later(current_user.id, course.id) end student_role = 1 end # 创建教师身份 if (params[:professor].present? && params[:professor].to_i == 1) || (params[:assistant_professor].present? && params[:assistant_professor].to_i == 1) teacher_already_exist = current_user.teacher_of_course_non_active? course unless teacher_already_exist existing_course_message = CourseMessage.find_by(course_id: course.id, course_message_id: current_user.id, course_message_type: "JoinCourseRequest", status: 0) if existing_course_message.blank? course_message = CourseMessage.new(course_id: course.id, user_id: course.tea_id, status: 0, course_message_id: current_user.id, course_message_type: "JoinCourseRequest", viewed: false) if params[:professor].present? && params[:professor].to_i == 1 course_message.content = 2 role = 9 message = "教师申请已提交,请等待审核" else course_message.content = 3 role = 7 message = "助教申请已提交,请等待审核" end course_message.save! # role = course_message.content == 2 ? '9' : '7' # 7:助教 9:教师 ApplyTeacherRoleJoinCourseNotifyJob.perform_later(current_user.id, course.id, role) # message = "#{course_message.content == 2 ? '教师' : '助教'}申请已提交,请等待审核" else message = "#{existing_course_message.content == '2' ? '教师' : '助教'}申请已提交,请等待审核" end else message = "您已是课堂成员" end teacher_role = 1 end if teacher_role && student_role render json: { status: 0, message: message, course_id: course.id} elsif student_role render json: { status: 0, message: "加入成功", course_id: course.id} else normal_status(message) end rescue => e uid_logger(e.message) tip_exception(e.message) raise ActiveRecord::Rollback end end end def top_banner @user = current_user @is_teacher = @user_course_identity < Course::STUDENT @is_student = @user_course_identity == Course::STUDENT @course.increment!(:visits) end def left_banner @user = current_user @is_teacher = @user_course_identity < Course::ASSISTANT_PROFESSOR @course_modules = @course.course_modules.where(hidden: 0) @hidden_modules = @course.course_modules.where(hidden: 1) @second_category_type = ["shixun_homework", "graduation", "attachment", "board", "course_group"] end def board_list begin @course = @board.course @current_user = current_user return normal_status(403, "你没有权限操作") if !@current_user.teacher_of_course?(@course) && !@current_user.course_identity(@current_user) == 4 @boards = @course.boards rescue Exception => e uid_logger(e.message) tip_exception("获取数据失败") raise ActiveRecord::Rollback end end def attahcment_category_list @has_course_groups = @course.course_groups.exists? @course_modules = @course.attachment_course_modules end def mine @page = params[:page] || 1 @page_size = params[:page_size] || 15 @courses = Course.by_user(current_user).hidden(false).processing.not_deleted.by_keywords(params[:search]).distinct # @total_count = @courses.count # offset = 0 # while offset < @total_count # # offset = offset + @page_size.to_i + 1 # @courses = @courses.offset(offset) # end @courses= @courses.page(@page).per(@page_size) end # 导出课堂信息 def export_couser_info if params[:export].present? && params[:export] normal_status(0,"正在下载中") else set_export_cookies course_info_to_xlsx @course filename_ = "#{current_user.real_name}_#{@course.name}_课堂信息_#{Time.now.strftime('%Y%m%d_%H%M%S')}" render xlsx: "#{format_sheet_name filename_.strip}",template: "courses/export_course_info.xlsx.axlsx", locals: {course_info: @course_info} end end # 导出活跃度 def export_member_act_score search = params[:search] ? "#{params[:search].strip}" : "" #用户名或学生学号id搜索 group_id = params[:group_id] #分班的班级id @all_members = @course.students @all_members = @all_members.where(course_group_id: group_id) unless group_id.blank? unless search.blank? @all_members = @all_members.joins(user: [:user_extension]).where('concat(users.lastname, users.firstname) like ? or user_extensions.student_id like ?',"%#{search}%","%#{search}%") end if @all_members.size == 0 normal_status(-1,"课堂暂时没有学生") elsif params[:export].present? && params[:export] normal_status(0,"正在下载中") else set_export_cookies @all_members = student_act_score group_id, search act_score_to_xlsx(@all_members) filename_ = "#{current_user.real_name}_#{@course.name}_活跃度_#{Time.now.strftime('%Y%m%d_%H%M%S')}" render xlsx: "#{format_sheet_name filename_.strip}",template: "courses/export_member_act_score.xlsx.axlsx", locals: {activity_level:@user_activity_level} end end # 导出学生成绩 def export_member_scores_excel ActiveRecord::Base.transaction do begin @all_members = @course.students search = params[:search] ? "#{params[:search].strip}" : "" #用户名或学生学号id搜索 group_id = params[:group_id] #分班的班级id @all_members = @all_members.where(course_group_id: group_id) unless group_id.blank? unless search.blank? @all_members = @all_members.joins(user: [:user_extension]).where('concat(users.lastname, users.firstname) like ? or user_extensions.student_id like ?',"%#{search}%","%#{search}%") end if @all_members.length == 0 normal_status(-1,"课堂暂时没有学生") elsif params[:export].present? && params[:export] normal_status(0,"正在下载中") else @c_homeworks = @course.homework_commons.homework_published.order("homework_commons.publish_time asc, homework_commons.created_at asc") @c_exercises = @course.exercises.is_exercise_published.order("exercises.publish_time asc, exercises.created_at asc") # @c_polls = @course.polls.publish_or_not.order("polls.publish_time asc, polls.created_at asc") @c_tasks = @course.graduation_tasks.task_published.order("graduation_tasks.publish_time asc, graduation_tasks.created_at asc") set_export_cookies member_to_xlsx(@course, @all_members, @c_homeworks, @c_exercises, @c_tasks) filename_ = "#{current_user.real_name}_#{@course.name}_总成绩_#{Time.now.strftime('%Y%m%d_%H%M%S')}" render xlsx: "#{format_sheet_name filename_.strip}",template: "courses/export_member_scores_excel.xlsx.axlsx", locals: {course_scores:@course_user_scores,shixun_works:@shixun_work_arrays, common_works:@common_work_arrays,group_works:@group_work_arrays,task_works:@task_work_arrays, exercise_works:@exercise_work_arrays} end rescue Exception => e uid_logger_error(e.message) tip_exception(e.message) raise ActiveRecord::Rollback end end end def search_slim courses = current_user.manage_courses.not_deleted.processing keyword = params[:keyword].to_s.strip if keyword.present? courses = courses.where('name LIKE ?', "%#{keyword}%") end count = courses.count courses = paginate(courses) render_ok(count: count, courses: courses.select(:id, :name).as_json) end def tasks_list case params[:container_type] when 'shixun_homework' @tasks = @course.practice_homeworks when 'common_homework' @tasks = @course.normal_homeworks when 'group_homework' @tasks = @course.group_homeworks when 'exercise' @tasks = @course.exercises when 'poll' @tasks = @course.polls when 'graduation_topic' @tasks = @course.graduation_topics when 'graduation_task' @tasks = @course.graduation_tasks when 'attachment' @tasks = @course.attachments else tip_exception("请指定任务类型") end end def update_task_position Rails.logger.info("#######task_ids_length#{params[:task_ids].uniq.length}#########task_count:#{@tasks.count}") tip_exception("task_ids参数有误") if params[:task_ids].blank? || params[:task_ids].uniq.length != @tasks.count ActiveRecord::Base.transaction do begin @tasks.each do |task| position = params[:task_ids].reverse.index(task.id).to_i + 1 task.update_attributes!(position: position) end normal_status(0, "移动成功") rescue Exception => e uid_logger(e.message) tip_exception(e.message) raise ActiveRecord::Rollback end end end private # Use callbacks to share common setup or constraints between actions. def set_course @course = Course.find_by!(id: params[:id]) tip_exception(404, "") if @course.is_delete == 1 && !current_user.admin? end # Never trust parameters from the scary internet, only allow the white list through. def course_params params.require(:course).permit(:name, :class_period, :credit, :end_date, :is_public, :authentication, :professional_certification) end def validate_course_name tip_exception("课堂名称不能为空!") if params[:course][:name].blank? if params[:subject_id].blank? && @course.blank? || (@course && @course.subject.blank?) tip_exception("课程名称不能为空!") if params[:course_list_name].blank? tip_exception("课堂名称应以课程名称开头命名") unless params[:course][:name].index(params[:course_list_name]) && params[:course][:name].index(params[:course_list_name]) == 0 else @subject = @course.present? ? @course.subject : Subject.find_by!(id: params[:subject_id]) tip_exception("开始时间不能为空") if params[:start_date].blank? tip_exception("结束时间不能为空") if params[:end_date].blank? tip_exception("结束时间必须晚于开始时间") if strf_date(params[:end_date]) <= strf_date(params[:start_date]) tip_exception("开始时间和结束时间不能早于往期开课时间") if @course.nil? && @subject.max_course_end_date && strf_date(params[:start_date]) <= strf_date(@subject.max_course_end_date) validate_start_end_date if @course.present? tip_exception("开放课堂必须包含公告栏和在线学习模块") unless params[:course_module_types].include?("announcement") && params[:course_module_types].include?("online_learning") end tip_exception("课堂所属单位不能为空!") if params[:school].blank? tip_exception("请至少添加一个课堂模块") if params[:course_module_types].blank? @school = School.find_by(name: params[:school].strip) tip_exception("所属单位不存在") unless @school.present? end def validate_start_end_date prev_course = @subject.courses.where("id < #{@course.id}").last next_course = @subject.courses.where("id > #{@course.id}").first tip_exception("开始时间不能与往期开课时间重叠") if prev_course && strf_date(params[:start_date]) <= strf_date(prev_course.end_date) tip_exception("结束时间不能与后期开课时间重叠") if next_course && strf_date(params[:end_date]) >= strf_date(next_course.start_date) end # 超级管理员和课堂管理员的权限判断 def admin_allowed unless @user_course_identity < Course::PROFESSOR tip_exception(403, "..") end end # 课堂教师的权限判断 def teacher_allowed unless @user_course_identity < Course::STUDENT tip_exception(403, "..") end end # 课堂教师,课堂管理员以及超级管理员的权限判断 def teacher_or_admin_allowed unless @user_course_identity < Course::ASSISTANT_PROFESSOR tip_exception(403, "..") end end def course_tasks case params[:container_type] when 'shixun_homework' @tasks = @course.practice_homeworks when 'common_homework' @tasks = @course.normal_homeworks when 'group_homework' @tasks = @course.group_homeworks when 'exercise' @tasks = @course.exercises when 'poll' @tasks = @course.polls when 'graduation_topic' @tasks = @course.graduation_topics when 'graduation_task' @tasks = @course.graduation_tasks when 'attachment' @tasks = @course.attachments else tip_exception("请指定任务类型") end end def validate_inform_params tip_exception("公告标题不能为空") if params[:name].blank? tip_exception("公告内容不能为空") if params[:description].blank? end # def find_container # case params[:container_type] # when 'shixun_homework', 'common_homework', 'group_homework' # @task = HomeworkCommon.find_by(id: params[:container_id]) # when 'exercise' # @task = Exercise.find_by(id: params[:container_id]) # when 'poll' # @task = Poll.find_by(id: params[:container_id]) # when 'graduation_topic' # @task = GraduationTopic.find_by(id: params[:container_id]) # when 'graduation_task' # @task = GraduationTask.find_by(id: params[:container_id]) # when 'attachment' # @task = Attachment.find_by(id: params[:container_id]) # else # tip_exception("container_type参数有误") # end # end def student_act_score group_id, search sql_select = %Q{SELECT cm.*, (SELECT max(student_id) FROM user_extensions WHERE user_extensions.user_id = cm.user_id) AS student_id, (SELECT count(messages.id) FROM messages join boards on messages.board_id = boards.id WHERE boards.course_id = #{@course.id} AND messages.author_id = cm.user_id and messages.parent_id is null) AS message_num, (SELECT count(messages.id) FROM messages join boards on messages.board_id = boards.id WHERE boards.course_id = #{@course.id} AND messages.author_id = cm.user_id and messages.parent_id is not null) AS message_reply_num, (SELECT count(attachments.id) FROM attachments WHERE container_id = #{@course.id} and container_type = "Course" AND attachments.author_id = cm.user_id) AS resource_num, (SELECT count(jfm.id) FROM journals_for_messages AS jfm, homework_commons hs WHERE jfm.jour_id = hs.id AND jfm.user_id = cm.user_id and jfm.jour_type = "HomeworkCommon" and hs.course_id = #{@course.id}) AS homework_journal_num, (SELECT COUNT(gw.id) FROM graduation_works AS gw, graduation_tasks AS gt WHERE gw.graduation_task_id = gt.id AND gt.course_id = #{@course.id} AND gw.work_status != 0 AND gw.user_id = cm.user_id) AS graduation_num, (SELECT COUNT(ss.id) FROM student_works AS ss ,homework_commons AS hc WHERE ss.homework_common_id = hc.id AND hc.course_id = #{@course.id} AND ss.work_status != 0 AND ss.user_id = cm.user_id) AS homework_num, (SELECT COUNT(eu.id) FROM exercise_users AS eu,exercises WHERE eu.exercise_id = exercises.id AND exercises.course_id = #{@course.id} AND eu.commit_status = 1 AND eu.user_id = cm.user_id) AS exercise_num, (SELECT COUNT(pu.id) FROM poll_users AS pu, polls WHERE pu.poll_id = polls.id AND polls.course_id = #{@course.id} AND pu.commit_status = 1 AND pu.user_id = cm.user_id) AS poll_num FROM course_members cm} if search.present? && group_id.present? sql_select += %Q{ join users on cm.user_id = users.id join user_extensions ue on ue.user_id = users.id WHERE cm.role = 4 and cm.course_id = #{@course.id} and cm.course_group_id = #{group_id} and (concat(users.lastname, users.firstname) like '%#{search}%' or ue.student_id like '%#{search}%')} elsif search.present? sql_select += %Q{ join users on cm.user_id = users.id join user_extensions ue on ue.user_id = users.id WHERE cm.role = 4 and (concat(users.lastname, users.firstname) like '%#{search}%' or ue.student_id like '%#{search}%')} elsif group_id.present? sql_select += %Q{ WHERE cm.role = 4 and cm.course_id = #{@course.id} and cm.course_group_id = #{group_id}} else sql_select += %Q{ WHERE cm.role = 4 and cm.course_id = #{@course.id}} end act_scores = CourseMember.find_by_sql(sql_select) act_scores end def course_info_to_xlsx course #课堂信息 @course_info = [] course_info_title = "课堂信息概要" course_id = course.id course_name = course.name course_list_name = course.course_list.present? ? course.course_list.name : "--" course_assistants = course.teachers course_assistants_count = course_assistants&.size course_assistants_name = course_assistants_count > 0 ? course_assistants.map{|m| m.user.real_name}.join('、') : "--" course_teacher_member = course.course_members.course_user_role(%i[CREATOR]) course_teacher = course_teacher_member.present? ? course_teacher_member.first.user.real_name : "--" course_class_counts = course.course_groups_count course_students_count = course.students.size course_1 = ["课堂编号",course_id] course_2 = ["课程名称",course_list_name] course_3 = ["课堂名称",course_name] course_4 = ["教师团队(#{course_assistants_count})", course_assistants_name] course_5 = ["主讲教师", course_teacher] course_6 = ["分班",course_class_counts] course_7 = ["学生", course_students_count] course_main_info = [course_1,course_2,course_3,course_4,course_5,course_6,course_7] course_group_info_head = %w(序号 分班名称 邀请码 学生数量) course_group_info_body = [] none_group_counts = course.none_group_count #当有未分班时,应该也做个统计 if none_group_counts > 0 none_group_index = 2 no_group_array = [1,"未分班",course.invite_code,none_group_counts] course_group_info_body.push(no_group_array) else none_group_index = 1 end if course.course_groups.exists? course.course_groups.each_with_index do |group, index| group_index = (index+none_group_index) group_name = group.name group_code = group.invite_code group_count = group.course_members_count group_array = [group_index,group_name,group_code,group_count] course_group_info_body.push(group_array) end end course_group_info = [course_group_info_head,course_group_info_body] @course_info += [course_info_title,course_main_info,course_group_info] end def act_score_to_xlsx all_members #课堂活跃度 @user_activity_level = [] course_user_level = [] course_activity_title = "课堂活跃度统计" user_cell_head = %w(排名 真实姓名 登录名 邮箱 学号 学校 分班 作业完成数(*10) 试卷完成数(*10) 问卷完成数(*7) 资源发布数(*5) 帖子发布数(*2) 帖子回复数(*1) 作业回复数(*1) 活跃度) all_members.each do |u| #用户的基本信息 user = u.user user_login = user.login user_name = user.real_name user_mail = user.mail user_stu_id = u.student_id.present? ? (u.student_id.to_s + "\t") : "--" user_school = user.school_name user_course_group = u.course_group_name #课堂活跃度统计 user_homeworks_num = u.homework_num.to_i #完成的作业数 user_graduate_num = u.graduation_num.to_i #毕业任务完成数 user_exercise_num = u.exercise_num.to_i #根据试卷的id来查找 user_poll_num = u.poll_num.to_i #已完成问卷 user_file_num = u.resource_num.to_i user_messages_num = u.message_num.to_i #帖子发布数 user_reply_num = u.message_reply_num.to_i #帖子回复数 user_work_reply_num = u.homework_journal_num.to_i #作业回复数的数量 c_works_num = (user_homeworks_num + user_graduate_num)*10 c_exercise_num = user_exercise_num*10 c_poll_num = user_poll_num*7 c_file_num = user_file_num*5 c_message_num = user_messages_num*2 c_reply_num = user_reply_num user_activity_levels = c_works_num + c_exercise_num + c_poll_num + c_file_num + c_message_num + c_reply_num + user_work_reply_num user_ac_level = { u_1: user_name, u_2: user_login, u_2_1: user_mail, u_3: user_stu_id, u_4: user_school, u_5: user_course_group, u_6: c_works_num, u_7: c_exercise_num, u_8: c_poll_num, u_9: c_file_num, u_10: c_message_num, u_11: c_reply_num, u_12: user_work_reply_num, u_13: user_activity_levels } course_user_level.push(user_ac_level) #.课堂活跃度统计的集合 course_user_level = course_user_level.sort_by {|k| k[:u_13]}.reverse @user_activity_level = [course_activity_title,user_cell_head,course_user_level] end end def member_to_xlsx(course,all_members,homeworks,exercises,tasks) #课堂的作业信息 shixun_homeworks = homeworks.search_homework_type(4) #全部实训作业 shixun_titles = shixun_homeworks.pluck(:name) + ["总得分"] # 更新实训作业成绩 shixun_homeworks.includes(:homework_challenge_settings, :published_settings, :homework_commons_shixun).each do |homework| homework.update_homework_work_score end shixun_homeworks = shixun_homeworks&.includes(score_student_works: :user) common_homeworks = homeworks.search_homework_type(1) #全部普通作业 common_titles = common_homeworks.pluck(:name)+ ["总得分"] common_homeworks = common_homeworks&.includes(score_student_works: :user) group_homeworks = homeworks.search_homework_type(3) #全部分组作业 group_titles = group_homeworks.pluck(:name)+ ["总得分"] group_homeworks = group_homeworks&.includes(score_student_works: :user) task_titles = tasks.pluck(:name) + ["总得分"] tasks = tasks&.includes(user: :user_extension, score_graduation_works: :user) exercise_titles = exercises.pluck(:exercise_name) + ["总得分"] exercises = exercises&.includes(user: :user_extension, score_exercise_users: :user) total_user_score_array = [] #学生总成绩集合 all_members.each do |u| #用户的基本信息 user = u.user user_login = user.login user_name = user.real_name user_mail = user.mail user_stu_id = user.student_id.present? ? (user.student_id.to_s + "\t") : "--" user_school = user.school_name user_course_group = u.course_group_name user_info_array = [user_name,user_login,user_mail,user_stu_id,user_school,user_course_group] #用户的信息集合 user_work_scores = [] #学生总成绩 shixun_score = 0.0 # 实训作业的总分 common_score = 0.0 #普通作业的总分 group_score = 0.0 #分组作业的总分 task_score = 0.0 # 毕业任务的总得分 exercise_score = 0.0 #试卷的总得分 shixun_score_array = [] common_score_array = [] group_score_array = [] task_score_array = [] exercise_score_array = [] #实训作业 if shixun_homeworks.size > 0 shixun_homeworks.each do |s| user_student_work = s.score_student_works.select{|work| work.user_id == user.id}.first #当前用户的对该作业的回答 if user_student_work.nil? h_score = 0.0 #该作业的得分为0 else h_score = user_student_work.work_score.nil? ? 0.0 : user_student_work.work_score #用户对该作业的分数 end shixun_score_array.push(h_score) end end shixun_score += shixun_score_array.sum shixun_score_array.push(shixun_score) #shixun_score_array的最后一行为总分 user_work_scores += user_info_array + shixun_score_array #单个用户的实训作业得分信息 #普通作业 if common_homeworks.size > 0 common_homeworks.each do |c| user_student_work_1 = c.score_student_works.select{|work| work.user_id == user.id}.first #当前用户的对该作业的回答 if user_student_work_1.nil? h_score_1 = 0.0 #该作业的得分为0 else h_score_1 = user_student_work_1.work_score.nil? ? 0.0 : user_student_work_1.work_score #用户对该作业的分数 end common_score_array.push(h_score_1) end end common_score += common_score_array.sum common_score_array.push(common_score) #shixun_score_array的最后一行为总分 user_work_scores += common_score_array #单个用户的普通作业得分信息 #分组作业 if group_homeworks.size > 0 group_homeworks.each do |g| user_student_work_3 = g.score_student_works.select{|work| work.user_id == user.id}.first #当前用户的对该作业的回答 if user_student_work_3.nil? h_score_3 = 0.0 #该作业的得分为0 else h_score_3 = user_student_work_3.work_score.nil? ? 0.0 : user_student_work_3.work_score #用户对该作业的分数 end group_score_array.push(h_score_3) end end group_score += group_score_array.sum group_score_array.push(group_score) #shixun_score_array的最后一行为总分 user_work_scores += group_score_array #单个用户的分组作业得分信息 #毕设作业 if tasks.size > 0 tasks.each do |task| graduation_work = task.score_graduation_works.select{|work| work.user_id == user.id}.first if graduation_work.nil? t_score = 0.0 else t_score = graduation_work.work_score.nil? ? 0.0 : graduation_work.work_score end task_score_array.push(t_score) end end task_score += task_score_array.sum task_score_array.push(task_score) user_work_scores += task_score_array #单个用户的分组作业得分信息 #试卷 if exercises.size > 0 exercises.each do |ex| exercise_work = ex.score_exercise_users.select{|work| work.user_id == user.id}.first if exercise_work.nil? e_score = 0.0 else e_score = exercise_work.score.nil? ? 0.0 : exercise_work.score end exercise_score_array.push(e_score) end end exercise_score += exercise_score_array.sum exercise_score_array.push(exercise_score) user_work_scores += exercise_score_array #单个用户的分组作业得分信息 total_user_scores = shixun_score + common_score + group_score + task_score + exercise_score user_work_scores.push(total_user_scores) #个人的行内容添加总成绩 total_user_score_array.push(user_work_scores) # 全部成员的集合 end #2.学生总成绩的集合 ## 作业标题的集合 course_user_score_title = "学生总成绩" score_title_cells = shixun_titles + common_titles + group_titles + task_titles + exercise_titles score_title_counts = [shixun_titles.count,common_titles.count,group_titles.count,task_titles.count,exercise_titles.count] score_cell_head = %w(序号 真实姓名 登录名 邮箱 学号 学校 分班) + score_title_cells + ["个人总成绩"] @course_user_scores = [course_user_score_title,score_cell_head,score_title_counts,total_user_score_array] #作业的全部集合 @shixun_work_arrays = [] @group_work_arrays = [] @common_work_arrays = [] @task_work_arrays = [] @exercise_work_arrays = [] count_1 = shixun_homeworks.size count_2 = common_homeworks.size count_3 = group_homeworks.size count_4 = tasks.size #实训作业 shixun_homeworks.each_with_index do |s,index| all_student_works = s.score_student_works #该实训题的全部用户回答 title_no = index.to_i + 1 student_work_to_xlsx(all_student_works,s) shixun_work_display_name = format_sheet_name (title_no.to_s + "." + s.name).strip.first(30) shixun_work_content = [shixun_work_display_name,@work_head_cells,@work_cells_column] @shixun_work_arrays.push(shixun_work_content) end #普通作业 common_homeworks.each_with_index do |c,index| all_student_works = c.score_student_works #当前用户的对该作业的回答 title_no = count_1 + index.to_i + 1 student_work_to_xlsx(all_student_works,c) work_name = format_sheet_name (title_no.to_s + "." + c.name).strip.first(30) work_content = [work_name,@work_head_cells,@work_cells_column] @common_work_arrays.push(work_content) title_no end #分组作业 group_homeworks.each_with_index do |c,index| all_student_works = c.score_student_works #当前用户的对该作业的回答 title_no = count_1 + count_2 + index.to_i + 1 student_work_to_xlsx(all_student_works,c) work_name = format_sheet_name (title_no.to_s + "." + c.name).strip.first(30) work_content = [work_name,@work_head_cells,@work_cells_column] @group_work_arrays.push(work_content) end #毕设任务 tasks.each_with_index do |c,index| all_student_works = c.score_graduation_works #当前用户的对该作业的回答 title_no = count_1 + count_2 + count_3 + index.to_i + 1 graduation_work_to_xlsx(all_student_works,c,current_user) work_name = format_sheet_name (title_no.to_s + "." + c.name).strip.first(30) work_content = [work_name,@head_cells_column,@task_cells_column] @task_work_arrays.push(work_content) end #试卷的导出 exercises.each_with_index do |c,index| all_student_works = c.score_exercise_users #当前用户的对该作业的回答 title_no = count_1 + count_2 + count_3 + count_4 + index.to_i + 1 get_export_users(c,course,all_student_works) work_name = format_sheet_name (title_no.to_s + "." + c.exercise_name).strip.first(30) work_content = [work_name,@table_columns,@user_columns] @exercise_work_arrays.push(work_content) end end end