From b17d4840b11a789ad4614fa1a5995ffa581a4cd2 Mon Sep 17 00:00:00 2001
From: alan <547533434@qq.com>
Date: Thu, 25 Dec 2014 10:23:59 +0800
Subject: [PATCH 01/46] =?UTF-8?q?=E3=80=8A=E4=BD=9C=E4=B8=9A=E4=BC=98?=
=?UTF-8?q?=E5=8C=96=E3=80=8B=20Signed-off-by:=20alan=20<547533434@qq.com>?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/courses_controller.rb | 22 +++++++++++-----------
app/helpers/courses_helper.rb | 11 +++++++++--
2 files changed, 20 insertions(+), 13 deletions(-)
diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb
index ae6ad4ce3..1ec17e2cf 100644
--- a/app/controllers/courses_controller.rb
+++ b/app/controllers/courses_controller.rb
@@ -213,10 +213,10 @@ class CoursesController < ApplicationController
q = "#{params[:name].strip}"
#(redirect_to stores_url, :notice => l(:label_sumbit_empty);return) if params[:name].blank?
if params[:incourse]
- @results = searchmember_by_name(@@member_scores, q)
+ @results = searchmember_by_name(student_homework_score, q)
elsif params[:ingroup]
@group = CourseGroup.find(params[:search_group_id])
- @results = @results =searchgroupmember_by_name(@@member_scores, @group, q)
+ @results = @results =searchgroupmember_by_name(student_homework_score, @group, q)
end
@result_count = @results.count
@@ -285,7 +285,7 @@ class CoursesController < ApplicationController
member.course_group_id = group.id
member.save
@group = group
- @members = searchStudent(@course)
+
@course_groups = @course.course_groups
@membercount = @members.count
search_group_members group
@@ -298,7 +298,7 @@ class CoursesController < ApplicationController
member.save
@group = group
@course_groups = @course.course_groups
- @members = searchStudent(@course)
+
@membercount = @members.count
search_group_members group
end
@@ -309,9 +309,9 @@ class CoursesController < ApplicationController
@is_remote = true
if params[:group_id] && params[:group_id] != "0"
@group = CourseGroup.find(params[:group_id])
- @results = @@member_scores.find_all {|mem| mem.course_group_id == group.id}
+ @results = student_homework_score.find_all {|mem| mem.course_group_id == group.id}
else
- @results = @@member_scores
+ @results = student_homework_score
end
@@result = @results
@@ -336,8 +336,8 @@ class CoursesController < ApplicationController
@members = searchTeacherAndAssistant(@course)
when '2'
@subPage_title = l :label_student_list
- @@member_scores = student_homework_score
- @members = @@member_scores
+ @members = student_homework_score
+
# @member_scores = @@member_scores
# @members = searchStudent_sort(@course, 'desc', @@member_scores)
@membercount = @members.count
@@ -886,8 +886,8 @@ class CoursesController < ApplicationController
homework_scores = Member.find_by_sql("SELECT id, user_id,course_id, course_group_id,created_on,IFNULL(SUM(CASE WHEN t_score <> 0 AND t_score IS NOT NULL THEN t_score ELSE s_score END),0) as score
FROM (
SELECT members.id as id, members.user_id AS user_id, members.course_id AS course_id, members.created_on as created_on,members.course_group_id AS course_group_id,
- (SELECT AVG(seems_rateable_rates.stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (3040,4762,4765)) AS t_score,
- (SELECT AVG(seems_rateable_rates.stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (3040,4762,4765)) AS s_score
+ (SELECT AVG(seems_rateable_rates.stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers})) AS t_score,
+ (SELECT AVG(seems_rateable_rates.stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score
FROM `homework_attaches` , members
WHERE members.course_id = #{@course.id}
AND members.user_id NOT IN (#{teachers}) AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = #{@course.id})
@@ -909,7 +909,7 @@ class CoursesController < ApplicationController
@members = searchStudent(@course)
@membercount = @members.count
- @results = @@member_scores.find_all {|mem| mem.course_group_id == group.id}
+ @results = student_homework_score.find_all {|mem| mem.course_group_id == group.id}
@@result = @results
@results = paginateHelper @results
end
diff --git a/app/helpers/courses_helper.rb b/app/helpers/courses_helper.rb
index a5ae7d760..096ce7ad8 100644
--- a/app/helpers/courses_helper.rb
+++ b/app/helpers/courses_helper.rb
@@ -194,19 +194,23 @@ module CoursesHelper
def searchmember_by_name members, name
#searchPeopleByRoles(project, StudentRoles)
mems = []
- members.each do |m|
+ if name != ""
+ members.each do |m|
username = m.user[:lastname].to_s + m.user[:firstname].to_s
if(m.user[:login].to_s.include?(name) || m.user.user_extensions[:student_id].to_s.include?(name) || username.include?(name))
mems << m
end
-
+ end
+ else
+ mems = members
end
mems
end
def searchgroupmember_by_name members, name, group
#searchPeopleByRoles(project, StudentRoles)
mems = []
+ if name != ""
members.each do |m|
if m.course_group_id == group.id
username = m.user[:lastname].to_s + m.user[:firstname].to_s
@@ -215,6 +219,9 @@ module CoursesHelper
end
end
end
+ else
+ mems = members
+ end
mems
end
def searchgroupstudent_by_name(group, project, name)
From f549530744c2b02580495c5734867d81ff9fae48 Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Thu, 25 Dec 2014 17:36:53 +0800
Subject: [PATCH 02/46] =?UTF-8?q?=E5=8F=96=E6=B6=88=E8=AF=BE=E7=A8=8B?=
=?UTF-8?q?=E5=8A=A8=E6=80=81=E4=B8=AD=E6=8F=8F=E8=BF=B0=E6=98=BE=E7=A4=BA?=
=?UTF-8?q?=E4=B8=BA=E6=9C=80=E5=A4=9A30=E4=B8=AA=E5=AD=97=E6=AF=8D?=
=?UTF-8?q?=E6=88=96=E6=B1=89=E5=AD=97=E7=9A=84=E9=99=90=E5=88=B6?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/views/courses/show.html.erb | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/app/views/courses/show.html.erb b/app/views/courses/show.html.erb
index 629cac072..9f0084019 100644
--- a/app/views/courses/show.html.erb
+++ b/app/views/courses/show.html.erb
@@ -35,7 +35,7 @@
- <%= h(truncate(strip_tags(e.event_description).gsub(/ /, ' '), length: 30, omission: '...')) %>
+ <%= e.event_description %>
|
From d2aef552e6bf24a56042f851da2717384000d859 Mon Sep 17 00:00:00 2001
From: alan <547533434@qq.com>
Date: Fri, 26 Dec 2014 14:50:14 +0800
Subject: [PATCH 03/46] =?UTF-8?q?=E4=BC=98=E5=8C=96=E3=80=8A=E4=BD=9C?=
=?UTF-8?q?=E4=B8=9A=E8=AF=84=E5=88=86=E3=80=8B=20Signed-off-by:=20alan=20?=
=?UTF-8?q?<547533434@qq.com>?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/application_controller.rb | 1 +
app/controllers/courses_controller.rb | 18 ++---
app/views/courses/_member_list.html.erb | 4 +-
data/member_score.sql | 97 +++++++++++++++++++++++
4 files changed, 106 insertions(+), 14 deletions(-)
create mode 100644 data/member_score.sql
diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb
index 54346c0cc..35e034603 100644
--- a/app/controllers/application_controller.rb
+++ b/app/controllers/application_controller.rb
@@ -759,6 +759,7 @@ class ApplicationController < ActionController::Base
end
end
+
#查找首页相关信息
def find_first_page
@first_page = FirstPage.find_by_page_type('project')
diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb
index 2e28c793e..ffdd51762 100644
--- a/app/controllers/courses_controller.rb
+++ b/app/controllers/courses_controller.rb
@@ -216,7 +216,7 @@ class CoursesController < ApplicationController
@results = searchmember_by_name(student_homework_score, q)
elsif params[:ingroup]
@group = CourseGroup.find(params[:search_group_id])
- @results = @results =searchgroupmember_by_name(student_homework_score, @group, q)
+ @results =searchgroupmember_by_name(student_homework_score, @group, q)
end
@result_count = @results.count
@@ -881,17 +881,11 @@ class CoursesController < ApplicationController
end
def student_homework_score
- teachers = find_course_teachers(@course)
- homework_scores = Member.find_by_sql("SELECT id, user_id,course_id, course_group_id,created_on,IFNULL(SUM(CASE WHEN t_score <> 0 AND t_score IS NOT NULL THEN t_score ELSE s_score END),0) as score
- FROM (
- SELECT members.id as id, members.user_id AS user_id, members.course_id AS course_id, members.created_on as created_on,members.course_group_id AS course_group_id,
- (SELECT AVG(seems_rateable_rates.stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers})) AS t_score,
- (SELECT AVG(seems_rateable_rates.stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score
- FROM `homework_attaches` , members
- WHERE members.course_id = #{@course.id}
- AND members.user_id NOT IN (#{teachers}) AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = #{@course.id})
- AND homework_attaches.user_id = members.user_id
- ) AS table1 GROUP BY user_id ORDER BY score DESC")
+ #teachers = find_course_teachers(@course)
+ sql = ActiveRecord::Base.connection()
+
+ homework_scores = Member.find_by_sql("call member_score(#{@course.id})")
+ sql.close()
homework_scores
end
#获取课程的老师列表
diff --git a/app/views/courses/_member_list.html.erb b/app/views/courses/_member_list.html.erb
index 9b3a0443d..860c86ba4 100644
--- a/app/views/courses/_member_list.html.erb
+++ b/app/views/courses/_member_list.html.erb
@@ -53,7 +53,7 @@
<% members.each do |member| %>
<% else %>
diff --git a/data/member_score.sql b/data/member_score.sql
new file mode 100644
index 000000000..13858ccce
--- /dev/null
+++ b/data/member_score.sql
@@ -0,0 +1,97 @@
+
+DELIMITER $$
+
+CREATE
+ /*[DEFINER = { user | CURRENT_USER }]*/
+ PROCEDURE `member_score`(IN courseid INT)
+ /*LANGUAGE SQL
+ | [NOT] DETERMINISTIC
+ | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
+ | SQL SECURITY { DEFINER | INVOKER }
+ | COMMENT 'string'*/
+ BEGIN
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS course_teachers (
+ id INT
+
+ );
+ TRUNCATE TABLE course_teachers;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS mems (
+ id INT ,
+ user_id INT,
+ course_id INT,
+ created_on DATETIME,
+ course_group_id INT,
+ score FLOAT DEFAULT 0
+ );
+ TRUNCATE TABLE mems;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS mem_home (
+ id INT,
+ user_id INT,
+ course_id INT,
+ created_on DATETIME,
+ course_group_id INT,
+ home_id INT,
+ score FLOAT DEFAULT 0
+ );
+ TRUNCATE TABLE mem_home;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS t_scores (
+
+ home_id INT,
+ score FLOAT
+ );
+ TRUNCATE TABLE t_scores;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS s_scores (
+
+ home_id INT,
+ score FLOAT
+ );
+ TRUNCATE TABLE s_scores;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS scores (
+
+ user_id INT,
+ score FLOAT
+ );
+ TRUNCATE TABLE scores;
+
+ INSERT INTO course_teachers (SELECT members.user_id FROM members WHERE members.user_id NOT IN (SELECT student_id FROM students_for_courses WHERE course_id = courseid));
+
+ #查出所有的学生
+
+ INSERT INTO mems (id, user_id, course_id, created_on, course_group_id)
+ (SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id
+ FROM members WHERE course_id = courseid AND members.user_id NOT IN (SELECT id FROM course_teachers));
+
+ # 查出所有的学生列表及其作业
+ INSERT INTO mem_home (id, user_id, course_id, created_on, course_group_id,home_id)
+ (SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id, homework_attaches.id
+ FROM members, homework_attaches WHERE course_id = courseid
+ AND members.user_id = homework_attaches.user_id AND members.user_id NOT IN (SELECT id FROM course_teachers)
+ AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = courseid ));
+
+ INSERT INTO t_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
+ FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
+ AND rater_id IN (SELECT id FROM course_teachers)
+ GROUP BY rateable_id);
+
+ INSERT INTO s_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
+ FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
+ AND rater_id NOT IN (SELECT id FROM course_teachers)
+ GROUP BY rateable_id) ;
+
+ UPDATE mem_home, t_scores SET mem_home.score = t_scores.score WHERE mem_home.home_id = t_scores.home_id ;
+
+ UPDATE mem_home, s_scores SET mem_home.score = s_scores.score WHERE mem_home.home_id = s_scores.home_id AND mem_home.score = 0;
+
+ INSERT INTO scores (user_id, score) (SELECT user_id, SUM(score) FROM mem_home GROUP BY user_id);
+ UPDATE mems, scores SET mems.score = scores.score WHERE mems.user_id = scores.user_id;
+
+ SELECT * FROM mems ORDER BY score DESC;
+ END$$
+
+DELIMITER ;
\ No newline at end of file
From 68cadba317bf0f65019a177b0b14ca896c3e53ee Mon Sep 17 00:00:00 2001
From: z9hang
Date: Fri, 26 Dec 2014 15:35:38 +0800
Subject: [PATCH 04/46] =?UTF-8?q?#1710=20=E6=B5=8B=E8=AF=95=E7=89=88--?=
=?UTF-8?q?=E9=A1=B9=E7=9B=AE--=E4=BD=9C=E5=93=81=E4=B8=8B=E8=BD=BD?=
=?UTF-8?q?=EF=BC=9A=E9=80=89=E6=8B=A9=E4=BB=BB=E6=84=8F=E5=86=85=E5=AE=B9?=
=?UTF-8?q?=E7=B1=BB=E5=9E=8B=E3=80=81=E6=96=87=E4=BB=B6=E7=B1=BB=E5=9E=8B?=
=?UTF-8?q?=EF=BC=8C=E9=83=BD=E5=BC=B9=E5=87=BAerror=E7=9A=84=E6=8F=90?=
=?UTF-8?q?=E7=A4=BA=E6=A1=86?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/files_controller.rb | 16 +++++++++-------
1 file changed, 9 insertions(+), 7 deletions(-)
diff --git a/app/controllers/files_controller.rb b/app/controllers/files_controller.rb
index d87992ec8..56f760e13 100644
--- a/app/controllers/files_controller.rb
+++ b/app/controllers/files_controller.rb
@@ -395,16 +395,18 @@ class FilesController < ApplicationController
render :layout => 'base_courses'
}
end
+ else
+ show_attachments @containers
+ @attachtype = params[:type].to_i
+ @contenttype = params[:contentType].to_s
+
+ respond_to do |format|
+ format.js
+ format.html
+ end
end
- show_attachments @containers
- @attachtype = params[:type].to_i
- @contenttype = params[:contentType].to_s
- respond_to do |format|
- format.js
- format.html
- end
end
end
From b79b08fa8f112c6a6e2b3c7f897fcda650f40807 Mon Sep 17 00:00:00 2001
From: alan <547533434@qq.com>
Date: Fri, 26 Dec 2014 15:51:39 +0800
Subject: [PATCH 05/46] =?UTF-8?q?=E7=BC=96=E5=86=99=E3=80=8A=E4=BD=9C?=
=?UTF-8?q?=E4=B8=9A=E6=9F=A5=E8=AF=A2=E5=AD=98=E5=82=A8=E8=BF=87=E7=A8=8B?=
=?UTF-8?q?=E3=80=8B=20Signed-off-by:=20alan=20<547533434@qq.com>?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/courses_controller.rb | 8 +-
app/controllers/members_controller.rb | 4 +-
.../20141226074532_select_member_score.rb | 197 +++++++++---------
db/schema.rb | 2 +-
4 files changed, 107 insertions(+), 104 deletions(-)
rename data/member_score.sql => db/migrate/20141226074532_select_member_score.rb (59%)
diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb
index ffdd51762..d5ebb4c05 100644
--- a/app/controllers/courses_controller.rb
+++ b/app/controllers/courses_controller.rb
@@ -285,7 +285,7 @@ class CoursesController < ApplicationController
member.course_group_id = group.id
member.save
@group = group
-
+ @members = student_homework_score
@course_groups = @course.course_groups
@membercount = @members.count
search_group_members group
@@ -298,7 +298,7 @@ class CoursesController < ApplicationController
member.save
@group = group
@course_groups = @course.course_groups
-
+ @members = student_homework_score
@membercount = @members.count
search_group_members group
end
@@ -309,12 +309,12 @@ class CoursesController < ApplicationController
@is_remote = true
if params[:group_id] && params[:group_id] != "0"
@group = CourseGroup.find(params[:group_id])
- @results = student_homework_score.find_all {|mem| mem.course_group_id == group.id}
+ @results = student_homework_score.find_all {|mem| mem.course_group_id == @group.id}
else
@results = student_homework_score
end
@@result = @results
-
+
@members = searchStudent(@course)
@membercount = @members.count
@results = paginateHelper @results
diff --git a/app/controllers/members_controller.rb b/app/controllers/members_controller.rb
index 867c2a302..ce899eff5 100644
--- a/app/controllers/members_controller.rb
+++ b/app/controllers/members_controller.rb
@@ -129,7 +129,7 @@ class MembersController < ApplicationController
member = Member.new(:role_ids => params[:membership][:role_ids], :user_id => user_id)
role = Role.find_by_id(params[:membership][:role_ids])
# 这里的判断只能通过角色名,可以弄成常量
- if role.name == "学生"
+ if role.name == "学生" || role.name == "Student"
StudentsForCourse.create(:student_id => user_id, :course_id =>@course.id)
end
members << member
@@ -210,7 +210,7 @@ class MembersController < ApplicationController
if (params[:membership][:role_ids])
role = Role.find(params[:membership][:role_ids][0])
# 这里的判断只能通过角色名,可以弄成常量
- if role.name == "学生"
+ if role.name == "学生" || role.name == "Student"
StudentsForCourse.create(:student_id => @member.user_id, :course_id =>@course.id)
else
joined = StudentsForCourse.where('student_id = ? and course_id = ?', @member.user_id,@course.id)
diff --git a/data/member_score.sql b/db/migrate/20141226074532_select_member_score.rb
similarity index 59%
rename from data/member_score.sql
rename to db/migrate/20141226074532_select_member_score.rb
index 13858ccce..2303c6235 100644
--- a/data/member_score.sql
+++ b/db/migrate/20141226074532_select_member_score.rb
@@ -1,97 +1,100 @@
-
-DELIMITER $$
-
-CREATE
- /*[DEFINER = { user | CURRENT_USER }]*/
- PROCEDURE `member_score`(IN courseid INT)
- /*LANGUAGE SQL
- | [NOT] DETERMINISTIC
- | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
- | SQL SECURITY { DEFINER | INVOKER }
- | COMMENT 'string'*/
- BEGIN
-
- CREATE TEMPORARY TABLE IF NOT EXISTS course_teachers (
- id INT
-
- );
- TRUNCATE TABLE course_teachers;
-
- CREATE TEMPORARY TABLE IF NOT EXISTS mems (
- id INT ,
- user_id INT,
- course_id INT,
- created_on DATETIME,
- course_group_id INT,
- score FLOAT DEFAULT 0
- );
- TRUNCATE TABLE mems;
-
- CREATE TEMPORARY TABLE IF NOT EXISTS mem_home (
- id INT,
- user_id INT,
- course_id INT,
- created_on DATETIME,
- course_group_id INT,
- home_id INT,
- score FLOAT DEFAULT 0
- );
- TRUNCATE TABLE mem_home;
-
- CREATE TEMPORARY TABLE IF NOT EXISTS t_scores (
-
- home_id INT,
- score FLOAT
- );
- TRUNCATE TABLE t_scores;
-
- CREATE TEMPORARY TABLE IF NOT EXISTS s_scores (
-
- home_id INT,
- score FLOAT
- );
- TRUNCATE TABLE s_scores;
-
- CREATE TEMPORARY TABLE IF NOT EXISTS scores (
-
- user_id INT,
- score FLOAT
- );
- TRUNCATE TABLE scores;
-
- INSERT INTO course_teachers (SELECT members.user_id FROM members WHERE members.user_id NOT IN (SELECT student_id FROM students_for_courses WHERE course_id = courseid));
-
- #查出所有的学生
-
- INSERT INTO mems (id, user_id, course_id, created_on, course_group_id)
- (SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id
- FROM members WHERE course_id = courseid AND members.user_id NOT IN (SELECT id FROM course_teachers));
-
- # 查出所有的学生列表及其作业
- INSERT INTO mem_home (id, user_id, course_id, created_on, course_group_id,home_id)
- (SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id, homework_attaches.id
- FROM members, homework_attaches WHERE course_id = courseid
- AND members.user_id = homework_attaches.user_id AND members.user_id NOT IN (SELECT id FROM course_teachers)
- AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = courseid ));
-
- INSERT INTO t_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
- FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
- AND rater_id IN (SELECT id FROM course_teachers)
- GROUP BY rateable_id);
-
- INSERT INTO s_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
- FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
- AND rater_id NOT IN (SELECT id FROM course_teachers)
- GROUP BY rateable_id) ;
-
- UPDATE mem_home, t_scores SET mem_home.score = t_scores.score WHERE mem_home.home_id = t_scores.home_id ;
-
- UPDATE mem_home, s_scores SET mem_home.score = s_scores.score WHERE mem_home.home_id = s_scores.home_id AND mem_home.score = 0;
-
- INSERT INTO scores (user_id, score) (SELECT user_id, SUM(score) FROM mem_home GROUP BY user_id);
- UPDATE mems, scores SET mems.score = scores.score WHERE mems.user_id = scores.user_id;
-
- SELECT * FROM mems ORDER BY score DESC;
- END$$
-
-DELIMITER ;
\ No newline at end of file
+#encoding=UTF-8
+class SelectMemberScore < ActiveRecord::Migration
+ def up
+ sql = ("
+
+CREATE
+
+ PROCEDURE `member_score`(IN courseid INT)
+
+ BEGIN
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS course_teachers (
+ id INT
+
+ );
+ TRUNCATE TABLE course_teachers;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS mems (
+ id INT ,
+ user_id INT,
+ course_id INT,
+ created_on DATETIME,
+ course_group_id INT,
+ score FLOAT DEFAULT 0
+ );
+ TRUNCATE TABLE mems;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS mem_home (
+ id INT,
+ user_id INT,
+ course_id INT,
+ created_on DATETIME,
+ course_group_id INT,
+ home_id INT,
+ score FLOAT DEFAULT 0
+ );
+ TRUNCATE TABLE mem_home;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS t_scores (
+
+ home_id INT,
+ score FLOAT
+ );
+ TRUNCATE TABLE t_scores;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS s_scores (
+
+ home_id INT,
+ score FLOAT
+ );
+ TRUNCATE TABLE s_scores;
+
+ CREATE TEMPORARY TABLE IF NOT EXISTS scores (
+
+ user_id INT,
+ score FLOAT
+ );
+ TRUNCATE TABLE scores;
+
+ INSERT INTO course_teachers (SELECT members.user_id FROM members WHERE members.user_id NOT IN (SELECT student_id FROM students_for_courses WHERE course_id = courseid));
+
+
+
+ INSERT INTO mems (id, user_id, course_id, created_on, course_group_id)
+ (SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id
+ FROM members WHERE course_id = courseid AND members.user_id NOT IN (SELECT id FROM course_teachers));
+
+ INSERT INTO mem_home (id, user_id, course_id, created_on, course_group_id,home_id)
+ (SELECT members.id, members.user_id, members.course_id, members.created_on, members.course_group_id, homework_attaches.id
+ FROM members, homework_attaches WHERE course_id = courseid
+ AND members.user_id = homework_attaches.user_id AND members.user_id NOT IN (SELECT id FROM course_teachers)
+ AND homework_attaches.bid_id IN (SELECT bid_id FROM homework_for_courses WHERE course_id = courseid ));
+
+ INSERT INTO t_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
+ FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
+ AND rater_id IN (SELECT id FROM course_teachers)
+ GROUP BY rateable_id);
+
+ INSERT INTO s_scores (home_id, score) (SELECT rateable_id,AVG(seems_rateable_rates.stars)
+ FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id IN (SELECT mem_home.home_id FROM mem_home)
+ AND rater_id NOT IN (SELECT id FROM course_teachers)
+ GROUP BY rateable_id) ;
+
+ UPDATE mem_home, t_scores SET mem_home.score = t_scores.score WHERE mem_home.home_id = t_scores.home_id ;
+
+ UPDATE mem_home, s_scores SET mem_home.score = s_scores.score WHERE mem_home.home_id = s_scores.home_id AND mem_home.score = 0;
+
+ INSERT INTO scores (user_id, score) (SELECT user_id, SUM(score) FROM mem_home GROUP BY user_id);
+ UPDATE mems, scores SET mems.score = scores.score WHERE mems.user_id = scores.user_id;
+
+ SELECT * FROM mems ORDER BY score DESC;
+ END;
+
+ ")
+ execute(sql)
+ end
+
+ def down
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index a75c6eb29..f850e759e 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -11,7 +11,7 @@
#
# It's strongly recommended to check this file into your version control system.
-ActiveRecord::Schema.define(:version => 20141210070327) do
+ActiveRecord::Schema.define(:version => 20141226074532) do
create_table "activities", :force => true do |t|
t.integer "act_id", :null => false
From 329be27567837bca6e3d3e71ac0700ba34f47afb Mon Sep 17 00:00:00 2001
From: alan <547533434@qq.com>
Date: Fri, 26 Dec 2014 17:31:01 +0800
Subject: [PATCH 06/46] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E3=80=8A=E5=88=86?=
=?UTF-8?q?=E7=8F=AD=E6=9F=A5=E8=AF=A2=E3=80=8B=20Signed-off-by:=20alan=20?=
=?UTF-8?q?<547533434@qq.com>?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/courses_controller.rb | 33 +++++++++++----------
app/views/courses/_member_list.html.erb | 6 ++--
app/views/courses/_searchmembers.html.erb | 11 +++++++
app/views/courses/member.html.erb | 16 ++--------
app/views/courses/searchgroupmembers.js.erb | 1 +
5 files changed, 36 insertions(+), 31 deletions(-)
create mode 100644 app/views/courses/_searchmembers.html.erb
diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb
index d5ebb4c05..61bce8b36 100644
--- a/app/controllers/courses_controller.rb
+++ b/app/controllers/courses_controller.rb
@@ -218,7 +218,7 @@ class CoursesController < ApplicationController
@group = CourseGroup.find(params[:search_group_id])
@results =searchgroupmember_by_name(student_homework_score, @group, q)
end
-
+ @is_remote = true
@result_count = @results.count
@results = paginateHelper @results
@@ -313,7 +313,7 @@ class CoursesController < ApplicationController
else
@results = student_homework_score
end
- @@result = @results
+
@members = searchStudent(@course)
@membercount = @members.count
@@ -328,6 +328,7 @@ class CoursesController < ApplicationController
@teachers= searchTeacherAndAssistant(@course)
@canShowCode = isCourseTeacher(User.current.id,@course) && params[:role] != '1'
@role = params[:role]
+ @is_remote = false
@course_groups = @course.course_groups if @course.course_groups
@show_serch = params[:role] == '2'
case params[:role]
@@ -346,7 +347,7 @@ class CoursesController < ApplicationController
@subPage_title = ''
@members = @course.member_principals.includes(:roles, :principal).all.sort
end
- @@result = @members
+
@members = paginateHelper @members
render :layout => 'base_courses'
else
@@ -356,19 +357,19 @@ class CoursesController < ApplicationController
end
def member_score_sort
- @teachers= searchTeacherAndAssistant(@course)
- @canShowCode = isCourseTeacher(User.current.id,@course) && params[:role] != '1'
- @role = params[:role]
- @course_groups = @course.course_groups if @course.course_groups
- @show_serch = params[:role] == '2'
- @subPage_title = l :label_student_list
- @render_file = 'member_list'
-
- unless @@result.nil?
- @results = @@result.reverse
- @@result = @results
- end
- @results = paginateHelper @results
+ # @teachers= searchTeacherAndAssistant(@course)
+ # @canShowCode = isCourseTeacher(User.current.id,@course) && params[:role] != '1'
+ # @role = params[:role]
+ # @course_groups = @course.course_groups if @course.course_groups
+ # @show_serch = params[:role] == '2'
+ # @subPage_title = l :label_student_list
+ # @render_file = 'member_list'
+ # @results = params[:result] if params[:result]
+ # unless @result.nil?
+ # @results = @result.reverse
+ #
+ # end
+ # @results = paginateHelper @results
end
# 显示每个学生的作业评分详情
def show_member_score
diff --git a/app/views/courses/_member_list.html.erb b/app/views/courses/_member_list.html.erb
index 860c86ba4..7e6407aa5 100644
--- a/app/views/courses/_member_list.html.erb
+++ b/app/views/courses/_member_list.html.erb
@@ -3,9 +3,11 @@
var classname = document.getElementById(id).className
if(classname == 'st_up') {
document.getElementById(id).className = 'st_down'
+
}
else
document.getElementById(id).className = 'st_up'
+
}
@@ -34,7 +36,7 @@
<% if @subPage_title == l(:label_student_list) %>
- - <%= link_to '作业积分', member_score_sort_course_path ,method: 'get', remote: true, :onclick => "change_pic('pic')"%>
+
- <%= link_to '作业积分', member_score_sort_course_path ,:result => members,method: 'get', remote: true, :onclick => "change_pic('pic')"%>
-
@@ -101,7 +103,7 @@
<% else %>
diff --git a/app/views/courses/_searchmembers.html.erb b/app/views/courses/_searchmembers.html.erb
new file mode 100644
index 000000000..426c52ca5
--- /dev/null
+++ b/app/views/courses/_searchmembers.html.erb
@@ -0,0 +1,11 @@
+<% if @subPage_title && @subPage_title == l(:label_student_list)%>
+ <%= form_tag( searchmembers_course_path(@course), method: 'get',:class => "f_l",:style => "margin-left: 5px; ",:remote=>true) do %>
+ <%= text_field_tag 'name', params[:name], name: "name", :class => 'f_1', :style => "height:15px; float: left;"%>
+ <% if @group %>
+ <%= hidden_field "search_group_id", params[:search_group_id],:value => "#{@group.id}", name: 'search_group_id' %>
+ <%= submit_tag l(:label_search_member), :name => "ingroup",:class => "f_2", :style => "float: left "%>
+ <% else %>
+ <%= submit_tag l(:label_search_member),:style => "float: left", :name => 'incourse',:onclick => "checkclass('group_name_0')",:class => "f_2"%>
+ <% end %>
+ <% end %>
+<% end %>
\ No newline at end of file
diff --git a/app/views/courses/member.html.erb b/app/views/courses/member.html.erb
index 91d8badcc..313e50748 100644
--- a/app/views/courses/member.html.erb
+++ b/app/views/courses/member.html.erb
@@ -57,20 +57,10 @@
<%= stylesheet_link_tag 'course_group', :media => 'all' %>
-
+
<%= @subPage_title %>
-
- <% if @subPage_title && @subPage_title == l(:label_student_list)%>
- <%= form_tag( searchmembers_course_path(@course), method: 'get',:class => "f_l",:style => "margin-left: 5px; ",:remote=>true) do %>
- <%= text_field_tag 'name', params[:name], name: "name", :class => 'f_1', :style => "height:15px; float: left;"%>
- <% if @group %>
- <%= hidden_field "search_group_id", params[:search_group_id],:value => "#{@group.id}", name: 'search_group_id' %>
- <%= submit_tag l(:label_search_member), :name => "ingroup",:class => "f_2", :style => "float: left "%>
- <% else %>
- <%= submit_tag l(:label_search_member),:style => "float: left", :name => 'incourse',:onclick => "checkclass('group_name_0')",:class => "f_2"%>
- <% end %>
- <% end %>
- <% end %>
+
+ <%= render :partial => 'searchmembers' %>
diff --git a/app/views/courses/searchgroupmembers.js.erb b/app/views/courses/searchgroupmembers.js.erb
index c6ff97164..5e88de865 100644
--- a/app/views/courses/searchgroupmembers.js.erb
+++ b/app/views/courses/searchgroupmembers.js.erb
@@ -1,4 +1,5 @@
/**
* Created by Administrator on 2014/12/3.
*/
+$("#search_members").html("<%= escape_javascript( render :partial => 'searchmembers')%>");
$("#member_content").html("<%= escape_javascript( render :partial => @render_file, :locals => {:members => @results})%>");
\ No newline at end of file
From afbcc3f8d3f10fe8ccdb98ea298dd547cfaf4ce8 Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Mon, 29 Dec 2014 10:42:48 +0800
Subject: [PATCH 07/46] =?UTF-8?q?1.#1742=20=E9=A6=96=E6=AC=A1=E5=8A=A0?=
=?UTF-8?q?=E8=BD=BD=E8=AF=BE=E7=A8=8B=E5=AE=9E=E8=B7=B5=E5=B9=B3=E5=8F=B0?=
=?UTF-8?q?=E4=B8=BB=E9=A1=B5=E6=97=B6=EF=BC=8C=E7=82=B9=E5=87=BB=E2=80=9C?=
=?UTF-8?q?=E5=8A=A0=E5=85=A5=E8=AF=BE=E7=A8=8B=E2=80=9D=E5=BF=AB=E6=8D=B7?=
=?UTF-8?q?=E9=80=9A=E9=81=93=EF=BC=8C=E8=AF=BE=E7=A8=8BID=E9=BB=98?=
=?UTF-8?q?=E8=AE=A4=E6=98=AF=E5=BD=93=E5=89=8D=E7=99=BB=E5=BD=95=E7=94=A8?=
=?UTF-8?q?=E6=88=B7=E5=90=8D=EF=BC=8C=E5=8F=A3=E4=BB=A4=E9=BB=98=E8=AE=A4?=
=?UTF-8?q?=E4=B8=BA=E5=BD=93=E5=89=8D=E7=99=BB=E5=BD=95=E7=94=A8=E6=88=B7?=
=?UTF-8?q?=E5=AF=86=E7=A0=81=202.=E4=BF=AE=E6=94=B9=E5=8A=A0=E5=85=A5?=
=?UTF-8?q?=E8=AF=BE=E7=A8=8B=E5=BC=B9=E5=87=BA=E6=A1=86=E6=A0=B7=E5=BC=8F?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../courses/_join_private_course.html.erb | 18 +++++++++++----
app/views/courses/join_private_courses.js.erb | 8 ++++++-
app/views/welcome/course.html.erb | 22 ++++++++++++++-----
3 files changed, 38 insertions(+), 10 deletions(-)
diff --git a/app/views/courses/_join_private_course.html.erb b/app/views/courses/_join_private_course.html.erb
index e3e75b9d7..343e7252a 100644
--- a/app/views/courses/_join_private_course.html.erb
+++ b/app/views/courses/_join_private_course.html.erb
@@ -13,7 +13,7 @@
a{ text-decoration:none; }
a:hover{ }
-
+ .alert_box {width:488px;height:550px;position:fixed;z-index:1002;left:50%;top:40%;margin:-215px 0 0 -300px; background:#fff; -moz-border-radius:5px; -webkit-border-radius:5px; border-radius:5px; box-shadow:0px 0px 8px #194a81; padding:5px; overflow:auto; }
#popbox{width:488px;height:308px;}
.alert .C{width:476px;height:296px;position:absolute;left:5px;top:5px; }
.C_top{ margin-top:20px; width:368px; height:100px; background:#e9e9e9; padding:0px 60px; }
@@ -21,7 +21,7 @@
.C_top p{ color:#a9aaaa; line-height:22px;}
.C_form{ margin:20px 0 0 60px;}
.C_form ul li{ font-size:14px; color:#3f3a39; line-height:30px; }
- .C_form ul li input{ margin-left:30px; border:0px; border:1px solid #e1e1e1; color:#898989; padding-left:5px; -moz-border-radius:5px; -webkit-border-radius:5px; border-radius:5px; }
+ .C_form ul li input{ margin-left:20px; border:0px; border:1px solid #e1e1e1; color:#898989; padding-left:5px; -moz-border-radius:5px; -webkit-border-radius:5px; border-radius:5px; padding: 0 !important; }
.C_form ul li.mB5{ color:#898989; font-size:12px; padding-left:90px;}
.width190{ width:190px; height:26px; border-color:#e1e1e1;}
.C_form a{ font-size:12px; color:#15bccf; float:left; display:block; height:40px; width:200px; margin-top:25px;}
@@ -35,6 +35,11 @@
hideModal(obj);
$("#new-watcher-form").submit();
}
+
+ function hidden_join_course_form()
+ {
+ hideModal($("#popbox"));
+ }
@@ -55,6 +60,7 @@
课 程 ID:
+
课程ID是所在课程网址中显示的序号
@@ -62,8 +68,12 @@
- <%= l(:label_new_join) %>
- <%= l(:button_cancel)%>
+
+ <%= l(:label_new_join) %>
+
+
+ <%= l(:button_cancel)%>
+
<% end%>
diff --git a/app/views/courses/join_private_courses.js.erb b/app/views/courses/join_private_courses.js.erb
index 0cf723f6b..254311ce7 100644
--- a/app/views/courses/join_private_courses.js.erb
+++ b/app/views/courses/join_private_courses.js.erb
@@ -1,3 +1,9 @@
$('#ajax-modal').html('<%= escape_javascript(render :partial => 'join_private_course') %>');
showModal('ajax-modal', '510px');
-$('#ajax-modal').css('height','330px');
\ No newline at end of file
+$('#ajax-modal').css('height','330px');
+$('#ajax-modal').siblings().remove();
+$('#ajax-modal').before("
" +
+ "
");
+$('#ajax-modal').parent().removeClass("alert_praise");
+$('#ajax-modal').parent().css("top","").css("left","");
+$('#ajax-modal').parent().addClass("alert_box");
diff --git a/app/views/welcome/course.html.erb b/app/views/welcome/course.html.erb
index 5886f0525..47433b30d 100644
--- a/app/views/welcome/course.html.erb
+++ b/app/views/welcome/course.html.erb
@@ -55,13 +55,19 @@
<% end %>
<% unless @course_page.nil? %>
-
<%= @course_page.title %>
+
+ <%= @course_page.title %>
+
<% if @school_id.nil? and (User.current.user_extensions.nil? || User.current.user_extensions.school.nil?) %>
-
, <%= @course_page.description %>
+
,
+ <%= @course_page.description %>
+
<% else %>
<% if @school_id == "0" %>
-
, <%= @course_page.description %>
+
,
+ <%= @course_page.description %>
+
<% end %>
<% end %>
<% end %>
@@ -77,7 +83,11 @@
-
<%= l(:lable_hot_course)%>
+
+
+ <%= l(:lable_hot_course)%>
+
+
<% month_now = Time.now.strftime("%m").to_i %>
<% year_now = Time.new.strftime("%Y") %>
@@ -86,7 +96,9 @@
<% @school_id.nil? ? cur_school_course = [] : cur_school_course = find_miracle_course(10,7,@school_id, year_now, course_term) %>
<% if cur_school_course.count == 0 %>
-
<%= render :partial => 'more_course', :locals => {:school_id => nil}%>
+
+ <%= render :partial => 'more_course', :locals => {:school_id => nil}%>
+
<% if User.current.logged? %>
From fa36e6d2b0565c76a22fb29a7728f79a54692cb1 Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Mon, 29 Dec 2014 10:58:45 +0800
Subject: [PATCH 08/46] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E5=88=A4=E6=96=AD?=
=?UTF-8?q?=E8=AF=84=E5=88=86=E6=98=AF=E4=B8=8D=E6=98=AF=E8=80=81=E5=B8=88?=
=?UTF-8?q?=E8=AF=84=E5=88=86=E7=9A=84=E5=88=97?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...0141229025519_add_colum_to_seems_rateable_rates.rb | 5 +++++
db/schema.rb | 11 ++++++-----
2 files changed, 11 insertions(+), 5 deletions(-)
create mode 100644 db/migrate/20141229025519_add_colum_to_seems_rateable_rates.rb
diff --git a/db/migrate/20141229025519_add_colum_to_seems_rateable_rates.rb b/db/migrate/20141229025519_add_colum_to_seems_rateable_rates.rb
new file mode 100644
index 000000000..29a9a671c
--- /dev/null
+++ b/db/migrate/20141229025519_add_colum_to_seems_rateable_rates.rb
@@ -0,0 +1,5 @@
+class AddColumToSeemsRateableRates < ActiveRecord::Migration
+ def change
+ add_column :seems_rateable_rates, :is_teacher_score, :integer, default: 0
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index a75c6eb29..e109212cc 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -11,7 +11,7 @@
#
# It's strongly recommended to check this file into your version control system.
-ActiveRecord::Schema.define(:version => 20141210070327) do
+ActiveRecord::Schema.define(:version => 20141229025519) do
create_table "activities", :force => true do |t|
t.integer "act_id", :null => false
@@ -977,13 +977,14 @@ ActiveRecord::Schema.define(:version => 20141210070327) do
end
create_table "seems_rateable_rates", :force => true do |t|
- t.integer "rater_id", :limit => 8
+ t.integer "rater_id", :limit => 8
t.integer "rateable_id"
t.string "rateable_type"
- t.float "stars", :null => false
+ t.float "stars", :null => false
t.string "dimension"
- t.datetime "created_at", :null => false
- t.datetime "updated_at", :null => false
+ t.datetime "created_at", :null => false
+ t.datetime "updated_at", :null => false
+ t.integer "is_teacher_score", :default => 0
end
create_table "settings", :force => true do |t|
From 259799eb89366bcb3f89d3e8badb91f202363b95 Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Mon, 29 Dec 2014 11:38:35 +0800
Subject: [PATCH 09/46] =?UTF-8?q?1.=E5=A2=9E=E5=8A=A0=E8=AF=84=E5=88=86?=
=?UTF-8?q?=E7=9A=84model=202.=E4=BF=AE=E6=94=B9=E8=AF=84=E5=88=86?=
=?UTF-8?q?=E8=A1=A8=E4=B8=AD=E4=B8=BA=E6=95=99=E5=B8=88=E8=AF=84=E5=88=86?=
=?UTF-8?q?=E7=9A=84=E5=8E=86=E5=8F=B2=E6=95=B0=E6=8D=AE=E7=9A=84is=5Fteac?=
=?UTF-8?q?her=5Fscore=E7=9A=84=E5=80=BC?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/models/seems_rateable_rates.rb | 3 +++
...41229025925_change_seems_rateable_rates.rb | 23 +++++++++++++++++++
db/schema.rb | 2 +-
3 files changed, 27 insertions(+), 1 deletion(-)
create mode 100644 app/models/seems_rateable_rates.rb
create mode 100644 db/migrate/20141229025925_change_seems_rateable_rates.rb
diff --git a/app/models/seems_rateable_rates.rb b/app/models/seems_rateable_rates.rb
new file mode 100644
index 000000000..664f987ba
--- /dev/null
+++ b/app/models/seems_rateable_rates.rb
@@ -0,0 +1,3 @@
+class SeemsRateableRates < ActiveRecord::Base
+ attr_accessible :rater_id, :rateable_id, :rateable_type, :stars, :dimension, :is_teacher_score
+end
diff --git a/db/migrate/20141229025925_change_seems_rateable_rates.rb b/db/migrate/20141229025925_change_seems_rateable_rates.rb
new file mode 100644
index 000000000..9ea75e68e
--- /dev/null
+++ b/db/migrate/20141229025925_change_seems_rateable_rates.rb
@@ -0,0 +1,23 @@
+class ChangeSeemsRateableRates < ActiveRecord::Migration
+ def up
+ SeemsRateableRates.where("rateable_type = 'HomeworkAttach'").each do |rate|
+ homework = HomeworkAttach.find_by_id rate.rateable_id
+ if homework
+ course = homework.bid.courses.first
+ if course
+ teachers = []
+ course.members.each do |m|
+ teachers << m.user_id if m && m.user && m.user.allowed_to?(:as_teacher,course)
+ end
+ if teachers.include?(rate.rater_id)
+ rate.is_teacher_score = 1
+ rate.save
+ end
+ end
+ end
+ end
+ end
+
+ def down
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index e109212cc..5725d8221 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -11,7 +11,7 @@
#
# It's strongly recommended to check this file into your version control system.
-ActiveRecord::Schema.define(:version => 20141229025519) do
+ActiveRecord::Schema.define(:version => 20141229025925) do
create_table "activities", :force => true do |t|
t.integer "act_id", :null => false
From 0a58fce2515cf0e1f10efcd7d7c03c1bd2295a8a Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Mon, 29 Dec 2014 11:53:26 +0800
Subject: [PATCH 10/46] =?UTF-8?q?=E4=BC=98=E5=8C=96=E6=95=B0=E6=8D=AE?=
=?UTF-8?q?=E8=BF=81=E7=A7=BB=E6=95=88=E7=8E=87?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
...41229025925_change_seems_rateable_rates.rb | 30 +++++++++++--------
1 file changed, 17 insertions(+), 13 deletions(-)
diff --git a/db/migrate/20141229025925_change_seems_rateable_rates.rb b/db/migrate/20141229025925_change_seems_rateable_rates.rb
index 9ea75e68e..7be2a81fe 100644
--- a/db/migrate/20141229025925_change_seems_rateable_rates.rb
+++ b/db/migrate/20141229025925_change_seems_rateable_rates.rb
@@ -1,23 +1,27 @@
class ChangeSeemsRateableRates < ActiveRecord::Migration
def up
- SeemsRateableRates.where("rateable_type = 'HomeworkAttach'").each do |rate|
- homework = HomeworkAttach.find_by_id rate.rateable_id
- if homework
- course = homework.bid.courses.first
- if course
- teachers = []
- course.members.each do |m|
- teachers << m.user_id if m && m.user && m.user.allowed_to?(:as_teacher,course)
- end
- if teachers.include?(rate.rater_id)
- rate.is_teacher_score = 1
- rate.save
+ Course.all.each do |course|
+ teachers = []
+ course.members.each do |m|
+ teachers << m.user_id if m && m.user && m.user.allowed_to?(:as_teacher,course)
+ end
+ course.homeworks.each do |bid|
+ bid.homeworks.each do |homework|
+ SeemsRateableRates.where("rateable_type = 'HomeworkAttach' and rateable_id = #{homework.id}").each do |rate|
+ if teachers.include?(rate.rater_id)
+ rate.is_teacher_score = 1
+ rate.save
+ end
+ end
end
end
end
- end
end
def down
+ SeemsRateableRates.where("is_teacher_score = 1").each do |rate|
+ rate.is_teacher_score = 0
+ rate.save
+ end
end
end
From 3f6b36096c33cdf581a3778b32d7847b84f7a760 Mon Sep 17 00:00:00 2001
From: z9hang
Date: Mon, 29 Dec 2014 11:54:31 +0800
Subject: [PATCH 11/46] =?UTF-8?q?=E7=BC=BA=E9=99=B7=E6=9F=A5=E8=AF=A2?=
=?UTF-8?q?=E6=B7=BB=E5=8A=A0integer=5Fdone=E7=B1=BB=E5=9E=8B=E5=A4=84?=
=?UTF-8?q?=E7=90=86=EF=BC=88=E6=9A=82=E6=9C=AA=E7=94=A8=E4=B8=8A=EF=BC=89?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/models/query.rb | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/app/models/query.rb b/app/models/query.rb
index 550047c57..19bd1bed5 100644
--- a/app/models/query.rb
+++ b/app/models/query.rb
@@ -173,6 +173,7 @@ class Query < ActiveRecord::Base
:string => [ "=", "~", "!", "!~", "!*", "*" ],
:text => [ "~", "!~", "!*", "*" ],
:integer => [ "=", ">=", "<=", "><", "!*", "*" ],
+ :integer_done => [ "=", ">=", "<=", "><", "!*", "*" ],
:float => [ "=", ">=", "<=", "><", "!*", "*" ],
:relation => ["=", "=p", "=!p", "!p", "!*", "*"]
}
@@ -217,6 +218,8 @@ class Query < ActiveRecord::Base
case type_for(field)
when :integer
add_filter_error(field, :invalid) if values_for(field).detect {|v| v.present? && !v.match(/^[+-]?\d+$/) }
+ when :integer_done
+ add_filter_error(field, :invalid) if values_for(field).detect {|v| v.present? && !v.match(/^[+-]?\d+$/) || (v.match(/^[+-]?\d+$/) && (v.to_i<0 || v.to_i> 100)) }
when :float
add_filter_error(field, :invalid) if values_for(field).detect {|v| v.present? && !v.match(/^[+-]?\d+(\.\d*)?$/) }
when :date, :date_past
@@ -602,6 +605,12 @@ class Query < ActiveRecord::Base
else
sql = "#{db_table}.#{db_field} = #{value.first.to_i}"
end
+ when :integer_done
+ if is_custom_filter
+ sql = "(#{db_table}.#{db_field} <> '' AND CAST(CASE #{db_table}.#{db_field} WHEN '' THEN '0' ELSE #{db_table}.#{db_field} END AS decimal(30,3)) = #{value.first.to_i})"
+ else
+ sql = "#{db_table}.#{db_field} = #{value.first.to_i}"
+ end
when :float
if is_custom_filter
sql = "(#{db_table}.#{db_field} <> '' AND CAST(CASE #{db_table}.#{db_field} WHEN '' THEN '0' ELSE #{db_table}.#{db_field} END AS decimal(30,3)) BETWEEN #{value.first.to_f - 1e-5} AND #{value.first.to_f + 1e-5})"
From aa06251fd3969ed3bec3af0a26d3e17bff6449d5 Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Mon, 29 Dec 2014 16:03:21 +0800
Subject: [PATCH 12/46] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E5=BD=93=E7=94=A8?=
=?UTF-8?q?=E6=88=B7=E8=A7=92=E8=89=B2=E6=94=B9=E5=8F=98=E6=97=B6=EF=BC=8C?=
=?UTF-8?q?=E8=AF=A5=E7=94=A8=E6=88=B7=E8=AF=84=E5=88=86=E6=89=80=E5=B1=9E?=
=?UTF-8?q?=E8=A7=92=E8=89=B2=E4=B9=9F=E8=B7=9F=E7=9D=80=E6=94=B9=E5=8F=98?=
=?UTF-8?q?=E7=9A=84BUG?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/bids_controller.rb | 28 ++-----
app/controllers/homework_attach_controller.rb | 74 +++++++++----------
2 files changed, 42 insertions(+), 60 deletions(-)
diff --git a/app/controllers/bids_controller.rb b/app/controllers/bids_controller.rb
index 2997f4205..eaeca0e46 100644
--- a/app/controllers/bids_controller.rb
+++ b/app/controllers/bids_controller.rb
@@ -492,26 +492,17 @@ class BidsController < ApplicationController
if @bid.homework_type
@homework = HomeworkAttach.new
@is_teacher = is_course_teacher(User.current,@bid.courses.first)
- teachers = "("
- teacher_members = searchTeacherAndAssistant(@bid.courses.first)
- teacher_members.each do |member|
- if member == teacher_members.last
- teachers += member.user_id.to_s + ")"
- else
- teachers += member.user_id.to_s + ","
- end
- end
if @is_teacher
all_homework_list = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT * FROM (SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN #{teachers}) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN #{teachers}) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches WHERE bid_id = #{@bid.id} ORDER BY s_score DESC,created_at ASC) AS table1
WHERE table1.t_score IS NULL")
@cur_type = 1
else
all_homework_list = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN #{teachers}) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN #{teachers}) AS s_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score,
(SELECT stars FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id = #{User.current.id}) AS m_score
FROM homework_attaches
INNER JOIN homework_evaluations ON homework_evaluations.homework_attach_id = homework_attaches.id
@@ -1056,17 +1047,8 @@ class BidsController < ApplicationController
elsif @bid.comment_status == 1
@totle_size = 0
@bid.homeworks.map { |homework| @totle_size += homework.homework_evaluations.count}
- teachers = "("
- teacher_members = searchTeacherAndAssistant(@course)
- teacher_members.each do |member|
- if member == teacher_members.last
- teachers += member.user_id.to_s + ")"
- else
- teachers += member.user_id.to_s + ","
- end
- end
@cur_size = 0
- @bid.homeworks.map { |homework| @cur_size += homework.rates(:quality).where("seems_rateable_rates.rater_id not in #{teachers}").count}
+ @bid.homeworks.map { |homework| @cur_size += homework.rates(:quality).where("seems_rateable_rates.rater_id is_teacher_score = 0").count}
end
@percent = format("%.2f",(@cur_size.to_f / ( @totle_size == 0 ? 1 : @totle_size)) * 100)
respond_to do |format|
diff --git a/app/controllers/homework_attach_controller.rb b/app/controllers/homework_attach_controller.rb
index 5c4542944..fedc99030 100644
--- a/app/controllers/homework_attach_controller.rb
+++ b/app/controllers/homework_attach_controller.rb
@@ -22,8 +22,7 @@ class HomeworkAttachController < ApplicationController
#获取未批作业列表
def get_not_batch_homework
sort, direction = params[:sort] || "s_socre", params[:direction] || "desc"
- teachers = find_course_teachers @course
- get_not_batch_homework_list sort,direction,teachers, @bid.id
+ get_not_batch_homework_list sort,direction, @bid.id
@cur_page = params[:page] || 1
@cur_type = 1
@direction = direction == 'asc'? 'desc' : 'asc'
@@ -42,10 +41,9 @@ class HomeworkAttachController < ApplicationController
elsif sort == 'time'
order_by = "created_at #{direction}"
end
- teachers = find_course_teachers @course
all_homework_list = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT * FROM (SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers}) and stars IS NOT NULL) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1 and stars IS NOT NULL) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches WHERE bid_id = #{@bid.id}
ORDER BY #{order_by}) AS table1
WHERE table1.t_score IS NOT NULL")
@@ -68,10 +66,9 @@ class HomeworkAttachController < ApplicationController
elsif sort == 'time'
order_by = "created_at #{direction}"
end
- teachers = find_course_teachers @course
all_homework_list = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id in (#{teachers})) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id not in (#{teachers})) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches WHERE bid_id = #{@bid.id}
ORDER BY #{order_by}")
@cur_page = params[:page] || 1
@@ -86,10 +83,9 @@ class HomeworkAttachController < ApplicationController
#获取学生匿评列表
def get_student_batch_homework
@is_student_batch_homework = true
- teachers = find_course_teachers @course
all_homework_list = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers})) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score,
(SELECT stars FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id = #{User.current.id}) AS m_score
FROM homework_attaches
INNER JOIN homework_evaluations ON homework_evaluations.homework_attach_id = homework_attaches.id
@@ -105,17 +101,16 @@ class HomeworkAttachController < ApplicationController
#获取我的作业
def get_my_homework
@is_my_homework = true
- teachers = find_course_teachers @course
all_homework_list = HomeworkAttach.find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers})) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches
WHERE homework_attaches.bid_id = #{@bid.id} AND homework_attaches.user_id = #{User.current.id}")
#如果我没有创建过作业,就检索我是否参与了某个作业
if all_homework_list.empty?
all_homework_list = HomeworkAttach.find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers})) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches
INNER JOIN homework_users ON homework_users.homework_attach_id = homework_attaches.id
WHERE homework_attaches.bid_id = #{@bid.id} AND homework_users.user_id = #{User.current.id}")
@@ -360,9 +355,8 @@ class HomeworkAttachController < ApplicationController
#我的评分
@has_evaluation = @stars_reates.where("rater_id = #{User.current.id}").first
@m_score = @has_evaluation.nil? ? 0 : @has_evaluation.stars
- teachers = find_course_teachers(@course)
- @teacher_stars = @stars_reates.where("rater_id in (#{teachers})") #老师评分列表
- @student_stars = @stars_reates.where("rater_id not in (#{teachers})") #学生评分列表
+ @teacher_stars = @stars_reates.where("is_teacher_score = 1") #老师评分列表
+ @student_stars = @stars_reates.where("is_teacher_score = 0") #学生评分列表
@is_teacher = is_course_teacher User.current,@course
@is_anonymous_comments = @bid.comment_status == 1 && !@homework.users.include?(User.current) && @homework.user != User.current && !@is_teacher #判断是不是匿评(开启匿评,当前用户不是作业的创建者或者参与者,不是老师)
jours = @homework.journals_for_messages.where("is_comprehensive_evaluation = 3 or is_comprehensive_evaluation is null").order("created_on DESC")#jours留言 is null条件用以兼容历史数据
@@ -385,10 +379,9 @@ class HomeworkAttachController < ApplicationController
@journal_destroyed = JournalsForMessage.find(params[:object_id])
if @journal_destroyed.is_comprehensive_evaluation == 3 && @journal_destroyed.destroy
render_403 unless User.current == @journal_destroyed.user || User.current.admin?
- teachers = find_course_teachers(@homework.bid.courses.first)
@stars_reates = @homework.rates(:quality)
- @teacher_stars = @stars_reates.where("rater_id in (#{teachers})") #老师评分列表
- @student_stars = @stars_reates.where("rater_id not in (#{teachers})") #学生评分列表
+ @teacher_stars = @stars_reates.where("is_teacher_score = 1)") #老师评分列表
+ @student_stars = @stars_reates.where("is_teacher_score = 0") #学生评分列表
jours = @homework.journals_for_messages.where("is_comprehensive_evaluation = 3 or is_comprehensive_evaluation is null").order("created_on DESC")#jours留言 is null条件用以兼容历史数据
@jour = paginateHelper jours,5 #留言
else
@@ -426,39 +419,46 @@ class HomeworkAttachController < ApplicationController
@cur_page,@cur_type = params[:cur_page] || 1,params[:cur_type] || 5
@homework = HomeworkAttach.find(params[:homework_id])
- #保存评分
- @homework.rate(@m_score.to_i,User.current.id,:quality) if @m_score
+ #保存评分@homework.rate(@m_score.to_i,User.current.id,:quality, (@is_teacher ? 1 : 0))
+ if @m_score
+ if @homework.has_rated?(User.current, :quality)
+ rate = @homework.rates(:quality).where(:rater_id => User.current.id).first
+ rate.stars = @m_score
+ rate.save!
+ else
+ @homework.rates(:quality).new(:stars => @m_score, :rater_id => User.current.id, :is_teacher_score => (@is_teacher ? 1 : 0)).save!
+ end
+ end
#保存评论
@is_comprehensive_evaluation = @is_teacher ? 1 : (@is_anonymous_comments ? 2 : 3) #判断当前评论是老师评论?匿评?留言
if params[:new_form] && params[:new_form][:user_message] && params[:new_form][:user_message] != "" #有没有留言
@homework.addjours User.current.id, params[:new_form][:user_message],0,@is_comprehensive_evaluation
end
- teachers = find_course_teachers(@homework.bid.courses.first)
@stars_reates = @homework.rates(:quality)
- @teacher_stars = @stars_reates.where("rater_id in (#{teachers})") #老师评分列表
- @student_stars = @stars_reates.where("rater_id not in (#{teachers})") #学生评分列表
+ @teacher_stars = @stars_reates.where("is_teacher_score = 1") #老师评分列表
+ @student_stars = @stars_reates.where("is_teacher_score = 0") #学生评分列表
jours = @homework.journals_for_messages.where("is_comprehensive_evaluation = 3 or is_comprehensive_evaluation is null").order("created_on DESC")#jours留言 is null条件用以兼容历史数据
@jour = paginateHelper jours,5 #留言
if @cur_type == "1" #如果当前是老师未批列表,需要刷新整个作业列表界面
@bid = @homework.bid
- get_not_batch_homework_list "s_socre","desc",teachers,@homework.bid_id
+ get_not_batch_homework_list "s_socre","desc",@homework.bid_id
elsif @cur_type == "2" #老师已批列表
@result_homework = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers}) and stars IS NOT NULL) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1 and stars IS NOT NULL) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches WHERE id = #{@homework.id}").first
elsif @cur_type == "3" #全部作业列表
@result_homework = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id in (#{teachers})) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id not in (#{teachers})) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches WHERE id = #{@homework.id}").first
elsif @cur_type == "4" #匿评作业列表
@is_student_batch_homework = true
@result_homework = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers})) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score,
(SELECT stars FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id = #{User.current.id}) AS m_score
FROM homework_attaches
WHERE homework_attaches.id = #{@homework.id}").first
@@ -552,7 +552,7 @@ class HomeworkAttachController < ApplicationController
teacher_proportion
end
- def get_not_batch_homework_list sort,direction,teachers,bid_id
+ def get_not_batch_homework_list sort,direction,bid_id
if sort == 't_socre'
order_by = "t_score #{direction}"
elsif sort == 's_socre'
@@ -561,8 +561,8 @@ class HomeworkAttachController < ApplicationController
order_by = "created_at #{direction}"
end
all_homework_list = HomeworkAttach.eager_load(:attachments,:user,:rate_averages).find_by_sql("SELECT * FROM (SELECT homework_attaches.*,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id IN (#{teachers})) AS t_score,
- (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND rater_id NOT IN (#{teachers})) AS s_score
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 1) AS t_score,
+ (SELECT AVG(stars) FROM seems_rateable_rates WHERE rateable_type = 'HomeworkAttach' AND rateable_id = homework_attaches.id AND is_teacher_score = 0) AS s_score
FROM homework_attaches WHERE bid_id = #{bid_id}
ORDER BY #{order_by}) AS table1
WHERE table1.t_score IS NULL")
From 8dc9b223b1f27379512145e8a4dc72c357e2bf5a Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Mon, 29 Dec 2014 16:03:51 +0800
Subject: [PATCH 13/46] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E7=AB=9E=E8=B5=9B?=
=?UTF-8?q?=E6=A8=A1=E5=9D=97=EF=BC=8C=E9=87=8D=E5=A4=8D=E8=AF=84=E5=88=86?=
=?UTF-8?q?=E4=B8=8D=E4=BC=9A=E4=BB=A5=E6=9C=80=E5=90=8E=E4=B8=80=E6=AC=A1?=
=?UTF-8?q?=E8=AF=84=E5=88=86=E4=B8=BA=E5=87=86=E7=9A=84BUG?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
lib/seems_rateable/lib/seems_rateable/model.rb | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/lib/seems_rateable/lib/seems_rateable/model.rb b/lib/seems_rateable/lib/seems_rateable/model.rb
index 83d37d555..b4ebbb196 100644
--- a/lib/seems_rateable/lib/seems_rateable/model.rb
+++ b/lib/seems_rateable/lib/seems_rateable/model.rb
@@ -37,9 +37,9 @@ module SeemsRateable
def update_users_rating(stars, user_id, dimension=nil)
obj = rates(dimension).where(:rater_id => user_id).first
- #current_record = average(dimension)
- #current_record.avg = (current_record.avg*current_record.cnt - obj.stars + stars) / (current_record.cnt)
- #current_record.save!
+ current_record = average(dimension)
+ current_record.avg = (current_record.avg*current_record.cnt - obj.stars + stars) / (current_record.cnt)
+ current_record.save!
obj.stars = stars
obj.save!
end
From cd6508efa25d3d980e247d839272db377bcd4b27 Mon Sep 17 00:00:00 2001
From: z9hang
Date: Mon, 29 Dec 2014 16:30:39 +0800
Subject: [PATCH 14/46] =?UTF-8?q?=E6=8F=90=E4=BA=A4=E9=83=A8=E5=88=86?=
=?UTF-8?q?=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/views/bids/_homework_list.html.erb | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/app/views/bids/_homework_list.html.erb b/app/views/bids/_homework_list.html.erb
index 202a2ee91..ea1f9b770 100644
--- a/app/views/bids/_homework_list.html.erb
+++ b/app/views/bids/_homework_list.html.erb
@@ -62,6 +62,11 @@
:is_student_batch_homework => @is_student_batch_homework}%>
+ <% if @is_teacher %>
+
+ <% end %>