socialforge/app/controllers/poll_controller.rb

420 lines
13 KiB
Ruby
Raw Normal View History

2015-01-12 16:56:53 +08:00
class PollController < ApplicationController
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]
2015-01-12 16:56:53 +08:00
before_filter :find_container, :only => [:new,:create, :index]
before_filter :is_member_of_course, :only => [:index,:show,:poll_result]
2015-01-20 11:42:28 +08:00
before_filter :is_course_teacher, :only => [:new,:create,:edit,:update,:destroy,:publish_poll,:republish_poll]
2015-01-15 09:41:19 +08:00
include PollHelper
2015-01-12 16:56:53 +08:00
def index
if @course
@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
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]
#已提交问卷的用户不能再访问该界面
if has_commit_poll?(@poll.id,User.current.id) && (!User.current.admin?)
render_403
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)
poll_questions = @poll.poll_questions
@poll_questions = paginateHelper poll_questions,5 #分页
respond_to do |format|
format.html {render :layout => 'base_courses'}
end
end
2015-01-12 16:56:53 +08:00
end
def new
if @course
option = {
: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,
:show_result => 1,
2015-01-12 16:56:53 +08:00
:polls_description => ""
}
@poll = Poll.create option
if @poll
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
respond_to do |format|
format.html{render :layout => 'base_courses'}
end
2015-01-12 16:56:53 +08:00
end
def update
@poll.polls_name = params[:polls_name].empty? ? l(:label_poll_title) : params[:polls_name]
@poll.polls_description = params[:polls_description].empty? ? l(:label_poll_description) : params[:polls_description]
2015-01-12 16:56:53 +08:00
if @poll.save
respond_to do |format|
format.js
2015-01-12 16:56:53 +08:00
end
else
render_404
2015-01-12 16:56:53 +08:00
end
end
def destroy
if @poll && @poll.destroy
2015-01-12 16:56:53 +08:00
respond_to do |format|
format.js
end
end
end
def statistics_result
2015-01-16 10:51:08 +08:00
@poll = Poll.find(params[:id])
poll_questions = @poll.poll_questions
2015-01-16 15:49:22 +08:00
@poll_questions = paginateHelper poll_questions, 5
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-16 15:57:49 +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,
: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,
:answer_text => answer
2015-01-14 15:35:04 +08:00
}
@poll_questions.poll_answers.new question_option
end
end
if @poll_questions.save
respond_to do |format|
format.js
end
end
end
2015-01-16 15:57:49 +08:00
#修改题目
def update_poll_question
@poll_question = PollQuestion.find params[:poll_question]
#@poll = @poll_question.poll
@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|
answer.destroy unless params[:question_answer].keys.include? answer.id.to_s
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
respond_to do |format|
format.js
end
end
2015-01-16 15:57:49 +08:00
#删除题目
def delete_poll_question
@poll_question = PollQuestion.find params[:poll_question]
@poll = @poll_question.poll
poll_questions = @poll.poll_questions.where("question_number > #{@poll_question.question_number}")
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
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])
if has_commit_poll?(@poll.id,User.current.id) && (!User.current.admin?)
2015-01-16 15:32:09 +08:00
render :json => {:text => "failure"}
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-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
#显示某个学生某份问卷的填写结果
def poll_result
@poll_questions = paginateHelper @poll.poll_questions,5
respond_to do |format|
format.html{render :layout => 'base_courses'}
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
render_403 unless(@course && User.current.member_of_course?(@course))
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-01-12 16:56:53 +08:00
end