aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src
diff options
context:
space:
mode:
authorJulien Lancelot <julien.lancelot@sonarsource.com>2016-11-08 12:41:25 +0100
committerJulien Lancelot <julien.lancelot@sonarsource.com>2016-11-09 16:47:34 +0100
commit72fa937e63b9ec047ef5b0cb5df6d192e6909cfb (patch)
tree6c0c74b0327d4a84ed6c8fa685aece5e50da2702 /server/sonar-web/src
parentc1cd38a648edbd56f5ca928ea7e9a2a97ff1de8a (diff)
downloadsonarqube-72fa937e63b9ec047ef5b0cb5df6d192e6909cfb.tar.gz
sonarqube-72fa937e63b9ec047ef5b0cb5df6d192e6909cfb.zip
SONAR-8355 Remove rails code related to measure filters
Diffstat (limited to 'server/sonar-web/src')
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/controllers/all_projects_controller.rb34
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/helpers/application_helper.rb307
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/helpers/components_helper.rb87
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/helpers/measures_helper.rb130
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/helpers/properties_helper.rb12
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter.rb372
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display.rb49
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display_list.rb109
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_favourite.rb25
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/models/property_type.rb1
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/models/user.rb9
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/views/all_projects/index.html.erb81
12 files changed, 0 insertions, 1216 deletions
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/all_projects_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/all_projects_controller.rb
deleted file mode 100644
index 356c0012ea9..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/all_projects_controller.rb
+++ /dev/null
@@ -1,34 +0,0 @@
-#
-# SonarQube, open source software quality management tool.
-# Copyright (C) 2008-2014 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# SonarQube is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 3 of the License, or (at your option) any later version.
-#
-# SonarQube 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
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser 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.
-#
-class AllProjectsController < ApplicationController
-
- SECTION=Navigation::SECTION_HOME
-
- def index
- @qualifier = params[:qualifier]||'TRK'
- bad_request("The 'qualifier' parameter is not valid. It must reference a root type.") unless Project.root_qualifiers.include?(@qualifier)
-
- @filter = MeasureFilter.new
- @filter.criteria={:qualifiers => @qualifier, :sort => 'name', :asc => (params[:asc]!='false'), :pageSize=>200, :page => params[:page]}
- @filter.require_links=true
- @filter.execute(self, :user => current_user)
- end
-
-end
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/application_helper.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/application_helper.rb
index 4e4819a04bc..55432e2504a 100644
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/application_helper.rb
+++ b/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/application_helper.rb
@@ -127,21 +127,6 @@ module ApplicationHelper
Api::Utils.message(key, options)
end
- # deprecated since 2.5. Use trend_icon() instead
- def tendency_icon(metric_or_measure, small=true, no_tendency_img=true)
- trend_icon(nil, {:empty => !no_tendency_img})
- end
-
- def boolean_icon(boolean_value, options={})
- if boolean_value
- "<i class='icon-check'></i>"
- elsif options[:display_false]
- image_tag('cross.png', options)
- else
- nil
- end
- end
-
def configuring?
params['configuring']=='true'
end
@@ -155,298 +140,6 @@ module ApplicationHelper
Metric.by_key(key)
end
- # URL to static resource.
- #
- # === Optional parameters
- #
- # * <tt>:plugin</tt> - key of plugin, from where this resource should be loaded.
- #
- # === Examples
- #
- # url_for_static(:path => 'images/sonarqube-24x100.png')
- # url_for_static(:plugin => 'myplugin', :path => 'image.png')
- def url_for_static(options={})
- if options[:plugin]
- "#{ApplicationController.root_context}/static/#{options[:plugin]}/#{options[:path]}"
- else
- "#{ApplicationController.root_context}/#{options[:path]}"
- end
- end
-
- # URL to measures drilldown page for a given metric.
- #
- # === Optional parameters
- #
- # * <tt>:resource</tt> - id or key of the selected resource
- # * <tt>:highlight</tt> - key of the metric to highlight, different than the metric to drilldown.
- # * <tt>:period</tt> - period index
- #
- # === Examples
- #
- # url_for_drilldown('ncloc')
- # url_for_drilldown('ncloc', {:resource => 'org.apache.struts:struts-parent', :highlight => 'lines'})
- # url_for_drilldown('ncloc', {:resource => 'org.apache.struts:struts-parent'})
- #
- def url_for_drilldown(metric_or_measure, options={})
- if options[:resource].nil? && !@resource
- return ''
- end
-
- if metric_or_measure.is_a? ProjectMeasure
- metric_key = metric_or_measure.metric.key
- elsif metric_or_measure.is_a? Metric
- metric_key = metric_or_measure.key
- else
- metric_key = metric_or_measure
- end
-
- issues_metrics = get_issue_metrics
-
- if issues_metrics.include? metric_key
- resource = options[:resource]||@resource.key
- url = url_for({:controller => 'component_issues', :action => 'index'}) + '?id=' + url_encode(resource) + '#'
- if options[:period] && @snapshot
- snapshot_datetime = @snapshot.period_datetime(options[:period])
- if snapshot_datetime
- date = snapshot_datetime.strftime('%FT%T%z')
- url += "createdAfter=#{date}|"
- end
- end
- case metric_key
- when 'blocker_violations', 'new_blocker_violations'
- url += 'resolved=false|severities=BLOCKER'
- when 'critical_violations', 'new_critical_violations'
- url += 'resolved=false|severities=CRITICAL'
- when 'major_violations', 'new_major_violations'
- url += 'resolved=false|severities=MAJOR'
- when 'minor_violations', 'new_minor_violations'
- url += 'resolved=false|severities=MINOR'
- when 'info_violations', 'new_info_violations'
- url += 'resolved=false|severities=INFO'
- when 'open_issues'
- url += 'resolved=false|statuses=OPEN'
- when 'reopened_issues'
- url += 'resolved=false|statuses=REOPENED'
- when 'confirmed_issues'
- url += 'resolved=false|statuses=CONFIRMED'
- when 'false_positive_issues'
- url += 'resolutions=FALSE-POSITIVE'
- else
- url += 'resolved=false'
- end
- else
- url = url_for(options.merge({:controller => 'drilldown', :action => 'measures', :metric => metric_key, :id => options[:resource]||@resource.id}))
- end
-
- url
- end
-
- #
- # Display a measure
- #
- # === Optional parameters
- # * <tt>:skip_span_id</tt> - skip the generation of the html attribute 'id'. Default is false
- # * <tt>:url</tt> - add an url on the measure.
- # * <tt>:prefix</tt> - add a prefix. Default is ''.
- # * <tt>:suffix</tt> - add a suffix. Default is ''.
- # * <tt>:period</tt> - period index, from 1 to 5. Optional. Default is nil.
- # * <tt>:default</tt> - text to return if metric or measure not found. Default is blank string.
- #
- # === Examples
- #
- # format_measure('ncloc')
- # format_measure('ncloc', {:suffix => '', :url => url_for_drilldown('ncloc'), :default => '-'})
- #
- def format_measure(metric_or_measure, options={})
- html=''
- m=nil
- if metric_or_measure.is_a? ProjectMeasure
- m = metric_or_measure
- elsif @snapshot
- m = @snapshot.measure(metric_or_measure)
- end
-
- if m.nil?
- return options[:default] || ''
- end
-
- if m && m.metric
- link_rel=''
- show_link= !options[:url].blank?
-
- if options[:period]
- html=m.format_numeric_value(m.variation(options[:period].to_i))
- elsif m.metric.val_type==Metric::VALUE_TYPE_LEVEL
- if m.alert_status.blank?
- html = m.formatted_value
- else
- html = "<i class=\"icon-alert-#{m.alert_status.downcase}\"></i>"
- end
- elsif m.metric.val_type == Metric::VALUE_TYPE_RATING
- html = m.formatted_value
- if html.ord < 65 || html.ord > 69
- html = (Integer(html) + 64).chr
- end
- else
- html = m.formatted_value
- end
-
- alert_class=''
- style = ''
- if !(m.alert_status.blank?)
- alert_class="class='alert_#{m.alert_status}'" unless m.metric.val_type==Metric::VALUE_TYPE_LEVEL
- link_rel=h(m.alert_text)
- elsif m.metric.val_type==Metric::VALUE_TYPE_RATING
- alert_class="class='rating rating-" + html + "'"
- end
-
- span_id=''
- unless options[:skip_span_id]
- span_id="id='m_#{m.key}'"
- end
- html="<span #{span_id} #{alert_class} #{style}>#{html}</span>"
- if options[:prefix]
- html="#{options[:prefix]}#{html}"
- end
- if options[:suffix]
- html="#{html}#{options[:suffix]}"
- end
-
- if show_link
- if options[:url].blank?
- url='#'
- link_class='nolink'
- else
- url=options[:url]
- link_class=''
- end
- # Do not put url between simple quotes to prevent problem if url contain simple quote
- html='<a href="'+ url +'"'+ " class='widget-link #{link_class}' rel='#{link_rel}' title='#{link_rel}'>#{html}</a>"
- end
- end
- html
- end
-
-
- #
- #
- # link to the current page with the given resource. If file, then open a popup to display resource viewers.
- #
- #
- def link_to_resource(resource, name=nil, options={})
- period_index=options[:period]
- period_index=nil if period_index && period_index<=0
- if resource.display_dashboard?
- if options[:dashboard]
- root = "#{ApplicationController.root_context}/dashboard/index?"
- else
- # stay on the same page (for example components)
- root = "#{ApplicationController.root_context}/#{u params[:controller]}/#{u params[:action]}?"
- end
- path = ''
- query = request.query_parameters
- query[:id] = resource.id
- query[:metric] = options[:metric] if options[:metric]
- query[:period] = period_index if period_index
- query.each do |key, value|
- path += '&' unless path.empty?
- path += "#{u key}=#{u value}"
- end
- "<a class='#{options[:class]}' title='#{options[:title]}' href='#{root + path}'>#{name || resource.name}</a>"
- else
- url = "#{ApplicationController.root_context}/dashboard/index?id=#{u resource.key}"
- url += "&period=#{u period_index}" if period_index
- url += "&metric=#{u options[:metric]}" if options[:metric]
- "<a class='#{options[:class]}' title='#{options[:title]}' " +
- "onclick='window.open(this.href,\"resource-#{resource.key.parameterize}\",\"\");return false;' " +
- "href='#{url}'>#{name || resource.name}</a>"
- end
- end
-
-
- #
- #
- # Piechart for a distribution string or measure (foo=1;bar=2)
- #
- #
- def piechart(distribution, options={})
- chart = ""
- data=nil
- if distribution
- data=(distribution.kind_of? ProjectMeasure) ? distribution.data : distribution
- end
-
- if data && data.size > 0
- labels = []
- values = []
- skipZeros = options[:skipZeros].nil? ? true : options[:skipZeros]
- options[:skipZeros] = nil
- data.split(';').each do |pair|
- splitted = pair.split('=')
- value = splitted[1]
- next if skipZeros && value.to_i == 0
- labels << splitted[0]
- values << value
- end
- if labels.size > 0
- options[:alt] ||= ""
- chart = gchart("chs=#{options[:size] || '250x90'}&chd=t:#{values.join(',')}&cht=p&chl=#{labels.join('|')}", options)
- end
- end
- chart
- end
-
- #
- #
- # Draw a HTML/CSS bar
- #
- # === Optional parameters
- # * width: container width in pixels. Default is 150.
- # * percent: integer between -100 and 100. Size of the bar inside the container. Default is 100. Bar is aligned to right if the value is negative.
- # * color: the bar HTML color. Default value is '#777'
- # * tooltip: tooltip to display on the bar
- #
- def barchart(options)
- percent = (options[:percent] || 100).to_i
- width=(options[:width] || 150).to_i
- if options[:positive_color] && percent>0
- color = options[:positive_color]
- elsif options[:negative_color] && percent<0
- color = options[:negative_color]
- else
- color = options[:color]||'#236a97'
- end
-
- align=(percent<0 ? 'float: right;' : nil)
- "<div class='barchart' style='width: #{width}px' title='#{options[:tooltip]}'><div style='width: #{percent.abs}%;background-color:#{color};#{align}'></div></div>"
- end
-
- def chart(parameters, options={})
- image_tag("#{ApplicationController.root_context}/chart?#{parameters}", options)
- end
-
- def link_to_favourite(resource, deprecated_options=nil)
- return '' unless (logged_in?)
- return '' if resource.nil?
- resource_id=(resource.is_a?(Fixnum) ? resource : resource.permanent_id)
-
- if current_user.favourite?(resource_id)
- css='icon-favorite'
- title=message('click_to_remove_from_favorites')
- else
- css='icon-not-favorite'
- title=message('click_to_add_to_favorites')
- end
- link_to_function '', "toggleFav(#{resource_id}, this)", :class => css, :title => title
- end
-
- #
- # Unsupported since version 5.2
- #
- def trend_icon(metric_or_measure, options={})
- return options[:empty] ? "<i class=\"icon-trend-0\"></i>" : nil
- end
-
#
#
# Numeric value of variation
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/components_helper.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/components_helper.rb
deleted file mode 100644
index ffb0b1727f3..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/components_helper.rb
+++ /dev/null
@@ -1,87 +0,0 @@
-#
-# SonarQube, open source software quality management tool.
-# Copyright (C) 2008-2014 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# SonarQube is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 3 of the License, or (at your option) any later version.
-#
-# SonarQube 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
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser 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 ComponentsHelper
- include ActionView::Helpers::UrlHelper
-
- def get_header_content(column, snapshot)
- get_column_content(column, snapshot, {snapshot => snapshot.measures}, 'th')
- end
-
- def get_column_content(column, snapshot, measures_by_snapshot, html_node='td')
- project = snapshot.project
- content = ''
- nowrap = true
- measure_param = '0'
-
- if column.language_column?
- content = project.language || ''
-
- elsif column.version_column?
- content = snapshot.version || ''
-
- elsif column.links_column?
- links = links_by_project_uuid[project.uuid]
- if links
- links.each do |link|
- content << link_to("<i class='icon-#{link.link_type}' alt='#{link.name}'></i>", link.href, :popup => true) unless link.custom?
- content << '&nbsp;&nbsp;'
- end
- end
- elsif column.build_time_column?
- measure_param = snapshot.created_at.tv_sec
- content = human_short_date( snapshot.created_at )
-
- elsif column.metric_column?
- measure = item_by_metric_id(measures_by_snapshot[snapshot], column.id )
- measure_param = measure.value if measure
- content = format_measure(measure)
- end
-
- "<#{html_node} #{"nowrap='nowrap'" if nowrap} #{"x='#{measure_param}'" if measure_param} class='right'><span class='no-transform'>" + content + "</span></#{html_node}>"
- end
-
-
- def search_measure(measures, metric_key)
- item_by_metric_id(measures, metric_key )
- end
-
- private
-
- def item_by_metric_id(items, metric_name)
- return nil if items.nil?
- items.each do |item|
- metric = Metric.by_name(metric_name)
- return item if (item && metric && item.metric_id==metric.id && item.person_id.nil?)
- end
- nil
- end
-
- def links_by_project_uuid
- @links_by_project_uuid ||= {}
- if @links_by_project_uuid.empty?
- ProjectLink.find(:all, :order => 'link_type').each do |link|
- @links_by_project_uuid[link.component_uuid] ||= []
- @links_by_project_uuid[link.component_uuid]<<link
- end
- end
- @links_by_project_uuid
- end
-
-end
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/measures_helper.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/measures_helper.rb
deleted file mode 100644
index 6bcfae18be6..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/measures_helper.rb
+++ /dev/null
@@ -1,130 +0,0 @@
-#
-# SonarQube, open source software quality management tool.
-# Copyright (C) 2008-2014 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# SonarQube is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 3 of the License, or (at your option) any later version.
-#
-# SonarQube 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
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser 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 MeasuresHelper
-
- def list_column_html(filter, column, widget_id)
- if column.sort?
- html = link_to_function(h(column.title_label), "refreshList#{widget_id}('#{h escape_javascript column.key}',#{!filter.sort_asc?}, '#{h(escape_javascript(filter.criteria[:page])) || 1}')", :title => h(column.tooltip))
- else
- html=h(column.title_label)
- end
- if column.period
- html += "<br><span class='note'>#{Api::Utils.period_abbreviation(column.period)}</small>"
- end
- if column.sort? && filter.sort_key==column.key
- html << (filter.sort_asc? ? ' <i class="icon-sort-asc"></i>' : ' <i class="icon-sort-desc"></i>')
- end
- "<th class='#{column.align} #{column.title_css}'>#{html}</th>"
- end
-
- def list_cell_html(column, row)
- if column.metric
- measure = row.measure(column.metric)
- if column.period
- if measure && measure.metric.on_new_code?
- format_new_metric_measure(measure, column.period)
- else
- format_variation(measure, :index => column.period, :style => 'light')
- end
- else
- format_measure(measure) + ' '
- end
-
- elsif column.key=='name'
- "#{qualifier_icon(row.resource)} #{link_to(h(row.resource.name(true)), {:controller => 'dashboard', :id => row.resource.id}, {:title => h(row.resource.key)})}"
- elsif column.key=='short_name'
- "#{qualifier_icon(row.resource)} #{link_to(h(row.resource.name(false)), {:controller => 'dashboard', :id => row.resource.id}, {:title => h(row.resource.key)})}"
- elsif column.key=='date'
- human_short_date(row.analysis.created_at) if row.analysis
- elsif column.key=='project_creation_date'
- human_short_date(row.resource.created_at) if row.resource.created_at
- elsif column.key=='key'
- "<span class='small'>#{row.resource.kee}</span>"
- elsif column.key=='description'
- h row.resource.description
- elsif column.key=='version'
- h row.analysis.version if row.analysis
- elsif column.key=='language'
- Api::Utils.language_name(row.resource.language)
- elsif column.key=='links' && row.links
- html = ''
- row.links.select { |link| link.href.start_with?('http') }.each do |link|
- html += "<a target='_blank' href='#{link.href}' class='icon-#{link.link_type}'></a> " unless link.custom?
- end
- html
- end
- end
-
- def measure_filter_star(filter, is_favourite)
- if is_favourite
- style='icon-favorite'
- title=message('click_to_remove_from_favorites')
- else
- style='icon-not-favorite'
- title=message('click_to_add_to_favorites')
- end
-
- "<a href='#' id='star-#{filter.name.parameterize}' class='measure-filter-star #{style}' filter-id='#{filter.id}' title='#{title}'></a>"
- end
-
- def period_labels
- [Api::Utils.period_label(1), Api::Utils.period_label(2), Api::Utils.period_label(3)]
- end
-
- def more_criteria_options(filter)
- more_criteria_options = [['', '']]
- more_criteria_options << [message('measure_filter.criteria.metric'), 'metric']
- more_criteria_options << [message('measure_filter.criteria.age'), 'age'] unless filter.criteria('ageMinDays') || filter.criteria('ageMaxDays')
- more_criteria_options << [message('measure_filter.criteria.date'), 'date'] unless filter.criteria('fromDate') || filter.criteria('toDate')
- more_criteria_options << [message('measure_filter.criteria.only_favorites'), 'fav'] unless filter.criteria('onFavourites')
- more_criteria_options << [message('measure_filter.criteria.key'), 'key'] unless filter.criteria('keySearch')
- more_criteria_options << [message('measure_filter.criteria.language'), 'lang'] unless filter.criteria('languages')
- more_criteria_options << [message('measure_filter.criteria.name'), 'name'] unless filter.criteria('nameSearch')
- more_criteria_options << [message('measure_filter.criteria.components_of_project'), 'project'] unless filter.base_resource
- more_criteria_options << [message('measure_filter.criteria.alert'), 'alert'] unless filter.criteria('alertLevels')
- # SONAR-4508 sort criterias
- Api::Utils.insensitive_sort(more_criteria_options){|option| option[0]}
- end
-
-
- private
-
- #
- # This method is a inspired by ApplicationHelper#format_variation for measure where metrics key begin with 'new_'
- # It will display measure in color, without operand (+/-), and prefix with a %.
- #
- def format_new_metric_measure(metric_or_measure, index)
- if metric_or_measure.is_a?(ProjectMeasure)
- m = metric_or_measure
- elsif @snapshot
- m = @snapshot.measure(metric_or_measure)
- end
- html=nil
- if m
- val=variation_value(m, :index => index)
- if val
- formatted_val = m.format_numeric_value(val, :variation => false)
- html = "<span>#{formatted_val}</span>"
- end
- end
- html
- end
-
-end
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/properties_helper.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/properties_helper.rb
index 55c546244d7..408472e7a4f 100644
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/properties_helper.rb
+++ b/server/sonar-web/src/main/webapp/WEB-INF/app/helpers/properties_helper.rb
@@ -73,22 +73,10 @@ module PropertiesHelper
size = options[:size] || 50
text_field_tag name, value, {:size => size}.update(html_options)
- when PropertyType::TYPE_FILTER
- user_filters = options_id(value, current_user.measure_filters)
- shared_filters = options_id(value, MeasureFilter.find(:all, :conditions => ['(user_id<>? or user_id is null) and shared=?', current_user.id, true]).sort_by(&:name))
-
- filters_combo = select_tag name, option_group('My Filters', user_filters) + option_group('Shared Filters', shared_filters), html_options
- filter_link = link_to message('widget.filter.edit'), {:controller => 'measures', :action => 'manage'}, :class => 'link-action'
-
- "#{filters_combo} #{filter_link}"
-
when PropertyType::TYPE_ISSUE_FILTER
user_filters = options_id(value, Internal.issues.findIssueFiltersForCurrentUser())
shared_filters = options_id(value, Internal.issues.findSharedFiltersForCurrentUser())
- #user_filters = options_id(value, current_user.measure_filters)
- #shared_filters = options_id(value, MeasureFilter.find(:all, :conditions => ['(user_id<>? or user_id is null) and shared=?', current_user.id, true]).sort_by(&:name))
-
filters_combo = select_tag name, option_group('My Filters', user_filters) + option_group('Shared Filters', shared_filters), html_options
filter_link = link_to message('widget.filter.edit'), {:controller => 'issues', :action => 'manage'}, :class => 'link-action'
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter.rb
deleted file mode 100644
index 46fcb766648..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter.rb
+++ /dev/null
@@ -1,372 +0,0 @@
-#
-# SonarQube, open source software quality management tool.
-# Copyright (C) 2008-2014 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# SonarQube is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 3 of the License, or (at your option) any later version.
-#
-# SonarQube 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
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser 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.
-#
-require 'set'
-class MeasureFilter < ActiveRecord::Base
-
- # Row in the table of results
- class Row
- attr_reader :component, :measures_by_metric, :links, :analysis
-
- def initialize(component)
- @component = component
- @measures_by_metric = {}
- @links = nil
- end
-
- def resource
- component
- end
-
- # For internal use
- def add_measure(measure)
- @measures_by_metric[measure.metric] = measure
- end
-
- # For internal use
- def set_analysis(analysis)
- @analysis=analysis
- end
-
- # For internal use
- def add_link(link)
- @links ||= []
- @links << link
- end
-
- def measure(metric)
- @measures_by_metric[metric]
- end
-
- def measures
- @measures_by_metric.values
- end
- end
-
- CRITERIA_SEPARATOR = '|'
- CRITERIA_KEY_VALUE_SEPARATOR = ','
-
- belongs_to :user
- has_many :measure_filter_favourites, :dependent => :delete_all
-
- validates_length_of :description, :allow_nil => true, :maximum => 4000
- validate :validate_name
-
- attr_reader :pagination, :security_exclusions, :base_row, :rows, :display
-
- def validate_name
- if name.nil? || name.empty?
- errors.add :name, Api::Utils.message('measure_filter.missing_name')
- elsif name.size > 100
- errors.add :name, Api::Utils.message('measure_filter.name_too_long')
- end
- end
-
- def sort_key
- criteria['sort']
- end
-
- def sort_asc?
- criteria['asc']!='false'
- end
-
- # array of the metrics to use when loading measures
- def metrics
- @metrics ||= []
- end
-
- # Set the metrics of the result measures to load. Array of Metric or String.
- def metrics=(array=[])
- @metrics = array.map { |m| m.is_a?(Metric) ? m : Metric.by_key(m) }.compact
- end
-
- # Enable the loading of result links. False by default
- def require_links=(flag)
- @require_links=flag
- end
-
- # boolean flag that indicates if project links should be loaded
- def require_links?
- @require_links
- end
-
- def require_authentication?
- criteria[:onFavourites]=='true'
- end
-
- def can_be_reassigned_by(user)
- user.has_role?(:admin) && shared
- end
-
- def criteria(key=nil)
- @criteria ||= HashWithIndifferentAccess.new
- if key
- @criteria[key]
- else
- @criteria
- end
- end
-
- def criteria=(hash)
- @criteria = HashWithIndifferentAccess.new
- hash.each_pair do |k, v|
- set_criteria_value(k, v)
- end
- end
-
- def override_criteria(hash)
- @criteria ||= HashWithIndifferentAccess.new
- hash.each_pair do |k, v|
- set_criteria_value(k, v)
- end
- end
-
- # API used by Displays
- def set_criteria_value(key, value)
- @criteria ||= HashWithIndifferentAccess.new
- if key
- if value!=nil && value!='' && value!=['']
- value = (value.kind_of?(Array) ? value : value.to_s)
- @criteria[key]=value
- else
- @criteria.delete(key)
- end
- end
- end
-
- # API used by Displays
- def set_criteria_default_value(key, value)
- @criteria ||= HashWithIndifferentAccess.new
- unless @criteria.has_key?(key)
- if key
- if value!=nil && value!='' && value!=['']
- value = (value.kind_of?(Array) ? value : value.to_s)
- @criteria[key]=value
- else
- @criteria.delete(key)
- end
- end
- end
- end
-
- def load_criteria_from_data
- if self.data
- @criteria = self.data.split(CRITERIA_SEPARATOR).inject(HashWithIndifferentAccess.new) do |h, s|
- k, v=s.split('=')
- if k && v
- # nameSearch can contains comma, in this case we should not split the value
- if k != 'nameSearch'
- # Empty values are removed
- v=v.split(CRITERIA_KEY_VALUE_SEPARATOR).select{|v| !v.empty?} if v.include?(CRITERIA_KEY_VALUE_SEPARATOR)
- end
- h[k]=v
- end
- h
- end
- else
- @criteria = HashWithIndifferentAccess.new
- end
- end
-
- def convert_criteria_to_data
- string_data = []
- if @criteria
- @criteria.each_pair do |k, v|
- string_value = (v.is_a?(String) ? v : v.join(CRITERIA_KEY_VALUE_SEPARATOR))
- string_data << "#{k}=#{string_value}"
- end
- end
- self.data = string_data.join(CRITERIA_SEPARATOR)
- end
-
- def enable_default_display
- set_criteria_default_value('display', 'list')
- end
-
- def base_resource
- if criteria('base')
- Project.first(:conditions => ['kee=? and copy_component_uuid is null and developer_uuid is null', criteria('base')])
- end
- end
-
- def system?
- user_id == nil
- end
-
- # ==== Options
- # :user : the authenticated user
- def execute(controller, options={})
- init_results
- init_display(options)
- user = options[:user]
- result = Api::Utils.java_facade.executeMeasureFilter(criteria, (user && user.id))
- if result.error
- errors.add_to_base(Api::Utils.message("measure_filter.error.#{result.error}"))
- else
- rows = result.getRows()
- component_uuids = filter_authorized_component_uuids(rows, controller)
- base_project = filter_authorized_base_project(base_resource, controller)
- load_results(component_uuids, base_project)
- end
- self
- end
-
- def owner?(user)
- return false if user==nil || user.id==nil
- (self.id==nil) || (self.user_id==user.id) || (self.user_id==nil && user.has_role?(:admin))
- end
-
- private
-
- def init_results
- @pagination = nil
- @security_exclusions = nil
- @rows = nil
- @base_row = nil
- self
- end
-
- def init_display(options)
- @display = MeasureFilterDisplay.create(self, options)
- end
-
- def filter_authorized_base_project(base_resource, controller)
- # SONAR-4793
- # Verify that user has browse permission on base project
- controller.has_role?(:user, base_resource) ? base_resource : nil
- end
-
- def filter_authorized_component_uuids(rows, controller)
- project_uuids = rows.map { |row| row.getRootComponentUuid() }.compact.uniq
- authorized_project_uuids = controller.select_authorized(:user, project_uuids)
- component_uuids = rows.map { |row| row.getComponentUuid() if authorized_project_uuids.include?(row.getRootComponentUuid()) }.compact
- @security_exclusions = (component_uuids.size<rows.size)
- @pagination = Api::Pagination.new
- @pagination.per_page=(criteria(:pageSize)||999999).to_i
- @pagination.page=(criteria(:page)||1).to_i
- @pagination.count = component_uuids.size
- component_uuids[@pagination.offset ... (@pagination.offset+@pagination.limit)] || []
- end
-
- def load_results(component_uuids, base_resource)
- @rows = []
- metric_ids = metrics.map(&:id)
-
- if !component_uuids.empty?
- rows_by_component_uuid = {}
-
- components = []
- component_uuids.each_slice(999) do |safe_for_oracle_uuids|
- components.concat(Project.find(:all, :conditions => ['uuid in (?)', safe_for_oracle_uuids]))
- end
- project_uuids = []
- components.each do |component|
- row = Row.new(component)
- rows_by_component_uuid[component.uuid] = row
- project_uuids << component.project_uuid
- end
- project_uuids.uniq!
-
- analysis_by_project_uuid = Snapshot.all(:conditions => ['component_uuid in (?) and islast=?', project_uuids, true]).inject({}) do |hash, analysis|
- hash[analysis.component_uuid] = analysis
- hash
- end
-
- components.each do |component|
- analysis = analysis_by_project_uuid[component.project_uuid]
- rows_by_component_uuid[component.uuid].set_analysis(analysis) if analysis
- end
-
- # @rows must be in the same order as the component uuids
- component_uuids.each do |uuid|
- @rows << rows_by_component_uuid[uuid]
- end
-
- unless metric_ids.empty?
- measures = []
- component_uuids.each_slice(999) do |safe_for_oracle_uuids|
- measures.concat(ProjectMeasure.all(:include => :analysis, :conditions =>
- ['project_measures.person_id is null and project_measures.component_uuid in (?) and project_measures.metric_id in (?) and snapshots.islast=?', safe_for_oracle_uuids, metric_ids, true]
- ))
- end
- measures.each do |measure|
- row = rows_by_component_uuid[measure.component_uuid]
- row.add_measure(measure)
- end
- end
-
- if require_links?
- uuids_for_links = components.map { |c| c.uuid if c.scope=='PRJ'}.compact.uniq
-
- uuids_for_links.each_slice(999) do |safe_for_oracle_uuids|
- ProjectLink.all(:conditions => {:component_uuid => safe_for_oracle_uuids}, :order => 'link_type').each do |link|
- rows_by_component_uuid[link.component_uuid].add_link(link)
- end
- end
- end
- end
- if base_resource
- base_snapshot = base_resource.last_snapshot
- if base_snapshot
- @base_row = Row.new(base_resource)
- unless metric_ids.empty?
- base_measures = ProjectMeasure.all(:include => :analysis, :conditions =>
- ['project_measures.person_id is null and project_measures.component_uuid=? and project_measures.metric_id in (?) and snapshots.islast=?', base_resource.uuid, metric_ids, true]
- )
- base_measures.each do |base_measure|
- @base_row.add_measure(base_measure)
- end
- end
- end
- end
- end
-
- def validate
- # validate uniqueness of name
- if id
- # update existing filter
- if user_id
- count = MeasureFilter.count('id', :conditions => ['name=? and user_id=? and id<>?', name, user_id, id])
- else
- count = MeasureFilter.count('id', :conditions => ['name=? and user_id is null and id<>?', name, id])
- end
- else
- # new filter
- count = MeasureFilter.count('id', :conditions => ['name=? and user_id=?', name, user_id])
- end
- errors.add_to_base('Name already exists') if count>0
-
- if shared
- if id
- count = MeasureFilter.count('id', :conditions => ['name=? and shared=? and (user_id is null or user_id<>?) and id<>?', name, true, user_id, id])
- else
- count = MeasureFilter.count('id', :conditions => ['name=? and shared=? and (user_id is null or user_id<>?)', name, true, user_id])
- end
- errors.add_to_base('Other users already share filters with the same name') if count>0
-
- # Verify filter owner has sharing permission
- if !user
- errors.add(:user, "cannot own this filter because of insufficient rights")
- end
- elsif system?
- errors.add_to_base("System filters can't be unshared")
- end
- end
-
-end
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display.rb
deleted file mode 100644
index 8066e3d59ba..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display.rb
+++ /dev/null
@@ -1,49 +0,0 @@
-#
-# SonarQube, open source software quality management tool.
-# Copyright (C) 2008-2014 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# SonarQube is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 3 of the License, or (at your option) any later version.
-#
-# SonarQube 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
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser 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.
-#
-class MeasureFilterDisplay
-
- def self.create(filter, options)
- # Do not init a MeasureFilterDisplayList when we want to completely control the render (column to return, pagination, etc.) of the filter
- # For instance, the /measures/search_filter manage by itself the column and the pagination
- MeasureFilterDisplayList.new(filter, options) if filter.criteria('display') == 'list'
- end
-
- def key
- self.class::KEY
- end
-
- attr_reader :filter, :options
-
- def initialize(filter, options)
- @filter = filter
- @options = options
-
- if filter.base_resource
- qualifiers = filter.criteria(:qualifiers)
- filter.set_criteria_value(:onBaseComponents, 'true') unless qualifiers && !qualifiers.empty?
- end
- end
-
- # sorted array of parameters :
- # [[key1,value1], [key2,value2]]
- def url_params
- []
- end
-end
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display_list.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display_list.rb
deleted file mode 100644
index c56cdc6636b..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_display_list.rb
+++ /dev/null
@@ -1,109 +0,0 @@
-#
-# SonarQube, open source software quality management tool.
-# Copyright (C) 2008-2014 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# SonarQube is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 3 of the License, or (at your option) any later version.
-#
-# SonarQube 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
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser 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.
-#
-require 'set'
-class MeasureFilterDisplayList < MeasureFilterDisplay
- KEY = :list
- MAX_PAGE_SIZE = 250
-
- class Column
- attr_reader :key, :metric, :period
-
- def initialize(key)
- @key = key
- fields = @key.split(':')
- if fields.size>=2 && fields[0]=='metric'
- @metric = Metric.by_key(fields[1])
- @period = fields[2].to_i if fields.size>=3
- end
- end
-
- def title_label
- if @metric
- label = @metric.abbreviation
- else
- label = Api::Utils.message("measure_filter.abbr.#{@key}", :default => @key)
- end
- label
- end
-
- def tooltip
- if @metric
- tooltip = @metric.description
- else
- tooltip = Api::Utils.message("measure_filter.col.#{@key}", :default => @key)
- end
- tooltip
- end
-
- def align
- @align ||=
- begin
- # by default is table cells are left-aligned
- (@key=='name' || @key=='short_name' || @key=='description') ? '' : 'right'
- end
- end
-
- def title_css
- 'thin' if @metric && @metric.val_type==Metric::VALUE_TYPE_LEVEL
- end
-
- def row_css
- 'nowrap' unless (@metric && !@metric.numeric?) || @key=='description'
- end
-
- def sort?
- !links?
- end
-
- def links?
- @key == 'links'
- end
-
- end
-
- attr_reader :columns
-
- def initialize(filter, options)
- super(filter, options)
-
- # default values
- filter.set_criteria_default_value(:cols, ['metric:alert_status', 'name', 'date', 'metric:ncloc', 'metric:violations', 'links'])
- filter.set_criteria_default_value(:sort, 'name')
- filter.set_criteria_default_value(:asc, true)
- filter.set_criteria_default_value(:pageSize, 100)
- filter.set_criteria_value(:pageSize, MAX_PAGE_SIZE) if filter.criteria(:pageSize).to_i>MAX_PAGE_SIZE
-
- @columns = []
- metrics = []
- filter.criteria(:cols).each do |column_key|
- column = Column.new(column_key)
- @columns << column
- metrics << column.metric if column.metric
- filter.require_links=true if column.links?
- end
- filter.metrics=(metrics)
- end
-
- PROPERTY_KEYS = Set.new([:cols, :sort, :asc, :pageSize])
-
- def url_params
- @filter.criteria.select { |k, v| PROPERTY_KEYS.include?(k.to_sym) }
- end
-end
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_favourite.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_favourite.rb
deleted file mode 100644
index 441fd42c451..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/measure_filter_favourite.rb
+++ /dev/null
@@ -1,25 +0,0 @@
-#
-# SonarQube, open source software quality management tool.
-# Copyright (C) 2008-2014 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# SonarQube is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 3 of the License, or (at your option) any later version.
-#
-# SonarQube 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
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser 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.
-#
-class MeasureFilterFavourite < ActiveRecord::Base
- belongs_to :user
- belongs_to :measure_filter
-
- validates_uniqueness_of :measure_filter_id, :scope => :user_id
-end
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/property_type.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/property_type.rb
index 9c890604ca5..d8623c070fa 100644
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/property_type.rb
+++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/property_type.rb
@@ -29,7 +29,6 @@ class PropertyType
TYPE_LICENSE = 'LICENSE'
TYPE_REGULAR_EXPRESSION = 'REGULAR_EXPRESSION'
- TYPE_FILTER = 'FILTER'
# Since 3.7
TYPE_ISSUE_FILTER = 'ISSUE_FILTER'
TYPE_USER_LOGIN = 'USER_LOGIN'
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/models/user.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/models/user.rb
index 27954262a92..f6eec34aeb6 100644
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/models/user.rb
+++ b/server/sonar-web/src/main/webapp/WEB-INF/app/models/user.rb
@@ -26,15 +26,6 @@ class User < ActiveRecord::Base
has_and_belongs_to_many :groups
has_many :properties, :foreign_key => 'user_id', :dependent => :delete_all
- has_many :active_dashboards, :dependent => :destroy, :order => 'order_index'
- has_many :dashboards, :dependent => :destroy
- has_many :measure_filters, :class_name => 'MeasureFilter', :dependent => :delete_all, :order => 'name asc'
-
- # measure filters that are marked as favourites
- has_many :favourited_measure_filters, :class_name => 'MeasureFilter', :through => :measure_filter_favourites, :source => :measure_filter, :order => 'name asc'
-
- # the join table MEASURE_FILTER_FAVOURITES
- has_many :measure_filter_favourites, :class_name => 'MeasureFilterFavourite', :dependent => :delete_all
include Authentication
include Authentication::ByPassword
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/all_projects/index.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/all_projects/index.html.erb
deleted file mode 100644
index b7bc5fd17ef..00000000000
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/all_projects/index.html.erb
+++ /dev/null
@@ -1,81 +0,0 @@
-<% if @filter.rows %>
- <div class="page">
- <header class="page-header">
- <h1 class="page-title"><%= message('qualifiers.all.' + @qualifier) -%></h1>
- </header>
-
- <div id="all-projects">
-
- <% if @filter.security_exclusions %>
- <p class="notes"><%= message('all-projects.results_not_display_due_to_security') -%></p>
- <% end %>
-
- <%
- display_favourites = logged_in?
- colspan = 5
- colspan += 1 if display_favourites
- %>
-
- <table class="data" id="all-projects-table">
- <thead>
- <tr>
- <% if display_favourites %>
- <th class="thin" style></th>
- <% end %>
- <th class="thin nowrap">
- <%= link_to message('all-projects.cols.name'), {:action => 'index', :qualifier => params[:qualifier], :asc => (!@filter.sort_asc?).to_s} -%>
- <%= @filter.sort_asc? ? '<i class="icon-sort-asc"></i>' : '<i class="icon-sort-desc"></i>' -%>
- </th>
- <th></th>
- <th></th>
- <th></th>
- <th></th>
- </tr>
- </thead>
-
- <tbody>
- <% @filter.rows.each do |row| %>
- <tr class="thin <%= cycle 'even', 'odd' -%>">
- <% if display_favourites %>
- <td class="thin"><%= link_to_favourite(row.resource) -%></td>
- <% end %>
- <td class="nowrap">
- <%= qualifier_icon(row.resource) -%> <%= link_to(h(row.resource.name(true)), {:controller => 'dashboard', :id => row.resource.id}, :title => h(row.resource.key)) -%>
- </td>
- <td class="sep"></td>
- <td>
- <%= h row.resource.description -%>
- </td>
- <td class="sep"></td>
- <td class="nowrap text-right">
- <%
- if row.links
- row.links.select { |link| link.href.start_with?('http') }.each do |link|
- %>
- <a target="_blank" href="<%= link.href -%>" class="icon-<%= link.link_type -%>"></a>
- <%
- end
- end
- %>
- </td>
- </tr>
- <% end %>
-
- <% if @filter.rows.empty? %>
- <tr class="even">
- <td colspan="<%= colspan -%>"><%= message 'no_data' -%></td>
- </tr>
- <% end %>
- </tbody>
-
- <%= table_pagination(@filter.pagination, :colspan => colspan) { |label, page_id|
- link_to(label, :action => 'index', :qualifier => h(@qualifier), :asc => h(@filter.criteria[:asc]), :page => page_id)
- }
- -%>
-
- </table>
- </div>
-
- </div>
-
-<% end %>