]> source.dussan.org Git - redmine.git/commitdiff
Thumbnails in issue history (#13429).
authorJean-Philippe Lang <jp_lang@yahoo.fr>
Sat, 24 Oct 2015 05:51:14 +0000 (05:51 +0000)
committerJean-Philippe Lang <jp_lang@yahoo.fr>
Sat, 24 Oct 2015 05:51:14 +0000 (05:51 +0000)
git-svn-id: http://svn.redmine.org/redmine/trunk@14731 e93f8b46-1217-0410-a6f0-8f06a7374b81

app/helpers/journals_helper.rb
app/views/issues/_history.html.erb
public/stylesheets/application.css
test/unit/helpers/journals_helper_test.rb [new file with mode: 0644]

index dfe729506a7f738fe8af93018ba3aacd24e96358..d6d6ec4e9af2f31f69f5e72ddfe9b3cd037a5d06 100644 (file)
 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 
 module JournalsHelper
+
+  # Returns the attachments of a journal that are displayed as thumbnails
+  def journal_thumbnail_attachments(journal)
+    ids = journal.details.select {|d| d.property == 'attachment' && d.value.present?}.map(&:prop_key)
+    ids.any? ? Attachment.where(:id => ids).select(&:thumbnailable?) : []
+  end
+
   def render_notes(issue, journal, options={})
     content = ''
     editable = User.current.logged? && (User.current.allowed_to?(:edit_issue_notes, issue.project) || (journal.user == User.current && User.current.allowed_to?(:edit_own_issue_notes, issue.project)))
index fc4593ab87525b44a161a200511afe0d1e918043..993dfee3c3c9a64b07d7bcb3a00fd19d0d1b92b0 100644 (file)
        <li><%= string %></li>
       <% end %>
     </ul>
+    <% if Setting.thumbnails_enabled? && (thumbnail_attachments = journal_thumbnail_attachments(journal)).any? %>
+      <div class="thumbnails">
+        <% thumbnail_attachments.each do |attachment| %>
+          <div><%= thumbnail_tag(attachment) %></div>
+        <% end %>
+      </div>
+    <% end %>
     <% end %>
     <%= render_notes(issue, journal, :reply_links => reply_links) unless journal.notes.blank? %>
     </div>
index f134fdf6699d89a1164110cbff2e172de169897c..7c93063756d1a686f0d8c75c6401e91f931d2e30 100644 (file)
@@ -599,7 +599,8 @@ div.attachments span.author { font-size: 0.9em; color: #888; }
 
 div.thumbnails {margin-top:0.6em;}
 div.thumbnails div {background:#fff;border:2px solid #ddd;display:inline-block;margin-right:2px;}
-div.thumbnails img {margin: 3px;}
+div.thumbnails img {margin: 3px; vertical-align: middle;}
+#history div.thumbnails {margin-left: 2em;}
 
 p.other-formats { text-align: right; font-size:0.9em; color: #666; }
 .other-formats span + span:before { content: "| "; }
diff --git a/test/unit/helpers/journals_helper_test.rb b/test/unit/helpers/journals_helper_test.rb
new file mode 100644 (file)
index 0000000..eb3b222
--- /dev/null
@@ -0,0 +1,48 @@
+# Redmine - project management software
+# Copyright (C) 2006-2015  Jean-Philippe Lang
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
+
+require File.expand_path('../../../test_helper', __FILE__)
+
+class JournalsHelperTest < ActionView::TestCase
+  include JournalsHelper
+
+  fixtures :projects, :trackers, :issue_statuses, :issues,
+           :enumerations, :issue_categories,
+           :projects_trackers,
+           :users, :roles, :member_roles, :members,
+           :enabled_modules,
+           :custom_fields,
+           :attachments,
+           :versions
+
+  def test_journal_thumbnail_attachments_should_return_thumbnailable_attachments
+    issue = Issue.generate!
+    
+    journal = new_record(Journal) do
+      issue.init_journal(User.find(1))
+      issue.attachments << Attachment.new(:file => mock_file_with_options(:original_filename => 'image.png'), :author => User.find(1))
+      issue.attachments << Attachment.new(:file => mock_file_with_options(:original_filename => 'foo'), :author => User.find(1))
+      issue.save
+    end
+    assert_equal 2, journal.details.count
+
+    thumbnails = journal_thumbnail_attachments(journal)
+    assert_equal 1, thumbnails.count
+    assert_kind_of Attachment, thumbnails.first
+    assert_equal 'image.png', thumbnails.first.filename
+  end
+end