|
|
class Weapps::CoursesController < Weapps::BaseController
|
|
|
include CustomSortable
|
|
|
|
|
|
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
|
|
|
|
|
|
member = @course.course_members.find_by(user_id: current_user.id, is_active: 1)
|
|
|
|
|
|
# 签到数据
|
|
|
attendances = @course.course_attendances
|
|
|
current_date = Date.current
|
|
|
current_end_time = Time.current.strftime("%H:%M:%S")
|
|
|
if @user_course_identity == Course::STUDENT
|
|
|
attendances = attendances.joins(:course_attendance_groups).where(course_attendance_groups: {course_group_id: [member.try(:course_group_id).to_i, 0]})
|
|
|
.where("attendance_date < '#{current_date}' or (attendance_date = '#{current_date}' and start_time < '#{current_end_time}')")
|
|
|
end
|
|
|
attendance_ids = attendances.blank? ? "(-1)" : "(" + attendances.pluck(:id).join(",") + ")"
|
|
|
|
|
|
homework_commons = @course.homework_commons.where(homework_type: ["practice", "normal"]).homework_published
|
|
|
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}) or
|
|
|
(course_act_type = 'CourseAttendance' and course_act_id in #{attendance_ids})").order("id desc")
|
|
|
@activities_count = activities.size
|
|
|
@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 course_videos
|
|
|
videos = @course.videos.where(transcoded: true)
|
|
|
videos = custom_sort(videos, params[:sort_by], params[:sort_direction])
|
|
|
#sql = "left join videos on videos.id=course_videos.video_id AND (videos.transcoded=1 OR videos.user_id = #{current_user.id})"
|
|
|
#@videos = paginate videos.joins(sql).includes(video: [user: :user_extension], user: :user_extension)
|
|
|
videos = videos.includes(user: :user_extension)
|
|
|
@count = videos.count
|
|
|
@videos = paginate videos
|
|
|
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
|
|
|
@teacher_users = @course.teacher_users.where.not(id: @course.tea_id).map(&:real_name)[0..3]
|
|
|
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 ?", "%#{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
|
|
|
user_extensions.student_id like ?", "%#{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 |