|
|
|
|
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)
|
|
|
|
|
course.attachments.where(course_second_category_id: category_id).size
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
# 获取课堂的作业数
|
|
|
|
|
def get_homework_commons_count(course, type, category_id)
|
|
|
|
|
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.count > 0
|
|
|
|
|
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
|
|
|
|
|
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
|
|
|
|
|
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"}
|
|
|
|
|
end
|
|
|
|
|
group_info
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
end
|