198 lines
6.1 KiB
Ruby
198 lines
6.1 KiB
Ruby
# encoding: utf-8
|
|
include UserScoreHelper
|
|
|
|
module StudentWorkHelper
|
|
#获取当前用户的项目列表
|
|
def user_projects_option
|
|
projects = User.current.projects.visible
|
|
not_have_project = []
|
|
not_have_project << "请选择关联项目"
|
|
not_have_project << 0
|
|
type = []
|
|
type << not_have_project
|
|
projects.each do |project|
|
|
if project
|
|
option = []
|
|
option << project.name
|
|
option << project.id
|
|
type << option
|
|
end
|
|
end
|
|
type
|
|
end
|
|
|
|
#获取指定用户对某一作业的评分结果
|
|
def student_work_score work,user,reviewer_role=0
|
|
if reviewer_role != 0
|
|
StudentWorksScore.where(:user_id => user.id,:student_work_id => work.id,:reviewer_role => reviewer_role).last
|
|
else
|
|
StudentWorksScore.where(:user_id => user.id,:student_work_id => work.id).last
|
|
end
|
|
end
|
|
|
|
#获取指定评分的角色
|
|
def student_work_score_role score
|
|
case score.reviewer_role
|
|
when 1
|
|
role = "教师"
|
|
when 2
|
|
role = "助教"
|
|
when 3
|
|
role = "学生"
|
|
end
|
|
end
|
|
|
|
def get_role_by_name role
|
|
case role
|
|
when "Teacher"
|
|
result = 1
|
|
when "Manager"
|
|
result = 1
|
|
when "TeachingAsistant"
|
|
result = 2
|
|
when "Student"
|
|
result = 3
|
|
end
|
|
result
|
|
end
|
|
|
|
def get_status status, re_commit
|
|
str = ""
|
|
if re_commit
|
|
str = "重新提交"
|
|
else
|
|
case status
|
|
when 0
|
|
str = "未提交"
|
|
when 1
|
|
str = "已提交"
|
|
when 2
|
|
str = "迟交"
|
|
end
|
|
end
|
|
str
|
|
end
|
|
|
|
#获取学生作品的评分记录:同一个教师或教辅只显示未隐藏的评分
|
|
def student_work_score_record work
|
|
# sql = "SELECT MAX(id) id FROM student_works_scores WHERE (reviewer_role = 2 OR reviewer_role = 1) AND score IS NOT NULL AND is_hidden = 0 AND student_work_id = #{work.id} GROUP BY user_id"
|
|
# tea_ts_ids = StudentWorksScore.find_by_sql sql
|
|
# tea_ts_ids = tea_ts_ids.empty? ? "(-1)" : "(" + tea_ts_ids.map{|tea| tea.id}.join(",") + ")"
|
|
# scores = work.student_works_scores.where("score IS NULL or reviewer_role = 3 or id in #{tea_ts_ids}").order("updated_at desc")
|
|
scores = work.student_works_scores.where(:is_hidden => false).order("created_at desc")
|
|
return scores
|
|
end
|
|
|
|
#获取赞的总数
|
|
def praise_homework_count obj_id
|
|
PraiseTread.where("praise_tread_object_id = #{obj_id} AND praise_tread_object_type = 'StudentWork'").count
|
|
end
|
|
|
|
#判断指定用户是不是已经赞过该作业
|
|
def is_praise_homework user_id, obj_id
|
|
PraiseTread.where("user_id = #{user_id} AND praise_tread_object_id = #{obj_id} AND praise_tread_object_type = 'StudentWork'").empty?
|
|
end
|
|
|
|
#获取指定学生在指定作业内应匿评的数量
|
|
def all_evaluation_count user,homework
|
|
StudentWorksEvaluationDistribution.joins(:student_work).where("student_works_evaluation_distributions.user_id = #{user.id} AND student_works.homework_common_id = #{homework.id}").count
|
|
end
|
|
|
|
#获取指定学生在指定作业内已匿评的数量
|
|
def has_evaluation_count user,homework
|
|
StudentWorksScore.joins(:student_work).where("student_works_scores.user_id = #{user.id} AND student_works.homework_common_id = #{homework.id}").count
|
|
end
|
|
|
|
#传入分数,获取对应颜色
|
|
def score_color score
|
|
if score
|
|
color = score >= 90 ? "c_red" : "c_green"
|
|
else
|
|
color = "c_grey"
|
|
end
|
|
color
|
|
end
|
|
|
|
#获取分班信息
|
|
def course_group_list course
|
|
result = []
|
|
if course.course_groups && !course.course_groups.empty?
|
|
base = []
|
|
base << l(:label_chose_group)
|
|
base << -1
|
|
result << base
|
|
base = []
|
|
base << l(:label_no_group)
|
|
base << 0
|
|
result << base
|
|
course.course_groups.each do |group|
|
|
option = []
|
|
option << group.name
|
|
option << group.id
|
|
result << option
|
|
end
|
|
end
|
|
result
|
|
end
|
|
|
|
#教辅评分比例下拉框
|
|
def ta_proportion_option
|
|
type = []
|
|
i = 0
|
|
while i <= 100
|
|
option = []
|
|
option << i.to_s + "%"
|
|
option << i.to_f / 100
|
|
type << option
|
|
i += 10
|
|
end
|
|
type
|
|
end
|
|
|
|
def ta_proportion_option_to num
|
|
type = []
|
|
i = 0
|
|
while i <= num
|
|
option = []
|
|
option << i.to_s + "%"
|
|
option << i.to_f / 100
|
|
type << option
|
|
i += 10
|
|
end
|
|
type
|
|
end
|
|
|
|
def revise_attachment_status homework, attach
|
|
date = Time.parse(format_time(attach.created_on.to_s)).strftime("%Y-%m-%d")
|
|
status = ""
|
|
if homework.homework_detail_manual && ((homework.anonymous_comment == 0 &&homework.homework_detail_manual.evaluation_start.to_s <= date) || (homework.anonymous_comment == 1 && homework.end_time < attach.created_on))
|
|
status = "此时其他同学作品已公开"
|
|
else
|
|
status = "此时其他同学作品尚未公开"
|
|
end
|
|
return status
|
|
end
|
|
|
|
def group_student_works student_work, homework
|
|
pros = student_work.student_work_projects.where("is_leader = 0")
|
|
user_ids = pros.empty? ? "(-1)" : "(" + pros.map{|stu|stu.user_id}.join(",") + ")"
|
|
student_works = homework.student_works.where("user_id in #{user_ids}")
|
|
return student_works
|
|
end
|
|
|
|
def add_score_to_member student_work, homework, new_score
|
|
student_works = group_student_works student_work, homework
|
|
student_works.each do |st_work|
|
|
st_work.student_works_scores << StudentWorksScore.create(:user_id => new_score.user_id, :score => new_score.score, :reviewer_role => new_score.reviewer_role, :comment => new_score.comment)
|
|
if new_score.reviewer_role == 1
|
|
st_work.teacher_score = new_score.score
|
|
elsif new_score.reviewer_role == 2
|
|
ts_score = StudentWorksScore.find_by_sql("SELECT AVG(score) AS score FROM (SELECT * FROM (SELECT * FROM student_works_scores WHERE student_work_id = #{st_work.id} AND reviewer_role = 2 AND score IS NOT NULL ORDER BY created_at DESC) AS t GROUP BY user_id) AS a")
|
|
st_work.teaching_asistant_score = ts_score.first.score.nil? ? nil : ts_score.first.score.try(:round, 2).to_f
|
|
else
|
|
st_work.student_score = student_work.student_score
|
|
end
|
|
st_work.save
|
|
end
|
|
end
|
|
end |