summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/controllers/issues_controller.rb16
-rw-r--r--app/views/issues/_pdf.rfpdf24
-rw-r--r--app/views/issues/show.rfpdf (renamed from app/views/issues/export_pdf.rfpdf)2
-rw-r--r--app/views/issues/show.rhtml2
-rw-r--r--lib/redmine.rb2
5 files changed, 25 insertions, 21 deletions
diff --git a/app/controllers/issues_controller.rb b/app/controllers/issues_controller.rb
index 716816e34..d8fd95b6a 100644
--- a/app/controllers/issues_controller.rb
+++ b/app/controllers/issues_controller.rb
@@ -58,15 +58,17 @@ class IssuesController < ApplicationController
end
def show
- @status_options = @issue.status.find_new_statuses_allowed_to(logged_in_user.role_for_project(@project), @issue.tracker) if logged_in_user
@custom_values = @issue.custom_values.find(:all, :include => :custom_field)
@journals = @issue.journals.find(:all, :include => [:user, :details], :order => "#{Journal.table_name}.created_on ASC")
- end
-
- def export_pdf
- @custom_values = @issue.custom_values.find(:all, :include => :custom_field)
- @options_for_rfpdf ||= {}
- @options_for_rfpdf[:file_name] = "#{@project.name}_#{@issue.id}.pdf"
+
+ if params[:format]=='pdf'
+ @options_for_rfpdf ||= {}
+ @options_for_rfpdf[:file_name] = "#{@project.identifier}-#{@issue.id}.pdf"
+ render :template => 'issues/show.rfpdf', :layout => false
+ else
+ @status_options = @issue.status.find_new_statuses_allowed_to(logged_in_user.role_for_project(@project), @issue.tracker) if logged_in_user
+ render :template => 'issues/show.rhtml'
+ end
end
def edit
diff --git a/app/views/issues/_pdf.rfpdf b/app/views/issues/_pdf.rfpdf
index 485066894..558399abb 100644
--- a/app/views/issues/_pdf.rfpdf
+++ b/app/views/issues/_pdf.rfpdf
@@ -70,7 +70,7 @@
pdf.SetFontStyle('B',9)
pdf.Cell(190,5, l(:label_history), "B")
pdf.Ln
- for journal in issue.journals.find(:all, :include => :user, :order => "journals.created_on desc")
+ for journal in issue.journals.find(:all, :include => [:user, :details], :order => "#{Journal.table_name}.created_on ASC")
pdf.SetFontStyle('B',8)
pdf.Cell(190,5, format_time(journal.created_on) + " - " + journal.user.name)
pdf.Ln
@@ -86,15 +86,17 @@
pdf.Ln
end
- pdf.SetFontStyle('B',9)
- pdf.Cell(190,5, l(:label_attachment_plural), "B")
- pdf.Ln
- for attachment in issue.attachments
- pdf.SetFontStyle('',8)
- pdf.Cell(80,5, attachment.filename)
- pdf.Cell(20,5, number_to_human_size(attachment.filesize),0,0,"R")
- pdf.Cell(25,5, format_date(attachment.created_on),0,0,"R")
- pdf.Cell(65,5, attachment.author.name,0,0,"R")
+ if issue.attachments.any?
+ pdf.SetFontStyle('B',9)
+ pdf.Cell(190,5, l(:label_attachment_plural), "B")
pdf.Ln
+ for attachment in issue.attachments
+ pdf.SetFontStyle('',8)
+ pdf.Cell(80,5, attachment.filename)
+ pdf.Cell(20,5, number_to_human_size(attachment.filesize),0,0,"R")
+ pdf.Cell(25,5, format_date(attachment.created_on),0,0,"R")
+ pdf.Cell(65,5, attachment.author.name,0,0,"R")
+ pdf.Ln
+ end
end
-%> \ No newline at end of file
+%>
diff --git a/app/views/issues/export_pdf.rfpdf b/app/views/issues/show.rfpdf
index 51a71c0c1..08f2cb92d 100644
--- a/app/views/issues/export_pdf.rfpdf
+++ b/app/views/issues/show.rfpdf
@@ -7,4 +7,4 @@
render :partial => 'issues/pdf', :locals => { :pdf => pdf, :issue => @issue }
%>
-<%= pdf.Output %> \ No newline at end of file
+<%= pdf.Output %>
diff --git a/app/views/issues/show.rhtml b/app/views/issues/show.rhtml
index 9075df9f9..ed615c69f 100644
--- a/app/views/issues/show.rhtml
+++ b/app/views/issues/show.rhtml
@@ -111,7 +111,7 @@ end %>
<% end %>
<div class="contextual">
-<%= l(:label_export_to) %><%= link_to 'PDF', {:action => 'export_pdf', :id => @issue}, :class => 'icon icon-pdf' %>
+<%= l(:label_export_to) %><%= link_to 'PDF', {:format => 'pdf'}, :class => 'icon icon-pdf' %>
</div>
&nbsp;
diff --git a/lib/redmine.rb b/lib/redmine.rb
index 7217abe16..f5682a959 100644
--- a/lib/redmine.rb
+++ b/lib/redmine.rb
@@ -25,7 +25,7 @@ Redmine::AccessControl.map do |map|
map.permission :manage_categories, {:projects => [:settings, :add_issue_category], :issue_categories => [:edit, :destroy]}, :require => :member
# Issues
map.permission :view_issues, {:projects => [:list_issues, :export_issues_csv, :export_issues_pdf, :changelog, :roadmap],
- :issues => [:show, :export_pdf],
+ :issues => :show,
:queries => :index,
:reports => :issue_report}, :public => true
map.permission :add_issues, {:projects => :add_issue}, :require => :loggedin