org.wicketstuff.gchart.ChartLibLoaderBehavior Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of wicket-gchart Show documentation
Show all versions of wicket-gchart Show documentation
Integrate Google Charts API (v45) with wicket.
The API tries not to hide all details of the Google API,
but makes use of the JSON lib of wicket to mix Java, JavaScript and JSON in a transparent way..
The newest version!
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.wicketstuff.gchart;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Locale;
import java.util.Set;
import org.apache.wicket.Component;
import org.apache.wicket.Page;
import org.apache.wicket.Session;
import org.apache.wicket.behavior.Behavior;
import org.apache.wicket.markup.head.HeaderItem;
import org.apache.wicket.markup.head.IHeaderResponse;
import org.apache.wicket.markup.head.JavaScriptContentHeaderItem;
import org.apache.wicket.markup.head.JavaScriptHeaderItem;
import com.github.openjson.JSONArray;
import com.github.openjson.JSONObject;
import static org.wicketstuff.gchart.Chart.LOADER_URL;
/**
* Behavior to bundle the Google chart lib loading and package declaration for
* multiple charts on one page. All needed packages are merged in a set, so the
* loading is done only once as the
* docs
* request.
*
* To use add this behavior to the page (not the chart) and give the
* instance as param to every constructor of a chart component of the page. The
* Charts will register in the loader by {@link ChartLibLoader#addChart(org.wicketstuff.gchart.Chart)
* }
* and lib loading is done centralized.
*
* Use this behavior at page when you display multiple charts on the page (Since
* Google Charts version 45 this is mandatory, but still recommended.)
*
* @author Dieter Tremel
*/
public class ChartLibLoaderBehavior extends Behavior implements JavaScriptable, ChartLibLoader {
public static final String LOADER_SCRIPT_ID = ChartLibLoaderBehavior.class.getSimpleName();
private static final long serialVersionUID = 1L;
private Locale locale = null;
private boolean renderLocale = true;
private final List charts = new ArrayList<>();
private HeaderItem headerItem = null;
@Override
public void bind(Component component) {
if (!(component instanceof Page)) {
throw new IllegalArgumentException("This behavior should be used at the page, not the chart!");
}
super.bind(component);
locale = component.getLocale();
}
@Override
public boolean addChart(Chart chart) {
return charts.add(chart);
}
@Override
public boolean removeChart(Chart chart) {
return charts.remove(chart);
}
/**
* The Locale is used to render a {@code language = "de"} in the
* load
* statement like in the example:
*
* {@code
* // Load Google Charts for the Japanese locale.
* google.charts.load('current', {'packages':['corechart'], 'language': 'ja'});
* }
If this behavior is attached to the Page, Locale is set from the
* Page which normally is identical to {@link Session#getLocale() }. To
* override use {@link #setLocale(java.util.Locale) }.
*
* @return Locale used for the package language option.
*/
public Locale getLocale() {
return locale;
}
public void setLocale(Locale locale) {
this.locale = locale;
}
public List getCharts() {
return charts;
}
public boolean isRenderLocale() {
return renderLocale;
}
public void setRenderLocale(boolean renderLocale) {
this.renderLocale = renderLocale;
}
/**
* Get Google loader URL. Can be overwritten, if Google changes URL in
* future.
*
* @return Returns {@link Chart#LOADER_URL}.
*/
public String getLoaderUrl() {
return LOADER_URL;
}
@Override
public String toJavaScript() {
// collect information from charts
Set packageSet = new HashSet<>();
String mapsApiKey = null;
for (Chart chart : charts) {
packageSet.add(chart.getTypeModel().getObject().getLoadPackage());
if (chart.getMapsApiKey() != null) {
mapsApiKey = chart.getMapsApiKey();
}
}
StringBuilder sb = new StringBuilder();
// Load the Visualization API and the package.
// google.charts.load('current', {'packages':['corechart']});
JSONObject packageDecl = new JSONObject();
JSONArray packages = new JSONArray(packageSet);
// packages.put(packageSet);
packageDecl.put("packages", packages);
if (renderLocale) {
packageDecl.put("language", getLocale().getLanguage());
}
if (mapsApiKey != null) {
packageDecl.put("mapsApiKey", mapsApiKey);
}
sb.append("google.charts.load('current', ").append(packageDecl.toString()).append(");").append("\n");
return sb.toString();
}
@Override
public HeaderItem getHeaderItem() {
if (headerItem == null) {
headerItem = new JavaScriptContentHeaderItem(toJavaScript(), LOADER_SCRIPT_ID) {
private static final long serialVersionUID = 1L;
@Override
public List getDependencies() {
final List dependencies = super.getDependencies();
dependencies.add(JavaScriptHeaderItem.forUrl(getLoaderUrl()));
return dependencies;
}
};
}
return headerItem;
}
@Override
public void renderHead(Component component, IHeaderResponse response) {
response.render(getHeaderItem());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy