Applied CQL_Filter for cross filtering

This commit is contained in:
Francesco Mangiacrapa 2023-05-31 17:02:03 +02:00
parent 9d48e78fac
commit 33d6dbc89f
9 changed files with 448 additions and 144 deletions

View File

@ -60,6 +60,7 @@
@ -143,6 +144,7 @@
@ -226,6 +228,7 @@
@ -309,6 +312,7 @@
@ -392,6 +396,7 @@
@ -475,6 +480,7 @@
@ -561,6 +567,7 @@
@ -644,6 +651,7 @@
@ -727,6 +735,7 @@
@ -810,6 +819,7 @@

View File

@ -12,6 +12,7 @@ import org.gcube.application.geoportalcommon.shared.GNADataViewerConfigProfile;
import org.gcube.application.geoportalcommon.shared.GeoportalItemReferences; import org.gcube.application.geoportalcommon.shared.GeoportalItemReferences;
import org.gcube.application.geoportalcommon.shared.geoportal.config.GroupedLayersDV; import org.gcube.application.geoportalcommon.shared.geoportal.config.GroupedLayersDV;
import org.gcube.application.geoportalcommon.shared.geoportal.config.layers.LayerIDV; import org.gcube.application.geoportalcommon.shared.geoportal.config.layers.LayerIDV;
import org.gcube.application.geoportalcommon.shared.geoportal.materialization.GCubeSDILayer;
import org.gcube.application.geoportalcommon.shared.geoportal.materialization.IndexLayerDV; import org.gcube.application.geoportalcommon.shared.geoportal.materialization.IndexLayerDV;
import org.gcube.application.geoportalcommon.shared.geoportal.project.ProjectDV; import org.gcube.application.geoportalcommon.shared.geoportal.project.ProjectDV;
import org.gcube.application.geoportalcommon.shared.geoportal.project.RelationshipDV; import org.gcube.application.geoportalcommon.shared.geoportal.project.RelationshipDV;
@ -24,6 +25,8 @@ import org.gcube.portlets.user.geoportaldataviewer.client.events.AddLayerToMapEv
import org.gcube.portlets.user.geoportaldataviewer.client.events.AddedLayerToMapEvent; import org.gcube.portlets.user.geoportaldataviewer.client.events.AddedLayerToMapEvent;
import org.gcube.portlets.user.geoportaldataviewer.client.events.AddedLayerToMapEvent.LAYER_TYPE; import org.gcube.portlets.user.geoportaldataviewer.client.events.AddedLayerToMapEvent.LAYER_TYPE;
import org.gcube.portlets.user.geoportaldataviewer.client.events.AddedLayerToMapEventHandler; import org.gcube.portlets.user.geoportaldataviewer.client.events.AddedLayerToMapEventHandler;
import org.gcube.portlets.user.geoportaldataviewer.client.events.ApplyCQLToLayerMapEvent;
import org.gcube.portlets.user.geoportaldataviewer.client.events.ApplyCQLToLayerMapEventHandler;
import org.gcube.portlets.user.geoportaldataviewer.client.events.ChangeMapLayerEvent; import org.gcube.portlets.user.geoportaldataviewer.client.events.ChangeMapLayerEvent;
import org.gcube.portlets.user.geoportaldataviewer.client.events.ChangeMapLayerEventHandler; import org.gcube.portlets.user.geoportaldataviewer.client.events.ChangeMapLayerEventHandler;
import org.gcube.portlets.user.geoportaldataviewer.client.events.ClosedViewDetailsEvent; import org.gcube.portlets.user.geoportaldataviewer.client.events.ClosedViewDetailsEvent;
@ -863,9 +866,6 @@ public class GeoportalDataViewer implements EntryPoint {
cqlFilter = cqlFilter.substring(0, cqlFilter.length() - 1) + ")"; cqlFilter = cqlFilter.substring(0, cqlFilter.length() - 1) + ")";
setCqlFilter = cqlFilter; setCqlFilter = cqlFilter;
setCqlFilter = "INTERSECTS(geom,querySingle('limiti_amministrativi:regioni','the_geom','DEN_REG=''Calabria'''));INCLUDE";
GWT.log("HARD-CODED CQL FILTER: " + setCqlFilter);
olMapMng.getOLMap().setCQLFilterToWMSLayer(layerName, setCqlFilter); olMapMng.getOLMap().setCQLFilterToWMSLayer(layerName, setCqlFilter);
} else { } else {
@ -886,6 +886,48 @@ public class GeoportalDataViewer implements EntryPoint {
} }
}); });
applicationBus.addHandler(ApplyCQLToLayerMapEvent.TYPE, new ApplyCQLToLayerMapEventHandler() {
@Override
public void onApplyCQL(ApplyCQLToLayerMapEvent applyCQLToLayerMapEvent) {
GWT.log("Fired: " + applyCQLToLayerMapEvent);
if (applyCQLToLayerMapEvent != null) {
String layerName = null;
GCubeSDILayer layer = applyCQLToLayerMapEvent.getTheIndeLayer().getLayer();
try {
String wmsLink = layer.getOgcLinks().get("wms");
layerName = URLUtil.extractValueOfParameterFromURL("layers", wmsLink);
} catch (Exception e) {
// TODO: handle exception
}
String setCqlFilter = null;
if (layerName != null) {
GWT.log("ApplyCQLToLayerMapEvent: " + layerName + ", filter : "
+ applyCQLToLayerMapEvent.getCqlFilterValue());
if (applyCQLToLayerMapEvent.getCqlFilterValue() == null) {
olMapMng.getOLMap().setCQLFilterToWMSLayer(layerName, null);
setCqlFilter = null; // is already null
} else {
setCqlFilter = applyCQLToLayerMapEvent.getCqlFilterValue();
olMapMng.getOLMap().setCQLFilterToWMSLayer(layerName, setCqlFilter);
}
layerManager.setCQLForLayerToIndexLayer(layerName, setCqlFilter);
}
}
}
});
} }
/** /**

View File

@ -0,0 +1,72 @@
package org.gcube.portlets.user.geoportaldataviewer.client.events;
import org.gcube.application.geoportalcommon.shared.geoportal.materialization.IndexLayerDV;
import com.google.gwt.event.shared.GwtEvent;
/**
* The Class AddedLayerToMapEvent.
*
* @author Francesco Mangiacrapa at ISTI-CNR (francesco.mangiacrapa@isti.cnr.it)
*
* Nov 18, 2020
*/
public class ApplyCQLToLayerMapEvent extends GwtEvent<ApplyCQLToLayerMapEventHandler> {
public static Type<ApplyCQLToLayerMapEventHandler> TYPE = new Type<ApplyCQLToLayerMapEventHandler>();
private IndexLayerDV theIndeLayer;
private String cqlFilterValue;
/**
* Instantiates a new apply CQL to layer map event.
*
* @param theIndeLayer the the inde layer
* @param cqlFilter the cql filter
*/
public ApplyCQLToLayerMapEvent(IndexLayerDV theIndeLayer, String cqlFilterValue) {
this.theIndeLayer = theIndeLayer;
this.cqlFilterValue = cqlFilterValue;
}
/**
* Gets the associated type.
*
* @return the associated type
*/
@Override
public Type<ApplyCQLToLayerMapEventHandler> getAssociatedType() {
return TYPE;
}
/**
* Dispatch.
*
* @param handler the handler
*/
@Override
protected void dispatch(ApplyCQLToLayerMapEventHandler handler) {
handler.onApplyCQL(this);
}
public IndexLayerDV getTheIndeLayer() {
return theIndeLayer;
}
public String getCqlFilterValue() {
return cqlFilterValue;
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("ApplyCQLToLayerMapEvent [theIndeLayer=");
builder.append(theIndeLayer);
builder.append(", cqlFilterValue=");
builder.append(cqlFilterValue);
builder.append("]");
return builder.toString();
}
}

View File

@ -0,0 +1,20 @@
package org.gcube.portlets.user.geoportaldataviewer.client.events;
import com.google.gwt.event.shared.EventHandler;
/**
* The Interface ApplyCQLToLayerMapEventHandler.
*
* @author Francesco Mangiacrapa at ISTI-CNR francesco.mangiacrapa@isti.cnr.it
*
* May 31, 2023
*/
public interface ApplyCQLToLayerMapEventHandler extends EventHandler {
/**
* On apply CQL.
*
* @param applyCQLToLayerMapEvent the apply CQL to layer map event
*/
void onApplyCQL(ApplyCQLToLayerMapEvent applyCQLToLayerMapEvent);
}

View File

@ -741,12 +741,12 @@ public class GeonaDataViewMainPanel extends Composite {
lcInner.add(overlayGroupDescr); lcInner.add(overlayGroupDescr);
// panelCustomOverlayLayers.add(overlayGroupDescr); // panelCustomOverlayLayers.add(overlayGroupDescr);
} }
lcInner.add(new CrossFilteringLayerPanel(groupedLayerDV, applicationBus)); CrossFilteringLayerPanel cfp = new CrossFilteringLayerPanel(collection, groupedLayerDV, applicationBus);
cfp.setFilterButton(linkCrossFilteringLayers);
lcInner.add(cfp);
panelCrossFilteringLayers.add(lcInner); panelCrossFilteringLayers.add(lcInner);
} }
//panelCrossFilteringLayers.add(new CrossFilteringLayerPanel(groupedLayerDV, applicationBus));
linkCrossFilteringLayers.setVisible(listGroupedLayers.size() > 0); linkCrossFilteringLayers.setVisible(listGroupedLayers.size() > 0);
} }

View File

@ -127,6 +127,7 @@ public class SearchFacilityUI extends Composite {
* *
* @param profileID the profile ID * @param profileID the profile ID
* @param appManagerBus the app manager bus * @param appManagerBus the app manager bus
* @param displayByFields the display by fields
* @param sortByFields the sort by fields * @param sortByFields the sort by fields
* @param searchForFields the search for fields * @param searchForFields the search for fields
* @param initialSortFilter the initial sort filter * @param initialSortFilter the initial sort filter
@ -237,6 +238,9 @@ public class SearchFacilityUI extends Composite {
} }
/**
* Reset current search.
*/
public void resetCurrentSearch() { public void resetCurrentSearch() {
searchField.setText(""); searchField.setText("");
resetSearch.setVisible(false); resetSearch.setVisible(false);
@ -356,7 +360,8 @@ public class SearchFacilityUI extends Composite {
profileID); profileID);
// here // here
appManagerBus.fireEvent(new ClosedViewDetailsEvent()); appManagerBus.fireEvent(new ClosedViewDetailsEvent());
appManagerBus.fireEvent(new ShowDetailsEvent(gir, null, true, true, EVENT_SOURCE.LOCATE_SEARCHED)); appManagerBus.fireEvent(
new ShowDetailsEvent(gir, null, true, true, EVENT_SOURCE.LOCATE_SEARCHED));
// appManagerBus.fireEvent(new ShowPopupOnCentroidEvent(profileID, // appManagerBus.fireEvent(new ShowPopupOnCentroidEvent(profileID,
// resultDoc.getProjectID(), resultDoc.getSpatialReference())); // resultDoc.getProjectID(), resultDoc.getSpatialReference()));

View File

@ -9,19 +9,26 @@ import org.gcube.application.geoportalcommon.shared.geoportal.config.GroupedLaye
import org.gcube.application.geoportalcommon.shared.geoportal.config.layers.CrossFilteringLayerDV; import org.gcube.application.geoportalcommon.shared.geoportal.config.layers.CrossFilteringLayerDV;
import org.gcube.application.geoportalcommon.shared.geoportal.config.layers.LayerIDV; import org.gcube.application.geoportalcommon.shared.geoportal.config.layers.LayerIDV;
import org.gcube.portlets.user.geoportaldataviewer.client.GeoportalDataViewerConstants.MAP_PROJECTION; import org.gcube.portlets.user.geoportaldataviewer.client.GeoportalDataViewerConstants.MAP_PROJECTION;
import org.gcube.portlets.user.geoportaldataviewer.client.events.ApplyCQLToLayerMapEvent;
import org.gcube.portlets.user.geoportaldataviewer.client.ui.util.OLGeoJSONUtil; import org.gcube.portlets.user.geoportaldataviewer.client.ui.util.OLGeoJSONUtil;
import org.gcube.portlets.user.geoportaldataviewer.shared.GCubeCollection;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.LayerItem; import org.gcube.portlets.user.geoportaldataviewer.shared.gis.LayerItem;
import org.gcube.portlets.user.geoportaldataviewer.shared.gis.wms.GeoInformationForWMSRequest; import org.gcube.portlets.user.geoportaldataviewer.shared.gis.wms.GeoInformationForWMSRequest;
import com.github.gwtbootstrap.client.ui.Button;
import com.github.gwtbootstrap.client.ui.CheckBox; import com.github.gwtbootstrap.client.ui.CheckBox;
import com.github.gwtbootstrap.client.ui.ControlGroup; import com.github.gwtbootstrap.client.ui.ControlGroup;
import com.github.gwtbootstrap.client.ui.ControlLabel; import com.github.gwtbootstrap.client.ui.ControlLabel;
import com.github.gwtbootstrap.client.ui.Controls; import com.github.gwtbootstrap.client.ui.Controls;
import com.github.gwtbootstrap.client.ui.DropdownButton;
import com.github.gwtbootstrap.client.ui.Fieldset; import com.github.gwtbootstrap.client.ui.Fieldset;
import com.github.gwtbootstrap.client.ui.ListBox; import com.github.gwtbootstrap.client.ui.ListBox;
import com.github.gwtbootstrap.client.ui.constants.ButtonType;
import com.google.gwt.core.client.GWT; import com.google.gwt.core.client.GWT;
import com.google.gwt.event.dom.client.ChangeEvent; import com.google.gwt.event.dom.client.ChangeEvent;
import com.google.gwt.event.dom.client.ChangeHandler; import com.google.gwt.event.dom.client.ChangeHandler;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.shared.HandlerManager; import com.google.gwt.event.shared.HandlerManager;
import com.google.gwt.http.client.Request; import com.google.gwt.http.client.Request;
import com.google.gwt.http.client.RequestBuilder; import com.google.gwt.http.client.RequestBuilder;
@ -54,6 +61,9 @@ public class CrossFilteringLayerPanel extends Composite {
@UiField @UiField
Fieldset fieldSet; Fieldset fieldSet;
@UiField
Button buttonReset;
private CheckBox checkbox; private CheckBox checkbox;
private GeoInformationForWMSRequest geoInformation; private GeoInformationForWMSRequest geoInformation;
@ -72,6 +82,10 @@ public class CrossFilteringLayerPanel extends Composite {
private GroupedLayersDV<? extends LayerIDV> groupedLayersDV; private GroupedLayersDV<? extends LayerIDV> groupedLayersDV;
private GCubeCollection gCubeCollection;
private DropdownButton filterButton;
/** /**
* The Interface LayerCollectionPanelUiBinder. * The Interface LayerCollectionPanelUiBinder.
* *
@ -82,74 +96,68 @@ public class CrossFilteringLayerPanel extends Composite {
interface CrossFilteringLayerPanelUiBinder extends UiBinder<Widget, CrossFilteringLayerPanel> { interface CrossFilteringLayerPanelUiBinder extends UiBinder<Widget, CrossFilteringLayerPanel> {
} }
public class SelectableItem { /**
String key; * Instantiates a new overlay custom layer panel.
String parentKey; *
String itemField; * @param gCubeCollection the g cube collection
* @param groupedLayersDV the grouped layers DV
* @param applicationBus the application bus
*/
public CrossFilteringLayerPanel(GCubeCollection gCubeCollection,
GroupedLayersDV<? extends LayerIDV> groupedLayersDV, HandlerManager applicationBus) {
initWidget(uiBinder.createAndBindUi(this));
this.applicationBus = applicationBus;
this.groupedLayersDV = groupedLayersDV;
this.gCubeCollection = gCubeCollection;
GWT.log("Building cross-filtering for: " + groupedLayersDV);
String provenance; // layerName buttonReset.setType(ButtonType.LINK);
SelectableItem() { int level = 0;
// Building mapInnestedFiltering
recursivelyBuildSelectableLevels(level, groupedLayersDV.getListCustomLayers());
GWT.log("cross-filtering mapInnestedFiltering: " + mapInnestedFiltering);
for (Integer theLevel : mapInnestedFiltering.keySet()) {
addListBoxesLevelToPanel(theLevel, mapInnestedFiltering.get(theLevel));
} }
public SelectableItem(String key, String parentKey, String itemField, String provenance) { fillSelectableLevel(level, null);
super();
this.key = key;
this.parentKey = parentKey;
this.itemField = itemField;
this.provenance = provenance;
}
public String getKey() { bindEvents();
return key;
}
public String getParentKey() {
return parentKey;
}
public String getItemField() {
return itemField;
}
public String getProvenance() {
return provenance;
}
public void setKey(String key) {
this.key = key;
}
public void setParentKey(String parentKey) {
this.parentKey = parentKey;
}
public void setItemField(String itemField) {
this.itemField = itemField;
}
public void setProvenance(String provenance) {
this.provenance = provenance;
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("SelectableItem [key=");
builder.append(key);
builder.append(", parentKey=");
builder.append(parentKey);
builder.append(", itemField=");
builder.append(itemField);
builder.append(", provenance=");
builder.append(provenance);
builder.append("]");
return builder.toString();
}
} }
/**
* Bind events.
*/
private void bindEvents() {
buttonReset.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
for (int i = 1; i < mapInnestedListBoxes.size(); i++) {
resetListBoxLevel(i);
}
// Selecting the placeholder of the fist list box
List<ListBox> listBox = mapInnestedListBoxes.get(0);
listBox.get(0).setSelectedIndex(0);
// Resetting CQL filtering
applicationBus.fireEvent(new ApplyCQLToLayerMapEvent(gCubeCollection.getIndexes().get(0), null));
setFilterHighLighted(false);
}
});
}
/**
* Recursively build selectable levels.
*
* @param level the level
* @param layersIDV the layers IDV
*/
private void recursivelyBuildSelectableLevels(int level, List<? extends LayerIDV> layersIDV) { private void recursivelyBuildSelectableLevels(int level, List<? extends LayerIDV> layersIDV) {
if (layersIDV == null) if (layersIDV == null)
@ -169,49 +177,21 @@ public class CrossFilteringLayerPanel extends Composite {
} }
/** /**
* Instantiates a new overlay custom layer panel. * Fill selectable level.
* *
* @param listGroupedLayers the layer item * @param level the level
* @param applicationBus the application bus * @param selectedItem the selected item
*/ */
public CrossFilteringLayerPanel(GroupedLayersDV<? extends LayerIDV> groupedLayersDV, private void fillSelectableLevel(int level, SelectableItem selectedItem) {
HandlerManager applicationBus) {
initWidget(uiBinder.createAndBindUi(this));
this.applicationBus = applicationBus;
this.groupedLayersDV = groupedLayersDV;
GWT.log("Building cross-filtering for: " + groupedLayersDV);
int level = 0;
// Building mapInnestedFiltering
recursivelyBuildSelectableLevels(level, groupedLayersDV.getListCustomLayers());
GWT.log("cross-filtering mapInnestedFiltering: " + mapInnestedFiltering);
for (Integer theLevel : mapInnestedFiltering.keySet()) {
addListBoxesLevelToPanel(theLevel, mapInnestedFiltering.get(theLevel));
}
filleSelectableLevel(level, null);
}
private void filleSelectableLevel(int level, SelectableItem selectedItem) {
//HashMap<String, SelectableItem> mapOfFeatureAtLevel = mapInnestedFeatures.get(level);
List<? extends LayerIDV> layersIDV = mapInnestedFiltering.get(level); List<? extends LayerIDV> layersIDV = mapInnestedFiltering.get(level);
List<ListBox> listBoxes = mapInnestedListBoxes.get(level); List<ListBox> listBoxes = mapInnestedListBoxes.get(level);
if (layersIDV == null) if (layersIDV == null)
return; return;
// final HashMap<String, SelectableItem> mapSelectableFeatures = mapOfFeatureAtLevel == null
// ? new HashMap<String, SelectableItem>()
// : mapOfFeatureAtLevel;
final HashMap<String, SelectableItem> mapSelectableFeatures = new HashMap<String, CrossFilteringLayerPanel.SelectableItem>(); final HashMap<String, SelectableItem> mapSelectableFeatures = new HashMap<String, CrossFilteringLayerPanel.SelectableItem>();
// if (mapSelectableFeatures.isEmpty()) {
LayerIDV layerIDV = layersIDV.get(0); // Expected one LayerIDV layerIDV = layersIDV.get(0); // Expected one
if (layerIDV instanceof CrossFilteringLayerDV) { if (layerIDV instanceof CrossFilteringLayerDV) {
@ -220,7 +200,7 @@ public class CrossFilteringLayerPanel extends Composite {
if (selectedItem != null) { if (selectedItem != null) {
String cqlFilterValue = crossFilteringLayer.getTable_parent_key_field() + "=" + selectedItem.getKey(); String cqlFilterValue = crossFilteringLayer.getTable_parent_key_field() + "=" + selectedItem.keyValue;
wfsURL += "&CQL_FILTER=" + URL.encode(cqlFilterValue); wfsURL += "&CQL_FILTER=" + URL.encode(cqlFilterValue);
} }
@ -241,7 +221,7 @@ public class CrossFilteringLayerPanel extends Composite {
for (Feature feature : features) { for (Feature feature : features) {
JsPropertyMap<Object> properties = feature.getProperties(); JsPropertyMap<Object> properties = feature.getProperties();
Object key = properties.get(crossFilteringLayer.getTable_key_field()); Object keyValue = properties.get(crossFilteringLayer.getTable_key_field());
Object itemField = properties.get(crossFilteringLayer.getTable_show_field()); Object itemField = properties.get(crossFilteringLayer.getTable_show_field());
Object parentKey = null; Object parentKey = null;
@ -251,14 +231,17 @@ public class CrossFilteringLayerPanel extends Composite {
parentKey = parentKey == null ? "" : parentKey; parentKey = parentKey == null ? "" : parentKey;
SelectableItem selectableItem = new SelectableItem(key + "", parentKey + "", itemField + "", SelectableItem selectableItem = new SelectableItem(
crossFilteringLayer.getName()); crossFilteringLayer.getTable_key_field() + "", keyValue + "",
GWT.log("select item: " + selectableItem); crossFilteringLayer.getTable_parent_key_field(), itemField + "",
crossFilteringLayer.getName(), crossFilteringLayer.getTable_geometry_name());
GWT.log("selectableItem: " + selectableItem);
String pathFeatureKey = pathFeatureKey(selectableItem); String pathFeatureKey = pathFeatureKey(selectableItem);
mapSelectableFeatures.put(pathFeatureKey, selectableItem); mapSelectableFeatures.put(pathFeatureKey, selectableItem);
} }
GWT.log("mapSelectableFeatures: " + mapSelectableFeatures);
mapInnestedFeatures.put(level, mapSelectableFeatures); mapInnestedFeatures.put(level, mapSelectableFeatures);
String placholder = placeholderLayer(layersIDV.get(0)); // Expected one String placholder = placeholderLayer(layersIDV.get(0)); // Expected one
fillListBoxLevel(level, mapSelectableFeatures, listBoxes, placholder); fillListBoxLevel(level, mapSelectableFeatures, listBoxes, placholder);
@ -269,23 +252,39 @@ public class CrossFilteringLayerPanel extends Composite {
// Code omitted for clarity // Code omitted for clarity
} }
} }
// } else {
//
// String placholder = placeholderLayer(layersIDV.get(0)); // Expected one
// fillListBoxLevel(level, mapInnestedFeatures.get(level), listBoxes, placholder);
// }
} }
/**
* Path feature key.
*
* @param selectableItem the selectable item
* @return the string
*/
private String pathFeatureKey(SelectableItem selectableItem) { private String pathFeatureKey(SelectableItem selectableItem) {
return "root_" + selectableItem.getParentKey() + "_"+selectableItem.getKey(); return "root_" + selectableItem.parentKeyField + "_" + selectableItem.keyField + "_" + selectableItem.keyValue;
} }
/**
* Placeholder layer.
*
* @param layersIDV the layers IDV
* @return the string
*/
private String placeholderLayer(LayerIDV layersIDV) { private String placeholderLayer(LayerIDV layersIDV) {
return "Select " + layersIDV.getTitle() + "..."; String placeholder = "Select";
if (layersIDV != null)
placeholder += " " + layersIDV.getTitle() + "...";
placeholder += " ...";
return placeholder;
} }
/**
* Adds the list boxes level to panel.
*
* @param level the level
* @param layersIDV the layers IDV
*/
private void addListBoxesLevelToPanel(int level, List<? extends LayerIDV> layersIDV) { private void addListBoxesLevelToPanel(int level, List<? extends LayerIDV> layersIDV) {
if (layersIDV == null) if (layersIDV == null)
@ -312,18 +311,35 @@ public class CrossFilteringLayerPanel extends Composite {
mapInnestedListBoxes.put(level, listBoxes); mapInnestedListBoxes.put(level, listBoxes);
} }
/**
* Sets the enabled box.
*
* @param listBox the list box
* @param bool the bool
*/
public void setEnabledBox(ListBox listBox, boolean bool) { public void setEnabledBox(ListBox listBox, boolean bool) {
listBox.setEnabled(bool); listBox.setEnabled(bool);
} }
/**
* Clear list box.
*
* @param listBox the list box
* @param bool the bool
*/
public void clearListBox(ListBox listBox, boolean bool) { public void clearListBox(ListBox listBox, boolean bool) {
listBox.setEnabled(bool); listBox.setEnabled(bool);
} }
/**
* Reset list box level.
*
* @param level the level
*/
private void resetListBoxLevel(int level) { private void resetListBoxLevel(int level) {
List<ListBox> listBoxes = mapInnestedListBoxes.get(level); List<ListBox> listBoxes = mapInnestedListBoxes.get(level);
if(listBoxes!=null) { if (listBoxes != null) {
for (ListBox listBox : listBoxes) { for (ListBox listBox : listBoxes) {
listBox.clear(); listBox.clear();
setEnabledBox(listBox, false); setEnabledBox(listBox, false);
@ -331,6 +347,14 @@ public class CrossFilteringLayerPanel extends Composite {
} }
} }
/**
* Fill list box level.
*
* @param level the level
* @param mapSelectableFeatures the map selectable features
* @param listBoxes the list boxes
* @param placeholder the placeholder
*/
private void fillListBoxLevel(int level, HashMap<String, SelectableItem> mapSelectableFeatures, private void fillListBoxLevel(int level, HashMap<String, SelectableItem> mapSelectableFeatures,
List<ListBox> listBoxes, String placeholder) { List<ListBox> listBoxes, String placeholder) {
GWT.log("fillBox level: " + level + " map: " + mapSelectableFeatures); GWT.log("fillBox level: " + level + " map: " + mapSelectableFeatures);
@ -345,7 +369,7 @@ public class CrossFilteringLayerPanel extends Composite {
for (String key : mapSelectableFeatures.keySet()) { for (String key : mapSelectableFeatures.keySet()) {
SelectableItem selItem = mapSelectableFeatures.get(key); SelectableItem selItem = mapSelectableFeatures.get(key);
listBox.addItem(selItem.getItemField(), key); listBox.addItem(selItem.itemValue, key);
} }
listBox.addChangeHandler(new ChangeHandler() { listBox.addChangeHandler(new ChangeHandler() {
@ -353,12 +377,44 @@ public class CrossFilteringLayerPanel extends Composite {
@Override @Override
public void onChange(ChangeEvent event) { public void onChange(ChangeEvent event) {
loadInnerLevel(level, listBox.getSelectedValue()); loadInnerLevel(level, listBox.getSelectedValue());
for (int i = level + 1; i < mapInnestedListBoxes.size(); i++) {
resetListBoxLevel(i);
}
String key = listBox.getSelectedValue();
SelectableItem selectableItem = mapSelectableFeatures.get(key);
buildCrossFilteringCQLAndFireEvent(selectableItem);
setFilterHighLighted(true);
} }
}); });
setEnabledBox(listBox, true); setEnabledBox(listBox, true);
} }
/**
* Builds the cross filtering CQL and fire event.
*
* @param selectableItem the selectable item
*/
private void buildCrossFilteringCQLAndFireEvent(SelectableItem selectableItem) {
String setCqlFilter = "INTERSECTS(geom,querySingle('" + selectableItem.layername + "','"
+ selectableItem.theGeometryName + "','" + selectableItem.keyField + "=''" + selectableItem.keyValue
+ "'''));INCLUDE";
GWT.log("CQL FILTER built: " + setCqlFilter);
// olMapMng.getOLMap().setCQLFilterToWMSLayer(layerName, setCqlFilter);
applicationBus.fireEvent(new ApplyCQLToLayerMapEvent(gCubeCollection.getIndexes().get(0), setCqlFilter));
}
/**
* Load inner level.
*
* @param level the level
* @param selectableItemValue the selectable item value
*/
private void loadInnerLevel(int level, String selectableItemValue) { private void loadInnerLevel(int level, String selectableItemValue) {
GWT.log("selected level " + level + " selectableItemValue " + selectableItemValue); GWT.log("selected level " + level + " selectableItemValue " + selectableItemValue);
HashMap<String, SelectableItem> mapSelectableItem = mapInnestedFeatures.get(level); HashMap<String, SelectableItem> mapSelectableItem = mapInnestedFeatures.get(level);
@ -368,24 +424,106 @@ public class CrossFilteringLayerPanel extends Composite {
int innerLevel = level + 1; int innerLevel = level + 1;
List<? extends LayerIDV> selectedLayers = mapInnestedFiltering.get(innerLevel); List<? extends LayerIDV> selectedLayers = mapInnestedFiltering.get(innerLevel);
//if layer filtering exists at this level // if layer filtering exists at this level
if (selectedLayers != null) { if (selectedLayers != null) {
List<ListBox> selectedListBoxes = mapInnestedListBoxes.get(innerLevel); List<ListBox> selectedListBoxes = mapInnestedListBoxes.get(innerLevel);
GWT.log("loading inner layers " + selectedLayers); GWT.log("loading inner layers " + selectedLayers);
GWT.log("loading selectedListBoxes " + selectedListBoxes); GWT.log("loading selectedListBoxes " + selectedListBoxes);
filleSelectableLevel(innerLevel, selectedItem); fillSelectableLevel(innerLevel, selectedItem);
} }
} }
// public void resetCurrentSearch() { /**
// searchField.setText(""); * Sets the filter high lighted.
// resetSearch.setVisible(false); *
// panelResults.clear(); * @param bool the new filter high lighted
// latestResult = null; */
// appManagerBus.fireEvent(new SearchPerformedEvent(profileID, null, true)); private void setFilterHighLighted(boolean bool) {
// setSearchEnabled(false); if (bool) {
// } filterButton.getElement().addClassName("highlight-button");
} else {
filterButton.getElement().removeClassName("highlight-button");
}
}
/**
* Sets the search button.
*
* @param searchFacilityButton the new search button
*/
public void setFilterButton(DropdownButton searchFacilityButton) {
this.filterButton = searchFacilityButton;
}
/**
* The Class SelectableItem.
*
* @author Francesco Mangiacrapa at ISTI-CNR francesco.mangiacrapa@isti.cnr.it
*
* May 31, 2023
*/
public class SelectableItem {
protected String keyField;
protected String keyValue;
protected String parentKeyField;
protected String itemValue;
protected String layername;
protected String theGeometryName;
/**
* Instantiates a new selectable item.
*/
SelectableItem() {
}
/**
* Instantiates a new selectable item.
*
* @param keyField the key field
* @param keyValue the key value
* @param parentKeyField the parent key field
* @param itemValue the item value
* @param layername the layername
* @param theGeometryName the the geometry name
*/
public SelectableItem(String keyField, String keyValue, String parentKeyField, String itemValue,
String layername, String theGeometryName) {
super();
this.keyField = keyField;
this.keyValue = keyValue;
this.parentKeyField = parentKeyField;
this.itemValue = itemValue;
this.layername = layername;
this.theGeometryName = theGeometryName;
}
/**
* To string.
*
* @return the string
*/
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("SelectableItem [keyField=");
builder.append(keyField);
builder.append(", keyValue=");
builder.append(keyValue);
builder.append(", parentKeyField=");
builder.append(parentKeyField);
builder.append(", itemValue=");
builder.append(itemValue);
builder.append(", layername=");
builder.append(layername);
builder.append(", theGeometryName=");
builder.append(theGeometryName);
builder.append("]");
return builder.toString();
}
}
} }

View File

@ -13,10 +13,14 @@
</ui:style> </ui:style>
<g:HTMLPanel> <g:HTMLPanel>
<g:ScrollPanel> <g:ScrollPanel>
<b:Form ui:field="panelForm"> <g:HTMLPanel>
<b:Fieldset ui:field="fieldSet"> <b:Form ui:field="panelForm">
</b:Fieldset> <b:Fieldset ui:field="fieldSet">
</b:Form> </b:Fieldset>
</b:Form>
<b:Button icon="REMOVE_CIRCLE" ui:field="buttonReset"
title="Reset the filter">Reset</b:Button>
</g:HTMLPanel>
</g:ScrollPanel> </g:ScrollPanel>
</g:HTMLPanel> </g:HTMLPanel>
</ui:UiBinder> </ui:UiBinder>

View File

@ -836,7 +836,8 @@ RESPONSIVE
.overlay-panel-style-description { .overlay-panel-style-description {
border: none !important; border: none !important;
white-space: pre-line; white-space: pre-line;
padding: 5px 0px; padding: 10px 0px;
font-style: italic;
} }
.overlay-panel-style > div { .overlay-panel-style > div {
@ -855,10 +856,15 @@ RESPONSIVE
max-width: 350px; max-width: 350px;
} }
.filter-panel-style select {
min-width: 310px;
}
.filter-panel-style-description { .filter-panel-style-description {
border: none !important; border: none !important;
white-space: pre-line; white-space: pre-line;
padding: 5px 0px; padding: 10px 0px;
font-style: italic;
} }
.filter-panel-style > div { .filter-panel-style > div {
@ -869,4 +875,11 @@ RESPONSIVE
margin-top: 5px; margin-top: 5px;
} }
.filter-panel-style a {
float: right;
}
.filter-panel-style label {
font-weight: bold;
}