项目issue导出excel功能
This commit is contained in:
parent
4d97dd3889
commit
2ae7dd0087
|
@ -1,3 +1,4 @@
|
|||
# encoding: utf-8
|
||||
# Redmine - project management software
|
||||
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
||||
#
|
||||
|
@ -685,6 +686,90 @@ class ApplicationController < ActionController::Base
|
|||
:content_type => 'application/atom+xml'
|
||||
end
|
||||
|
||||
# 项目列表导出Excel功能
|
||||
def issue_list_xls issues
|
||||
xls_report = StringIO.new
|
||||
book = Spreadsheet::Workbook.new
|
||||
sheet1 = book.create_worksheet :name => "issues"
|
||||
blue = Spreadsheet::Format.new :color => :blue, :weight => :bold, :size => 10
|
||||
sheet1.row(0).default_format = blue
|
||||
sheet1.row(0).concat([l(:issue_xls_id),l(:issue_xls_tracker_id),l(:issue_xls_title),l(:issue_xls_description),l(:issue_xls_status),l(:issue_xls_assign),l(:issue_xls_priority),l(:issue_xls_author),l(:issue_xls_created_at),l(:issue_xls_version),l(:issue_xls_start),l(:issue_xls_due),l(:issue_xls_ratio)])
|
||||
count_row = 1
|
||||
issues.each do |issue|
|
||||
sheet1[count_row,0] = issue.id
|
||||
sheet1[count_row,1] = issue_tracker_change(issue.tracker_id)
|
||||
sheet1[count_row,2] = issue.subject
|
||||
sheet1[count_row,3] = issue.description
|
||||
sheet1[count_row,4] = issue_status_change(issue.status_id)
|
||||
sheet1[count_row,5] = issue.assigned_to.show_name
|
||||
sheet1[count_row,6] = issue_priority_change(issue.priority_id)
|
||||
sheet1[count_row,7] = issue.author.show_name
|
||||
sheet1[count_row,8] = issue.created_on
|
||||
sheet1[count_row,9] = issue.fixed_version.try(:name)
|
||||
sheet1[count_row,10] = issue.start_date
|
||||
sheet1[count_row,11] = issue.due_date
|
||||
sheet1[count_row,12] = issue_ratio_change(issue.done_ratio, issue.status_id)
|
||||
count_row += 1
|
||||
end
|
||||
book.write xls_report
|
||||
xls_report.string
|
||||
end
|
||||
|
||||
def issue_ratio_change done_ratio, status_id
|
||||
if done_ratio == 100 || status_id == 3
|
||||
"已完成"
|
||||
else
|
||||
done_ratio.to_s + "%"
|
||||
end
|
||||
end
|
||||
|
||||
def issue_priority_change priority_id
|
||||
case priority_id
|
||||
when 1
|
||||
"低"
|
||||
when 2
|
||||
"正常"
|
||||
when 3
|
||||
"高"
|
||||
when 4
|
||||
"紧急"
|
||||
when 5
|
||||
"立即"
|
||||
end
|
||||
end
|
||||
|
||||
def issue_status_change status_id
|
||||
case status_id
|
||||
when 1
|
||||
"新增"
|
||||
when 2
|
||||
"正在解决"
|
||||
when 3
|
||||
"已解决"
|
||||
when 4
|
||||
"反馈"
|
||||
when 5
|
||||
"关闭"
|
||||
when 6
|
||||
"拒绝"
|
||||
end
|
||||
end
|
||||
|
||||
def issue_tracker_change tracker_id
|
||||
case tracker_id
|
||||
when 1
|
||||
"缺陷"
|
||||
when 2
|
||||
"功能"
|
||||
when 3
|
||||
"支持"
|
||||
when 4
|
||||
"任务"
|
||||
when 5
|
||||
"周报"
|
||||
end
|
||||
end
|
||||
|
||||
def self.accept_rss_auth(*actions)
|
||||
if actions.any?
|
||||
self.accept_rss_auth_actions = actions
|
||||
|
|
|
@ -97,13 +97,14 @@ class IssuesController < ApplicationController
|
|||
respond_to do |format|
|
||||
format.js
|
||||
format.html { render :template => 'issues/index', :layout => @project_base_tag }#by young
|
||||
format.api {
|
||||
Issue.load_visible_relations(@issues) if include_in_api_response?('relations')
|
||||
}
|
||||
format.api {Issue.load_visible_relations(@issues) if include_in_api_response?('relations')}
|
||||
# format.json { render :json => @issues.map { |issue| issue.to_json}} #:json => @issues.map { |issue| issue.to_json}
|
||||
format.atom { render_feed(@issues, :title => "#{@project || Setting.app_title}: #{l(:label_issue_plural)}") }
|
||||
format.csv { send_data(query_to_csv(@issues, @query, params), :type => 'text/csv; header=present', :filename => 'issues.csv') }
|
||||
format.pdf { send_data(issues_to_pdf(@issues, @project, @query), :type => 'application/pdf', :filename => 'issues.pdf') }
|
||||
format.xls {filename = "#{@project.name.to_s}_#{l(:label_issue_list_xls)}.xls"
|
||||
send_data(issue_list_xls(@issues), :type => 'application/octet-stream', :filename => filename_for_content_disposition(filename))
|
||||
}
|
||||
end
|
||||
else
|
||||
respond_to do |format|
|
||||
|
|
|
@ -139,13 +139,13 @@
|
|||
|
||||
<% end %>
|
||||
|
||||
<!--<div style="float: left; padding-top: 30px">-->
|
||||
<!--<%# other_formats_links do |f| %>-->
|
||||
<!--<%#= f.link_to 'Atom', :url => params.merge(:key => User.current.rss_key) %>-->
|
||||
<!--<%#= f.link_to 'CSV', :url => params, :onclick => "showModal('csv-export-options', '330px'); return false;" %>-->
|
||||
<!--<%#= f.link_to 'PDF', :url => params %>-->
|
||||
<!--<%# end %>-->
|
||||
<!--</div>-->
|
||||
<div style="float: left; padding-top: 30px">
|
||||
<%= link_to "导出:XLS", project_issues_path(:project_id => @project, :format => 'xls') %>
|
||||
<%# other_formats_links do |f| %>
|
||||
<%#= f.link_to "XLS", :url => params, :remote => false %>
|
||||
<%#= f.link_to 'PDF', :url => params %>
|
||||
<%# end %>
|
||||
</div>
|
||||
|
||||
<div id="csv-export-options" style="display:none;">
|
||||
<h3 class="title"><%= l(:label_export_options, :export_format => 'CSV') %></h3>
|
||||
|
|
|
@ -199,7 +199,24 @@ zh:
|
|||
lable_issues_undo: "未解决"
|
||||
label_issue_new: 新建问题
|
||||
label_query: 自定义查询
|
||||
|
||||
label_issue_list_xls: Issue列表
|
||||
|
||||
# Issue列表 excel导出参数
|
||||
issue_xls_id: ID
|
||||
issue_xls_title: 标题
|
||||
issue_xls_description: 描述
|
||||
issue_xls_created_at: 创建时间
|
||||
issue_xls_tracker_id: 类型
|
||||
issue_xls_author: 作者
|
||||
issue_xls_assign: 指派给
|
||||
issue_xls_status: 状态
|
||||
issue_xls_priority: 优先级
|
||||
issue_xls_version: 目标版本
|
||||
issue_xls_start: 开始时间
|
||||
issue_xls_due: 截止时间
|
||||
issue_xls_ratio: 完成度
|
||||
|
||||
|
||||
# 自定义查询
|
||||
label_query_plural: 自定义查询
|
||||
label_query_new: 新建查询
|
||||
|
|
Loading…
Reference in New Issue