##// END OF EJS Templates
mark deprecated Enumeration#overridding_change? which was changed in r13056...
Toshi MARUYAMA -
r12811:c777f75edd77
parent child
Show More
@@ -1,142 +1,148
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2014 Jean-Philippe Lang
2 # Copyright (C) 2006-2014 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
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
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.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 class Enumeration < ActiveRecord::Base
18 class Enumeration < ActiveRecord::Base
19 include Redmine::SubclassFactory
19 include Redmine::SubclassFactory
20
20
21 default_scope :order => "#{Enumeration.table_name}.position ASC"
21 default_scope :order => "#{Enumeration.table_name}.position ASC"
22
22
23 belongs_to :project
23 belongs_to :project
24
24
25 acts_as_list :scope => 'type = \'#{type}\''
25 acts_as_list :scope => 'type = \'#{type}\''
26 acts_as_customizable
26 acts_as_customizable
27 acts_as_tree :order => "#{Enumeration.table_name}.position ASC"
27 acts_as_tree :order => "#{Enumeration.table_name}.position ASC"
28
28
29 before_destroy :check_integrity
29 before_destroy :check_integrity
30 before_save :check_default
30 before_save :check_default
31
31
32 attr_protected :type
32 attr_protected :type
33
33
34 validates_presence_of :name
34 validates_presence_of :name
35 validates_uniqueness_of :name, :scope => [:type, :project_id]
35 validates_uniqueness_of :name, :scope => [:type, :project_id]
36 validates_length_of :name, :maximum => 30
36 validates_length_of :name, :maximum => 30
37
37
38 scope :shared, lambda { where(:project_id => nil) }
38 scope :shared, lambda { where(:project_id => nil) }
39 scope :sorted, lambda { order("#{table_name}.position ASC") }
39 scope :sorted, lambda { order("#{table_name}.position ASC") }
40 scope :active, lambda { where(:active => true) }
40 scope :active, lambda { where(:active => true) }
41 scope :system, lambda { where(:project_id => nil) }
41 scope :system, lambda { where(:project_id => nil) }
42 scope :named, lambda {|arg| where("LOWER(#{table_name}.name) = LOWER(?)", arg.to_s.strip)}
42 scope :named, lambda {|arg| where("LOWER(#{table_name}.name) = LOWER(?)", arg.to_s.strip)}
43
43
44 def self.default
44 def self.default
45 # Creates a fake default scope so Enumeration.default will check
45 # Creates a fake default scope so Enumeration.default will check
46 # it's type. STI subclasses will automatically add their own
46 # it's type. STI subclasses will automatically add their own
47 # types to the finder.
47 # types to the finder.
48 if self.descends_from_active_record?
48 if self.descends_from_active_record?
49 where(:is_default => true, :type => 'Enumeration').first
49 where(:is_default => true, :type => 'Enumeration').first
50 else
50 else
51 # STI classes are
51 # STI classes are
52 where(:is_default => true).first
52 where(:is_default => true).first
53 end
53 end
54 end
54 end
55
55
56 # Overloaded on concrete classes
56 # Overloaded on concrete classes
57 def option_name
57 def option_name
58 nil
58 nil
59 end
59 end
60
60
61 def check_default
61 def check_default
62 if is_default? && is_default_changed?
62 if is_default? && is_default_changed?
63 Enumeration.where({:type => type}).update_all({:is_default => false})
63 Enumeration.where({:type => type}).update_all({:is_default => false})
64 end
64 end
65 end
65 end
66
66
67 # Overloaded on concrete classes
67 # Overloaded on concrete classes
68 def objects_count
68 def objects_count
69 0
69 0
70 end
70 end
71
71
72 def in_use?
72 def in_use?
73 self.objects_count != 0
73 self.objects_count != 0
74 end
74 end
75
75
76 # Is this enumeration overriding a system level enumeration?
76 # Is this enumeration overriding a system level enumeration?
77 def is_override?
77 def is_override?
78 !self.parent.nil?
78 !self.parent.nil?
79 end
79 end
80
80
81 alias :destroy_without_reassign :destroy
81 alias :destroy_without_reassign :destroy
82
82
83 # Destroy the enumeration
83 # Destroy the enumeration
84 # If a enumeration is specified, objects are reassigned
84 # If a enumeration is specified, objects are reassigned
85 def destroy(reassign_to = nil)
85 def destroy(reassign_to = nil)
86 if reassign_to && reassign_to.is_a?(Enumeration)
86 if reassign_to && reassign_to.is_a?(Enumeration)
87 self.transfer_relations(reassign_to)
87 self.transfer_relations(reassign_to)
88 end
88 end
89 destroy_without_reassign
89 destroy_without_reassign
90 end
90 end
91
91
92 def <=>(enumeration)
92 def <=>(enumeration)
93 position <=> enumeration.position
93 position <=> enumeration.position
94 end
94 end
95
95
96 def to_s; name end
96 def to_s; name end
97
97
98 # Returns the Subclasses of Enumeration. Each Subclass needs to be
98 # Returns the Subclasses of Enumeration. Each Subclass needs to be
99 # required in development mode.
99 # required in development mode.
100 #
100 #
101 # Note: subclasses is protected in ActiveRecord
101 # Note: subclasses is protected in ActiveRecord
102 def self.get_subclasses
102 def self.get_subclasses
103 subclasses
103 subclasses
104 end
104 end
105
105
106 # TODO: remove in Redmine 3.0
107 def self.overridding_change?(new, previous)
108 ActiveSupport::Deprecation.warn "Enumeration#overridding_change? is deprecated and will be removed in Redmine 3.0. Please use #overriding_change?."
109 overriding_change?(new, previous)
110 end
111
106 # Does the +new+ Hash override the previous Enumeration?
112 # Does the +new+ Hash override the previous Enumeration?
107 def self.overriding_change?(new, previous)
113 def self.overriding_change?(new, previous)
108 if (same_active_state?(new['active'], previous.active)) && same_custom_values?(new,previous)
114 if (same_active_state?(new['active'], previous.active)) && same_custom_values?(new,previous)
109 return false
115 return false
110 else
116 else
111 return true
117 return true
112 end
118 end
113 end
119 end
114
120
115 # Does the +new+ Hash have the same custom values as the previous Enumeration?
121 # Does the +new+ Hash have the same custom values as the previous Enumeration?
116 def self.same_custom_values?(new, previous)
122 def self.same_custom_values?(new, previous)
117 previous.custom_field_values.each do |custom_value|
123 previous.custom_field_values.each do |custom_value|
118 if custom_value.value != new["custom_field_values"][custom_value.custom_field_id.to_s]
124 if custom_value.value != new["custom_field_values"][custom_value.custom_field_id.to_s]
119 return false
125 return false
120 end
126 end
121 end
127 end
122
128
123 return true
129 return true
124 end
130 end
125
131
126 # Are the new and previous fields equal?
132 # Are the new and previous fields equal?
127 def self.same_active_state?(new, previous)
133 def self.same_active_state?(new, previous)
128 new = (new == "1" ? true : false)
134 new = (new == "1" ? true : false)
129 return new == previous
135 return new == previous
130 end
136 end
131
137
132 private
138 private
133 def check_integrity
139 def check_integrity
134 raise "Can't delete enumeration" if self.in_use?
140 raise "Can't delete enumeration" if self.in_use?
135 end
141 end
136
142
137 end
143 end
138
144
139 # Force load the subclasses in development mode
145 # Force load the subclasses in development mode
140 require_dependency 'time_entry_activity'
146 require_dependency 'time_entry_activity'
141 require_dependency 'document_category'
147 require_dependency 'document_category'
142 require_dependency 'issue_priority'
148 require_dependency 'issue_priority'
General Comments 0
You need to be logged in to leave comments. Login now