Changes misleading scopes on Enumeration.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3083 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
4bdfef4dc4
commit
d8c5549168
|
@ -38,7 +38,7 @@ module TimelogHelper
|
||||||
def activity_collection_for_select_options(time_entry=nil, project=nil)
|
def activity_collection_for_select_options(time_entry=nil, project=nil)
|
||||||
project ||= @project
|
project ||= @project
|
||||||
if project.nil?
|
if project.nil?
|
||||||
activities = TimeEntryActivity.active
|
activities = TimeEntryActivity.shared.active
|
||||||
else
|
else
|
||||||
activities = project.activities
|
activities = project.activities
|
||||||
end
|
end
|
||||||
|
|
|
@ -16,6 +16,8 @@
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
class Enumeration < ActiveRecord::Base
|
class Enumeration < ActiveRecord::Base
|
||||||
|
default_scope :order => "#{Enumeration.table_name}.position ASC"
|
||||||
|
|
||||||
belongs_to :project
|
belongs_to :project
|
||||||
|
|
||||||
acts_as_list :scope => 'type = \'#{type}\''
|
acts_as_list :scope => 'type = \'#{type}\''
|
||||||
|
@ -58,14 +60,8 @@ class Enumeration < ActiveRecord::Base
|
||||||
end
|
end
|
||||||
# End backwards compatiblity named_scopes
|
# End backwards compatiblity named_scopes
|
||||||
|
|
||||||
named_scope :all, :order => 'position', :conditions => { :project_id => nil }
|
named_scope :shared, :conditions => { :project_id => nil }
|
||||||
|
named_scope :active, :conditions => { :active => true }
|
||||||
named_scope :active, lambda {
|
|
||||||
{
|
|
||||||
:conditions => {:active => true, :project_id => nil},
|
|
||||||
:order => 'position'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
def self.default
|
def self.default
|
||||||
# Creates a fake default scope so Enumeration.default will check
|
# Creates a fake default scope so Enumeration.default will check
|
||||||
|
|
|
@ -21,11 +21,7 @@ class Project < ActiveRecord::Base
|
||||||
STATUS_ARCHIVED = 9
|
STATUS_ARCHIVED = 9
|
||||||
|
|
||||||
# Specific overidden Activities
|
# Specific overidden Activities
|
||||||
has_many :time_entry_activities do
|
has_many :time_entry_activities
|
||||||
def active
|
|
||||||
find(:all, :conditions => {:active => true})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
has_many :members, :include => [:user, :roles], :conditions => "#{User.table_name}.type='User' AND #{User.table_name}.status=#{User::STATUS_ACTIVE}"
|
has_many :members, :include => [:user, :roles], :conditions => "#{User.table_name}.type='User' AND #{User.table_name}.status=#{User::STATUS_ACTIVE}"
|
||||||
has_many :member_principals, :class_name => 'Member',
|
has_many :member_principals, :class_name => 'Member',
|
||||||
:include => :principal,
|
:include => :principal,
|
||||||
|
@ -572,7 +568,7 @@ class Project < ActiveRecord::Base
|
||||||
overridden_activity_ids = self.time_entry_activities.active.collect(&:parent_id)
|
overridden_activity_ids = self.time_entry_activities.active.collect(&:parent_id)
|
||||||
|
|
||||||
if overridden_activity_ids.empty?
|
if overridden_activity_ids.empty?
|
||||||
return TimeEntryActivity.active
|
return TimeEntryActivity.shared.active
|
||||||
else
|
else
|
||||||
return system_activities_and_project_overrides
|
return system_activities_and_project_overrides
|
||||||
end
|
end
|
||||||
|
@ -584,7 +580,7 @@ class Project < ActiveRecord::Base
|
||||||
overridden_activity_ids = self.time_entry_activities.collect(&:parent_id)
|
overridden_activity_ids = self.time_entry_activities.collect(&:parent_id)
|
||||||
|
|
||||||
if overridden_activity_ids.empty?
|
if overridden_activity_ids.empty?
|
||||||
return TimeEntryActivity.all
|
return TimeEntryActivity.shared
|
||||||
else
|
else
|
||||||
return system_activities_and_project_overrides(true)
|
return system_activities_and_project_overrides(true)
|
||||||
end
|
end
|
||||||
|
@ -593,12 +589,12 @@ class Project < ActiveRecord::Base
|
||||||
# Returns the systemwide active activities merged with the project specific overrides
|
# Returns the systemwide active activities merged with the project specific overrides
|
||||||
def system_activities_and_project_overrides(include_inactive=false)
|
def system_activities_and_project_overrides(include_inactive=false)
|
||||||
if include_inactive
|
if include_inactive
|
||||||
return TimeEntryActivity.all.
|
return TimeEntryActivity.shared.
|
||||||
find(:all,
|
find(:all,
|
||||||
:conditions => ["id NOT IN (?)", self.time_entry_activities.collect(&:parent_id)]) +
|
:conditions => ["id NOT IN (?)", self.time_entry_activities.collect(&:parent_id)]) +
|
||||||
self.time_entry_activities
|
self.time_entry_activities
|
||||||
else
|
else
|
||||||
return TimeEntryActivity.active.
|
return TimeEntryActivity.shared.active.
|
||||||
find(:all,
|
find(:all,
|
||||||
:conditions => ["id NOT IN (?)", self.time_entry_activities.active.collect(&:parent_id)]) +
|
:conditions => ["id NOT IN (?)", self.time_entry_activities.active.collect(&:parent_id)]) +
|
||||||
self.time_entry_activities.active
|
self.time_entry_activities.active
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<% Enumeration.get_subclasses.each do |klass| %>
|
<% Enumeration.get_subclasses.each do |klass| %>
|
||||||
<h3><%= l(klass::OptionName) %></h3>
|
<h3><%= l(klass::OptionName) %></h3>
|
||||||
|
|
||||||
<% enumerations = klass.all %>
|
<% enumerations = klass.shared %>
|
||||||
<% if enumerations.any? %>
|
<% if enumerations.any? %>
|
||||||
<table class="list">
|
<table class="list">
|
||||||
<tr>
|
<tr>
|
||||||
|
|
Loading…
Reference in New Issue