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 |
|