diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2012-07-05 13:51:56 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2012-07-05 13:51:56 +0000 |
commit | 196f96fff1d93ba55453166192cb242da048a742 (patch) | |
tree | 718bcea4969e41e7e0b80c5d2a51d12617876d43 /app/models/query.rb | |
parent | 1d7c0eb7c02d22f65ed1e4443abcf92b5bd7a899 (diff) | |
download | redmine-196f96fff1d93ba55453166192cb242da048a742.tar.gz redmine-196f96fff1d93ba55453166192cb242da048a742.zip |
Adds Private filter to the issue list (#8577).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@9920 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/query.rb')
-rw-r--r-- | app/models/query.rb | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/app/models/query.rb b/app/models/query.rb index 42309e01a..cd3a10f0a 100644 --- a/app/models/query.rb +++ b/app/models/query.rb @@ -302,7 +302,12 @@ class Query < ActiveRecord::Base end add_custom_fields_filters(IssueCustomField.find(:all, :conditions => {:is_filter => true, :is_for_all => true})) end - + + if User.current.allowed_to?(:set_issues_private, nil, :global => true) || + User.current.allowed_to?(:set_own_issues_private, nil, :global => true) + @available_filters["is_private"] = { :type => :list, :order => 15, :values => [[l(:general_text_yes), "1"], [l(:general_text_no), "0"]] } + end + Tracker.disabled_core_fields(trackers).each {|field| @available_filters.delete field } @@ -704,6 +709,13 @@ class Query < ActiveRecord::Base end end + def sql_for_is_private_field(field, operator, value) + op = (operator == "=" ? 'IN' : 'NOT IN') + va = value.map {|v| v == '0' ? connection.quoted_false : connection.quoted_true}.uniq.join(',') + + "#{Issue.table_name}.is_private #{op} (#{va})" + end + private def sql_for_custom_field(field, operator, value, custom_field_id) |