From 19571000622b34c39a3ccee390793ff0e66d4f38 Mon Sep 17 00:00:00 2001 From: ouyangxuhua Date: Sat, 29 Aug 2015 11:34:27 +0800 Subject: [PATCH 1/7] =?UTF-8?q?=E7=94=A8=E6=88=B7=E5=85=B3=E6=B3=A8ajax?= =?UTF-8?q?=E5=88=B7=E6=96=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/views/users/_user_show.html.erb | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/app/views/users/_user_show.html.erb b/app/views/users/_user_show.html.erb index 7cbb20e40..9eabb2be5 100644 --- a/app/views/users/_user_show.html.erb +++ b/app/views/users/_user_show.html.erb @@ -30,9 +30,13 @@ 编辑资料 <%else%> <%if(user.watched_by?(User.current))%> - 取消关注 + + <%=link_to "取消关注", watch_path(:object_type=> 'user',:object_id=>user.id,:target_id=>user.id, :remote => "true"), :class => "fr qx_btn mr10", :method => "delete", :title => "取消关注" %> + <% else %> - 添加关注 + + <%= link_to "添加关注", watch_path(:object_type=>'user',:object_id=>user.id,:target_id=>user.id, :remote => "true"), :class => "fr gz_btn mr10", :method => "post", :title => "添加关注" %> + <% end %> <% end%> <% end %> From f438d300dd760c210fdcc16e91f6cf75608af4e1 Mon Sep 17 00:00:00 2001 From: huang Date: Sat, 29 Aug 2015 11:50:08 +0800 Subject: [PATCH 2/7] =?UTF-8?q?=E6=B6=88=E6=81=AF=E6=95=B0=E6=8D=AE?= =?UTF-8?q?=E8=BF=81=E7=A7=BB=EF=BC=88=E6=9C=AA=E5=AE=8C=EF=BC=89?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/models/course.rb | 3 +- db/migrate/20150829023459_forge_messages.rb | 65 ++++++++++++++++++++ db/migrate/20150829024549_course_messages.rb | 38 ++++++++++++ 3 files changed, 105 insertions(+), 1 deletion(-) create mode 100644 db/migrate/20150829023459_forge_messages.rb create mode 100644 db/migrate/20150829024549_course_messages.rb diff --git a/app/models/course.rb b/app/models/course.rb index 26220f245..501d958e4 100644 --- a/app/models/course.rb +++ b/app/models/course.rb @@ -37,7 +37,8 @@ class Course < ActiveRecord::Base has_many :course_acts, :class_name => 'CourseActivity',:as =>:course_act ,:dependent => :destroy has_many :course_activities - has_many :course_messages + # 课程消息 + has_many :course_messages, :class_name =>'CourseMessage', :as => :course_message, :dependent => :destroy acts_as_taggable acts_as_nested_set :order => 'name', :dependent => :destroy diff --git a/db/migrate/20150829023459_forge_messages.rb b/db/migrate/20150829023459_forge_messages.rb new file mode 100644 index 000000000..39e9e9027 --- /dev/null +++ b/db/migrate/20150829023459_forge_messages.rb @@ -0,0 +1,65 @@ +class ForgeMessages < ActiveRecord::Migration + def up + Project.all.each do |project| + transaction do + project.forge_messages << ForgeMessage.new(:user_id => project.user_id, :course_id => project.id) + + # 新闻 + project.news.each do |new| + new.project.members.each do |m| + if m.user_id != new.author_id + if m.created_on < new.created_on # 在成员加入项目之后 + new.forge_messages << ForgeMessage.new(:user_id => m.user_id, :project_id => self.project_id, :viewed => true) + end + end + end + end + + # 讨论区 + if project.boards.first + project.boards.first.messages.each do |message| + if message.parent_id.nil? # 主贴 + message.project.members.each do |m| + if m.user_id != message.author_id + if m.created_on < message.created_on + message.forge_messages << ForgeMessage.new(:user_id => m.user_id, :project_id => message.board.project_id, :viewed => true) + end + end + end + else # 回帖 + message.project.members.each do |m| + if m.user_id == Message.find(message.parent_id).author_id && m.user_id != message.author_id # 只针对主贴回复,回复自己的帖子不发消息 + if m.created_on < message.created_on + message.forge_messages << ForgeMessage.new(:user_id => m.user_id, :project_id => message.board.project_id, :viewed => true) + end + end + end + end + end + end + + # 缺陷 + project.issues.each do |issue| + unless issue.author_id == issue.assigned_to_id + issue.forge_messages << ForgeMessage.new(:user_id => issue.assigned_to_id, :project_id => issue.project_id, :viewed => true) + end + end + + # 缺陷更新 + project.issues.each do |issue| + issue.journals.each do |journal| + if journal.user_id != journal.issue.author_id + journal.forge_messages << ForgeMessage.new(:user_id => journal.issue.author_id, :project_id => journal.issue.project_id, :viewed => true) + end + if journal.user_id != journal.issue.assigned_to_id && journal.issue.assigned_to_id != journal.issue.author_id # 指派人不是自己的话,则给指派人发送 + journal.forge_messages << ForgeMessage.new(:user_id => journal.issue.assigned_to_id, :project_id => journal.issue.project_id, :viewed => true) + end + end + end + end + end + end + + def down + end +end diff --git a/db/migrate/20150829024549_course_messages.rb b/db/migrate/20150829024549_course_messages.rb new file mode 100644 index 000000000..63b2c2dd3 --- /dev/null +++ b/db/migrate/20150829024549_course_messages.rb @@ -0,0 +1,38 @@ +class CourseMessages < ActiveRecord::Migration + def up + Course.all.each do |course| + transaction do + course.course_messages << CourseActivity.new(:user_id => course.tea_id,:course_id => course.id) + #作业 + course.homework_commons.each do |homework_common| + homework_common.course_acts << CourseActivity.new(:user_id => homework_common.user_id,:course_id => course.id) + end + #通知 + course.news.each do |new| + new.course_acts << CourseActivity.new(:user_id => new.author_id,:course_id => course.id) + end + #资源 + course.attachments.each do |attachment| + attachment.course_acts << CourseActivity.new(:user_id => attachment.author_id,:course_id => course.id) + end + #讨论区 + if course.boards.first + course.boards.first.messages.each do |message| + message.course_acts << CourseActivity.new(:user_id => message.author_id,:course_id => course.id) + end + end + #留言 + course.journals_for_messages.each do |jour| + jour.course_acts << CourseActivity.new(:user_id => jour.user_id,:course_id => course.id) + end + #问卷 + Poll.where("polls_type = 'Course' and polls_group_id = #{course.id}").each do |poll| + poll.course_acts << CourseActivity.new(:user_id => poll.user_id,:course_id => course.id) + end + end + end + end + + def down + end +end From 353e2f5d185cd53af43325cc47ee23e27f9e42a1 Mon Sep 17 00:00:00 2001 From: huang Date: Sat, 29 Aug 2015 16:08:09 +0800 Subject: [PATCH 3/7] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E8=AF=BE=E7=A8=8B?= =?UTF-8?q?=E6=B6=88=E6=81=AF=E8=BF=81=E7=A7=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/controllers/users_controller.rb | 2 +- app/models/course_message.rb | 1 + app/models/project.rb | 2 +- app/views/users/user_messages.html.erb | 4 +- db/migrate/20150829023459_forge_messages.rb | 32 +++-- db/migrate/20150829024549_course_messages.rb | 120 +++++++++++++++--- .../20150829070453_about_message_alls.rb | 31 +++++ db/schema.rb | 5 +- 8 files changed, 161 insertions(+), 36 deletions(-) create mode 100644 db/migrate/20150829070453_about_message_alls.rb diff --git a/app/controllers/users_controller.rb b/app/controllers/users_controller.rb index 555c67d13..132767fa3 100644 --- a/app/controllers/users_controller.rb +++ b/app/controllers/users_controller.rb @@ -155,7 +155,7 @@ class UsersController < ApplicationController @message_alls = CourseMessage.where("course_message_type =? and user_id =?", "JournalsForMessage", @user).order("created_at desc") @message_alls_count = @message_alls.count when 'issue' - @message_alls = ForgeMessage.where("forge_message_type =? and user_id =?", "Issue", @user).order("created_at desc") + @message_alls = ForgeMessage.where("forge_message_type =? and user_id =?", "Issue", @user).reverse @message_alls_count = @message_alls.count when 'issue_update' # 缺陷状态更新、留言 @message_alls = ForgeMessage.where("forge_message_type =? and user_id =?", "Journal", @user).order("created_at desc") diff --git a/app/models/course_message.rb b/app/models/course_message.rb index 95ce3a56b..de1be1a20 100644 --- a/app/models/course_message.rb +++ b/app/models/course_message.rb @@ -11,6 +11,7 @@ class CourseMessage < ActiveRecord::Base validates :course_id,presence: true validates :course_message_id,presence: true validates :course_message_type, presence: true + validates :content, length: {maximum: 1000} after_create :add_user_message def add_user_message diff --git a/app/models/project.rb b/app/models/project.rb index 77711edff..0618dd145 100644 --- a/app/models/project.rb +++ b/app/models/project.rb @@ -92,7 +92,7 @@ class Project < ActiveRecord::Base has_many :tags, :through => :project_tags, :class_name => 'Tag' has_many :project_tags, :class_name => 'ProjectTags' # 关联虚拟表 - has_many :forge_messages + has_many :forge_messages, :class_name =>'ForgeMessage', :as => :forge_message, :dependent => :destroy belongs_to :organization diff --git a/app/views/users/user_messages.html.erb b/app/views/users/user_messages.html.erb index a0d568710..15f77a2a6 100644 --- a/app/views/users/user_messages.html.erb +++ b/app/views/users/user_messages.html.erb @@ -98,7 +98,7 @@ <% unless ma.content.nil? %> <%= link_to ma.content.html_safe, student_work_index_path(:homework => ma.course_message.student_work.homework_common_id),:class=>"newsGrey",:title => "#{ma.content.html_safe}" %> <% end %> -
  • <%= time_tag(ma.created_at).html_safe %>
  • +
  • <%= time_tag(ma.course_message.created_at).html_safe %>
  • <% end %> <% if ma.course_message_type == "JournalsForMessage" %> @@ -125,7 +125,7 @@
  • <%= link_to ma.forge_message.subject, issue_path(:id => ma.forge_message.id), :class => "#{ma.viewed == 0 ? "newsBlack" : "newsGrey"}",:title => "#{ma.forge_message.subject}" %>
  • -
  • <%= time_tag(ma.created_at).html_safe %>
  • +
  • <%= time_tag(ma.forge_message.created_on).html_safe %>
  • <% end %> <% if ma.forge_message_type == "Journal" %> diff --git a/db/migrate/20150829023459_forge_messages.rb b/db/migrate/20150829023459_forge_messages.rb index 39e9e9027..e0e00e123 100644 --- a/db/migrate/20150829023459_forge_messages.rb +++ b/db/migrate/20150829023459_forge_messages.rb @@ -1,15 +1,27 @@ +# encoding: UTF-8 class ForgeMessages < ActiveRecord::Migration def up Project.all.each do |project| transaction do - project.forge_messages << ForgeMessage.new(:user_id => project.user_id, :course_id => project.id) + project.forge_messages << ForgeMessage.new(:user_id => project.user_id, :project_id => project.id) # 新闻 project.news.each do |new| new.project.members.each do |m| if m.user_id != new.author_id if m.created_on < new.created_on # 在成员加入项目之后 - new.forge_messages << ForgeMessage.new(:user_id => m.user_id, :project_id => self.project_id, :viewed => true) + new.forge_messages << ForgeMessage.new(:user_id => m.user_id, :project_id => new.project_id, :viewed => true) + end + end + end + end + + # 新闻回复 + project.news.each do |new| + if new.comments + new.comments.each do |comment| + if comment.author_id != comment.commented.author_id + comment.forge_messages << ForgeMessage.new(:user_id => comment.commented.author_id, :project_id => comment.commented.project.id, :viewed => true) end end end @@ -47,19 +59,23 @@ class ForgeMessages < ActiveRecord::Migration # 缺陷更新 project.issues.each do |issue| - issue.journals.each do |journal| - if journal.user_id != journal.issue.author_id - journal.forge_messages << ForgeMessage.new(:user_id => journal.issue.author_id, :project_id => journal.issue.project_id, :viewed => true) - end - if journal.user_id != journal.issue.assigned_to_id && journal.issue.assigned_to_id != journal.issue.author_id # 指派人不是自己的话,则给指派人发送 - journal.forge_messages << ForgeMessage.new(:user_id => journal.issue.assigned_to_id, :project_id => journal.issue.project_id, :viewed => true) + if issue.journals + issue.journals.each do |journal| + if journal.user_id != journal.issue.author_id + journal.forge_messages << ForgeMessage.new(:user_id => journal.issue.author_id, :project_id => journal.issue.project_id, :viewed => true) + end + if journal.user_id != journal.issue.assigned_to_id && journal.issue.assigned_to_id != journal.issue.author_id # 指派人不是自己的话,则给指派人发送 + journal.forge_messages << ForgeMessage.new(:user_id => journal.issue.assigned_to_id, :project_id => journal.issue.project_id, :viewed => true) + end end end end + end end end def down + ForgeMessages.destroy_all end end diff --git a/db/migrate/20150829024549_course_messages.rb b/db/migrate/20150829024549_course_messages.rb index 63b2c2dd3..a26a5a281 100644 --- a/db/migrate/20150829024549_course_messages.rb +++ b/db/migrate/20150829024549_course_messages.rb @@ -1,34 +1,112 @@ +# encoding: UTF-8 class CourseMessages < ActiveRecord::Migration def up Course.all.each do |course| transaction do - course.course_messages << CourseActivity.new(:user_id => course.tea_id,:course_id => course.id) - #作业 + course.course_messages << CourseMessage.new(:user_id => course.tea_id,:course_id => course.id) + # 作业 course.homework_commons.each do |homework_common| - homework_common.course_acts << CourseActivity.new(:user_id => homework_common.user_id,:course_id => course.id) - end - #通知 - course.news.each do |new| - new.course_acts << CourseActivity.new(:user_id => new.author_id,:course_id => course.id) - end - #资源 - course.attachments.each do |attachment| - attachment.course_acts << CourseActivity.new(:user_id => attachment.author_id,:course_id => course.id) - end - #讨论区 - if course.boards.first - course.boards.first.messages.each do |message| - message.course_acts << CourseActivity.new(:user_id => message.author_id,:course_id => course.id) + homework_common.course.members.each do |m| + if m.user_id != homework_common.user_id + if m.created_on < homework_common.created_at + homework_common.course_messages << CourseMessage.new(:user_id => m.user_id, :course_id => course.id, :viewed => true) + end + end end end - #留言 - course.journals_for_messages.each do |jour| - jour.course_acts << CourseActivity.new(:user_id => jour.user_id,:course_id => course.id) + + # 通知 + course.news.each do |new| + new.course.members.each do |m| + if m.user_id != new.author_id + if m.created_on < new.created_on # 在成员加入课程之后 + new.course_messages << CourseMessage.new(:user_id => m.user_id, :course_id => course.id, :viewed => true) + end + end + end end - #问卷 + + # 通知的回复 + course.news.each do |new| + if new.comments + new.comments.each do |comment| + if comment.author_id != comment.commented.author_id + comment.course_messages << CourseMessage.new(:user_id => comment.commented.author_id, :course_id => course.id, :viewed => true) + end + end + end + end + + # 讨论区 + if course.boards.first + course.boards.first.messages.each do |message| + if message.parent_id.nil? # 主贴 + message.course.members.each do |m| + if message.author.allowed_to?(:as_teacher, message.course) && m.user_id != message.author_id # 老师 自己的帖子不给自己发送消息 + if m.created_on < message.created_on + message.course_messages << CourseMessage.new(:user_id => m.user_id, :course_id => course.id, :viewed => true) + end + end + end + else # 回帖 + message.course.members.each do |m| + if m.user_id == Message.find(message.parent_id).author_id && m.user_id != message.author_id # 只针对主贴回复,回复自己的帖子不发消息 + if m.created_on < message.created_on + message.course_messages << CourseMessage.new(:user_id => m.user_id, :course_id => course.id, :viewed => true) + end + end + end + end + end + end + + # 问卷 Poll.where("polls_type = 'Course' and polls_group_id = #{course.id}").each do |poll| - poll.course_acts << CourseActivity.new(:user_id => poll.user_id,:course_id => course.id) + if poll.polls_status == 2 #问卷是发布状态 + Course.find(poll.polls_group_id).members.each do |m| + if m.user_id != poll.user_id + if m.created_on < poll.created_at + poll.course_messages << CourseMessage.new(:user_id => m.user_id, :course_id => course.id, :viewed => true) + end + end + end + elsif poll.polls_status == 1 #问卷是新建状态 + poll.course_messages.destroy_all + end end + + # 作品评阅 + course.homework_commons.each do |homework_common| + if homework_common.student_works + homework_common.student_works.each do |student_work| + if student_work.student_works_scores + student_work.student_works_scores.each do |student_works_score| + receiver = student_works_score.student_work.user + if student_works_score.created_at == student_works_score.updated_at + if student_works_score.comment.nil? + student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + :viewed => true, :content => "作业评分:#{student_works_score.score}", :status=> true) + else + student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + :viewed => true, :content => "作业评分:#{student_works_score.score}    评语:#{student_works_score.comment}", :status=> true) + end + else # 更新 + if student_works_score.comment.nil? + student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + :viewed => true, :content => "作业评分:#{student_works_score.score}", :status=> true) + else + student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + :viewed => true, :content => "作业评分:#{student_works_score.score}    评语:#{student_works_score.comment}", :status=> true) + end + end + end + end + end + end + end + + # 作品讨论 + end end end diff --git a/db/migrate/20150829070453_about_message_alls.rb b/db/migrate/20150829070453_about_message_alls.rb new file mode 100644 index 000000000..6f8acae38 --- /dev/null +++ b/db/migrate/20150829070453_about_message_alls.rb @@ -0,0 +1,31 @@ +class AboutMessageAlls < ActiveRecord::Migration + def up + forge_count = ForgeMessage.all.count / 30 + 2 + transaction do + for i in 1 ... forge_count do i + ForgeMessage.page(i).per(30).each do |forge_message| + message = MessageAll.new + message.message_id = forge_message.forge_message_id + message.message_type = forge_message.forge_message_type + message.user_id = forge_message.user_id + message.save + end + end + end + + course_count = CourseMessage.all.count / 30 + 2 + transaction do + for i in 1 ... course_count do i + CourseMessage.page(i).per(30).each do |course_message| + message = MessageAll.new + message.message_id = course_message.course_message_id + message.message_type = course_message.course_message_type + message.save + end + end + end + end + + def down + end +end diff --git a/db/schema.rb b/db/schema.rb index 5b09c8f3d..05825bd5d 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 => 20150826061843) do +ActiveRecord::Schema.define(:version => 20150829070453) do create_table "activities", :force => true do |t| t.integer "act_id", :null => false @@ -913,7 +913,6 @@ ActiveRecord::Schema.define(:version => 20150826061843) do t.datetime "created_on" t.integer "comments_count", :default => 0, :null => false t.integer "course_id" - t.datetime "updated_on" end add_index "news", ["author_id"], :name => "index_news_on_author_id" @@ -1318,7 +1317,6 @@ ActiveRecord::Schema.define(:version => 20150826061843) do t.datetime "updated_at", :null => false t.integer "late_penalty", :default => 0 t.integer "absence_penalty", :default => 0 - t.integer "system_score" end create_table "student_works_evaluation_distributions", :force => true do |t| @@ -1536,6 +1534,7 @@ ActiveRecord::Schema.define(:version => 20150826061843) do t.string "identity_url" t.string "mail_notification", :default => "", :null => false t.string "salt", :limit => 64 + t.integer "gid" end add_index "users", ["auth_source_id"], :name => "index_users_on_auth_source_id" From 43170c696c296d81ddbd5c99be8916462eb8bc0d Mon Sep 17 00:00:00 2001 From: huang Date: Sat, 29 Aug 2015 17:09:44 +0800 Subject: [PATCH 4/7] =?UTF-8?q?=E8=BF=81=E7=A7=BB=E6=80=BB=E8=A1=A8?= =?UTF-8?q?=E6=97=B6=E9=97=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/models/course_message.rb | 2 +- db/migrate/20150829023459_forge_messages.rb | 1 - .../20150829070453_about_message_alls.rb | 31 ------------- .../20150829081822_update_message_time.rb | 46 +++++++++++++++++++ 4 files changed, 47 insertions(+), 33 deletions(-) delete mode 100644 db/migrate/20150829070453_about_message_alls.rb create mode 100644 db/migrate/20150829081822_update_message_time.rb diff --git a/app/models/course_message.rb b/app/models/course_message.rb index de1be1a20..4f62d24c2 100644 --- a/app/models/course_message.rb +++ b/app/models/course_message.rb @@ -11,7 +11,7 @@ class CourseMessage < ActiveRecord::Base validates :course_id,presence: true validates :course_message_id,presence: true validates :course_message_type, presence: true - validates :content, length: {maximum: 1000} + validates_length_of :content, :maximum => 100 after_create :add_user_message def add_user_message diff --git a/db/migrate/20150829023459_forge_messages.rb b/db/migrate/20150829023459_forge_messages.rb index e0e00e123..c468ad68f 100644 --- a/db/migrate/20150829023459_forge_messages.rb +++ b/db/migrate/20150829023459_forge_messages.rb @@ -76,6 +76,5 @@ class ForgeMessages < ActiveRecord::Migration end def down - ForgeMessages.destroy_all end end diff --git a/db/migrate/20150829070453_about_message_alls.rb b/db/migrate/20150829070453_about_message_alls.rb deleted file mode 100644 index 6f8acae38..000000000 --- a/db/migrate/20150829070453_about_message_alls.rb +++ /dev/null @@ -1,31 +0,0 @@ -class AboutMessageAlls < ActiveRecord::Migration - def up - forge_count = ForgeMessage.all.count / 30 + 2 - transaction do - for i in 1 ... forge_count do i - ForgeMessage.page(i).per(30).each do |forge_message| - message = MessageAll.new - message.message_id = forge_message.forge_message_id - message.message_type = forge_message.forge_message_type - message.user_id = forge_message.user_id - message.save - end - end - end - - course_count = CourseMessage.all.count / 30 + 2 - transaction do - for i in 1 ... course_count do i - CourseMessage.page(i).per(30).each do |course_message| - message = MessageAll.new - message.message_id = course_message.course_message_id - message.message_type = course_message.course_message_type - message.save - end - end - end - end - - def down - end -end diff --git a/db/migrate/20150829081822_update_message_time.rb b/db/migrate/20150829081822_update_message_time.rb new file mode 100644 index 000000000..0bbc4458c --- /dev/null +++ b/db/migrate/20150829081822_update_message_time.rb @@ -0,0 +1,46 @@ +class UpdateMessageTime < ActiveRecord::Migration + def up + course_count = CourseMessage.all.count / 30 + 1 + transaction do + for i in 1 ... course_count do i + CourseMessage.page(i).per(30).each do |cmessage| + if cmessage.course_message + if cmessage.course_message.respond_to?("created_at") + cmessage.created_at = cmessage.course_message.created_at + elsif cmessage.course_message.respond_to?("created_on") + cmessage.created_at = cmessage.course_message.created_on + end + cmessage.save + + course_all_message = MessageAll.where("message_type = '#{cmessage.class.to_s}' and message_id = '#{cmessage.id}'").first + course_all_message.created_at = cmessage.created_at + course_all_message.save + end + end + end + end + + forge_count = ForgeMessage.all.count / 30 + 2 + transaction do + for i in 1 ... forge_count do i + ForgeMessage.page(i).per(30).each do |fmessage| + if fmessage.forge_message + if fmessage.forge_message.respond_to?("created_at") + fmessage.created_at = fmessage.forge_message.created_at + elsif fmessage.forge_message.respond_to?("created_on") + fmessage.created_at = fmessage.forge_message.created_on + end + fmessage.save + + forge_all_message = MessageAll.where("message_type = '#{fmessage.class.to_s}' and message_id = '#{fmessage.id}'").first + forge_all_message.created_at = fmessage.created_at + forge_all_message.save + end + end + end + end + end + + def down + end +end From 7a4d5627730a2d7eec233c6bfccad6255e43caa4 Mon Sep 17 00:00:00 2001 From: sw <939547590@qq.com> Date: Sat, 29 Aug 2015 19:15:06 +0800 Subject: [PATCH 5/7] =?UTF-8?q?=E8=AF=BE=E7=A8=8B=E4=B8=BB=E9=A1=B5?= =?UTF-8?q?=EF=BC=8C=E9=A1=B9=E7=9B=AE=E4=B8=BB=E9=A1=B5=20500?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/controllers/welcome_controller.rb | 58 +++++++++++++-------------- 1 file changed, 29 insertions(+), 29 deletions(-) diff --git a/app/controllers/welcome_controller.rb b/app/controllers/welcome_controller.rb index 24cbecb81..784066378 100644 --- a/app/controllers/welcome_controller.rb +++ b/app/controllers/welcome_controller.rb @@ -96,14 +96,14 @@ class WelcomeController < ApplicationController @projects = Project.all_public.active render :layout => false, :content_type => 'text/plain' end - + def course redirect_to signin_path return - - @course_page = FirstPage.find_by_page_type('course') - @school_id = params[:school_id] || User.current.user_extensions.school.try(:id) || 117 - @logoLink ||= logolink() + # + # @course_page = FirstPage.find_by_page_type('course') + # @school_id = params[:school_id] || User.current.user_extensions.school.try(:id) || 117 + # @logoLink ||= logolink() end def logolink() @@ -146,8 +146,8 @@ class WelcomeController < ApplicationController redirect_to signin_path return - @contest_page = FirstPage.find_by_page_type('contest') - @contest_notifications = Contestnotification.order("created_at desc").limit(5) + # @contest_page = FirstPage.find_by_page_type('contest') + # @contest_notifications = Contestnotification.order("created_at desc").limit(5) end def search @@ -187,28 +187,28 @@ class WelcomeController < ApplicationController private # 判断网站的入口,是课程 course 则跳过index去渲染 course 方法 def entry_select - url = request.original_url.gsub('/','') - if url.include?(Setting.url_course.gsub('/','')) - if @first_page.show_course == 1 - course - render :course - else - render_404 - end - - return 0 - elsif url.include?(Setting.url_contest.gsub('/','')) - if @first_page.show_contest == 1 - contest - render :contest - else - render_404 - end - - return 0 - elsif url.include?(Setting.url_user.gsub('/','')) - #redirect_to(:controller => "users", :action => "index") - end + # url = request.original_url.gsub('/','') + # if url.include?(Setting.url_course.gsub('/','')) + # if @first_page.show_course == 1 + # course + # render :course + # else + # render_404 + # end + # + # return 0 + # elsif url.include?(Setting.url_contest.gsub('/','')) + # if @first_page.show_contest == 1 + # contest + # render :contest + # else + # render_404 + # end + # + # return 0 + # elsif url.include?(Setting.url_user.gsub('/','')) + # #redirect_to(:controller => "users", :action => "index") + # end end From 7ed93c1d808599efc25957c458076e6c1259af13 Mon Sep 17 00:00:00 2001 From: huang Date: Sat, 29 Aug 2015 19:26:23 +0800 Subject: [PATCH 6/7] =?UTF-8?q?=E6=B6=88=E6=81=AF=E6=80=BB=E8=A1=A8?= =?UTF-8?q?=E6=95=B0=E6=8D=AE=E8=BF=81=E7=A7=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- db/migrate/20150829024549_course_messages.rb | 57 +++++++++---------- .../20150829081822_update_message_time.rb | 2 +- 2 files changed, 29 insertions(+), 30 deletions(-) diff --git a/db/migrate/20150829024549_course_messages.rb b/db/migrate/20150829024549_course_messages.rb index a26a5a281..666ccdaeb 100644 --- a/db/migrate/20150829024549_course_messages.rb +++ b/db/migrate/20150829024549_course_messages.rb @@ -76,35 +76,34 @@ class CourseMessages < ActiveRecord::Migration end # 作品评阅 - course.homework_commons.each do |homework_common| - if homework_common.student_works - homework_common.student_works.each do |student_work| - if student_work.student_works_scores - student_work.student_works_scores.each do |student_works_score| - receiver = student_works_score.student_work.user - if student_works_score.created_at == student_works_score.updated_at - if student_works_score.comment.nil? - student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, - :viewed => true, :content => "作业评分:#{student_works_score.score}", :status=> true) - else - student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, - :viewed => true, :content => "作业评分:#{student_works_score.score}    评语:#{student_works_score.comment}", :status=> true) - end - else # 更新 - if student_works_score.comment.nil? - student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, - :viewed => true, :content => "作业评分:#{student_works_score.score}", :status=> true) - else - student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, - :viewed => true, :content => "作业评分:#{student_works_score.score}    评语:#{student_works_score.comment}", :status=> true) - end - end - end - end - end - end - end - + # course.homework_commons.each do |homework_common| + # if homework_common.student_works + # homework_common.student_works.each do |student_work| + # if student_work.student_works_scores + # student_work.student_works_scores.each do |student_works_score| + # receiver = student_works_score.student_work.user + # if student_works_score.created_at == student_works_score.updated_at + # if student_works_score.comment.nil? + # student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + # :viewed => true, :content => "作业评分:#{student_works_score.score}", :status=> true) + # else + # student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + # :viewed => true, :content => "作业评分:#{student_works_score.score}    评语:#{student_works_score.comment}", :status=> true) + # end + # else # 更新 + # if student_works_score.comment.nil? + # student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + # :viewed => true, :content => "作业评分:#{student_works_score.score}", :status=> true) + # else + # student_works_score.course_messages << CourseMessage.new(:user_id => receiver.id, :course_id => course.id, + # :viewed => true, :content => "作业评分:#{student_works_score.score}    评语:#{student_works_score.comment}", :status=> true) + # end + # end + # end + # end + # end + # end + # end # 作品讨论 end diff --git a/db/migrate/20150829081822_update_message_time.rb b/db/migrate/20150829081822_update_message_time.rb index 0bbc4458c..31dcb0b4f 100644 --- a/db/migrate/20150829081822_update_message_time.rb +++ b/db/migrate/20150829081822_update_message_time.rb @@ -20,7 +20,7 @@ class UpdateMessageTime < ActiveRecord::Migration end end - forge_count = ForgeMessage.all.count / 30 + 2 + forge_count = ForgeMessage.all.count / 30 + 1 transaction do for i in 1 ... forge_count do i ForgeMessage.page(i).per(30).each do |fmessage| From e652e92217a9eb57324b493f924d77a316becfde Mon Sep 17 00:00:00 2001 From: huang Date: Sun, 30 Aug 2015 11:20:37 +0800 Subject: [PATCH 7/7] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E6=B6=88=E6=81=AF?= =?UTF-8?q?=E8=BF=81=E7=A7=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/controllers/users_controller.rb | 2 +- app/views/users/user_messages.html.erb | 24 ++++++++--------- .../20150829081822_update_message_time.rb | 20 -------------- ...0150829130302_update_forge_message_time.rb | 26 +++++++++++++++++++ 4 files changed, 39 insertions(+), 33 deletions(-) create mode 100644 db/migrate/20150829130302_update_forge_message_time.rb diff --git a/app/controllers/users_controller.rb b/app/controllers/users_controller.rb index 12caefde2..900af0e77 100644 --- a/app/controllers/users_controller.rb +++ b/app/controllers/users_controller.rb @@ -155,7 +155,7 @@ class UsersController < ApplicationController @message_alls = CourseMessage.where("course_message_type =? and user_id =?", "JournalsForMessage", @user).order("created_at desc") @message_alls_count = @message_alls.count when 'issue' - @message_alls = ForgeMessage.where("forge_message_type =? and user_id =?", "Issue", @user).reverse + @message_alls = ForgeMessage.where("forge_message_type =? and user_id =?", "Issue", @user).order("created_at desc") @message_alls_count = @message_alls.count when 'issue_update' # 缺陷状态更新、留言 @message_alls = ForgeMessage.where("forge_message_type =? and user_id =?", "Journal", @user).order("created_at desc") diff --git a/app/views/users/user_messages.html.erb b/app/views/users/user_messages.html.erb index 65d1cb591..207572a1c 100644 --- a/app/views/users/user_messages.html.erb +++ b/app/views/users/user_messages.html.erb @@ -44,7 +44,7 @@ <%= link_to ma.course_message.title, {:controller => 'news', :action => 'show', :id => ma.course_message.id }, :class =>"#{ma.viewed == 0 ? "newsBlack" : "newsGrey"}", :title => "#{ma.course_message.title}" %> -
  • <%= time_tag(ma.course_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.course_message_type == "Comment" %> @@ -55,7 +55,7 @@ <%= link_to ma.course_message.comments.html_safe, {:controller => 'news', :action => 'show', :id => ma.course_message.commented.id }, :class =>"#{ma.viewed == 0 ? "newsBlack" : "newsGrey"}", :title => "#{ma.course_message.comments.html_safe}" %> -
  • <%= time_tag(ma.course_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.course_message_type == "HomeworkCommon" %> @@ -64,7 +64,7 @@
  • <%=link_to ma.course_message.user, user_path(ma.course_message.user), :class => "newsBlue homepageNewsPublisher" %>">发布了作业:
  • <%= link_to ma.course_message.name, student_work_index_path(:homework => ma.course_message.id),:class => "newsGrey", :title => "#{ma.course_message.name}" %>
  • -
  • <%= time_tag(ma.course_message.created_at).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.course_message_type == "Poll" %> @@ -75,7 +75,7 @@ <%= link_to format_activity_title(" #{ma.course_message.polls_name.nil? ? "未命名问卷" : ma.course_message.polls_name}"), poll_path(ma.course_message.id), :class=>"#{ma.viewed==0?"newsBlack":"newsGrey"}", :title => "#{ma.course_message.polls_name}" %> -
  • <%= time_tag(ma.course_message.created_at).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.course_message_type == "Message" %> @@ -86,7 +86,7 @@ <%=link_to ma.course_message.subject.html_safe, course_boards_path(ma.course_message.course,:parent_id => ma.course_message.parent_id ? ma.course_message.parent_id : ma.course_message.id, :topic_id => ma.course_message.id),:class=>"#{ma.viewed==0?"newsBlack":"newsGrey"}", :title => "#{ma.course_message.subject.html_safe}" %> -
  • <%= time_tag(ma.course_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> @@ -98,7 +98,7 @@ <% unless ma.content.nil? %> <%= link_to ma.content.html_safe, student_work_index_path(:homework => ma.course_message.student_work.homework_common_id),:class=>"newsGrey",:title => "#{ma.content.html_safe}" %> <% end %> -
  • <%= time_tag(ma.course_message.created_at).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.course_message_type == "JournalsForMessage" %> @@ -107,7 +107,7 @@
  • <%=link_to ma.course_message.user, user_path(ma.course_message.user), :class => "newsBlue homepageNewsPublisher" %>">回复了作品评论:
  • <%= link_to ma.course_message.notes, student_work_index_path(:homework => ma.course_message.jour.student_work.homework_common_id),:class=>"newsGrey",:title => "#{ma.course_message.notes}" %>
  • -
  • <%= time_tag(ma.course_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% end %> @@ -125,7 +125,7 @@
  • <%= link_to ma.forge_message.subject, issue_path(:id => ma.forge_message.id), :class => "#{ma.viewed == 0 ? "newsBlack" : "newsGrey"}",:title => "#{ma.forge_message.subject}" %>
  • -
  • <%= time_tag(ma.forge_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.forge_message_type == "Journal" %> @@ -143,7 +143,7 @@ issue_path(:id => ma.forge_message.journalized_id), :class => "#{ma.viewed == 0 ? "newsBlack" : "newsGrey"}", :title => "#{get_issue_des_update(ma.forge_message).html_safe}" %> -
  • <%= time_tag(ma.forge_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.forge_message_type == "Message" %> @@ -156,7 +156,7 @@ :parent_id => ma.forge_message.parent_id ? ma.forge_message.parent_id : ma.forge_message.id, :topic_id => ma.forge_message.id),:class=>"#{ma.viewed==0?"newsBlack":"newsGrey"}", :title => "#{ma.forge_message.subject.html_safe}" %> -
  • <%= time_tag(ma.forge_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.forge_message_type == "News" %> @@ -171,7 +171,7 @@
  • <%= link_to ("#{ma.forge_message.title.html_safe}"), {:controller => 'news', :action => 'show', :id => ma.forge_message.id}, :class => "newsGrey", :title => "#{ma.forge_message.title.html_safe}" %>
  • -
  • <%= time_tag(ma.forge_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% if ma.forge_message_type == "Comment" %> @@ -182,7 +182,7 @@
  • <%= link_to "#{ma.forge_message.comments.html_safe}", {:controller => 'news', :action => 'show', :id => ma.forge_message.commented.id },:class =>"#{ma.viewed == 0 ? "newsBlack" : "newsGrey"}", :title => "#{ma.forge_message.comments.html_safe}"%>
  • -
  • <%= time_tag(ma.forge_message.created_on).html_safe %>
  • +
  • <%= time_tag(ma.created_at).html_safe %>
  • <% end %> <% end %> diff --git a/db/migrate/20150829081822_update_message_time.rb b/db/migrate/20150829081822_update_message_time.rb index 31dcb0b4f..fe670e9b8 100644 --- a/db/migrate/20150829081822_update_message_time.rb +++ b/db/migrate/20150829081822_update_message_time.rb @@ -19,26 +19,6 @@ class UpdateMessageTime < ActiveRecord::Migration end end end - - forge_count = ForgeMessage.all.count / 30 + 1 - transaction do - for i in 1 ... forge_count do i - ForgeMessage.page(i).per(30).each do |fmessage| - if fmessage.forge_message - if fmessage.forge_message.respond_to?("created_at") - fmessage.created_at = fmessage.forge_message.created_at - elsif fmessage.forge_message.respond_to?("created_on") - fmessage.created_at = fmessage.forge_message.created_on - end - fmessage.save - - forge_all_message = MessageAll.where("message_type = '#{fmessage.class.to_s}' and message_id = '#{fmessage.id}'").first - forge_all_message.created_at = fmessage.created_at - forge_all_message.save - end - end - end - end end def down diff --git a/db/migrate/20150829130302_update_forge_message_time.rb b/db/migrate/20150829130302_update_forge_message_time.rb new file mode 100644 index 000000000..70811c307 --- /dev/null +++ b/db/migrate/20150829130302_update_forge_message_time.rb @@ -0,0 +1,26 @@ +class UpdateForgeMessageTime < ActiveRecord::Migration + def up + forge_count = ForgeMessage.all.count / 30 + 1 + transaction do + for i in 1 ... forge_count do i + ForgeMessage.page(i).per(30).each do |fmessage| + if fmessage.forge_message + if fmessage.forge_message.respond_to?("created_at") + fmessage.created_at = fmessage.forge_message.created_at + elsif fmessage.forge_message.respond_to?("created_on") + fmessage.created_at = fmessage.forge_message.created_on + end + fmessage.save + + forge_all_message = MessageAll.where("message_type = '#{fmessage.class.to_s}' and message_id = '#{fmessage.id}'").first + forge_all_message.created_at = fmessage.created_at + forge_all_message.save + end + end + end + end + end + + def down + end +end