Feature #33641 » 33641-v3.patch
| app/helpers/application_helper.rb | ||
|---|---|---|
| 642 | 642 | end | 
| 643 | 643 | |
| 644 | 644 |   def authoring(created, author, options={}) | 
| 645 | l(options[:label] || :label_added_time_by, :author => link_to_user(author), :age => time_tag(created)).html_safe | |
| 645 |     l(options[:label] || :label_added_time_by, :author => link_to_user(author), :badge => options[:badge], :age => time_tag(created)).html_safe | |
| 646 | 646 | end | 
| 647 | 647 | |
| 648 | 648 | def time_tag(time) | 
| app/helpers/journals_helper.rb | ||
|---|---|---|
| 68 | 68 | css_classes = journal.private_notes? ? 'badge badge-private private' : '' | 
| 69 | 69 |     content_tag('span', content.html_safe, :id => "journal-#{journal.id}-private_notes", :class => css_classes) | 
| 70 | 70 | end | 
| 71 | ||
| 72 | def journal_user_badge(journal) | |
| 73 | issue = journal&.journalized | |
| 74 | return '' if issue.nil? | |
| 75 | ||
| 76 | # Show only "Author" badge if the user is both an author and an assignee | |
| 77 | case journal.user | |
| 78 | when issue.author | |
| 79 |       content_tag('span', l(:label_author), class: 'badge badge-user-author') | |
| 80 | when issue.assigned_to | |
| 81 |       content_tag('span', l(:field_assigned_to), class: 'badge badge-user-assignee') | |
| 82 | else | |
| 83 | '' | |
| 84 | end | |
| 85 | end | |
| 71 | 86 | end | 
| app/helpers/messages_helper.rb | ||
|---|---|---|
| 18 | 18 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
| 19 | 19 | |
| 20 | 20 | module MessagesHelper | 
| 21 | def message_user_badge(message) | |
| 22 | return '' if message&.parent.nil? | |
| 23 | ||
| 24 | if message.parent.author == message.author | |
| 25 |       content_tag('span', l(:label_author), class: 'badge badge-user-author') | |
| 26 | else | |
| 27 | '' | |
| 28 | end | |
| 29 | end | |
| 21 | 30 | end | 
| app/helpers/news_helper.rb | ||
|---|---|---|
| 18 | 18 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
| 19 | 19 | |
| 20 | 20 | module NewsHelper | 
| 21 | def news_comment_user_badge(comment) | |
| 22 | return '' if comment&.commented.nil? | |
| 23 | ||
| 24 | if comment.commented.author == comment.author | |
| 25 |       content_tag('span', l(:label_author), class: 'badge badge-user-author') | |
| 26 | else | |
| 27 | '' | |
| 28 | end | |
| 29 | end | |
| 21 | 30 | end | 
| app/helpers/wiki_helper.rb | ||
|---|---|---|
| 66 | 66 | end | 
| 67 | 67 | |
| 68 | 68 | def wiki_content_update_info(content) | 
| 69 | l(:label_updated_time_by, :author => link_to_user(content.author), :age => time_tag(content.updated_on)).html_safe | |
| 69 |     l(:label_updated_time_by, :author => link_to_user(content.author), :age => time_tag(content.updated_on), :badge => '').html_safe | |
| 70 | 70 | end | 
| 71 | 71 | end | 
| app/views/issues/tabs/_history.html.erb | ||
|---|---|---|
| 13 | 13 | </div> | 
| 14 | 14 | <h4 class='note-header'> | 
| 15 | 15 | <%= avatar(journal.user) %> | 
| 16 | <%= authoring journal.created_on, journal.user, :label => :label_updated_time_by %> | |
| 16 |       <%= authoring journal.created_on, journal.user, :label => :label_updated_time_by, :badge => journal_user_badge(journal) %> | |
| 17 | 17 | <%= render_private_notes_indicator(journal) %> | 
| 18 | 18 | </h4> | 
| 19 | 19 | |
| app/views/messages/show.html.erb | ||
|---|---|---|
| 69 | 69 | <%= avatar(message.author) %> | 
| 70 | 70 |     <%= link_to message.subject, { :controller => 'messages', :action => 'show', :board_id => @board, :id => @topic, :r => message, :anchor => "message-#{message.id}" } %> | 
| 71 | 71 | - | 
| 72 | <%= authoring message.created_on, message.author %> | |
| 72 |     <%= authoring message.created_on, message.author, :badge => message_user_badge(message) %> | |
| 73 | 73 | </h4> | 
| 74 | 74 | <div class="wiki"><%= textilizable message, :content, :attachments => message.attachments %></div> | 
| 75 | 75 | <%= link_to_attachments message, :author => false, :thumbnails => true %> | 
| app/views/news/show.html.erb | ||
|---|---|---|
| 42 | 42 | :title => l(:button_delete), | 
| 43 | 43 | :class => 'icon-only icon-del' %> | 
| 44 | 44 | </div> | 
| 45 | <h4><%= avatar(comment.author) %><%= authoring comment.created_on, comment.author %></h4> | |
| 45 |     <h4><%= avatar(comment.author) %><%= authoring comment.created_on, comment.author, :badge => news_comment_user_badge(comment) %></h4> | |
| 46 | 46 | <div class="wiki"> | 
| 47 | 47 | <%= textilizable(comment.comments) %> | 
| 48 | 48 | </div> | 
| config/locales/en.yml | ||
|---|---|---|
| 895 | 895 | label_missing_feeds_access_key: Missing a Atom access key | 
| 896 | 896 |   label_feeds_access_key_created_on: "Atom access key created %{value} ago" | 
| 897 | 897 | label_module_plural: Modules | 
| 898 |   label_added_time_by: "Added by %{author} %{age} ago" | |
| 899 |   label_updated_time_by: "Updated by %{author} %{age} ago" | |
| 898 |   label_added_time_by: "Added by %{author} %{badge} %{age} ago" | |
| 899 |   label_updated_time_by: "Updated by %{author} %{badge} %{age} ago" | |
| 900 | 900 |   label_updated_time: "Updated %{value} ago" | 
| 901 | 901 | label_jump_to_a_project: Jump to a project... | 
| 902 | 902 | label_file_plural: Files | 
| ... | ... | |
| 1089 | 1089 | label_display_type_board: Board | 
| 1090 | 1090 | label_my_bookmarks: My bookmarks | 
| 1091 | 1091 | label_assign_to_me: Assign to me | 
| 1092 | label_author: Author | |
| 1092 | 1093 | |
| 1093 | 1094 | button_login: Login | 
| 1094 | 1095 | button_submit: Submit | 
| public/stylesheets/application.css | ||
|---|---|---|
| 1446 | 1446 | color: #1D781D; | 
| 1447 | 1447 | border: 1px solid #1D781D; | 
| 1448 | 1448 | } | 
| 1449 | .badge-user-author { | |
| 1450 | color: #205D86; | |
| 1451 | border: 1px solid #205D86; | |
| 1452 | } | |
| 1453 | .badge-user-assignee { | |
| 1454 | color: #205D86; | |
| 1455 | border: 1px solid #205D86; | |
| 1456 | } | |
| 1457 | ||
| 1449 | 1458 | /***** Tooltips *****/ | 
| 1450 | 1459 | .ui-tooltip { | 
| 1451 | 1460 | background: #000; | 
| test/helpers/journals_helper_test.rb | ||
|---|---|---|
| 49 | 49 | assert_kind_of Attachment, thumbnails.first | 
| 50 | 50 | assert_equal 'image.png', thumbnails.first.filename | 
| 51 | 51 | end | 
| 52 | ||
| 53 | def test_journal_user_badge | |
| 54 | issue = Issue.generate!(:author_id => 1, :assigned_to_id => 2) | |
| 55 | ||
| 56 | journal = issue.init_journal(User.find(1), "Updated by an author") | |
| 57 | assert_equal '<span class="badge badge-user-author">Author</span>', journal_user_badge(journal) | |
| 58 | ||
| 59 | issue.clear_journal | |
| 60 | journal = issue.init_journal(User.find(2), "Updated by an assignee") | |
| 61 | assert_equal '<span class="badge badge-user-assignee">Assignee</span>', journal_user_badge(journal) | |
| 62 | ||
| 63 | issue.clear_journal | |
| 64 | issue.update_attribute(:assigned_to_id, 1) | |
| 65 | journal = issue.init_journal(User.find(1), "The user is both an author and an assignee") | |
| 66 | assert_equal '<span class="badge badge-user-author">Author</span>', journal_user_badge(journal) | |
| 67 | end | |
| 52 | 68 | end | 
| test/helpers/messages_helper_test.rb | ||
|---|---|---|
| 1 | # frozen_string_literal: true | |
| 2 | ||
| 3 | # Redmine - project management software | |
| 4 | # Copyright (C) 2006-2020 Jean-Philippe Lang | |
| 5 | # | |
| 6 | # This program is free software; you can redistribute it and/or | |
| 7 | # modify it under the terms of the GNU General Public License | |
| 8 | # as published by the Free Software Foundation; either version 2 | |
| 9 | # of the License, or (at your option) any later version. | |
| 10 | # | |
| 11 | # This program is distributed in the hope that it will be useful, | |
| 12 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | # GNU General Public License for more details. | |
| 15 | # | |
| 16 | # You should have received a copy of the GNU General Public License | |
| 17 | # along with this program; if not, write to the Free Software | |
| 18 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | |
| 19 | ||
| 20 | require File.expand_path('../../test_helper', __FILE__) | |
| 21 | ||
| 22 | class MessagesHelperTest < Redmine::HelperTest | |
| 23 | include MessagesHelper | |
| 24 | ||
| 25 | fixtures :messages, :users | |
| 26 | ||
| 27 | def test_message_user_badge | |
| 28 | assert_equal '<span class="badge badge-user-author">Author</span>', message_user_badge(messages(:messages_002)) | |
| 29 | assert_empty message_user_badge(messages(:messages_001)) | |
| 30 | end | |
| 31 | end | |
| test/helpers/news_helper_test.rb | ||
|---|---|---|
| 1 | # frozen_string_literal: true | |
| 2 | ||
| 3 | # Redmine - project management software | |
| 4 | # Copyright (C) 2006-2020 Jean-Philippe Lang | |
| 5 | # | |
| 6 | # This program is free software; you can redistribute it and/or | |
| 7 | # modify it under the terms of the GNU General Public License | |
| 8 | # as published by the Free Software Foundation; either version 2 | |
| 9 | # of the License, or (at your option) any later version. | |
| 10 | # | |
| 11 | # This program is distributed in the hope that it will be useful, | |
| 12 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | # GNU General Public License for more details. | |
| 15 | # | |
| 16 | # You should have received a copy of the GNU General Public License | |
| 17 | # along with this program; if not, write to the Free Software | |
| 18 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | |
| 19 | ||
| 20 | require File.expand_path('../../test_helper', __FILE__) | |
| 21 | ||
| 22 | class NewsHelperTest < Redmine::HelperTest | |
| 23 | include NewsHelper | |
| 24 | ||
| 25 | fixtures :news, :comments, :users | |
| 26 | ||
| 27 | def test_news_comment_user_badge | |
| 28 | assert_equal '<span class="badge badge-user-author">Author</span>', news_comment_user_badge(comments(:comments_002)) | |
| 29 | assert_empty news_comment_user_badge(comments(:comments_001)) | |
| 30 | end | |
| 31 | end | |