2015-08-11 11:30:17 +08:00
|
|
|
|
#encoding utf-8
|
2015-01-12 16:56:53 +08:00
|
|
|
|
class PollController < ApplicationController
|
2015-06-09 17:03:28 +08:00
|
|
|
|
before_filter :find_poll_and_course, :only => [:edit,:update,:destroy,:show,:statistics_result,:create_poll_question,:commit_poll,:commit_answer,:publish_poll,:republish_poll,:poll_result,:close_poll,:export_poll]
|
2015-01-12 16:56:53 +08:00
|
|
|
|
before_filter :find_container, :only => [:new,:create, :index]
|
2015-01-21 17:51:12 +08:00
|
|
|
|
before_filter :is_member_of_course, :only => [:index,:show,:poll_result]
|
2015-06-09 17:03:28 +08:00
|
|
|
|
before_filter :is_course_teacher, :only => [:new,:create,:edit,:update,:destroy,:publish_poll,:republish_poll,:close_poll,:export_poll]
|
2015-01-15 09:41:19 +08:00
|
|
|
|
include PollHelper
|
2015-01-12 16:56:53 +08:00
|
|
|
|
def index
|
|
|
|
|
if @course
|
2015-01-13 11:44:28 +08:00
|
|
|
|
@is_teacher = User.current.allowed_to?(:as_teacher,@course)
|
2015-01-17 13:30:50 +08:00
|
|
|
|
if @is_teacher
|
|
|
|
|
polls = Poll.where("polls_type = 'Course' and polls_group_id = #{@course.id}")
|
|
|
|
|
else
|
|
|
|
|
polls = Poll.where("polls_type = 'Course' and polls_group_id = #{@course.id} and polls_status = 2")
|
|
|
|
|
end
|
2015-01-17 14:41:33 +08:00
|
|
|
|
@polls = paginateHelper polls,20 #分页
|
2015-01-12 16:56:53 +08:00
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.html{render :layout => 'base_courses'}
|
|
|
|
|
end
|
|
|
|
|
elsif @project
|
|
|
|
|
#项目的问卷调查相关代码
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def show
|
|
|
|
|
@poll = Poll.find params[:id]
|
2015-07-10 10:05:28 +08:00
|
|
|
|
if @poll.polls_status != 2 && (!User.current.allowed_to?(:as_teacher,@course) || User.current.admin?)
|
2015-03-03 17:53:15 +08:00
|
|
|
|
render_403
|
|
|
|
|
return
|
|
|
|
|
end
|
2015-09-02 10:23:22 +08:00
|
|
|
|
# 问卷消息状态更新
|
2015-08-25 17:06:38 +08:00
|
|
|
|
query_course_poll = @poll.course_messages
|
|
|
|
|
query_course_poll.each do |query|
|
|
|
|
|
if User.current.id == query.user_id
|
|
|
|
|
query.update_attributes(:viewed => true)
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-01-16 10:19:38 +08:00
|
|
|
|
#已提交问卷的用户不能再访问该界面
|
|
|
|
|
if has_commit_poll?(@poll.id,User.current.id) && (!User.current.admin?)
|
2015-04-21 15:10:45 +08:00
|
|
|
|
redirect_to poll_index_url(:polls_type => "Course", :polls_group_id => @course.id)
|
2015-01-16 10:19:38 +08:00
|
|
|
|
else
|
|
|
|
|
@can_edit_poll = (!has_commit_poll?(@poll.id,User.current.id)) || User.current.admin?
|
2015-01-16 15:32:09 +08:00
|
|
|
|
@percent = get_percent(@poll,User.current)
|
2015-01-16 10:19:38 +08:00
|
|
|
|
poll_questions = @poll.poll_questions
|
2015-01-17 13:35:15 +08:00
|
|
|
|
@poll_questions = paginateHelper poll_questions,5 #分页
|
2015-01-16 10:19:38 +08:00
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.html {render :layout => 'base_courses'}
|
|
|
|
|
end
|
2015-01-13 15:59:02 +08:00
|
|
|
|
end
|
2015-01-12 16:56:53 +08:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def new
|
|
|
|
|
if @course
|
|
|
|
|
option = {
|
2015-01-21 09:55:40 +08:00
|
|
|
|
:polls_name => "",
|
2015-01-12 16:56:53 +08:00
|
|
|
|
:polls_type => @course.class.to_s,
|
|
|
|
|
:polls_group_id => @course.id,
|
|
|
|
|
:polls_status => 1,
|
|
|
|
|
:user_id => User.current.id,
|
|
|
|
|
:published_at => Time.now,
|
|
|
|
|
:closed_at => Time.now,
|
2015-01-23 14:10:38 +08:00
|
|
|
|
:show_result => 1,
|
2015-01-12 16:56:53 +08:00
|
|
|
|
:polls_description => ""
|
|
|
|
|
}
|
|
|
|
|
@poll = Poll.create option
|
|
|
|
|
if @poll
|
2015-01-16 11:05:04 +08:00
|
|
|
|
redirect_to edit_poll_url @poll.id
|
2015-01-12 16:56:53 +08:00
|
|
|
|
end
|
|
|
|
|
elsif @project
|
|
|
|
|
#项目的问卷调查相关代码
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def create
|
|
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def edit
|
2015-01-14 14:23:41 +08:00
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.html{render :layout => 'base_courses'}
|
|
|
|
|
end
|
2015-01-12 16:56:53 +08:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def update
|
2015-01-23 14:25:29 +08:00
|
|
|
|
@poll.polls_name = params[:polls_name]
|
|
|
|
|
@poll.polls_description = params[:polls_description]
|
2015-01-12 16:56:53 +08:00
|
|
|
|
if @poll.save
|
|
|
|
|
respond_to do |format|
|
2015-01-15 10:50:08 +08:00
|
|
|
|
format.js
|
2015-01-12 16:56:53 +08:00
|
|
|
|
end
|
|
|
|
|
else
|
2015-01-15 10:50:08 +08:00
|
|
|
|
render_404
|
2015-01-12 16:56:53 +08:00
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def destroy
|
2015-01-12 17:55:22 +08:00
|
|
|
|
if @poll && @poll.destroy
|
2015-01-29 17:33:10 +08:00
|
|
|
|
if @is_teacher
|
|
|
|
|
polls = Poll.where("polls_type = 'Course' and polls_group_id = #{@course.id}")
|
|
|
|
|
else
|
|
|
|
|
polls = Poll.where("polls_type = 'Course' and polls_group_id = #{@course.id} and polls_status = 2")
|
|
|
|
|
end
|
|
|
|
|
@polls = paginateHelper polls,20 #分页
|
2015-01-12 16:56:53 +08:00
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-13 15:59:02 +08:00
|
|
|
|
def statistics_result
|
2015-01-16 10:51:08 +08:00
|
|
|
|
@poll = Poll.find(params[:id])
|
2015-01-16 11:18:39 +08:00
|
|
|
|
poll_questions = @poll.poll_questions
|
2015-01-16 15:49:22 +08:00
|
|
|
|
@poll_questions = paginateHelper poll_questions, 5
|
2015-01-13 15:59:02 +08:00
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.html{render :layout => 'base_courses'}
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-01-14 16:36:30 +08:00
|
|
|
|
|
2015-01-16 10:51:08 +08:00
|
|
|
|
def get_poll_totalcount poll_question
|
|
|
|
|
@total_questions_count = poll_question.poll_votes.count
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def get_poll_everycount poll_answer
|
|
|
|
|
@every_answer_count = poll_answer.poll_votes.count
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-13 15:59:02 +08:00
|
|
|
|
|
2015-01-16 15:57:49 +08:00
|
|
|
|
#添加题目
|
2015-01-14 14:23:41 +08:00
|
|
|
|
def create_poll_question
|
2015-01-14 15:35:04 +08:00
|
|
|
|
question_title = params[:poll_questions_title].nil? || params[:poll_questions_title].empty? ? l(:label_enter_single_title) : params[:poll_questions_title]
|
|
|
|
|
option = {
|
2015-01-15 16:50:06 +08:00
|
|
|
|
:is_necessary => (params[:is_necessary]=="true" ? 1 : 0),
|
2015-01-14 15:35:04 +08:00
|
|
|
|
:question_title => question_title,
|
2015-01-14 16:15:33 +08:00
|
|
|
|
:question_type => params[:question_type] || 1,
|
|
|
|
|
:question_number => @poll.poll_questions.count + 1
|
2015-01-14 15:35:04 +08:00
|
|
|
|
}
|
|
|
|
|
@poll_questions = @poll.poll_questions.new option
|
|
|
|
|
if params[:question_answer]
|
|
|
|
|
for i in 1..params[:question_answer].count
|
|
|
|
|
answer = (params[:question_answer].values[i-1].nil? || params[:question_answer].values[i-1].empty?) ? l(:label_new_answer) : params[:question_answer].values[i-1]
|
|
|
|
|
question_option = {
|
|
|
|
|
:answer_position => i,
|
2015-01-15 10:50:08 +08:00
|
|
|
|
:answer_text => answer
|
2015-01-14 15:35:04 +08:00
|
|
|
|
}
|
|
|
|
|
@poll_questions.poll_answers.new question_option
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-07-28 10:27:45 +08:00
|
|
|
|
# 如果是插入的话,那么从插入的这个id以后的question_num都将要+1
|
|
|
|
|
if params[:quest_id]
|
|
|
|
|
@is_insert = true
|
|
|
|
|
@poll.poll_questions.where("question_number > #{params[:quest_num].to_i}").update_all(" question_number = question_number + 1")
|
|
|
|
|
@poll_question_num = params[:quest_num].to_i
|
|
|
|
|
@poll_questions.question_number = params[:quest_num].to_i + 1
|
2015-01-14 15:35:04 +08:00
|
|
|
|
end
|
2015-07-28 10:27:45 +08:00
|
|
|
|
if @poll_questions.save
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-13 20:13:50 +08:00
|
|
|
|
end
|
|
|
|
|
|
2015-01-16 15:57:49 +08:00
|
|
|
|
#修改题目
|
2015-01-15 14:40:17 +08:00
|
|
|
|
def update_poll_question
|
2015-01-15 18:17:45 +08:00
|
|
|
|
@poll_question = PollQuestion.find params[:poll_question]
|
2015-01-16 15:05:30 +08:00
|
|
|
|
#@poll = @poll_question.poll
|
2015-01-16 10:11:17 +08:00
|
|
|
|
@poll_question.is_necessary = params[:is_necessary]=="true" ? 1 : 0
|
|
|
|
|
@poll_question.question_title = params[:poll_questions_title].nil? || params[:poll_questions_title].empty? ? l(:label_enter_single_title) : params[:poll_questions_title]
|
|
|
|
|
################处理选项
|
|
|
|
|
if params[:question_answer]
|
|
|
|
|
@poll_question.poll_answers.each do |answer|
|
2015-01-16 10:43:05 +08:00
|
|
|
|
answer.destroy unless params[:question_answer].keys.include? answer.id.to_s
|
2015-01-16 10:11:17 +08:00
|
|
|
|
end
|
|
|
|
|
for i in 1..params[:question_answer].count
|
|
|
|
|
question = @poll_question.poll_answers.find_by_id params[:question_answer].keys[i-1]
|
|
|
|
|
answer = (params[:question_answer].values[i-1].nil? || params[:question_answer].values[i-1].empty?) ? l(:label_new_answer) : params[:question_answer].values[i-1]
|
|
|
|
|
if question
|
|
|
|
|
question.answer_position = i
|
|
|
|
|
question.answer_text = answer
|
|
|
|
|
question.save
|
|
|
|
|
else
|
|
|
|
|
question_option = {
|
|
|
|
|
:answer_position => i,
|
|
|
|
|
:answer_text => answer
|
|
|
|
|
}
|
|
|
|
|
@poll_question.poll_answers.new question_option
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
@poll_question.save
|
2015-01-15 18:17:45 +08:00
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
2015-01-15 14:40:17 +08:00
|
|
|
|
end
|
|
|
|
|
|
2015-01-16 15:57:49 +08:00
|
|
|
|
#删除题目
|
2015-01-15 17:15:29 +08:00
|
|
|
|
def delete_poll_question
|
|
|
|
|
@poll_question = PollQuestion.find params[:poll_question]
|
2015-01-15 17:26:56 +08:00
|
|
|
|
@poll = @poll_question.poll
|
|
|
|
|
poll_questions = @poll.poll_questions.where("question_number > #{@poll_question.question_number}")
|
2015-01-15 17:15:29 +08:00
|
|
|
|
poll_questions.each do |question|
|
|
|
|
|
question.question_number -= 1
|
|
|
|
|
question.save
|
|
|
|
|
end
|
|
|
|
|
if @poll_question && @poll_question.destroy
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-16 15:57:49 +08:00
|
|
|
|
#发布问卷
|
|
|
|
|
def publish_poll
|
2015-01-16 17:21:33 +08:00
|
|
|
|
@poll.polls_status = 2
|
|
|
|
|
@poll.published_at = Time.now
|
|
|
|
|
if @poll.save
|
2015-01-21 11:14:01 +08:00
|
|
|
|
if params[:is_remote]
|
|
|
|
|
redirect_to poll_index_url(:polls_type => "Course", :polls_group_id => @course.id)
|
|
|
|
|
else
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-01-16 17:21:33 +08:00
|
|
|
|
end
|
2015-01-16 15:57:49 +08:00
|
|
|
|
end
|
|
|
|
|
|
2015-01-15 09:41:19 +08:00
|
|
|
|
#提交答案
|
|
|
|
|
def commit_answer
|
2015-01-15 11:54:30 +08:00
|
|
|
|
pq = PollQuestion.find(params[:poll_question_id])
|
2015-01-16 10:19:38 +08:00
|
|
|
|
if has_commit_poll?(@poll.id,User.current.id) && (!User.current.admin?)
|
2015-01-16 15:32:09 +08:00
|
|
|
|
render :json => {:text => "failure"}
|
2015-01-16 10:19:38 +08:00
|
|
|
|
return
|
|
|
|
|
end
|
2015-01-15 11:54:30 +08:00
|
|
|
|
if pq.question_type == 1
|
|
|
|
|
#单选题
|
|
|
|
|
pv = PollVote.find_by_poll_question_id_and_user_id(params[:poll_question_id],User.current.id)
|
|
|
|
|
if pv.nil?
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#尚未答该题,添加答案
|
2015-01-15 11:54:30 +08:00
|
|
|
|
pv = PollVote.new
|
|
|
|
|
pv.user_id = User.current.id
|
|
|
|
|
pv.poll_question_id = params[:poll_question_id]
|
|
|
|
|
end
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#修改该题对应答案
|
2015-01-15 11:54:30 +08:00
|
|
|
|
pv.poll_answer_id = params[:poll_answer_id]
|
|
|
|
|
if pv.save
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#保存成功返回成功信息及当前以答题百分比
|
2015-01-16 15:32:09 +08:00
|
|
|
|
@percent = get_percent(@poll,User.current)
|
|
|
|
|
render :json => {:text => "ok" ,:percent => format("%.2f" ,@percent)}
|
2015-01-15 11:54:30 +08:00
|
|
|
|
else
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#返回失败信息
|
2015-01-16 15:32:09 +08:00
|
|
|
|
render :json => {:text => "failure"}
|
2015-01-15 11:54:30 +08:00
|
|
|
|
end
|
|
|
|
|
elsif pq.question_type == 2
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#多选题
|
2015-01-15 11:54:30 +08:00
|
|
|
|
pv = PollVote.find_by_poll_answer_id_and_user_id(params[:poll_answer_id],User.current.id)
|
|
|
|
|
if pv.nil?
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#尚未答该题,添加答案
|
2015-01-15 11:54:30 +08:00
|
|
|
|
pv = PollVote.new
|
|
|
|
|
pv.user_id = User.current.id
|
|
|
|
|
pv.poll_question_id = params[:poll_question_id]
|
|
|
|
|
pv.poll_answer_id = params[:poll_answer_id]
|
|
|
|
|
if pv.save
|
2015-01-16 15:32:09 +08:00
|
|
|
|
@percent = get_percent(@poll,User.current)
|
|
|
|
|
render :json => {:text => "true",:percent => format("%.2f" ,@percent)}
|
2015-01-15 11:54:30 +08:00
|
|
|
|
else
|
2015-01-16 15:32:09 +08:00
|
|
|
|
render :json => {:text => "failure"}
|
2015-01-15 11:54:30 +08:00
|
|
|
|
end
|
|
|
|
|
else
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#pv不为空,则当前选项之前已被选择,再次点击则是不再选择该项,故删除该答案
|
2015-01-15 11:54:30 +08:00
|
|
|
|
if pv.delete
|
2015-01-16 15:32:09 +08:00
|
|
|
|
@percent = get_percent(@poll,User.current)
|
|
|
|
|
render :json => {:text => "false" ,:percent => format("%.2f" ,@percent)}
|
2015-01-15 11:54:30 +08:00
|
|
|
|
else
|
2015-01-16 15:32:09 +08:00
|
|
|
|
render :json => {:text => "failure"}
|
2015-01-15 11:54:30 +08:00
|
|
|
|
end
|
|
|
|
|
end
|
2015-01-15 17:36:30 +08:00
|
|
|
|
elsif pq.question_type == 3 || pq.question_type == 4
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#单行文本,多行文本题
|
2015-01-15 17:36:30 +08:00
|
|
|
|
pv = PollVote.find_by_poll_question_id_and_user_id(params[:poll_question_id],User.current.id)
|
|
|
|
|
if pv.nil?
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#pv为空之前尚未答题,添加答案
|
2015-01-16 15:32:09 +08:00
|
|
|
|
if params[:vote_text].nil? || params[:vote_text].blank?
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#用户提交空答案,视作不作答
|
2015-01-16 15:32:09 +08:00
|
|
|
|
@percent = get_percent(@poll,User.current)
|
|
|
|
|
render :json => {:text => pv.vote_text,:percent => format("%.2f" ,@percent)}
|
|
|
|
|
else
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#添加答案
|
2015-01-16 15:32:09 +08:00
|
|
|
|
pv = PollVote.new
|
|
|
|
|
pv.user_id = User.current.id
|
|
|
|
|
pv.poll_question_id = params[:poll_question_id]
|
|
|
|
|
pv.vote_text = params[:vote_text]
|
|
|
|
|
if pv.save
|
|
|
|
|
@percent = get_percent(@poll,User.current)
|
|
|
|
|
render :json => {:text => pv.vote_text,:percent => format("%.2f" ,@percent)}
|
|
|
|
|
else
|
|
|
|
|
render :json => {:text => "failure"}
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-01-15 17:36:30 +08:00
|
|
|
|
else
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#pv不为空说明用户之前已作答
|
2015-01-16 15:32:09 +08:00
|
|
|
|
if params[:vote_text].nil? || params[:vote_text].blank?
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#用户提交空答案,视为删除答案
|
2015-01-16 15:32:09 +08:00
|
|
|
|
if pv.delete
|
|
|
|
|
@percent = get_percent(@poll,User.current)
|
|
|
|
|
render :json => {:text => pv.vote_text,:percent => format("%.2f" ,@percent)}
|
|
|
|
|
else
|
|
|
|
|
render :json => {:text => "failure"}
|
|
|
|
|
end
|
|
|
|
|
else
|
2015-01-16 15:51:26 +08:00
|
|
|
|
#用户修改答案
|
2015-01-16 15:32:09 +08:00
|
|
|
|
pv.vote_text = params[:vote_text]
|
|
|
|
|
if pv.save
|
|
|
|
|
@percent = get_percent(@poll,User.current)
|
|
|
|
|
render :json => {:text => pv.vote_text,:percent => format("%.2f" ,@percent)}
|
|
|
|
|
else
|
|
|
|
|
render :json => {:text => "failure"}
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-01-15 17:36:30 +08:00
|
|
|
|
end
|
2015-01-16 15:32:09 +08:00
|
|
|
|
|
2015-01-15 17:36:30 +08:00
|
|
|
|
else
|
2015-01-16 15:32:09 +08:00
|
|
|
|
render :json => {:text => "failure"}
|
2015-01-15 09:41:19 +08:00
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-15 17:36:30 +08:00
|
|
|
|
#提交问卷
|
|
|
|
|
def commit_poll
|
2015-01-16 15:32:09 +08:00
|
|
|
|
@uncomplete_question = get_uncomplete_question(@poll,User.current)
|
2015-01-15 17:36:30 +08:00
|
|
|
|
if @uncomplete_question.count < 1
|
|
|
|
|
pu = get_poll_user(@poll.id,User.current.id)
|
|
|
|
|
pu.user_id = User.current.id
|
|
|
|
|
pu.poll_id = @poll.id
|
|
|
|
|
if pu.save
|
|
|
|
|
#redirect_to poll_index_path(:polls_group_id => @course.id,:polls_type => 'Course')
|
2015-01-15 18:22:30 +08:00
|
|
|
|
@status = 0 #提交成功
|
|
|
|
|
else
|
|
|
|
|
@status = 2 #未知错误
|
2015-01-15 17:36:30 +08:00
|
|
|
|
end
|
|
|
|
|
else
|
2015-01-15 18:22:30 +08:00
|
|
|
|
@status = 1 #有未做得必答题
|
2015-01-15 17:36:30 +08:00
|
|
|
|
end
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-07-29 10:07:00 +08:00
|
|
|
|
|
|
|
|
|
def import_poll
|
|
|
|
|
@poll = Poll.find(params[:to_id])
|
|
|
|
|
question_num = @poll.poll_questions.select("max(question_number) question_number").first.question_number
|
|
|
|
|
import_poll = Poll.find(params[:import_id])
|
|
|
|
|
import_poll.poll_questions.each_with_index do |question,index|
|
|
|
|
|
option = {
|
|
|
|
|
:is_necessary => question.is_necessary,
|
|
|
|
|
:question_title => question.question_title,
|
|
|
|
|
:question_type => question.question_type,
|
|
|
|
|
:question_number => question_num + index+1
|
|
|
|
|
}
|
|
|
|
|
poll_questions = @poll.poll_questions.new option
|
|
|
|
|
for i in 1..question.poll_answers.count
|
|
|
|
|
answer = question.poll_answers[i-1][:answer_text]
|
|
|
|
|
question_option = {
|
|
|
|
|
:answer_position => i,
|
|
|
|
|
:answer_text => answer
|
|
|
|
|
}
|
|
|
|
|
poll_questions.poll_answers.new question_option
|
|
|
|
|
end
|
|
|
|
|
@poll.poll_questions << poll_questions
|
|
|
|
|
end
|
|
|
|
|
if @poll.save
|
|
|
|
|
@poll = Poll.find(params[:to_id])
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-20 11:42:28 +08:00
|
|
|
|
#重新发布问卷
|
|
|
|
|
def republish_poll
|
|
|
|
|
@poll.poll_questions.each do |poll_question|
|
|
|
|
|
poll_question.poll_votes.destroy_all
|
|
|
|
|
end
|
|
|
|
|
@poll.poll_users.destroy_all
|
|
|
|
|
@poll.polls_status = 1
|
|
|
|
|
@poll.save
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-21 17:51:12 +08:00
|
|
|
|
#显示某个学生某份问卷的填写结果
|
|
|
|
|
def poll_result
|
|
|
|
|
@poll_questions = paginateHelper @poll.poll_questions,5
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.html{render :layout => 'base_courses'}
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-27 09:45:15 +08:00
|
|
|
|
#关闭问卷
|
|
|
|
|
def close_poll
|
|
|
|
|
@poll.polls_status = 3
|
2015-01-27 09:55:02 +08:00
|
|
|
|
@poll.closed_at = Time.now
|
2015-01-27 09:45:15 +08:00
|
|
|
|
if @poll.save
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-09 17:03:28 +08:00
|
|
|
|
#导出问卷
|
|
|
|
|
def export_poll
|
|
|
|
|
poll_questions = @poll.poll_questions
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.xls {
|
|
|
|
|
send_data(poll_to_xls(poll_questions), :type => "text/excel;charset=utf-8; header=present",
|
|
|
|
|
:filename => "#{@poll.polls_name}.xls")
|
|
|
|
|
}
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-08-10 09:12:26 +08:00
|
|
|
|
# 将其他地方的问卷导出来
|
|
|
|
|
def other_poll
|
2015-08-11 11:30:17 +08:00
|
|
|
|
# 查作者是我,或者作者是当前课程的老师,且不在当前课程内的问卷 进行导入
|
|
|
|
|
tea_ids = '('
|
|
|
|
|
tea_ids << Course.find(params[:polls_group_id]).tea_id.to_s << ','<< User.current.id.to_s << ')'
|
|
|
|
|
@polls = Poll.where("user_id in #{tea_ids} and polls_type = 'course' and polls_group_id != #{params[:polls_group_id]}")
|
2015-08-10 09:12:26 +08:00
|
|
|
|
@polls_group_id = params[:polls_group_id]
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
# 将问卷导入本课程
|
|
|
|
|
def import_other_poll
|
|
|
|
|
course_id = params[:course_id]
|
|
|
|
|
@course = Course.find(course_id)
|
|
|
|
|
params[:polls].each_with_index do |p,i|
|
|
|
|
|
poll = Poll.find(p)
|
|
|
|
|
option = {
|
2015-08-11 11:30:17 +08:00
|
|
|
|
:polls_name => poll.polls_name || l(:label_poll_new),
|
2015-08-10 09:12:26 +08:00
|
|
|
|
:polls_type => 'Course',
|
|
|
|
|
:polls_group_id => course_id,
|
|
|
|
|
:polls_status => 1,
|
|
|
|
|
:user_id => User.current.id,
|
|
|
|
|
:published_at => Time.now,
|
|
|
|
|
:closed_at => Time.now,
|
|
|
|
|
:show_result => 1,
|
|
|
|
|
:polls_description => poll.polls_description
|
|
|
|
|
}
|
|
|
|
|
@poll = Poll.create option
|
|
|
|
|
|
|
|
|
|
poll.poll_questions.each do | q|
|
|
|
|
|
#question_title = params[:poll_questions_title].nil? || params[:poll_questions_title].empty? ? l(:label_enter_single_title) : params[:poll_questions_title]
|
|
|
|
|
option = {
|
|
|
|
|
:is_necessary => q[:is_necessary],
|
|
|
|
|
:question_title => q[:question_title],
|
|
|
|
|
:question_type => q[:question_type] || 1,
|
|
|
|
|
:question_number => q[:question_number]
|
|
|
|
|
}
|
|
|
|
|
@poll_questions = @poll.poll_questions.new option
|
|
|
|
|
|
|
|
|
|
for i in 1..q.poll_answers.count
|
|
|
|
|
answer = q.poll_answers[i-1].nil? ? l(:label_new_answer) : q.poll_answers[i-1][:answer_text]
|
|
|
|
|
question_option = {
|
|
|
|
|
:answer_position => i,
|
|
|
|
|
:answer_text => answer
|
|
|
|
|
}
|
|
|
|
|
@poll_questions.poll_answers.new question_option
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
@poll.save
|
|
|
|
|
end
|
|
|
|
|
@is_teacher = User.current.allowed_to?(:as_teacher,@course)
|
|
|
|
|
if @is_teacher
|
|
|
|
|
polls = Poll.where("polls_type = 'Course' and polls_group_id = #{@course.id}")
|
|
|
|
|
else
|
|
|
|
|
polls = Poll.where("polls_type = 'Course' and polls_group_id = #{@course.id} and polls_status = 2")
|
|
|
|
|
end
|
|
|
|
|
@polls = paginateHelper polls,20 #分页
|
|
|
|
|
respond_to do |format|
|
|
|
|
|
format.js
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-12 16:56:53 +08:00
|
|
|
|
private
|
|
|
|
|
def find_poll_and_course
|
|
|
|
|
@poll = Poll.find params[:id]
|
|
|
|
|
@course = Course.find @poll.polls_group_id
|
|
|
|
|
rescue Exception => e
|
|
|
|
|
render_404
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def find_container
|
|
|
|
|
if params[:polls_type] && params[:polls_group_id]
|
|
|
|
|
case params[:polls_type]
|
|
|
|
|
when "Course"
|
|
|
|
|
@course = Course.find_by_id params[:polls_group_id]
|
|
|
|
|
when "Project"
|
|
|
|
|
@project = Project.find_by_id params[:polls_group_id]
|
|
|
|
|
end
|
|
|
|
|
else
|
|
|
|
|
render_404
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-01-13 10:23:26 +08:00
|
|
|
|
|
|
|
|
|
def is_member_of_course
|
2015-07-10 10:05:28 +08:00
|
|
|
|
render_403 unless(@course && (User.current.member_of_course?(@course) || User.current.admin?))
|
2015-01-13 10:23:26 +08:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def is_course_teacher
|
2015-01-20 11:42:28 +08:00
|
|
|
|
@is_teacher = User.current.allowed_to?(:as_teacher,@course)
|
|
|
|
|
render_403 unless(@course && @is_teacher)
|
2015-01-13 10:23:26 +08:00
|
|
|
|
end
|
2015-01-15 17:36:30 +08:00
|
|
|
|
|
|
|
|
|
#获取未完成的题目
|
2015-01-16 15:32:09 +08:00
|
|
|
|
def get_uncomplete_question poll,user
|
2015-01-15 17:36:30 +08:00
|
|
|
|
necessary_questions = poll.poll_questions.where("#{PollQuestion.table_name}.is_necessary = 1")
|
|
|
|
|
uncomplete_question = []
|
|
|
|
|
necessary_questions.each do |question|
|
2015-01-16 15:32:09 +08:00
|
|
|
|
answers = get_user_answer(question,user)
|
|
|
|
|
if answers.nil? || answers.count < 1
|
2015-01-15 17:36:30 +08:00
|
|
|
|
uncomplete_question << question
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
uncomplete_question
|
|
|
|
|
end
|
|
|
|
|
|
2015-01-16 15:32:09 +08:00
|
|
|
|
#获取用户对某个问题的答案
|
|
|
|
|
def get_user_answer(question,user)
|
|
|
|
|
user_answer = question.poll_votes.where("#{PollVote.table_name}.user_id = #{user.id}")
|
|
|
|
|
user_answer
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def get_complete_question(poll,user)
|
|
|
|
|
questions = poll.poll_questions
|
|
|
|
|
complete_question = []
|
|
|
|
|
questions.each do |question|
|
|
|
|
|
answers = get_user_answer(question,user)
|
|
|
|
|
if !(answers.nil? || answers.count < 1)
|
|
|
|
|
complete_question << question
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
complete_question
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def get_percent poll,user
|
|
|
|
|
complete_count = get_complete_question(poll,user).count
|
2015-01-16 15:51:26 +08:00
|
|
|
|
if poll.poll_questions.count == 0
|
|
|
|
|
return 0
|
|
|
|
|
else
|
|
|
|
|
return (complete_count.to_f / poll.poll_questions.count.to_f)*100
|
|
|
|
|
end
|
2015-01-16 15:32:09 +08:00
|
|
|
|
end
|
|
|
|
|
|
2015-01-15 17:36:30 +08:00
|
|
|
|
#PollUser记录用户是否已提交问卷有对应的记录则已提交,没有则新建一个
|
|
|
|
|
def get_poll_user poll_id,user_id
|
|
|
|
|
pu = PollUser.find_by_poll_id_and_user_id(poll_id,user_id)
|
|
|
|
|
if pu.nil?
|
|
|
|
|
pu = PollUser.new
|
|
|
|
|
end
|
|
|
|
|
pu
|
|
|
|
|
end
|
2015-06-09 17:03:28 +08:00
|
|
|
|
|
|
|
|
|
#将poll中题目转换为Excel
|
|
|
|
|
def poll_to_xls poll_questions
|
|
|
|
|
xls_report = StringIO.new
|
|
|
|
|
book = Spreadsheet::Workbook.new
|
|
|
|
|
sheet1 = book.create_worksheet :name => "poll"
|
|
|
|
|
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
|
|
|
|
count_row = 0
|
|
|
|
|
poll_questions.each do |poll_question|
|
|
|
|
|
if poll_question.question_type == 1 || poll_question.question_type == 2
|
|
|
|
|
sheet1.row(count_row).default_format = blue
|
|
|
|
|
sheet1[count_row,0]= l(:label_poll_question_num,:num => poll_question.question_number)
|
|
|
|
|
sheet1[count_row + 1,0] = l(:label_poll_subtotal)
|
|
|
|
|
sheet1[count_row + 2,0] = l(:label_poll_proportion)
|
|
|
|
|
poll_question.poll_answers.each_with_index do |poll_answer,i|
|
2015-06-12 16:58:43 +08:00
|
|
|
|
sheet1[count_row, i + 1] = poll_answer.answer_text.gsub(/<\/?.*?>/,"").gsub(/ /," ")
|
2015-06-09 17:03:28 +08:00
|
|
|
|
sheet1[count_row + 1, i + 1] = poll_answer.poll_votes.count
|
|
|
|
|
sheet1[count_row + 2, i + 1] = statistics_result_percentage(poll_answer.poll_votes.count, total_answer(poll_question.id)).to_s + "%"
|
|
|
|
|
end
|
|
|
|
|
sheet1[count_row + 3,0] = l(:label_poll_valid_commit)
|
|
|
|
|
sheet1[count_row + 3,1] = total_answer(poll_question.id)
|
|
|
|
|
count_row += 5
|
|
|
|
|
else
|
|
|
|
|
sheet1.row(count_row).default_format = blue
|
|
|
|
|
sheet1[count_row,0] = l(:label_poll_question_num,:num => poll_question.question_number)
|
|
|
|
|
sheet1[count_row,1] = poll_question.question_title
|
|
|
|
|
count_row += 1
|
|
|
|
|
poll_question.poll_votes.each do |poll_vote|
|
2015-06-12 16:58:43 +08:00
|
|
|
|
sheet1[count_row,0] = poll_vote.vote_text.gsub(/<\/?.*?>/,"").gsub(/ /," ")
|
2015-06-09 17:03:28 +08:00
|
|
|
|
count_row += 1
|
|
|
|
|
end
|
|
|
|
|
count_row += 1
|
|
|
|
|
end
|
|
|
|
|
end
|
2015-06-15 15:06:58 +08:00
|
|
|
|
|
|
|
|
|
sheet1.row(count_row).default_format = blue
|
|
|
|
|
sheet1[count_row ,0] = l(:label_bidding_user_studentname)
|
|
|
|
|
poll_questions.each_with_index do |poll_question, i|
|
|
|
|
|
sheet1[count_row ,i + 1] = poll_question.question_title
|
|
|
|
|
end
|
|
|
|
|
count_row += 1
|
|
|
|
|
@poll.users.each do |user|
|
|
|
|
|
sheet1[count_row ,0] = user.show_name
|
|
|
|
|
poll_questions.each_with_index do |poll_question, i|
|
|
|
|
|
if poll_question.question_type == 1 || poll_question.question_type == 2
|
|
|
|
|
sheet1[count_row ,i + 1] = user.poll_votes.where(:poll_question_id => poll_question.id).map{|poll_vote| poll_vote.poll_answer.answer_text.gsub(/<\/?.*?>/,"").gsub(/ /," ") if poll_vote.poll_answer}.join(";")
|
|
|
|
|
else
|
|
|
|
|
sheet1[count_row ,i + 1] = user.poll_votes.where(:poll_question_id => poll_question.id).map{|poll_vote| poll_vote.vote_text.gsub(/<\/?.*?>/,"").gsub(/ /," ")}.join(";")
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
count_row += 1
|
|
|
|
|
end
|
2015-06-09 17:03:28 +08:00
|
|
|
|
book.write xls_report
|
|
|
|
|
xls_report.string
|
|
|
|
|
end
|
2015-01-12 16:56:53 +08:00
|
|
|
|
end
|