Feature/17249 #1
|
@ -1,12 +1,12 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<classpath>
|
<classpath>
|
||||||
<classpathentry kind="src" output="target/performfish-analytics-portlet-0.6.0-SNAPSHOT/WEB-INF/classes" path="src/main/java">
|
<classpathentry kind="src" output="target/performfish-analytics-portlet-0.7.0-SNAPSHOT/WEB-INF/classes" path="src/main/java">
|
||||||
<attributes>
|
<attributes>
|
||||||
<attribute name="optional" value="true"/>
|
<attribute name="optional" value="true"/>
|
||||||
<attribute name="maven.pomderived" value="true"/>
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
</attributes>
|
</attributes>
|
||||||
</classpathentry>
|
</classpathentry>
|
||||||
<classpathentry excluding="**" kind="src" output="target/performfish-analytics-portlet-0.6.0-SNAPSHOT/WEB-INF/classes" path="src/main/resources">
|
<classpathentry excluding="**" kind="src" output="target/performfish-analytics-portlet-0.7.0-SNAPSHOT/WEB-INF/classes" path="src/main/resources">
|
||||||
<attributes>
|
<attributes>
|
||||||
<attribute name="maven.pomderived" value="true"/>
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
</attributes>
|
</attributes>
|
||||||
|
@ -35,5 +35,5 @@
|
||||||
<attribute name="maven.pomderived" value="true"/>
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
</attributes>
|
</attributes>
|
||||||
</classpathentry>
|
</classpathentry>
|
||||||
<classpathentry kind="output" path="target/performfish-analytics-portlet-0.6.0-SNAPSHOT/WEB-INF/classes"/>
|
<classpathentry kind="output" path="target/performfish-analytics-portlet-0.7.0-SNAPSHOT/WEB-INF/classes"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?><project-modules id="moduleCoreId" project-version="1.5.0">
|
<?xml version="1.0" encoding="UTF-8"?><project-modules id="moduleCoreId" project-version="1.5.0">
|
||||||
<wb-module deploy-name="performfish-analytics-portlet-0.6.0-SNAPSHOT">
|
<wb-module deploy-name="performfish-analytics-portlet-0.7.0-SNAPSHOT">
|
||||||
<wb-resource deploy-path="/" source-path="/target/m2e-wtp/web-resources"/>
|
<wb-resource deploy-path="/" source-path="/target/m2e-wtp/web-resources"/>
|
||||||
<wb-resource deploy-path="/" source-path="/src/main/webapp" tag="defaultRootSource"/>
|
<wb-resource deploy-path="/" source-path="/src/main/webapp" tag="defaultRootSource"/>
|
||||||
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/java"/>
|
<wb-resource deploy-path="/WEB-INF/classes" source-path="/src/main/java"/>
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
# Changelog
|
||||||
|
|
||||||
|
All notable changes to this project will be documented in this file.
|
||||||
|
This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
|
|
||||||
|
## [v1.0.0] - 2020-05-28
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
**Features**
|
||||||
|
|
||||||
|
[#17249] Added PDF support
|
||||||
|
|
||||||
|
|
||||||
|
## [v0.4.0] - 2019-11-07
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
**Features**
|
||||||
|
|
||||||
|
[#17252] Enabled DEA Analysis
|
||||||
|
|
||||||
|
|
||||||
|
## [v0.3.0] - 2019-07-07
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
**Features**
|
||||||
|
|
||||||
|
[#17247] Add numbers to correlation charts
|
||||||
|
|
||||||
|
[#17225] Change Speedometer to Performeter
|
||||||
|
|
||||||
|
[#17570] Added synoptic tables for Pre-grow and Hatchery
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [v0.2.0] - 2019-06-07
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
**Features**
|
||||||
|
|
||||||
|
[#17166] Release Synoptic table functionality
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## [v0.1.0] - 2019-05-07
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
**Features**
|
||||||
|
|
||||||
|
first release
|
||||||
|
|
|
@ -1,21 +1,25 @@
|
||||||
<ReleaseNotes>
|
<ReleaseNotes>
|
||||||
|
<Changeset
|
||||||
|
component="org.gcube.portlets.user.performfish-analytics-portlet.1-0-0"
|
||||||
|
date="2020-05-28">
|
||||||
|
<Change>[#17249] Added PDF support</Change>
|
||||||
|
</Changeset>
|
||||||
<Changeset
|
<Changeset
|
||||||
component="org.gcube.portlets.user.performfish-analytics-portlet.0-4-0"
|
component="org.gcube.portlets.user.performfish-analytics-portlet.0-4-0"
|
||||||
date="2019-11-07">
|
date="2019-11-07">
|
||||||
<Change>[Task #17252] Enabled DEA Analysis</Change>
|
<Change>[#17252] Enabled DEA Analysis</Change>
|
||||||
</Changeset>
|
</Changeset>
|
||||||
<Changeset
|
<Changeset
|
||||||
component="org.gcube.portlets.user.performfish-analytics-portlet.0-3-0"
|
component="org.gcube.portlets.user.performfish-analytics-portlet.0-3-0"
|
||||||
date="2019-07-07">
|
date="2019-07-07">
|
||||||
<Change>[Task #17247] Add numbers to correlation charts</Change>
|
<Change>[#17247] Add numbers to correlation charts</Change>
|
||||||
<Change>[Task #17225] Change Speedometer to Performeter</Change>
|
<Change>[#17225] Change Speedometer to Performeter</Change>
|
||||||
<Change>[Task #17570] Added synoptic tables for Pre-grow and Hatchery</Change>
|
<Change>[#17570] Added synoptic tables for Pre-grow and Hatchery</Change>
|
||||||
</Changeset>
|
</Changeset>
|
||||||
<Changeset
|
<Changeset
|
||||||
component="org.gcube.portlets.user.performfish-analytics-portlet.0-2-0"
|
component="org.gcube.portlets.user.performfish-analytics-portlet.0-2-0"
|
||||||
date="2019-06-07">
|
date="2019-06-07">
|
||||||
<Change>[Task #17165]</Change>
|
<Change>[#17166] Release Synoptic table functionality</Change>
|
||||||
<Change>[]Task #17166] Release Synoptic table functionality</Change>
|
|
||||||
</Changeset>
|
</Changeset>
|
||||||
<Changeset
|
<Changeset
|
||||||
component="org.gcube.portlets.user.performfish-analytics-portlet.0-1-0"
|
component="org.gcube.portlets.user.performfish-analytics-portlet.0-1-0"
|
||||||
|
|
2
pom.xml
2
pom.xml
|
@ -11,7 +11,7 @@
|
||||||
<groupId>org.gcube.portlets.user</groupId>
|
<groupId>org.gcube.portlets.user</groupId>
|
||||||
<artifactId>performfish-analytics-portlet</artifactId>
|
<artifactId>performfish-analytics-portlet</artifactId>
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
<version>0.7.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
<name>PerformFish Analytics Portlet</name>
|
<name>PerformFish Analytics Portlet</name>
|
||||||
|
|
||||||
<scm>
|
<scm>
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -33,7 +33,7 @@ import org.gcube.portlets.user.performfishanalytics.client.event.SubmitRequestEv
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.event.SubmitRequestEventHandler;
|
import org.gcube.portlets.user.performfishanalytics.client.event.SubmitRequestEventHandler;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.AnalyticsPanelResult;
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.CorrelationPanelResult;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.BoxPlotPanelResult;
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.BoxPlotPanelResult;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.DeaPanelResult;
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.DeaPanelResult;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.ScatterPanelResult;
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.ScatterPanelResult;
|
||||||
|
@ -366,8 +366,9 @@ public class PerformFishAnalyticsController {
|
||||||
final Map<String, List<String>> performFishRequestParameters) {
|
final Map<String, List<String>> performFishRequestParameters) {
|
||||||
GWT.log("Read perform fish response: " + performFishResponse);
|
GWT.log("Read perform fish response: " + performFishResponse);
|
||||||
|
|
||||||
|
requestId++;
|
||||||
@SuppressWarnings("unused")
|
@SuppressWarnings("unused")
|
||||||
SynopticTablePanelResult synopticTablePanelResult = new SynopticTablePanelResult(requestId++, viewController,
|
SynopticTablePanelResult synopticTablePanelResult = new SynopticTablePanelResult(requestId, viewController,
|
||||||
performFishResponse, performFishRequestParameters);
|
performFishResponse, performFishRequestParameters);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -490,12 +491,15 @@ public class PerformFishAnalyticsController {
|
||||||
submitRequestPanel.showLoader(true,
|
submitRequestPanel.showLoader(true,
|
||||||
"Submitting " + DataMinerAlgorithms.CORRELATION.getTitle() + " request to DM Service...");
|
"Submitting " + DataMinerAlgorithms.CORRELATION.getTitle() + " request to DM Service...");
|
||||||
|
|
||||||
String tabTitle = DataMinerAlgorithms.CORRELATION.getTitle();
|
final String tabTitle = DataMinerAlgorithms.CORRELATION.getTitle();
|
||||||
|
final String tabDescr = PerformFishResources.INSTANCE.batch_CORRELATION().getText();
|
||||||
final Tab tab = viewController.createTab(tabTitle + " #" + (viewController.currentNumberOfTab() + 1),
|
final Tab tab = viewController.createTab(tabTitle + " #" + (viewController.currentNumberOfTab() + 1),
|
||||||
PerformFishResources.INSTANCE.batch_CORRELATION().getText(), submitRequestPanel);
|
tabDescr, submitRequestPanel);
|
||||||
|
|
||||||
final List<KPI> selectedKPI = new ArrayList<KPI>(viewController.getSelectedKPIs());
|
final List<KPI> selectedKPI = new ArrayList<KPI>(viewController.getSelectedKPIs());
|
||||||
final List<String> batchIDs = new ArrayList<String>(viewController.getListBatchesID());
|
final List<String> batchIDs = new ArrayList<String>(viewController.getListBatchesID());
|
||||||
|
|
||||||
|
requestId++;
|
||||||
PerformFishAnalyticsServiceAsync.Util.getInstance().callingDataMinerPerformFishCorrelationAnalysis(
|
PerformFishAnalyticsServiceAsync.Util.getInstance().callingDataMinerPerformFishCorrelationAnalysis(
|
||||||
performFishResponse, mapParameters, new AsyncCallback<DataMinerResponse>() {
|
performFishResponse, mapParameters, new AsyncCallback<DataMinerResponse>() {
|
||||||
|
|
||||||
|
@ -503,7 +507,7 @@ public class PerformFishAnalyticsController {
|
||||||
public void onSuccess(DataMinerResponse dmResponse) {
|
public void onSuccess(DataMinerResponse dmResponse) {
|
||||||
submitRequestPanel.showLoader(false, null);
|
submitRequestPanel.showLoader(false, null);
|
||||||
checkTabSpinner(submitRequestPanel, tab);
|
checkTabSpinner(submitRequestPanel, tab);
|
||||||
AnalyticsPanelResult analyticsPanelResult = new AnalyticsPanelResult();
|
CorrelationPanelResult analyticsPanelResult = new CorrelationPanelResult(requestId,tabTitle, tabDescr);
|
||||||
analyticsPanelResult.addSelectedAreas(
|
analyticsPanelResult.addSelectedAreas(
|
||||||
performFishRequestParameters.get(PerformFishAnalyticsConstant.PERFORM_FISH_AREA_PARAM));
|
performFishRequestParameters.get(PerformFishAnalyticsConstant.PERFORM_FISH_AREA_PARAM));
|
||||||
analyticsPanelResult.addSelectedKPIs(selectedKPI);
|
analyticsPanelResult.addSelectedKPIs(selectedKPI);
|
||||||
|
@ -524,7 +528,7 @@ public class PerformFishAnalyticsController {
|
||||||
submitRequestPanel.showLoader(false, null);
|
submitRequestPanel.showLoader(false, null);
|
||||||
checkTabSpinner(submitRequestPanel, tab);
|
checkTabSpinner(submitRequestPanel, tab);
|
||||||
try {
|
try {
|
||||||
AnalyticsPanelResult analyticsPanelResult = new AnalyticsPanelResult();
|
CorrelationPanelResult analyticsPanelResult = new CorrelationPanelResult(requestId, tabTitle, tabDescr);
|
||||||
analyticsPanelResult.addSelectedAreas(performFishRequestParameters
|
analyticsPanelResult.addSelectedAreas(performFishRequestParameters
|
||||||
.get(PerformFishAnalyticsConstant.PERFORM_FISH_AREA_PARAM));
|
.get(PerformFishAnalyticsConstant.PERFORM_FISH_AREA_PARAM));
|
||||||
analyticsPanelResult.addSelectedKPIs(selectedKPI);
|
analyticsPanelResult.addSelectedKPIs(selectedKPI);
|
||||||
|
@ -564,21 +568,22 @@ public class PerformFishAnalyticsController {
|
||||||
if (selectedBatchID == null || selectedBatchID.isEmpty())
|
if (selectedBatchID == null || selectedBatchID.isEmpty())
|
||||||
Window.alert("Something seems wrong, no selected BatchID, try again");
|
Window.alert("Something seems wrong, no selected BatchID, try again");
|
||||||
|
|
||||||
|
requestId++;
|
||||||
switch (algorithm) {
|
switch (algorithm) {
|
||||||
case BOXPLOT:
|
case BOXPLOT:
|
||||||
@SuppressWarnings("unused")
|
@SuppressWarnings("unused")
|
||||||
BoxPlotPanelResult boxPlotPanelResult = new BoxPlotPanelResult(requestId++, viewController, algorithm,
|
BoxPlotPanelResult boxPlotPanelResult = new BoxPlotPanelResult(requestId, viewController, algorithm,
|
||||||
focusID, inputKPI, outputKPI);
|
focusID, inputKPI, outputKPI);
|
||||||
break;
|
break;
|
||||||
case SPEEDOMETER:
|
case SPEEDOMETER:
|
||||||
@SuppressWarnings("unused")
|
@SuppressWarnings("unused")
|
||||||
SpeedometerPanelResult speedometerPanelResult = new SpeedometerPanelResult(requestId++, viewController,
|
SpeedometerPanelResult speedometerPanelResult = new SpeedometerPanelResult(requestId, viewController,
|
||||||
algorithm, focusID, inputKPI, outputKPI);
|
algorithm, focusID, inputKPI, outputKPI);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case SCATTER:
|
case SCATTER:
|
||||||
@SuppressWarnings("unused")
|
@SuppressWarnings("unused")
|
||||||
ScatterPanelResult scatterPanelResult = new ScatterPanelResult(requestId++, viewController, algorithm,
|
ScatterPanelResult scatterPanelResult = new ScatterPanelResult(requestId, viewController, algorithm,
|
||||||
focusID, inputKPI, outputKPI);
|
focusID, inputKPI, outputKPI);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
The correlation matrix is a table displaying the correlation between pairs of KPIs.
|
The correlation matrix is a table displaying the correlation between pairs of KPIs.
|
||||||
Correlation coefficients are calculated using the Person parametric correlation test and coloured according to the value in red (significant positive correlation), yellow (significant negative correlation), and in light blue (non-significant correlation).
|
Correlation coefficients are calculated using the Pearson parametric correlation test and coloured according to the value in red (significant positive correlation), yellow (significant negative correlation), and in light blue (non-significant correlation).
|
||||||
The Student t-test is used to determine the ranges of correlation for Pearson coefficients.
|
The Student t-test is used to determine the ranges of correlation for Pearson coefficients.
|
||||||
The analysis is performed on all batches data.
|
The analysis is performed on all batches data.
|
|
@ -1,4 +1,4 @@
|
||||||
The correlation matrix is a table displaying the correlation between pairs of KPIs.
|
The correlation matrix is a table displaying the correlation between pairs of KPIs.
|
||||||
Correlation coefficients are calculated using the Person parametric correlation test and coloured according to the value in red (significant positive correlation), yellow (significant negative correlation), and in light blue (non-significant correlation).
|
Correlation coefficients are calculated using the Pearson parametric correlation test and coloured according to the value in red (significant positive correlation), yellow (significant negative correlation), and in light blue (non-significant correlation).
|
||||||
The Student t-test is used to determine the ranges of correlation for Pearson coefficients.
|
The Student t-test is used to determine the ranges of correlation for Pearson coefficients.
|
||||||
The analysis is performed on all farm data.
|
The analysis is performed on all farm data.
|
|
@ -0,0 +1,591 @@
|
||||||
|
package org.gcube.portlets.user.performfishanalytics.client.viewannualbinder;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.DataMinerInputParameters;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.PerformFishAnnualAnalyticsViewController;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.ShowResult;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.SubmitRequestPanel;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.dataminer.DataMinerResponse;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.performfishservice.PerformFishResponse;
|
||||||
|
|
||||||
|
import com.github.gwtbootstrap.client.ui.Alert;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Button;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Tab;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.IconType;
|
||||||
|
import com.google.gwt.core.client.Scheduler;
|
||||||
|
import com.google.gwt.core.shared.GWT;
|
||||||
|
import com.google.gwt.dom.client.Style.Unit;
|
||||||
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
|
import com.google.gwt.resources.client.TextResource;
|
||||||
|
import com.google.gwt.user.client.Window;
|
||||||
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
|
import com.google.gwt.user.client.ui.ComplexPanel;
|
||||||
|
import com.google.gwt.user.client.ui.FlexTable;
|
||||||
|
import com.google.gwt.user.client.ui.HTML;
|
||||||
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Panel;
|
||||||
|
|
||||||
|
public class BoxPlotAnnualPanelResult {
|
||||||
|
|
||||||
|
private Map<Integer, FlexTable> boxPlotOrderBy = new HashMap<Integer, FlexTable>();
|
||||||
|
|
||||||
|
private PerformFishAnnualAnalyticsViewController viewAnnualController;
|
||||||
|
private int outputIteration = 0;
|
||||||
|
private int outputNumber = 2;
|
||||||
|
private int requestId = 0;
|
||||||
|
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
|
public BoxPlotAnnualPanelResult(int reqId, PerformFishAnnualAnalyticsViewController viewAnnualController,
|
||||||
|
PerformFishResponse thePerformFishResponse, final DataMinerAlgorithms algorithm, String focusID,
|
||||||
|
List<KPI> inputKPI, final List<KPI> outputKPI) {
|
||||||
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
|
this.viewAnnualController = viewAnnualController;
|
||||||
|
TextResource algDescr = PerformFishResources.INSTANCE.farm_BOXPLOT();
|
||||||
|
|
||||||
|
String algDesrTxt = algDescr != null ? algDescr.getText() : null;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
final String tabTitle = algorithm.getTitle();
|
||||||
|
final String tabDescr = algDesrTxt;
|
||||||
|
|
||||||
|
final SubmitRequestPanel submitRequestPanel = new SubmitRequestPanel("", 1);
|
||||||
|
Tab tab = viewAnnualController.createTab(tabTitle + " #" + (viewAnnualController.currentNumberOfTab() + 1),
|
||||||
|
algDesrTxt, submitRequestPanel);
|
||||||
|
|
||||||
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
|
savePDFButton = new Button();
|
||||||
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId, outputIteration, outputNumber);
|
||||||
|
// dmResponse.getListOutput().size()
|
||||||
|
}
|
||||||
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
|
res.add(savePDFButton);
|
||||||
|
submitRequestPanel.addWidget(res);
|
||||||
|
int oIteration = 0;
|
||||||
|
|
||||||
|
submitRequestPanel.setTotalRequests(inputKPI.size());
|
||||||
|
for (KPI kpi : inputKPI) {
|
||||||
|
oIteration++;
|
||||||
|
String title = "KPI: " + kpi.getName();
|
||||||
|
HTML toBigTitle = new HTML(title);
|
||||||
|
toBigTitle.getElement().setId("KPI_BoxPlotAnnual_" + requestId + "_" + oIteration);
|
||||||
|
toBigTitle.getElement().addClassName("to-big-title");
|
||||||
|
submitRequestPanel.addWidget(toBigTitle);
|
||||||
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
|
hp.getElement().addClassName("ext-horizontal-panel");
|
||||||
|
|
||||||
|
DataMinerInputParameters dmInputParams = new DataMinerInputParameters(thePerformFishResponse,
|
||||||
|
viewAnnualController.getSelectedYears(), Arrays.asList(kpi), null, algorithm, focusID);
|
||||||
|
callDataMinerServiceForChart(dmInputParams, submitRequestPanel, hp, tab, oIteration);
|
||||||
|
// resultPanel.add(hp);
|
||||||
|
submitRequestPanel.addWidget(hp);
|
||||||
|
}
|
||||||
|
outputIteration = oIteration;
|
||||||
|
GWT.log("outputInteration: " + outputIteration);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Call data miner service for chart.
|
||||||
|
*
|
||||||
|
* @param dmInputParameters
|
||||||
|
* the dm input parameters
|
||||||
|
* @param requestPanel
|
||||||
|
* the request panel
|
||||||
|
* @param panelContainer
|
||||||
|
* the panel
|
||||||
|
* @param tab
|
||||||
|
* the tab
|
||||||
|
* @param tabDescr
|
||||||
|
* @param tabTitle
|
||||||
|
*/
|
||||||
|
private void callDataMinerServiceForChart(final DataMinerInputParameters dmInputParameters,
|
||||||
|
final SubmitRequestPanel requestPanel, final ComplexPanel panelContainer, final Tab tab,
|
||||||
|
final int oIteration) {
|
||||||
|
|
||||||
|
GWT.log("Building DM request with input parameters: " + dmInputParameters);
|
||||||
|
|
||||||
|
StringBuilder dataInputsFormatter = new StringBuilder();
|
||||||
|
dataInputsFormatter
|
||||||
|
.append(PerformFishAnalyticsConstant.DM_CHARTTYPE_PARAM + "=" + dmInputParameters.getChartType() + ";");
|
||||||
|
|
||||||
|
String yearsValue = "";
|
||||||
|
for (String year : dmInputParameters.getSelectedYears()) {
|
||||||
|
yearsValue += year + "|";
|
||||||
|
}
|
||||||
|
yearsValue = yearsValue.substring(0, yearsValue.length() - 1);
|
||||||
|
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_YEARS_PARAM + "=" + yearsValue + ";");
|
||||||
|
dataInputsFormatter
|
||||||
|
.append(PerformFishAnalyticsConstant.DM_FOCUS_PARAM + "=" + dmInputParameters.getFocusID() + ";");
|
||||||
|
// dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_FOCUS_PARAM+"=ID;");
|
||||||
|
|
||||||
|
if (dmInputParameters.getInputKPI() != null && dmInputParameters.getInputKPI().size() > 0) {
|
||||||
|
String kpiCodes = "";
|
||||||
|
for (KPI kpi : dmInputParameters.getInputKPI()) {
|
||||||
|
kpiCodes += kpi.getCode() + "|";
|
||||||
|
}
|
||||||
|
// remove last |
|
||||||
|
kpiCodes = kpiCodes.substring(0, kpiCodes.length() - 1);
|
||||||
|
|
||||||
|
GWT.log("Input KPICodes: " + kpiCodes);
|
||||||
|
// ADDING KPIs code
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_INPUT_KPI_PARAM + "=" + kpiCodes + ";");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dmInputParameters.getOutputKPI() != null && dmInputParameters.getOutputKPI().size() > 0) {
|
||||||
|
String kpiCodes = "";
|
||||||
|
for (KPI kpi : dmInputParameters.getOutputKPI()) {
|
||||||
|
kpiCodes += kpi.getCode() + "|";
|
||||||
|
}
|
||||||
|
// remove last |
|
||||||
|
kpiCodes = kpiCodes.substring(0, kpiCodes.length() - 1);
|
||||||
|
|
||||||
|
GWT.log("Output KPICodes: " + kpiCodes);
|
||||||
|
// ADDING KPIs code
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_OUTPUT_KPI_PARAM + "=" + kpiCodes + ";");
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, String> performFishResponseMap = dmInputParameters.getPerformFishResponse().getMapParameters();
|
||||||
|
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.LethalIncidentsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AnnualTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntibioticsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntiparasiticTable);
|
||||||
|
|
||||||
|
String dataInParameters = dataInputsFormatter.toString();
|
||||||
|
GWT.log("Calling DM service with client input parameters: " + dataInParameters);
|
||||||
|
|
||||||
|
Map<String, List<String>> mapParameters = new HashMap<String, List<String>>();
|
||||||
|
mapParameters.put(PerformFishAnalyticsConstant.DATA_INPUTS, Arrays.asList(dataInParameters));
|
||||||
|
|
||||||
|
final LoaderIcon loaderIcon = new LoaderIcon(
|
||||||
|
"Submitting request to " + dmInputParameters.getChartType().getTitle() + " Analysis...");
|
||||||
|
loaderIcon.setVisible(true);
|
||||||
|
panelContainer.setVisible(true);
|
||||||
|
panelContainer.add(loaderIcon);
|
||||||
|
Scheduler.get().scheduleDeferred(new Scheduler.ScheduledCommand() {
|
||||||
|
@Override
|
||||||
|
public void execute() {
|
||||||
|
loaderIcon.setFocus(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().callingDataMinerPerformFishAnnualAnalysis(mapParameters,
|
||||||
|
new AsyncCallback<DataMinerResponse>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(DataMinerResponse dmResponse) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(requestPanel, tab);
|
||||||
|
// field_unary_algorithm.setVisible(true);
|
||||||
|
GWT.log("I'm displaying: " + dmResponse);
|
||||||
|
displayOutputFilesAsStaticEntities(dmResponse, dmInputParameters.getChartType(),
|
||||||
|
dmInputParameters.getInputKPI(), dmInputParameters.getOutputKPI(),
|
||||||
|
dmInputParameters.getFocusID(), panelContainer, false, oIteration);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(requestPanel, tab);
|
||||||
|
displayOutputFilesAsStaticEntities(null, dmInputParameters.getChartType(),
|
||||||
|
dmInputParameters.getInputKPI(), dmInputParameters.getOutputKPI(),
|
||||||
|
dmInputParameters.getFocusID(), panelContainer, true, oIteration);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append DM input table.
|
||||||
|
*
|
||||||
|
* @param performFishResponseMap
|
||||||
|
* the perform fish response map
|
||||||
|
* @param dataInputsFormatter
|
||||||
|
* the data inputs formatter
|
||||||
|
* @param table
|
||||||
|
* the table
|
||||||
|
* @return the string builder
|
||||||
|
*/
|
||||||
|
private StringBuilder appendDMInputTable(Map<String, String> performFishResponseMap,
|
||||||
|
StringBuilder dataInputsFormatter, PFSERVICE_TO_DM_MAPPING_TABLE table) {
|
||||||
|
|
||||||
|
String toDMInputTable = performFishResponseMap.get(table.getPerformFishTable());
|
||||||
|
|
||||||
|
if (toDMInputTable != null && !toDMInputTable.isEmpty()) {
|
||||||
|
dataInputsFormatter.append(table.getDataMinerTable() + "=" + toDMInputTable + ";");
|
||||||
|
}
|
||||||
|
|
||||||
|
return dataInputsFormatter;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, String title) {
|
||||||
|
if (title.startsWith("My")) {
|
||||||
|
return null;
|
||||||
|
} else if (title.startsWith("All")) {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
return outputId;
|
||||||
|
} else {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 2;
|
||||||
|
return outputId;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
if (displayError) {
|
||||||
|
Alert alert = new Alert(title);
|
||||||
|
alert.setType(AlertType.ERROR);
|
||||||
|
alert.setClose(false);
|
||||||
|
alert.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
container.add(alert);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(true);
|
||||||
|
final String toTitle = title;
|
||||||
|
|
||||||
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
|
switch (outputFile.getDataType()) {
|
||||||
|
case IMAGE:
|
||||||
|
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getImageFile(outputFile,
|
||||||
|
new AsyncCallback<String>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(String base64Content) {
|
||||||
|
|
||||||
|
String title = toTitle;
|
||||||
|
|
||||||
|
title = chartType.getTitle() + " - on all farm data<br>";
|
||||||
|
title += "Blue dots indicate the selected farm: " + focusID;
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showImage(base64Content);
|
||||||
|
displayingOrderedBoxPlot(dmResponse, title, container, showResult);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case CSV:
|
||||||
|
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true,
|
||||||
|
new AsyncCallback<CSVFile>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(CSVFile result) {
|
||||||
|
GWT.log("Displaying: " + result);
|
||||||
|
|
||||||
|
String cssTableStyle = "simpletable";
|
||||||
|
|
||||||
|
String title = toTitle;
|
||||||
|
|
||||||
|
if (result.getFileName().contains("_user")) {
|
||||||
|
title = "My Batch(es)";
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
title = "All farm data in the VRE (including mine)";
|
||||||
|
}
|
||||||
|
title += "<br>";
|
||||||
|
title += "Data aggregation is performed by considering farms as base units";
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
|
displayingOrderedBoxPlot(dmResponse, title, container, showResult);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayingOrderedBoxPlot(final DataMinerResponse dmResponse, String title, final Panel container,
|
||||||
|
ShowResult showResult) {
|
||||||
|
int hashcode = dmResponse.hashCode();
|
||||||
|
GWT.log("The hascode is: " + hashcode);
|
||||||
|
FlexTable flex = boxPlotOrderBy.get(hashcode);
|
||||||
|
|
||||||
|
if (flex == null) {
|
||||||
|
GWT.log("The flextable is null");
|
||||||
|
flex = new FlexTable();
|
||||||
|
boxPlotOrderBy.put(hashcode, flex);
|
||||||
|
container.add(flex);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (title.startsWith("My")) {
|
||||||
|
flex.setWidget(0, 0, showResult);
|
||||||
|
} else if (title.startsWith("All")) {
|
||||||
|
flex.setWidget(0, 1, showResult);
|
||||||
|
} else {
|
||||||
|
flex.setWidget(0, 2, showResult);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the spinner if all DM responses are returned.
|
||||||
|
*
|
||||||
|
* @param requestPanel
|
||||||
|
* the request panel
|
||||||
|
* @param tab
|
||||||
|
* the tab
|
||||||
|
*/
|
||||||
|
private void checkTabSpinner(SubmitRequestPanel requestPanel, Tab tab) {
|
||||||
|
requestPanel.incrementCompletedRequests();
|
||||||
|
int completed = requestPanel.getCompletedRequests();
|
||||||
|
int total = requestPanel.getTotalRequests();
|
||||||
|
|
||||||
|
if (completed >= total) {
|
||||||
|
viewAnnualController.noSpinner(tab);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static native void saveFilePDF(String chartType, String filename, String tabTitle, String tabDescr,
|
||||||
|
int requestId, int outputIteration, int outputNumber)/*-{
|
||||||
|
var that = this;
|
||||||
|
console.log('saveFilePDF()');
|
||||||
|
console.log('requestId: ' + requestId);
|
||||||
|
console.log('OutputIteration: ' + outputIteration);
|
||||||
|
console.log('OutputNumber:' + outputNumber);
|
||||||
|
|
||||||
|
var tTitle = tabTitle;
|
||||||
|
var tDescr = tabDescr;
|
||||||
|
|
||||||
|
var pdoc = new jsPDF("p", "mm", "a4");
|
||||||
|
pdoc.setProperties({
|
||||||
|
title : 'PerformFish ' + tTitle,
|
||||||
|
subject : ' Results',
|
||||||
|
author : 'PerformFish',
|
||||||
|
keywords : 'PerformFish',
|
||||||
|
creator : 'D4Science'
|
||||||
|
});
|
||||||
|
|
||||||
|
var lMargin = 15; //left margin in mm
|
||||||
|
var rMargin = 15; //right margin in mm
|
||||||
|
var tMargin = 15; //top margin in mm
|
||||||
|
var bMargin = 15; //bottom margin in mm
|
||||||
|
var pdfWidthInMM = 210; // width of A4 in mm
|
||||||
|
var pdfHeightInMM = 297; // height of A4 in mm
|
||||||
|
var pageCenter = pdfWidthInMM / 2;
|
||||||
|
|
||||||
|
pdoc.setFontSize(24);
|
||||||
|
var title = "PerformFish " + tTitle;
|
||||||
|
var titleHeight = pdoc.getLineHeight(title) / pdoc.internal.scaleFactor
|
||||||
|
var xPos = lMargin;
|
||||||
|
var yPos = tMargin;
|
||||||
|
pdoc.text(title, pageCenter, yPos, 'center');
|
||||||
|
yPos += titleHeight;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
var lineHeight = pdoc.getLineHeight(tDescr) / pdoc.internal.scaleFactor
|
||||||
|
var splittedAnalysisDescription = pdoc.splitTextToSize(tDescr,
|
||||||
|
(pdfWidthInMM - lMargin - rMargin));
|
||||||
|
var lines = splittedAnalysisDescription.length // splitted text is a string array
|
||||||
|
var analysisDescriptionHeight = lines * lineHeight
|
||||||
|
|
||||||
|
pdoc.text(splittedAnalysisDescription, xPos, yPos, 'left');
|
||||||
|
yPos += analysisDescriptionHeight;
|
||||||
|
|
||||||
|
//yPos += 2;
|
||||||
|
//pdoc.text("Analysis:", xPos, yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
|
var kpiId = 'KPI_BoxPlotAnnual_' + requestId + '_' + i;
|
||||||
|
console.log('kpiId: ' + kpiId);
|
||||||
|
|
||||||
|
var kpiName = $doc.getElementById(kpiId);
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(14);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
|
||||||
|
var kpiText = kpiName.textContent;
|
||||||
|
var kpiHeight = pdoc.getLineHeight(kpiText)
|
||||||
|
/ pdoc.internal.scaleFactor;
|
||||||
|
var splittedKpiName = pdoc.splitTextToSize(kpiText, (pdfWidthInMM
|
||||||
|
- lMargin - rMargin));
|
||||||
|
var kpiLines = splittedKpiName.length; // splitted text is a string array
|
||||||
|
var kpiLinesHeight = kpiLines * kpiHeight;
|
||||||
|
pdoc.text(splittedKpiName, xPos, yPos, 'left');
|
||||||
|
yPos += kpiLinesHeight;
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
|
var outputId = 'OutputId_' + requestId + '_' + i + '_' + j;
|
||||||
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
|
var resultOutputNumber = $doc.getElementById(outputId);
|
||||||
|
|
||||||
|
console.log('OutputId_: ' + resultOutputNumber.innerHTML);
|
||||||
|
var resultType = resultOutputNumber.className;
|
||||||
|
|
||||||
|
console.log('resultOutputNumber className: ' + resultType);
|
||||||
|
|
||||||
|
if (typeof resultType !== 'undefined' && resultType !== null
|
||||||
|
&& resultType !== '') {
|
||||||
|
|
||||||
|
if (resultType == 'csv') {
|
||||||
|
console.log('Result Type csv: ' + i);
|
||||||
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
|
console.log('CSV SecondTable: ' + secondTable);
|
||||||
|
|
||||||
|
pdoc.autoTable({
|
||||||
|
theme : 'grid',
|
||||||
|
startY : yPos,
|
||||||
|
pageBreak : 'auto',
|
||||||
|
bodyStyles : {
|
||||||
|
fontSize : 9
|
||||||
|
},
|
||||||
|
html : secondTable
|
||||||
|
});
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
} else {
|
||||||
|
if (resultType == 'image') {
|
||||||
|
console.log('Result Type image: ' + i);
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
|
'img').item(0);
|
||||||
|
console.log('Image element: ' + imageElement);
|
||||||
|
pdoc.addImage(imageElement, lMargin, yPos);
|
||||||
|
console.log('Image Height: ' + imageElement.height);
|
||||||
|
yPos += (imageElement.height * 0.26458333);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
console.log('Result Type unknow: ' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Result Type is undefined:' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (i < outputIteration) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var numberOfPages=pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/"+numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Done');
|
||||||
|
|
||||||
|
pdoc.save(filename);
|
||||||
|
|
||||||
|
}-*/;
|
||||||
|
|
||||||
|
}
|
|
@ -10,7 +10,7 @@ import java.util.Map;
|
||||||
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsController;
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.PerformFishAnnualAnalyticsController;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.event.CallAlgorithmEvent;
|
import org.gcube.portlets.user.performfishanalytics.client.event.CallAlgorithmEvent;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.view.util.CorrelationValueToColourUtil;
|
import org.gcube.portlets.user.performfishanalytics.client.view.util.CorrelationValueToColourUtil;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
|
@ -32,7 +32,6 @@ import com.google.gwt.dom.client.Style.Unit;
|
||||||
import com.google.gwt.event.dom.client.ClickEvent;
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
import com.google.gwt.event.dom.client.ClickHandler;
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
import com.google.gwt.event.logical.shared.AttachEvent;
|
import com.google.gwt.event.logical.shared.AttachEvent;
|
||||||
import com.google.gwt.event.shared.HandlerManager;
|
|
||||||
import com.google.gwt.uibinder.client.UiBinder;
|
import com.google.gwt.uibinder.client.UiBinder;
|
||||||
import com.google.gwt.uibinder.client.UiField;
|
import com.google.gwt.uibinder.client.UiField;
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
|
@ -51,13 +50,13 @@ import com.google.gwt.user.client.ui.Widget;
|
||||||
*
|
*
|
||||||
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it Jan 29, 2019
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it Jan 29, 2019
|
||||||
*/
|
*/
|
||||||
public class AnalyticsAnnualPanelResult extends Composite {
|
public class CorrelationAnnualPanelResult extends Composite {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
private static AnalyticsPanelResultUiBinder uiBinder = GWT.create(AnalyticsPanelResultUiBinder.class);
|
private static CorrelationPanelResultUiBinder uiBinder = GWT.create(CorrelationPanelResultUiBinder.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The Interface AnalyticsPanelResultUiBinder.
|
* The Interface AnalyticsPanelResultUiBinder.
|
||||||
|
@ -65,7 +64,7 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
* @author Francesco Mangiacrapa at ISTI-CNR
|
* @author Francesco Mangiacrapa at ISTI-CNR
|
||||||
* (francesco.mangiacrapa@isti.cnr.it) Jan 30, 2019
|
* (francesco.mangiacrapa@isti.cnr.it) Jan 30, 2019
|
||||||
*/
|
*/
|
||||||
interface AnalyticsPanelResultUiBinder extends UiBinder<Widget, AnalyticsAnnualPanelResult> {
|
interface CorrelationPanelResultUiBinder extends UiBinder<Widget, CorrelationAnnualPanelResult> {
|
||||||
}
|
}
|
||||||
|
|
||||||
@UiField
|
@UiField
|
||||||
|
@ -114,19 +113,17 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
|
|
||||||
private List<String> selectedAreas;
|
private List<String> selectedAreas;
|
||||||
|
|
||||||
// private HandlerManager theEventBus;
|
|
||||||
|
|
||||||
private Map<String, CSVFile> csvGenerated = new HashMap<String, CSVFile>();
|
private Map<String, CSVFile> csvGenerated = new HashMap<String, CSVFile>();
|
||||||
|
|
||||||
private AnalyticsAnnualPanelResult analyticsPanelResult;
|
private CorrelationAnnualPanelResult analyticsPanelResult;
|
||||||
|
|
||||||
private static int callNumber;
|
private int outputNumber;
|
||||||
|
private int requestId = 0;
|
||||||
|
|
||||||
private static Map<String, Integer> outputNumbers = new HashMap<String, Integer>();
|
public CorrelationAnnualPanelResult(int reqId, final String tabTitle,
|
||||||
|
final String tabDescription) {
|
||||||
private String analysisDescription;
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
public AnalyticsAnnualPanelResult(HandlerManager eventBus) {
|
|
||||||
|
|
||||||
initWidget(uiBinder.createAndBindUi(this));
|
initWidget(uiBinder.createAndBindUi(this));
|
||||||
// this.theEventBus = eventBus;
|
// this.theEventBus = eventBus;
|
||||||
|
@ -138,26 +135,10 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick(ClickEvent event) {
|
public void onClick(ClickEvent event) {
|
||||||
saveFilePDF(analyticsPanelResult, "AnalysisResult.pdf");
|
saveFilePDF(analyticsPanelResult, tabTitle, tabTitle, tabDescription, requestId, outputNumber);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
/*
|
|
||||||
* uib_save_pdf_2.setIcon(IconType.PRINT);
|
|
||||||
* uib_save_pdf_2.addClickHandler(new ClickHandler() {
|
|
||||||
*
|
|
||||||
* @Override public void onClick(ClickEvent event) {
|
|
||||||
* saveFilePDF(analyticsPanelResult, "AnalysisResult.pdf"); } });
|
|
||||||
*/
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getAnalysisDescription() {
|
|
||||||
return analysisDescription;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setAnalysisDescription(String analysisDescription) {
|
|
||||||
this.analysisDescription = analysisDescription;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -256,6 +237,7 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
public void addParameters(String keyToGet, Map<String, List<String>> parameters, String toShowBatchTypeValue) {
|
public void addParameters(String keyToGet, Map<String, List<String>> parameters, String toShowBatchTypeValue) {
|
||||||
|
|
||||||
final FlexTable flexTable = new FlexTable();
|
final FlexTable flexTable = new FlexTable();
|
||||||
|
flexTable.getElement().setId("CorrelationParameterInputKPIs");
|
||||||
flexTable.setStyleName("colgrouptable");
|
flexTable.setStyleName("colgrouptable");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -289,8 +271,8 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
KPINames += kpi.getName() + ", ";
|
KPINames += kpi.getName() + ", ";
|
||||||
}
|
}
|
||||||
KPINames = KPINames.substring(0, KPINames.length() - 2);
|
KPINames = KPINames.substring(0, KPINames.length() - 2);
|
||||||
flexTable.setWidget(2, 0, new HTML("KPIs:"));
|
flexTable.setWidget(1, 0, new HTML("KPIs:"));
|
||||||
flexTable.setWidget(2, 1, new HTML(KPINames));
|
flexTable.setWidget(1, 1, new HTML(KPINames));
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// silent
|
// silent
|
||||||
|
@ -311,6 +293,13 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getOutputId() {
|
||||||
|
outputNumber++;
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + outputNumber;
|
||||||
|
GWT.log("Generated OutputId: " + outputId);
|
||||||
|
return outputId;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds the results.
|
* Adds the results.
|
||||||
*
|
*
|
||||||
|
@ -321,7 +310,8 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
|
|
||||||
this.dmResponse = dmResponse;
|
this.dmResponse = dmResponse;
|
||||||
|
|
||||||
for (final OutputFile outputFile : dmResponse.getListOutput()) {
|
outputNumber = 0;
|
||||||
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
|
||||||
if (outputFile.getDataType().equals(FileContentType.CSV)) {
|
if (outputFile.getDataType().equals(FileContentType.CSV)) {
|
||||||
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true,
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true,
|
||||||
|
@ -373,7 +363,9 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
|
|
||||||
HorizontalPanel hp = new HorizontalPanel();
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
final FlexTable flexTable = new FlexTable();
|
final FlexTable flexTable = new FlexTable();
|
||||||
|
|
||||||
flexTable.setStyleName("fixedtable");
|
flexTable.setStyleName("fixedtable");
|
||||||
|
flexTable.getElement().setId(getOutputId());
|
||||||
flexTable.getElement().getStyle().setMarginBottom(10, Unit.PX);
|
flexTable.getElement().getStyle().setMarginBottom(10, Unit.PX);
|
||||||
|
|
||||||
flexTable.setWidget(0, 0, new Label(""));
|
flexTable.setWidget(0, 0, new Label(""));
|
||||||
|
@ -453,7 +445,7 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
buttonHTML.getElement().getStyle().setBackgroundColor(theColor);
|
||||||
flexTable.setWidget(rowIndex, j, buttonHTML);
|
flexTable.setWidget(rowIndex, j, buttonHTML);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -462,6 +454,7 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
hp.add(flexTable);
|
hp.add(flexTable);
|
||||||
|
|
||||||
final FlexTable flexLegend = new FlexTable();
|
final FlexTable flexLegend = new FlexTable();
|
||||||
|
flexLegend.getElement().setId(getOutputId());
|
||||||
flexLegend.setStyleName("simpletable");
|
flexLegend.setStyleName("simpletable");
|
||||||
Map<String, String> map = CorrelationValueToColourUtil.getMap();
|
Map<String, String> map = CorrelationValueToColourUtil.getMap();
|
||||||
flexLegend.setWidget(0, 0, new Label("Legend"));
|
flexLegend.setWidget(0, 0, new Label("Legend"));
|
||||||
|
@ -470,6 +463,7 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
for (String key : map.keySet()) {
|
for (String key : map.keySet()) {
|
||||||
final String rgbColor = map.get(key);
|
final String rgbColor = map.get(key);
|
||||||
final HTML theLegendColor = new HTML("");
|
final HTML theLegendColor = new HTML("");
|
||||||
|
theLegendColor.getElement().getStyle().setBackgroundColor(rgbColor);
|
||||||
flexLegend.setWidget(i, 0, theLegendColor);
|
flexLegend.setWidget(i, 0, theLegendColor);
|
||||||
flexLegend.setWidget(i, 1, new HTML(key));
|
flexLegend.setWidget(i, 1, new HTML(key));
|
||||||
theLegendColor.addAttachHandler(new AttachEvent.Handler() {
|
theLegendColor.addAttachHandler(new AttachEvent.Handler() {
|
||||||
|
@ -567,17 +561,21 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
GWT.log("Called ScatterChart at rowIndex: " + rowIndex + ", columnIndex: " + columnIndex);
|
GWT.log("Called ScatterChart at rowIndex: " + rowIndex + ", columnIndex: " + columnIndex);
|
||||||
List<KPI> selectedKPI = getKPIForIndexes(rowIndex, columnIndex);
|
List<KPI> selectedKPI = getKPIForIndexes(rowIndex, columnIndex);
|
||||||
GWT.log("Selected KPI: " + selectedKPI);
|
GWT.log("Selected KPI: " + selectedKPI);
|
||||||
PerformFishAnalyticsController.eventBus
|
PerformFishAnnualAnalyticsController.eventBus
|
||||||
.fireEvent(new CallAlgorithmEvent(DataMinerAlgorithms.SCATTER, focusID, selectedKPI, null));
|
.fireEvent(new CallAlgorithmEvent(DataMinerAlgorithms.SCATTER, focusID, selectedKPI, null));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native void saveFilePDF(AnalyticsAnnualPanelResult chart, String filename)/*-{
|
private static native void saveFilePDF(CorrelationAnnualPanelResult chart, String filename, String tabTitle,
|
||||||
|
String tabDescr, int requestId, int outputNumber)/*-{
|
||||||
var that = this;
|
var that = this;
|
||||||
console.log('saveFilePDF()');
|
console.log('saveFilePDF()');
|
||||||
|
|
||||||
|
var tTitle = tabTitle;
|
||||||
|
var tDescr = tabDescr;
|
||||||
|
|
||||||
var pdoc = new jsPDF("p", "mm", "a4");
|
var pdoc = new jsPDF("p", "mm", "a4");
|
||||||
pdoc.setProperties({
|
pdoc.setProperties({
|
||||||
title : 'PerformFish Analysis',
|
title : 'PerformFish ' + tTitle,
|
||||||
subject : ' Results',
|
subject : ' Results',
|
||||||
author : 'PerformFish',
|
author : 'PerformFish',
|
||||||
keywords : 'PerformFish',
|
keywords : 'PerformFish',
|
||||||
|
@ -593,131 +591,196 @@ public class AnalyticsAnnualPanelResult extends Composite {
|
||||||
var pageCenter = pdfWidthInMM / 2;
|
var pageCenter = pdfWidthInMM / 2;
|
||||||
|
|
||||||
pdoc.setFontSize(24);
|
pdoc.setFontSize(24);
|
||||||
var title = "PerformFish Analysis";
|
var title = "PerformFish " + tTitle;
|
||||||
var titleHeight = pdoc.getLineHeight(title) / pdoc.internal.scaleFactor
|
var titleHeight = pdoc.getLineHeight(title) / pdoc.internal.scaleFactor
|
||||||
var xPos = lMargin;
|
var xPos = lMargin;
|
||||||
var yPos = tMargin;
|
var yPos = tMargin;
|
||||||
pdoc.text(title, pageCenter, yPos, 'center');
|
pdoc.text(title, pageCenter, yPos, 'center');
|
||||||
yPos += titleHeight;
|
yPos += titleHeight;
|
||||||
|
|
||||||
var analysisDescription = chart.@org.gcube.portlets.user.performfishanalytics.client.viewannualbinder.AnalyticsAnnualPanelResult::analysisDescription;
|
|
||||||
|
|
||||||
pdoc.setFontSize(10);
|
pdoc.setFontSize(10);
|
||||||
var lineHeight = pdoc.getLineHeight(deaDescription)
|
var lineHeight = pdoc.getLineHeight(tDescr) / pdoc.internal.scaleFactor
|
||||||
/ pdoc.internal.scaleFactor
|
var splittedAnalysisDescription = pdoc.splitTextToSize(tDescr,
|
||||||
var splittedAnalysisDescription = pdoc.splitTextToSize(
|
(pdfWidthInMM - lMargin - rMargin));
|
||||||
analysisDescription, (pdfWidthInMM - lMargin - rMargin));
|
|
||||||
var lines = splittedAnalysisDescription.length // splitted text is a string array
|
var lines = splittedAnalysisDescription.length // splitted text is a string array
|
||||||
var analysisDescriptionHeight = lines * lineHeight
|
var analysisDescriptionHeight = lines * lineHeight
|
||||||
|
|
||||||
pdoc.text(splittedAnalysisDescription, xPos, yPos, 'left');
|
pdoc.text(splittedAnalysisDescription, xPos, yPos, 'left');
|
||||||
yPos += analysisDescriptionHeight;
|
yPos += analysisDescriptionHeight;
|
||||||
|
|
||||||
yPos += 2;
|
yPos += 4;
|
||||||
pdoc.text("Analysis:", xPos, yPos, 'left');
|
pdoc.setFontSize(10);
|
||||||
yPos += 6;
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text("Parameters:", xPos, yPos, 'left');
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
yPos += 4;
|
||||||
|
|
||||||
var callNumber = @org.gcube.portlets.user.performfishanalytics.client.viewannualbinder.AnalyticsAnnualPanelResult::callNumber;
|
var correlationParametersInputKPIs = $doc
|
||||||
console.log('CallNumber: ' + callNumber);
|
.getElementById('CorrelationParameterInputKPIs');
|
||||||
|
|
||||||
for (var n = 1; n <= callNumber; n++) {
|
console.log('InputKPIs: ' + correlationParametersInputKPIs);
|
||||||
var deaAnalysisResultParametersInputKPIs = $doc
|
|
||||||
.getElementById('DeaAnalysisResultParameterInputKPIs_' + n).innerHTML;
|
|
||||||
|
|
||||||
console.log('InputKPIs: ' + deaAnalysisResultParametersInputKPIs);
|
pdoc.autoTable({
|
||||||
var deaAnalysisResultParametersOutputKPIs = $doc
|
theme : 'plain',
|
||||||
.getElementById('DeaAnalysisResultParameterOutputKPIs_' + n).innerHTML;
|
startY : yPos,
|
||||||
console.log('OuputKPIs: ' + deaAnalysisResultParametersOutputKPIs);
|
pageBreak : 'auto',
|
||||||
|
columnStyles : {
|
||||||
pdoc.autoTable({
|
0 : {
|
||||||
theme : 'plain',
|
halign : 'left',
|
||||||
startY : yPos,
|
fillColor : [ 211, 225, 241 ]
|
||||||
pageBreak : 'auto',
|
|
||||||
columnStyles : {
|
|
||||||
0 : {
|
|
||||||
halign : 'left',
|
|
||||||
fillColor : [ 211, 225, 241 ]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
head : null,
|
|
||||||
body : [
|
|
||||||
[ 'Selected Input KPIs',
|
|
||||||
deaAnalysisResultParametersInputKPIs ],
|
|
||||||
[ 'Selected Output KPIs',
|
|
||||||
deaAnalysisResultParametersOutputKPIs ] ]
|
|
||||||
});
|
|
||||||
|
|
||||||
yPos = pdoc.previousAutoTable.finalY + 6;
|
|
||||||
|
|
||||||
var deaAnalysisResults = $doc.getElementById('DeaAnalysisResults');
|
|
||||||
|
|
||||||
var deaAnalysisResult = $doc.getElementById('DeaAnalysisResult_'
|
|
||||||
+ n);
|
|
||||||
|
|
||||||
console.log("DeaAnalysisResult: " + n);
|
|
||||||
|
|
||||||
var outputNumber = @org.gcube.portlets.user.performfishanalytics.client.viewbinder.DeaPanelResult::getOutputNumber(Ljava/lang/String;)('DeaAnalysisResult_'+ n);
|
|
||||||
console.log('OutputNumber: ' + outputNumber);
|
|
||||||
|
|
||||||
for (var i = 1; i <= outputNumber; i++) {
|
|
||||||
|
|
||||||
var deaOutputId = 'DeaAnalysisResult_' + n + '_' + i;
|
|
||||||
console.log('DeaOutputId: ' + deaOutputId);
|
|
||||||
|
|
||||||
var deaOutputNumber = $doc.getElementById(deaOutputId);
|
|
||||||
|
|
||||||
console.log('DeaOutputNumber: ' + deaOutputNumber.innerHTML);
|
|
||||||
var resultType = deaOutputNumber.className;
|
|
||||||
|
|
||||||
console.log('DeaOutputNumber className: ' + resultType);
|
|
||||||
|
|
||||||
if (typeof resultType !== 'undefined' && resultType !== null
|
|
||||||
&& resultType !== '') {
|
|
||||||
|
|
||||||
if (resultType == 'csv') {
|
|
||||||
console.log('Result Type csv: ' + i);
|
|
||||||
// foo could get resolved and it's defined
|
|
||||||
|
|
||||||
var childrenTable = deaOutputNumber.children;
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
|
||||||
var secondTable = secondDiv.children[0].children[0];
|
|
||||||
|
|
||||||
console.log('CSV SecondTable: ' + secondTable);
|
|
||||||
|
|
||||||
pdoc.autoTable({
|
|
||||||
theme : 'grid',
|
|
||||||
startY : yPos,
|
|
||||||
pageBreak : 'auto',
|
|
||||||
bodyStyles : {
|
|
||||||
fontSize : 9
|
|
||||||
},
|
|
||||||
html : secondTable
|
|
||||||
});
|
|
||||||
|
|
||||||
yPos = pdoc.previousAutoTable.finalY + 6;
|
|
||||||
} else {
|
|
||||||
if (resultType == 'image') {
|
|
||||||
console.log('Result Type image: ' + i);
|
|
||||||
var childrenTable = deaOutputNumber.children;
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
|
||||||
var imageElement = secondDiv.getElementsByTagName(
|
|
||||||
'img').item(0);
|
|
||||||
console.log('Image element: ' + imageElement);
|
|
||||||
pdoc.addImage(imageElement, lMargin, yPos);
|
|
||||||
console.log('Image Height: ' + imageElement.height);
|
|
||||||
yPos += (imageElement.height * 0.26458333);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
console.log('Result Type unknow: ' + i);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
console.log('Result Type is undefined:' + i);
|
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
html : correlationParametersInputKPIs
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
//head : null,
|
||||||
|
// body : [
|
||||||
|
// [ 'Parameters',
|
||||||
|
// correlationParametersInputKPIs ]
|
||||||
|
// ]
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text("CORRELATION Matrix:", xPos, yPos, 'left');
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
yPos += 4;
|
||||||
|
|
||||||
|
console.log('OutputNumber: ' + outputNumber);
|
||||||
|
|
||||||
|
for (var i = 1; i <= outputNumber; i++) {
|
||||||
|
|
||||||
|
var outputId = 'OutputId_' + requestId + '_' + i;
|
||||||
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
|
var resultElement = $doc.getElementById(outputId);
|
||||||
|
|
||||||
|
console.log('Result Element: ' + resultElement);
|
||||||
|
var resultType = resultElement.className;
|
||||||
|
|
||||||
|
console.log('Result Element className: ' + resultType);
|
||||||
|
|
||||||
|
if (typeof resultType !== 'undefined' && resultType !== null
|
||||||
|
&& resultType !== '') {
|
||||||
|
|
||||||
|
if (resultType == 'fixedtable' || resultType == 'simpletable') {
|
||||||
|
console.log('Result Type csv: ' + i);
|
||||||
|
console.log('Result Content: ' + resultElement.innerHTML);
|
||||||
|
|
||||||
|
var checkColor = function(data) {
|
||||||
|
if (data.section === 'body') {
|
||||||
|
console.log(data);
|
||||||
|
if (typeof data.cell !== 'undefined'
|
||||||
|
&& data.cell !== null) {
|
||||||
|
if (typeof data.cell.raw !== 'undefined'
|
||||||
|
&& data.cell.raw !== null) {
|
||||||
|
console.log(data.cell.raw.innerHTML);
|
||||||
|
var positive = 'rgb(255, 68, 45)';
|
||||||
|
var negative = 'rgb(173, 216, 230)';
|
||||||
|
var nonsignificant = 'rgb(230, 223, 0)';
|
||||||
|
|
||||||
|
if (data.cell.raw.innerHTML
|
||||||
|
.indexOf(positive) >= 0) {
|
||||||
|
data.cell.styles.fillColor = [ 255, 68,
|
||||||
|
45 ];
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML
|
||||||
|
.indexOf(negative) >= 0) {
|
||||||
|
data.cell.styles.fillColor = [ 173,
|
||||||
|
216, 230 ];
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML
|
||||||
|
.indexOf(nonsignificant) >= 0) {
|
||||||
|
data.cell.styles.fillColor = [
|
||||||
|
230, 223, 0 ];
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
pdoc.autoTable({
|
||||||
|
theme : 'grid',
|
||||||
|
startY : yPos,
|
||||||
|
pageBreak : 'auto',
|
||||||
|
bodyStyles : {
|
||||||
|
fontSize : 9
|
||||||
|
},
|
||||||
|
didParseCell : checkColor,
|
||||||
|
html : resultElement
|
||||||
|
});
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
} else {
|
||||||
|
if (resultType == 'image') {
|
||||||
|
console.log('Result Type image: ' + i);
|
||||||
|
var childrenTable = outputNumber.children;
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var imageElement = secondDiv
|
||||||
|
.getElementsByTagName('img').item(0);
|
||||||
|
console.log('Image element: ' + imageElement);
|
||||||
|
pdoc.addImage(imageElement, lMargin, yPos);
|
||||||
|
console.log('Image Height: ' + imageElement.height);
|
||||||
|
yPos += (imageElement.height * 0.26458333);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
console.log('Result Type unknow: ' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Result Type is undefined:' + i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 7) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var focusIDElement = $doc
|
||||||
|
.getElementById('field_list_focus_id_correlation');
|
||||||
|
console.log('FocusID Element: ' + focusIDElement);
|
||||||
|
var selectedIndex = focusIDElement.selectedIndex;
|
||||||
|
if (selectedIndex > -1) {
|
||||||
|
var value = focusIDElement[selectedIndex].innerText;
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
pdoc.text("Focus ID: "+value, xPos, yPos, 'left');
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
yPos += 4;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages = pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/" + numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
console.log('Done');
|
console.log('Done');
|
||||||
|
|
||||||
pdoc.save(filename);
|
pdoc.save(filename);
|
|
@ -0,0 +1,548 @@
|
||||||
|
package org.gcube.portlets.user.performfishanalytics.client.viewannualbinder;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.DataMinerInputParameters;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.PerformFishAnnualAnalyticsViewController;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.ShowResult;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.SubmitRequestPanel;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.dataminer.DataMinerResponse;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.performfishservice.PerformFishResponse;
|
||||||
|
|
||||||
|
import com.github.gwtbootstrap.client.ui.Alert;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Button;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Tab;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.IconType;
|
||||||
|
import com.google.gwt.core.client.Scheduler;
|
||||||
|
import com.google.gwt.core.shared.GWT;
|
||||||
|
import com.google.gwt.dom.client.Style.Unit;
|
||||||
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
|
import com.google.gwt.resources.client.TextResource;
|
||||||
|
import com.google.gwt.user.client.Window;
|
||||||
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
|
import com.google.gwt.user.client.ui.ComplexPanel;
|
||||||
|
import com.google.gwt.user.client.ui.HTML;
|
||||||
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Panel;
|
||||||
|
|
||||||
|
public class ScatterAnnualPanelResult {
|
||||||
|
|
||||||
|
private PerformFishAnnualAnalyticsViewController viewAnnualController;
|
||||||
|
private int requestId;
|
||||||
|
private int outputIteration = 1;
|
||||||
|
private int outputNumber = 1;
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
|
public ScatterAnnualPanelResult(int reqId, PerformFishAnnualAnalyticsViewController viewAnnualController,
|
||||||
|
PerformFishResponse thePerformFishResponse, final DataMinerAlgorithms algorithm, String focusID,
|
||||||
|
List<KPI> inputKPI, final List<KPI> outputKPI) {
|
||||||
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
|
this.viewAnnualController = viewAnnualController;
|
||||||
|
TextResource algDescr = PerformFishResources.INSTANCE.farm_SCATTER();
|
||||||
|
String algDesrTxt = algDescr != null ? algDescr.getText() : null;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
final String tabTitle = algorithm.getTitle();
|
||||||
|
final String tabDescr = algDesrTxt;
|
||||||
|
|
||||||
|
final SubmitRequestPanel submitRequestPanel = new SubmitRequestPanel("", 1);
|
||||||
|
|
||||||
|
Tab tab = viewAnnualController.createTab(tabTitle + " #" + (viewAnnualController.currentNumberOfTab() + 1),
|
||||||
|
algDesrTxt, submitRequestPanel);
|
||||||
|
|
||||||
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
|
savePDFButton = new Button();
|
||||||
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId, outputIteration, outputNumber);
|
||||||
|
// dmResponse.getListOutput().size()
|
||||||
|
}
|
||||||
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
|
res.add(savePDFButton);
|
||||||
|
submitRequestPanel.addWidget(res);
|
||||||
|
|
||||||
|
if (inputKPI.get(0) == null || inputKPI.get(1) == null) {
|
||||||
|
submitRequestPanel
|
||||||
|
.setTheTitle("Sorry, something seems wrong, the selected KPIs are not valid. Please try again");
|
||||||
|
checkTabSpinner(submitRequestPanel, tab);
|
||||||
|
return;
|
||||||
|
// Window.alert("Something seems wrong, no selected BatchID, try
|
||||||
|
// again");
|
||||||
|
}
|
||||||
|
|
||||||
|
String title = "KPI: " + inputKPI.get(0).getName() + " vs " + inputKPI.get(1).getName();
|
||||||
|
|
||||||
|
HTML toBigTitle = new HTML(title);
|
||||||
|
toBigTitle.getElement().setId("KPI_ScatterAnnual_" + requestId + "_" + outputIteration);
|
||||||
|
toBigTitle.getElement().addClassName("to-big-title");
|
||||||
|
submitRequestPanel.addWidget(toBigTitle);
|
||||||
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
|
hp.getElement().addClassName("ext-horizontal-panel");
|
||||||
|
|
||||||
|
DataMinerInputParameters dmInputParams = new DataMinerInputParameters(thePerformFishResponse,
|
||||||
|
viewAnnualController.getSelectedYears(), inputKPI, outputKPI, algorithm, focusID);
|
||||||
|
callDataMinerServiceForChart(dmInputParams, submitRequestPanel, hp, tab, outputIteration);
|
||||||
|
submitRequestPanel.addWidget(hp);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Call data miner service for chart.
|
||||||
|
*
|
||||||
|
* @param dmInputParameters
|
||||||
|
* the dm input parameters
|
||||||
|
* @param requestPanel
|
||||||
|
* the request panel
|
||||||
|
* @param panelContainer
|
||||||
|
* the panel
|
||||||
|
* @param tab
|
||||||
|
* the tab
|
||||||
|
* @param tabDescr
|
||||||
|
* @param tabTitle
|
||||||
|
*/
|
||||||
|
private void callDataMinerServiceForChart(final DataMinerInputParameters dmInputParameters,
|
||||||
|
final SubmitRequestPanel requestPanel, final ComplexPanel panelContainer, final Tab tab,
|
||||||
|
final int oIteration) {
|
||||||
|
|
||||||
|
GWT.log("Building DM request with input parameters: " + dmInputParameters);
|
||||||
|
|
||||||
|
StringBuilder dataInputsFormatter = new StringBuilder();
|
||||||
|
dataInputsFormatter
|
||||||
|
.append(PerformFishAnalyticsConstant.DM_CHARTTYPE_PARAM + "=" + dmInputParameters.getChartType() + ";");
|
||||||
|
|
||||||
|
String yearsValue = "";
|
||||||
|
for (String year : dmInputParameters.getSelectedYears()) {
|
||||||
|
yearsValue += year + "|";
|
||||||
|
}
|
||||||
|
yearsValue = yearsValue.substring(0, yearsValue.length() - 1);
|
||||||
|
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_YEARS_PARAM + "=" + yearsValue + ";");
|
||||||
|
dataInputsFormatter
|
||||||
|
.append(PerformFishAnalyticsConstant.DM_FOCUS_PARAM + "=" + dmInputParameters.getFocusID() + ";");
|
||||||
|
// dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_FOCUS_PARAM+"=ID;");
|
||||||
|
|
||||||
|
if (dmInputParameters.getInputKPI() != null && dmInputParameters.getInputKPI().size() > 0) {
|
||||||
|
String kpiCodes = "";
|
||||||
|
for (KPI kpi : dmInputParameters.getInputKPI()) {
|
||||||
|
kpiCodes += kpi.getCode() + "|";
|
||||||
|
}
|
||||||
|
// remove last |
|
||||||
|
kpiCodes = kpiCodes.substring(0, kpiCodes.length() - 1);
|
||||||
|
|
||||||
|
GWT.log("Input KPICodes: " + kpiCodes);
|
||||||
|
// ADDING KPIs code
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_INPUT_KPI_PARAM + "=" + kpiCodes + ";");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dmInputParameters.getOutputKPI() != null && dmInputParameters.getOutputKPI().size() > 0) {
|
||||||
|
String kpiCodes = "";
|
||||||
|
for (KPI kpi : dmInputParameters.getOutputKPI()) {
|
||||||
|
kpiCodes += kpi.getCode() + "|";
|
||||||
|
}
|
||||||
|
// remove last |
|
||||||
|
kpiCodes = kpiCodes.substring(0, kpiCodes.length() - 1);
|
||||||
|
|
||||||
|
GWT.log("Output KPICodes: " + kpiCodes);
|
||||||
|
// ADDING KPIs code
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_OUTPUT_KPI_PARAM + "=" + kpiCodes + ";");
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, String> performFishResponseMap = dmInputParameters.getPerformFishResponse().getMapParameters();
|
||||||
|
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.LethalIncidentsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AnnualTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntibioticsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntiparasiticTable);
|
||||||
|
|
||||||
|
String dataInParameters = dataInputsFormatter.toString();
|
||||||
|
GWT.log("Calling DM service with client input parameters: " + dataInParameters);
|
||||||
|
|
||||||
|
Map<String, List<String>> mapParameters = new HashMap<String, List<String>>();
|
||||||
|
mapParameters.put(PerformFishAnalyticsConstant.DATA_INPUTS, Arrays.asList(dataInParameters));
|
||||||
|
|
||||||
|
final LoaderIcon loaderIcon = new LoaderIcon(
|
||||||
|
"Submitting request to " + dmInputParameters.getChartType().getTitle() + " Analysis...");
|
||||||
|
loaderIcon.setVisible(true);
|
||||||
|
panelContainer.setVisible(true);
|
||||||
|
panelContainer.add(loaderIcon);
|
||||||
|
Scheduler.get().scheduleDeferred(new Scheduler.ScheduledCommand() {
|
||||||
|
@Override
|
||||||
|
public void execute() {
|
||||||
|
loaderIcon.setFocus(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().callingDataMinerPerformFishAnnualAnalysis(mapParameters,
|
||||||
|
new AsyncCallback<DataMinerResponse>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(DataMinerResponse dmResponse) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(requestPanel, tab);
|
||||||
|
// field_unary_algorithm.setVisible(true);
|
||||||
|
GWT.log("I'm displaying: " + dmResponse);
|
||||||
|
displayOutputFilesAsStaticEntities(dmResponse, dmInputParameters.getChartType(),
|
||||||
|
dmInputParameters.getInputKPI(), dmInputParameters.getOutputKPI(),
|
||||||
|
dmInputParameters.getFocusID(), panelContainer, false, oIteration);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(requestPanel, tab);
|
||||||
|
displayOutputFilesAsStaticEntities(null, dmInputParameters.getChartType(),
|
||||||
|
dmInputParameters.getInputKPI(), dmInputParameters.getOutputKPI(),
|
||||||
|
dmInputParameters.getFocusID(), panelContainer, true, oIteration);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append DM input table.
|
||||||
|
*
|
||||||
|
* @param performFishResponseMap
|
||||||
|
* the perform fish response map
|
||||||
|
* @param dataInputsFormatter
|
||||||
|
* the data inputs formatter
|
||||||
|
* @param table
|
||||||
|
* the table
|
||||||
|
* @return the string builder
|
||||||
|
*/
|
||||||
|
private StringBuilder appendDMInputTable(Map<String, String> performFishResponseMap,
|
||||||
|
StringBuilder dataInputsFormatter, PFSERVICE_TO_DM_MAPPING_TABLE table) {
|
||||||
|
|
||||||
|
String toDMInputTable = performFishResponseMap.get(table.getPerformFishTable());
|
||||||
|
|
||||||
|
if (toDMInputTable != null && !toDMInputTable.isEmpty()) {
|
||||||
|
dataInputsFormatter.append(table.getDataMinerTable() + "=" + toDMInputTable + ";");
|
||||||
|
}
|
||||||
|
|
||||||
|
return dataInputsFormatter;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, String title) {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
return outputId;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
if (displayError) {
|
||||||
|
Alert alert = new Alert(title);
|
||||||
|
alert.setType(AlertType.ERROR);
|
||||||
|
alert.setClose(false);
|
||||||
|
alert.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
container.add(alert);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(true);
|
||||||
|
|
||||||
|
final String toTitle = title;
|
||||||
|
|
||||||
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
|
||||||
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
|
|
||||||
|
switch (outputFile.getDataType()) {
|
||||||
|
case IMAGE:
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getImageFile(outputFile,
|
||||||
|
new AsyncCallback<String>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(String base64Content) {
|
||||||
|
String title = toTitle;
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showImage(base64Content);
|
||||||
|
container.add(showResult);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case CSV:
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true,
|
||||||
|
new AsyncCallback<CSVFile>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(CSVFile result) {
|
||||||
|
GWT.log("Displaying: " + result);
|
||||||
|
|
||||||
|
String cssTableStyle = "simpletable";
|
||||||
|
|
||||||
|
String title = toTitle;
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
|
container.add(showResult);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the spinner if all DM responses are returned.
|
||||||
|
*
|
||||||
|
* @param requestPanel
|
||||||
|
* the request panel
|
||||||
|
* @param tab
|
||||||
|
* the tab
|
||||||
|
*/
|
||||||
|
private void checkTabSpinner(SubmitRequestPanel requestPanel, Tab tab) {
|
||||||
|
requestPanel.incrementCompletedRequests();
|
||||||
|
int completed = requestPanel.getCompletedRequests();
|
||||||
|
int total = requestPanel.getTotalRequests();
|
||||||
|
|
||||||
|
if (completed >= total) {
|
||||||
|
viewAnnualController.noSpinner(tab);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static native void saveFilePDF(String chartType, String filename, String tabTitle, String tabDescr,
|
||||||
|
int requestId, int outputIteration, int outputNumber)/*-{
|
||||||
|
var that = this;
|
||||||
|
console.log('saveFilePDF()');
|
||||||
|
console.log('requestId: ' + requestId);
|
||||||
|
console.log('OutputIteration: ' + outputIteration);
|
||||||
|
console.log('OutputNumber:' + outputNumber);
|
||||||
|
|
||||||
|
var tTitle = tabTitle;
|
||||||
|
var tDescr = tabDescr;
|
||||||
|
|
||||||
|
var pdoc = new jsPDF("p", "mm", "a4");
|
||||||
|
pdoc.setProperties({
|
||||||
|
title : 'PerformFish ' + tTitle,
|
||||||
|
subject : ' Results',
|
||||||
|
author : 'PerformFish',
|
||||||
|
keywords : 'PerformFish',
|
||||||
|
creator : 'D4Science'
|
||||||
|
});
|
||||||
|
|
||||||
|
var lMargin = 15; //left margin in mm
|
||||||
|
var rMargin = 15; //right margin in mm
|
||||||
|
var tMargin = 15; //top margin in mm
|
||||||
|
var bMargin = 15; //bottom margin in mm
|
||||||
|
var pdfWidthInMM = 210; // width of A4 in mm
|
||||||
|
var pdfHeightInMM = 297; // height of A4 in mm
|
||||||
|
var pageCenter = pdfWidthInMM / 2;
|
||||||
|
|
||||||
|
pdoc.setFontSize(24);
|
||||||
|
var title = "PerformFish " + tTitle;
|
||||||
|
var titleHeight = pdoc.getLineHeight(title) / pdoc.internal.scaleFactor;
|
||||||
|
var xPos = lMargin;
|
||||||
|
var yPos = tMargin;
|
||||||
|
pdoc.text(title, pageCenter, yPos, 'center');
|
||||||
|
yPos += titleHeight;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
var lineHeight = pdoc.getLineHeight(tDescr) / pdoc.internal.scaleFactor;
|
||||||
|
var splittedAnalysisDescription = pdoc.splitTextToSize(tDescr,
|
||||||
|
(pdfWidthInMM - lMargin - rMargin));
|
||||||
|
var lines = splittedAnalysisDescription.length;// splitted text is a string array
|
||||||
|
var analysisDescriptionHeight = lines * lineHeight;
|
||||||
|
|
||||||
|
pdoc.text(splittedAnalysisDescription, xPos, yPos, 'left');
|
||||||
|
yPos += analysisDescriptionHeight;
|
||||||
|
|
||||||
|
//yPos += 2;
|
||||||
|
//pdoc.text("Analysis:", xPos, yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
|
var kpiId = 'KPI_ScatterAnnual_' + requestId + '_' + i;
|
||||||
|
console.log('kpiId: ' + kpiId);
|
||||||
|
|
||||||
|
var kpiName = $doc.getElementById(kpiId);
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(14);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
|
||||||
|
var kpiText = kpiName.textContent;
|
||||||
|
var kpiHeight = pdoc.getLineHeight(kpiText)
|
||||||
|
/ pdoc.internal.scaleFactor;
|
||||||
|
var splittedKpiName = pdoc.splitTextToSize(kpiText, (pdfWidthInMM
|
||||||
|
- lMargin - rMargin));
|
||||||
|
var kpiLines = splittedKpiName.length; // splitted text is a string array
|
||||||
|
var kpiLinesHeight = kpiLines * kpiHeight;
|
||||||
|
pdoc.text(splittedKpiName, xPos, yPos, 'left');
|
||||||
|
yPos += kpiLinesHeight;
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
|
var outputId = 'OutputId_' + requestId + '_' + i + '_' + j;
|
||||||
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
|
var resultOutputNumber = $doc.getElementById(outputId);
|
||||||
|
|
||||||
|
console.log('OutputId_: ' + resultOutputNumber.innerHTML);
|
||||||
|
var resultType = resultOutputNumber.className;
|
||||||
|
|
||||||
|
console.log('resultOutputNumber className: ' + resultType);
|
||||||
|
|
||||||
|
if (typeof resultType !== 'undefined' && resultType !== null
|
||||||
|
&& resultType !== '') {
|
||||||
|
|
||||||
|
if (resultType == 'csv') {
|
||||||
|
console.log('Result Type csv: ' + i);
|
||||||
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
|
console.log('CSV SecondTable: ' + secondTable);
|
||||||
|
|
||||||
|
pdoc.autoTable({
|
||||||
|
theme : 'grid',
|
||||||
|
startY : yPos,
|
||||||
|
pageBreak : 'auto',
|
||||||
|
bodyStyles : {
|
||||||
|
fontSize : 9
|
||||||
|
},
|
||||||
|
html : secondTable
|
||||||
|
});
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
} else {
|
||||||
|
if (resultType == 'image') {
|
||||||
|
console.log('Result Type image: ' + i);
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
|
'img').item(0);
|
||||||
|
console.log('Image element: ' + imageElement);
|
||||||
|
pdoc.addImage(imageElement, lMargin, yPos);
|
||||||
|
console.log('Image Height: ' + imageElement.height);
|
||||||
|
yPos += (imageElement.height * 0.26458333);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
console.log('Result Type unknow: ' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Result Type is undefined:' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 4) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages=pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/"+numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Done');
|
||||||
|
|
||||||
|
pdoc.save(filename);
|
||||||
|
|
||||||
|
}-*/;
|
||||||
|
}
|
|
@ -0,0 +1,578 @@
|
||||||
|
package org.gcube.portlets.user.performfishanalytics.client.viewannualbinder;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.DataMinerInputParameters;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.PerformFishAnnualAnalyticsViewController;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.ShowResult;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.SubmitRequestPanel;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.dataminer.DataMinerResponse;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.performfishservice.PerformFishResponse;
|
||||||
|
|
||||||
|
import com.github.gwtbootstrap.client.ui.Alert;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Button;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Tab;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.IconType;
|
||||||
|
import com.google.gwt.core.client.Scheduler;
|
||||||
|
import com.google.gwt.core.shared.GWT;
|
||||||
|
import com.google.gwt.dom.client.Style.Unit;
|
||||||
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
|
import com.google.gwt.resources.client.TextResource;
|
||||||
|
import com.google.gwt.user.client.Window;
|
||||||
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
|
import com.google.gwt.user.client.ui.ComplexPanel;
|
||||||
|
import com.google.gwt.user.client.ui.FlexTable;
|
||||||
|
import com.google.gwt.user.client.ui.HTML;
|
||||||
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Panel;
|
||||||
|
|
||||||
|
public class SpeedometerAnnualPanelResult {
|
||||||
|
|
||||||
|
private Map<Integer, FlexTable> boxPlotOrderBy = new HashMap<Integer, FlexTable>();
|
||||||
|
|
||||||
|
private PerformFishAnnualAnalyticsViewController viewAnnualController;
|
||||||
|
private int requestId = 0;
|
||||||
|
private int outputIteration = 0;
|
||||||
|
private int outputNumber = 1;
|
||||||
|
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
|
public SpeedometerAnnualPanelResult(int reqId, PerformFishAnnualAnalyticsViewController viewAnnualController,
|
||||||
|
PerformFishResponse thePerformFishResponse, final DataMinerAlgorithms algorithm, String focusID,
|
||||||
|
List<KPI> inputKPI, final List<KPI> outputKPI) {
|
||||||
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
|
this.viewAnnualController = viewAnnualController;
|
||||||
|
TextResource algDescr = PerformFishResources.INSTANCE.farm_SPEEDOMETER();
|
||||||
|
|
||||||
|
String algDesrTxt = algDescr != null ? algDescr.getText() : null;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
final String tabTitle = algorithm.getTitle();
|
||||||
|
final String tabDescr = algDesrTxt;
|
||||||
|
|
||||||
|
final SubmitRequestPanel submitRequestPanel = new SubmitRequestPanel("", 1);
|
||||||
|
Tab tab = viewAnnualController.createTab(tabTitle + " #" + (viewAnnualController.currentNumberOfTab() + 1),
|
||||||
|
algDesrTxt, submitRequestPanel);
|
||||||
|
|
||||||
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
|
savePDFButton = new Button();
|
||||||
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId, outputIteration, outputNumber);
|
||||||
|
// dmResponse.getListOutput().size()
|
||||||
|
}
|
||||||
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
|
res.add(savePDFButton);
|
||||||
|
submitRequestPanel.addWidget(res);
|
||||||
|
int oIteration = 0;
|
||||||
|
|
||||||
|
submitRequestPanel.setTotalRequests(inputKPI.size());
|
||||||
|
for (KPI kpi : inputKPI) {
|
||||||
|
oIteration++;
|
||||||
|
String title = "KPI: " + kpi.getName();
|
||||||
|
HTML toBigTitle = new HTML(title);
|
||||||
|
toBigTitle.getElement().setId("KPI_SpeedometerAnnual_" + requestId + "_" + oIteration);
|
||||||
|
toBigTitle.getElement().addClassName("to-big-title");
|
||||||
|
submitRequestPanel.addWidget(toBigTitle);
|
||||||
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
|
hp.getElement().addClassName("ext-horizontal-panel");
|
||||||
|
|
||||||
|
DataMinerInputParameters dmInputParams = new DataMinerInputParameters(thePerformFishResponse,
|
||||||
|
viewAnnualController.getSelectedYears(), Arrays.asList(kpi), null, algorithm, focusID);
|
||||||
|
callDataMinerServiceForChart(dmInputParams, submitRequestPanel, hp, tab, oIteration);
|
||||||
|
// resultPanel.add(hp);
|
||||||
|
submitRequestPanel.addWidget(hp);
|
||||||
|
}
|
||||||
|
outputIteration = oIteration;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Call data miner service for chart.
|
||||||
|
*
|
||||||
|
* @param dmInputParameters
|
||||||
|
* the dm input parameters
|
||||||
|
* @param requestPanel
|
||||||
|
* the request panel
|
||||||
|
* @param panelContainer
|
||||||
|
* the panel
|
||||||
|
* @param tab
|
||||||
|
* the tab
|
||||||
|
* @param tabDescr
|
||||||
|
* @param tabTitle
|
||||||
|
*/
|
||||||
|
private void callDataMinerServiceForChart(final DataMinerInputParameters dmInputParameters,
|
||||||
|
final SubmitRequestPanel requestPanel, final ComplexPanel panelContainer, final Tab tab,
|
||||||
|
final int oIteration) {
|
||||||
|
|
||||||
|
GWT.log("Building DM request with input parameters: " + dmInputParameters);
|
||||||
|
|
||||||
|
StringBuilder dataInputsFormatter = new StringBuilder();
|
||||||
|
dataInputsFormatter
|
||||||
|
.append(PerformFishAnalyticsConstant.DM_CHARTTYPE_PARAM + "=" + dmInputParameters.getChartType() + ";");
|
||||||
|
|
||||||
|
String yearsValue = "";
|
||||||
|
for (String year : dmInputParameters.getSelectedYears()) {
|
||||||
|
yearsValue += year + "|";
|
||||||
|
}
|
||||||
|
yearsValue = yearsValue.substring(0, yearsValue.length() - 1);
|
||||||
|
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_YEARS_PARAM + "=" + yearsValue + ";");
|
||||||
|
dataInputsFormatter
|
||||||
|
.append(PerformFishAnalyticsConstant.DM_FOCUS_PARAM + "=" + dmInputParameters.getFocusID() + ";");
|
||||||
|
// dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_FOCUS_PARAM+"=ID;");
|
||||||
|
|
||||||
|
if (dmInputParameters.getInputKPI() != null && dmInputParameters.getInputKPI().size() > 0) {
|
||||||
|
String kpiCodes = "";
|
||||||
|
for (KPI kpi : dmInputParameters.getInputKPI()) {
|
||||||
|
kpiCodes += kpi.getCode() + "|";
|
||||||
|
}
|
||||||
|
// remove last |
|
||||||
|
kpiCodes = kpiCodes.substring(0, kpiCodes.length() - 1);
|
||||||
|
|
||||||
|
GWT.log("Input KPICodes: " + kpiCodes);
|
||||||
|
// ADDING KPIs code
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_INPUT_KPI_PARAM + "=" + kpiCodes + ";");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dmInputParameters.getOutputKPI() != null && dmInputParameters.getOutputKPI().size() > 0) {
|
||||||
|
String kpiCodes = "";
|
||||||
|
for (KPI kpi : dmInputParameters.getOutputKPI()) {
|
||||||
|
kpiCodes += kpi.getCode() + "|";
|
||||||
|
}
|
||||||
|
// remove last |
|
||||||
|
kpiCodes = kpiCodes.substring(0, kpiCodes.length() - 1);
|
||||||
|
|
||||||
|
GWT.log("Output KPICodes: " + kpiCodes);
|
||||||
|
// ADDING KPIs code
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_OUTPUT_KPI_PARAM + "=" + kpiCodes + ";");
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, String> performFishResponseMap = dmInputParameters.getPerformFishResponse().getMapParameters();
|
||||||
|
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.LethalIncidentsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AnnualTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntibioticsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntiparasiticTable);
|
||||||
|
|
||||||
|
String dataInParameters = dataInputsFormatter.toString();
|
||||||
|
GWT.log("Calling DM service with client input parameters: " + dataInParameters);
|
||||||
|
|
||||||
|
Map<String, List<String>> mapParameters = new HashMap<String, List<String>>();
|
||||||
|
mapParameters.put(PerformFishAnalyticsConstant.DATA_INPUTS, Arrays.asList(dataInParameters));
|
||||||
|
|
||||||
|
final LoaderIcon loaderIcon = new LoaderIcon(
|
||||||
|
"Submitting request to " + dmInputParameters.getChartType().getTitle() + " Analysis...");
|
||||||
|
loaderIcon.setVisible(true);
|
||||||
|
panelContainer.setVisible(true);
|
||||||
|
panelContainer.add(loaderIcon);
|
||||||
|
Scheduler.get().scheduleDeferred(new Scheduler.ScheduledCommand() {
|
||||||
|
@Override
|
||||||
|
public void execute() {
|
||||||
|
loaderIcon.setFocus(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().callingDataMinerPerformFishAnnualAnalysis(mapParameters,
|
||||||
|
new AsyncCallback<DataMinerResponse>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(DataMinerResponse dmResponse) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(requestPanel, tab);
|
||||||
|
// field_unary_algorithm.setVisible(true);
|
||||||
|
GWT.log("I'm displaying: " + dmResponse);
|
||||||
|
displayOutputFilesAsStaticEntities(dmResponse, dmInputParameters.getChartType(),
|
||||||
|
dmInputParameters.getInputKPI(), dmInputParameters.getOutputKPI(),
|
||||||
|
dmInputParameters.getFocusID(), panelContainer, false, oIteration);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(requestPanel, tab);
|
||||||
|
displayOutputFilesAsStaticEntities(null, dmInputParameters.getChartType(),
|
||||||
|
dmInputParameters.getInputKPI(), dmInputParameters.getOutputKPI(),
|
||||||
|
dmInputParameters.getFocusID(), panelContainer, true, oIteration);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append DM input table.
|
||||||
|
*
|
||||||
|
* @param performFishResponseMap
|
||||||
|
* the perform fish response map
|
||||||
|
* @param dataInputsFormatter
|
||||||
|
* the data inputs formatter
|
||||||
|
* @param table
|
||||||
|
* the table
|
||||||
|
* @return the string builder
|
||||||
|
*/
|
||||||
|
private StringBuilder appendDMInputTable(Map<String, String> performFishResponseMap,
|
||||||
|
StringBuilder dataInputsFormatter, PFSERVICE_TO_DM_MAPPING_TABLE table) {
|
||||||
|
|
||||||
|
String toDMInputTable = performFishResponseMap.get(table.getPerformFishTable());
|
||||||
|
|
||||||
|
if (toDMInputTable != null && !toDMInputTable.isEmpty()) {
|
||||||
|
dataInputsFormatter.append(table.getDataMinerTable() + "=" + toDMInputTable + ";");
|
||||||
|
}
|
||||||
|
|
||||||
|
return dataInputsFormatter;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, String title) {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
return outputId;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
if (displayError) {
|
||||||
|
Alert alert = new Alert(title);
|
||||||
|
alert.setType(AlertType.ERROR);
|
||||||
|
alert.setClose(false);
|
||||||
|
alert.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
container.add(alert);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(true);
|
||||||
|
|
||||||
|
final String toTitle = title;
|
||||||
|
|
||||||
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
|
|
||||||
|
switch (outputFile.getDataType()) {
|
||||||
|
case IMAGE:
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getImageFile(outputFile,
|
||||||
|
new AsyncCallback<String>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(String base64Content) {
|
||||||
|
|
||||||
|
String title = toTitle;
|
||||||
|
|
||||||
|
title = chartType.getTitle() + "<br>";
|
||||||
|
title += "Selected Farm: " + focusID + "<br>";
|
||||||
|
title += "Normalized with respect to all farm data in the VRE";
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showImage(base64Content);
|
||||||
|
container.add(showResult);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case CSV:
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true,
|
||||||
|
new AsyncCallback<CSVFile>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(CSVFile result) {
|
||||||
|
GWT.log("Displaying: " + result);
|
||||||
|
|
||||||
|
String cssTableStyle = "simpletable";
|
||||||
|
|
||||||
|
String title = toTitle;
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
|
container.add(showResult);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayingOrderedBoxPlot(final DataMinerResponse dmResponse, String title, final Panel container,
|
||||||
|
ShowResult showResult) {
|
||||||
|
int hashcode = dmResponse.hashCode();
|
||||||
|
GWT.log("The hascode is: " + hashcode);
|
||||||
|
FlexTable flex = boxPlotOrderBy.get(hashcode);
|
||||||
|
|
||||||
|
if (flex == null) {
|
||||||
|
GWT.log("The flextable is null");
|
||||||
|
flex = new FlexTable();
|
||||||
|
boxPlotOrderBy.put(hashcode, flex);
|
||||||
|
container.add(flex);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (title.startsWith("My")) {
|
||||||
|
flex.setWidget(0, 0, showResult);
|
||||||
|
} else if (title.startsWith("All")) {
|
||||||
|
flex.setWidget(0, 1, showResult);
|
||||||
|
} else {
|
||||||
|
flex.setWidget(0, 2, showResult);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the spinner if all DM responses are returned.
|
||||||
|
*
|
||||||
|
* @param requestPanel
|
||||||
|
* the request panel
|
||||||
|
* @param tab
|
||||||
|
* the tab
|
||||||
|
*/
|
||||||
|
private void checkTabSpinner(SubmitRequestPanel requestPanel, Tab tab) {
|
||||||
|
requestPanel.incrementCompletedRequests();
|
||||||
|
int completed = requestPanel.getCompletedRequests();
|
||||||
|
int total = requestPanel.getTotalRequests();
|
||||||
|
|
||||||
|
if (completed >= total) {
|
||||||
|
viewAnnualController.noSpinner(tab);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static native void saveFilePDF(String chartType, String filename, String tabTitle, String tabDescr,
|
||||||
|
int requestId, int outputIteration, int outputNumber)/*-{
|
||||||
|
var that = this;
|
||||||
|
console.log('saveFilePDF()');
|
||||||
|
console.log('requestId: ' + requestId);
|
||||||
|
console.log('OutputIteration: ' + outputIteration);
|
||||||
|
console.log('OutputNumber:' + outputNumber);
|
||||||
|
|
||||||
|
var tTitle = tabTitle;
|
||||||
|
var tDescr = tabDescr;
|
||||||
|
|
||||||
|
var pdoc = new jsPDF("p", "mm", "a4");
|
||||||
|
pdoc.setProperties({
|
||||||
|
title : 'PerformFish ' + tTitle,
|
||||||
|
subject : ' Results',
|
||||||
|
author : 'PerformFish',
|
||||||
|
keywords : 'PerformFish',
|
||||||
|
creator : 'D4Science'
|
||||||
|
});
|
||||||
|
|
||||||
|
var lMargin = 15; //left margin in mm
|
||||||
|
var rMargin = 15; //right margin in mm
|
||||||
|
var tMargin = 15; //top margin in mm
|
||||||
|
var bMargin = 15; //bottom margin in mm
|
||||||
|
var pdfWidthInMM = 210; // width of A4 in mm
|
||||||
|
var pdfHeightInMM = 297; // height of A4 in mm
|
||||||
|
var pageCenter = pdfWidthInMM / 2;
|
||||||
|
|
||||||
|
pdoc.setFontSize(24);
|
||||||
|
var title = "PerformFish " + tTitle;
|
||||||
|
var titleHeight = pdoc.getLineHeight(title) / pdoc.internal.scaleFactor
|
||||||
|
var xPos = lMargin;
|
||||||
|
var yPos = tMargin;
|
||||||
|
pdoc.text(title, pageCenter, yPos, 'center');
|
||||||
|
yPos += titleHeight;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
var lineHeight = pdoc.getLineHeight(tDescr) / pdoc.internal.scaleFactor
|
||||||
|
var splittedAnalysisDescription = pdoc.splitTextToSize(tDescr,
|
||||||
|
(pdfWidthInMM - lMargin - rMargin));
|
||||||
|
var lines = splittedAnalysisDescription.length // splitted text is a string array
|
||||||
|
var analysisDescriptionHeight = lines * lineHeight
|
||||||
|
|
||||||
|
pdoc.text(splittedAnalysisDescription, xPos, yPos, 'left');
|
||||||
|
yPos += analysisDescriptionHeight;
|
||||||
|
|
||||||
|
//yPos += 2;
|
||||||
|
//pdoc.text("Analysis:", xPos, yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
|
var kpiId = 'KPI_SpeedometerAnnual_' + requestId + '_' + i;
|
||||||
|
console.log('kpiId: ' + kpiId);
|
||||||
|
|
||||||
|
var kpiName = $doc.getElementById(kpiId);
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(14);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
|
||||||
|
var kpiText = kpiName.textContent;
|
||||||
|
var kpiHeight = pdoc.getLineHeight(kpiText)
|
||||||
|
/ pdoc.internal.scaleFactor;
|
||||||
|
var splittedKpiName = pdoc.splitTextToSize(kpiText, (pdfWidthInMM
|
||||||
|
- lMargin - rMargin));
|
||||||
|
var kpiLines = splittedKpiName.length; // splitted text is a string array
|
||||||
|
var kpiLinesHeight = kpiLines * kpiHeight;
|
||||||
|
pdoc.text(splittedKpiName, xPos, yPos, 'left');
|
||||||
|
yPos += kpiLinesHeight;
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
|
||||||
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
|
var outputId = 'OutputId_' + requestId + '_' + i + '_' + j;
|
||||||
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
|
var resultOutputNumber = $doc.getElementById(outputId);
|
||||||
|
|
||||||
|
console.log('OutputId_: ' + resultOutputNumber.innerHTML);
|
||||||
|
var resultType = resultOutputNumber.className;
|
||||||
|
|
||||||
|
console.log('resultOutputNumber className: ' + resultType);
|
||||||
|
|
||||||
|
if (typeof resultType !== 'undefined' && resultType !== null
|
||||||
|
&& resultType !== '') {
|
||||||
|
|
||||||
|
if (resultType == 'csv') {
|
||||||
|
console.log('Result Type csv: ' + i);
|
||||||
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
|
console.log('CSV SecondTable: ' + secondTable);
|
||||||
|
|
||||||
|
pdoc.autoTable({
|
||||||
|
theme : 'grid',
|
||||||
|
startY : yPos,
|
||||||
|
pageBreak : 'auto',
|
||||||
|
bodyStyles : {
|
||||||
|
fontSize : 9
|
||||||
|
},
|
||||||
|
html : secondTable
|
||||||
|
});
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
} else {
|
||||||
|
if (resultType == 'image') {
|
||||||
|
console.log('Result Type image: ' + i);
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
|
'img').item(0);
|
||||||
|
console.log('Image element: ' + imageElement);
|
||||||
|
pdoc.addImage(imageElement, lMargin, yPos);
|
||||||
|
console.log('Image Height: ' + imageElement.height);
|
||||||
|
yPos += (imageElement.height * 0.26458333);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
console.log('Result Type unknow: ' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Result Type is undefined:' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 4) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages=pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/"+numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Done');
|
||||||
|
|
||||||
|
pdoc.save(filename);
|
||||||
|
|
||||||
|
}-*/;
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,561 @@
|
||||||
|
package org.gcube.portlets.user.performfishanalytics.client.viewannualbinder;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.annualcontrollers.PerformFishAnnualAnalyticsViewController;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.ShowResult;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.viewbinder.SubmitRequestPanel;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.dataminer.DataMinerResponse;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.performfishservice.PerformFishResponse;
|
||||||
|
|
||||||
|
import com.github.gwtbootstrap.client.ui.Alert;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Button;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Tab;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.IconType;
|
||||||
|
import com.google.gwt.core.client.Scheduler;
|
||||||
|
import com.google.gwt.core.shared.GWT;
|
||||||
|
import com.google.gwt.dom.client.Style.Unit;
|
||||||
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
|
import com.google.gwt.user.client.Window;
|
||||||
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
|
import com.google.gwt.user.client.ui.FlexTable;
|
||||||
|
import com.google.gwt.user.client.ui.HTMLPanel;
|
||||||
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Panel;
|
||||||
|
|
||||||
|
public class SynopticTableAnnualPanelResult {
|
||||||
|
|
||||||
|
private Map<Integer, FlexTable> synopticOrderBy = new HashMap<Integer, FlexTable>();
|
||||||
|
|
||||||
|
private PerformFishAnnualAnalyticsViewController viewAnnualController;
|
||||||
|
private int requestId;
|
||||||
|
private int outputIteration = 1;
|
||||||
|
private int outputNumber = 0;
|
||||||
|
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
|
public SynopticTableAnnualPanelResult(int reqId, PerformFishAnnualAnalyticsViewController viewAnnualController,
|
||||||
|
PerformFishResponse performFishResponse) {
|
||||||
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
|
this.viewAnnualController = viewAnnualController;
|
||||||
|
|
||||||
|
final DataMinerAlgorithms algorithm = DataMinerAlgorithms.PERFORMFISH_SYNOPTIC_TABLE_FARM;
|
||||||
|
final SubmitRequestPanel submitRequestPanel = new SubmitRequestPanel("", 1);
|
||||||
|
final String tabTitle = "Synoptic Table";
|
||||||
|
final String tabDescr = PerformFishResources.INSTANCE.synopticTable().getText();
|
||||||
|
final Tab tab = viewAnnualController.createTab(
|
||||||
|
tabTitle + " #" + (viewAnnualController.currentNumberOfTab() + 1), tabDescr, submitRequestPanel);
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
|
savePDFButton = new Button();
|
||||||
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId, outputIteration, outputNumber);
|
||||||
|
// dmResponse.getListOutput().size()
|
||||||
|
}
|
||||||
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
|
res.add(savePDFButton);
|
||||||
|
submitRequestPanel.addWidget(res);
|
||||||
|
|
||||||
|
StringBuilder dataInputsFormatter = new StringBuilder();
|
||||||
|
Map<String, String> performFishResponseMap = performFishResponse.getMapParameters();
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.LethalIncidentsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AnnualTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntibioticsTable);
|
||||||
|
dataInputsFormatter = appendDMInputTable(performFishResponseMap, dataInputsFormatter,
|
||||||
|
PerformFishAnalyticsConstant.PFSERVICE_TO_DM_MAPPING_TABLE.AntiparasiticTable);
|
||||||
|
|
||||||
|
String yearsValue = "";
|
||||||
|
for (String year : viewAnnualController.getSelectedYears()) {
|
||||||
|
yearsValue += year + "#";
|
||||||
|
}
|
||||||
|
yearsValue = yearsValue.substring(0, yearsValue.length() - 1);
|
||||||
|
|
||||||
|
dataInputsFormatter.append(PerformFishAnalyticsConstant.DM_ALLYEARS_PARAM + "=" + yearsValue + ";");
|
||||||
|
|
||||||
|
String dataInParameters = dataInputsFormatter.toString();
|
||||||
|
GWT.log("Calling DM service with client input parameters: " + dataInParameters);
|
||||||
|
|
||||||
|
Map<String, List<String>> mapParameters = new HashMap<String, List<String>>();
|
||||||
|
mapParameters.put(PerformFishAnalyticsConstant.DATA_INPUTS, Arrays.asList(dataInParameters));
|
||||||
|
|
||||||
|
final HTMLPanel panelContainer = submitRequestPanel.getContainerPanel();
|
||||||
|
final LoaderIcon loaderIcon = new LoaderIcon("Submitting request to " + algorithm.getTitle() + "...");
|
||||||
|
loaderIcon.setVisible(true);
|
||||||
|
panelContainer.setVisible(true);
|
||||||
|
panelContainer.add(loaderIcon);
|
||||||
|
Scheduler.get().scheduleDeferred(new Scheduler.ScheduledCommand() {
|
||||||
|
@Override
|
||||||
|
public void execute() {
|
||||||
|
loaderIcon.setFocus(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().callDMServiceToLoadSynopticAnnualTable(performFishResponse,
|
||||||
|
mapParameters, new AsyncCallback<DataMinerResponse>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(DataMinerResponse dmResponse) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(submitRequestPanel, tab);
|
||||||
|
// field_unary_algorithm.setVisible(true);
|
||||||
|
GWT.log("I'm displaying: " + dmResponse);
|
||||||
|
displayOutputFilesAsStaticEntities(dmResponse, algorithm, null, null, null, panelContainer,
|
||||||
|
false, outputIteration);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
loaderIcon.setVisible(false);
|
||||||
|
checkTabSpinner(submitRequestPanel, tab);
|
||||||
|
displayOutputFilesAsStaticEntities(null, algorithm, null, null, null, panelContainer, true,
|
||||||
|
outputIteration);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append DM input table.
|
||||||
|
*
|
||||||
|
* @param performFishResponseMap
|
||||||
|
* the perform fish response map
|
||||||
|
* @param dataInputsFormatter
|
||||||
|
* the data inputs formatter
|
||||||
|
* @param table
|
||||||
|
* the table
|
||||||
|
* @return the string builder
|
||||||
|
*/
|
||||||
|
private StringBuilder appendDMInputTable(Map<String, String> performFishResponseMap,
|
||||||
|
StringBuilder dataInputsFormatter, PFSERVICE_TO_DM_MAPPING_TABLE table) {
|
||||||
|
|
||||||
|
String toDMInputTable = performFishResponseMap.get(table.getPerformFishTable());
|
||||||
|
|
||||||
|
if (toDMInputTable != null && !toDMInputTable.isEmpty()) {
|
||||||
|
dataInputsFormatter.append(table.getDataMinerTable() + "=" + toDMInputTable + ";");
|
||||||
|
}
|
||||||
|
|
||||||
|
return dataInputsFormatter;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Remove the spinner if all DM responses are returned.
|
||||||
|
*
|
||||||
|
* @param requestPanel
|
||||||
|
* the request panel
|
||||||
|
* @param tab
|
||||||
|
* the tab
|
||||||
|
*/
|
||||||
|
private void checkTabSpinner(SubmitRequestPanel requestPanel, Tab tab) {
|
||||||
|
requestPanel.incrementCompletedRequests();
|
||||||
|
int completed = requestPanel.getCompletedRequests();
|
||||||
|
int total = requestPanel.getTotalRequests();
|
||||||
|
|
||||||
|
if (completed >= total) {
|
||||||
|
viewAnnualController.noSpinner(tab);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, boolean isLegend) {
|
||||||
|
String outputId;
|
||||||
|
if (isLegend) {
|
||||||
|
outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
} else {
|
||||||
|
outputNumber++;
|
||||||
|
outputId = "OutputId_" + requestId + "_" + oIteration + "_" + outputNumber;
|
||||||
|
}
|
||||||
|
return outputId;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
if (displayError) {
|
||||||
|
Alert alert = new Alert(title);
|
||||||
|
alert.setType(AlertType.ERROR);
|
||||||
|
alert.setClose(false);
|
||||||
|
alert.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
container.add(alert);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(true);
|
||||||
|
|
||||||
|
final String toTitle = title;
|
||||||
|
|
||||||
|
outputNumber = 1;
|
||||||
|
|
||||||
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
|
||||||
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
|
|
||||||
|
switch (outputFile.getDataType()) {
|
||||||
|
case IMAGE:
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getImageFile(outputFile,
|
||||||
|
new AsyncCallback<String>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(String base64Content) {
|
||||||
|
|
||||||
|
String title = toTitle;
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, false);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showImage(base64Content);
|
||||||
|
container.add(showResult);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case CSV:
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true,
|
||||||
|
new AsyncCallback<CSVFile>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
// showAlert(caught.getMessage(),
|
||||||
|
// AlertType.ERROR, true,
|
||||||
|
// uib_vp_deanalanlysis_request_container);
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(CSVFile result) {
|
||||||
|
GWT.log("Displaying: " + result);
|
||||||
|
|
||||||
|
String cssTableStyle = "simpletable";
|
||||||
|
|
||||||
|
String title = toTitle;
|
||||||
|
switch (chartType) {
|
||||||
|
case PERFORMFISH_SYNOPTIC_TABLE_FARM:
|
||||||
|
String outputId;
|
||||||
|
if (!result.getFileName().contains("legend")) {
|
||||||
|
cssTableStyle = "synoptictable-farm";
|
||||||
|
outputId = getOutputId(oIteration, false);
|
||||||
|
} else {
|
||||||
|
cssTableStyle = "simpletable-synoptic";
|
||||||
|
outputId = getOutputId(oIteration, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
ShowResult showResultSin = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResultSin.showCSVFile(result, cssTableStyle);
|
||||||
|
displayingOrderedSynopticTable(dmResponse, result.getFileName(), container,
|
||||||
|
showResultSin);
|
||||||
|
return;
|
||||||
|
case PERFORMFISH_SYNOPTICTABLE_BATCH:
|
||||||
|
break;
|
||||||
|
case PERFORMFISH_SYNOPTICTABLE_BATCH_HATCHERY:
|
||||||
|
break;
|
||||||
|
case PERFORMFISH_SYNOPTICTABLE_BATCH_PREGROW:
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
String outputId = getOutputId(oIteration, false);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
|
container.add(showResult);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayingOrderedSynopticTable(final DataMinerResponse dmResponse, String fileName,
|
||||||
|
final Panel container, ShowResult showResult) {
|
||||||
|
int hashcode = dmResponse.hashCode();
|
||||||
|
GWT.log("The hascode is: " + hashcode);
|
||||||
|
FlexTable flex = synopticOrderBy.get(hashcode);
|
||||||
|
|
||||||
|
if (flex == null) {
|
||||||
|
GWT.log("The flextable is null");
|
||||||
|
flex = new FlexTable();
|
||||||
|
synopticOrderBy.put(hashcode, flex);
|
||||||
|
container.add(flex);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fileName.toLowerCase().contains("legend")) {
|
||||||
|
flex.setWidget(0, 0, showResult);
|
||||||
|
} else {
|
||||||
|
flex.setWidget(flex.getRowCount() + 1, 0, showResult);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static native void saveFilePDF(String chartType, String filename, String tabTitle, String tabDescr,
|
||||||
|
int requestId, int outputIteration, int outputNumber)/*-{
|
||||||
|
var that = this;
|
||||||
|
console.log('saveFilePDF()');
|
||||||
|
console.log('requestId: ' + requestId);
|
||||||
|
console.log('OutputIteration: ' + outputIteration);
|
||||||
|
console.log('OutputNumber:' + outputNumber);
|
||||||
|
|
||||||
|
var tTitle = tabTitle;
|
||||||
|
var tDescr = tabDescr;
|
||||||
|
|
||||||
|
var pdoc = new jsPDF("p", "mm", "a4");
|
||||||
|
pdoc.setProperties({
|
||||||
|
title : 'PerformFish ' + tTitle,
|
||||||
|
subject : ' Results',
|
||||||
|
author : 'PerformFish',
|
||||||
|
keywords : 'PerformFish',
|
||||||
|
creator : 'D4Science'
|
||||||
|
});
|
||||||
|
|
||||||
|
var lMargin = 15; //left margin in mm
|
||||||
|
var rMargin = 15; //right margin in mm
|
||||||
|
var tMargin = 15; //top margin in mm
|
||||||
|
var bMargin = 15; //bottom margin in mm
|
||||||
|
var pdfWidthInMM = 210; // width of A4 in mm
|
||||||
|
var pdfHeightInMM = 297; // height of A4 in mm
|
||||||
|
var pageCenter = pdfWidthInMM / 2;
|
||||||
|
|
||||||
|
pdoc.setFontSize(24);
|
||||||
|
var title = "PerformFish " + tTitle;
|
||||||
|
var titleHeight = pdoc.getLineHeight(title) / pdoc.internal.scaleFactor
|
||||||
|
var xPos = lMargin;
|
||||||
|
var yPos = tMargin;
|
||||||
|
pdoc.text(title, pageCenter, yPos, 'center');
|
||||||
|
yPos += titleHeight;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
var lineHeight = pdoc.getLineHeight(tDescr) / pdoc.internal.scaleFactor
|
||||||
|
var splittedAnalysisDescription = pdoc.splitTextToSize(tDescr,
|
||||||
|
(pdfWidthInMM - lMargin - rMargin));
|
||||||
|
var lines = splittedAnalysisDescription.length // splitted text is a string array
|
||||||
|
var analysisDescriptionHeight = lines * lineHeight
|
||||||
|
|
||||||
|
pdoc.text(splittedAnalysisDescription, xPos, yPos, 'left');
|
||||||
|
yPos += analysisDescriptionHeight;
|
||||||
|
|
||||||
|
//yPos += 2;
|
||||||
|
//pdoc.text("Analysis:", xPos, yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
|
var outputId = 'OutputId_' + requestId + '_' + i + '_' + j;
|
||||||
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
|
var resultOutputNumber = $doc.getElementById(outputId);
|
||||||
|
|
||||||
|
console.log('OutputId_: ' + resultOutputNumber.innerHTML);
|
||||||
|
var resultType = resultOutputNumber.className;
|
||||||
|
|
||||||
|
console.log('resultOutputNumber className: ' + resultType);
|
||||||
|
|
||||||
|
if (typeof resultType !== 'undefined' && resultType !== null
|
||||||
|
&& resultType !== '') {
|
||||||
|
|
||||||
|
if (resultType == 'csv') {
|
||||||
|
console.log('Result Type csv: ' + i);
|
||||||
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
|
console.log('CSV SecondTable: ' + secondTable);
|
||||||
|
|
||||||
|
var checkColor = function(data) {
|
||||||
|
if (data.section === 'body') {
|
||||||
|
console.log(data);
|
||||||
|
var good = '<div class="gwt-HTML"><span style="padding-left: 10px; padding-right: 10px; background-color: limegreen; border: 1px solid limegreen;"></span></div>';
|
||||||
|
var normal = '<div class="gwt-HTML"><span style="padding-left: 10px; padding-right: 10px; background-color: yellow; border: 1px solid yellow;"></span></div>';
|
||||||
|
var bad = '<div class="gwt-HTML"><span style="padding-left: 10px; padding-right: 10px; background-color: red;border: 1px solid red;"></span></div>';
|
||||||
|
|
||||||
|
if (typeof data.cell !== 'undefined'
|
||||||
|
&& data.cell !== null) {
|
||||||
|
if (typeof data.cell.raw !== 'undefined'
|
||||||
|
&& data.cell.raw !== null) {
|
||||||
|
|
||||||
|
console.log(data.cell.raw.innerHTML);
|
||||||
|
if (data.cell.raw.innerHTML === good) {
|
||||||
|
console.log('good');
|
||||||
|
var posIW = (data.cell.x + (data.cell.width / 2)-2);
|
||||||
|
var posIH = (data.cell.y + (data.cell.height / 2)-2);
|
||||||
|
var greenImg = ''
|
||||||
|
pdoc.addImage(greenImg, 'JPEG', posIW, posIH, 4, 4);
|
||||||
|
//pdoc.setFontSize(10);
|
||||||
|
//pdoc.setFontType("normal");
|
||||||
|
//var posW = (data.cell.x + (data.cell.width / 2));
|
||||||
|
//var posH = (data.cell.y + (data.cell.height / 2));
|
||||||
|
//pdoc.text('G', posW, posH,'center');
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML === normal) {
|
||||||
|
console.log('normal');
|
||||||
|
var posIW = (data.cell.x + (data.cell.width / 2)-2);
|
||||||
|
var posIH = (data.cell.y + (data.cell.height / 2)-2);
|
||||||
|
var yellowImg = ''
|
||||||
|
pdoc.addImage(yellowImg, 'JPEG', posIW, posIH, 4, 4);
|
||||||
|
//pdoc.setFontSize(10);
|
||||||
|
//pdoc.setFontType("normal");
|
||||||
|
//var posW = (data.cell.x + (data.cell.width / 2));
|
||||||
|
//var posH = (data.cell.y + (data.cell.height / 2));
|
||||||
|
//pdoc.text('N', posW, posH,'center');
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML === bad) {
|
||||||
|
console.log('bad');
|
||||||
|
var posIW = (data.cell.x + (data.cell.width / 2)-2);
|
||||||
|
var posIH = (data.cell.y + (data.cell.height / 2)-2);
|
||||||
|
var redImg = ''
|
||||||
|
pdoc.addImage(redImg, 'JPEG', posIW, posIH, 4, 4);
|
||||||
|
//pdoc.setFontSize(10);
|
||||||
|
//pdoc.setFontType("normal");
|
||||||
|
//var posW = (data.cell.x + (data.cell.width / 2));
|
||||||
|
//var posH = (data.cell.y + (data.cell.height / 2));
|
||||||
|
//pdoc.text('B', posW, posH,'center');
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
pdoc.autoTable({
|
||||||
|
theme : 'grid',
|
||||||
|
startY : yPos,
|
||||||
|
pageBreak : 'auto',
|
||||||
|
bodyStyles : {
|
||||||
|
fontSize : 9
|
||||||
|
},
|
||||||
|
didDrawCell : checkColor,
|
||||||
|
html : secondTable
|
||||||
|
});
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
} else {
|
||||||
|
if (resultType == 'image') {
|
||||||
|
console.log('Result Type image: ' + i);
|
||||||
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
|
'img').item(0);
|
||||||
|
console.log('Image element: ' + imageElement);
|
||||||
|
pdoc.addImage(imageElement, lMargin, yPos);
|
||||||
|
console.log('Image Height: ' + imageElement.height);
|
||||||
|
yPos += (imageElement.height * 0.26458333);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
console.log('Result Type unknow: ' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Result Type is undefined:' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 7) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages = pdoc.internal.getNumberOfPages();
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/" + numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Done');
|
||||||
|
|
||||||
|
pdoc.save(filename);
|
||||||
|
|
||||||
|
}-*/;
|
||||||
|
|
||||||
|
}
|
|
@ -1,588 +0,0 @@
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
package org.gcube.portlets.user.performfishanalytics.client.viewbinder;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsController;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.event.CallAlgorithmEvent;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.view.util.CorrelationValueToColourUtil;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVRow;
|
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.dataminer.DataMinerResponse;
|
|
||||||
|
|
||||||
import com.github.gwtbootstrap.client.ui.Alert;
|
|
||||||
import com.github.gwtbootstrap.client.ui.ControlGroup;
|
|
||||||
import com.github.gwtbootstrap.client.ui.ListBox;
|
|
||||||
import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
|
||||||
import com.github.gwtbootstrap.client.ui.constants.ControlGroupType;
|
|
||||||
import com.google.gwt.core.client.GWT;
|
|
||||||
import com.google.gwt.dom.client.Style.Unit;
|
|
||||||
import com.google.gwt.event.dom.client.ClickEvent;
|
|
||||||
import com.google.gwt.event.dom.client.ClickHandler;
|
|
||||||
import com.google.gwt.event.logical.shared.AttachEvent;
|
|
||||||
import com.google.gwt.uibinder.client.UiBinder;
|
|
||||||
import com.google.gwt.uibinder.client.UiField;
|
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
|
||||||
import com.google.gwt.user.client.ui.ComplexPanel;
|
|
||||||
import com.google.gwt.user.client.ui.Composite;
|
|
||||||
import com.google.gwt.user.client.ui.FlexTable;
|
|
||||||
import com.google.gwt.user.client.ui.HTML;
|
|
||||||
import com.google.gwt.user.client.ui.HTMLPanel;
|
|
||||||
import com.google.gwt.user.client.ui.HorizontalPanel;
|
|
||||||
import com.google.gwt.user.client.ui.Label;
|
|
||||||
import com.google.gwt.user.client.ui.VerticalPanel;
|
|
||||||
import com.google.gwt.user.client.ui.Widget;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Class AnalyticsPanelResult.
|
|
||||||
*
|
|
||||||
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
|
|
||||||
* Jan 29, 2019
|
|
||||||
*/
|
|
||||||
public class AnalyticsPanelResult extends Composite {
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
private static AnalyticsPanelResultUiBinder uiBinder =
|
|
||||||
GWT.create(AnalyticsPanelResultUiBinder.class);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Interface AnalyticsPanelResultUiBinder.
|
|
||||||
*
|
|
||||||
* @author Francesco Mangiacrapa at ISTI-CNR (francesco.mangiacrapa@isti.cnr.it)
|
|
||||||
* Jan 30, 2019
|
|
||||||
*/
|
|
||||||
interface AnalyticsPanelResultUiBinder
|
|
||||||
extends UiBinder<Widget, AnalyticsPanelResult> {
|
|
||||||
}
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
HTMLPanel field_html_panel;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
VerticalPanel field_parameters_container;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
VerticalPanel uib_vp_correlation_results_container;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
VerticalPanel field_unary_algorithm_container;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
VerticalPanel field_binary_algorithm;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
VerticalPanel field_binary_algorithm_container;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
VerticalPanel field_unary_algorithm;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
Label uib_label_focus_id;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
ControlGroup cg_focus_id_correlation;
|
|
||||||
|
|
||||||
@UiField
|
|
||||||
ListBox field_list_focus_id_correlation;
|
|
||||||
|
|
||||||
|
|
||||||
private Map<String,String> dataInputParameters;
|
|
||||||
|
|
||||||
private DataMinerResponse dmResponse;
|
|
||||||
|
|
||||||
private Map<String,List<KPI>> kpiMapPointers = new HashMap<String, List<KPI>>();
|
|
||||||
|
|
||||||
private List<KPI> selectedKPIs;
|
|
||||||
|
|
||||||
private List<String> selectedAreas;
|
|
||||||
|
|
||||||
private Map<String, CSVFile> csvGenerated = new HashMap<String, CSVFile>();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Because this class has a default constructor, it can
|
|
||||||
* be used as a binder template. In other words, it can be used in other
|
|
||||||
* *.ui.xml files as follows:
|
|
||||||
* <ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
|
|
||||||
* xmlns:g="urn:import:**user's package**">
|
|
||||||
* <g:**UserClassName**>Hello!</g:**UserClassName>
|
|
||||||
* </ui:UiBinder>
|
|
||||||
* Note that depending on the widget that is used, it may be necessary to
|
|
||||||
* implement HasHTML instead of HasText.
|
|
||||||
*/
|
|
||||||
public AnalyticsPanelResult() {
|
|
||||||
|
|
||||||
initWidget(uiBinder.createAndBindUi(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds the selected areas.
|
|
||||||
*
|
|
||||||
* @param listAreas the list areas
|
|
||||||
*/
|
|
||||||
public void addSelectedAreas(List<String> listAreas) {
|
|
||||||
|
|
||||||
this.selectedAreas = listAreas;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the data miner response.
|
|
||||||
*
|
|
||||||
* @return the data miner response
|
|
||||||
*/
|
|
||||||
public DataMinerResponse getDataMinerResponse(){
|
|
||||||
return dmResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the data input parameters.
|
|
||||||
*
|
|
||||||
* @return the data input parameters
|
|
||||||
*/
|
|
||||||
public Map<String, String> getDataInputParameters() {
|
|
||||||
|
|
||||||
return dataInputParameters;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Show alert.
|
|
||||||
*
|
|
||||||
* @param error the error
|
|
||||||
* @param type the type
|
|
||||||
* @param closable the closable
|
|
||||||
* @param panel the panel
|
|
||||||
*/
|
|
||||||
private void showAlert(String error, AlertType type, boolean closable, ComplexPanel panel){
|
|
||||||
Alert alert = new Alert(error);
|
|
||||||
alert.setType(type);
|
|
||||||
alert.setClose(closable);
|
|
||||||
alert.getElement().getStyle().setMargin(10, Unit.PX);
|
|
||||||
panel.add(alert);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds the selected kp is.
|
|
||||||
*
|
|
||||||
* @param selectedKPIs the selected kp is
|
|
||||||
*/
|
|
||||||
public void addSelectedKPIs(List<KPI> selectedKPIs) {
|
|
||||||
|
|
||||||
this.selectedKPIs = selectedKPIs;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the KPI for name.
|
|
||||||
*
|
|
||||||
* @param name the name
|
|
||||||
* @return the KPI for name
|
|
||||||
*/
|
|
||||||
public KPI getKPIForName(String name){
|
|
||||||
|
|
||||||
GWT.log("Searching KPI name: "+name);
|
|
||||||
KPI foundKPI = null;
|
|
||||||
String purgedName = name.trim();
|
|
||||||
for (KPI kpi : selectedKPIs) {
|
|
||||||
String purgedKPIName = kpi.getName().trim();
|
|
||||||
if(purgedKPIName.compareToIgnoreCase(purgedName)==0) {
|
|
||||||
foundKPI = kpi;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
GWT.log("FOUND KPI: "+foundKPI);
|
|
||||||
return foundKPI;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds the parameters.
|
|
||||||
*
|
|
||||||
* @param keyToGet the key to get
|
|
||||||
* @param parameters the parameters
|
|
||||||
* @param toShowBatchTypeValue label to show batch type value
|
|
||||||
*/
|
|
||||||
public void addParameters(String keyToGet, Map<String, List<String>> parameters, String toShowBatchTypeValue) {
|
|
||||||
|
|
||||||
|
|
||||||
final FlexTable flexTable = new FlexTable();
|
|
||||||
flexTable.setStyleName("colgrouptable");
|
|
||||||
|
|
||||||
try{
|
|
||||||
List<String> dataInputs = parameters.get(keyToGet);
|
|
||||||
|
|
||||||
if(dataInputs==null || dataInputs.isEmpty())
|
|
||||||
return;
|
|
||||||
|
|
||||||
dataInputParameters = new HashMap<String, String>();
|
|
||||||
|
|
||||||
String theDataInputs = dataInputs.get(0);
|
|
||||||
String[] splittedParams = theDataInputs.split(";");
|
|
||||||
|
|
||||||
for (String splitParam : splittedParams) {
|
|
||||||
try{
|
|
||||||
String[] keyvalue = splitParam.split("=");
|
|
||||||
dataInputParameters.put(keyvalue[0], keyvalue[1]);
|
|
||||||
}catch(Exception e){
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
flexTable.setWidget(0, 0, new HTML("Batch Type:"));
|
|
||||||
flexTable.setWidget(0, 1, new HTML(toShowBatchTypeValue));
|
|
||||||
flexTable.setWidget(1, 0, new HTML("Level:"));
|
|
||||||
flexTable.setWidget(1, 1, new HTML(dataInputParameters.get(PerformFishAnalyticsConstant.DM_SCALEP_PARAM)));
|
|
||||||
|
|
||||||
String KPINames = "";
|
|
||||||
for (KPI kpi: selectedKPIs) {
|
|
||||||
KPINames+=kpi.getName() +", ";
|
|
||||||
}
|
|
||||||
KPINames = KPINames.substring(0, KPINames.length()-2);
|
|
||||||
flexTable.setWidget(2, 0, new HTML("KPIs:"));
|
|
||||||
flexTable.setWidget(2, 1, new HTML(KPINames));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}catch(Exception e){
|
|
||||||
//silent
|
|
||||||
}
|
|
||||||
|
|
||||||
field_parameters_container.add(flexTable);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds the list focus ids.
|
|
||||||
*
|
|
||||||
* @param listFocusIDs the list focus I ds
|
|
||||||
*/
|
|
||||||
public void addListFocusIds(List<String> listFocusIDs){
|
|
||||||
for (String batchID : listFocusIDs) {
|
|
||||||
field_list_focus_id_correlation.addItem(batchID, batchID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds the results.
|
|
||||||
*
|
|
||||||
* @param dmResponse the dm response
|
|
||||||
*/
|
|
||||||
public void addResults(DataMinerResponse dmResponse) {
|
|
||||||
this.dmResponse = dmResponse;
|
|
||||||
|
|
||||||
for (final OutputFile outputFile : dmResponse.getListOutput()) {
|
|
||||||
|
|
||||||
if(outputFile.getDataType().equals(FileContentType.CSV)){
|
|
||||||
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true, new AsyncCallback<CSVFile>() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onFailure(Throwable caught) {
|
|
||||||
showAlert(caught.getMessage(), AlertType.ERROR, true, uib_vp_correlation_results_container);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onSuccess(CSVFile result) {
|
|
||||||
|
|
||||||
csvGenerated.put(result.getFileName(), result);
|
|
||||||
fillCorrelationMatrix();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void fillCorrelationMatrix() {
|
|
||||||
|
|
||||||
if(csvGenerated.size()<2)
|
|
||||||
return;
|
|
||||||
|
|
||||||
String corrIndexFilename = null;
|
|
||||||
String corrFilename = null;
|
|
||||||
for (String fileName : csvGenerated.keySet()) {
|
|
||||||
if(fileName.contains("index")) {
|
|
||||||
corrIndexFilename = fileName;
|
|
||||||
}else {
|
|
||||||
corrFilename = fileName;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
GWT.log("Correlation Matrix Index File: "+corrIndexFilename);
|
|
||||||
GWT.log("Correlation Matrix File: "+corrFilename);
|
|
||||||
CSVFile corrIndexCsvFile = csvGenerated.get(corrIndexFilename);
|
|
||||||
CSVFile corrCsvFile = csvGenerated.get(corrFilename);
|
|
||||||
GWT.log("Correlation Matrix Index CSV: "+corrIndexCsvFile);
|
|
||||||
GWT.log("Correlation Matrix CSV: "+corrCsvFile);
|
|
||||||
|
|
||||||
HorizontalPanel hp = new HorizontalPanel();
|
|
||||||
final FlexTable flexTable = new FlexTable();
|
|
||||||
flexTable.setStyleName("fixedtable");
|
|
||||||
flexTable.getElement().getStyle().setMarginBottom(10, Unit.PX);
|
|
||||||
|
|
||||||
flexTable.setWidget(0, 0,new Label(""));
|
|
||||||
|
|
||||||
|
|
||||||
CSVRow headerRow = corrIndexCsvFile.getHeaderRow();
|
|
||||||
//HEADER
|
|
||||||
for (int i=1; i<headerRow.getListValues().size(); i++) {
|
|
||||||
|
|
||||||
final String headerValue = headerRow.getListValues().get(i);
|
|
||||||
// final Button button = new Button(headerValue);
|
|
||||||
// button.setType(ButtonType.LINK);
|
|
||||||
HTML label = new HTML(headerValue);
|
|
||||||
label.getElement().getStyle().setFontSize(16, Unit.PX);
|
|
||||||
|
|
||||||
final int columnIndex = i;
|
|
||||||
KPI kpi = getKPIForName(headerValue);
|
|
||||||
fillKPIReferenceForIndex(0, columnIndex, Arrays.asList(kpi));
|
|
||||||
// button.addClickHandler(new ClickHandler() {
|
|
||||||
//
|
|
||||||
// @Override
|
|
||||||
// public void onClick(ClickEvent event) {
|
|
||||||
// //calling unary operator
|
|
||||||
// callBoxPlotAndSpeedoMeter(0,columnIndex,button);
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
// });
|
|
||||||
flexTable.setWidget(0, i,label);
|
|
||||||
}
|
|
||||||
//DATA
|
|
||||||
for (int i=0; i<corrIndexCsvFile.getValueRows().size(); i++) {
|
|
||||||
CSVRow row = corrIndexCsvFile.getValueRows().get(i);
|
|
||||||
CSVRow rowMatrixColor = corrCsvFile.getValueRows().get(i);
|
|
||||||
final int rowIndex = i+1; //adding +1 for header row
|
|
||||||
for (int j=0; j<row.getListValues().size(); j++) {
|
|
||||||
final String rowValue = row.getListValues().get(j);
|
|
||||||
final String rowMatrixColorValue = rowMatrixColor.getListValues().get(j);
|
|
||||||
final String theColor = CorrelationValueToColourUtil.getRGBColor(rowMatrixColorValue);
|
|
||||||
final int columnIndex = j;
|
|
||||||
//final Button button = new Button(rowValue);
|
|
||||||
final HTML buttonHTML = new HTML(rowValue);
|
|
||||||
buttonHTML.addStyleName("my-active-html");
|
|
||||||
// button.setType(ButtonType.LINK);
|
|
||||||
// button.setSize(ButtonSize.LARGE);
|
|
||||||
|
|
||||||
//only the first column
|
|
||||||
if(j==0){
|
|
||||||
HTML label = new HTML(rowValue);
|
|
||||||
label.getElement().getStyle().setFontSize(16, Unit.PX);
|
|
||||||
flexTable.setWidget(rowIndex, j,label);
|
|
||||||
//rowValue is a KPI name
|
|
||||||
KPI kpi = getKPIForName(rowValue);
|
|
||||||
fillKPIReferenceForIndex(rowIndex, columnIndex, Arrays.asList(kpi));
|
|
||||||
continue;
|
|
||||||
//rowValue is a KPI name
|
|
||||||
// KPI kpi = getKPIForName(rowValue);
|
|
||||||
// fillKPIReferenceForIndex(rowIndex, columnIndex, Arrays.asList(kpi));
|
|
||||||
// button.addClickHandler(new ClickHandler() {
|
|
||||||
//
|
|
||||||
// @Override
|
|
||||||
// public void onClick(ClickEvent event) {
|
|
||||||
// //calling unary operator
|
|
||||||
// callBoxPlotAndSpeedoMeter(rowIndex, columnIndex, button);
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
// });
|
|
||||||
}
|
|
||||||
//diagonal
|
|
||||||
else if(rowIndex==j){
|
|
||||||
//rowValue should be 1
|
|
||||||
//HTML dg = new HTML("1");
|
|
||||||
HTML dg = new HTML(rowValue);
|
|
||||||
dg.getElement().getStyle().setFontSize(18, Unit.PX);
|
|
||||||
flexTable.setWidget(rowIndex, j,dg);
|
|
||||||
continue;
|
|
||||||
//j > 0
|
|
||||||
}else{
|
|
||||||
KPI columnKPI = getKPIForName(headerRow.getListValues().get(columnIndex));
|
|
||||||
//Here the first index is the KPI name
|
|
||||||
KPI rowKPI = getKPIForName(row.getListValues().get(0));
|
|
||||||
fillKPIReferenceForIndex(rowIndex, columnIndex, Arrays.asList(columnKPI, rowKPI));
|
|
||||||
//button.setText(" ");
|
|
||||||
//button.setIcon(IconType.COMPASS);
|
|
||||||
//button.setSize(ButtonSize.LARGE);
|
|
||||||
|
|
||||||
buttonHTML.addClickHandler(new ClickHandler() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(ClickEvent event) {
|
|
||||||
|
|
||||||
//callScatterAndDeaChart(rowIndex, columnIndex, button);
|
|
||||||
callScatter(rowIndex, columnIndex, buttonHTML);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
//button.setType(ButtonType.LINK);
|
|
||||||
//APPLYING STYLE ONLY ON INTERNAL VALUES OF CSV
|
|
||||||
if(j>0)
|
|
||||||
buttonHTML.getElement().getStyle().setColor("#000");
|
|
||||||
|
|
||||||
buttonHTML.addAttachHandler(new AttachEvent.Handler() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onAttachOrDetach(AttachEvent event) {
|
|
||||||
if(theColor.startsWith("#")){
|
|
||||||
GWT.log("Setting backgrounf color: "+theColor);
|
|
||||||
buttonHTML.getElement().getParentElement().getStyle().setBackgroundColor(theColor);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
flexTable.setWidget(rowIndex, j,buttonHTML);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
hp.add(flexTable);
|
|
||||||
|
|
||||||
final FlexTable flexLegend = new FlexTable();
|
|
||||||
flexLegend.setStyleName("simpletable");
|
|
||||||
//flexLegend.getElement().getStyle().setBorderWidth(0, Unit.PX);
|
|
||||||
Map<String, String> map = CorrelationValueToColourUtil.getMap();
|
|
||||||
flexLegend.setWidget(0, 0, new Label("Legend"));
|
|
||||||
flexLegend.setWidget(0, 1, new HTML(""));
|
|
||||||
int i = 1;
|
|
||||||
for (String key : map.keySet()) {
|
|
||||||
final String rgbColor = map.get(key);
|
|
||||||
final HTML theLegendColor = new HTML("");
|
|
||||||
flexLegend.setWidget(i, 0, theLegendColor);
|
|
||||||
flexLegend.setWidget(i, 1, new HTML(key));
|
|
||||||
theLegendColor.addAttachHandler(new AttachEvent.Handler() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onAttachOrDetach(AttachEvent event) {
|
|
||||||
theLegendColor.getElement().getParentElement().getStyle().setBackgroundColor(rgbColor);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
|
|
||||||
flexLegend.getElement().getStyle().setMarginLeft(15, Unit.PX);
|
|
||||||
hp.add(flexLegend);
|
|
||||||
uib_vp_correlation_results_container.insert(hp,0);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Fill kpi reference for index.
|
|
||||||
*
|
|
||||||
* @param rowIndex the row index
|
|
||||||
* @param columnIndex the column index
|
|
||||||
* @param listKPI the list kpi
|
|
||||||
*/
|
|
||||||
private void fillKPIReferenceForIndex(int rowIndex, int columnIndex, List<KPI> listKPI){
|
|
||||||
|
|
||||||
String key = generateKey(rowIndex, columnIndex);
|
|
||||||
kpiMapPointers.put(key, listKPI);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the KPI for indexes.
|
|
||||||
*
|
|
||||||
* @param rowIndex the row index
|
|
||||||
* @param columnIndex the column index
|
|
||||||
* @return the KPI for indexes
|
|
||||||
*/
|
|
||||||
public List<KPI> getKPIForIndexes(int rowIndex, int columnIndex){
|
|
||||||
String key = generateKey(rowIndex, columnIndex);
|
|
||||||
return kpiMapPointers.get(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Generate key.
|
|
||||||
*
|
|
||||||
* @param rowIndex the row index
|
|
||||||
* @param columnIndex the column index
|
|
||||||
* @return the string
|
|
||||||
*/
|
|
||||||
private String generateKey(int rowIndex, int columnIndex) {
|
|
||||||
return rowIndex+"-"+columnIndex;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check valid focus id.
|
|
||||||
*
|
|
||||||
* @return the FocusID if it is valid, null otherwise.
|
|
||||||
*/
|
|
||||||
public String checkValidFocusID(){
|
|
||||||
|
|
||||||
cg_focus_id_correlation.setType(ControlGroupType.NONE);
|
|
||||||
|
|
||||||
//CHECK THE FOCUS ID VALUE
|
|
||||||
String focusID = field_list_focus_id_correlation.getSelectedItemText();
|
|
||||||
|
|
||||||
if(focusID==null || focusID.isEmpty()){
|
|
||||||
|
|
||||||
String msgError = "Could not execute a valid Analysis.";
|
|
||||||
|
|
||||||
if(selectedAreas==null || selectedAreas.isEmpty()){
|
|
||||||
msgError+=" Please select another parameters computation";
|
|
||||||
}else{
|
|
||||||
msgError+=" Select at least the Area of your FARM";
|
|
||||||
}
|
|
||||||
|
|
||||||
showAlert(msgError, AlertType.ERROR, true, uib_vp_correlation_results_container);
|
|
||||||
cg_focus_id_correlation.setType(ControlGroupType.ERROR);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return focusID;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Call scatter.
|
|
||||||
*
|
|
||||||
* @param rowIndex the row index
|
|
||||||
* @param columnIndex the column index
|
|
||||||
* @param button the button
|
|
||||||
*/
|
|
||||||
private void callScatter(int rowIndex, int columnIndex, HTML button){
|
|
||||||
|
|
||||||
String focusID = checkValidFocusID();
|
|
||||||
|
|
||||||
if(focusID==null)
|
|
||||||
return;
|
|
||||||
|
|
||||||
GWT.log("Called ScatterChart at rowIndex: "+rowIndex +", columnIndex: "+columnIndex);
|
|
||||||
List<KPI> selectedKPI = getKPIForIndexes(rowIndex, columnIndex);
|
|
||||||
GWT.log("Selected KPI: "+selectedKPI);
|
|
||||||
PerformFishAnalyticsController.eventBus.fireEvent(new CallAlgorithmEvent(DataMinerAlgorithms.SCATTER, focusID, selectedKPI, null));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
|
@ -12,6 +12,7 @@ import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsS
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
@ -43,13 +44,15 @@ public class BoxPlotPanelResult {
|
||||||
|
|
||||||
private PerformFishAnalyticsViewController viewController;
|
private PerformFishAnalyticsViewController viewController;
|
||||||
private int outputIteration = 0;
|
private int outputIteration = 0;
|
||||||
private int outputNumber = 0;
|
private int outputNumber = 3;
|
||||||
private int requestId;
|
private int requestId = 0;
|
||||||
|
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
public BoxPlotPanelResult(int reqId,PerformFishAnalyticsViewController viewController, final DataMinerAlgorithms algorithm,
|
public BoxPlotPanelResult(int reqId, PerformFishAnalyticsViewController viewController,
|
||||||
String focusID, List<KPI> inputKPI, final List<KPI> outputKPI) {
|
final DataMinerAlgorithms algorithm, String focusID, List<KPI> inputKPI, final List<KPI> outputKPI) {
|
||||||
this.requestId=reqId;
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
this.viewController = viewController;
|
this.viewController = viewController;
|
||||||
TextResource algDescr = PerformFishResources.INSTANCE.batch_BOXPLOT();
|
TextResource algDescr = PerformFishResources.INSTANCE.batch_BOXPLOT();
|
||||||
|
|
||||||
|
@ -65,7 +68,7 @@ public class BoxPlotPanelResult {
|
||||||
|
|
||||||
HorizontalPanel res = new HorizontalPanel();
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
Button savePDFButton = new Button();
|
savePDFButton = new Button();
|
||||||
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
savePDFButton.setIcon(IconType.PRINT);
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
savePDFButton.addClickHandler(new ClickHandler() {
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
@ -76,6 +79,7 @@ public class BoxPlotPanelResult {
|
||||||
// dmResponse.getListOutput().size()
|
// dmResponse.getListOutput().size()
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
res.add(savePDFButton);
|
res.add(savePDFButton);
|
||||||
submitRequestPanel.addWidget(res);
|
submitRequestPanel.addWidget(res);
|
||||||
|
@ -86,6 +90,7 @@ public class BoxPlotPanelResult {
|
||||||
oIteration++;
|
oIteration++;
|
||||||
String title = "KPI: " + kpi.getName();
|
String title = "KPI: " + kpi.getName();
|
||||||
HTML toBigTitle = new HTML(title);
|
HTML toBigTitle = new HTML(title);
|
||||||
|
toBigTitle.getElement().setId("KPI_BoxPlot_" + requestId + "_" + oIteration);
|
||||||
toBigTitle.getElement().addClassName("to-big-title");
|
toBigTitle.getElement().addClassName("to-big-title");
|
||||||
submitRequestPanel.addWidget(toBigTitle);
|
submitRequestPanel.addWidget(toBigTitle);
|
||||||
HorizontalPanel hp = new HorizontalPanel();
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
|
@ -194,11 +199,26 @@ public class BoxPlotPanelResult {
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, String title) {
|
||||||
|
if (title.startsWith("My")) {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
return outputId;
|
||||||
|
} else if (title.startsWith("All")) {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 2;
|
||||||
|
return outputId;
|
||||||
|
} else {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 3;
|
||||||
|
return outputId;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
final Panel container, boolean displayError, int oIteration) {
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
String title = displayError ? "No results " : "";
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
@ -211,15 +231,12 @@ public class BoxPlotPanelResult {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(true);
|
||||||
final String toTitle = title;
|
final String toTitle = title;
|
||||||
|
|
||||||
outputNumber = dmResponse.getListOutput().size();
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
|
||||||
int oNumber = 0;
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
|
|
||||||
for (final OutputFile outputFile : dmResponse.getListOutput()) {
|
|
||||||
oNumber++;
|
|
||||||
final String outputId = "OutputId_" +requestId+"_"+ oIteration + "_" + oNumber;
|
|
||||||
|
|
||||||
switch (outputFile.getDataType()) {
|
switch (outputFile.getDataType()) {
|
||||||
case IMAGE:
|
case IMAGE:
|
||||||
|
@ -243,7 +260,8 @@ public class BoxPlotPanelResult {
|
||||||
title = chartType.getName() + " - on all batches<br>";
|
title = chartType.getName() + " - on all batches<br>";
|
||||||
title += "Blue dots indicate the selected batch(es): " + focusID;
|
title += "Blue dots indicate the selected batch(es): " + focusID;
|
||||||
|
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showImage(base64Content);
|
showResult.showImage(base64Content);
|
||||||
displayingOrderedBoxPlot(dmResponse, title, container, showResult);
|
displayingOrderedBoxPlot(dmResponse, title, container, showResult);
|
||||||
}
|
}
|
||||||
|
@ -277,7 +295,8 @@ public class BoxPlotPanelResult {
|
||||||
title += "<br>";
|
title += "<br>";
|
||||||
title += "Data aggregation is performed by considering batches as base units";
|
title += "Data aggregation is performed by considering batches as base units";
|
||||||
|
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showCSVFile(result, cssTableStyle);
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
displayingOrderedBoxPlot(dmResponse, title, container, showResult);
|
displayingOrderedBoxPlot(dmResponse, title, container, showResult);
|
||||||
|
|
||||||
|
@ -337,7 +356,7 @@ public class BoxPlotPanelResult {
|
||||||
int requestId, int outputIteration, int outputNumber)/*-{
|
int requestId, int outputIteration, int outputNumber)/*-{
|
||||||
var that = this;
|
var that = this;
|
||||||
console.log('saveFilePDF()');
|
console.log('saveFilePDF()');
|
||||||
console.log('requestId: '+requestId);
|
console.log('requestId: ' + requestId);
|
||||||
console.log('OutputIteration: ' + outputIteration);
|
console.log('OutputIteration: ' + outputIteration);
|
||||||
console.log('OutputNumber:' + outputNumber);
|
console.log('OutputNumber:' + outputNumber);
|
||||||
|
|
||||||
|
@ -385,9 +404,32 @@ public class BoxPlotPanelResult {
|
||||||
|
|
||||||
for (var i = 1; i <= outputIteration; i++) {
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
|
var kpiId = 'KPI_BoxPlot_' + requestId + '_' + i;
|
||||||
|
console.log('kpiId: ' + kpiId);
|
||||||
|
|
||||||
|
var kpiName = $doc.getElementById(kpiId);
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(14);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
|
||||||
|
var kpiText = kpiName.textContent;
|
||||||
|
var kpiHeight = pdoc.getLineHeight(kpiText)
|
||||||
|
/ pdoc.internal.scaleFactor;
|
||||||
|
var splittedKpiName = pdoc.splitTextToSize(kpiText, (pdfWidthInMM
|
||||||
|
- lMargin - rMargin));
|
||||||
|
var kpiLines = splittedKpiName.length; // splitted text is a string array
|
||||||
|
var kpiLinesHeight = kpiLines * kpiHeight;
|
||||||
|
pdoc.text(splittedKpiName, xPos, yPos, 'left');
|
||||||
|
yPos += kpiLinesHeight;
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
for (var j = 1; j <= outputNumber; j++) {
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
var outputId = 'OutputId_'+requestId+'_'+ i + '_' + j;
|
var outputId = 'OutputId_' + requestId + '_' + i + '_' + j;
|
||||||
console.log('OutputId: ' + outputId);
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
var resultOutputNumber = $doc.getElementById(outputId);
|
var resultOutputNumber = $doc.getElementById(outputId);
|
||||||
|
@ -405,6 +447,19 @@ public class BoxPlotPanelResult {
|
||||||
// foo could get resolved and it's defined
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var secondTable = secondDiv.children[0].children[0];
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
|
@ -425,6 +480,20 @@ public class BoxPlotPanelResult {
|
||||||
if (resultType == 'image') {
|
if (resultType == 'image') {
|
||||||
console.log('Result Type image: ' + i);
|
console.log('Result Type image: ' + i);
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var imageElement = secondDiv.getElementsByTagName(
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
'img').item(0);
|
'img').item(0);
|
||||||
|
@ -443,6 +512,24 @@ public class BoxPlotPanelResult {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (i < outputIteration) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages=pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/"+numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('Done');
|
console.log('Done');
|
||||||
|
|
|
@ -0,0 +1,807 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.gcube.portlets.user.performfishanalytics.client.viewbinder;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.DataMinerAlgorithms;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsConstant;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsServiceAsync;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsController;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.event.CallAlgorithmEvent;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.client.view.util.CorrelationValueToColourUtil;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVRow;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.dataminer.DataMinerResponse;
|
||||||
|
|
||||||
|
import com.github.gwtbootstrap.client.ui.Alert;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Button;
|
||||||
|
import com.github.gwtbootstrap.client.ui.ControlGroup;
|
||||||
|
import com.github.gwtbootstrap.client.ui.ListBox;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.ControlGroupType;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.IconType;
|
||||||
|
import com.google.gwt.core.client.GWT;
|
||||||
|
import com.google.gwt.dom.client.Style.Unit;
|
||||||
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
|
import com.google.gwt.event.logical.shared.AttachEvent;
|
||||||
|
import com.google.gwt.uibinder.client.UiBinder;
|
||||||
|
import com.google.gwt.uibinder.client.UiField;
|
||||||
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
|
import com.google.gwt.user.client.ui.ComplexPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Composite;
|
||||||
|
import com.google.gwt.user.client.ui.FlexTable;
|
||||||
|
import com.google.gwt.user.client.ui.HTML;
|
||||||
|
import com.google.gwt.user.client.ui.HTMLPanel;
|
||||||
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Label;
|
||||||
|
import com.google.gwt.user.client.ui.VerticalPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Widget;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Class AnalyticsPanelResult.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it Jan 29, 2019
|
||||||
|
*/
|
||||||
|
public class CorrelationPanelResult extends Composite {
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
private static CorrelationPanelResultUiBinder uiBinder = GWT.create(CorrelationPanelResultUiBinder.class);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Interface AnalyticsPanelResultUiBinder.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa at ISTI-CNR
|
||||||
|
* (francesco.mangiacrapa@isti.cnr.it) Jan 30, 2019
|
||||||
|
*/
|
||||||
|
interface CorrelationPanelResultUiBinder extends UiBinder<Widget, CorrelationPanelResult> {
|
||||||
|
}
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
HTMLPanel field_html_panel;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
VerticalPanel field_parameters_container;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
VerticalPanel uib_vp_correlation_results_container;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
VerticalPanel field_unary_algorithm_container;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
VerticalPanel field_binary_algorithm;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
VerticalPanel field_binary_algorithm_container;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
VerticalPanel field_unary_algorithm;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
Label uib_label_focus_id;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
ControlGroup cg_focus_id_correlation;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
ListBox field_list_focus_id_correlation;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
Button uib_save_pdf_1;
|
||||||
|
|
||||||
|
private Map<String, String> dataInputParameters;
|
||||||
|
|
||||||
|
private DataMinerResponse dmResponse;
|
||||||
|
|
||||||
|
private Map<String, List<KPI>> kpiMapPointers = new HashMap<String, List<KPI>>();
|
||||||
|
|
||||||
|
private List<KPI> selectedKPIs;
|
||||||
|
|
||||||
|
private List<String> selectedAreas;
|
||||||
|
|
||||||
|
private Map<String, CSVFile> csvGenerated = new HashMap<String, CSVFile>();
|
||||||
|
|
||||||
|
private CorrelationPanelResult analyticsPanelResult;
|
||||||
|
|
||||||
|
private int outputNumber;
|
||||||
|
private int requestId = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param reqId
|
||||||
|
* Request Identifier
|
||||||
|
* @param tabTitle
|
||||||
|
* Title
|
||||||
|
* @param tabDescription
|
||||||
|
* Description
|
||||||
|
*/
|
||||||
|
public CorrelationPanelResult(int reqId, final String tabTitle, final String tabDescription) {
|
||||||
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
|
|
||||||
|
initWidget(uiBinder.createAndBindUi(this));
|
||||||
|
|
||||||
|
analyticsPanelResult = this;
|
||||||
|
|
||||||
|
uib_save_pdf_1.setIcon(IconType.PRINT);
|
||||||
|
uib_save_pdf_1.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
saveFilePDF(analyticsPanelResult, tabTitle, tabTitle, tabDescription, requestId, outputNumber);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the selected areas.
|
||||||
|
*
|
||||||
|
* @param listAreas
|
||||||
|
* the list areas
|
||||||
|
*/
|
||||||
|
public void addSelectedAreas(List<String> listAreas) {
|
||||||
|
|
||||||
|
this.selectedAreas = listAreas;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the data miner response.
|
||||||
|
*
|
||||||
|
* @return the data miner response
|
||||||
|
*/
|
||||||
|
public DataMinerResponse getDataMinerResponse() {
|
||||||
|
return dmResponse;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the data input parameters.
|
||||||
|
*
|
||||||
|
* @return the data input parameters
|
||||||
|
*/
|
||||||
|
public Map<String, String> getDataInputParameters() {
|
||||||
|
|
||||||
|
return dataInputParameters;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show alert.
|
||||||
|
*
|
||||||
|
* @param error
|
||||||
|
* the error
|
||||||
|
* @param type
|
||||||
|
* the type
|
||||||
|
* @param closable
|
||||||
|
* the closable
|
||||||
|
* @param panel
|
||||||
|
* the panel
|
||||||
|
*/
|
||||||
|
private void showAlert(String error, AlertType type, boolean closable, ComplexPanel panel) {
|
||||||
|
Alert alert = new Alert(error);
|
||||||
|
alert.setType(type);
|
||||||
|
alert.setClose(closable);
|
||||||
|
alert.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
|
panel.add(alert);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the selected kp is.
|
||||||
|
*
|
||||||
|
* @param selectedKPIs
|
||||||
|
* the selected kp is
|
||||||
|
*/
|
||||||
|
public void addSelectedKPIs(List<KPI> selectedKPIs) {
|
||||||
|
|
||||||
|
this.selectedKPIs = selectedKPIs;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the KPI for name.
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* the name
|
||||||
|
* @return the KPI for name
|
||||||
|
*/
|
||||||
|
public KPI getKPIForName(String name) {
|
||||||
|
|
||||||
|
GWT.log("Searching KPI name: " + name);
|
||||||
|
KPI foundKPI = null;
|
||||||
|
String purgedName = name.trim();
|
||||||
|
for (KPI kpi : selectedKPIs) {
|
||||||
|
String purgedKPIName = kpi.getName().trim();
|
||||||
|
if (purgedKPIName.compareToIgnoreCase(purgedName) == 0) {
|
||||||
|
foundKPI = kpi;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
GWT.log("FOUND KPI: " + foundKPI);
|
||||||
|
return foundKPI;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the parameters.
|
||||||
|
*
|
||||||
|
* @param keyToGet
|
||||||
|
* the key to get
|
||||||
|
* @param parameters
|
||||||
|
* the parameters
|
||||||
|
* @param toShowBatchTypeValue
|
||||||
|
* label to show batch type value
|
||||||
|
*/
|
||||||
|
public void addParameters(String keyToGet, Map<String, List<String>> parameters, String toShowBatchTypeValue) {
|
||||||
|
|
||||||
|
final FlexTable flexTable = new FlexTable();
|
||||||
|
flexTable.getElement().setId("CorrelationParameterInputKPIs");
|
||||||
|
flexTable.setStyleName("colgrouptable");
|
||||||
|
|
||||||
|
try {
|
||||||
|
List<String> dataInputs = parameters.get(keyToGet);
|
||||||
|
|
||||||
|
if (dataInputs == null || dataInputs.isEmpty())
|
||||||
|
return;
|
||||||
|
|
||||||
|
dataInputParameters = new HashMap<String, String>();
|
||||||
|
|
||||||
|
String theDataInputs = dataInputs.get(0);
|
||||||
|
String[] splittedParams = theDataInputs.split(";");
|
||||||
|
|
||||||
|
for (String splitParam : splittedParams) {
|
||||||
|
try {
|
||||||
|
String[] keyvalue = splitParam.split("=");
|
||||||
|
dataInputParameters.put(keyvalue[0], keyvalue[1]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
flexTable.setWidget(0, 0, new HTML("Batch Type:"));
|
||||||
|
flexTable.setWidget(0, 1, new HTML(toShowBatchTypeValue));
|
||||||
|
flexTable.setWidget(1, 0, new HTML("Level:"));
|
||||||
|
flexTable.setWidget(1, 1, new HTML(dataInputParameters.get(PerformFishAnalyticsConstant.DM_SCALEP_PARAM)));
|
||||||
|
|
||||||
|
String KPINames = "";
|
||||||
|
for (KPI kpi : selectedKPIs) {
|
||||||
|
KPINames += kpi.getName() + ", ";
|
||||||
|
}
|
||||||
|
KPINames = KPINames.substring(0, KPINames.length() - 2);
|
||||||
|
flexTable.setWidget(2, 0, new HTML("KPIs:"));
|
||||||
|
flexTable.setWidget(2, 1, new HTML(KPINames));
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
// silent
|
||||||
|
}
|
||||||
|
|
||||||
|
field_parameters_container.add(flexTable);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the list focus ids.
|
||||||
|
*
|
||||||
|
* @param listFocusIDs
|
||||||
|
* the list focus I ds
|
||||||
|
*/
|
||||||
|
public void addListFocusIds(List<String> listFocusIDs) {
|
||||||
|
for (String batchID : listFocusIDs) {
|
||||||
|
field_list_focus_id_correlation.addItem(batchID, batchID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getOutputId() {
|
||||||
|
outputNumber++;
|
||||||
|
String outputId = "OutputId_" + outputNumber;
|
||||||
|
GWT.log("Generated OutputId: " + outputId);
|
||||||
|
return outputId;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the results.
|
||||||
|
*
|
||||||
|
* @param dmResponse
|
||||||
|
* the dm response
|
||||||
|
*/
|
||||||
|
public void addResults(DataMinerResponse dmResponse) {
|
||||||
|
this.dmResponse = dmResponse;
|
||||||
|
|
||||||
|
outputNumber = 0;
|
||||||
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
|
||||||
|
if (outputFile.getDataType().equals(FileContentType.CSV)) {
|
||||||
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getCSVFile(outputFile, true,
|
||||||
|
new AsyncCallback<CSVFile>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
showAlert(caught.getMessage(), AlertType.ERROR, true,
|
||||||
|
uib_vp_correlation_results_container);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(CSVFile result) {
|
||||||
|
|
||||||
|
csvGenerated.put(result.getFileName(), result);
|
||||||
|
fillCorrelationMatrix();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void fillCorrelationMatrix() {
|
||||||
|
|
||||||
|
if (csvGenerated.size() < 2)
|
||||||
|
return;
|
||||||
|
|
||||||
|
String corrIndexFilename = null;
|
||||||
|
String corrFilename = null;
|
||||||
|
for (String fileName : csvGenerated.keySet()) {
|
||||||
|
if (fileName.contains("index")) {
|
||||||
|
corrIndexFilename = fileName;
|
||||||
|
} else {
|
||||||
|
corrFilename = fileName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
GWT.log("Correlation Matrix Index File: " + corrIndexFilename);
|
||||||
|
GWT.log("Correlation Matrix File: " + corrFilename);
|
||||||
|
CSVFile corrIndexCsvFile = csvGenerated.get(corrIndexFilename);
|
||||||
|
CSVFile corrCsvFile = csvGenerated.get(corrFilename);
|
||||||
|
GWT.log("Correlation Matrix Index CSV: " + corrIndexCsvFile);
|
||||||
|
GWT.log("Correlation Matrix CSV: " + corrCsvFile);
|
||||||
|
|
||||||
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
|
final FlexTable flexTable = new FlexTable();
|
||||||
|
flexTable.getElement().setId(getOutputId());
|
||||||
|
flexTable.setStyleName("fixedtable");
|
||||||
|
flexTable.getElement().getStyle().setMarginBottom(10, Unit.PX);
|
||||||
|
|
||||||
|
flexTable.setWidget(0, 0, new Label(""));
|
||||||
|
|
||||||
|
CSVRow headerRow = corrIndexCsvFile.getHeaderRow();
|
||||||
|
// HEADER
|
||||||
|
for (int i = 1; i < headerRow.getListValues().size(); i++) {
|
||||||
|
|
||||||
|
final String headerValue = headerRow.getListValues().get(i);
|
||||||
|
HTML label = new HTML(headerValue);
|
||||||
|
label.getElement().getStyle().setFontSize(16, Unit.PX);
|
||||||
|
|
||||||
|
final int columnIndex = i;
|
||||||
|
KPI kpi = getKPIForName(headerValue);
|
||||||
|
fillKPIReferenceForIndex(0, columnIndex, Arrays.asList(kpi));
|
||||||
|
flexTable.setWidget(0, i, label);
|
||||||
|
}
|
||||||
|
// DATA
|
||||||
|
for (int i = 0; i < corrIndexCsvFile.getValueRows().size(); i++) {
|
||||||
|
CSVRow row = corrIndexCsvFile.getValueRows().get(i);
|
||||||
|
CSVRow rowMatrixColor = corrCsvFile.getValueRows().get(i);
|
||||||
|
final int rowIndex = i + 1; // adding +1 for header row
|
||||||
|
for (int j = 0; j < row.getListValues().size(); j++) {
|
||||||
|
final String rowValue = row.getListValues().get(j);
|
||||||
|
final String rowMatrixColorValue = rowMatrixColor.getListValues().get(j);
|
||||||
|
final String theColor = CorrelationValueToColourUtil.getRGBColor(rowMatrixColorValue);
|
||||||
|
final int columnIndex = j;
|
||||||
|
final HTML buttonHTML = new HTML(rowValue);
|
||||||
|
buttonHTML.addStyleName("my-active-html");
|
||||||
|
if (j == 0) {
|
||||||
|
HTML label = new HTML(rowValue);
|
||||||
|
label.getElement().getStyle().setFontSize(16, Unit.PX);
|
||||||
|
flexTable.setWidget(rowIndex, j, label);
|
||||||
|
// rowValue is a KPI name
|
||||||
|
KPI kpi = getKPIForName(rowValue);
|
||||||
|
fillKPIReferenceForIndex(rowIndex, columnIndex, Arrays.asList(kpi));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// diagonal
|
||||||
|
else if (rowIndex == j) {
|
||||||
|
HTML dg = new HTML(rowValue);
|
||||||
|
dg.getElement().getStyle().setFontSize(18, Unit.PX);
|
||||||
|
flexTable.setWidget(rowIndex, j, dg);
|
||||||
|
continue;
|
||||||
|
// j > 0
|
||||||
|
} else {
|
||||||
|
KPI columnKPI = getKPIForName(headerRow.getListValues().get(columnIndex));
|
||||||
|
// Here the first index is the KPI name
|
||||||
|
KPI rowKPI = getKPIForName(row.getListValues().get(0));
|
||||||
|
fillKPIReferenceForIndex(rowIndex, columnIndex, Arrays.asList(columnKPI, rowKPI));
|
||||||
|
|
||||||
|
buttonHTML.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
|
||||||
|
// callScatterAndDeaChart(rowIndex, columnIndex,
|
||||||
|
// button);
|
||||||
|
callScatter(rowIndex, columnIndex, buttonHTML);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// button.setType(ButtonType.LINK);
|
||||||
|
// APPLYING STYLE ONLY ON INTERNAL VALUES OF CSV
|
||||||
|
if (j > 0)
|
||||||
|
buttonHTML.getElement().getStyle().setColor("#000");
|
||||||
|
|
||||||
|
buttonHTML.addAttachHandler(new AttachEvent.Handler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onAttachOrDetach(AttachEvent event) {
|
||||||
|
if (theColor.startsWith("#")) {
|
||||||
|
GWT.log("Setting backgrounf color: " + theColor);
|
||||||
|
buttonHTML.getElement().getParentElement().getStyle().setBackgroundColor(theColor);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
buttonHTML.getElement().getStyle().setBackgroundColor(theColor);
|
||||||
|
flexTable.setWidget(rowIndex, j, buttonHTML);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
hp.add(flexTable);
|
||||||
|
|
||||||
|
final FlexTable flexLegend = new FlexTable();
|
||||||
|
flexLegend.getElement().setId(getOutputId());
|
||||||
|
flexLegend.setStyleName("simpletable");
|
||||||
|
Map<String, String> map = CorrelationValueToColourUtil.getMap();
|
||||||
|
flexLegend.setWidget(0, 0, new Label("Legend"));
|
||||||
|
flexLegend.setWidget(0, 1, new HTML(""));
|
||||||
|
int i = 1;
|
||||||
|
for (String key : map.keySet()) {
|
||||||
|
final String rgbColor = map.get(key);
|
||||||
|
final HTML theLegendColor = new HTML("");
|
||||||
|
theLegendColor.getElement().getStyle().setBackgroundColor(rgbColor);
|
||||||
|
flexLegend.setWidget(i, 0, theLegendColor);
|
||||||
|
flexLegend.setWidget(i, 1, new HTML(key));
|
||||||
|
theLegendColor.addAttachHandler(new AttachEvent.Handler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onAttachOrDetach(AttachEvent event) {
|
||||||
|
theLegendColor.getElement().getParentElement().getStyle().setBackgroundColor(rgbColor);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
flexLegend.getElement().getStyle().setMarginLeft(15, Unit.PX);
|
||||||
|
hp.add(flexLegend);
|
||||||
|
uib_vp_correlation_results_container.insert(hp, 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fill kpi reference for index.
|
||||||
|
*
|
||||||
|
* @param rowIndex
|
||||||
|
* the row index
|
||||||
|
* @param columnIndex
|
||||||
|
* the column index
|
||||||
|
* @param listKPI
|
||||||
|
* the list kpi
|
||||||
|
*/
|
||||||
|
private void fillKPIReferenceForIndex(int rowIndex, int columnIndex, List<KPI> listKPI) {
|
||||||
|
|
||||||
|
String key = generateKey(rowIndex, columnIndex);
|
||||||
|
kpiMapPointers.put(key, listKPI);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the KPI for indexes.
|
||||||
|
*
|
||||||
|
* @param rowIndex
|
||||||
|
* the row index
|
||||||
|
* @param columnIndex
|
||||||
|
* the column index
|
||||||
|
* @return the KPI for indexes
|
||||||
|
*/
|
||||||
|
public List<KPI> getKPIForIndexes(int rowIndex, int columnIndex) {
|
||||||
|
String key = generateKey(rowIndex, columnIndex);
|
||||||
|
return kpiMapPointers.get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate key.
|
||||||
|
*
|
||||||
|
* @param rowIndex
|
||||||
|
* the row index
|
||||||
|
* @param columnIndex
|
||||||
|
* the column index
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
|
private String generateKey(int rowIndex, int columnIndex) {
|
||||||
|
return rowIndex + "-" + columnIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check valid focus id.
|
||||||
|
*
|
||||||
|
* @return the FocusID if it is valid, null otherwise.
|
||||||
|
*/
|
||||||
|
public String checkValidFocusID() {
|
||||||
|
|
||||||
|
cg_focus_id_correlation.setType(ControlGroupType.NONE);
|
||||||
|
|
||||||
|
// CHECK THE FOCUS ID VALUE
|
||||||
|
String focusID = field_list_focus_id_correlation.getSelectedItemText();
|
||||||
|
|
||||||
|
if (focusID == null || focusID.isEmpty()) {
|
||||||
|
|
||||||
|
String msgError = "Could not execute a valid Analysis.";
|
||||||
|
|
||||||
|
if (selectedAreas == null || selectedAreas.isEmpty()) {
|
||||||
|
msgError += " Please select another parameters computation";
|
||||||
|
} else {
|
||||||
|
msgError += " Select at least the Area of your FARM";
|
||||||
|
}
|
||||||
|
|
||||||
|
showAlert(msgError, AlertType.ERROR, true, uib_vp_correlation_results_container);
|
||||||
|
cg_focus_id_correlation.setType(ControlGroupType.ERROR);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return focusID;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Call scatter.
|
||||||
|
*
|
||||||
|
* @param rowIndex
|
||||||
|
* the row index
|
||||||
|
* @param columnIndex
|
||||||
|
* the column index
|
||||||
|
* @param button
|
||||||
|
* the button
|
||||||
|
*/
|
||||||
|
private void callScatter(int rowIndex, int columnIndex, HTML button) {
|
||||||
|
|
||||||
|
String focusID = checkValidFocusID();
|
||||||
|
|
||||||
|
if (focusID == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
GWT.log("Called ScatterChart at rowIndex: " + rowIndex + ", columnIndex: " + columnIndex);
|
||||||
|
List<KPI> selectedKPI = getKPIForIndexes(rowIndex, columnIndex);
|
||||||
|
GWT.log("Selected KPI: " + selectedKPI);
|
||||||
|
PerformFishAnalyticsController.eventBus
|
||||||
|
.fireEvent(new CallAlgorithmEvent(DataMinerAlgorithms.SCATTER, focusID, selectedKPI, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static native void saveFilePDF(CorrelationPanelResult chart, String filename, String tabTitle,
|
||||||
|
String tabDescr, int requestId, int outputNumber)/*-{
|
||||||
|
var that = this;
|
||||||
|
console.log('saveFilePDF()');
|
||||||
|
|
||||||
|
var tTitle = tabTitle;
|
||||||
|
var tDescr = tabDescr;
|
||||||
|
|
||||||
|
var pdoc = new jsPDF("p", "mm", "a4");
|
||||||
|
pdoc.setProperties({
|
||||||
|
title : 'PerformFish ' + tTitle,
|
||||||
|
subject : ' Results',
|
||||||
|
author : 'PerformFish',
|
||||||
|
keywords : 'PerformFish',
|
||||||
|
creator : 'D4Science'
|
||||||
|
});
|
||||||
|
|
||||||
|
var lMargin = 15; //left margin in mm
|
||||||
|
var rMargin = 15; //right margin in mm
|
||||||
|
var tMargin = 15; //top margin in mm
|
||||||
|
var bMargin = 15; //bottom margin in mm
|
||||||
|
var pdfWidthInMM = 210; // width of A4 in mm
|
||||||
|
var pdfHeightInMM = 297; // height of A4 in mm
|
||||||
|
var pageCenter = pdfWidthInMM / 2;
|
||||||
|
|
||||||
|
pdoc.setFontSize(24);
|
||||||
|
var title = "PerformFish " + tTitle;
|
||||||
|
var titleHeight = pdoc.getLineHeight(title) / pdoc.internal.scaleFactor
|
||||||
|
var xPos = lMargin;
|
||||||
|
var yPos = tMargin;
|
||||||
|
pdoc.text(title, pageCenter, yPos, 'center');
|
||||||
|
yPos += titleHeight;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
var lineHeight = pdoc.getLineHeight(tDescr) / pdoc.internal.scaleFactor
|
||||||
|
var splittedAnalysisDescription = pdoc.splitTextToSize(tDescr,
|
||||||
|
(pdfWidthInMM - lMargin - rMargin));
|
||||||
|
var lines = splittedAnalysisDescription.length // splitted text is a string array
|
||||||
|
var analysisDescriptionHeight = lines * lineHeight
|
||||||
|
|
||||||
|
pdoc.text(splittedAnalysisDescription, xPos, yPos, 'left');
|
||||||
|
yPos += analysisDescriptionHeight;
|
||||||
|
|
||||||
|
yPos += 4;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text("Parameters:", xPos, yPos, 'left');
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
yPos += 4;
|
||||||
|
|
||||||
|
var correlationParametersInputKPIs = $doc
|
||||||
|
.getElementById('CorrelationParameterInputKPIs');
|
||||||
|
|
||||||
|
console.log('InputKPIs: ' + correlationParametersInputKPIs);
|
||||||
|
|
||||||
|
pdoc.autoTable({
|
||||||
|
theme : 'plain',
|
||||||
|
startY : yPos,
|
||||||
|
pageBreak : 'auto',
|
||||||
|
columnStyles : {
|
||||||
|
0 : {
|
||||||
|
halign : 'left',
|
||||||
|
fillColor : [ 211, 225, 241 ]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
html : correlationParametersInputKPIs
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
//head : null,
|
||||||
|
// body : [
|
||||||
|
// [ 'Parameters',
|
||||||
|
// correlationParametersInputKPIs ]
|
||||||
|
// ]
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text("CORRELATION Matrix:", xPos, yPos, 'left');
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
yPos += 4;
|
||||||
|
|
||||||
|
console.log('OutputNumber: ' + outputNumber);
|
||||||
|
|
||||||
|
for (var i = 1; i <= outputNumber; i++) {
|
||||||
|
|
||||||
|
var outputId = 'OutputId_' + requestId + '_' + i;
|
||||||
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
|
var resultElement = $doc.getElementById(outputId);
|
||||||
|
|
||||||
|
console.log('Result Element: ' + resultElement);
|
||||||
|
var resultType = resultElement.className;
|
||||||
|
|
||||||
|
console.log('Result Element className: ' + resultType);
|
||||||
|
|
||||||
|
if (typeof resultType !== 'undefined' && resultType !== null
|
||||||
|
&& resultType !== '') {
|
||||||
|
|
||||||
|
if (resultType == 'fixedtable' || resultType == 'simpletable') {
|
||||||
|
console.log('Result Type csv: ' + i);
|
||||||
|
console.log('Result Content: ' + resultElement.innerHTML);
|
||||||
|
|
||||||
|
var checkColor = function(data) {
|
||||||
|
if (data.section === 'body') {
|
||||||
|
console.log(data);
|
||||||
|
if (typeof data.cell !== 'undefined'
|
||||||
|
&& data.cell !== null) {
|
||||||
|
if (typeof data.cell.raw !== 'undefined'
|
||||||
|
&& data.cell.raw !== null) {
|
||||||
|
console.log(data.cell.raw.innerHTML);
|
||||||
|
var positive = 'rgb(255, 68, 45)';
|
||||||
|
var negative = 'rgb(173, 216, 230)';
|
||||||
|
var nonsignificant = 'rgb(230, 223, 0)';
|
||||||
|
|
||||||
|
if (data.cell.raw.innerHTML
|
||||||
|
.indexOf(positive) >= 0) {
|
||||||
|
data.cell.styles.fillColor = [ 255, 68,
|
||||||
|
45 ];
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML
|
||||||
|
.indexOf(negative) >= 0) {
|
||||||
|
data.cell.styles.fillColor = [ 173,
|
||||||
|
216, 230 ];
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML
|
||||||
|
.indexOf(nonsignificant) >= 0) {
|
||||||
|
data.cell.styles.fillColor = [
|
||||||
|
230, 223, 0 ];
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
pdoc.autoTable({
|
||||||
|
theme : 'grid',
|
||||||
|
startY : yPos,
|
||||||
|
pageBreak : 'auto',
|
||||||
|
bodyStyles : {
|
||||||
|
fontSize : 9
|
||||||
|
},
|
||||||
|
didParseCell : checkColor,
|
||||||
|
html : resultElement
|
||||||
|
});
|
||||||
|
|
||||||
|
yPos = pdoc.previousAutoTable.finalY + 6;
|
||||||
|
} else {
|
||||||
|
if (resultType == 'image') {
|
||||||
|
console.log('Result Type image: ' + i);
|
||||||
|
var childrenTable = outputNumber.children;
|
||||||
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
|
var imageElement = secondDiv
|
||||||
|
.getElementsByTagName('img').item(0);
|
||||||
|
console.log('Image element: ' + imageElement);
|
||||||
|
pdoc.addImage(imageElement, lMargin, yPos);
|
||||||
|
console.log('Image Height: ' + imageElement.height);
|
||||||
|
yPos += (imageElement.height * 0.26458333);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
console.log('Result Type unknow: ' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('Result Type is undefined:' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 7) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var focusIDElement = $doc
|
||||||
|
.getElementById('field_list_focus_id_correlation');
|
||||||
|
console.log('FocusID Element: ' + focusIDElement);
|
||||||
|
var selectedIndex = focusIDElement.selectedIndex;
|
||||||
|
if (selectedIndex > -1) {
|
||||||
|
var value = focusIDElement[selectedIndex].innerText;
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
pdoc.text("Focus ID: "+value, xPos, yPos, 'left');
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
yPos += 4;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages = pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/" + numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Done');
|
||||||
|
|
||||||
|
pdoc.save(filename);
|
||||||
|
|
||||||
|
}-*/;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -9,6 +9,9 @@
|
||||||
|
|
||||||
<g:HTMLPanel ui:field="field_html_panel" addStyleNames="the_margin">
|
<g:HTMLPanel ui:field="field_html_panel" addStyleNames="the_margin">
|
||||||
|
|
||||||
|
<b:Button size="SMALL" ui:field="uib_save_pdf_1"
|
||||||
|
title="Save PDF" />
|
||||||
|
|
||||||
<g:VerticalPanel ui:field="field_parameters">
|
<g:VerticalPanel ui:field="field_parameters">
|
||||||
<g:VerticalPanel ui:field="field_parameters_container"
|
<g:VerticalPanel ui:field="field_parameters_container"
|
||||||
addStyleNames="the_margin_top_bottom">
|
addStyleNames="the_margin_top_bottom">
|
|
@ -12,6 +12,7 @@ import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsS
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
@ -32,19 +33,22 @@ import com.google.gwt.resources.client.TextResource;
|
||||||
import com.google.gwt.user.client.Window;
|
import com.google.gwt.user.client.Window;
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
import com.google.gwt.user.client.ui.ComplexPanel;
|
import com.google.gwt.user.client.ui.ComplexPanel;
|
||||||
|
import com.google.gwt.user.client.ui.HTML;
|
||||||
import com.google.gwt.user.client.ui.HorizontalPanel;
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
import com.google.gwt.user.client.ui.Panel;
|
import com.google.gwt.user.client.ui.Panel;
|
||||||
|
|
||||||
public class ScatterPanelResult {
|
public class ScatterPanelResult {
|
||||||
|
|
||||||
private PerformFishAnalyticsViewController viewController;
|
private PerformFishAnalyticsViewController viewController;
|
||||||
private int requestId;
|
private int requestId = 0;
|
||||||
private int outputIteration = 0;
|
private int outputIteration = 1;
|
||||||
private int outputNumber = 0;
|
private int outputNumber = 1;
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
public ScatterPanelResult(int reqId,PerformFishAnalyticsViewController viewController,
|
public ScatterPanelResult(int reqId, PerformFishAnalyticsViewController viewController,
|
||||||
final DataMinerAlgorithms algorithm, String focusID, List<KPI> inputKPI, final List<KPI> outputKPI) {
|
final DataMinerAlgorithms algorithm, String focusID, List<KPI> inputKPI, final List<KPI> outputKPI) {
|
||||||
this.requestId=reqId;
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
this.viewController = viewController;
|
this.viewController = viewController;
|
||||||
TextResource algDescr = PerformFishResources.INSTANCE.batch_SCATTER();
|
TextResource algDescr = PerformFishResources.INSTANCE.batch_SCATTER();
|
||||||
|
|
||||||
|
@ -60,21 +64,21 @@ public class ScatterPanelResult {
|
||||||
|
|
||||||
HorizontalPanel res = new HorizontalPanel();
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
Button savePDFButton = new Button();
|
savePDFButton = new Button();
|
||||||
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
savePDFButton.setIcon(IconType.PRINT);
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
savePDFButton.addClickHandler(new ClickHandler() {
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick(ClickEvent event) {
|
public void onClick(ClickEvent event) {
|
||||||
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId,outputIteration, outputNumber);
|
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId, outputIteration, outputNumber);
|
||||||
// dmResponse.getListOutput().size()
|
// dmResponse.getListOutput().size()
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
res.add(savePDFButton);
|
res.add(savePDFButton);
|
||||||
submitRequestPanel.addWidget(res);
|
submitRequestPanel.addWidget(res);
|
||||||
int oIteration = 1;
|
|
||||||
|
|
||||||
if (inputKPI.get(0) == null || inputKPI.get(1) == null) {
|
if (inputKPI.get(0) == null || inputKPI.get(1) == null) {
|
||||||
submitRequestPanel
|
submitRequestPanel
|
||||||
|
@ -85,13 +89,17 @@ public class ScatterPanelResult {
|
||||||
// again");
|
// again");
|
||||||
}
|
}
|
||||||
|
|
||||||
String titleScatter = "KPI: " + inputKPI.get(0).getName() + " vs " + inputKPI.get(1).getName();
|
String title = "KPI: " + inputKPI.get(0).getName() + " vs " + inputKPI.get(1).getName();
|
||||||
submitRequestPanel.setTheTitle(titleScatter);
|
HTML toBigTitle = new HTML(title);
|
||||||
|
toBigTitle.getElement().setId("KPI_Scatter_" + requestId + "_" + outputIteration);
|
||||||
|
toBigTitle.getElement().addClassName("to-big-title");
|
||||||
|
submitRequestPanel.addWidget(toBigTitle);
|
||||||
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
|
hp.getElement().addClassName("ext-horizontal-panel");
|
||||||
|
|
||||||
callDataMinerServiceForChart(viewController.getPerformFishResponse(), POPULATION_LEVEL.BATCH, inputKPI,
|
callDataMinerServiceForChart(viewController.getPerformFishResponse(), POPULATION_LEVEL.BATCH, inputKPI,
|
||||||
outputKPI, algorithm, focusID, submitRequestPanel, submitRequestPanel.getContainerPanel(), tab,
|
outputKPI, algorithm, focusID, submitRequestPanel, hp, tab, outputIteration);
|
||||||
oIteration);
|
submitRequestPanel.addWidget(hp);
|
||||||
outputIteration = oIteration;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,9 +199,15 @@ public class ScatterPanelResult {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, String title) {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
return outputId;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
final Panel container, boolean displayError, int oIteration) {
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
String title = displayError ? "No results " : "";
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
@ -206,16 +220,12 @@ public class ScatterPanelResult {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(true);
|
||||||
final String toTitle = title;
|
final String toTitle = title;
|
||||||
|
|
||||||
outputNumber = dmResponse.getListOutput().size();
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
|
||||||
int oNumber = 0;
|
|
||||||
|
|
||||||
for (final OutputFile outputFile : dmResponse.getListOutput()) {
|
|
||||||
oNumber++;
|
|
||||||
final String outputId = "OutputId_" + requestId+"_"+oIteration + "_" + oNumber;
|
|
||||||
|
|
||||||
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
switch (outputFile.getDataType()) {
|
switch (outputFile.getDataType()) {
|
||||||
case IMAGE:
|
case IMAGE:
|
||||||
PerformFishAnalyticsServiceAsync.Util.getInstance().getImageFile(outputFile,
|
PerformFishAnalyticsServiceAsync.Util.getInstance().getImageFile(outputFile,
|
||||||
|
@ -234,11 +244,11 @@ public class ScatterPanelResult {
|
||||||
public void onSuccess(String base64Content) {
|
public void onSuccess(String base64Content) {
|
||||||
String title = toTitle;
|
String title = toTitle;
|
||||||
|
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showImage(base64Content);
|
showResult.showImage(base64Content);
|
||||||
container.add(showResult);
|
container.add(showResult);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
|
@ -262,7 +272,8 @@ public class ScatterPanelResult {
|
||||||
|
|
||||||
String title = toTitle;
|
String title = toTitle;
|
||||||
|
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showCSVFile(result, cssTableStyle);
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
container.add(showResult);
|
container.add(showResult);
|
||||||
}
|
}
|
||||||
|
@ -277,8 +288,6 @@ public class ScatterPanelResult {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove the spinner if all DM responses are returned.
|
* Remove the spinner if all DM responses are returned.
|
||||||
*
|
*
|
||||||
|
@ -301,7 +310,7 @@ public class ScatterPanelResult {
|
||||||
int requestId, int outputIteration, int outputNumber)/*-{
|
int requestId, int outputIteration, int outputNumber)/*-{
|
||||||
var that = this;
|
var that = this;
|
||||||
console.log('saveFilePDF()');
|
console.log('saveFilePDF()');
|
||||||
console.log('requestId: '+requestId);
|
console.log('requestId: ' + requestId);
|
||||||
console.log('OutputIteration: ' + outputIteration);
|
console.log('OutputIteration: ' + outputIteration);
|
||||||
console.log('OutputNumber:' + outputNumber);
|
console.log('OutputNumber:' + outputNumber);
|
||||||
|
|
||||||
|
@ -349,9 +358,32 @@ public class ScatterPanelResult {
|
||||||
|
|
||||||
for (var i = 1; i <= outputIteration; i++) {
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
|
var kpiId = 'KPI_Scatter_' + requestId + '_' + i;
|
||||||
|
console.log('kpiId: ' + kpiId);
|
||||||
|
|
||||||
|
var kpiName = $doc.getElementById(kpiId);
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(14);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
|
||||||
|
var kpiText = kpiName.textContent;
|
||||||
|
var kpiHeight = pdoc.getLineHeight(kpiText)
|
||||||
|
/ pdoc.internal.scaleFactor;
|
||||||
|
var splittedKpiName = pdoc.splitTextToSize(kpiText, (pdfWidthInMM
|
||||||
|
- lMargin - rMargin));
|
||||||
|
var kpiLines = splittedKpiName.length; // splitted text is a string array
|
||||||
|
var kpiLinesHeight = kpiLines * kpiHeight;
|
||||||
|
pdoc.text(splittedKpiName, xPos, yPos, 'left');
|
||||||
|
yPos += kpiLinesHeight;
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
for (var j = 1; j <= outputNumber; j++) {
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
var outputId = 'OutputId_'+requestId+'_'+ i + '_' + j;
|
var outputId = 'OutputId_' + requestId + '_' + i + '_' + j;
|
||||||
console.log('OutputId: ' + outputId);
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
var resultOutputNumber = $doc.getElementById(outputId);
|
var resultOutputNumber = $doc.getElementById(outputId);
|
||||||
|
@ -369,6 +401,19 @@ public class ScatterPanelResult {
|
||||||
// foo could get resolved and it's defined
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var secondTable = secondDiv.children[0].children[0];
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
|
@ -389,6 +434,20 @@ public class ScatterPanelResult {
|
||||||
if (resultType == 'image') {
|
if (resultType == 'image') {
|
||||||
console.log('Result Type image: ' + i);
|
console.log('Result Type image: ' + i);
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var imageElement = secondDiv.getElementsByTagName(
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
'img').item(0);
|
'img').item(0);
|
||||||
|
@ -407,6 +466,26 @@ public class ScatterPanelResult {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 4) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages=pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/"+numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('Done');
|
console.log('Done');
|
||||||
|
|
|
@ -12,6 +12,7 @@ import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsS
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
@ -41,11 +42,13 @@ public class SpeedometerPanelResult {
|
||||||
private PerformFishAnalyticsViewController viewController;
|
private PerformFishAnalyticsViewController viewController;
|
||||||
private int requestId;
|
private int requestId;
|
||||||
private int outputIteration = 0;
|
private int outputIteration = 0;
|
||||||
private int outputNumber = 0;
|
private int outputNumber = 1;
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
public SpeedometerPanelResult(int reqId,PerformFishAnalyticsViewController viewController,
|
public SpeedometerPanelResult(int reqId, PerformFishAnalyticsViewController viewController,
|
||||||
final DataMinerAlgorithms algorithm, String focusID, List<KPI> inputKPI, final List<KPI> outputKPI) {
|
final DataMinerAlgorithms algorithm, String focusID, List<KPI> inputKPI, final List<KPI> outputKPI) {
|
||||||
this.requestId=reqId;
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
this.viewController = viewController;
|
this.viewController = viewController;
|
||||||
TextResource algDescr = PerformFishResources.INSTANCE.batch_SPEEDOMETER();
|
TextResource algDescr = PerformFishResources.INSTANCE.batch_SPEEDOMETER();
|
||||||
|
|
||||||
|
@ -61,16 +64,17 @@ public class SpeedometerPanelResult {
|
||||||
|
|
||||||
HorizontalPanel res = new HorizontalPanel();
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
Button savePDFButton = new Button();
|
savePDFButton = new Button();
|
||||||
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
savePDFButton.setIcon(IconType.PRINT);
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
savePDFButton.addClickHandler(new ClickHandler() {
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick(ClickEvent event) {
|
public void onClick(ClickEvent event) {
|
||||||
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId,outputIteration, outputNumber);
|
saveFilePDF(algorithm.getId(), tabTitle, tabTitle, tabDescr, requestId, outputIteration, outputNumber);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
res.add(savePDFButton);
|
res.add(savePDFButton);
|
||||||
submitRequestPanel.addWidget(res);
|
submitRequestPanel.addWidget(res);
|
||||||
|
@ -81,6 +85,7 @@ public class SpeedometerPanelResult {
|
||||||
oIteration++;
|
oIteration++;
|
||||||
String title = "KPI: " + kpi.getName();
|
String title = "KPI: " + kpi.getName();
|
||||||
HTML toBigTitle = new HTML(title);
|
HTML toBigTitle = new HTML(title);
|
||||||
|
toBigTitle.getElement().setId("KPI_Speedometer_" + requestId + "_" + oIteration);
|
||||||
toBigTitle.getElement().addClassName("to-big-title");
|
toBigTitle.getElement().addClassName("to-big-title");
|
||||||
submitRequestPanel.addWidget(toBigTitle);
|
submitRequestPanel.addWidget(toBigTitle);
|
||||||
HorizontalPanel hp = new HorizontalPanel();
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
|
@ -191,9 +196,15 @@ public class SpeedometerPanelResult {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, String title) {
|
||||||
|
String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
return outputId;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
final Panel container, boolean displayError, int oIteration) {
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
String title = displayError ? "No results " : "";
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
@ -206,15 +217,12 @@ public class SpeedometerPanelResult {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(true);
|
||||||
|
|
||||||
final String toTitle = title;
|
final String toTitle = title;
|
||||||
|
|
||||||
outputNumber = dmResponse.getListOutput().size();
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
int oNumber = 0;
|
|
||||||
|
|
||||||
for (final OutputFile outputFile : dmResponse.getListOutput()) {
|
|
||||||
oNumber++;
|
|
||||||
final String outputId = "OutputId_" +requestId+"_"+ oIteration + "_" + oNumber;
|
|
||||||
|
|
||||||
switch (outputFile.getDataType()) {
|
switch (outputFile.getDataType()) {
|
||||||
case IMAGE:
|
case IMAGE:
|
||||||
|
@ -238,7 +246,8 @@ public class SpeedometerPanelResult {
|
||||||
title += "Selected Batch ID: " + focusID + "<br>";
|
title += "Selected Batch ID: " + focusID + "<br>";
|
||||||
title += "Normalized with respect to all batches in the VRE";
|
title += "Normalized with respect to all batches in the VRE";
|
||||||
|
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showImage(base64Content);
|
showResult.showImage(base64Content);
|
||||||
container.add(showResult);
|
container.add(showResult);
|
||||||
|
|
||||||
|
@ -265,7 +274,8 @@ public class SpeedometerPanelResult {
|
||||||
|
|
||||||
String title = toTitle;
|
String title = toTitle;
|
||||||
|
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
String outputId = getOutputId(oIteration, title);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showCSVFile(result, cssTableStyle);
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
container.add(showResult);
|
container.add(showResult);
|
||||||
}
|
}
|
||||||
|
@ -280,8 +290,6 @@ public class SpeedometerPanelResult {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove the spinner if all DM responses are returned.
|
* Remove the spinner if all DM responses are returned.
|
||||||
*
|
*
|
||||||
|
@ -304,7 +312,7 @@ public class SpeedometerPanelResult {
|
||||||
int requestId, int outputIteration, int outputNumber)/*-{
|
int requestId, int outputIteration, int outputNumber)/*-{
|
||||||
var that = this;
|
var that = this;
|
||||||
console.log('saveFilePDF()');
|
console.log('saveFilePDF()');
|
||||||
console.log('requestId: '+requestId);
|
console.log('requestId: ' + requestId);
|
||||||
console.log('OutputIteration: ' + outputIteration);
|
console.log('OutputIteration: ' + outputIteration);
|
||||||
console.log('OutputNumber:' + outputNumber);
|
console.log('OutputNumber:' + outputNumber);
|
||||||
|
|
||||||
|
@ -352,9 +360,32 @@ public class SpeedometerPanelResult {
|
||||||
|
|
||||||
for (var i = 1; i <= outputIteration; i++) {
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
|
var kpiId = 'KPI_Speedometer_' + requestId + '_' + i;
|
||||||
|
console.log('kpiId: ' + kpiId);
|
||||||
|
|
||||||
|
var kpiName = $doc.getElementById(kpiId);
|
||||||
|
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(14);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
|
||||||
|
var kpiText = kpiName.textContent;
|
||||||
|
var kpiHeight = pdoc.getLineHeight(kpiText)
|
||||||
|
/ pdoc.internal.scaleFactor;
|
||||||
|
var splittedKpiName = pdoc.splitTextToSize(kpiText, (pdfWidthInMM
|
||||||
|
- lMargin - rMargin));
|
||||||
|
var kpiLines = splittedKpiName.length; // splitted text is a string array
|
||||||
|
var kpiLinesHeight = kpiLines * kpiHeight;
|
||||||
|
pdoc.text(splittedKpiName, xPos, yPos, 'left');
|
||||||
|
yPos += kpiLinesHeight;
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
for (var j = 1; j <= outputNumber; j++) {
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
var outputId = 'OutputId_'+requestId+'_'+ i + '_' + j;
|
var outputId = 'OutputId_' + requestId + '_' + i + '_' + j;
|
||||||
console.log('OutputId: ' + outputId);
|
console.log('OutputId: ' + outputId);
|
||||||
|
|
||||||
var resultOutputNumber = $doc.getElementById(outputId);
|
var resultOutputNumber = $doc.getElementById(outputId);
|
||||||
|
@ -372,6 +403,19 @@ public class SpeedometerPanelResult {
|
||||||
// foo could get resolved and it's defined
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var secondTable = secondDiv.children[0].children[0];
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
|
@ -392,6 +436,20 @@ public class SpeedometerPanelResult {
|
||||||
if (resultType == 'image') {
|
if (resultType == 'image') {
|
||||||
console.log('Result Type image: ' + i);
|
console.log('Result Type image: ' + i);
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var imageElement = secondDiv.getElementsByTagName(
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
'img').item(0);
|
'img').item(0);
|
||||||
|
@ -410,6 +468,26 @@ public class SpeedometerPanelResult {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 4) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages=pdoc.internal.getNumberOfPages()
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/"+numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('Done');
|
console.log('Done');
|
||||||
|
@ -417,4 +495,5 @@ public class SpeedometerPanelResult {
|
||||||
pdoc.save(filename);
|
pdoc.save(filename);
|
||||||
|
|
||||||
}-*/;
|
}-*/;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -92,6 +92,11 @@ public class SubmitRequestPanel extends Composite {
|
||||||
theTitle.setHTML("");
|
theTitle.setHTML("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void addTheTitleClassName(String className){
|
||||||
|
theTitle.getElement().addClassName(className);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the panel.
|
* Gets the panel.
|
||||||
*
|
*
|
||||||
|
|
|
@ -11,6 +11,7 @@ import org.gcube.portlets.user.performfishanalytics.client.PerformFishAnalyticsS
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
import org.gcube.portlets.user.performfishanalytics.client.controllers.PerformFishAnalyticsViewController;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
import org.gcube.portlets.user.performfishanalytics.client.resources.PerformFishResources;
|
||||||
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
import org.gcube.portlets.user.performfishanalytics.client.view.LoaderIcon;
|
||||||
|
import org.gcube.portlets.user.performfishanalytics.shared.FileContentType;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
import org.gcube.portlets.user.performfishanalytics.shared.KPI;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.OutputFile;
|
||||||
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
import org.gcube.portlets.user.performfishanalytics.shared.csv.CSVFile;
|
||||||
|
@ -40,12 +41,15 @@ public class SynopticTablePanelResult {
|
||||||
|
|
||||||
private PerformFishAnalyticsViewController viewController;
|
private PerformFishAnalyticsViewController viewController;
|
||||||
private int requestId;
|
private int requestId;
|
||||||
private int outputIteration = 0;
|
private int outputIteration = 1;
|
||||||
private int outputNumber = 0;
|
private int outputNumber = 0;
|
||||||
|
|
||||||
|
private Button savePDFButton;
|
||||||
|
|
||||||
public SynopticTablePanelResult(int reqId, PerformFishAnalyticsViewController viewController,
|
public SynopticTablePanelResult(int reqId, PerformFishAnalyticsViewController viewController,
|
||||||
PerformFishResponse performFishResponse, final Map<String, List<String>> performFishRequestParameters) {
|
PerformFishResponse performFishResponse, final Map<String, List<String>> performFishRequestParameters) {
|
||||||
this.requestId = reqId;
|
GWT.log("RequestID: " + reqId);
|
||||||
|
requestId = reqId;
|
||||||
this.viewController = viewController;
|
this.viewController = viewController;
|
||||||
|
|
||||||
String batchTableURL = performFishResponse.getMapParameters().get(PerformFishAnalyticsConstant.BATCHES_TABLE);
|
String batchTableURL = performFishResponse.getMapParameters().get(PerformFishAnalyticsConstant.BATCHES_TABLE);
|
||||||
|
@ -103,7 +107,7 @@ public class SynopticTablePanelResult {
|
||||||
PerformFishResources.INSTANCE.synopticTable().getText(), submitRequestPanel);
|
PerformFishResources.INSTANCE.synopticTable().getText(), submitRequestPanel);
|
||||||
HorizontalPanel res = new HorizontalPanel();
|
HorizontalPanel res = new HorizontalPanel();
|
||||||
|
|
||||||
Button savePDFButton = new Button();
|
savePDFButton = new Button();
|
||||||
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
savePDFButton.getElement().getStyle().setMargin(10, Unit.PX);
|
||||||
savePDFButton.setIcon(IconType.PRINT);
|
savePDFButton.setIcon(IconType.PRINT);
|
||||||
savePDFButton.addClickHandler(new ClickHandler() {
|
savePDFButton.addClickHandler(new ClickHandler() {
|
||||||
|
@ -114,10 +118,10 @@ public class SynopticTablePanelResult {
|
||||||
// dmResponse.getListOutput().size()
|
// dmResponse.getListOutput().size()
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
res.add(savePDFButton);
|
res.add(savePDFButton);
|
||||||
submitRequestPanel.addWidget(res);
|
submitRequestPanel.addWidget(res);
|
||||||
outputIteration=1;
|
|
||||||
|
|
||||||
final HTMLPanel panelContainer = submitRequestPanel.getContainerPanel();
|
final HTMLPanel panelContainer = submitRequestPanel.getContainerPanel();
|
||||||
|
|
||||||
|
@ -144,7 +148,7 @@ public class SynopticTablePanelResult {
|
||||||
// field_unary_algorithm.setVisible(true);
|
// field_unary_algorithm.setVisible(true);
|
||||||
GWT.log("I'm displaying: " + dmResponse);
|
GWT.log("I'm displaying: " + dmResponse);
|
||||||
displayOutputFilesAsStaticEntities(dmResponse, toFinalChartType, null, null, null,
|
displayOutputFilesAsStaticEntities(dmResponse, toFinalChartType, null, null, null,
|
||||||
panelContainer, false, 1);
|
panelContainer, false, outputIteration);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -152,7 +156,7 @@ public class SynopticTablePanelResult {
|
||||||
loaderIcon.setVisible(false);
|
loaderIcon.setVisible(false);
|
||||||
checkTabSpinner(submitRequestPanel, tab);
|
checkTabSpinner(submitRequestPanel, tab);
|
||||||
displayOutputFilesAsStaticEntities(null, toFinalChartType, null, null, null, panelContainer,
|
displayOutputFilesAsStaticEntities(null, toFinalChartType, null, null, null, panelContainer,
|
||||||
true, 1);
|
true, outputIteration);
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -177,9 +181,20 @@ public class SynopticTablePanelResult {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getOutputId(int oIteration, boolean isLegend) {
|
||||||
|
String outputId;
|
||||||
|
if (isLegend) {
|
||||||
|
outputId = "OutputId_" + requestId + "_" + oIteration + "_" + 1;
|
||||||
|
} else {
|
||||||
|
outputNumber++;
|
||||||
|
outputId = "OutputId_" + requestId + "_" + oIteration + "_" + outputNumber;
|
||||||
|
}
|
||||||
|
return outputId;
|
||||||
|
}
|
||||||
|
|
||||||
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
private void displayOutputFilesAsStaticEntities(final DataMinerResponse dmResponse,
|
||||||
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
final DataMinerAlgorithms chartType, List<KPI> inputKPIs, List<KPI> outputKPIs, final String focusID,
|
||||||
final Panel container, boolean displayError, int oIteration) {
|
final Panel container, boolean displayError, final int oIteration) {
|
||||||
|
|
||||||
String title = displayError ? "No results " : "";
|
String title = displayError ? "No results " : "";
|
||||||
|
|
||||||
|
@ -192,15 +207,15 @@ public class SynopticTablePanelResult {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
savePDFButton.setVisible(false);
|
||||||
|
|
||||||
final String toTitle = title;
|
final String toTitle = title;
|
||||||
|
|
||||||
outputNumber = dmResponse.getListOutput().size();
|
outputNumber = 1;
|
||||||
|
|
||||||
int oNumber = 0;
|
for (OutputFile outputFile : dmResponse.getListOutput()) {
|
||||||
|
|
||||||
for (final OutputFile outputFile : dmResponse.getListOutput()) {
|
final FileContentType fileContentType = outputFile.getDataType();
|
||||||
oNumber++;
|
|
||||||
final String outputId = "OutputId_" + requestId + "_" + oIteration + "_" + oNumber;
|
|
||||||
|
|
||||||
switch (outputFile.getDataType()) {
|
switch (outputFile.getDataType()) {
|
||||||
case IMAGE:
|
case IMAGE:
|
||||||
|
@ -221,7 +236,8 @@ public class SynopticTablePanelResult {
|
||||||
|
|
||||||
String title = toTitle;
|
String title = toTitle;
|
||||||
|
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
String outputId = getOutputId(oIteration, false);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showImage(base64Content);
|
showResult.showImage(base64Content);
|
||||||
container.add(showResult);
|
container.add(showResult);
|
||||||
|
|
||||||
|
@ -252,14 +268,16 @@ public class SynopticTablePanelResult {
|
||||||
case PERFORMFISH_SYNOPTICTABLE_BATCH_HATCHERY:
|
case PERFORMFISH_SYNOPTICTABLE_BATCH_HATCHERY:
|
||||||
case PERFORMFISH_SYNOPTICTABLE_BATCH_PREGROW:
|
case PERFORMFISH_SYNOPTICTABLE_BATCH_PREGROW:
|
||||||
|
|
||||||
|
String outputId;
|
||||||
if (!result.getFileName().contains("legend")) {
|
if (!result.getFileName().contains("legend")) {
|
||||||
cssTableStyle = "synoptictable-batch";
|
cssTableStyle = "synoptictable-farm";
|
||||||
|
outputId = getOutputId(oIteration, false);
|
||||||
} else {
|
} else {
|
||||||
cssTableStyle = "simpletable-synoptic";
|
cssTableStyle = "simpletable-synoptic";
|
||||||
|
outputId = getOutputId(oIteration, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
ShowResult showResultSin = new ShowResult(outputId, title,
|
ShowResult showResultSin = new ShowResult(outputId, title, fileContentType);
|
||||||
outputFile.getDataType());
|
|
||||||
showResultSin.showCSVFile(result, cssTableStyle);
|
showResultSin.showCSVFile(result, cssTableStyle);
|
||||||
displayingOrderedSynopticTable(dmResponse, result.getFileName(), container,
|
displayingOrderedSynopticTable(dmResponse, result.getFileName(), container,
|
||||||
showResultSin);
|
showResultSin);
|
||||||
|
@ -271,7 +289,9 @@ public class SynopticTablePanelResult {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// ALL OTHER CASES
|
// ALL OTHER CASES
|
||||||
ShowResult showResult = new ShowResult(outputId, title, outputFile.getDataType());
|
|
||||||
|
String outputId = getOutputId(oIteration, false);
|
||||||
|
ShowResult showResult = new ShowResult(outputId, title, fileContentType);
|
||||||
showResult.showCSVFile(result, cssTableStyle);
|
showResult.showCSVFile(result, cssTableStyle);
|
||||||
container.add(showResult);
|
container.add(showResult);
|
||||||
}
|
}
|
||||||
|
@ -356,7 +376,7 @@ public class SynopticTablePanelResult {
|
||||||
//pdoc.text("Analysis:", xPos, yPos, 'left');
|
//pdoc.text("Analysis:", xPos, yPos, 'left');
|
||||||
yPos += 6;
|
yPos += 6;
|
||||||
|
|
||||||
for (var i = 1; i <= outputIteration; i++) {
|
for (var i = 1; i <= outputIteration; i++) {
|
||||||
|
|
||||||
for (var j = 1; j <= outputNumber; j++) {
|
for (var j = 1; j <= outputNumber; j++) {
|
||||||
|
|
||||||
|
@ -378,11 +398,85 @@ public class SynopticTablePanelResult {
|
||||||
// foo could get resolved and it's defined
|
// foo could get resolved and it's defined
|
||||||
|
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
var titleCurrentTable = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current table: '
|
||||||
|
+ titleCurrentTable.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentTable.textContent, xPos, yPos,
|
||||||
|
'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var secondTable = secondDiv.children[0].children[0];
|
var secondTable = secondDiv.children[0].children[0];
|
||||||
|
|
||||||
console.log('CSV SecondTable: ' + secondTable);
|
console.log('CSV SecondTable: ' + secondTable);
|
||||||
|
|
||||||
|
var checkColor = function(data) {
|
||||||
|
if (data.section === 'body') {
|
||||||
|
console.log(data);
|
||||||
|
var good = '<div class="gwt-HTML"><span style="padding-left: 10px; padding-right: 10px; background-color: limegreen; border: 1px solid limegreen;"></span></div>';
|
||||||
|
var normal = '<div class="gwt-HTML"><span style="padding-left: 10px; padding-right: 10px; background-color: yellow; border: 1px solid yellow;"></span></div>';
|
||||||
|
var bad = '<div class="gwt-HTML"><span style="padding-left: 10px; padding-right: 10px; background-color: red;border: 1px solid red;"></span></div>';
|
||||||
|
|
||||||
|
if (typeof data.cell !== 'undefined'
|
||||||
|
&& data.cell !== null) {
|
||||||
|
if (typeof data.cell.raw !== 'undefined'
|
||||||
|
&& data.cell.raw !== null) {
|
||||||
|
|
||||||
|
console.log(data.cell.raw.innerHTML);
|
||||||
|
if (data.cell.raw.innerHTML === good) {
|
||||||
|
console.log('good');
|
||||||
|
var posIW = (data.cell.x + (data.cell.width / 2)-2);
|
||||||
|
var posIH = (data.cell.y + (data.cell.height / 2)-2);
|
||||||
|
var greenImg = ''
|
||||||
|
pdoc.addImage(greenImg, 'JPEG', posIW, posIH, 4, 4);
|
||||||
|
//pdoc.setFontSize(10);
|
||||||
|
//pdoc.setFontType("normal");
|
||||||
|
//var posW = (data.cell.x + (data.cell.width / 2));
|
||||||
|
//var posH = (data.cell.y + (data.cell.height / 2));
|
||||||
|
//pdoc.text('G', posW, posH,'center');
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML === normal) {
|
||||||
|
console.log('normal');
|
||||||
|
var posIW = (data.cell.x + (data.cell.width / 2)-2);
|
||||||
|
var posIH = (data.cell.y + (data.cell.height / 2)-2);
|
||||||
|
var yellowImg = ''
|
||||||
|
pdoc.addImage(yellowImg, 'JPEG', posIW, posIH, 4, 4);
|
||||||
|
//pdoc.setFontSize(10);
|
||||||
|
//pdoc.setFontType("normal");
|
||||||
|
//var posW = (data.cell.x + (data.cell.width / 2));
|
||||||
|
//var posH = (data.cell.y + (data.cell.height / 2));
|
||||||
|
//pdoc.text('N', posW, posH,'center');
|
||||||
|
} else {
|
||||||
|
if (data.cell.raw.innerHTML === bad) {
|
||||||
|
console.log('bad');
|
||||||
|
var posIW = (data.cell.x + (data.cell.width / 2)-2);
|
||||||
|
var posIH = (data.cell.y + (data.cell.height / 2)-2);
|
||||||
|
var redImg = ''
|
||||||
|
pdoc.addImage(redImg, 'JPEG', posIW, posIH, 4, 4);
|
||||||
|
//pdoc.setFontSize(10);
|
||||||
|
//pdoc.setFontType("normal");
|
||||||
|
//var posW = (data.cell.x + (data.cell.width / 2));
|
||||||
|
//var posH = (data.cell.y + (data.cell.height / 2));
|
||||||
|
//pdoc.text('B', posW, posH,'center');
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
pdoc.autoTable({
|
pdoc.autoTable({
|
||||||
theme : 'grid',
|
theme : 'grid',
|
||||||
startY : yPos,
|
startY : yPos,
|
||||||
|
@ -390,6 +484,7 @@ public class SynopticTablePanelResult {
|
||||||
bodyStyles : {
|
bodyStyles : {
|
||||||
fontSize : 9
|
fontSize : 9
|
||||||
},
|
},
|
||||||
|
didDrawCell : checkColor,
|
||||||
html : secondTable
|
html : secondTable
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -398,6 +493,20 @@ public class SynopticTablePanelResult {
|
||||||
if (resultType == 'image') {
|
if (resultType == 'image') {
|
||||||
console.log('Result Type image: ' + i);
|
console.log('Result Type image: ' + i);
|
||||||
var childrenTable = resultOutputNumber.children;
|
var childrenTable = resultOutputNumber.children;
|
||||||
|
|
||||||
|
var titleCurrentImage = childrenTable[0].rows[0].cells[0];
|
||||||
|
console.log('Title current image: '
|
||||||
|
+ titleCurrentImage.textContent);
|
||||||
|
yPos += 2;
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("bold");
|
||||||
|
pdoc.text(titleCurrentImage.textContent, xPos,
|
||||||
|
yPos, 'left');
|
||||||
|
yPos += 6;
|
||||||
|
|
||||||
|
pdoc.setFontSize(10);
|
||||||
|
pdoc.setFontType("normal");
|
||||||
|
|
||||||
var secondDiv = childrenTable[0].rows[1].cells[0];
|
var secondDiv = childrenTable[0].rows[1].cells[0];
|
||||||
var imageElement = secondDiv.getElementsByTagName(
|
var imageElement = secondDiv.getElementsByTagName(
|
||||||
'img').item(0);
|
'img').item(0);
|
||||||
|
@ -416,6 +525,26 @@ public class SynopticTablePanelResult {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (i == outputNumber) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (pdfHeightInMM - yPos < pdfHeightInMM / 7) {
|
||||||
|
pdoc.addPage();
|
||||||
|
yPos = tMargin; // Restart position
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var numberOfPages = pdoc.internal.getNumberOfPages();
|
||||||
|
console.log('NumberOfPages: ' + numberOfPages);
|
||||||
|
for (var k = 1; k <= numberOfPages; k++) {
|
||||||
|
pdoc.setPage(k);
|
||||||
|
console.log('CurrentPage: ' + k);
|
||||||
|
var footner = 'Page ' + k + "/" + numberOfPages;
|
||||||
|
pdoc.text(footner, pageCenter, pdfHeightInMM - 7, 'center');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('Done');
|
console.log('Done');
|
||||||
|
@ -423,5 +552,4 @@ public class SynopticTablePanelResult {
|
||||||
pdoc.save(filename);
|
pdoc.save(filename);
|
||||||
|
|
||||||
}-*/;
|
}-*/;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue