summaryrefslogtreecommitdiffstats
path: root/app/models
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2007-05-08 12:46:15 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2007-05-08 12:46:15 +0000
commitdf0a49ff14474dd2230a823f57e95aa9d3b1cd71 (patch)
tree8cf5eff97f9ae378cccdf041135d5b0d1f364392 /app/models
parent50429d0819e41ea01837fccb7a878f0d878e5f6c (diff)
downloadredmine-df0a49ff14474dd2230a823f57e95aa9d3b1cd71.tar.gz
redmine-df0a49ff14474dd2230a823f57e95aa9d3b1cd71.zip
"me" value is now available in queries for "assigned to" and "author" filters.
When executing the query, it is replaced by the currently logged in user. git-svn-id: http://redmine.rubyforge.org/svn/trunk@520 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models')
-rw-r--r--app/models/query.rb21
1 files changed, 18 insertions, 3 deletions
diff --git a/app/models/query.rb b/app/models/query.rb
index e26e6a68e..026e79ea9 100644
--- a/app/models/query.rb
+++ b/app/models/query.rb
@@ -21,6 +21,7 @@ class Query < ActiveRecord::Base
serialize :filters
attr_protected :project, :user
+ attr_accessor :executed_by
validates_presence_of :name, :on => :save
@@ -59,6 +60,11 @@ class Query < ActiveRecord::Base
self.is_public = true
end
+ def executed_by=(user)
+ @executed_by = user
+ set_language_if_valid(user.language) if user
+ end
+
def validate
filters.each_key do |field|
errors.add label_for(field), :activerecord_error_blank unless
@@ -81,8 +87,12 @@ class Query < ActiveRecord::Base
"due_date" => { :type => :date, :order => 12 } }
unless project.nil?
# project specific filters
- @available_filters["assigned_to_id"] = { :type => :list_optional, :order => 4, :values => @project.users.collect{|s| [s.name, s.id.to_s] } }
- @available_filters["author_id"] = { :type => :list, :order => 5, :values => @project.users.collect{|s| [s.name, s.id.to_s] } }
+ user_values = []
+ user_values << ["<< #{l(:label_me)} >>", "me"] if executed_by
+ user_values += @project.users.collect{|s| [s.name, s.id.to_s] }
+
+ @available_filters["assigned_to_id"] = { :type => :list_optional, :order => 4, :values => user_values }
+ @available_filters["author_id"] = { :type => :list, :order => 5, :values => user_values }
@available_filters["category_id"] = { :type => :list_optional, :order => 6, :values => @project.issue_categories.collect{|s| [s.name, s.id.to_s] } }
@available_filters["fixed_version_id"] = { :type => :list_optional, :order => 7, :values => @project.versions.collect{|s| [s.name, s.id.to_s] } }
unless @project.children.empty?
@@ -162,7 +172,7 @@ class Query < ActiveRecord::Base
end
filters.each_key do |field|
next if field == "subproject_id"
- v = values_for field
+ v = values_for(field).clone
next unless v and !v.empty?
sql = sql + " AND " unless sql.empty?
@@ -179,6 +189,11 @@ class Query < ActiveRecord::Base
db_field = field
end
+ # "me" value subsitution
+ if %w(assigned_to_id author_id).include?(field)
+ v.push(executed_by ? executed_by.id.to_s : "0") if v.delete("me")
+ end
+
case operator_for field
when "="
sql = sql + "#{db_table}.#{db_field} IN (" + v.collect{|val| "'#{connection.quote_string(val)}'"}.join(",") + ")"