diff --git a/app/controllers/messages_controller.rb b/app/controllers/messages_controller.rb index 08c77d7d2..554279d21 100644 --- a/app/controllers/messages_controller.rb +++ b/app/controllers/messages_controller.rb @@ -22,7 +22,9 @@ class MessagesController < ApplicationController before_filter :authorize, :except => :preview verify :method => :post, :only => [ :reply, :destroy ], :redirect_to => { :action => :show } + verify :xhr => true, :only => :quote + helper :attachments include AttachmentsHelper @@ -82,6 +84,20 @@ class MessagesController < ApplicationController { :action => 'show', :id => @message.parent } end + def quote + user = @message.author + text = @message.content + content = "#{ll(Setting.default_language, :text_user_wrote, user)}\\n> " + content << text.to_s.strip.gsub(%r{
((.|\s)*?)
}m, '[...]').gsub('"', '\"').gsub(/(\r?\n|\r\n?)/, "\\n> ") + "\\n\\n" + render(:update) { |page| + page.<< "$('message_content').value = \"#{content}\";" + page.show 'reply' + page << "Form.Element.focus('message_content');" + page << "Element.scrollTo('reply');" + page << "$('message_content').scrollTop = $('message_content').scrollHeight - $('message_content').clientHeight;" + } + end + def preview message = @board.messages.find_by_id(params[:id]) @attachements = message.attachments if message diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb index ed5c6bdb7..78e5bdc65 100644 --- a/app/helpers/application_helper.rb +++ b/app/helpers/application_helper.rb @@ -34,6 +34,12 @@ module ApplicationHelper def link_to_if_authorized(name, options = {}, html_options = nil, *parameters_for_method_reference) link_to(name, options, html_options, *parameters_for_method_reference) if authorize_for(options[:controller] || params[:controller], options[:action]) end + + # Display a link to remote if user is authorized + def link_to_remote_if_authorized(name, options = {}, html_options = nil) + url = options[:url] || {} + link_to_remote(name, options, html_options) if authorize_for(url[:controller] || params[:controller], url[:action]) + end # Display a link to user's account page def link_to_user(user) diff --git a/app/views/messages/show.rhtml b/app/views/messages/show.rhtml index 7e5975bfd..c24be7a21 100644 --- a/app/views/messages/show.rhtml +++ b/app/views/messages/show.rhtml @@ -2,6 +2,7 @@ link_to(h(@board.name), {:controller => 'boards', :action => 'show', :project_id => @project, :id => @board}) %>
+ <%= link_to_remote_if_authorized l(:button_quote), { :url => {:action => 'quote', :id => @topic} }, :class => 'icon icon-comment' %> <%= link_to_if_authorized l(:button_edit), {:action => 'edit', :id => @topic}, :class => 'icon icon-edit' %> <%= link_to_if_authorized l(:button_delete), {:action => 'destroy', :id => @topic}, :method => :post, :confirm => l(:text_are_you_sure), :class => 'icon icon-del' %>
@@ -22,6 +23,7 @@ <% @replies.each do |message| %> ">
+ <%= link_to_remote_if_authorized image_tag('comment.png'), { :url => {:action => 'quote', :id => message} }, :title => l(:button_quote) %> <%= link_to_if_authorized image_tag('edit.png'), {:action => 'edit', :id => message}, :title => l(:button_edit) %> <%= link_to_if_authorized image_tag('delete.png'), {:action => 'destroy', :id => message}, :method => :post, :confirm => l(:text_are_you_sure), :title => l(:button_delete) %>
diff --git a/lang/bg.yml b/lang/bg.yml index f15ba4da7..1f174e29f 100644 --- a/lang/bg.yml +++ b/lang/bg.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/cs.yml b/lang/cs.yml index b7b1b9eaf..609e95478 100644 --- a/lang/cs.yml +++ b/lang/cs.yml @@ -640,3 +640,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/da.yml b/lang/da.yml index 3227dc7bd..a76e7ea5c 100644 --- a/lang/da.yml +++ b/lang/da.yml @@ -637,3 +637,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/de.yml b/lang/de.yml index 5093c31fd..e309dfb57 100644 --- a/lang/de.yml +++ b/lang/de.yml @@ -636,3 +636,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/en.yml b/lang/en.yml index 6cd6d4270..5f552774c 100644 --- a/lang/en.yml +++ b/lang/en.yml @@ -561,6 +561,7 @@ button_copy: Copy button_annotate: Annotate button_update: Update button_configure: Configure +button_quote: Quote status_active: active status_registered: registered diff --git a/lang/es.yml b/lang/es.yml index 58d27f28d..fc9540a02 100644 --- a/lang/es.yml +++ b/lang/es.yml @@ -638,3 +638,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/fi.yml b/lang/fi.yml index 394ff23f3..6eb16bfac 100644 --- a/lang/fi.yml +++ b/lang/fi.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/fr.yml b/lang/fr.yml index e6c4b3340..81e44949f 100644 --- a/lang/fr.yml +++ b/lang/fr.yml @@ -561,6 +561,7 @@ button_copy: Copier button_annotate: Annoter button_update: Mettre à jour button_configure: Configurer +button_quote: Citer status_active: actif status_registered: enregistré diff --git a/lang/he.yml b/lang/he.yml index 652b0ed8e..77fe32e53 100644 --- a/lang/he.yml +++ b/lang/he.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/hu.yml b/lang/hu.yml index 15c420539..208b6fe1e 100644 --- a/lang/hu.yml +++ b/lang/hu.yml @@ -636,3 +636,4 @@ text_email_delivery_not_configured: "Az E-mail küldés nincs konfigurálva, és field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/it.yml b/lang/it.yml index 3e1c1d53b..d123e913a 100644 --- a/lang/it.yml +++ b/lang/it.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "La consegna via e-mail non è configurata e field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/ja.yml b/lang/ja.yml index e7805393a..5a728fb02 100644 --- a/lang/ja.yml +++ b/lang/ja.yml @@ -636,3 +636,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/ko.yml b/lang/ko.yml index c85ce72e2..16bd65364 100644 --- a/lang/ko.yml +++ b/lang/ko.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/lt.yml b/lang/lt.yml index 188faf215..2a75a95ea 100644 --- a/lang/lt.yml +++ b/lang/lt.yml @@ -638,3 +638,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/nl.yml b/lang/nl.yml index fd5bff1f6..f79e78994 100644 --- a/lang/nl.yml +++ b/lang/nl.yml @@ -636,3 +636,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/no.yml b/lang/no.yml index 2cdc0bcd6..6643f9c86 100644 --- a/lang/no.yml +++ b/lang/no.yml @@ -636,3 +636,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/pl.yml b/lang/pl.yml index 69e04e4dd..2df921b71 100644 --- a/lang/pl.yml +++ b/lang/pl.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/pt-br.yml b/lang/pt-br.yml index 2b25e023f..8cd171b72 100644 --- a/lang/pt-br.yml +++ b/lang/pt-br.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/pt.yml b/lang/pt.yml index 6505b762a..5562ca4ac 100644 --- a/lang/pt.yml +++ b/lang/pt.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/ro.yml b/lang/ro.yml index 4887bcf92..5bb49ecec 100644 --- a/lang/ro.yml +++ b/lang/ro.yml @@ -635,3 +635,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/ru.yml b/lang/ru.yml index 095e4db34..01cdcd478 100644 --- a/lang/ru.yml +++ b/lang/ru.yml @@ -639,3 +639,4 @@ text_email_delivery_not_configured: "Параметры работы с почт field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/sr.yml b/lang/sr.yml index f81d0e054..566a46d9f 100644 --- a/lang/sr.yml +++ b/lang/sr.yml @@ -636,3 +636,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/sv.yml b/lang/sv.yml index 5e120b3f2..4cb1f073b 100644 --- a/lang/sv.yml +++ b/lang/sv.yml @@ -636,3 +636,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/th.yml b/lang/th.yml index 3ae37e551..2c3977de2 100644 --- a/lang/th.yml +++ b/lang/th.yml @@ -638,3 +638,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/uk.yml b/lang/uk.yml index cf5f384b9..7ba152413 100644 --- a/lang/uk.yml +++ b/lang/uk.yml @@ -637,3 +637,4 @@ text_email_delivery_not_configured: "Email delivery is not configured, and notif field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/zh-tw.yml b/lang/zh-tw.yml index f13331df4..6a1441364 100644 --- a/lang/zh-tw.yml +++ b/lang/zh-tw.yml @@ -636,3 +636,4 @@ enumeration_activities: 活動 (時間追蹤) field_parent_title: Parent page label_issue_watchers: Watchers setting_commit_logs_encoding: Commit messages encoding +button_quote: Quote diff --git a/lang/zh.yml b/lang/zh.yml index 07829a541..bfe551093 100644 --- a/lang/zh.yml +++ b/lang/zh.yml @@ -636,3 +636,4 @@ default_activity_development: 开发 enumeration_issue_priorities: 问题优先级 enumeration_doc_categories: 文档类别 enumeration_activities: 活动(时间跟踪) +button_quote: Quote diff --git a/lib/redmine.rb b/lib/redmine.rb index 9890ab06f..33d33752b 100644 --- a/lib/redmine.rb +++ b/lib/redmine.rb @@ -92,7 +92,7 @@ Redmine::AccessControl.map do |map| map.project_module :boards do |map| map.permission :manage_boards, {:boards => [:new, :edit, :destroy]}, :require => :member map.permission :view_messages, {:boards => [:index, :show], :messages => [:show]}, :public => true - map.permission :add_messages, {:messages => [:new, :reply]} + map.permission :add_messages, {:messages => [:new, :reply, :quote]} map.permission :edit_messages, {:messages => :edit}, :require => :member map.permission :delete_messages, {:messages => :destroy}, :require => :member end diff --git a/public/stylesheets/application.css b/public/stylesheets/application.css index c7e9284d2..e5ca9e8f2 100644 --- a/public/stylesheets/application.css +++ b/public/stylesheets/application.css @@ -599,6 +599,7 @@ vertical-align: middle; .icon-checked { background-image: url(../images/true.png); } .icon-details { background-image: url(../images/zoom_in.png); } .icon-report { background-image: url(../images/report.png); } +.icon-comment { background-image: url(../images/comment.png); } .icon22-projects { background-image: url(../images/22x22/projects.png); } .icon22-users { background-image: url(../images/22x22/users.png); } diff --git a/test/functional/messages_controller_test.rb b/test/functional/messages_controller_test.rb index 1fe8d086a..b1b3ea942 100644 --- a/test/functional/messages_controller_test.rb +++ b/test/functional/messages_controller_test.rb @@ -40,6 +40,15 @@ class MessagesControllerTest < Test::Unit::TestCase assert_not_nil assigns(:topic) end + def test_show_with_reply_permission + @request.session[:user_id] = 2 + get :show, :board_id => 1, :id => 1 + assert_response :success + assert_template 'show' + assert_tag :div, :attributes => { :id => 'reply' }, + :descendant => { :tag => 'textarea', :attributes => { :id => 'message_content' } } + end + def test_show_message_not_found get :show, :board_id => 1, :id => 99999 assert_response 404 @@ -108,4 +117,11 @@ class MessagesControllerTest < Test::Unit::TestCase assert_redirected_to 'boards/show' assert_nil Message.find_by_id(1) end + + def test_quote + @request.session[:user_id] = 2 + xhr :get, :quote, :board_id => 1, :id => 3 + assert_response :success + assert_select_rjs :show, 'reply' + end end