diff --git a/queries/trunk/app/controllers/projects_controller.rb b/queries/trunk/app/controllers/projects_controller.rb index d912f35aa..92025921d 100644 --- a/queries/trunk/app/controllers/projects_controller.rb +++ b/queries/trunk/app/controllers/projects_controller.rb @@ -208,10 +208,15 @@ class ProjectsController < ApplicationController sort_init 'issues.id', 'desc' sort_update - @query = Query.new - params[:fields].each do |field| - @query.add_filter(field, params[:operators][field], params[:values][field]) - end if params[:fields] + session[:query] = nil if params[:set_filter] + @query = session[:query] || Query.new + if params[:fields] and params[:fields].is_a? Array + @query.filters = {} + params[:fields].each do |field| + @query.add_filter(field, params[:operators][field], params[:values][field]) + end + end + session[:query] = @query @results_per_page_options = [ 15, 25, 50, 100 ] if params[:per_page] and @results_per_page_options.include? params[:per_page].to_i @@ -237,11 +242,11 @@ class ProjectsController < ApplicationController sort_init 'issues.id', 'desc' sort_update - search_filter_init_list_issues + @query = session[:query] || Query.new @issues = Issue.find :all, :order => sort_clause, :include => [ :author, :status, :tracker, :project, :custom_values ], - :conditions => search_filter_clause + :conditions => @query.statement ic = Iconv.new('ISO-8859-1', 'UTF-8') export = StringIO.new @@ -270,11 +275,11 @@ class ProjectsController < ApplicationController sort_init 'issues.id', 'desc' sort_update - search_filter_init_list_issues + @query = session[:query] || Query.new @issues = Issue.find :all, :order => sort_clause, :include => [ :author, :status, :tracker, :project, :custom_values ], - :conditions => search_filter_clause + :conditions => @query.statement @options_for_rfpdf ||= {} @options_for_rfpdf[:file_name] = "export.pdf" diff --git a/queries/trunk/app/models/query.rb b/queries/trunk/app/models/query.rb index 8201d08bd..8e826da53 100644 --- a/queries/trunk/app/models/query.rb +++ b/queries/trunk/app/models/query.rb @@ -1,7 +1,7 @@ class Query < ActiveRecord::Base serialize :filters - validates_presence_of :name + validates_presence_of :name, :on => :save @@operators = { "=" => "Egal", "!" => "Different", @@ -56,7 +56,7 @@ class Query < ActiveRecord::Base def add_filter(field, operator, values) # values must be an array - return unless values and values.is_a? Array + return unless values and values.is_a? Array # and !values.first.empty? # check if field is defined as an available filter if @@available_filters.has_key? field filter_options = @@available_filters[field] diff --git a/queries/trunk/app/views/projects/list_issues.rhtml b/queries/trunk/app/views/projects/list_issues.rhtml index 92f726532..b4dff2c9c 100644 --- a/queries/trunk/app/views/projects/list_issues.rhtml +++ b/queries/trunk/app/views/projects/list_issues.rhtml @@ -7,12 +7,20 @@ -
| <%= submit_tag l(:button_apply), :class => "button-small" %> <%= end_form_tag %> - +<%= start_form_tag :action => 'list_issues', :set_filter => 1 %> +<%= submit_tag l(:button_clear), :class => "button-small" %> +<%= end_form_tag %> + | +