2006-06-28 22:11:03 +04:00
|
|
|
# redMine - project management software
|
|
|
|
# Copyright (C) 2006 Jean-Philippe Lang
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License
|
|
|
|
# as published by the Free Software Foundation; either version 2
|
|
|
|
# of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
module SearchFilterHelper
|
|
|
|
|
2006-07-03 23:38:10 +04:00
|
|
|
def search_filter_criteria(name, options = {})
|
2006-07-09 20:30:01 +04:00
|
|
|
@search_filter ||= {}
|
|
|
|
@search_filter[name] ||= {}
|
|
|
|
@search_filter[name][:options] = []
|
|
|
|
@search_filter[name][:conditions] = {}
|
|
|
|
yield.each { |c|
|
|
|
|
@search_filter[name][:options] << [c[0], c[1].to_s]
|
|
|
|
@search_filter[name][:conditions].store(c[1].to_s, c[2])
|
|
|
|
}
|
2006-07-03 23:38:10 +04:00
|
|
|
end
|
2006-06-28 22:11:03 +04:00
|
|
|
|
2006-07-03 23:38:10 +04:00
|
|
|
def search_filter_update
|
2006-07-13 01:35:56 +04:00
|
|
|
session[:search_filter] ||= {}
|
2006-07-09 20:30:01 +04:00
|
|
|
@search_filter.each_key {|field| session[:search_filter][field] = params[field] }
|
2006-07-03 23:38:10 +04:00
|
|
|
end
|
2006-06-28 22:11:03 +04:00
|
|
|
|
2006-07-03 23:38:10 +04:00
|
|
|
def search_filter_clause
|
2006-07-09 23:53:13 +04:00
|
|
|
session[:search_filter] ||= {}
|
2006-07-09 20:30:01 +04:00
|
|
|
clause = ["1=1"]
|
|
|
|
@search_filter.each { |k, v|
|
|
|
|
filter_value = session[:search_filter][k] || v[:options][0][1]
|
|
|
|
if v[:conditions][filter_value]
|
|
|
|
clause[0] = clause[0] + " AND " + v[:conditions][filter_value].first
|
|
|
|
clause += v[:conditions][filter_value][1..-1]
|
2006-07-03 23:38:10 +04:00
|
|
|
end
|
|
|
|
}
|
|
|
|
clause
|
|
|
|
end
|
2006-06-28 22:11:03 +04:00
|
|
|
|
2006-07-09 20:30:01 +04:00
|
|
|
def search_filter_tag(criteria, options = {})
|
2006-07-13 01:35:56 +04:00
|
|
|
session[:search_filter] ||= {}
|
2006-07-09 20:30:01 +04:00
|
|
|
options[:name] = criteria
|
2006-07-13 01:35:56 +04:00
|
|
|
options[:class] += " active-filter" if session[:search_filter][criteria] and session[:search_filter][criteria] != @search_filter[criteria][:options][0][1]
|
2006-07-03 23:38:10 +04:00
|
|
|
content_tag("select",
|
2006-07-09 20:30:01 +04:00
|
|
|
options_for_select(@search_filter[criteria][:options], session[:search_filter][criteria]),
|
|
|
|
options
|
2006-06-28 22:11:03 +04:00
|
|
|
)
|
2006-07-03 23:38:10 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
def search_filter_init_list_issues
|
|
|
|
search_filter_criteria('status_id') {
|
2006-07-29 23:54:22 +04:00
|
|
|
[ [('['+l(:label_open_issues_plural)+']'), "O", ["issue_statuses.is_closed=?", false]],
|
|
|
|
[('['+l(:label_closed_issues_plural)+']'), "C", ["issue_statuses.is_closed=?", true]],
|
|
|
|
[('['+l(:label_all)+']'), "A", nil]
|
2006-07-03 23:38:10 +04:00
|
|
|
] + IssueStatus.find(:all).collect {|s| [s.name, s.id, ["issues.status_id=?", s.id]] }
|
|
|
|
}
|
|
|
|
|
|
|
|
search_filter_criteria('tracker_id') {
|
2006-07-29 23:54:22 +04:00
|
|
|
[ [('['+l(:label_all)+']'), "A", nil]
|
2006-07-03 23:38:10 +04:00
|
|
|
] + Tracker.find(:all).collect {|s| [s.name, s.id, ["issues.tracker_id=?", s.id]] }
|
|
|
|
}
|
|
|
|
|
|
|
|
search_filter_criteria('priority_id') {
|
2006-07-29 23:54:22 +04:00
|
|
|
[ [('['+l(:label_all)+']'), "A", nil]
|
2006-07-03 23:38:10 +04:00
|
|
|
] + Enumeration.find(:all, :conditions => ['opt=?','IPRI']).collect {|s| [s.name, s.id, ["issues.priority_id=?", s.id]] }
|
|
|
|
}
|
|
|
|
|
|
|
|
search_filter_criteria('category_id') {
|
2006-07-29 23:54:22 +04:00
|
|
|
[ [('['+l(:label_all)+']'), "A", nil],
|
|
|
|
[('['+l(:label_none)+']'), "N", ["issues.category_id is null"]]
|
2006-07-03 23:38:10 +04:00
|
|
|
] + @project.issue_categories.find(:all).collect {|s| [s.name, s.id, ["issues.category_id=?", s.id]] }
|
|
|
|
}
|
2006-06-28 22:11:03 +04:00
|
|
|
|
2006-07-13 01:35:56 +04:00
|
|
|
search_filter_criteria('fixed_version_id') {
|
2006-07-29 23:54:22 +04:00
|
|
|
[ [('['+l(:label_all)+']'), "A", nil],
|
|
|
|
[('['+l(:label_none)+']'), "N", ["issues.fixed_version_id is null"]]
|
2006-07-13 01:35:56 +04:00
|
|
|
] + @project.versions.collect {|s| [s.name, s.id, ["issues.fixed_version_id=?", s.id]] }
|
|
|
|
}
|
|
|
|
|
2006-10-22 18:47:25 +04:00
|
|
|
search_filter_criteria('author_id') {
|
|
|
|
[ [('['+l(:label_all)+']'), "A", nil],
|
|
|
|
] + @project.users.collect {|s| [s.display_name, s.id, ["issues.author_id=?", s.id]] }
|
|
|
|
}
|
|
|
|
|
2006-07-03 23:38:10 +04:00
|
|
|
search_filter_criteria('assigned_to_id') {
|
2006-07-29 23:54:22 +04:00
|
|
|
[ [('['+l(:label_all)+']'), "A", nil],
|
|
|
|
[('['+l(:label_none)+']'), "N", ["issues.assigned_to_id is null"]]
|
2006-07-09 20:30:01 +04:00
|
|
|
] + @project.users.collect {|s| [s.display_name, s.id, ["issues.assigned_to_id=?", s.id]] }
|
|
|
|
}
|
2006-07-13 01:35:56 +04:00
|
|
|
|
2006-07-09 20:30:01 +04:00
|
|
|
search_filter_criteria('subproject_id') {
|
2006-07-29 23:54:22 +04:00
|
|
|
[ [('['+l(:label_none)+']'), "N", ["issues.project_id=?", @project.id]],
|
|
|
|
[('['+l(:label_all)+']'), "A", ["(issues.project_id=? or projects.parent_id=?)", @project.id, @project.id]]
|
2006-07-09 20:30:01 +04:00
|
|
|
]
|
|
|
|
}
|
2006-07-03 23:38:10 +04:00
|
|
|
end
|
2006-06-28 22:11:03 +04:00
|
|
|
end
|