To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.
root / app / models / workflow_transition.rb @ 1532:a0460a3d154f
History | View | Annotate | Download (1.48 KB)
| 1 | 1115:433d4f72a19b | Chris | # Redmine - project management software
|
|---|---|---|---|
| 2 | 1494:e248c7af89ec | Chris | # Copyright (C) 2006-2014 Jean-Philippe Lang
|
| 3 | 1115:433d4f72a19b | Chris | #
|
| 4 | # This program is free software; you can redistribute it and/or
|
||
| 5 | # modify it under the terms of the GNU General Public License
|
||
| 6 | # as published by the Free Software Foundation; either version 2
|
||
| 7 | # of the License, or (at your option) any later version.
|
||
| 8 | #
|
||
| 9 | # This program is distributed in the hope that it will be useful,
|
||
| 10 | # but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
| 11 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
| 12 | # GNU General Public License for more details.
|
||
| 13 | #
|
||
| 14 | # You should have received a copy of the GNU General Public License
|
||
| 15 | # along with this program; if not, write to the Free Software
|
||
| 16 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
| 17 | |||
| 18 | class WorkflowTransition < WorkflowRule |
||
| 19 | validates_presence_of :new_status
|
||
| 20 | |||
| 21 | # Returns workflow transitions count by tracker and role
|
||
| 22 | def self.count_by_tracker_and_role |
||
| 23 | counts = connection.select_all("SELECT role_id, tracker_id, count(id) AS c FROM #{table_name} WHERE type = 'WorkflowTransition' GROUP BY role_id, tracker_id")
|
||
| 24 | roles = Role.sorted.all
|
||
| 25 | trackers = Tracker.sorted.all
|
||
| 26 | |||
| 27 | result = [] |
||
| 28 | trackers.each do |tracker|
|
||
| 29 | t = [] |
||
| 30 | roles.each do |role|
|
||
| 31 | row = counts.detect {|c| c['role_id'].to_s == role.id.to_s && c['tracker_id'].to_s == tracker.id.to_s}
|
||
| 32 | t << [role, (row.nil? ? 0 : row['c'].to_i)] |
||
| 33 | end
|
||
| 34 | result << [tracker, t] |
||
| 35 | end
|
||
| 36 | |||
| 37 | result |
||
| 38 | end
|
||
| 39 | end |