Skip to content

Commit

Permalink
Fix geosolutions-it#9601 style issue on points generated from geo pro…
Browse files Browse the repository at this point in the history
…cess intersection
  • Loading branch information
MV88 committed Oct 19, 2023
1 parent 937edb2 commit 23ecca3
Show file tree
Hide file tree
Showing 3 changed files with 190 additions and 81 deletions.
127 changes: 70 additions & 57 deletions web/client/epics/__tests__/geoProcessing-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ import DESCRIBE_PROCESS_NO_BUFFER from 'raw-loader!../../test-resources/wfs/desc
import DESCRIBE_POIS from '../../test-resources/wfs/describe-pois.json';
import GET_FEATURES from '../../test-resources/wms/GetFeature.json';
import COLLECT_GEOM from '../../test-resources/wps/collectGeom.json';
import MULTIPOLYGON_FC from '../../test-resources/wps/MultiPolygonFC.json';


import {
Expand Down Expand Up @@ -602,67 +603,79 @@ describe('geoProcessing epics', () => {
}, {});
});
it('runIntersectProcessGPTEpic with double geom collect', (done) => {
const NUM_ACTIONS = 7;
mockAxios.onGet("mockUrl?service=WFS&version=1.1.0&request=GetFeature").reply(200, GET_FEATURES);
mockAxios.onPost("mockUrl?service=WPS&version=1.0.0&REQUEST=Execute").reply(200, COLLECT_GEOM, {
"content-type": "application/json"
});
mockAxios.onGet("mockUrl2?service=WFS&version=1.1.0&request=GetFeature").reply(200, GET_FEATURES);
mockAxios.onPost("mockUrl2?service=WPS&version=1.0.0&REQUEST=Execute").reply(200, COLLECT_GEOM, {
"content-type": "application/json"
});
try {
const NUM_ACTIONS = 7;
mockAxios.onGet("mockUrl?service=WFS&version=1.1.0&request=GetFeature").reply(200, GET_FEATURES);
mockAxios
.onPost("mockUrl?service=WPS&version=1.0.0&REQUEST=Execute")
.replyOnce(200, COLLECT_GEOM, {
"content-type": "application/json"
})
.onPost("mockUrl?service=WPS&version=1.0.0&REQUEST=Execute")
.replyOnce(200, MULTIPOLYGON_FC, {
"content-type": "application/json"
});
mockAxios.onGet("mockUrl2?service=WFS&version=1.1.0&request=GetFeature").reply(200, GET_FEATURES);
mockAxios.onPost("mockUrl2?service=WPS&version=1.0.0&REQUEST=Execute").replyOnce(200, COLLECT_GEOM, {
"content-type": "application/json"
});

const startActions = [runProcess(GPT_TOOL_INTERSECTION)];
testEpic(addTimeoutEpic(runIntersectProcessGPTEpic, 100), NUM_ACTIONS, startActions, actions => {
expect(actions.length).toBe(NUM_ACTIONS);
const [
action1,
action2,
action3,
action4,
action5,
action6,
action7
] = actions;
expect(action1).toEqual(runningProcess(true));
expect(action2.type).toEqual(addGroup().type);
expect(action3.type).toEqual(increaseIntersectedCounter().type);
expect(action4.type).toEqual(addLayer().type);
expect(action5.type).toEqual(zoomToExtent().type);
expect(action6.type).toEqual(showSuccessNotification().type);
expect(action7).toEqual(runningProcess(false));
done();
}, {
layers: {
flat: [{
id: "id",
url: "mockUrl",
name: "name",
search: {
url: "mockUrl"
}
const startActions = [runProcess(GPT_TOOL_INTERSECTION)];
testEpic(addTimeoutEpic(runIntersectProcessGPTEpic, 100), NUM_ACTIONS, startActions, actions => {
expect(actions.length).toBe(NUM_ACTIONS);
const [
action1,
action2,
action3,
action4,
action5,
action6,
action7
] = actions;
expect(action1).toEqual(runningProcess(true));
expect(action2.type).toEqual(addGroup().type);
expect(action3.type).toEqual(increaseIntersectedCounter().type);
expect(action4.type).toEqual(addLayer().type);
expect(action5.type).toEqual(zoomToExtent().type);
expect(action6.type).toEqual(showSuccessNotification().type);
expect(action7).toEqual(runningProcess(false));
done();
}, {
layers: {
flat: [{
id: "id",
url: "mockUrl",
name: "name",
search: {
url: "mockUrl"
}
},
{
id: "id2",
url: "mockUrl2",
name: "name2",
search: {
url: "mockUrl2"
}
}]
},
{
id: "id2",
url: "mockUrl2",
name: "name2",
search: {
url: "mockUrl2"
geoProcessing: {
source: {
layerId: "id"
},
intersection: {
layerId: "id2"
},
flags: {
showHighlightLayers: true
}
}]
},
geoProcessing: {
source: {
layerId: "id"
},
intersection: {
layerId: "id2"
},
flags: {
showHighlightLayers: true
}
}
});
});
} catch (e) {
// eslint-disable-next-line no-console
console.log(e);
done(e);
}
});
it('toggleHighlightLayersGPTEpic', (done) => {
const NUM_ACTIONS = 1;
Expand Down
87 changes: 63 additions & 24 deletions web/client/epics/geoProcessing.js
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,53 @@ const DEACTIVATE_ACTIONS = [
changeDrawingStatus("stop"),
changeDrawingStatus("clean", '', GPT_CONTROL_NAME)
];

const getGeom = (geomType) => {
switch (geomType) {
case "Point": case "MultiPoint": return "point";
case "LineString": case "MultiLineString": return "line";
case "Polygon": case "MultiPolygon": return "polygon";
default:
return geomType;
}
};

const styleRules = [
{
filter: [ '==', 'geomType', 'polygon' ],
symbolizers: [
{
"kind": "Fill",
"outlineWidth": 3,
"outlineColor": "#ffac12",
"color": "#ffffff",
"opacity": 1,
"fillOpacity": 0.3
}
]
}, {
filter: [ '==', 'geomType', 'line' ],
symbolizers: [{
"kind": "Line",
"width": 3,
"color": "#ffffff",
"opacity": 0.3
}]
}, {
filter: [ '==', 'geomType', 'point' ],
symbolizers: [{
"kind": "Mark",
"wellKnownName": "Circle",
"strokeColor": "#f5a623",
"color": "#ffffff",
"fillOpacity": 0.3,
"strokeWidth": 3,
"strokeOpacity": 1,
"radius": 8
}]
}
];

/**
* checks if a layer is a valid one that can be used in the gpt tool.
* also checks if it is a raster using describe layer
Expand Down Expand Up @@ -471,22 +518,18 @@ export const runBufferProcessGPTEpic = (action$, store) => action$
maxy: extent[3]
}
},
features,
features: features.map(f => ({
...f,
properties: {
...f.properties,
geomType: getGeom(f.geometry.type)
}
})),
style: {
format: "geostyler",
body: {
name: "",
rules: [{
symbolizers: [
{
"kind": "Fill",
"outlineWidth": 3,
"outlineColor": "#ffac12",
"color": "#ffffff",
"fillOpacity": 0.3
}
]
}]
rules: styleRules
}
}
}),
Expand Down Expand Up @@ -705,7 +748,13 @@ export const runIntersectProcessGPTEpic = (action$, store) => action$
group: GPT_INTERSECTION_GROUP_ID,
title: "Intersection Layer " + counter,
visibility: true,
features: featureCollection.features,
features: featureCollection.features.map(f => ({
...f,
properties: {
...f.properties,
geomType: getGeom(f.geometry.type)
}
})),
bbox: {
crs: "EPSG:4326",
bounds: {
Expand All @@ -719,17 +768,7 @@ export const runIntersectProcessGPTEpic = (action$, store) => action$
format: "geostyler",
body: {
name: "",
rules: [{
symbolizers: [
{
"kind": "Fill",
"outlineWidth": 3,
"outlineColor": "#ffac12",
"color": "#ffffff",
"fillOpacity": 0.3
}
]
}]
rules: styleRules
}
}
}),
Expand Down
57 changes: 57 additions & 0 deletions web/client/test-resources/wps/MultiPolygonFC.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
{
"type": "FeatureCollections",
"features": [
{
"type": "Feature",
"properties": {
"goat": "Valentino Rossi"
},
"geometry": {
"type": "MultiPolygon",
"coordinates": [
[
[
[
1.60533116,
46.01664018
],
[
9.80373297,
46.01664018
],
[
9.80373297,
44.55317604
],
[
10.48897253,
44.55317604
],
[
10.48897253,
44.27347776
],
[
9.80373297,
44.27347776
],
[
9.80373297,
43.62155322
],
[
1.60533116,
43.62155322
],
[
1.60533116,
46.01664018
]
]
]
]
}
}

]
}

0 comments on commit 23ecca3

Please sign in to comment.