|
- class Weapps::CoursesController < Weapps::BaseController
- before_action :require_login
- before_action :set_course, except: [:create, :check_invite_code]
- before_action :user_course_identity, except: [:basic_info, :create, :check_invite_code]
- before_action :check_account, only: [:create, :check_invite_code]
- before_action :teacher_allowed, only: [:edit, :update]
- before_action :teacher_or_admin_allowed, only: [:change_member_roles, :delete_course_teachers]
-
- def course_activities
- @course = current_course
- homework_commons = @course.homework_commons.where(homework_type: ["practice", "normal"]).homework_published
- member = @course.course_members.find_by(user_id: current_user.id, is_active: 1)
- if (@user_course_identity == Course::STUDENT && member.try(:course_group_id).to_i == 0) || @user_course_identity > Course::STUDENT
- homework_commons = homework_commons.unified_setting
- elsif @user_course_identity == Course::STUDENT
- not_homework_ids = @course.homework_group_settings.none_published.where("course_group_id = #{member.try(:course_group_id)}").pluck(:homework_common_id)
- homework_commons = homework_commons.where.not(id: not_homework_ids)
- end
- homework_ids = homework_commons.blank? ? "(-1)" : "(" + homework_commons.pluck(:id).join(",") + ")"
-
- activities = @course.course_activities.where("course_act_type in ('Course', 'CourseMessage') or
- (course_act_type = 'HomeworkCommon' and course_act_id in #{homework_ids})").order("id desc")
- @activities = paginate activities.includes(:course_act, user: :user_extension)
- end
-
- def create
- # return render_error("只有老师身份才能创建课堂") unless current_user.is_teacher?
- course = Course.new(tea_id: current_user.id)
- Weapps::CreateCourseService.call(course, course_params)
- render_ok(id: course.id)
-
- rescue ApplicationService::Error => ex
- render_error(ex.message)
- end
-
- def basic_info
- @course = current_course
- end
-
- def edit
- @course = current_course
- end
-
- def update
- course = Weapps::UpdateCourseService.call(current_course, update_course_params)
- render_ok(id: course.id)
- end
-
- def show
- @course = current_course
- @current_user = current_user
- end
-
- def shixun_homework_category
- @categories = current_course.shixun_course_modules.first&.course_second_categories
- end
-
- def check_invite_code
- tip_exception(-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, invite_code_halt: 0)
- if course.blank?
- tip_exception(-1, "邀请码无效") if course_group.blank?
-
- course = Course.find_by(id: course_group.course_id, is_delete: 0)
- tip_exception(-1, "邀请码无效") if course.blank?
- end
-
- tip_exception(-1, "课堂已结束,无法加入") if course.is_end
-
- render_ok
- end
-
- # 教师列表
- def teachers
- @course = current_course
- @page = (params[:page] || 1).to_i
- @limit = (params[:limit] || 20).to_i
- search = params[:search].present? ? params[:search].strip : ""
- if @course.try(:id) != 1309 || current_user.admin_or_business? || current_user.try(:id) == 15582
- @teacher_list = @course.course_members.joins(:user).where("course_members.role in (1, 2, 3)")
- 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))")
- end
-
- if search.present?
- @teacher_list = @teacher_list.joins(:user).where("LOWER(CONCAT(users.lastname, users.firstname)) like ? OR users.nickname like ?", "%#{search}%", "%#{search}%")
- end
-
- @teacher_list_size = @teacher_list.size
-
- @applications_size = CourseMessage.unhandled_join_course_requests_by_course(@course).size
-
- @teacher_list = @teacher_list.includes(user: [user_extension: :school])
- # 中英文混合排序(忽略大小写)
- @teacher_list = @teacher_list.sort {|x, y| Pinyin.t(x.user&.real_name, splitter: '').upcase <=> Pinyin.t(y.user&.real_name, splitter: '').upcase}
- @teacher_list = @teacher_list[(@page-1)*@limit ... @page*@limit]
- end
-
- # 批量删除教师或助教
- def delete_course_teachers
- begin
- @course = current_course
- @page = (params[:page] || 1).to_i
- @limit = (params[:limit] || 20).to_i
- course_members = @course.course_members.where(id: params[:course_member_ids], role: %i[PROFESSOR ASSISTANT_PROFESSOR])
- user_ids = course_members.pluck(:user_id)
- course_members.destroy_all
- CourseDeleteStudentNotifyJob.perform_later(@course.id, user_ids, current_user.id)
- @course.students.where(user_id: user_ids).update_all(is_active: 1)
- normal_status(0, "删除成功")
- rescue => e
- uid_logger_error(e.message)
- tip_exception("删除失败")
- end
- end
-
- def students
- @course = current_course
- @page = (params[:page] || 1).to_i
- @limit = (params[:limit] || 20).to_i
- search = params[:search].present? ? params[:search].strip : nil
- course_group_id = params[:course_group_id].present? ? params[:course_group_id].to_i : nil
-
- @students = CourseMember.students(@course)
-
- if search.present?
- @students = @students.joins(user: :user_extension).where("LOWER(CONCAT(users.lastname, users.firstname)) like ? or users.nickname like ? or
- user_extensions.student_id like ?", "%#{search}%", "%#{search}%", "%#{search}%")
- end
-
- if course_group_id.present?
- @course_group = CourseGroup.find(course_group_id) if course_group_id != 0
- @students = @students.where(course_group_id: @course_group&.id.to_i)
- end
-
- @students_count = @students.size
- @students = @students.includes(user: :user_extension)
- # 中英文混合排序(忽略大小写)
- @students = @students.sort {|x, y| Pinyin.t(x.user&.real_name, splitter: '').upcase <=> Pinyin.t(y.user&.real_name, splitter: '').upcase}
- @students = @students[(@page-1)*@limit ... @page*@limit]
- end
-
- # 批量修改角色
- def change_member_roles
- @course = current_course
- tip_exception("请至少选择一个角色") if params[:roles].reject(&:blank?).blank?
- tip_exception("教师、助教角色只能二选一") if params[:roles].include?("PROFESSOR") && params[:roles].include?("ASSISTANT_PROFESSOR")
-
- params[:user_ids].each do |user_id|
- course_members = @course.course_members.where(user_id: user_id)
- tip_exception("非课堂成员不能修改角色") if course_members.blank?
-
- ActiveRecord::Base.transaction do
- # 第一次修改为教师或助教身份时直接创建数据
- if params[:roles].include?("CREATOR")
- teacher_member = course_members.where(role: %i[CREATOR]).take
- elsif (params[:roles].include?("PROFESSOR") || params[:roles].include?("ASSISTANT_PROFESSOR")) && !course_members.exists?(role: %i[CREATOR PROFESSOR ASSISTANT_PROFESSOR])
- teacher_member = CourseMember.create!(course_id: @course.id, user_id: user_id, role: params[:roles].include?("PROFESSOR") ? 2 : 3)
- # 如果有未审批的申请教师/助教的记录,则修改状态为已审批
- apply_teacher = CourseMessage.where(course_id: @course.id, course_message_id: user_id, status: 0).last
- apply_teacher.update!(status: 1, apply_user_id: current_user.id) if apply_teacher
- elsif course_members.exists?(role: %i[PROFESSOR ASSISTANT_PROFESSOR])
- teacher_member = course_members.where(role: %i[PROFESSOR ASSISTANT_PROFESSOR]).take
- if params[:roles].include?("PROFESSOR") || params[:roles].include?("ASSISTANT_PROFESSOR")
- # 如果之前有老师身份且老师身份要调整时,只需要修改role字段
- if !params[:roles].include?(teacher_member.role) && params[:roles].include?("PROFESSOR")
- teacher_member.PROFESSOR!
- elsif !params[:roles].include?(teacher_member.role) && params[:roles].include?("ASSISTANT_PROFESSOR")
- teacher_member.ASSISTANT_PROFESSOR!
- end
- teacher_member.save!
- else
- # 不含教师的参数时删除记录
- teacher_member.destroy!
- # CourseDeleteStudentNotifyJob.perform_later(@course.id, [teacher_member.user_id], current_user.id)
- end
- end
-
- # 学生身份的处理
- student_member = course_members.where(role: %i[STUDENT]).take
-
- # 不存在则创建学生身份
- if params[:roles].include?("STUDENT") && student_member.blank?
- correspond_teacher_exist = CourseMember.exists?(user_id: user_id, is_active: 1, course_id: @course.id, role: %i[CREATOR PROFESSOR ASSISTANT_PROFESSOR])
- new_student = CourseMember.new(user_id: user_id, course_id: @course.id, role: 4)
- new_student.is_active = 0 if correspond_teacher_exist
- new_student.save!
-
- CourseAddStudentCreateWorksJob.perform_later(@course.id, [user_id])
- # StudentJoinCourseNotifyJob.perform_later(current_user.id, course.id)
- elsif !params[:roles].include?("STUDENT") && student_member.present?
- # 删除学生身份时激活老师身份
- teacher_member.update_attributes!(is_active: 1) if student_member.is_active && teacher_member.present?
- student_member.destroy!
- CourseDeleteStudentDeleteWorksJob.perform_later(@course.id, [user_id])
- # CourseDeleteStudentNotifyJob.perform_later(@course.id, [params[:user_id]], current_user.id)
- elsif params[:roles].include?("STUDENT") && student_member.present? && !params[:roles].include?("PROFESSOR") && !params[:roles].include?("ASSISTANT_PROFESSOR")
- # 学生身份存在且学生没有教师身份时更新is_active
- student_member.update_attributes!(is_active: 1)
- end
- end
- end
- normal_status(0, "修改成功")
- end
-
- # 分班列表
- def course_groups
- @course_groups = @course.course_groups
- @course_groups = @course_groups.where("name like ?", "%#{params[:search]}%") unless params[:search].blank?
- @all_group_count = @course_groups.size
- @teachers = @course.teachers.includes(:user, :teacher_course_groups) if @user_course_identity < Course::NORMAL
- @current_group_id = @course.students.where(user_id: current_user.id).take&.course_group_id if @user_course_identity == Course::STUDENT
- end
-
- private
-
- def course_params
- params.permit(:name, :course_list_name, :credit, :end_date, course_module_types: [])
- end
-
- def update_course_params
- params.permit(:name, :course_list_name, :credit, :end_date)
- end
-
- def current_course
- @_current_course = Course.find params[:id]
- end
-
- def teacher_allowed
- return render_forbidden unless @user_course_identity < Course::STUDENT
- end
-
- # 课堂教师,课堂管理员以及超级管理员的权限判断
- def teacher_or_admin_allowed
- unless @user_course_identity < Course::ASSISTANT_PROFESSOR
- tip_exception(403, "..")
- end
- end
-
- def set_course
- @course = Course.find_by!(id: params[:id])
- tip_exception(404, "") if @course.is_delete == 1 && !current_user.admin_or_business?
- end
- end
|