This commit is contained in:
sw 2015-07-03 10:55:53 +08:00
commit 467da8f01d
8 changed files with 226 additions and 86 deletions

View File

@ -311,6 +311,31 @@ module Mobile
present :data,news,with:Mobile::Entities::News present :data,news,with:Mobile::Entities::News
present :status,0 present :status,0
end end
desc '课程历次作业总成绩列表'
params do
requires :token,type:String
requires :course_id,type:Integer,desc:'课程id'
optional :page,type:Integer,desc:'页码'
end
get ':course_id/students_score_list' do
cs = CoursesService.new
news = cs.students_score_list params,current_user
present :data,news,with:Mobile::Entities::User
end
desc '课程某次作业提交列表 并显示成绩'
params do
requires :token,type:String
requires :course_id,type:Integer,desc:'课程id'
requires :homework_id,type:Integer,desc:'作业id'
optional :page,type:Integer,desc:'页码'
end
get ':course_id/student_works_list' do
cs = CoursesService.new
student_works = cs.student_work_list params,current_user
present :data,student_works.all,with:Mobile::Entities::StudentWork
end
end end
end end
end end

View File

@ -38,30 +38,6 @@ module Mobile
end end
end end
obj obj
elsif field == :homework_submit_num
obj = nil
c[:dynamics].each do |d|
if d[:type] == 4
obj = d[:submit_count]
end
end
obj
elsif field == :homework_submit_students
obj = nil
c[:dynamics].each do |d|
if d[:type] == 4
obj = d[:studentlist]
end
end
obj
elsif field == :homework_status
obj = nil
c[:dynamics].each do |d|
if d[:type] == 4
obj = d[:homework_status]
end
end
obj
else else
c[field] if (c.is_a?(Hash) && c.key?(field)) c[field] if (c.is_a?(Hash) && c.key?(field))
end end
@ -82,11 +58,8 @@ module Mobile
course_dynamic_expose :document_count course_dynamic_expose :document_count
course_dynamic_expose :topic_count course_dynamic_expose :topic_count
course_dynamic_expose :homework_count course_dynamic_expose :homework_count
course_dynamic_expose :homework_submit_students
course_dynamic_expose :homework_submit_num
course_dynamic_expose :homework_status
#在dynamics里解析出四种动态 #在dynamics里解析出四种动态
expose :document,using:Mobile::Entities::Attachment do |f,opt| expose :documents,using:Mobile::Entities::Attachment do |f,opt|
obj = nil obj = nil
f[:dynamics].each do |d| f[:dynamics].each do |d|
if d[:type] == 3 if d[:type] == 3
@ -95,20 +68,20 @@ module Mobile
end end
obj obj
end end
expose :topic,using:Mobile::Entities::Message do |f,opt| expose :topics,using:Mobile::Entities::Message do |f,opt|
obj = nil obj = nil
f[:dynamics].each do |d| f[:dynamics].each do |d|
if d[:type] == 2 if d[:type] == 2
obj = d[:topic] obj = d[:topics]
end end
end end
obj obj
end end
expose :homework,using:Mobile::Entities::Homework do |f,opt| expose :homeworks,using:Mobile::Entities::Homework do |f,opt|
obj = nil obj = nil
f[:dynamics].each do |d| f[:dynamics].each do |d|
if d[:type] == 4 if d[:type] == 4
obj = d[:homework] obj = d[:homeworks]
end end
end end
obj obj
@ -118,7 +91,17 @@ module Mobile
obj = nil obj = nil
f[:dynamics].each do |d| f[:dynamics].each do |d|
if d[:type] == 1 if d[:type] == 1
obj = d obj = d[:news]
end
end
obj
end
expose :better_students,using:Mobile::Entities::User do |f,opt|
obj = nil
f[:dynamics].each do |d|
if d[:type] == 6
obj = d[:better_students]
end end
end end
obj obj

View File

@ -3,6 +3,8 @@ module Mobile
module Entities module Entities
class Homework < Grape::Entity class Homework < Grape::Entity
include Redmine::I18n include Redmine::I18n
include ApplicationHelper
include ApiHelper
def self.homework_expose(field) def self.homework_expose(field)
expose field do |f,opt| expose field do |f,opt|
if f.is_a?(Hash) && f.key?(field) if f.is_a?(Hash) && f.key?(field)
@ -20,6 +22,12 @@ module Mobile
f.send(:name) f.send(:name)
when :homework_notsubmit_num when :homework_notsubmit_num
f.course.members.count - f.student_works.count f.course.members.count - f.student_works.count
when :homework_submit_num
f.student_works.count
when :homework_status
get_homework_status f
when :homework_times
f.course.homework_commons.index(f) + 1
end end
end end
end end
@ -66,11 +74,13 @@ module Mobile
f[:homework_for_anonymous_comments] if f.is_a?(Hash) && f.key?(:homework_for_anonymous_comments) f[:homework_for_anonymous_comments] if f.is_a?(Hash) && f.key?(:homework_for_anonymous_comments)
end end
homework_expose :homework_submit_num
homework_expose :homework_notsubmit_num homework_expose :homework_notsubmit_num
expose :submit_student_list ,using:Mobile::Entities::User do |f,opt| expose :submit_student_list ,using: Mobile::Entities::User do |f,opt|
f[:studentlist] get_submit_sutdent_list f
end end
homework_expose :homework_status
end end
end end

View File

@ -6,6 +6,12 @@ module Mobile
expose field do |f,opt| expose field do |f,opt|
if f.is_a?(Hash) && f.key?(field) if f.is_a?(Hash) && f.key?(field)
f[field] f[field]
elsif f.is_a?(::News)
if field == :created_on
format_time(f.send(field)) if f.respond_to?(field)
else
f.send(field) if f.respond_to?(field)
end
elsif f.is_a?(Hash) && !f.key?(field) elsif f.is_a?(Hash) && !f.key?(field)
n = f[:news] n = f[:news]
comments = f[:comments] comments = f[:comments]
@ -26,8 +32,13 @@ module Mobile
news_expose :title news_expose :title
expose :author,using: Mobile::Entities::User do |f, opt| expose :author,using: Mobile::Entities::User do |f, opt|
n = f[:author] obj = nil
#n.author if n.respond_to?(:author) if f.is_a?(::News) && f.respond_to?(:author)
obj = f.send(:author)
elsif f.is_a?(Hash) && f.key?(:author)
obj = f[:author]
end
obj
end end
#作者id #作者id
news_expose :author_id news_expose :author_id

View File

@ -0,0 +1,45 @@
module Mobile
module Entities
class StudentWork < Grape::Entity
include ApplicationHelper
include ApiHelper
def self.student_work_expose(f)
expose f do |u,opt|
if u.is_a?(Hash) && u.key?(f)
u[f]
elsif u.is_a?(::StudentWork)
if u.respond_to?(f)
if f == :created_at
format_time(u.send(:created_at))
else
u.send(f)
end
else
case f
when :student_id
u.user.user_extensions.student_id
end
end
end
end
end
expose :user, using: Mobile::Entities::User do |c, opt|
if c.is_a?(::StudentWork)
c.user
end
end
student_work_expose :student_id
student_work_expose :id
student_work_expose :name
student_work_expose :description
student_work_expose :final_score
student_work_expose :teacher_score
student_work_expose :student_score
student_work_expose :teacher_asistant_score
student_work_expose :created_at
end
end
end

View File

@ -22,6 +22,8 @@ module Mobile
get_user_location u unless u.user_extensions.nil? get_user_location u unless u.user_extensions.nil?
when :brief_introduction when :brief_introduction
u.nil? || u.user_extensions.nil? ? "" : u.user_extensions.brief_introduction u.nil? || u.user_extensions.nil? ? "" : u.user_extensions.brief_introduction
when :student_num
u.nil? || u.user_extensions.nil? ? "" : u.user_extensions.student_id
end end
end end
end end
@ -47,6 +49,10 @@ module Mobile
user_expose :location user_expose :location
#签名 #签名
user_expose :brief_introduction user_expose :brief_introduction
#总成绩
user_expose :score
#学号
user_expose :student_num
end end
end end

View File

@ -1,3 +1,4 @@
# encoding: utf-8
module ApiHelper module ApiHelper
#获取用户的工作单位 #获取用户的工作单位
def get_user_work_unit user def get_user_work_unit user
@ -64,4 +65,45 @@ module ApiHelper
def get_user_language user def get_user_language user
(user.language.nil? || user.language == "") ? 'zh':user.language (user.language.nil? || user.language == "") ? 'zh':user.language
end end
# 获取课程作业的状态
def get_homework_status homework
homework_status = ""
if !homework.nil?
if homework.homework_type == 1 && homework.homework_detail_manual
case homework.homework_detail_manual.comment_status
when 1
homework_status = show_homework_deadline homework
when 2
homework_status = "正在匿评中"
when 3
homework_status = "匿评已结束"
end
elsif homework.homework_type == 0
homework_status = "未启用匿评"
elsif homework.homework_type == 2
homework_status = "编程作业"
else
end
end
homework_status
end
#获取
def get_submit_sutdent_list homework
studentlist = []
if homework.is_a?(Hash) && homework.key?(:studentlist)
studentlist = homework[:studentlist]
else
homework.student_works.order("created_at desc").page(1).per(6).each do |work|
studentlist << work.user
end
end
studentlist
end
#计算作业的截止日期,剩余日期
def show_homework_deadline homework
"距作业截止还有" << (Date.parse(Time.now.to_s) - Date.parse(homework.end_time.to_s)).to_i.to_s << ""
end
end end

View File

@ -120,7 +120,7 @@ class CoursesService
if current_user.nil? || !(current_user.admin? || @course.is_public == 1 || (@course.is_public == 0 && current_user.member_of_course?(@course))) if current_user.nil? || !(current_user.admin? || @course.is_public == 1 || (@course.is_public == 0 && current_user.member_of_course?(@course)))
raise '403' raise '403'
end end
scope = @course ? @course.news.course_visible(current_user) : News.course_visible(current_user) scope = @course ? @course.news.order("news.created_on desc").course_visible(current_user) : News.order("news.created_on desc").course_visible(current_user)
news = [] news = []
scope.each do |n| scope.each do |n|
news << {:id => n.id,:title => n.title,:author_name => n.author.name,:author_id => n.author.id, :author=>n.author, :description => n.description,:created_on => format_time(n.created_on),:comments_count => n.comments_count} news << {:id => n.id,:title => n.title,:author_name => n.author.name,:author_id => n.author.id, :author=>n.author, :description => n.description,:created_on => format_time(n.created_on),:comments_count => n.comments_count}
@ -332,7 +332,7 @@ class CoursesService
def homework_list params,current_user def homework_list params,current_user
course = Course.find(params[:id]) course = Course.find(params[:id])
if course.is_public != 0 || current_user.member_of_course?(course) if course.is_public != 0 || current_user.member_of_course?(course)
bids = course.homework_commons.page(1).per(3).order('created_at DESC') bids = course.homework_commons.page(1).per(20).order('created_at DESC')
bids = bids.like(params[:name]) if params[:name].present? bids = bids.like(params[:name]) if params[:name].present?
homeworks = [] homeworks = []
bids.each do |bid| bids.each do |bid|
@ -667,58 +667,41 @@ class CoursesService
course = mp.course course = mp.course
latest_course_dynamics = [] latest_course_dynamics = []
dynamics_count = 0 dynamics_count = 0
# 课程学霸 学生总分数排名靠前的5个人
homework_count = course.homework_commons.count
unless homework_count == 0
sql = "select users.*,sum(IFNULL(0,student_works.final_score))/#{homework_count} score from student_works left outer join users on student_works.user_id = users.id" <<
" where homework_common_id in ( select id from homework_commons where homework_commons.course_id = #{course.id}) GROUP BY student_works.user_id ORDER BY score limit 0,6"
latest_course_dynamics <<{:type=> 6,:time=>Time.now.to_s,:count=> 6,:better_students=> User.find_by_sql(sql)}
dynamics_count += 1
end
# 课程通知 # 课程通知
latest_news = course.news.order("created_on desc").first latest_news = course.news.page(1).per(2).order("created_on desc")
unless latest_news.nil? unless latest_news.first.nil?
latest_course_dynamics << {:type => 1, :time => latest_news.created_on,:count=>course.news.count, latest_course_dynamics << {:type => 1, :time => latest_news.first.created_on,:count=>course.news.count,
:news => latest_news} :news => latest_news.all}
dynamics_count += 1 dynamics_count += 1
end end
# 课程讨论区 # 课程讨论区
latest_message = course.boards.first.topics[0] # latest_message = course.boards.first.topics.page(1).per(2)
unless latest_message.nil? # unless latest_message.first.nil?
latest_course_dynamics << {:type => 2, :time => latest_message.created_on, :count =>course.boards.nil? ? 0 : course.boards.first.topics.count, # latest_course_dynamics << {:type => 2, :time => latest_message.first.created_on, :count =>course.boards.nil? ? 0 : course.boards.first.topics.count,
:topic => latest_message} # :topics => latest_message.all}
dynamics_count += 1 # dynamics_count += 1
end # end
# 课程资源 # 课程资源
latest_attachment = course.attachments.order("created_on desc").first # latest_attachment = course.attachments.order("created_on desc").page(1).per(2)
unless latest_attachment.nil? # unless latest_attachment.first.nil?
latest_course_dynamics << {:type => 3, :time => latest_attachment.created_on,:count =>course.attachments.count , :documents=>latest_attachment} # latest_course_dynamics << {:type => 3, :time => latest_attachment.first.created_on,:count =>course.attachments.count , :documents=>latest_attachment}
dynamics_count += 1 # dynamics_count += 1
end # end
#课程作业 已经交的学生列表暂定显示6人未交的学生列表作业的状态 #课程作业 已经交的学生列表暂定显示6人未交的学生列表作业的状态
homework = course.homework_commons.order('created_at desc').first homeworks = course.homework_commons.page(1).per(2).order('created_at desc')
homework_status = ""; unless homeworks.first.nil?
# 判断作业所处的状态,如果是刚发布,就获取剩余时间 latest_course_dynamics << {:type => 4, :time => homeworks.first.updated_at, :count=>course.homework_commons.count , :homeworks => homeworks}
#如果是匿评状态,显示正在匿评
#如果是匿评结束,显示匿评结束
#获取作业提交的前6个人不足6个显示所有
studentlist = []
if !homework.nil?
if homework.homework_type == 1 && homework.homework_detail_manual
case homework.homework_detail_manual.comment_status
when 1
homework_status = show_homework_deadline homework
when 2
homework_status = "正在匿评中"
when 3
homework_status = "匿评已结束"
end
elsif homework.homework_type == 0
homework_status = "未启用匿评"
elsif homework.homework_type == 2
homework_status = "编程作业"
else
end
# 获取提交作业的前六个学生的名字 和 头像路径
homework.student_works.order("created_at desc").page(1).per(6).each do |work|
studentlist << {:image_url=> url_to_avatar(work.user),:user_name=>work.user.realname}
end
latest_course_dynamics << {:type => 4, :time => homework.updated_at, :count=>course.homework_commons.count,:submit_count => homework.student_works.count , :homework => homework, :homework_status => homework_status, :studentlist => studentlist}
dynamics_count += 1 dynamics_count += 1
end end
latest_course_dynamics.sort! { |order, newer| newer[:time] <=> order[:time] } latest_course_dynamics.sort! { |order, newer| newer[:time] <=> order[:time] }
@ -732,9 +715,44 @@ class CoursesService
result result
end end
#计算作业的截止日期,剩余日期 # 获取课程历次作业的学生总成绩
def show_homework_deadline homework def students_score_list params,current_user
"距作业截止还有" << (Date.parse(Time.now.to_s) - Date.parse(homework.end_time.to_s)).to_i.to_s << "" homework_count = Course.find(params[:course_id]).homework_commons.count
end page = (params[:page] || 1) - 1
sql = "select users.*,sum(IFNULL(0,student_works.final_score))/#{homework_count} score from student_works left outer join users on student_works.user_id = users.id" <<
" where homework_common_id in ( select id from homework_commons where homework_commons.course_id = #{params[:course_id]}) GROUP BY student_works.user_id ORDER BY score limit #{page*10},10"
User.find_by_sql(sql)
end end
# 获取某次作业的所有作业列表
def student_work_list params,current_user
is_teacher = User.current.allowed_to?(:as_teacher,Course.find(params[:course_id]))
homework = HomeworkCommon.find(params[:homework_id])
student_works = []
#老师 || 非匿评作业 || 匿评结束 显示所有的作品
show_all = is_teacher || homework.homework_type != 1 || homework.homework_detail_manual.comment_status == 3
if show_all
if homework.homework_type == 1 || is_teacher || current_user.admin?
student_works = homework.student_works.page(params[:page] || 1).per(10).order("final_score desc ")
else
my_work = homework.student_works.where(:user_id => current_user.id)
if my_work.empty?
student_works = []
else
student_works = homework.student_works.page(params[:page] || 1).per(10).order("final_score desc")
end
end
else #学生
if homework.homework_detail_manual.comment_status == 1 #未开启匿评,只显示我的作品
student_works = homework.student_works.where(:user_id => current_user.id).page(params[:page] || 1).per(10)
elsif homework.homework_detail_manual.comment_status == 2 #匿评列表,显示匿评作品和我的作品
#is_evaluation = true
my_work = homework.student_works.where(:user_id => current_user.id).page(params[:page] || 1).per(10)
student_works = my_work + current_user.student_works_evaluation_distributions.map(&:student_work).select { |work| work.homework_common_id == homework.id}
end
end
student_works
end
end