aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-server
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@gmail.com>2012-12-05 15:06:56 +0100
committerSimon Brandhof <simon.brandhof@gmail.com>2012-12-05 15:21:02 +0100
commit86dfaf2c03da2d7bc6c2f96a40b256cd96bc1132 (patch)
treea91a5dce2efa71ca154a9a64209d459db3845142 /sonar-server
parent2e92279e6f0f2bdea326b39fc50b740ca7f224b5 (diff)
downloadsonarqube-86dfaf2c03da2d7bc6c2f96a40b256cd96bc1132.tar.gz
sonarqube-86dfaf2c03da2d7bc6c2f96a40b256cd96bc1132.zip
Fix height of treemaps in production mode
Diffstat (limited to 'sonar-server')
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/models/sonar/treemap.rb180
1 files changed, 0 insertions, 180 deletions
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/models/sonar/treemap.rb b/sonar-server/src/main/webapp/WEB-INF/app/models/sonar/treemap.rb
deleted file mode 100644
index 63ae871374b..00000000000
--- a/sonar-server/src/main/webapp/WEB-INF/app/models/sonar/treemap.rb
+++ /dev/null
@@ -1,180 +0,0 @@
-#
-# Sonar, entreprise quality control tool.
-# Copyright (C) 2008-2012 SonarSource
-# mailto:contact AT sonarsource DOT com
-#
-# Sonar 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.
-#
-# Sonar 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 Sonar; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
-#
-class Sonar::Treemap
- include ActionView::Helpers::UrlHelper
-
- attr_accessor :size_metric, :color_metric, :height, :root_snapshot, :period_index,
- :id, :components_size, :measures
-
- def initialize(id, size_metric, height, options={})
- @components_size = 0
- @id = id
- @size_metric = size_metric
- @height = height
-
- @color_metric = options[:color_metric]
- @root_snapshot = options[:root_snapshot]
- @measures_by_snapshot = options[:measures_by_snapshot] # pre-computed measures, for example by filters
- if options[:period_index] && options[:period_index]>0
- @period_index = options[:period_index]
- end
- end
-
- def self.size_metrics()
- Metric.all.select { |metric|
- metric.treemap_size?
- }.sort
- end
-
- def self.color_metrics
- Metric.all.select { |metric|
- metric.treemap_color?
- }.sort
- end
-
- def generate_html
- root = Treemap::Node.new(:id => -1, :label => '')
- build_tree(root)
-
- output = Sonar::HtmlOutput.new do |o|
- o.width = 100
- o.height = @height
- o.full_html = false
- o.details_at_depth = 1
- end
- html = output.to_html(root)
- html + "<script>treemapById(#{@id}).onLoaded(#{@components_size});</script>"
- end
-
- def empty?
- @components_size==0
- end
-
- protected
-
- def measures_by_snapshot
- @measures_by_snapshot ||=
- begin
- metric_ids=[@size_metric.id]
- metric_ids << @color_metric.id if @color_metric && @color_metric.id!=@size_metric.id
-
- sql_conditions = 'snapshots.islast=? AND project_measures.characteristic_id IS NULL and project_measures.rule_id IS NULL ' +
- 'and project_measures.rule_priority IS NULL and project_measures.person_id IS NULL and project_measures.metric_id in (?)'
- sql_values = [true, metric_ids]
- if @root_snapshot
- sql_conditions += " AND snapshots.parent_snapshot_id=?"
- sql_values << @root_snapshot.id
- else
- sql_conditions<<" AND snapshots.scope='PRJ' and snapshots.qualifier='TRK'"
- end
-
- hash = {}
- ProjectMeasure.find(:all, :include => {:snapshot => :project}, :conditions => [sql_conditions].concat(sql_values)).each do |m|
- hash[m.snapshot]||={}
- hash[m.snapshot][m.metric]=m
- end
- hash
- end
- end
-
- def build_tree(node)
- measures_by_snapshot.each_pair do |snapshot, measures|
- size_measure=measures[size_metric]
- if size_measure
- color_measure=(color_metric ? measures[color_metric] : nil)
- resource = snapshot.project
- child = Treemap::Node.new(:id => "#{@id}-#{@components_size += 1}",
- :size => size_value(size_measure),
- :label => resource.name(false),
- :title => escape_javascript(resource.name(true)),
- :tooltip => tooltip(resource, size_measure, color_measure),
- :color => html_color(color_measure),
- :rid => resource.id,
- :leaf => resource.source_code?)
- node.add_child(child)
- end
- end
- end
-
- def tooltip(resource, size_measure, color_measure)
- html=CGI::escapeHTML(resource.name(true))
- html += " - #{CGI::escapeHTML(@size_metric.short_name)}: #{CGI::escapeHTML(size_measure.formatted_value)}"
- if color_measure
- html += " - #{CGI::escapeHTML(@color_metric.short_name)}: #{CGI::escapeHTML(color_measure.formatted_value)}"
- end
- html
- end
-
- def size_value(measure)
- if @period_index
- var=measure.variation(@period_index)
- var ? var.to_f.abs : 0.0
- elsif measure.value
- measure.value.to_f.abs||0.0
- else
- 0.0
- end
- end
-
- def html_color(measure)
- MeasureColor.color(measure).html
- end
-
-end
-
-class Sonar::HtmlOutput < Treemap::HtmlOutput
-
- def draw_node(node)
- return "" if node.bounds.nil?
-
- html = ''
- html += "<div style=\""
- html += "overflow:hidden;position:absolute;"
- html += "left:#{node.bounds.x1}%; top:#{node.bounds.y1}px;"
- html += "width:#{node.bounds.width}%;height: #{node.bounds.height}px;"
- html += "background-color:#FFF;\">"
- html += "<div rid='#{node.rid}' id=\"tm-node-#{node.id}\" style='margin: 1px;background-color: #{node.color}; height: #{node.bounds.height-4}px;
-border: 1px solid #{node.color};' alt=\"#{node.tooltip}\" title=\"#{node.tooltip}\""
- if node.leaf
- html += "l=1 "
- end
- if @details_at_depth==node.depth
- html += "onmouseover=\"this.style.borderColor='#444';\" onmouseout=\"this.style.borderColor='#{node.color}';\""
- end
- html += ' >'
- html += draw_node_body(node)
-
- if (!node.children.nil? && node.children.size > 0)
- node.children.each do |c|
- html += draw_node(c)
- end
- end
- html + '</div></div>'
- end
-
- def draw_label(node)
- if node.leaf
- "<a onclick=\"window.open(this.href,'resource','height=800,width=900,scrollbars=1,resizable=1');return false;\" " +
- "href=\"#{ApplicationController.root_context}/resource/index/#{node.rid}\">#{node_label(node)}</a>"
- else
- "<a href='#{ApplicationController.root_context}/dashboard/index/#{node.rid}'>#{node_label(node)}</a>"
- end
- end
-end \ No newline at end of file