You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

workflow_transition.rb 1.5KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. # Redmine - project management software
  2. # Copyright (C) 2006-2013 Jean-Philippe Lang
  3. #
  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. class WorkflowTransition < WorkflowRule
  18. validates_presence_of :new_status
  19. # Returns workflow transitions count by tracker and role
  20. def self.count_by_tracker_and_role
  21. 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")
  22. roles = Role.sorted.all
  23. trackers = Tracker.sorted.all
  24. result = []
  25. trackers.each do |tracker|
  26. t = []
  27. roles.each do |role|
  28. row = counts.detect {|c| c['role_id'].to_s == role.id.to_s && c['tracker_id'].to_s == tracker.id.to_s}
  29. t << [role, (row.nil? ? 0 : row['c'].to_i)]
  30. end
  31. result << [tracker, t]
  32. end
  33. result
  34. end
  35. end