diff options
Diffstat (limited to 'server/sonar-web/src')
20 files changed, 0 insertions, 842 deletions
diff --git a/server/sonar-web/src/main/es6/dashboard/app.js b/server/sonar-web/src/main/es6/dashboard/app.js deleted file mode 100644 index 7239062ac5a..00000000000 --- a/server/sonar-web/src/main/es6/dashboard/app.js +++ /dev/null @@ -1,58 +0,0 @@ -requirejs.config({ - baseUrl: `${baseUrl}/js`, - - paths: { - 'backbone': 'third-party/backbone', - 'backbone.marionette': 'third-party/backbone.marionette', - 'handlebars': 'third-party/handlebars' - }, - - shim: { - 'backbone.marionette': { - deps: ['backbone'], - exports: 'Marionette' - }, - 'backbone': { - exports: 'Backbone' - }, - 'handlebars': { - exports: 'Handlebars' - } - } -}); - - -requirejs([ - 'backbone', - 'backbone.marionette', - 'dashboard/collections/widgets', - 'dashboard/views/widgets-view', - 'dashboard/mockjax', - 'common/handlebars-extensions' -], function (Backbone, Marionette, Widgets, WidgetsView) { - - var App = new Marionette.Application(), - $ = jQuery; - - App.addInitializer(function () { - this.widgetsView = new WidgetsView({ - collection: this.widgets, - dashboard: this.dashboard, - el: $('#dashboard') - }); - this.widgetsView.render(); - }); - - var requestDetails = function () { - return $.get(`${baseUrl}/api/dashboards/details`, { did: window.did }, function (data) { - console.log(JSON.stringify(data)); - App.dashboard = new Backbone.Model(_.omit(data, 'widgets')); - App.widgets = new Widgets(data.widgets); - }); - }; - - $.when(requestDetails(), window.requestMessages()).done(function () { - App.start(); - }); - -}); diff --git a/server/sonar-web/src/main/es6/dashboard/collections/widgets.js b/server/sonar-web/src/main/es6/dashboard/collections/widgets.js deleted file mode 100644 index 03826f31482..00000000000 --- a/server/sonar-web/src/main/es6/dashboard/collections/widgets.js +++ /dev/null @@ -1,12 +0,0 @@ -define([ - 'backbone', - 'dashboard/models/widget' -], function ( - Backbone, - Widget) { - - return Backbone.Collection.extend({ - model: Widget - }); - -}); diff --git a/server/sonar-web/src/main/es6/dashboard/mockjax.js b/server/sonar-web/src/main/es6/dashboard/mockjax.js deleted file mode 100644 index b3cce8f4d42..00000000000 --- a/server/sonar-web/src/main/es6/dashboard/mockjax.js +++ /dev/null @@ -1,58 +0,0 @@ -define(['third-party/jquery.mockjax'], function () { - - jQuery.mockjaxSettings.contentType = 'text/json'; - jQuery.mockjaxSettings.responseTime = 250; - - jQuery.mockjax({ - url: `${baseUrl}/api/dashboards/details`, - responseText: JSON.stringify({ - name: 'Helicopter View', - description: '', - shared: true, - layout: '50%-50%', - - canManageDashboards: true, - canManageWidgets: true, - - widgets: [ - { - key: 'measure_filter_list', - props: [ - { - key: 'filter', - value: '48' - } - ], - layout: { - column: 1, - row: 1 - } - }, - { - key: 'my_reviews', - props: [], - layout: { - column: 2, - row: 1 - } - } - ] - }) - }); - - jQuery.mockjax({ - url: `${baseUrl}/api/dashboards/available_widgets`, - responseText: JSON.stringify({ - widgets: [ - { - key: '', - name: '', - description: '', - category: '', - props: [] - } - ] - }) - }); - -}); diff --git a/server/sonar-web/src/main/es6/dashboard/models/widget.js b/server/sonar-web/src/main/es6/dashboard/models/widget.js deleted file mode 100644 index 79300beaf71..00000000000 --- a/server/sonar-web/src/main/es6/dashboard/models/widget.js +++ /dev/null @@ -1,7 +0,0 @@ -define(['backbone'], function (Backbone) { - - return Backbone.Model.extend({ - idAttribute: 'key' - }); - -}); diff --git a/server/sonar-web/src/main/es6/dashboard/views/widget-view.js b/server/sonar-web/src/main/es6/dashboard/views/widget-view.js deleted file mode 100644 index 0507d5933b4..00000000000 --- a/server/sonar-web/src/main/es6/dashboard/views/widget-view.js +++ /dev/null @@ -1,45 +0,0 @@ -define([ - 'backbone.marionette', - 'templates/dashboard' -], function (Marionette, Templates) { - - var $ = jQuery; - - - class WidgetView extends Marionette.ItemView { - - initialize() { - this.requestContent(); - } - - requestContent() { - var props = this.getWidgetProps(); - $.get(`${baseUrl}/widget/show?id=${this.model.id}&${props}`, (html) => { - this.model.set('html', html); - this.render(); - }); - } - - getWidgetProps() { - var props = this.model.get('props') - .map(function (prop) { - return `${prop.key}=${encodeURIComponent(prop.value)}`; - }) - .join('&'); - return props; - } - - serializeData() { - var props = this.getWidgetProps(); - return _.extend(super.serializeData(), { - url: `${baseUrl}/widget?id=${this.model.id}&${props}` - }); - } - - } - - WidgetView.prototype.template = Templates['widget'] - - return WidgetView; - -}); diff --git a/server/sonar-web/src/main/es6/dashboard/views/widgets-view.js b/server/sonar-web/src/main/es6/dashboard/views/widgets-view.js deleted file mode 100644 index ce8692d38a7..00000000000 --- a/server/sonar-web/src/main/es6/dashboard/views/widgets-view.js +++ /dev/null @@ -1,31 +0,0 @@ -define([ - 'backbone.marionette', - 'templates/dashboard', - 'dashboard/views/widget-view' -], function (Marionette, Templates, WidgetView) { - - class WidgetsView extends Marionette.CompositeView { - - appendHtml(compositeView, itemView) { - var layout = itemView.model.get('layout'), - column = layout.column - 1; - var $container = this.getItemViewContainer(compositeView); - $container.eq(column).append(itemView.el); - } - - serializeData() { - return _.extend(super.serializeData(), { - dashboard: this.options.dashboard.toJSON(), - manageDashboardsUrl: `${baseUrl}/dashboards` - }); - } - - } - - WidgetsView.prototype.template = Templates['widgets']; - WidgetsView.prototype.itemView = WidgetView; - WidgetsView.prototype.itemViewContainer = '.dashboard-column'; - - return WidgetsView; - -}); diff --git a/server/sonar-web/src/main/hbs/dashboard/widget.hbs b/server/sonar-web/src/main/hbs/dashboard/widget.hbs deleted file mode 100644 index 91dcae71e96..00000000000 --- a/server/sonar-web/src/main/hbs/dashboard/widget.hbs +++ /dev/null @@ -1,9 +0,0 @@ -<div class="block"> - <div class="widget"> - {{#if html}} - {{{html}}} - {{else}} - <i class="spinner spinner-margin"></i> - {{/if}} - </div> -</div> diff --git a/server/sonar-web/src/main/hbs/dashboard/widgets.hbs b/server/sonar-web/src/main/hbs/dashboard/widgets.hbs deleted file mode 100644 index 7dd17d1b8ea..00000000000 --- a/server/sonar-web/src/main/hbs/dashboard/widgets.hbs +++ /dev/null @@ -1,19 +0,0 @@ -<div class="line-block"> - <div class="operations noprint button-group"> - <button>{{t 'dashboard.configure_widgets'}}</button> - <a class="button" href="{{manageDashboardsUrl}}">{{t 'dashboard.manage_dashboards'}}</a> - </div> -</div> - -{{#eq dashboard.layout '50%-50%'}} - <div class="dashboard-column-wrapper" style="width: 50%;margin: 0 -1px 0 0;"> - <div class="dashboard-column" style="margin: 0 5px 0 0;"> - - </div> - </div> - <div class="dashboard-column-wrapper" style="width: 50%;margin: 0 -1px 0 0;"> - <div class="dashboard-column" style="margin: 0 0 0 5px;"> - - </div> - </div> -{{/eq}} diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard2_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard2_controller.rb deleted file mode 100644 index 73a3a5e1999..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard2_controller.rb +++ /dev/null @@ -1,227 +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 Dashboard2Controller < ApplicationController - - SECTION=Navigation::SECTION_RESOURCE - - before_filter :login_required, :except => [:index] - - def index - load_resource() - - if !@resource || @resource.display_dashboard? - load_dashboard() - load_authorized_widget_definitions() - else - # display the layout of the parent without the sidebar, usually the directory, but display the file viewers - @hide_sidebar = true - @file = @resource - @project = @snapshot.parent.project - @metric=params[:metric] - render :action => 'no_dashboard' - end - end - - def configure - load_resource() - load_dashboard() - - @category=params[:category] - load_widget_definitions(@category) - end - - def set_layout - verify_post_request - dashboard=Dashboard.find(params[:did]) - if dashboard.editable_by?(current_user) - dashboard.column_layout=params[:layout] - dashboard.save! - columns=dashboard.column_layout.split('-') - dashboard.widgets.find(:all, :conditions => ["column_index > ?", columns.size()]).each do |widget| - widget.column_index=columns.size() - widget.save - end - end - redirect_to :action => 'configure', :did => dashboard.id, :id => params[:id] - end - - def set_dashboard - verify_post_request - load_dashboard() - - dashboardstate=params[:dashboardstate] - - columns=dashboardstate.split(";") - all_ids=[] - columns.each_with_index do |col, index| - ids=col.split(",") - ids.each_with_index do |id, order| - widget=@dashboard.widgets.to_a.find { |i| i.id==id.to_i() } - if widget - widget.column_index=index+1 - widget.row_index=order+1 - widget.save! - all_ids<<widget.id - end - end - end - @dashboard.widgets.reject { |w| all_ids.include?(w.id) }.each do |w| - w.destroy - end - render :json => {:status => 'ok'} - end - - def add_widget - verify_post_request - dashboard=Dashboard.find(params[:did]) - widget_id=nil - if dashboard.editable_by?(current_user) - definition=java_facade.getWidget(params[:widget]) - if definition - first_column_widgets=dashboard.widgets.select { |w| w.column_index==1 }.sort_by { |w| w.row_index } - new_widget=dashboard.widgets.create(:widget_key => definition.getId(), - :name => definition.getTitle(), - :column_index => 1, - :row_index => 1, - :configured => !(definition.hasRequiredProperties() || (dashboard.global && !definition.isGlobal))) - widget_id=new_widget.id - first_column_widgets.each_with_index do |w, index| - w.row_index=index+2 - w.save - end - end - end - redirect_to :action => 'configure', :did => dashboard.id, :id => params[:id], :highlight => widget_id, :category => params[:category] - end - - def save_widget - verify_post_request - widget=Widget.find(params[:wid]) - #TODO check owner of dashboard - Widget.transaction do - widget.properties.clear - widget.java_definition.getWidgetProperties().each do |java_property| - value=params[java_property.key()] || java_property.defaultValue() - if value && !value.empty? - prop = widget.properties.build(:kee => java_property.key, :text_value => value) - prop.save! - end - end - widget.resource_id=Project.by_key(params[:resource_id]).id if params[:resource_id].present? - widget.configured=true - widget.save! - render :update do |page| - page.redirect_to(url_for(:action => 'configure', :did => widget.dashboard_id, :id => params[:id])) - end - end - end - - def widget_definitions - @category=params[:category] - load_resource() - load_dashboard() - load_widget_definitions(@category) - render :partial => 'widget_definitions', :locals => {:category => @category} - end - - private - - def load_dashboard - active=nil - @dashboard=nil - - if logged_in? - if params[:did] - @dashboard=Dashboard.first(:conditions => ['id=? AND user_id=?', params[:did].to_i, current_user.id]) - elsif params[:name] - @dashboard=Dashboard.first(:conditions => ['name=? AND user_id=?', params[:name], current_user.id]) - elsif params[:id] - active=ActiveDashboard.user_dashboards(current_user, false).first - else - active=ActiveDashboard.user_dashboards(current_user, true).first - end - end - - unless active or @dashboard - # anonymous or not found in user dashboards - if params[:did] - @dashboard=Dashboard.first(:conditions => ['id=? AND shared=?', params[:did].to_i, true]) - elsif params[:name] - @dashboard=Dashboard.first(:conditions => ['name=? AND shared=?', params[:name], true]) - elsif params[:id] - active=ActiveDashboard.user_dashboards(nil, false).first - else - active=ActiveDashboard.user_dashboards(nil, true).first - end - end - - unless @dashboard - @dashboard=(active && active.dashboard) - end - - not_found('dashboard') unless @dashboard - - @dashboard_configuration=Api::DashboardConfiguration.new(@dashboard, :period_index => params[:period], :snapshot => @snapshot) if @dashboard && @snapshot - end - - def load_resource - if params[:id] - @resource=Project.by_key(params[:id]) - return project_not_found unless @resource - @resource=@resource.permanent_resource - - @snapshot=@resource.last_snapshot - return project_not_analyzed unless @snapshot - - access_denied unless has_role?(:user, @resource) - - @project=@resource # for backward compatibility with old widgets - end - end - - def project_not_found - flash[:error] = message('dashboard.project_not_found') - redirect_to :action => :index - end - - def project_not_analyzed - render :action => 'empty' - end - - def load_authorized_widget_definitions - @authorized_widget_definitions=java_facade.getWidgets().select do |widget| - roles = widget.getUserRoles() - roles.empty? || roles.any? { |role| (role=='user') || (role=='viewer') || has_role?(role, @resource) } - end - end - - def load_widget_definitions(filter_on_category) - @widget_definitions=java_facade.getWidgets().to_a.sort {|w1,w2| widgetL10nName(w1) <=> widgetL10nName(w2)} - - @widget_categories=@widget_definitions.map(&:getWidgetCategories).to_a.flatten.uniq.sort - unless filter_on_category.blank? - @widget_definitions=@widget_definitions.select { |definition| definition.getWidgetCategories().to_a.include?(filter_on_category) } - end - end - - def widgetL10nName(widget) - Api::Utils.message('widget.' + widget.id + '.name') - end -end diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_configure_widget.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_configure_widget.html.erb deleted file mode 100644 index e2ceea91e73..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_configure_widget.html.erb +++ /dev/null @@ -1,55 +0,0 @@ -<% - switch_to_widget_resource(widget) - widget_body=widget_body(widget) - default_layout=(widget.layout=='DEFAULT') -%> - -<div class="widget-header"> - <div class="widget-actions"> - <% if widget.java_definition.isEditable() || (!widget.java_definition.global && @dashboard.global) %> - <a class="link-action" onclick="portal.editWidget(<%= widget.id -%>);return false;"><%= message('edit') -%></a> - <% end %> - <a class="link-action" onclick="portal.deleteWidget(this);return false;"><%= message('delete') -%></a> - </div> - <div class="widget-handle"> - <%= h message('widget.' + widget.java_definition.getId() + '.name', :default => widget.java_definition.getTitle()) -%> - </div> -</div> - -<div class="widget_props" id="widget_props_<%= widget.id -%>" style="<%= 'display:none' if widget.configured -%>"> - <%= render :partial => 'widget_properties', :locals => {:widget => widget} -%> -</div> - -<%= render :partial => 'widget_title', :locals => {:widget => widget} -%> -<div id="widget_<%= widget.id -%>" class="configure_widget <%= h widget.java_definition.getId() -%>" style="height:100%;<%= 'display:none;' if !widget.configured -%>"> - <div class="transparent"></div> - <% if !widget_body %> - <div class="block"> - <% if default_layout %> - <div class="widget"> - <span class="empty_widget"><%= message('widget.error_occurred_please_read_logs', :params => [widget.key]) -%></span> - <div class="clear"></div> - </div> - <% else %> - <span class="empty_widget"><%= message('widget.error_occurred_please_read_logs', :params => [widget.key]) -%></span> - <% end %> - </div> - <% elsif widget_body.include? '<' %> - <% - - if default_layout - %> - <div class="widget"> - <% end %> - <%= widget_body -%> - <% if default_layout %> - <div class="clear"></div> - </div> - <% end %> - <% else %> - <div class="widget"><p><%= message('no_data') -%></p></div> - <% end %> - <div style="clear: both;"></div> -</div> - -<% restore_global_resource %> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_header.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_header.html.erb deleted file mode 100644 index 900075c19f0..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_header.html.erb +++ /dev/null @@ -1,34 +0,0 @@ -<% if logged_in? || @snapshot %> -<div class="line-block"> - - <% if logged_in? %> - <div class="operations noprint button-group"> - <% if back %> - <%= link_to message('dashboard.back_to_dashboard'), dashboard_action(:index), :class => 'button' -%> - <% else %> - <% if @dashboard.editable_by?(current_user) %> - <%= link_to message('dashboard.configure_widgets'), dashboard_action(:configure), :class => 'button' -%> - <% end %> - <% end %> - <%= link_to message('dashboard.manage_dashboards'), {:controller => :dashboards, :action => :index, :resource => (@resource.id if @resource) }, :class => 'button' -%> - </div> - <% end %> - - <% if @snapshot %> - <div id="snapshot_title" class="page_title"> - <h4> - <%= "Version #{@snapshot.version} - " if @snapshot.version.present? -%><%= l @snapshot.created_at -%> - <% if @snapshot.project_snapshot.periods? %> - <% period_options = period_select_option_tags(@snapshot, 'small') %> - <% if period_options %> - <form method="GET" action="<%= url_for :controller => :dashboard, :action => :index, :id => @resource.id -%>" style="display: inline" class="spacer-left"> - <input type="hidden" name="did" value="<%= @dashboard.id -%>"/> - <%= dropdown_tag 'period', period_options, {:width => '250px'}, {:id => 'select-comparison', :onchange => 'submit()'} -%> - </form> - <% end %> - <% end %> - </h4> - </div> - <% end %> -</div> -<% end %> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget.html.erb deleted file mode 100644 index b706fd19076..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget.html.erb +++ /dev/null @@ -1,48 +0,0 @@ -<% - switch_to_widget_resource(widget) - widget_body=widget_body(widget) - default_layout=(widget.java_definition.getWidgetLayout().name()=='DEFAULT') -%> - -<% if !widget.configured %> -<div class="block"> - <div class="widget"> - <span class="empty_widget"> - <a class="note" href="<%= url_for(dashboard_action(:configure)) -%>"><%= message('dashboard.please_configure_the_widget_x', :params => widget.java_definition.getTitle()) -%></a> - </span> - <div class="clear"></div> - </div> -</div> - -<% elsif !widget_body %> - <div class="block"> - <% if default_layout %> - <div class="widget"> - <span class="empty_widget"><%= message('widget.error_occurred_please_read_logs', :params => [widget.key]) -%></span> - <div class="clear"></div> - </div> - <% else %> - <span class="empty_widget"><%= message('widget.error_occurred_please_read_logs', :params => [widget.key]) -%></span> - <% end %> - </div> - -<% elsif widget_body.include?('<') %> - <div class="block" id="block_<%= widget.id -%>"> - <%= render :partial => 'widget_title', :locals => {:widget => widget} -%> - - <div class="<%= h widget.key -%>" style="height:100%;"> - <% if default_layout %> - <div class="widget"> - <%= widget_body -%> - <div class="clear"></div> - </div> - <% else %> - <%= widget_body -%> - <% end %> - - <div style="clear: both;"></div> - </div> - </div> -<% end %> - -<% restore_global_resource %> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_definition.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_definition.html.erb deleted file mode 100644 index c0ab98601ff..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_definition.html.erb +++ /dev/null @@ -1,10 +0,0 @@ - <div class="widget_def" id="def_<%= definition.id.tr('_', '') -%>"> - <p><b><%= h message("widget.#{definition.id}.name", :default => definition.title) -%></b></p> - - <p><%= h message("widget.#{definition.id}.description", :default => definition.description) -%></p> - - <% form_tag dashboard_action(:add_widget, :widget => definition.id) do -%> - <input type="hidden" name="category" value="<%= category -%>"> - <input type="submit" value="<%= message('dashboard.add_widget') -%>" id="add-widget-<%= u(definition.id) -%>"> - <% end -%> - </div>
\ No newline at end of file diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_definitions.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_definitions.html.erb deleted file mode 100644 index 64ed279cc23..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_definitions.html.erb +++ /dev/null @@ -1,27 +0,0 @@ -<table class="width100"> - <tr style="line-height: 20px;text-align: right"> - <td valign="top"> - <ul class="horizontal widget_categs" id="widget-filters"> - <li>Category:</li> - <li class="<%= 'selected' if category.blank? -%>"> - <a href="#" onClick="return filterWidgetsByCategory('')" id="widget-filter-none"><%= message('any') -%></a> - </li> - <% @widget_categories.each do |c| %> - <li class="<%= 'selected' if category==c -%>"> - <a href="#" onClick="return filterWidgetsByCategory('<%= escape_javascript(c) -%>')" id="widget-filter-<%= u(c) -%>"><%= h(c) -%></a> - </li> - <% end %> - </ul> - <%= image_tag 'loading.gif', :style => 'vertical-align: top; display: none', :id => 'filter-widgets-loading' -%> - </td> - <td nowrap valign="top"> - Search: - <input id="filter-widget-box" name="filter-widget-box" size="10" onKeyUp="filtersWidgetsByContent(this.value);" type="text"/> - </td> - </tr> -</table> - -<% @widget_definitions.each do |definition| %> - <%= render :partial => 'widget_definition', :locals => {:definition => definition, :dashboard => @dashboard, :resource => @resource, :category => category} %> -<% end %> - diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_properties.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_properties.html.erb deleted file mode 100644 index ae419530933..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_properties.html.erb +++ /dev/null @@ -1,67 +0,0 @@ -<form onsubmit="$j.ajax({ - url: '<%= ApplicationController.root_context-%>/dashboard/save_widget?wid=<%=widget.id-%>&id=<%= params[:id] -%>', - type: 'post', - data: $j(this).serialize(), - error: function(request) - { - $j('#error<%=widget.id-%>').text(request.responseText); - $j('#error<%=widget.id-%>').show(); - } - }); - return false;" - method="post" - action="<%= ApplicationController.root_context-%>/dashboard/save_widget?wid=<%=widget.id-%>"> - <div id="error<%= widget.id -%>" class="error" style="display: none"></div> - <table class="table width100"> - <tbody> - - <% if !widget.java_definition.global && @dashboard.global %> - <tr> - <td class="form-key-cell"><%= message('widget.resource_id') %> <em class="mandatory">*</em></td> - <td class="form-val-cell" id="row_resource"> - <%= resource_select_tag 'resource_id', { - :resource_type_property => 'supportsGlobalDashboards', - :selected_resource => widget.resource, - :width => '250px', - :html_id => "widget-#{widget.id}-select-prj-#{widget.key.parameterize}", - :html_class => "widget-select-prj-#{widget.key.parameterize}" - } -%> - </td> - </tr> - <% end %> - - <% widget.java_definition.getWidgetProperties().each do |property_def| %> - <tr> - <td class="form-key-cell"><%= message("widget." + widget.key + ".property." + property_def.key() + ".name", :default => property_def.key()) -%><%= " *" unless property_def.optional() -%></td> - <td class="form-val-cell" id="row_<%= property_def.key() -%>"> - <%= property_value_field(property_def, widget.property_text_value(property_def.key()), widget) -%> - <div class="form-val-note"> - <% - # Old key used for retro-compatibility - property_description = message("widget." + widget.key + ".param." + property_def.key(), :default => '') - property_description = message("widget." + widget.key + ".property." + property_def.key() + ".desc", :default => property_def.description()) unless property_description != '' - -%> - - <% unless property_description.blank? -%> - <div><%= property_description -%></div> - <% end %> - <% if !property_def.defaultValue.blank? || property_def.type.name == PropertyType::TYPE_BOOLEAN -%> - <div><%= message('default') %>: <%= h(default_value property_def) -%></div> - <% end -%> - </div> - </td> - </tr> - <% end %> - - <tr> - <td colspan="2"> - <%= submit_tag message('save'), :id => "widget-#{widget.id}-save-#{widget.key.parameterize}", :class => "widget-save-#{widget.key.parameterize}" -%> - <% if widget.configured %> - <a href="#" onClick="portal.cancelEditWidget(<%= widget.id -%>);return false;"><%= message('cancel') -%></a> - <% end %> - </td> - </tr> - </tbody> - </table> - <%= hidden_field_tag "widgetid", "", :class => "widgetid" %> -</form> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_title.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_title.html.erb deleted file mode 100644 index 0c9fb7ae468..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/_widget_title.html.erb +++ /dev/null @@ -1,3 +0,0 @@ -<% unless widget_title(widget).blank? %> - <div class="widget-title" id="widget_title_<%= widget.id -%>"><%= widget_title(widget) -%></div> -<% end %> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/configure.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/configure.html.erb deleted file mode 100644 index 30c43cc9aa0..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/configure.html.erb +++ /dev/null @@ -1,105 +0,0 @@ -<div id="dashboard"> - <%= render :partial => 'header', :locals => {:back => true} %> - - <div id="configure"> - <div id="widget_defs"> - <%= render :partial => 'widget_definitions', :locals => {:category => @category} -%> - </div> - - <div id="edit-layout"> - <% {'100%', 'layout100.png', - '50%-50%', 'layout5050.png', - '30%-70%', 'layout3070.png', - '70%-30%', 'layout7030.png', - '33%-33%-33%', 'layout333333.png' - }.each_pair do |layout, picto| %> - <div class="select-layout <%= 'selected' if @dashboard.layout==layout -%>"> - <%= link_to image_tag(picto), dashboard_action(:set_layout, :layout => layout), :method => :post, :title => layout %> - </div> - <% end %> - </div> - </div> - - <% - columns=@dashboard.column_layout.split('-') - for index in 1..columns.size() - %> - <div class="dashboard-column-wrapper" style="width: <%= columns[index-1] -%>;margin: 0 -1px 0 0;"> - <div class="dashboard-column" id="dashboard-column-<%= index -%>" style="margin: 0 <%= index<columns.size() ? "5px" : "0px" -%> 0 <%= index>1 ? "5px" : "0px" -%>;"> - <% - @dashboard.widgets.select { |widget| widget.column_index==index && widget.java_definition }.sort_by { |widget| widget.row_index }.each do |widget| - %> - <div class="block" id="block_<%= widget.id -%>"> - <%= render :partial => 'configure_widget', :locals => {:widget => widget} %> - </div> - <% - end - %> - <div class="column-handle" style="display: none"></div> - </div> - </div> - <% end %> -</div> - -<script type="text/javascript"> - <!-- - var options = { - editorEnabled: true, - column: 'dashboard-column', - columnHandle: 'column-handle', - block: 'block', - hoverClass: 'block-hover', - dashboardState: 'dashboardstate', - highlightDuration: 2000, - highlightStartColor: '#cae3f2', - highlightEndColor: '#ffffff', - saveUrl: '<%= url_for dashboard_action(:set_dashboard) -%>' - }; - var portal; - function init_dashboard() { - portal = new Portal(options); - <% if params[:highlight] %> - portal.highlightWidget(<%= escape_javascript(params[:highlight]) -%>); - <% end %> - } - $j(document).ready(function(){init_dashboard();}); - - function filterWidgetsByCategory(category) { - $j('#filter-widgets-loading').show(); - $j.ajax ({ url: '<%= add_category_to_url(url_for dashboard_action(:widget_definitions)) -%>' + encodeURIComponent(category), - success: function(responseHTML){$j('#widget_defs').html(responseHTML);}, - error:function(error){alert('error');} - }); - return false; - } - - var widgetContents = [ - <% - number_of_widgets = @widget_definitions.size() - @widget_definitions.each_with_index do |definition, index| - widget_id = "def_#{definition.id.tr('_', '')}" - widget_title = message("widget.#{definition.id}.name", :default => definition.title).downcase - widget_description = message("widget.#{definition.id}.description", :default => definition.description).downcase - %> - { id:"<%= widget_id -%>", c:"<%= widget_title.gsub(/\r\n?/, " ") -%> <%= widget_description.gsub(/\r\n?/, " ") -%>" } <%= "," unless index==number_of_widgets-1 -%> - <% end %> - ]; - - function filtersWidgetsByContent(text) { - var userInput = text.toLowerCase(); - widgetContents.forEach(function (widget) { - var element = $j('#'+widget.id); - if (element != null) { - if (widget.c.indexOf(userInput) != -1) { - element.show(); - } else { - element.hide(); - } - } - }); - return false; - } - //--> - - $j('#filter-widget-box').focus(); -</script> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/empty.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/empty.html.erb deleted file mode 100644 index a297b76e3f3..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/empty.html.erb +++ /dev/null @@ -1,3 +0,0 @@ -<% if @resource and !@snapshot %> -<p class="warning marginbottom10"><%= message('provisioning.no_analysis') -%></p> -<% end %> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/index.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/index.html.erb deleted file mode 100644 index 8dd759d6cf1..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/index.html.erb +++ /dev/null @@ -1,12 +0,0 @@ -<% content_for :script do %> - <script data-main="<%= ApplicationController.root_context -%>/js/dashboard/app" src="<%= ApplicationController.root_context -%>/js/require.js"></script> -<% end %> - -<div id="dashboard"> - <i class="spinner"></i> -</div> - -<script> - window.did = '<%= @dashboard.id -%>'; - jQuery('html').addClass('dashboard-page'); -</script> diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/no_dashboard.html.erb b/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/no_dashboard.html.erb deleted file mode 100644 index 8802eb19301..00000000000 --- a/server/sonar-web/src/main/webapp/WEB-INF/app/views/dashboard2/no_dashboard.html.erb +++ /dev/null @@ -1,12 +0,0 @@ -<% content_for :script do %> - <script data-main="<%= ApplicationController.root_context -%>/js/dashboard/file-app" src="<%= ApplicationController.root_context -%>/js/require.js"></script> -<% end %> - -<div class="marginbottom10"></div> -<div id="accordion-panel"></div> - -<script type="text/javascript"> - window.fileKey = '<%= @file.key -%>'; - window.metric = '<%= @metric -%>'; - document.getElementById('crumbs').remove(); -</script> |