annotate app/helpers/queries_helper.rb @ 1472:f0b798dad2d6 feature_526

Close obsolete branch feature_526
author Chris Cannam
date Tue, 20 Nov 2012 19:45:51 +0000
parents cbb26bc654de
children 433d4f72a19b
rev   line source
Chris@909 1 # encoding: utf-8
Chris@909 2 #
Chris@441 3 # Redmine - project management software
Chris@441 4 # Copyright (C) 2006-2011 Jean-Philippe Lang
Chris@0 5 #
Chris@0 6 # This program is free software; you can redistribute it and/or
Chris@0 7 # modify it under the terms of the GNU General Public License
Chris@0 8 # as published by the Free Software Foundation; either version 2
Chris@0 9 # of the License, or (at your option) any later version.
Chris@909 10 #
Chris@0 11 # This program is distributed in the hope that it will be useful,
Chris@0 12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@0 13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@0 14 # GNU General Public License for more details.
Chris@909 15 #
Chris@0 16 # You should have received a copy of the GNU General Public License
Chris@0 17 # along with this program; if not, write to the Free Software
Chris@0 18 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@0 19
Chris@0 20 module QueriesHelper
Chris@909 21
Chris@0 22 def operators_for_select(filter_type)
Chris@0 23 Query.operators_by_filter_type[filter_type].collect {|o| [l(Query.operators[o]), o]}
Chris@0 24 end
Chris@909 25
Chris@0 26 def column_header(column)
Chris@0 27 column.sortable ? sort_header_tag(column.name.to_s, :caption => column.caption,
Chris@909 28 :default_order => column.default_order) :
Chris@909 29 content_tag('th', h(column.caption))
Chris@0 30 end
Chris@909 31
Chris@0 32 def column_content(column, issue)
Chris@0 33 value = column.value(issue)
Chris@909 34
Chris@0 35 case value.class.name
Chris@0 36 when 'String'
Chris@0 37 if column.name == :subject
Chris@0 38 link_to(h(value), :controller => 'issues', :action => 'show', :id => issue)
Chris@0 39 else
Chris@0 40 h(value)
Chris@0 41 end
Chris@0 42 when 'Time'
Chris@0 43 format_time(value)
Chris@0 44 when 'Date'
Chris@0 45 format_date(value)
Chris@0 46 when 'Fixnum', 'Float'
Chris@0 47 if column.name == :done_ratio
Chris@0 48 progress_bar(value, :width => '80px')
Chris@0 49 else
Chris@909 50 h(value.to_s)
Chris@0 51 end
Chris@0 52 when 'User'
Chris@0 53 link_to_user value
Chris@0 54 when 'Project'
Chris@14 55 link_to_project value
Chris@0 56 when 'Version'
Chris@0 57 link_to(h(value), :controller => 'versions', :action => 'show', :id => value)
Chris@0 58 when 'TrueClass'
Chris@0 59 l(:general_text_Yes)
Chris@0 60 when 'FalseClass'
Chris@0 61 l(:general_text_No)
Chris@0 62 when 'Issue'
Chris@0 63 link_to_issue(value, :subject => false)
Chris@0 64 else
Chris@0 65 h(value)
Chris@0 66 end
Chris@0 67 end
Chris@0 68
Chris@0 69 # Retrieve query from session or build a new query
Chris@0 70 def retrieve_query
Chris@0 71 if !params[:query_id].blank?
Chris@0 72 cond = "project_id IS NULL"
Chris@0 73 cond << " OR project_id = #{@project.id}" if @project
Chris@0 74 @query = Query.find(params[:query_id], :conditions => cond)
Chris@507 75 raise ::Unauthorized unless @query.visible?
Chris@0 76 @query.project = @project
Chris@0 77 session[:query] = {:id => @query.id, :project_id => @query.project_id}
Chris@0 78 sort_clear
Chris@909 79 elsif api_request? || params[:set_filter] || session[:query].nil? || session[:query][:project_id] != (@project ? @project.id : nil)
Chris@909 80 # Give it a name, required to be valid
Chris@909 81 @query = Query.new(:name => "_")
Chris@909 82 @query.project = @project
Chris@909 83 build_query_from_params
Chris@909 84 session[:query] = {:project_id => @query.project_id, :filters => @query.filters, :group_by => @query.group_by, :column_names => @query.column_names}
Chris@0 85 else
Chris@909 86 # retrieve from session
Chris@909 87 @query = Query.find_by_id(session[:query][:id]) if session[:query][:id]
Chris@909 88 @query ||= Query.new(:name => "_", :filters => session[:query][:filters], :group_by => session[:query][:group_by], :column_names => session[:query][:column_names])
Chris@909 89 @query.project = @project
Chris@909 90 end
Chris@909 91 end
Chris@909 92
Chris@909 93 def build_query_from_params
Chris@909 94 if params[:fields] || params[:f]
Chris@909 95 @query.filters = {}
Chris@909 96 @query.add_filters(params[:fields] || params[:f], params[:operators] || params[:op], params[:values] || params[:v])
Chris@909 97 else
Chris@909 98 @query.available_filters.keys.each do |field|
Chris@909 99 @query.add_short_filter(field, params[field]) if params[field]
Chris@0 100 end
Chris@0 101 end
Chris@909 102 @query.group_by = params[:group_by] || (params[:query] && params[:query][:group_by])
Chris@909 103 @query.column_names = params[:c] || (params[:query] && params[:query][:column_names])
Chris@0 104 end
Chris@0 105 end