module CoursesHelper # 是否有切换为学生的入口 def switch_student_role is_teacher, course, user is_teacher && course.course_members.where(user_id: user.id, role: %i(STUDENT)).exists? end # 是否有切换为教师的入口 def switch_teacher_role is_student, course, user is_student && course.course_members.where(user_id: user.id, role: %i(CREATOR PROFESSOR)).exists? end # 是否有切换为助教的入口 def switch_assistant_role is_student, course, user is_student && course.course_members.where(user_id: user.id, role: %i(ASSISTANT_PROFESSOR)).exists? end # 课堂结束天数 def course_end_date end_date if end_date.present? curr = Time.new date = ((Date.parse(end_date.to_s) - Date.parse(curr.to_s)).to_i) date > 0 ? "#{date}天后" : "" end end # 课堂模块的url def module_url mod, course return nil if mod.blank? or course.blank? case mod.module_type when "shixun_homework" "/courses/#{course.id}/shixun_homeworks/#{mod.id}" when "common_homework" "/courses/#{course.id}/common_homeworks/#{mod.id}" when "group_homework" "/courses/#{course.id}/group_homeworks/#{mod.id}" when "graduation" "/courses/#{course.id}/graduation_topics/#{mod.id}" when "exercise" "/courses/#{course.id}/exercises/#{mod.id}" when "poll" "/courses/#{course.id}/polls/#{mod.id}" when "attachment" "/courses/#{course.id}/files/#{mod.id}" when "board" course_board = course.course_board "/courses/#{course.id}/boards/#{course_board.id}" when "course_group" "/courses/#{course.id}/students" end end # 子目录对应的url def category_url category, course case category.category_type when "shixun_homework" "/courses/#{course.id}/shixun_homework/#{category.id}" when "graduation" if category.name == "毕设选题" "/courses/#{course.id}/graduation_topics/#{category.course_module_id}" else "/courses/#{course.id}/graduation_tasks/#{category.course_module_id}" end when "attachment" "/courses/#{course.id}/file/#{category.id}" end end # 子目录下的任务数 def category_task_count course, category, user case category.category_type when "shixun_homework" get_homework_commons_count(course, 4, category.id) when "graduation" if category.name == "毕设选题" course.graduation_topics_count else course.graduation_tasks_count end when "attachment" get_attachment_count(course, category.id) end end # 课堂模块的任务数 def course_task_count(course, module_type) case module_type when "shixun_homework" get_homework_commons_count(course, 4, 0) when "common_homework" get_homework_commons_count(course, 1, 0) when "group_homework" get_homework_commons_count(course, 3, 0) when "graduation" 0 when "exercise" course.exercises_count when "poll" course.polls_count when "attachment" get_attachment_count(course, 0) when "board" course_board = course.course_board course_board.present? ? course_board.messages.size : 0 when "course_group" course.course_groups_count end end # 当前用户可见的课堂作业,type指定作业类型, category_id指定二级目录 def visible_homework course, user, type, category_id=0 if user.teacher_of_course?(course) homeworks = course.homework_commons.where("homework_type = #{type} and course_second_category_id = #{category_id}") elsif user.member_of_course?(course) member = course.course_members.find_by(user_id: user.id, role: 4) if member.try(:course_group_id).to_i == 0 homeworks = course.homework_commons.where("homework_commons.homework_type = #{type} and publish_time <= '#{Time.now}' and unified_setting = 1 and course_second_category_id = #{category_id}") else not_homework_ids = course.homework_group_settings.where("course_group_id = #{member.try(:course_group_id)} and (publish_time > '#{Time.now}' or publish_time is null)").pluck(:homework_common_id) # not_homework_ids = not_homework_ids.blank? ? "(-1)" : "(" + not_homework_ids.map(&:homework_common_id).join(",") + ")" homeworks = course.homework_commons.where.not(id: not_homework_ids).where("homework_commons.homework_type = #{type} and publish_time <= '#{Time.now}' and course_second_category_id = #{category_id}") end else homeworks = course.homework_commons.where("homework_type = #{type} and publish_time <= '#{Time.now}' and unified_setting = 1 and course_second_category_id = #{category_id}") end homeworks end # 当前用户可见的课堂试卷 def visible_exercise course, user if user.teacher_of_course?(course) exercises = course.exercises elsif user.member_of_course?(course) member = course.course_members.find_by(user_id: user.id, role: 4) if member.try(:course_group_id).to_i == 0 exercises = course.exercises.where("publish_time <= '#{Time.now}' and unified_setting = 1") else not_exercise_ids = course.exercise_group_settings.where("course_group_id = #{member.try(:course_group_id)} and (publish_time > '#{Time.now}' or publish_time is null)").pluck(:exercise_id) exercises = course.exercises.where.not(id: not_exercise_ids).where("publish_time <= '#{Time.now}'") end else exercises = course.exercises.where("publish_time <= '#{Time.now}' and unified_setting = 1") end exercises end # 当前用户可见的课堂问卷 def visible_poll course, user if user.teacher_of_course?(course) polls = course.polls elsif user.member_of_course?(course) member = course.course_members.find_by(user_id: user.id, role: 4) if member.try(:course_group_id).to_i == 0 polls = course.polls.where("publish_time <= '#{Time.now}' and unified_setting = 1") else not_poll_ids = course.poll_group_settings.where("course_group_id = #{member.try(:course_group_id)} and (publish_time > '#{Time.now}' or publish_time is null)").pluck(:poll_id) polls = course.polls.where.not(id: not_poll_ids).where("publish_time <= '#{Time.now}'") end else polls = course.polls.where("publish_time <= '#{Time.now}' and unified_setting = 1") end polls end # 当前用户可见的课堂资源,category_id指定资源的目录 def visible_attachment course, user, category_id=0 result = [] course.attachments.where(course_second_category_id: category_id).each do |attachment| if attachment.unified_setting if attachment.is_public == 1 && attachment.is_publish == 1 || user == attachment.author || user.teacher_of_course?(course) || (user.member_of_course?(course) && attachment.is_publish == 1) result << attachment end else if attachment.is_public == 1 && attachment.is_publish == 1 && !user.member_of_course?(course) || user == attachment.author || user.teacher_of_course?(course) result << attachment elsif user.member_of_course?(course) && attachment.is_publish == 1 member = course.course_members.find_by(user_id: user.id, role: 4) if member.try(:course_group_id).to_i == 0 && attachment.unified_setting result << attachment elsif attachment.attachment_group_settings.where("course_group_id = #{member.try(:course_group_id)} and publish_time > '#{Time.now}'").count == 0 result << attachment end end end end result end # 获取课堂的资源数 def get_attachment_count(course, category_id) category_id.to_i == 0 ? course.attachments.size : course.attachments.where(course_second_category_id: category_id).size end # 获取课堂的作业数 def get_homework_commons_count(course, type, category_id) category_id == 0 ? HomeworkCommon.where(course_id: course.id, homework_type: type).size : HomeworkCommon.where(course_id: course.id, homework_type: type, course_second_category_id: category_id).size end # 获取课堂的任务数(作业数+试卷数+问卷数) def get_tasks_count(course) course.homework_commons_count + course.exercises_count + course.polls_count end # 当前用户可见的毕设任务 def visible_graduation_task course, user if user.teacher_of_course?(course) tasks = course.graduation_tasks else tasks = course.graduation_tasks.where("publish_time <= '#{Time.now}'") end tasks end # 分班情况 def course_group_info course, user_id course_group_ids = course.group_course_power(user_id) course_groups = if course_group_ids.present? sql = %Q{ SELECT * FROM course_groups WHERE id in(SELECT course_group_id FROM teacher_course_groups WHERE id IN(#{course_group_ids.join(",")})) order by position ASC } CourseGroup.find_by_sql(sql) else course.course_groups.includes(:course_members) end group_info = [] if !course_groups.blank? course_groups.each do |group| group_info << {course_group_id: group.id, group_group_name: group.name, count: group.course_members_count} end none_group_count = course.students.where(course_group_id: 0).size group_info << {course_group_id: 0, group_group_name: "未分班", count: none_group_count} if none_group_count > 0 && !course_group_ids.present? end return group_info end def left_group_info course group_info = [] if course.course_groups_count > 0 none_group_count = course.students.where(course_group_id: 0).size group_info << {category_id: 0, category_name: "未分班", position: course.course_groups.pluck(:position).max.to_i + 1, category_count: none_group_count, category_type: false, second_category_url: "/courses/#{@course.id}/course_groups/0"} course.course_groups.each do |course_group| group_info << {category_id: course_group.id, category_name: course_group.name, position: course_group.position, category_count: course_group.course_members_count, category_type: false, second_category_url: "/courses/#{@course.id}/course_groups/#{course_group.id}"} end end group_info end end