parent
431d1d886c
commit
97485ca221
|
@ -27,19 +27,21 @@ class ExerciseController < ApplicationController
|
||||||
render_403
|
render_403
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
@can_edit_excercise = (!has_commit_exercise?(@exercise.id,User.current.id)) || User.current.admin?
|
||||||
|
@exercise_user = ExerciseUser.where("user_id=? and exercise_id=?", User.current.id, @exercise.id).first
|
||||||
# 学生点击的时候即创建关联,自动保存
|
# 学生点击的时候即创建关联,自动保存
|
||||||
#eu = ExerciseUser.create(:user_id => User.current, :exercise_id => @exercise.id, :start_at => Time.now, :status => false)
|
#eu = ExerciseUser.create(:user_id => User.current, :exercise_id => @exercise.id, :start_at => Time.now, :status => false)
|
||||||
|
|
||||||
# 已提交问卷的用户不能再访问该界面
|
# 已提交问卷的用户不能再访问该界面
|
||||||
if has_commit_exercise?(@exercise.id, User.current.id) && (!User.current.admin?)
|
if has_commit_exercise?(@exercise.id, User.current.id) && (!User.current.admin?)
|
||||||
redirect_to exercise_index_url(:course_id=> @course.id)
|
respond_to do |format|
|
||||||
|
format.html {render :layout => 'base_courses'}
|
||||||
|
end
|
||||||
else
|
else
|
||||||
if !@is_teacher && !has_click_exercise?(@exercise.id, User.current.id)
|
if !@is_teacher && !has_click_exercise?(@exercise.id, User.current.id)
|
||||||
eu = ExerciseUser.create(:user_id => User.current.id, :exercise_id => @exercise.id, :start_at => Time.now, :status => false)
|
eu = ExerciseUser.create(:user_id => User.current.id, :exercise_id => @exercise.id, :start_at => Time.now, :status => false)
|
||||||
end
|
end
|
||||||
@can_edit_excercise = (!has_commit_exercise?(@exercise.id,User.current.id)) || User.current.admin?
|
|
||||||
@exercise_user = ExerciseUser.where("user_id=? and exercise_id=?", User.current.id, @exercise.id).first
|
|
||||||
# @percent = get_percent(@exercise,User.current)
|
# @percent = get_percent(@exercise,User.current)
|
||||||
exercise_questions = @exercise.exercise_questions
|
exercise_questions = @exercise.exercise_questions
|
||||||
@exercise_questions = paginateHelper exercise_questions,5 #分页
|
@exercise_questions = paginateHelper exercise_questions,5 #分页
|
||||||
|
@ -433,6 +435,8 @@ class ExerciseController < ApplicationController
|
||||||
redirect_to exercise_url(@exercise)
|
redirect_to exercise_url(@exercise)
|
||||||
# REDO: 提示提交成功
|
# REDO: 提示提交成功
|
||||||
else
|
else
|
||||||
|
# 更新提交状态
|
||||||
|
@exercise.exercise_users.first.update_attributes(:status => true)
|
||||||
# 答题过程中需要统计完成量
|
# 答题过程中需要统计完成量
|
||||||
@uncomplete_question = get_uncomplete_question(@exercise, User.current)
|
@uncomplete_question = get_uncomplete_question(@exercise, User.current)
|
||||||
# 获取改学生的考试得分
|
# 获取改学生的考试得分
|
||||||
|
@ -480,16 +484,17 @@ class ExerciseController < ApplicationController
|
||||||
score2 = score + question.question_score unless question.question_score.nil?
|
score2 = score + question.question_score unless question.question_score.nil?
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
ecs = ExerciseAnswer.where("user_id =? and exercise_question_id =?", user.id, question.id)
|
get_mulscore(question, user, standard_answer)
|
||||||
arr = []
|
# ecs = ExerciseAnswer.where("user_id =? and exercise_question_id =?", user.id, question.id)
|
||||||
ecs.each do |ec|
|
# arr = []
|
||||||
arr << ec.exercise_choice.choice_position
|
# ecs.each do |ec|
|
||||||
end
|
# arr << ec.exercise_choice.choice_position
|
||||||
arr.sort
|
# end
|
||||||
arr = arr.join("")
|
# arr.sort
|
||||||
if arr.to_i == standard_answer.exercise_choice_id
|
# arr = arr.join("")
|
||||||
score3 = score + question.question_score unless question.question_score.nil?
|
# if arr.to_i == standard_answer.exercise_choice_id
|
||||||
end
|
# score3 = score + question.question_score unless question.question_score.nil?
|
||||||
|
# end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -497,6 +502,20 @@ class ExerciseController < ApplicationController
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
# 获取多选的得分
|
||||||
|
def get_mulscore(question, user, standard_answer)
|
||||||
|
ecs = ExerciseAnswer.where("user_id =? and exercise_question_id =?", user.id, question.id)
|
||||||
|
arr = []
|
||||||
|
ecs.each do |ec|
|
||||||
|
arr << ec.exercise_choice.choice_position
|
||||||
|
end
|
||||||
|
arr.sort
|
||||||
|
arr = arr.join("")
|
||||||
|
if arr.to_i == standard_answer.exercise_choice_id
|
||||||
|
score3 = score + question.question_score unless question.question_score.nil?
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
# ExerciseUser记录用户是否已提交问卷有对应的记录则已提交,没有则新建一个
|
# ExerciseUser记录用户是否已提交问卷有对应的记录则已提交,没有则新建一个
|
||||||
def get_exercise_user exercise_id,user_id
|
def get_exercise_user exercise_id,user_id
|
||||||
eu = ExerciseUser.find_by_exercise_id_and_user_id(exercise_id,user_id)
|
eu = ExerciseUser.find_by_exercise_id_and_user_id(exercise_id,user_id)
|
||||||
|
|
|
@ -12,9 +12,8 @@
|
||||||
<div class="fontGrey2">
|
<div class="fontGrey2">
|
||||||
<span class="mr130">开始时间:<%=format_time(exercise_user.start_at.to_s) %></span>
|
<span class="mr130">开始时间:<%=format_time(exercise_user.start_at.to_s) %></span>
|
||||||
<span class="mr130">测验时长:<%=exercise.time %>分钟</span>
|
<span class="mr130">测验时长:<%=exercise.time %>分钟</span>
|
||||||
<% time = exercise_user.end_at - exercise_user.start_at %>
|
<%# time = exercise_user.end_at - exercise_user.start_at %>
|
||||||
<span class="fr">测验用时:<span class="c_red"><%= (time % (24*60*60)) / (60*60)%></span> 小时 <span class="c_red"><%= ((time % (24*60*60)) % (60*60)) / 60%></span> 分钟 <span class="c_red"><%= ((time % (24*60*60)) % (60*60)) % 60%></span> 秒</span>
|
</div>
|
||||||
</div>
|
|
||||||
<div class="testDesEdit mt5"><%= exercise.exercise_description.nil? ? "" : exercise.exercise_description.html_safe%></div>
|
<div class="testDesEdit mt5"><%= exercise.exercise_description.nil? ? "" : exercise.exercise_description.html_safe%></div>
|
||||||
<div class="cl"></div>
|
<div class="cl"></div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -32,7 +31,7 @@
|
||||||
<span class="ml15 c_red">
|
<span class="ml15 c_red">
|
||||||
<% answer = get_user_answer(exercise_question, User.current)%>
|
<% answer = get_user_answer(exercise_question, User.current)%>
|
||||||
<% standard_answer = get_user_standard_answer(exercise_question, User.current)%>
|
<% standard_answer = get_user_standard_answer(exercise_question, User.current)%>
|
||||||
<% if answer.exercise_choice_id == standard_answer.exercise_choice_id %>
|
<% if answer.first.exercise_choice.choice_position == standard_answer.first.exercise_choice_id %>
|
||||||
√
|
√
|
||||||
<% else %>
|
<% else %>
|
||||||
×
|
×
|
||||||
|
@ -63,7 +62,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="testStatus" id="mcq_question_list" style="display: <%=mcq_question_list.count > 0 ? "" : "none" %>">
|
<div class="testStatus" id="mcq_question_list" style="display: <%=mcq_question_list.count > 0 ? "" : "none" %>">
|
||||||
<h3 class="fontGrey3">多选题</h3>
|
<h3 class="fontGrey3">多选题</h3>
|
||||||
<% mcq_question_list.each_wtih_index do |exercise_question, list_index| %>
|
<% mcq_question_list.each_with_index do |exercise_question, list_index| %>
|
||||||
<div id="poll_questions_<%= exercise_question.id%>">
|
<div id="poll_questions_<%= exercise_question.id%>">
|
||||||
<div id="show_poll_questions_<%= exercise_question.id %>">
|
<div id="show_poll_questions_<%= exercise_question.id %>">
|
||||||
<div>
|
<div>
|
||||||
|
@ -71,7 +70,7 @@
|
||||||
<span class="ml15 c_red">
|
<span class="ml15 c_red">
|
||||||
<% answer = get_user_answer(exercise_question, User.current)%>
|
<% answer = get_user_answer(exercise_question, User.current)%>
|
||||||
<% standard_answer = get_user_standard_answer(exercise_question, User.current)%>
|
<% standard_answer = get_user_standard_answer(exercise_question, User.current)%>
|
||||||
<% if answer.exercise_choice_id == standard_answer.exercise_choice_id %>
|
<% if answer.first.exercise_choice_id == standard_answer.first.exercise_choice_id %>
|
||||||
√
|
√
|
||||||
<% else %>
|
<% else %>
|
||||||
×
|
×
|
||||||
|
@ -110,7 +109,7 @@
|
||||||
<span class="ml15 c_red">
|
<span class="ml15 c_red">
|
||||||
<% answer = get_user_answer(exercise_question, User.current)%>
|
<% answer = get_user_answer(exercise_question, User.current)%>
|
||||||
<% standard_answer = get_user_standard_answer(exercise_question, User.current)%>
|
<% standard_answer = get_user_standard_answer(exercise_question, User.current)%>
|
||||||
<% if standard_answer.include?(answer.exercise_choice_id) %>
|
<% if standard_answer.include?(answer.first.answer_text) %>
|
||||||
√
|
√
|
||||||
<% else %>
|
<% else %>
|
||||||
×
|
×
|
||||||
|
|
Loading…
Reference in New Issue