Class: IssueStatus

Inherits:
ActiveRecord::Base
  • Object
show all
Defined in:
app/models/issue_status.rb

Overview

Redmine - project management software Copyright (C) 2006-2014 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 Method Summary collapse

Instance Method Summary collapse

Class Method Details

.update_issue_done_ratiosObject

Update all the Issues setting their done_ratio to the value of their IssueStatus


37
38
39
40
41
42
43
44
45
# File 'app/models/issue_status.rb', line 37

def self.update_issue_done_ratios
  if Issue.use_status_for_done_ratio?
    IssueStatus.where("default_done_ratio >= 0").each do |status|
      Issue.where({:status_id => status.id}).update_all({:done_ratio => status.default_done_ratio})
    end
  end

  return Issue.use_status_for_done_ratio?
end

Instance Method Details

#<=>(status) ⇒ Object


85
86
87
# File 'app/models/issue_status.rb', line 85

def <=>(status)
  position <=> status.position
end

#find_new_statuses_allowed_to(roles, tracker, author = false, assignee = false) ⇒ Object

Same thing as above but uses a database query More efficient than the previous method if called just once


65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'app/models/issue_status.rb', line 65

def find_new_statuses_allowed_to(roles, tracker, author=false, assignee=false)
  if roles.present? && tracker
    scope = IssueStatus.
      joins(:workflow_transitions_as_new_status).
      where(:workflows => {:old_status_id => id, :role_id => roles.map(&:id), :tracker_id => tracker.id})

    unless author && assignee
      if author || assignee
        scope = scope.where("author = ? OR assignee = ?", author, assignee)
      else
        scope = scope.where("author = ? AND assignee = ?", false, false)
      end
    end

    scope.uniq.to_a.sort
  else
    []
  end
end

#new_statuses_allowed_to(roles, tracker, author = false, assignee = false) ⇒ Object

Returns an array of all statuses the given role can switch to Uses association cache when called more than one time


49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'app/models/issue_status.rb', line 49

def new_statuses_allowed_to(roles, tracker, author=false, assignee=false)
  if roles && tracker
    role_ids = roles.collect(&:id)
    transitions = workflows.select do |w|
      role_ids.include?(w.role_id) &&
      w.tracker_id == tracker.id &&
      ((!w.author && !w.assignee) || (author && w.author) || (assignee && w.assignee))
    end
    transitions.map(&:new_status).compact.sort
  else
    []
  end
end

#to_sObject


89
# File 'app/models/issue_status.rb', line 89

def to_s; name end