org.sonar.api.web.Dashboard Maven / Gradle / Ivy
/*
* 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.
*/
package org.sonar.api.web;
import com.google.common.collect.ArrayListMultimap;
import com.google.common.collect.ListMultimap;
import com.google.common.collect.Maps;
import java.util.Collection;
import java.util.List;
import java.util.Map;
/**
* Definition of a dashboard.
*
* Its name and description can be retrieved using the i18n mechanism, using the keys "dashboard.<id>.name" and
* "dashboard.<id>.description".
*
* @since 2.13
*/
public final class Dashboard {
private String description;
private DashboardLayout layout = DashboardLayout.TWO_COLUMNS;
private ListMultimap widgetsByColumn = ArrayListMultimap.create();
private boolean global = false;
private boolean activated = true;
private Dashboard() {
}
/**
* Creates a new {@link Dashboard}.
*/
public static Dashboard create() {
return new Dashboard();
}
/**
* Add a widget with the given parameters, and return the newly created {@link Widget} object if one wants to add parameters to it.
*
* The widget ids are listed by the web service /api/widgets
*
* @param widgetId id of an existing widget
* @param columnId column starts with 1. The widget is ignored if the column id does not match the layout.
*/
public Widget addWidget(String widgetId, int columnId) {
if (columnId < 1) {
throw new IllegalArgumentException("Widget column starts with 1");
}
Widget widget = new Widget(widgetId);
widgetsByColumn.put(columnId, widget);
return widget;
}
public Collection getWidgets() {
return widgetsByColumn.values();
}
public List getWidgetsOfColumn(int columnId) {
return widgetsByColumn.get(columnId);
}
/**
* Returns the description of the dashboard.
*
* @return the description
*/
public String getDescription() {
return description;
}
/**
* Sets the description of the dashboard.
*
* Note: you should use the i18n mechanism for the description.
*
* @param description the description to set
*/
public Dashboard setDescription(String description) {
this.description = description;
return this;
}
/**
* Returns the layout. Default value is the 2 columns mode with width 50%/50%.
*
* @return the layout
*/
public DashboardLayout getLayout() {
return layout;
}
public Dashboard setLayout(DashboardLayout dl) {
if (dl == null) {
throw new IllegalArgumentException("The layout can not be null");
}
this.layout = dl;
return this;
}
/**
* A dashboard is global when it doesn't display information from a projet but rather more general information.
* Before version 3.1 no dashboard was global.
*
* @since 3.1
*/
public boolean isGlobal() {
return global;
}
/**
* A dashboard is global when it doesn't display information from a projet but rather more general information.
* Before version 3.1 no dashboard was global.
*
* @since 3.1
*/
public Dashboard setGlobal(boolean global) {
this.global = global;
return this;
}
/**
* A dashboard can be activated for all anonymous users or users who haven't configured their own dashboards.
* Before version 3.1 every dashboard created through this extension point was automatically activated.
* This is still the default behavior.
*
* @since 3.1
*/
public boolean isActivated() {
return activated;
}
/**
* Set whether the dashboard is activated for all anonymous users or users who haven't configured their own dashboards.
*
* @since 3.1
*/
public Dashboard setActivated(boolean activated) {
this.activated = activated;
return this;
}
/**
* Note that this class is an inner class to avoid confusion with the extension point org.sonar.api.web.Widget.
*/
public static final class Widget {
private String id;
private Map properties;
Widget(String id) {
this.id = id;
this.properties = Maps.newHashMap();
}
public Widget setProperty(String key, String value) {
properties.put(key, value);
return this;
}
/**
* Returns the properties of this widget.
*
* @return the properties
*/
public Map getProperties() {
return properties;
}
public String getProperty(String key) {
return properties.get(key);
}
/**
* Returns the identifier of this widget.
*
* @return the id
*/
public String getId() {
return id;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy