package org.gcube.portlets.admin.accountingmanager.client.maindata.charts.storage.panels; import java.util.Date; import org.gcube.portlets.admin.accountingmanager.client.maindata.charts.utils.ByteUnitMeasure; import org.gcube.portlets.admin.accountingmanager.client.maindata.charts.utils.ChartTimeMeasure; import org.gcube.portlets.admin.accountingmanager.client.maindata.charts.utils.DownloadConstants; import org.gcube.portlets.admin.accountingmanager.client.resource.AccountingManagerResources; import org.gcube.portlets.admin.accountingmanager.client.state.AccountingStateData; import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesStorage; import org.gcube.portlets.admin.accountingmanager.shared.data.response.SeriesStorageData; import com.allen_sauer.gwt.log.client.Log; import com.github.highcharts4gwt.client.view.widget.HighchartsLayoutPanel; import com.github.highcharts4gwt.model.array.api.ArrayNumber; import com.github.highcharts4gwt.model.array.api.ArrayString; import com.github.highcharts4gwt.model.factory.api.HighchartsOptionFactory; import com.github.highcharts4gwt.model.factory.jso.JsoHighchartsOptionFactory; import com.github.highcharts4gwt.model.highcharts.option.api.ChartOptions; import com.github.highcharts4gwt.model.highcharts.option.api.SeriesArea; import com.github.highcharts4gwt.model.highcharts.option.api.SeriesColumn; import com.google.gwt.event.logical.shared.SelectionEvent; import com.google.gwt.event.logical.shared.SelectionHandler; import com.google.gwt.i18n.client.DateTimeFormat; import com.google.gwt.i18n.client.DateTimeFormat.PredefinedFormat; import com.sencha.gxt.cell.core.client.ButtonCell.ButtonArrowAlign; import com.sencha.gxt.cell.core.client.ButtonCell.IconAlign; import com.sencha.gxt.core.client.util.Margins; import com.sencha.gxt.widget.core.client.button.TextButton; import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutData; import com.sencha.gxt.widget.core.client.container.MarginData; import com.sencha.gxt.widget.core.client.container.SimpleContainer; import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer; import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer.VerticalLayoutData; import com.sencha.gxt.widget.core.client.menu.Item; import com.sencha.gxt.widget.core.client.menu.Menu; import com.sencha.gxt.widget.core.client.menu.MenuItem; import com.sencha.gxt.widget.core.client.toolbar.ToolBar; /** * * @author giancarlo email: g.panichi@isti.cnr.it * */ public class StorageChartMultiPanel extends SimpleContainer { private static final String DATA_VOLUME_UNIT = "Data Volume Unit"; private DateTimeFormat dtf = DateTimeFormat .getFormat(PredefinedFormat.YEAR_MONTH_DAY); private AccountingStateData accountingStateData; private HighchartsLayoutPanel highchartsLayoutPanel; // Download Menu private MenuItem downloadPNGItem; private MenuItem downloadJPGItem; private MenuItem downloadPDFItem; private MenuItem downloadSVGItem; // Unit Menu private MenuItem kBItem; private MenuItem MBItem; private MenuItem GBItem; private MenuItem TBItem; ChartOptions options; private VerticalLayoutContainer vert; private long unitMeasure = ByteUnitMeasure.getMegaByteDimForStorage(); private String unitMeasureLabel = ByteUnitMeasure.MB; public StorageChartMultiPanel(AccountingStateData accountingStateData) { this.accountingStateData = accountingStateData; forceLayoutOnResize = true; create(); } private void create() { ToolBar toolBar = new ToolBar(); toolBar.setSpacing(2); // Download final TextButton downloadButton = new TextButton( DownloadConstants.DOWNLOAD, AccountingManagerResources.INSTANCE.accountingDownload24()); // downloadButton.setScale(ButtonScale.MEDIUM); downloadButton.setIconAlign(IconAlign.RIGHT); downloadButton.setArrowAlign(ButtonArrowAlign.RIGHT); downloadButton.setMenu(createDownloadMenu()); final TextButton unitButton = new TextButton(DATA_VOLUME_UNIT, AccountingManagerResources.INSTANCE.accountingByte24()); unitButton.setIconAlign(IconAlign.RIGHT); unitButton.setArrowAlign(ButtonArrowAlign.RIGHT); unitButton.setMenu(createUnitMenu()); toolBar.add(downloadButton, new BoxLayoutData(new Margins(0))); toolBar.add(unitButton, new BoxLayoutData(new Margins(0))); // createChart(); highchartsLayoutPanel = new HighchartsLayoutPanel(); highchartsLayoutPanel.renderChart(options); // vert = new VerticalLayoutContainer(); vert.add(toolBar, new VerticalLayoutData(1, -1, new Margins(0))); vert.add(highchartsLayoutPanel, new VerticalLayoutData(1, 1, new Margins(0))); add(vert, new MarginData(0)); } private void updateChart() { vert.remove(highchartsLayoutPanel); // createChart(); highchartsLayoutPanel = new HighchartsLayoutPanel(); highchartsLayoutPanel.renderChart(options); vert.add(highchartsLayoutPanel, new VerticalLayoutData(1, 1, new Margins(0))); forceLayout(); } private Menu createDownloadMenu() { Menu menuDownload = new Menu(); downloadPNGItem = new MenuItem(DownloadConstants.DOWNLOAD_PNG, AccountingManagerResources.INSTANCE.accountingFilePNG24()); downloadPNGItem.setHeight(30); downloadJPGItem = new MenuItem(DownloadConstants.DOWNLOAD_JPG, AccountingManagerResources.INSTANCE.accountingFileJPG24()); downloadJPGItem.setHeight(30); downloadPDFItem = new MenuItem(DownloadConstants.DOWNLOAD_PDF, AccountingManagerResources.INSTANCE.accountingFilePDF24()); downloadPDFItem.setHeight(30); downloadSVGItem = new MenuItem(DownloadConstants.DOWNLOAD_SVG, AccountingManagerResources.INSTANCE.accountingFileSVG24()); downloadSVGItem.setHeight(30); downloadPNGItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { String id = highchartsLayoutPanel.getElement().getId(); onDownloadPNG(id); } }); downloadJPGItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { String id = highchartsLayoutPanel.getElement().getId(); onDownloadJPG(id); } }); downloadPDFItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { String id = highchartsLayoutPanel.getElement().getId(); onDownloadPDF(id); } }); downloadSVGItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { String id = highchartsLayoutPanel.getElement().getId(); onDownloadSVG(id); } }); menuDownload.add(downloadPNGItem); menuDownload.add(downloadJPGItem); menuDownload.add(downloadPDFItem); menuDownload.add(downloadSVGItem); return menuDownload; } private Menu createUnitMenu() { Menu menuUnit = new Menu(); kBItem = new MenuItem(ByteUnitMeasure.KILOBYTE); kBItem.setHeight(30); MBItem = new MenuItem(ByteUnitMeasure.MEGABYTE); MBItem.setHeight(30); GBItem = new MenuItem(ByteUnitMeasure.GIGABYTE); GBItem.setHeight(30); TBItem = new MenuItem(ByteUnitMeasure.TERABYTE); TBItem.setHeight(30); kBItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { unitMeasure = ByteUnitMeasure.getKiloByteDimForStorage(); unitMeasureLabel = ByteUnitMeasure.kB; updateChart(); } }); MBItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { unitMeasure = ByteUnitMeasure.getMegaByteDimForStorage(); unitMeasureLabel = ByteUnitMeasure.MB; updateChart(); } }); GBItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { unitMeasure = ByteUnitMeasure.getGigaByteDimForStorage(); unitMeasureLabel = ByteUnitMeasure.GB; updateChart(); } }); TBItem.addSelectionHandler(new SelectionHandler() { @Override public void onSelection(SelectionEvent event) { unitMeasure = ByteUnitMeasure.getTeraByteDimForStorage(); unitMeasureLabel = ByteUnitMeasure.TB; updateChart(); } }); menuUnit.add(kBItem); menuUnit.add(MBItem); menuUnit.add(GBItem); menuUnit.add(TBItem); return menuUnit; } // chart.options.exporting.buttons.contextButton.menuItems[0].onclick(); public static native void onDownloadPNG(String id) /*-{ console.log(id); var chart = $wnd .jQuery('#' + id) .highcharts( this.@org.gcube.portlets.admin.accountingmanager.client.maindata.charts.storage.panels.StorageChartMultiPanel::options); console.log(chart); chart.exportChart(); }-*/; public static native void onDownloadJPG(String id) /*-{ console.log(id); var chart = $wnd .jQuery('#' + id) .highcharts( this.@org.gcube.portlets.admin.accountingmanager.client.maindata.charts.storage.panels.StorageChartMultiPanel::options); console.log(chart); chart.exportChart({ type : 'image/jpeg' }); }-*/; public static native void onDownloadPDF(String id) /*-{ console.log(id); var chart = $wnd .jQuery('#' + id) .highcharts( this.@org.gcube.portlets.admin.accountingmanager.client.maindata.charts.storage.panels.StorageChartMultiPanel::options); console.log(chart); chart.exportChart({ type : 'application/pdf' }); }-*/; public static native void onDownloadSVG(String id) /*-{ console.log(id); var chart = $wnd .jQuery('#' + id) .highcharts( this.@org.gcube.portlets.admin.accountingmanager.client.maindata.charts.storage.panels.StorageChartMultiPanel::options); console.log(chart); chart.exportChart({ type : 'image/svg+xml' }); }-*/; private void createChart() { SeriesStorage seriesStorage = (SeriesStorage) accountingStateData .getSeriesResponse(); double minRange = ChartTimeMeasure .calculateMinRange(accountingStateData.getSeriesRequest() .getAccountingPeriod()); double interval = ChartTimeMeasure .calculateInterval(accountingStateData.getSeriesRequest() .getAccountingPeriod()); Date dateStart = dtf.parse(accountingStateData.getSeriesRequest() .getAccountingPeriod().getStartDate()); dateStart.setTime(dateStart.getTime() + ChartTimeMeasure.timeZoneOffset() * ChartTimeMeasure.MINUTE); Log.debug("BuildChart DateStart: " + DateTimeFormat.getFormat(PredefinedFormat.DATE_TIME_FULL) .format(dateStart)); HighchartsOptionFactory highchartsFactory = new JsoHighchartsOptionFactory(); options = highchartsFactory.createChartOptions(); options.chart().zoomType("xy"); options.exporting().buttons().contextButton().enabled(false); options.exporting().filename("AccountingStorage"); options.title().text("Accounting Storage"); /* * options.subtitle().text("Click and drag in the plot area to zoom in"); */ ArrayString colors = options.colors(); // colors.setValue(0, "#cc0038"); // colors.setValue(1, "#32cd32"); // xAxis options.xAxis().type("datetime").minRange(minRange); // yAxis // options.yAxis().title().text("Exchange rate"); // Highcharts.getOptions().colors[0] String multiAxis = "[{" + " \"id\": \"OperationCount\"," + " \"labels\": { " + " \"format\": \"{value}\"," + " \"style\": { " + " \"color\": \"" + colors.get(1) + "\"" + " }" + " }," + " \"title\": { " + " \"text\": \"Operation Count\"," + " \"style\": {" + " \"color\": \"" + colors.get(1) + "\"" + " }" + " }" + "} , {" + " \"id\": \"DataVolume\", " + " \"title\": {" + " \"text\": \"Data Volume\"," + " \"style\": {" + " \"color\": \"" + colors.get(0) + "\"" + " }" + " }," + " \"labels\": {" + " \"format\": \"{value} " + unitMeasureLabel + "\"," + " \"style\": {" + " \"color\": \"" + colors.get(0) + "\"" + " }" + " }," + " \"opposite\": \"true\"" + "}]"; options.setFieldAsJsonObject("yAxis", multiAxis); // TODO does not seem to be working String fillcolor = "{" + "\"linearGradient\": {" + "\"x1\": 0," + "\"y1\": 0," + "\"x2\": 0," + "\"y2\": 1" + "}," + "\"stops\": [" + "[" + "0, \"#058DC7\"" + "]," + "[" + "1, \"#FFFFFF\"" + "]" + "]" + "}"; options.plotOptions().area() .setFieldAsJsonObject("fillColor", fillcolor).marker() .radius(2).lineWidth(1).states().hover().lineWidth(1); SeriesColumn seriesOperationCount = highchartsFactory .createSeriesColumn(); seriesOperationCount.name("Operation Count"); seriesOperationCount.color(colors.get(1)); seriesOperationCount.type("column"); ArrayNumber dataOperationCount = seriesOperationCount .dataAsArrayNumber(); seriesOperationCount.pointInterval(interval).pointStart( dateStart.getTime()); SeriesArea seriesDataVolume = highchartsFactory.createSeriesArea(); seriesDataVolume.name("Data Volume"); seriesDataVolume.color(colors.get(0)); seriesDataVolume.yAxisAsString("DataVolume"); ArrayNumber dataDataVolume = seriesDataVolume.dataAsArrayNumber(); seriesDataVolume.pointInterval(interval) .pointStart(dateStart.getTime()); for (SeriesStorageData seriesStorageData : seriesStorage.getSeries()) { dataOperationCount.push(seriesStorageData.getOperationCount()); dataDataVolume .push(seriesStorageData.getDataVolume() / unitMeasure); } options.series().addToEnd(seriesOperationCount); options.series().addToEnd(seriesDataVolume); options.chart().showAxes(true); options.legend().enabled(true); // options.legend().layout("vertical"); // options.legend().align("left"); // options.legend().x(120); // options.legend().verticalAlign("top"); // options.legend().y(100); // options.legend().floating(true); // options.legend() // .backgroundColor( // "(Highcharts.theme && Highcharts.theme.legendBackgroundColor) || 'white'"); return; } }