From 4835cab6e453dded0f93dfd67ff9266e0173be24 Mon Sep 17 00:00:00 2001
From: fanqiang <316257774@qq.com>
Date: Tue, 6 Aug 2013 22:26:52 +0800
Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E4=BA=86=E7=94=A8=E6=88=B7?=
=?UTF-8?q?=E6=9F=A5=E6=89=BE=E5=8F=8D=E9=A6=88=E7=9A=84=E5=8A=9F=E8=83=BD?=
=?UTF-8?q?=EF=BC=8C=E5=8F=AF=E4=BB=A5=E6=9F=A5=E7=9C=8B=E5=AF=B9=E7=94=A8?=
=?UTF-8?q?=E6=88=B7=E8=AF=84=E8=AE=BA=E7=9A=84=E5=BC=95=E7=94=A8=E5=92=8C?=
=?UTF-8?q?=E5=AF=B9=E7=94=A8=E6=88=B7=E9=9C=80=E6=B1=82=E7=9A=84=E8=AF=84?=
=?UTF-8?q?=E8=AE=BA=E3=80=82=E8=A7=A3=E5=86=B3=E4=BA=86=E7=95=99=E8=A8=80?=
=?UTF-8?q?=E9=97=AE=E9=A2=98?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/bids_controller.rb | 6 +++--
app/controllers/users_controller.rb | 27 ++++++++++++++++++++--
app/controllers/words_controller.rb | 8 ++++---
app/helpers/bids_helper.rb | 2 +-
app/models/bid.rb | 4 ++--
app/models/journals_for_message.rb | 10 ++++++++
app/models/user.rb | 8 +++----
app/views/bids/_history.html.erb | 6 ++---
app/views/bids/_new.html.erb | 3 ++-
app/views/bids/back.js.erb | 1 +
app/views/bids/create.js.erb | 3 ++-
app/views/bids/destroy.js.erb | 1 +
app/views/bids/more.js.erb | 1 +
app/views/bids/new.js.erb | 5 ++--
app/views/users/info.html.erb | 36 +++++++++++++++++++++++++++++
app/views/users/show.html.erb | 2 +-
app/views/words/_new.html.erb | 1 +
app/views/words/back.js.erb | 1 +
app/views/words/create.js.erb | 3 ++-
app/views/words/destroy.js.erb | 1 +
app/views/words/more.js.erb | 1 +
app/views/words/new.js.erb | 3 ++-
config/locales/zh.yml | 1 +
config/routes.rb | 9 ++++----
lib/redmine.rb | 2 ++
25 files changed, 116 insertions(+), 29 deletions(-)
create mode 100644 app/views/users/info.html.erb
diff --git a/app/controllers/bids_controller.rb b/app/controllers/bids_controller.rb
index 187b2adec..b13a097f9 100644
--- a/app/controllers/bids_controller.rb
+++ b/app/controllers/bids_controller.rb
@@ -1,7 +1,7 @@
# fq
class BidsController < ApplicationController
- before_filter :find_bid, :only => [:show, :show_project, :create, :destroy, :more, :back, :add]
+ before_filter :find_bid, :only => [:show, :show_project, :create, :destroy, :more, :back, :add, :new]
helper :watchers
def index
@@ -86,7 +86,8 @@ class BidsController < ApplicationController
def create
if params[:bid_message].size>0
message = params[:bid_message][:message]
- @bid.add_jour(User.current, message)
+ refer_user_id = params[:bid_message][:reference_user_id].to_i
+ @bid.add_jour(User.current, message, refer_user_id)
# if a_message.size > 5
# @message = a_message[-5, 5]
# else
@@ -137,6 +138,7 @@ class BidsController < ApplicationController
text = text.to_s.strip.gsub(%r{
((.|\s)*?)
}m, '[...]')
@content = "#{ll(Setting.default_language, :text_user_wrote, user)}\n> "
@content << text.gsub(/(\r?\n|\r\n?)/, "\n> ") + "\n\n"
+ @id = user.id
rescue ActiveRecord::RecordNotFound
render_404
end
diff --git a/app/controllers/users_controller.rb b/app/controllers/users_controller.rb
index 63b0bda97..e54c1c61b 100644
--- a/app/controllers/users_controller.rb
+++ b/app/controllers/users_controller.rb
@@ -17,8 +17,8 @@
class UsersController < ApplicationController
layout 'base_users'
- before_filter :require_admin, :except => [:show, :index,:tag_save, :user_projects, :user_newfeedback, :user_comments, :watch_bids]
- before_filter :find_user, :only => [:show, :edit, :update, :destroy, :edit_membership, :destroy_membership, :user_activities, :user_projects, :user_newfeedback, :user_comments, :watch_bids]
+ before_filter :require_admin, :except => [:show, :index,:tag_save, :user_projects, :user_newfeedback, :user_comments, :watch_bids, :info]
+ before_filter :find_user, :only => [:show, :edit, :update, :destroy, :edit_membership, :destroy_membership, :user_activities, :user_projects, :user_newfeedback, :user_comments, :watch_bids, :info]
accept_api_auth :index, :show, :create, :update, :destroy
helper :sort
@@ -148,8 +148,10 @@ class UsersController < ApplicationController
### modified by fq
def show
+
#####fq
@message = MessagesForUser.find_message(@user.id)
+ JournalsForMessage.reference_message(@user.id)
# show projects based on current user visibility
@memberships = @user.memberships.all(:conditions => Project.visible_condition(User.current))
if @user == User.current
@@ -181,6 +183,27 @@ class UsersController < ApplicationController
##end fq
+ #### added by fq
+ def info
+ @message = []
+ if @user == User.current
+ @message = JournalsForMessage.reference_message(@user.id)
+ end
+
+ unless User.current.admin?
+ if !@user.active?
+ render_404
+ return
+ end
+ end
+
+ respond_to do |format|
+ format.html
+ format.api
+ end
+ end
+ #### end
+
def new
@user = User.new(:language => Setting.default_language, :mail_notification => Setting.default_notification_option)
@auth_sources = AuthSource.all
diff --git a/app/controllers/words_controller.rb b/app/controllers/words_controller.rb
index ab7d7f9aa..e978b1d36 100644
--- a/app/controllers/words_controller.rb
+++ b/app/controllers/words_controller.rb
@@ -2,12 +2,13 @@
class WordsController < ApplicationController
before_filter :find_user, :only => [:new, :create, :destroy, :more, :back]
-
def create
if params[:new_form][:user_message].size>0
unless params[:user_id].nil?
message = params[:new_form][:user_message]
- @user.add_jour(User.current, message)
+ refer_user_id = params[:new_form][:reference_user_id].to_i
+
+ @user.add_jour(User.current, message, refer_user_id)
# if a_message.size > 5
# @message = a_message[-5, 5]
# else
@@ -23,7 +24,7 @@ class WordsController < ApplicationController
# format.html { redirect_to_referer_or {render :text => 'Watcher added.', :layout => true}}
format.js
#format.api { render_api_ok }
- end
+ end
end
def destroy
@@ -57,6 +58,7 @@ class WordsController < ApplicationController
text = text.to_s.strip.gsub(%r{((.|\s)*?)
}m, '[...]')
@content = "#{ll(Setting.default_language, :text_user_wrote, user)}\n> "
@content << text.gsub(/(\r?\n|\r\n?)/, "\n> ") + "\n\n"
+ @id = user.id
rescue ActiveRecord::RecordNotFound
render_404
end
diff --git a/app/helpers/bids_helper.rb b/app/helpers/bids_helper.rb
index fcd253c84..99154e75f 100644
--- a/app/helpers/bids_helper.rb
+++ b/app/helpers/bids_helper.rb
@@ -14,7 +14,7 @@ module BidsHelper
url = {:controller => 'bids',
:action => 'destroy',
:object_id => journal,
- :bid_id => bid}
+ :id => bid}
links << ' '
links << link_to(image_tag('delete.png'), url,
:remote => true, :method => 'delete', :class => "delete", :title => l(:button_delete))
diff --git a/app/models/bid.rb b/app/models/bid.rb
index ccc6247f2..0a3016539 100644
--- a/app/models/bid.rb
+++ b/app/models/bid.rb
@@ -40,8 +40,8 @@ class Bid < ActiveRecord::Base
acts_as_activity_provider :find_options => {:include => [:author]},
:author_key => :author_id
- def add_jour(user, notes)
- self.journals_for_messages << JournalsForMessage.new(:user_id => user.id, :notes => notes)
+ def add_jour(user, notes, reference_user_id = 0)
+ self.journals_for_messages << JournalsForMessage.new(:user_id => user.id, :notes => notes, :reply_id => reference_user_id)
end
def self.creat_bids(budget, deadline, name, description=nil)
diff --git a/app/models/journals_for_message.rb b/app/models/journals_for_message.rb
index c3085d1cf..2d53be81a 100644
--- a/app/models/journals_for_message.rb
+++ b/app/models/journals_for_message.rb
@@ -10,4 +10,14 @@ class JournalsForMessage < ActiveRecord::Base
self.delete_all "id = #{message_id}"
end
+ def reference_user
+ User.find(reply_id)
+ end
+
+ def self.reference_message(user_id)
+ @user = User.find(user_id)
+ message = JournalsForMessage.find_by_sql("select * from journals_for_messages where reply_id = #{@user.id} or (jour_type = 'Bid' and jour_id in (select id from bids where author_id = #{@user.id}))", )
+ message
+ end
+
end
diff --git a/app/models/user.rb b/app/models/user.rb
index e4667f720..6e720c06d 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -90,7 +90,7 @@ class User < Principal
#end
#####fq
has_many :jours, :class_name => 'JournalsForMessage', :dependent => :destroy
- has_many :bids, :dependent => :destroy
+ has_many :bids, :foreign_key => 'author_id', :dependent => :destroy
has_many :journals_for_messages, :as => :jour, :dependent => :destroy
#####
@@ -143,9 +143,9 @@ class User < Principal
scope :sorted, lambda { order(*User.fields_for_order_statement)}
- ###添加留言
- def add_jour(user, notes)
- self.journals_for_messages << JournalsForMessage.new(:user_id => user.id, :notes => notes)
+ ###添加留言 fq
+ def add_jour(user, notes, reference_user_id = 0)
+ self.journals_for_messages << JournalsForMessage.new(:user_id => user.id, :notes => notes, :reply_id => reference_user_id)
end
def set_mail_notification
diff --git a/app/views/bids/_history.html.erb b/app/views/bids/_history.html.erb
index 3df9bc99e..6bc784d3c 100644
--- a/app/views/bids/_history.html.erb
+++ b/app/views/bids/_history.html.erb
@@ -6,14 +6,14 @@
<% unless state%>
<%= link_to l(:button_more),
- {:controller => 'bids', :action => 'more', :bid_id => bid},
+ {:controller => 'bids', :action => 'more', :id => bid},
:remote => true,
:method => 'get' %>
<% else %>
<%= link_to l(:button_back),
- {:controller => 'bids', :action => 'back', :bid_id => bid},
+ {:controller => 'bids', :action => 'back', :id => bid},
:remote => true,
:method => 'get' %>
@@ -47,7 +47,7 @@
<%= journal.created_at %> |
<%= link_to(image_tag('comment.png'), {:controller => 'bids', :action => 'new', :id => bid, :journal_id => journal}, :remote => true,
- :method => 'post', :title => l(:button_quote))%><%= link_to(image_tag('delete.png'), {:controller => 'bids', :action => 'destroy', :object_id => journal, :bid_id => bid},
+ :method => 'post', :title => l(:button_quote))%><%= link_to(image_tag('delete.png'), {:controller => 'bids', :action => 'destroy', :object_id => journal, :id => bid},
:remote => true, :method => 'delete', :class => "delete", :title => l(:button_delete)) if remove_allowed || journal.user_id == User.current.id %> |
diff --git a/app/views/bids/_new.html.erb b/app/views/bids/_new.html.erb
index caf046b78..d203603d7 100644
--- a/app/views/bids/_new.html.erb
+++ b/app/views/bids/_new.html.erb
@@ -38,12 +38,13 @@
<%= form_for('bid_message', :remote => true, :method => :post,
:url => {:controller => 'bids',
:action => 'create',
- :bid_id => bid,
+ :id => bid,
:sta => sta}) do |f|%>
<%= f.text_area 'message', :rows => 3, :cols => 65, :value => "我要反馈", :style => "resize: none;", :class => 'noline'%> |
+ <%= f.text_field :reference_user_id, :style=>"display:none"%>
<%= submit_tag l(:button_leave_meassge), :name => nil , :class => "bid_btn", :onmouseout => "this.style.backgroundPosition = 'left top'", :onmouseover => "this.style.backgroundPosition = 'left -30px'"%>
<%= submit_tag l(:button_clear), :name => nil, :onclick => "clearMessage('bid_message_message');", :type => 'button', :class => "bid_btn", :onmouseout => "this.style.backgroundPosition = 'left top'", :onmouseover => "this.style.backgroundPosition = 'left -30px'" %> |
diff --git a/app/views/bids/back.js.erb b/app/views/bids/back.js.erb
index b2d3c5151..56272cd16 100644
--- a/app/views/bids/back.js.erb
+++ b/app/views/bids/back.js.erb
@@ -1 +1,2 @@
$('#history').html('<%= escape_javascript(render(:partial => 'history', :locals => {:bid => @bid, :journals => @jour, :state => @state})) %>');
+$('#bid_message_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/bids/create.js.erb b/app/views/bids/create.js.erb
index 15cf3f20d..197bfcdcb 100644
--- a/app/views/bids/create.js.erb
+++ b/app/views/bids/create.js.erb
@@ -1,2 +1,3 @@
$('#history').html('<%= escape_javascript(render(:partial => 'bids/history', :locals => {:bid => @bid, :journals => @jour, :state => true})) %>');
-$('#user_message_message').val("");
+$('#bid_message_message').val("");
+$('#bid_message_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/bids/destroy.js.erb b/app/views/bids/destroy.js.erb
index c5e1516b0..ca73a347a 100644
--- a/app/views/bids/destroy.js.erb
+++ b/app/views/bids/destroy.js.erb
@@ -1 +1,2 @@
$('#history').html('<%= escape_javascript(render(:partial => 'history', :locals => {:bid => @bid, :journals => @jour, :state => false})) %>');
+$('#bid_message_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/bids/more.js.erb b/app/views/bids/more.js.erb
index b2d3c5151..56272cd16 100644
--- a/app/views/bids/more.js.erb
+++ b/app/views/bids/more.js.erb
@@ -1 +1,2 @@
$('#history').html('<%= escape_javascript(render(:partial => 'history', :locals => {:bid => @bid, :journals => @jour, :state => @state})) %>');
+$('#bid_message_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/bids/new.js.erb b/app/views/bids/new.js.erb
index 2a4df8a67..5a74ec22f 100644
--- a/app/views/bids/new.js.erb
+++ b/app/views/bids/new.js.erb
@@ -1,2 +1,3 @@
-$('#user_message_message').val("<%= raw escape_javascript(@content) %>");
-showAndScrollTo("user_message", "user_message");
+$('#bid_message_message').val("<%= raw escape_javascript(@content) %>");
+$('#bid_message_reference_user_id').val("<%= @id%>");
+showAndScrollTo("bid_message", "bid_message");
diff --git a/app/views/users/info.html.erb b/app/views/users/info.html.erb
new file mode 100644
index 000000000..6a91e08b8
--- /dev/null
+++ b/app/views/users/info.html.erb
@@ -0,0 +1,36 @@
+
+<% unless @message.empty? %>
+
+ <% @message.sort {|x,y| y.created_at <=> x.created_at }.each do |e| -%>
+
+
+
+ <%= link_to image_tag(url_to_avatar(e.user), :class => "avatar"), user_path(e.user), :class => "avatar" %> |
+
+
+
+ <%= link_to(h(e.user), user_path(e.user)) %>
+ <% if e.jour_type == "Bid"%>
+ 对需求:<%= link_to(e.jour.name, respond_path(e.jour))%>进行了反馈
+ <% elsif e.jour_type == 'Principal' %>
+ 对<%= link_to("我", user_path(e.jour))%>的话进行了引用
+ <% end %>
+ |
+
+
+
+
+ <%= textilizable e.notes %>
+ |
+
+
+ |
+ <%= format_time e.created_at %> |
+
+
+ |
+
+
+ <% end %>
+
+<% end %>
diff --git a/app/views/users/show.html.erb b/app/views/users/show.html.erb
index c924f8d14..4bfc4b070 100644
--- a/app/views/users/show.html.erb
+++ b/app/views/users/show.html.erb
@@ -33,4 +33,4 @@
<% end %>
-<% end %>
+<% end %>
\ No newline at end of file
diff --git a/app/views/words/_new.html.erb b/app/views/words/_new.html.erb
index 4d2b0a7c8..8c007a321 100644
--- a/app/views/words/_new.html.erb
+++ b/app/views/words/_new.html.erb
@@ -7,6 +7,7 @@
:sta => sta}) do |f| %>
<%= label_tag 'user_message', l(:label_leave_message) %><%= f.text_area 'user_message', :rows => 3 %>
+ <%= f.text_field :reference_user_id, :style=>"display:none"%>
<%= submit_tag l(:button_leave_meassge), :name => nil %>
<%= submit_tag l(:button_clear), :name => nil, :onclick => "clearMessage('user_message');", :type => 'button' %>
diff --git a/app/views/words/back.js.erb b/app/views/words/back.js.erb
index 17c8aa9be..fa06ff487 100644
--- a/app/views/words/back.js.erb
+++ b/app/views/words/back.js.erb
@@ -1 +1,2 @@
$('#message').html('<%= escape_javascript(render(:partial => 'words/message', :locals => {:jour => @jour, :state => @state, :user => @user})) %>');
+$('#new_form_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/words/create.js.erb b/app/views/words/create.js.erb
index fa0798a5a..823587b30 100644
--- a/app/views/words/create.js.erb
+++ b/app/views/words/create.js.erb
@@ -1,2 +1,3 @@
$('#message').html('<%= escape_javascript(render(:partial => 'words/message', :locals => {:jour => @jour, :state => false, :user => @user})) %>');
-$('#new_form_user_message').val("");
\ No newline at end of file
+$('#new_form_user_message').val("");
+$('#new_form_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/words/destroy.js.erb b/app/views/words/destroy.js.erb
index d1eeb4d5f..f2030b783 100644
--- a/app/views/words/destroy.js.erb
+++ b/app/views/words/destroy.js.erb
@@ -1 +1,2 @@
$('#message').html('<%= escape_javascript(render(:partial => 'words/message', :locals => {:jour => @jour, :state => false, :user => @user})) %>');
+$('#new_form_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/words/more.js.erb b/app/views/words/more.js.erb
index 17c8aa9be..fa06ff487 100644
--- a/app/views/words/more.js.erb
+++ b/app/views/words/more.js.erb
@@ -1 +1,2 @@
$('#message').html('<%= escape_javascript(render(:partial => 'words/message', :locals => {:jour => @jour, :state => @state, :user => @user})) %>');
+$('#new_form_reference_user_id').val("");
\ No newline at end of file
diff --git a/app/views/words/new.js.erb b/app/views/words/new.js.erb
index 16fabe66f..dc8290a0f 100644
--- a/app/views/words/new.js.erb
+++ b/app/views/words/new.js.erb
@@ -1,2 +1,3 @@
-$('#new_form_user_message').val("<%= raw escape_javascript(@content) %>");
+$('#new_form_user_message').val("<%= raw escape_javascript(@content)%>");
+$('#new_form_reference_user_id').val("<%= @id %>");
showAndScrollTo("new_form_user_message", "new_form_user_message");
diff --git a/config/locales/zh.yml b/config/locales/zh.yml
index addafbc49..e1caac4ff 100644
--- a/config/locales/zh.yml
+++ b/config/locales/zh.yml
@@ -1158,4 +1158,5 @@ zh:
label_bidding_project: 应标项目
button_bidding: 我要应标
button_new_bid: 发布需求
+ label_user_information: "与我相关"
diff --git a/config/routes.rb b/config/routes.rb
index 8144504c3..3de86aded 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -75,6 +75,7 @@ RedmineApp::Application.routes.draw do
match 'user_activities', :to => 'users#show', :via => :get, :as => "user_activities"
match 'user_newfeedback', :to => 'users#user_newfeedback', :via => :get, :as => "user_newfeedback"
match 'watch_bids', :controller => 'users', :action => 'watch_bids', :via => [:get , :post]
+ match 'info', :to => 'users#info', :via => [:get , :post], :as => 'user_info'
end
end
#end
@@ -407,22 +408,20 @@ RedmineApp::Application.routes.draw do
delete 'words/destroy', :to => 'words#destroy'
get 'words/more', :to => 'words#more'
get 'words/back', :to=> 'words#back'
- ##############
+ ############## fq
post 'bids/create', :to => 'bids#create'
delete 'bids/destroy', :to => 'bids#destroy'
+ match 'bids/new', :controller => 'bids', :action => 'new', :via => [:get , :post]
get 'bids/more', :to => 'bids#more'
get 'bids/back', :to=> 'bids#back'
+ match 'bids/new_bid', :controller => 'bids', :action => 'new_bid'
match 'bids/:id/show_project', :controller => 'bids', :action => 'show_project', :as => 'project_for_bid'
match 'bids/:id/add', :controller => 'bids', :action => 'add'
- match 'bids/new_bid', :controller => 'bids', :action => 'new_bid'
# added by young
match 'bids', :controller => 'bids', :action => 'index'
match 'bids/:id', :controller => 'bids', :action => 'show', :as => 'respond'
- match 'bids/new', :controller => 'bids', :action => 'new', :via => [:get , :post]
-
-
########### added by liuping
match 'tags/add_tag',:to => 'tags#add_tag',:as=>"add_tag"
match 'tags/delete_tag',:to => 'tags#delete_tag',:as=>"add_tag"
diff --git a/lib/redmine.rb b/lib/redmine.rb
index a752c8168..e672e6608 100644
--- a/lib/redmine.rb
+++ b/lib/redmine.rb
@@ -267,9 +267,11 @@ end
#added by young
Redmine::MenuManager.map :user_menu do |menu|
menu.push :activity, {:controller => 'users', :action => 'show' }
+ menu.push :user_information, {:controller => 'users', :action => 'info'}
menu.push :project, {:controller => 'users', :action => 'user_projects'}
menu.push :requirement_focus, {:controller => 'users', :action => 'watch_bids'}
menu.push :user_newfeedback, {:controller => 'users', :action => 'user_newfeedback'}
+
end
#end