summaryrefslogtreecommitdiffstats
path: root/app/models/workflow.rb
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2008-09-28 12:03:17 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2008-09-28 12:03:17 +0000
commita37af7a2260d7da269a08e2d94d88f67aaad5c9b (patch)
treec1b0c8f0afd1e98f55b0b79d1c4af07eedba593d /app/models/workflow.rb
parent85711f1d5484ae9708dc4e92fdaf4eb499da8ede (diff)
downloadredmine-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.rb19
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