From da2333f47e1e379a47aa97df8a79ed47f54e8c8d Mon Sep 17 00:00:00 2001 From: github-actions Date: Thu, 23 Mar 2023 19:26:35 +0000 Subject: [PATCH 1/7] reset DRAFT_CHANGELOG --- DRAFT_CHANGELOG.md | 2 -- 1 file changed, 2 deletions(-) diff --git a/DRAFT_CHANGELOG.md b/DRAFT_CHANGELOG.md index e4e58ad31..cfc60e76e 100644 --- a/DRAFT_CHANGELOG.md +++ b/DRAFT_CHANGELOG.md @@ -12,8 +12,6 @@ * [Changed] - - mise à jour ol-ext 3.2.21 - * [Removed] * [Fixed] From 450e32de52b60624a22f6d60ddc11b0c57116d38 Mon Sep 17 00:00:00 2001 From: "jean-philippe.bazonnais" Date: Thu, 30 Mar 2023 21:58:04 +0200 Subject: [PATCH 2/7] Fix sur import des couches de calculs (compute) --- src/OpenLayers/OlMapLayers.js | 98 +++++++++++++++++++++++------------ 1 file changed, 64 insertions(+), 34 deletions(-) diff --git a/src/OpenLayers/OlMapLayers.js b/src/OpenLayers/OlMapLayers.js index 130516231..2f5d0c3dd 100644 --- a/src/OpenLayers/OlMapLayers.js +++ b/src/OpenLayers/OlMapLayers.js @@ -738,53 +738,80 @@ OlMap.prototype._registerUnknownLayer = function (layerObj) { // couches de résultats ou de calcul (itineraire, isochrone, ...) var layerId = "unknownLayer"; if (layerObj.hasOwnProperty("gpResultLayerId")) { - // isochrones : [GraphName]$GEOPORTAIL:GPP:Isocurve - // itineraire : [GraphName]$GEOPORTAIL:GPP:Itineraire layerId = layerObj.gpResultLayerId; } - // on rajoute un timestamp - layerId += "-" + Date.now(); // on rajoute des infos quand on en a var options = {}; - if (layerId.indexOf("drawing-") === 0) { - options.format = "drawing"; - } else if (layerId.indexOf("layerimport:KML") === 0) { - options.format = "KML"; - } else if (layerId.indexOf("layerimport:GPX") === 0) { - options.format = "GPX"; - } else if (layerId.indexOf("layerimport:GeoJSON") === 0) { - options.format = "GeoJSON"; - } else if (layerId.indexOf("layerimport:WMS") === 0) { - options.format = "WMS"; - if (layerObj.gpGFIparams) { - if (layerObj.gpGFIparams.queryable) { - options.queryable = true; - } - if (Array.isArray(layerObj.gpGFIparams.formats)) { - // par défaut on prend le premier - options.gfiFormat = layerObj.gpGFIparams.formats[0]; - // si on trouve "text/html" dans les formats disponibles, on prend "text/html" par défaut - for (var i = 0; i < layerObj.gpGFIparams.formats.length; i++) { - if (layerObj.gpGFIparams.formats[i] === "text/html") { - options.gfiFormat = "text/html"; - break; + + switch (layerId) { + case "drawing": + options.format = "drawing"; + break; + case "layerimport:KMl": + options.format = "KML"; + break; + case "layerimport:GPX": + options.format = "GPX"; + break; + case "layerimport:GeoJSON": + options.format = "GeoJSON"; + break; + case "layerimport:WMS": + options.format = "WMS"; + if (layerObj.gpGFIparams) { + if (layerObj.gpGFIparams.queryable) { + options.queryable = true; + } + if (Array.isArray(layerObj.gpGFIparams.formats)) { + // par défaut on prend le premier + options.gfiFormat = layerObj.gpGFIparams.formats[0]; + // si on trouve "text/html" dans les formats disponibles, on prend "text/html" par défaut + for (var i = 0; i < layerObj.gpGFIparams.formats.length; i++) { + if (layerObj.gpGFIparams.formats[i] === "text/html") { + options.gfiFormat = "text/html"; + break; + } } } } - } - } else if (layerId.indexOf("layerimport:WMTS") === 0) { - options.format = "WMTS"; - } else if (layerId.indexOf("layerimport:MAPBOX") === 0) { - options.format = "MAPBOX"; + break; + case "layerimport:WMTS": + options.format = "WMTS"; + break; + case "layerimport:MAPBOX": + options.format = "MAPBOX"; + break; + case "layerimport:COMPUTE": + // ex. isochrones : [GraphName]$GEOPORTAIL:GPP:Isocurve + // ex. itineraire : [GraphName]$GEOPORTAIL:GPP:Itineraire + + // result layer name + options.format = "COMPUTE"; + // graph name (voiture / pieton) + options.graph = layerId.split(/[$:;]/)[0]; + // control name (isocurve / itineraire) + options.control = layerId.split(/[$:;]/).slice(-1)[0]; + // title by default + options.title = options.control + " (" + options.graph + ")"; + // options control + options.controlOptions = {}; + // features to geojson + options.data = {}; + break; + default: + break; } - if (layerObj.hasOwnProperty("gpResultLayerId")) { + // FIXME + // la couche est encore inconnue !? + // on la traite comme une couche de calcul... + if (layerId === "unknownLayer") { // result layer name options.format = "COMPUTE"; // graph name (voiture / pieton) - options.graph = layerObj.gpResultLayerId.split(/[$:;]/)[0]; + options.graph = layerId.split(/[$:;]/)[0]; // control name (isocurve / itineraire) - options.control = layerObj.gpResultLayerId.split(/[$:;]/).slice(-1)[0]; + options.control = layerId.split(/[$:;]/).slice(-1)[0]; // title by default options.title = options.control + " (" + options.graph + ")"; // options control @@ -793,6 +820,9 @@ OlMap.prototype._registerUnknownLayer = function (layerObj) { options.data = {}; } + // on rajoute un timestamp + layerId += "-" + Date.now(); + this._layers.push({ id : layerId, obj : layerObj, From 00b10aaf623bb123afa3394d4c844ff6573bdb79 Mon Sep 17 00:00:00 2001 From: "jean-philippe.bazonnais" Date: Fri, 31 Mar 2023 17:45:11 +0200 Subject: [PATCH 3/7] Fix sur les couches de calculs Iso et Iti --- src/OpenLayers/OlMapLayers.js | 58 +++++++++++++++-------------------- 1 file changed, 25 insertions(+), 33 deletions(-) diff --git a/src/OpenLayers/OlMapLayers.js b/src/OpenLayers/OlMapLayers.js index 2f5d0c3dd..b41a3f5e9 100644 --- a/src/OpenLayers/OlMapLayers.js +++ b/src/OpenLayers/OlMapLayers.js @@ -735,7 +735,7 @@ OlMap.prototype._getLayerOpts = function (layerObj, layersStack) { * @returns {Object} - new layer index in this._layers */ OlMap.prototype._registerUnknownLayer = function (layerObj) { - // couches de résultats ou de calcul (itineraire, isochrone, ...) + // couches de résultats (imports) ou de calcul (itineraire, isochrone, ...) var layerId = "unknownLayer"; if (layerObj.hasOwnProperty("gpResultLayerId")) { layerId = layerObj.gpResultLayerId; @@ -781,43 +781,35 @@ OlMap.prototype._registerUnknownLayer = function (layerObj) { case "layerimport:MAPBOX": options.format = "MAPBOX"; break; - case "layerimport:COMPUTE": - // ex. isochrones : [GraphName]$GEOPORTAIL:GPP:Isocurve - // ex. itineraire : [GraphName]$GEOPORTAIL:GPP:Itineraire - - // result layer name - options.format = "COMPUTE"; - // graph name (voiture / pieton) - options.graph = layerId.split(/[$:;]/)[0]; - // control name (isocurve / itineraire) - options.control = layerId.split(/[$:;]/).slice(-1)[0]; - // title by default - options.title = options.control + " (" + options.graph + ")"; - // options control - options.controlOptions = {}; - // features to geojson - options.data = {}; - break; default: + // FIXME + // cas où l'ID est de la forme : + // ex. isochrones : Voiture$OGC:OPENLS;Isocurve ou VOITURE$GEOPORTAIL:GPP:Isocurve + // ex. itineraire : Voiture$OGC:OPENLS;Itineraire ou VOITURE$GEOPORTAIL:GPP:Itineraire + var key = layerId.toUpperCase(); + if (key.includes("OGC:OPENLS;ISOCURVE") || + key.includes("OGC:OPENLS;ITINERAIRE") || + key.includes("GEOPORTAIL:GPP:ISOCURVE") || + key.includes("GEOPORTAIL:GPP:ITINERAIRE")) { + // result layer name + options.format = "COMPUTE"; + // graph name (voiture / pieton) + options.graph = layerId.split(/[$:;]/)[0]; + // control name (isocurve / itineraire) + options.control = layerId.split(/[$:;]/).slice(-1)[0]; + // title by default + options.title = options.control + " (" + options.graph + ")"; + // options control + options.controlOptions = {}; + // features to geojson + options.data = {}; + } break; } - // FIXME - // la couche est encore inconnue !? - // on la traite comme une couche de calcul... + // Et, si la couche est toujours non reconnue !? if (layerId === "unknownLayer") { - // result layer name - options.format = "COMPUTE"; - // graph name (voiture / pieton) - options.graph = layerId.split(/[$:;]/)[0]; - // control name (isocurve / itineraire) - options.control = layerId.split(/[$:;]/).slice(-1)[0]; - // title by default - options.title = options.control + " (" + options.graph + ")"; - // options control - options.controlOptions = {}; - // features to geojson - options.data = {}; + return; } // on rajoute un timestamp From e3ff993104854c45a87e71b702a40c42f0d2479d Mon Sep 17 00:00:00 2001 From: "jean-philippe.bazonnais" Date: Fri, 31 Mar 2023 22:52:58 +0200 Subject: [PATCH 4/7] Fix sur l'import d'un KML --- src/OpenLayers/OlMapLayers.js | 53 +++++++++++++++++++++++++---------- 1 file changed, 38 insertions(+), 15 deletions(-) diff --git a/src/OpenLayers/OlMapLayers.js b/src/OpenLayers/OlMapLayers.js index b41a3f5e9..71b872dd3 100644 --- a/src/OpenLayers/OlMapLayers.js +++ b/src/OpenLayers/OlMapLayers.js @@ -743,20 +743,20 @@ OlMap.prototype._registerUnknownLayer = function (layerObj) { // on rajoute des infos quand on en a var options = {}; - switch (layerId) { + switch (layerId.toLowerCase()) { case "drawing": options.format = "drawing"; break; - case "layerimport:KMl": + case "layerimport:kml": options.format = "KML"; break; - case "layerimport:GPX": + case "layerimport:gpx": options.format = "GPX"; break; - case "layerimport:GeoJSON": + case "layerimport:geojson": options.format = "GeoJSON"; break; - case "layerimport:WMS": + case "layerimport:wms": options.format = "WMS"; if (layerObj.gpGFIparams) { if (layerObj.gpGFIparams.queryable) { @@ -775,22 +775,45 @@ OlMap.prototype._registerUnknownLayer = function (layerObj) { } } break; - case "layerimport:WMTS": + case "layerimport:wmts": options.format = "WMTS"; break; - case "layerimport:MAPBOX": + case "layerimport:mapbox": options.format = "MAPBOX"; break; + case "layerimport:compute": + // TODO + // Evolution : à mettre en place au niveau des extensions + // Le widget d'import recherche si le fichier KML, GeoJSON ou GPX + // est un fichier de calcul avec la lecture de la balise 'geoportail:compute'. + // Si oui, on modifie la property 'gpResultLayerId' -> layerimport:COMPUTE + // Et, on ajoute les options du calcul dans les properties de la couche. + options.format = "COMPUTE"; + var prop = layerObj.getProperties(); + options.graph = prop.graph || ""; + options.control = prop.control || ""; + options.title = prop.title || ""; + options.controlOptions = prop.controlOptions || {}; + options.data = prop.data || {}; + break; default: // FIXME // cas où l'ID est de la forme : - // ex. isochrones : Voiture$OGC:OPENLS;Isocurve ou VOITURE$GEOPORTAIL:GPP:Isocurve - // ex. itineraire : Voiture$OGC:OPENLS;Itineraire ou VOITURE$GEOPORTAIL:GPP:Itineraire - var key = layerId.toUpperCase(); - if (key.includes("OGC:OPENLS;ISOCURVE") || - key.includes("OGC:OPENLS;ITINERAIRE") || - key.includes("GEOPORTAIL:GPP:ISOCURVE") || - key.includes("GEOPORTAIL:GPP:ITINERAIRE")) { + // ex. isochrones : + // Voiture$OGC:OPENLS;Isocurve + // Voiture$GEOPORTAIL:GPP:Isocurve + // Pieton$OGC:OPENLS;Isocurve + // Pieton$GEOPORTAIL:GPP:Isocurve + // ex. itineraire : + // Voiture$OGC:OPENLS;Itineraire + // Voiture$GEOPORTAIL:GPP:Itineraire + // Pieton$OGC:OPENLS;Itineraire + // Pieton$GEOPORTAIL:GPP:Itineraire + var key = layerId.toLowerCase(); + if (key.includes("ogc:openls;isocurve") || + key.includes("ogc:openls;itineraire") || + key.includes("geoportail:gpp:isocurve") || + key.includes("geoportail:gpp:itineraire")) { // result layer name options.format = "COMPUTE"; // graph name (voiture / pieton) @@ -809,7 +832,7 @@ OlMap.prototype._registerUnknownLayer = function (layerObj) { // Et, si la couche est toujours non reconnue !? if (layerId === "unknownLayer") { - return; + return; // pas super... } // on rajoute un timestamp From 6c2f07f7a743825ce52fd7c0093941d5dd2ac8eb Mon Sep 17 00:00:00 2001 From: "jean-philippe.bazonnais" Date: Sat, 1 Apr 2023 17:53:06 +0200 Subject: [PATCH 5/7] Fix sur le style des couches COMPUTE --- src/Interface/IMapBase.js | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/src/Interface/IMapBase.js b/src/Interface/IMapBase.js index 673d3feb8..4e0ba3a14 100644 --- a/src/Interface/IMapBase.js +++ b/src/Interface/IMapBase.js @@ -41,10 +41,12 @@ var switch2D3D = function (viewMode) { // traitement des couches de calcul if (layer.options.format.toUpperCase() === "COMPUTE") { // TODO : - // transmettre les bons styles à la couche 2D->3D - // isocurve = fill-color : "rgba(0, 183, 152, 0.7)" - // itineraire = stroke-color : "rgba(0,183,152,0.9)", - // stroke-width : 12 + // les styles pour la 2D et 3D sont ajoutés à la volée, + // une evolution est à mettre en place sur les contrôles, + // les contrôles doivent transmettre les styles à la couche 2D & 3D. + // ex. isocurve = fill-color : "rgba(0,183,152,0.7)" + // ex. itineraire = stroke-color : "rgba(0,183,152,0.9)", + // stroke-width : 12 // les controles fournissent leurs méta-informations utiles à leur reconstruction en 2D. // les infos issues de la methode getData() : @@ -65,9 +67,19 @@ var switch2D3D = function (viewMode) { geojsonStr = this.getLibMapControl("route").getGeoJSON(); geojsonObj = JSON.parse(geojsonStr); geojsonObj.features.forEach(feature => { + if (!feature.properties) { + feature.properties = {}; + } if (feature.geometry.type === "Point") { + // style propre à la 3D feature.properties.icon = ""; } + // style pour la 2D et 3D + if (feature.geometry.type === "LineString") { + feature.properties["stroke"] = "#00B798"; + feature.properties["stroke-opacity"] = 0.9; + feature.properties["stroke-width"] = 12; + } }); oldMap.layersOptions[layer.id].data = JSON.stringify(geojsonObj); break; @@ -76,9 +88,18 @@ var switch2D3D = function (viewMode) { geojsonStr = this.getLibMapControl("isocurve").getGeoJSON(); geojsonObj = JSON.parse(geojsonStr); geojsonObj.features.forEach(feature => { + if (!feature.properties) { + feature.properties = {}; + } if (feature.geometry.type === "Point") { + // style propre à la 3D feature.properties.icon = ""; } + // style pour la 2D et 3D + if (feature.geometry.type === "Polygon") { + feature.properties["fill"] = "#00B798"; + feature.properties["fill-opacity"] = 0.7; + } }); oldMap.layersOptions[layer.id].data = JSON.stringify(geojsonObj); break; From ee5c03338c5bf4d5e1936ffc5ea1d172c97f4d96 Mon Sep 17 00:00:00 2001 From: elias couppe Date: Mon, 3 Apr 2023 14:56:28 +0200 Subject: [PATCH 6/7] update(changelog) changelog release 3.3.25 --- DRAFT_CHANGELOG.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/DRAFT_CHANGELOG.md b/DRAFT_CHANGELOG.md index cfc60e76e..069203cf9 100644 --- a/DRAFT_CHANGELOG.md +++ b/DRAFT_CHANGELOG.md @@ -6,6 +6,8 @@ ## Summary +Corrections styles couches COMPUTE et imports + ## Changelog * [Added] @@ -16,6 +18,9 @@ * [Fixed] + - fix sur le styles des couches COMPUTE (6c2f07f7a743825ce52fd7c0093941d5dd2ac8eb) + - fix import KML (e3ff993104854c45a87e71b702a40c42f0d2479d et 450e32de52b60624a22f6d60ddc11b0c57116d38) + * [Deprecated] * [Security] From 5f12868d84c398951a3c7de3e9d83309466a8d66 Mon Sep 17 00:00:00 2001 From: elias couppe Date: Mon, 3 Apr 2023 15:00:10 +0200 Subject: [PATCH 7/7] release 3.3.25 --- package.json | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/package.json b/package.json index e5bbf2289..9cc677c87 100644 --- a/package.json +++ b/package.json @@ -1,9 +1,9 @@ { "name": "geoportal-sdk", - "version": "3.3.24", - "date": "23/03/2023", - "SDK2DVersion": "3.3.24", - "SDK3DVersion": "3.3.24", + "version": "3.3.25", + "date": "03/04/2023", + "SDK2DVersion": "3.3.25", + "SDK3DVersion": "3.3.25", "description": "French Geoportal SDK based on OpenLayers (2D) and iTowns (3D) libraries", "main": "dist/2d/GpSDK2D-src.js, dist/3d/GpSDK3d-src.js", "module": "src/SDK2D.js, src/SDK3D.js",