summaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorEric Davis <edavis@littlestreamsoftware.com>2010-03-10 05:10:43 +0000
committerEric Davis <edavis@littlestreamsoftware.com>2010-03-10 05:10:43 +0000
commit22c1e2b8cf8527c1e97de976f3dd46e7bee7cba3 (patch)
treec868aacb521e2918f8ef1d67adf0b4c47b5b4ac2 /app
parentcfa1f0c231309c596900a0e82e89f15a4ab071a1 (diff)
downloadredmine-22c1e2b8cf8527c1e97de976f3dd46e7bee7cba3.tar.gz
redmine-22c1e2b8cf8527c1e97de976f3dd46e7bee7cba3.zip
Adds named scopes to replace custom finders.
* Adds watched_by class method in ActsAsWatchable * Adds Issue#recently_updated, Issue#with_limit and Issue#on_active_project #2482 git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3557 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app')
-rw-r--r--app/models/issue.rb8
-rw-r--r--app/views/my/blocks/_issueswatched.rhtml9
2 files changed, 9 insertions, 8 deletions
diff --git a/app/models/issue.rb b/app/models/issue.rb
index 9aaebce73..ffce8ea18 100644
--- a/app/models/issue.rb
+++ b/app/models/issue.rb
@@ -49,8 +49,9 @@ class Issue < ActiveRecord::Base
DONE_RATIO_OPTIONS = %w(issue_field issue_status)
attr_reader :current_journal
-
+
validates_presence_of :subject, :priority, :project, :tracker, :author, :status
+
validates_length_of :subject, :maximum => 255
validates_inclusion_of :done_ratio, :in => 0..100
validates_numericality_of :estimated_hours, :allow_nil => true
@@ -60,6 +61,11 @@ class Issue < ActiveRecord::Base
named_scope :open, :conditions => ["#{IssueStatus.table_name}.is_closed = ?", false], :include => :status
+ named_scope :recently_updated, :order => "#{self.table_name}.updated_on DESC"
+ named_scope :with_limit, lambda { |limit| { :limit => limit} }
+ named_scope :on_active_project, :include => [:status, :project, :tracker],
+ :conditions => ["#{Project.table_name}.status=#{Project::STATUS_ACTIVE}"]
+
before_create :default_assign
before_save :reschedule_following_issues, :close_duplicates, :update_done_ratio_from_issue_status
after_save :create_journal
diff --git a/app/views/my/blocks/_issueswatched.rhtml b/app/views/my/blocks/_issueswatched.rhtml
index 04f326c25..e48ec1662 100644
--- a/app/views/my/blocks/_issueswatched.rhtml
+++ b/app/views/my/blocks/_issueswatched.rhtml
@@ -1,10 +1,5 @@
-<h3><%=l(:label_watched_issues)%> (<%= Issue.visible.count(:include => :watchers,
- :conditions => ["#{Watcher.table_name}.user_id = ?", user.id]) %>)</h3>
-<% watched_issues = Issue.visible.find(:all,
- :include => [:status, :project, :tracker, :watchers],
- :limit => 10,
- :conditions => ["#{Watcher.table_name}.user_id = ?", user.id],
- :order => "#{Issue.table_name}.updated_on DESC") %>
+<h3><%=l(:label_watched_issues)%> (<%= Issue.visible.watched_by(user.id).count %>)</h3>
+<% watched_issues = Issue.visible.on_active_project.watched_by(user.id).recently_updated.with_limit(10) %>
<%= render :partial => 'issues/list_simple', :locals => { :issues => watched_issues } %>
<% if watched_issues.length > 0 %>