72 lines
3.6 KiB
Ruby
72 lines
3.6 KiB
Ruby
|
# redMine - project management software
|
||
|
# Copyright (C) 2006 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.
|
||
|
|
||
|
class ReportsController < ApplicationController
|
||
|
layout 'base'
|
||
|
before_filter :find_project, :authorize
|
||
|
|
||
|
def issue_report
|
||
|
@statuses = IssueStatus.find_all
|
||
|
@trackers = Tracker.find_all
|
||
|
@issues_by_tracker =
|
||
|
ActiveRecord::Base.connection.select_all("select s.id as status_id,
|
||
|
s.is_closed as closed,
|
||
|
t.id as tracker_id,
|
||
|
count(i.id) as total
|
||
|
from
|
||
|
issues i, issue_statuses s, trackers t
|
||
|
where
|
||
|
i.status_id=s.id
|
||
|
and i.tracker_id=t.id
|
||
|
and i.project_id=#{@project.id}
|
||
|
group by s.id, t.id")
|
||
|
@priorities = Enumeration::get_values('IPRI')
|
||
|
@issues_by_priority =
|
||
|
ActiveRecord::Base.connection.select_all("select s.id as status_id,
|
||
|
s.is_closed as closed,
|
||
|
p.id as priority_id,
|
||
|
count(i.id) as total
|
||
|
from
|
||
|
issues i, issue_statuses s, enumerations p
|
||
|
where
|
||
|
i.status_id=s.id
|
||
|
and i.priority_id=p.id
|
||
|
and i.project_id=#{@project.id}
|
||
|
group by s.id, p.id")
|
||
|
@categories = @project.issue_categories
|
||
|
@issues_by_category =
|
||
|
ActiveRecord::Base.connection.select_all("select s.id as status_id,
|
||
|
s.is_closed as closed,
|
||
|
c.id as category_id,
|
||
|
count(i.id) as total
|
||
|
from
|
||
|
issues i, issue_statuses s, issue_categories c
|
||
|
where
|
||
|
i.status_id=s.id
|
||
|
and i.category_id=c.id
|
||
|
and i.project_id=#{@project.id}
|
||
|
group by s.id, c.id")
|
||
|
end
|
||
|
|
||
|
|
||
|
private
|
||
|
# Find project of id params[:id]
|
||
|
def find_project
|
||
|
@project = Project.find(params[:id])
|
||
|
end
|
||
|
end
|