diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2008-09-28 12:03:17 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2008-09-28 12:03:17 +0000 |
commit | a37af7a2260d7da269a08e2d94d88f67aaad5c9b (patch) | |
tree | c1b0c8f0afd1e98f55b0b79d1c4af07eedba593d /app/models/workflow.rb | |
parent | 85711f1d5484ae9708dc4e92fdaf4eb499da8ede (diff) | |
download | redmine-a37af7a2260d7da269a08e2d94d88f67aaad5c9b.tar.gz redmine-a37af7a2260d7da269a08e2d94d88f67aaad5c9b.zip |
Adds a workflow overview screen.
Workflow setup moved to a dedicated controller.
git-svn-id: http://redmine.rubyforge.org/svn/trunk@1914 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/workflow.rb')
-rw-r--r-- | app/models/workflow.rb | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/app/models/workflow.rb b/app/models/workflow.rb index 89322aa58..e254ac48c 100644 --- a/app/models/workflow.rb +++ b/app/models/workflow.rb @@ -21,4 +21,23 @@ class Workflow < ActiveRecord::Base belongs_to :new_status, :class_name => 'IssueStatus', :foreign_key => 'new_status_id' validates_presence_of :role, :old_status, :new_status + + # Returns workflow transitions count by tracker and role + def self.count_by_tracker_and_role + counts = connection.select_all("SELECT role_id, tracker_id, count(id) AS c FROM #{Workflow.table_name} GROUP BY role_id, tracker_id") + roles = Role.find(:all, :order => 'builtin, position') + trackers = Tracker.find(:all, :order => 'position') + + result = [] + trackers.each do |tracker| + t = [] + roles.each do |role| + row = counts.detect {|c| c['role_id'] == role.id.to_s && c['tracker_id'] = tracker.id.to_s} + t << [role, (row.nil? ? 0 : row['c'].to_i)] + end + result << [tracker, t] + end + + result + end end |