From 6437d5fe85fa0072686ca31cab8e848e0ed75c33 Mon Sep 17 00:00:00 2001 From: Mauro Bartolomeoli Date: Mon, 8 Jul 2019 14:18:22 +0200 Subject: [PATCH] Fixes #3835: upgrade to openlayers 5.3.0 --- build/buildConfig.js | 1 - package-lock.json | 3780 ++++++++++++----- package.json | 5 +- project/custom/templates/index.html | 2 - project/custom/templates/webpack.config.js | 1 - project/standard/templates/index.html | 2 - project/standard/templates/indexTemplate.html | 2 - web/client/api/WFS3.js | 144 + web/client/api/__tests__/WFS3-test.js | 252 ++ .../components/map/__tests__/BaseMap-test.jsx | 11 +- .../cesium/__tests__/Layer-test-chrome.jsx | 126 + .../components/map/cesium/plugins/WMSLayer.js | 6 +- .../map/cesium/plugins/WMTSLayer.js | 25 +- .../components/map/leaflet/DrawSupport.jsx | 2 +- .../map/leaflet/__tests__/Layer-test.jsx | 156 + .../map/leaflet/plugins/WMSLayer.js | 4 +- .../map/leaflet/plugins/WMTSLayer.js | 23 +- .../components/map/openlayers/DrawSupport.jsx | 331 +- .../components/map/openlayers/Feature.jsx | 24 +- .../openlayers/HighlightFeatureSupport.jsx | 24 +- .../components/map/openlayers/Layer.jsx | 28 +- .../map/openlayers/LegacyVectorStyle.js | 181 +- .../components/map/openlayers/Locate.jsx | 9 +- web/client/components/map/openlayers/Map.jsx | 89 +- .../map/openlayers/MeasurementSupport.jsx | 122 +- .../components/map/openlayers/Overview.jsx | 19 +- .../components/map/openlayers/ScaleBar.jsx | 14 +- .../map/openlayers/SelectionSupport.jsx | 53 +- .../map/openlayers/SnapshotSupport.jsx | 9 +- .../components/map/openlayers/VectorStyle.js | 162 +- .../openlayers/__tests__/DrawSupport-test.jsx | 103 +- .../map/openlayers/__tests__/Feature-test.jsx | 49 +- .../HighlightFeatureSupport-test.jsx | 27 +- .../map/openlayers/__tests__/Layer-test.jsx | 346 +- .../__tests__/LegacyVectorStyle-test.js | 94 +- .../map/openlayers/__tests__/Locate-test.jsx | 21 +- .../map/openlayers/__tests__/Map-test.jsx | 85 +- .../__tests__/MeasurementSupport-test.jsx | 46 +- .../openlayers/__tests__/Overview-test.jsx | 21 +- .../openlayers/__tests__/ScaleBar-test.jsx | 21 +- .../openlayers/__tests__/VectorStyle-test.js | 136 +- web/client/components/map/openlayers/index.js | 14 +- .../map/openlayers/plugins/BingLayer.js | 9 +- .../map/openlayers/plugins/GoogleLayer.js | 26 +- .../map/openlayers/plugins/GraticuleLayer.js | 9 +- .../map/openlayers/plugins/MapQuest.js | 2 +- .../map/openlayers/plugins/MarkerLayer.js | 18 +- .../map/openlayers/plugins/OSMLayer.js | 9 +- .../map/openlayers/plugins/OverlayLayer.js | 8 +- .../openlayers/plugins/TileProviderLayer.js | 19 +- .../map/openlayers/plugins/VectorLayer.js | 17 +- .../map/openlayers/plugins/WFS3Layer.js | 128 + .../map/openlayers/plugins/WMSLayer.js | 331 +- .../map/openlayers/plugins/WMTSLayer.js | 113 +- .../map/openlayers/plugins/index.js | 21 +- .../map/openlayers/snapshot/GrabMap.jsx | 22 +- .../map/openlayers/snapshot/Preview.jsx | 14 +- .../snapshot/__tests__/GrabMap-test.jsx | 13 +- .../snapshot/__tests__/Preview-test.jsx | 14 +- .../components/map/plugins/openlayers.js | 16 +- .../mapcontrols/Snapshot/SnapshotSupport.jsx | 3 +- web/client/components/print/MapPreview.jsx | 7 +- web/client/examples/api/index.html | 2 - web/client/examples/plugins/index.html | 2 - web/client/index.html | 2 - web/client/indexTemplate.html | 2 - web/client/plugins/MapImport.jsx | 4 +- web/client/plugins/Snapshot.jsx | 5 +- web/client/plugins/map/openlayers/index.js | 20 +- web/client/reducers/annotations.js | 46 +- web/client/simple.html | 2 - web/client/utils/DrawSupportUtils.jsx | 79 - web/client/utils/StyleUtils.js | 3 +- web/client/utils/VectorStyleUtils.js | 11 +- web/client/utils/VectorTileUtils.js | 15 + .../utils/__tests__/VectorStyleUtils-test.js | 9 +- .../utils/__tests__/VectorTileUtils-test.js | 36 + web/client/utils/leaflet/DrawSupportUtils.js | 45 + .../__tests__/DrawSupportUtils-test.js | 0 .../leaflet/{test => __tests__}/WMTS-test.js | 0 .../utils/openlayers/DrawSupportUtils.js | 39 + web/client/utils/openlayers/DrawUtils.js | 38 +- web/client/utils/openlayers/Icons.js | 39 +- web/client/utils/openlayers/Layers.js | 139 +- web/client/utils/openlayers/OlLocate.js | 84 +- web/client/utils/openlayers/OlPopUp.js | 7 +- web/client/utils/openlayers/StyleUtils.js | 23 +- .../utils/openlayers/VectorTileUtils.js | 26 + .../utils/openlayers/__tests__/Icons-test.js | 5 +- .../__tests__/VectorTileUtils-test.js | 18 + web/client/utils/openlayers/projUtils.js | 10 +- 91 files changed, 5619 insertions(+), 2461 deletions(-) create mode 100644 web/client/api/WFS3.js create mode 100644 web/client/api/__tests__/WFS3-test.js create mode 100644 web/client/components/map/openlayers/plugins/WFS3Layer.js delete mode 100644 web/client/utils/DrawSupportUtils.jsx create mode 100644 web/client/utils/VectorTileUtils.js create mode 100644 web/client/utils/__tests__/VectorTileUtils-test.js create mode 100644 web/client/utils/leaflet/DrawSupportUtils.js rename web/client/utils/{ => leaflet}/__tests__/DrawSupportUtils-test.js (100%) rename web/client/utils/leaflet/{test => __tests__}/WMTS-test.js (100%) create mode 100644 web/client/utils/openlayers/DrawSupportUtils.js create mode 100644 web/client/utils/openlayers/VectorTileUtils.js create mode 100644 web/client/utils/openlayers/__tests__/VectorTileUtils-test.js diff --git a/build/buildConfig.js b/build/buildConfig.js index 61127206ad..4a55aea202 100644 --- a/build/buildConfig.js +++ b/build/buildConfig.js @@ -68,7 +68,6 @@ module.exports = (bundles, themeEntries, paths, extractThemesPlugin, prod, publi } }), new NormalModuleReplacementPlugin(/leaflet$/, path.join(paths.framework, "libs", "leaflet")), - new NormalModuleReplacementPlugin(/openlayers$/, path.join(paths.framework, "libs", "openlayers")), new NormalModuleReplacementPlugin(/proj4$/, path.join(paths.framework, "libs", "proj4")), new NoEmitOnErrorsPlugin(), extractThemesPlugin diff --git a/package-lock.json b/package-lock.json index bac2ba9632..54ab39cada 100644 --- a/package-lock.json +++ b/package-lock.json @@ -54,6 +54,122 @@ "xmldom": "0.1.27" } }, + "@terrestris/base-util": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/@terrestris/base-util/-/base-util-0.1.4.tgz", + "integrity": "sha512-LlGiKWCxBNthY9ktwoIpZ3BWVmdB4Ok5NJcp2U+Km5TFmTXiR7FD4y16Dt5YuY7Cd+nxjRgJzQxytY51z67H8Q==", + "requires": { + "lodash": "4.17.11", + "loglevel": "1.6.1", + "query-string": "5.1.1", + "url-parse": "1.4.4", + "validator": "10.11.0" + }, + "dependencies": { + "lodash": { + "version": "4.17.11", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", + "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" + }, + "query-string": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/query-string/-/query-string-5.1.1.tgz", + "integrity": "sha512-gjWOsm2SoGlgLEdAGt7a6slVOk9mGiXmPFMqrEhLQ68rhQuBnpfs3+EmlvqKyxnCo9/PPlF+9MtY02S1aFg+Jw==", + "requires": { + "decode-uri-component": "0.2.0", + "object-assign": "4.1.1", + "strict-uri-encode": "1.1.0" + } + }, + "url-parse": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.4.4.tgz", + "integrity": "sha512-/92DTTorg4JjktLNLe6GPS2/RvAd/RGr6LuktmWSMLEOa6rjnlrFXNgSbSmkNvCoL2T028A0a1JaJLzRMlFoHg==", + "requires": { + "querystringify": "2.1.1", + "requires-port": "1.0.0" + } + } + } + }, + "@terrestris/ol-util": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@terrestris/ol-util/-/ol-util-3.0.0.tgz", + "integrity": "sha512-5cNFdZAzf++m6gv2dZ5XyVT2QmOmb3Hwml4QgNaTjWyU3yvpi5vNqdVhUHgP5sSJDDM1pIIZLSJwDV4s2dmjow==", + "requires": { + "@terrestris/base-util": "0.1.4", + "@turf/turf": "5.1.6", + "lodash": "4.17.11", + "proj4": "2.5.0", + "shpjs": "3.4.3" + }, + "dependencies": { + "jszip": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/jszip/-/jszip-2.6.1.tgz", + "integrity": "sha1-uI86ey5noqBIFSmCx6N1bZxIKPA=", + "requires": { + "pako": "1.0.10" + } + }, + "lodash": { + "version": "4.17.11", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", + "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" + }, + "proj4": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/proj4/-/proj4-2.5.0.tgz", + "integrity": "sha512-XZTRT7OPdLzgvtTqL8DG2cEj8lYdovztOwiwpwRSYayOty5Ipf3H68dh/fiL+HKDEyetmQSMhkkMGiJoyziz3w==", + "requires": { + "mgrs": "1.0.0", + "wkt-parser": "https://github.com/geosolutions-it/wkt-parser/tarball/mapstore2_fixes" + } + }, + "shpjs": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/shpjs/-/shpjs-3.4.3.tgz", + "integrity": "sha512-NZM75+SLgPt9dK91Z92QK+fVd2OR6zswAmkTrkHRc4mnONbAWGo38I+AxCYsKgCNfqF5cZUi2KfO7r2TZ+tHdw==", + "requires": { + "jszip": "2.6.1", + "lie": "3.1.1", + "lru-cache": "2.7.3", + "parsedbf": "1.0.0", + "proj4": "2.5.0" + } + } + } + }, + "@turf/along": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/along/-/along-5.1.5.tgz", + "integrity": "sha1-YdbmplhKzdq1asVYTge/jL5fi+s=", + "requires": { + "@turf/bearing": "5.1.5", + "@turf/destination": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5" + } + }, + "@turf/area": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/area/-/area-5.1.5.tgz", + "integrity": "sha1-79iZv9Jgzb0VQbKjwVX4pdLu+h0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, "@turf/bbox": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-4.1.0.tgz", @@ -62,6 +178,16 @@ "@turf/meta": "4.7.4" } }, + "@turf/bbox-clip": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox-clip/-/bbox-clip-5.1.5.tgz", + "integrity": "sha1-M2S1Mo3/nzz0HZ4C7a/zdNFQzIQ=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "lineclip": "1.1.5" + } + }, "@turf/bbox-polygon": { "version": "5.1.5", "resolved": "https://registry.npmjs.org/@turf/bbox-polygon/-/bbox-polygon-5.1.5.tgz", @@ -79,6 +205,24 @@ "@turf/invariant": "5.2.0" } }, + "@turf/bezier-spline": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bezier-spline/-/bezier-spline-5.1.5.tgz", + "integrity": "sha1-WaJ7ul17l+8Vqz/VpA+9I4cEm8o=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/boolean-clockwise": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/boolean-clockwise/-/boolean-clockwise-5.1.5.tgz", + "integrity": "sha1-MwK32sYsXikaB4nimvcoM4f6nes=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, "@turf/boolean-contains": { "version": "5.1.5", "resolved": "https://registry.npmjs.org/@turf/boolean-contains/-/boolean-contains-5.1.5.tgz", @@ -110,6 +254,125 @@ } } }, + "@turf/boolean-crosses": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/boolean-crosses/-/boolean-crosses-5.1.5.tgz", + "integrity": "sha1-Ab+uollvFk3kpNMlCU3HwlXHFdY=", + "requires": { + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-intersect": "5.1.5", + "@turf/polygon-to-line": "5.1.5" + }, + "dependencies": { + "@turf/line-intersect": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-5.1.5.tgz", + "integrity": "sha1-DikHGuQDKV5JFyO8SfXPrI0R3fM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-segment": "5.1.5", + "@turf/meta": "5.2.0", + "geojson-rbush": "2.1.0" + } + }, + "@turf/line-segment": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", + "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "geojson-rbush": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/geojson-rbush/-/geojson-rbush-2.1.0.tgz", + "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "rbush": "2.0.2" + } + } + } + }, + "@turf/boolean-disjoint": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/@turf/boolean-disjoint/-/boolean-disjoint-5.1.6.tgz", + "integrity": "sha512-KHvUS6SBNYHBCLIJEJrg04pF5Oy+Fqn8V5G9U+9pti5vI9tyX7Ln2g7RSB7iJ1Cxsz8QAi6OukhXjEF2/8ZpGg==", + "requires": { + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/line-intersect": "5.1.5", + "@turf/meta": "5.2.0", + "@turf/polygon-to-line": "5.1.5" + }, + "dependencies": { + "@turf/line-intersect": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-5.1.5.tgz", + "integrity": "sha1-DikHGuQDKV5JFyO8SfXPrI0R3fM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-segment": "5.1.5", + "@turf/meta": "5.2.0", + "geojson-rbush": "2.1.0" + } + }, + "@turf/line-segment": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", + "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "geojson-rbush": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/geojson-rbush/-/geojson-rbush-2.1.0.tgz", + "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "rbush": "2.0.2" + } + } + } + }, + "@turf/boolean-equal": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/boolean-equal/-/boolean-equal-5.1.5.tgz", + "integrity": "sha1-Kfj21gu4RQff12WzIlTbjnLJOKQ=", + "requires": { + "@turf/clean-coords": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "geojson-equality": "0.1.6" + } + }, "@turf/boolean-overlap": { "version": "5.1.5", "resolved": "https://registry.npmjs.org/@turf/boolean-overlap/-/boolean-overlap-5.1.5.tgz", @@ -165,6 +428,37 @@ } } }, + "@turf/boolean-parallel": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/boolean-parallel/-/boolean-parallel-5.1.5.tgz", + "integrity": "sha1-c5NYR16ltlx+GCejw+DopofTqF0=", + "requires": { + "@turf/clean-coords": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/line-segment": "5.1.5", + "@turf/rhumb-bearing": "5.1.5" + }, + "dependencies": { + "@turf/line-segment": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", + "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, "@turf/boolean-point-in-polygon": { "version": "5.1.5", "resolved": "https://registry.npmjs.org/@turf/boolean-point-in-polygon/-/boolean-point-in-polygon-5.1.5.tgz", @@ -183,13 +477,16 @@ "@turf/invariant": "5.2.0" } }, - "@turf/center": { + "@turf/boolean-within": { "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/center/-/center-5.1.5.tgz", - "integrity": "sha1-RKss2VT2PA03dX9xWKmcPvURS4A=", + "resolved": "https://registry.npmjs.org/@turf/boolean-within/-/boolean-within-5.1.5.tgz", + "integrity": "sha1-RxBdVtB1Kp0Pv81Dw2pfkUnchpc=", "requires": { "@turf/bbox": "5.1.5", - "@turf/helpers": "5.1.5" + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/boolean-point-on-line": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" }, "dependencies": { "@turf/bbox": { @@ -211,106 +508,1688 @@ } } }, - "@turf/destination": { - "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/destination/-/destination-5.1.5.tgz", - "integrity": "sha1-7TU4G9zoO73cvQei4rzivd/7zCY=", - "requires": { - "@turf/helpers": "5.1.5", - "@turf/invariant": "5.2.0" - } - }, - "@turf/distance": { - "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/distance/-/distance-5.1.5.tgz", - "integrity": "sha1-Oc8YIEu/h1h9cH5gmmARiQkVZAk=", - "requires": { - "@turf/helpers": "5.1.5", - "@turf/invariant": "5.2.0" - } - }, - "@turf/great-circle": { + "@turf/buffer": { "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/great-circle/-/great-circle-5.1.5.tgz", - "integrity": "sha1-3r+2cc5HVQnLY3MBwV/PzPo1mpM=", + "resolved": "https://registry.npmjs.org/@turf/buffer/-/buffer-5.1.5.tgz", + "integrity": "sha1-hByWJ8+5dLEirE4alW8EZrwCMcQ=", "requires": { + "@turf/bbox": "5.1.5", + "@turf/center": "5.1.5", "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "@turf/projection": "5.1.5", + "d3-geo": "1.7.1", + "turf-jsts": "1.2.3" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/center": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/center/-/center-5.1.5.tgz", + "integrity": "sha1-RKss2VT2PA03dX9xWKmcPvURS4A=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/helpers": "5.1.5" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/center-mean": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/center-mean/-/center-mean-5.1.5.tgz", + "integrity": "sha1-jI6YdTkeXwnw5uePXWYbiLIQigo=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/center-median": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/center-median/-/center-median-5.1.5.tgz", + "integrity": "sha1-u0Yb/noqSGAdikcnaFcYcjoUqHI=", + "requires": { + "@turf/center-mean": "5.1.5", + "@turf/centroid": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/center-of-mass": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/center-of-mass/-/center-of-mass-5.1.5.tgz", + "integrity": "sha1-TTvXnYhJjbq4Mk1PafAyL2Uguco=", + "requires": { + "@turf/centroid": "5.1.5", + "@turf/convex": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/centroid": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/centroid/-/centroid-5.1.5.tgz", + "integrity": "sha1-d4radCFjNQIa2P0OemWoNJ1Tx2k=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/circle": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@turf/circle/-/circle-6.0.1.tgz", + "integrity": "sha512-pF9XsYtCvY9ZyNqJ3hFYem9VaiGdVNQb0SFq/zzDMwH3iWZPPJQHnnDB/3e8RD1VDtBBov9p5uO2k7otsfezjw==", + "requires": { + "@turf/destination": "6.0.1", + "@turf/helpers": "6.1.4" + }, + "dependencies": { + "@turf/destination": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@turf/destination/-/destination-6.0.1.tgz", + "integrity": "sha512-MroK4nRdp7as174miCAugp8Uvorhe6rZ7MJiC9Hb4+hZR7gNFJyVKmkdDDXIoCYs6MJQsx0buI+gsCpKwgww0Q==", + "requires": { + "@turf/helpers": "6.1.4", + "@turf/invariant": "6.1.2" + } + }, + "@turf/helpers": { + "version": "6.1.4", + "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-6.1.4.tgz", + "integrity": "sha512-vJvrdOZy1ngC7r3MDA7zIGSoIgyrkWcGnNIEaqn/APmw+bVLF2gAW7HIsdTxd12s5wQMqEpqIQrmrbRRZ0xC7g==" + }, + "@turf/invariant": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-6.1.2.tgz", + "integrity": "sha512-WU08Ph8j0J2jVGlQCKChXoCtI50BB3yEH21V++V0T4cR1T27HKCxkehV2sYMwTierfMBgjwSwDIsxnR4/2mWXg==", + "requires": { + "@turf/helpers": "6.1.4" + } + } + } + }, + "@turf/clean-coords": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/clean-coords/-/clean-coords-5.1.5.tgz", + "integrity": "sha1-EoAKmKeMmkUqcuxChJPEOs8q2h8=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/clone": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/clone/-/clone-5.1.5.tgz", + "integrity": "sha1-JT6NNUdxgZduM636tQoPAqfw42c=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "@turf/clusters": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/clusters/-/clusters-5.1.5.tgz", + "integrity": "sha1-ZzpeXxsZycq6vFfJCO6t1oIiTdQ=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/clusters-dbscan": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/clusters-dbscan/-/clusters-dbscan-5.1.5.tgz", + "integrity": "sha1-V4H7TmVsdHoLjpk333MYHAMJ4m8=", + "requires": { + "@turf/clone": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "density-clustering": "1.3.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/clusters-kmeans": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/clusters-kmeans/-/clusters-kmeans-5.1.5.tgz", + "integrity": "sha1-/W3+qLEzuovcI3CsPKzuFYejAvE=", + "requires": { + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "skmeans": "0.9.7" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/collect": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/collect/-/collect-5.1.5.tgz", + "integrity": "sha1-/pjJqMIY7PJP/DPXApUXt8GbKj4=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/helpers": "5.1.5", + "rbush": "2.0.2" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/combine": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/combine/-/combine-5.1.5.tgz", + "integrity": "sha1-uxS976VVBDVxlfwaEkzX1TqMiQU=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/concave": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/concave/-/concave-5.1.5.tgz", + "integrity": "sha1-I7uqw4fQNLlldKG9cNBZI3qdIRA=", + "requires": { + "@turf/clone": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "@turf/tin": "5.1.5", + "topojson-client": "3.0.0", + "topojson-server": "3.0.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/convex": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/convex/-/convex-5.1.5.tgz", + "integrity": "sha1-Dfk3fdACIWzpghsH9wXgN9rj4B0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "concaveman": "1.1.1" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/destination": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/destination/-/destination-5.1.5.tgz", + "integrity": "sha1-7TU4G9zoO73cvQei4rzivd/7zCY=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/difference": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/difference/-/difference-5.1.5.tgz", + "integrity": "sha1-ok1pCnvKgD8QkKnuO52Qb8Q3H0I=", + "requires": { + "@turf/area": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "turf-jsts": "1.2.3" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/dissolve": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/dissolve/-/dissolve-5.1.5.tgz", + "integrity": "sha1-LPEzqQIdIWODHD16lY1lB/nYGTg=", + "requires": { + "@turf/boolean-overlap": "5.1.5", + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-intersect": "5.1.5", + "@turf/meta": "5.2.0", + "@turf/union": "5.1.5", + "geojson-rbush": "2.1.0", + "get-closest": "0.0.4" + }, + "dependencies": { + "@turf/line-intersect": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-5.1.5.tgz", + "integrity": "sha1-DikHGuQDKV5JFyO8SfXPrI0R3fM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-segment": "5.1.5", + "@turf/meta": "5.2.0", + "geojson-rbush": "2.1.0" + } + }, + "@turf/line-segment": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", + "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "geojson-rbush": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/geojson-rbush/-/geojson-rbush-2.1.0.tgz", + "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "rbush": "2.0.2" + } + } + } + }, + "@turf/distance": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/distance/-/distance-5.1.5.tgz", + "integrity": "sha1-Oc8YIEu/h1h9cH5gmmARiQkVZAk=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/ellipse": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/ellipse/-/ellipse-5.1.5.tgz", + "integrity": "sha1-1XyrhTmFkgzeYCKKeNgEWAJcVL4=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/rhumb-destination": "5.1.5", + "@turf/transform-rotate": "5.1.5" + } + }, + "@turf/envelope": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/envelope/-/envelope-5.1.5.tgz", + "integrity": "sha1-UBMwnFP91D369LWIplw/7X28EIo=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/bbox-polygon": "5.1.5", + "@turf/helpers": "5.1.5" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/explode": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/explode/-/explode-5.1.5.tgz", + "integrity": "sha1-sSsvd0AEobSPYrqVsgocZVo94Rg=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/flatten": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/flatten/-/flatten-5.1.5.tgz", + "integrity": "sha1-2iknBnEz7WFpsLnWB7khVoiqE1g=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/flip": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/flip/-/flip-5.1.5.tgz", + "integrity": "sha1-Q29kOnIvDKU7n85jjkaT2zYIpoo=", + "requires": { + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/great-circle": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/great-circle/-/great-circle-5.1.5.tgz", + "integrity": "sha1-3r+2cc5HVQnLY3MBwV/PzPo1mpM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/helpers": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-5.1.5.tgz", + "integrity": "sha1-FTQFInq5M9AEpbuWQantmZ/L4M8=" + }, + "@turf/hex-grid": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/hex-grid/-/hex-grid-5.1.5.tgz", + "integrity": "sha1-m3ul/s9QUfHoWJL3E/zlxVBQKmo=", + "requires": { + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/intersect": "5.1.6", + "@turf/invariant": "5.2.0" + } + }, + "@turf/inside": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/@turf/inside/-/inside-4.1.0.tgz", + "integrity": "sha1-0zIidYVLcxxNeP/AaFbcWbEgCYU=", + "requires": { + "@turf/invariant": "4.7.3" + }, + "dependencies": { + "@turf/invariant": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", + "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + } + } + }, + "@turf/interpolate": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/interpolate/-/interpolate-5.1.5.tgz", + "integrity": "sha1-DxLwq3VtbdEK+ykMpuh3ve8BPqo=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/centroid": "5.1.5", + "@turf/clone": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/hex-grid": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "@turf/point-grid": "5.1.5", + "@turf/square-grid": "5.1.5", + "@turf/triangle-grid": "5.1.5" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/intersect": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/@turf/intersect/-/intersect-5.1.6.tgz", + "integrity": "sha512-KXyNv/GXdoGAOy03qZF53rgtXC2tNhF/4jLwTKiVRrBQH6kcEpipGStdJ+QkYIlarQPa8f7I9UlVAB19et4MfQ==", + "requires": { + "@turf/clean-coords": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/truncate": "5.1.5", + "turf-jsts": "1.2.3" + } + }, + "@turf/invariant": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-5.2.0.tgz", + "integrity": "sha1-8BUP9ykLOFd7c9CIt5MsHuCqkKc=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "@turf/isobands": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/isobands/-/isobands-5.1.5.tgz", + "integrity": "sha1-a0TO9YTVUaMTBBh68jtKFYLj8I0=", + "requires": { + "@turf/area": "5.1.5", + "@turf/bbox": "5.1.5", + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/explode": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/isolines": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/isolines/-/isolines-5.1.5.tgz", + "integrity": "sha1-irTn9Cuz38VGFOW/FVln9+VdLeE=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/kinks": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/kinks/-/kinks-5.1.5.tgz", + "integrity": "sha1-irtpYdm7AQchO63fLCwmQNAlaYA=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "@turf/length": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/length/-/length-5.1.5.tgz", + "integrity": "sha1-86X4ZMK5lqi7RxeUU1ofrxLuvvs=", + "requires": { + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/line-arc": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-arc/-/line-arc-5.1.5.tgz", + "integrity": "sha1-AHinRHg1oSrkFKIR+aZNEYYVDhU=", + "requires": { + "@turf/circle": "5.1.5", + "@turf/destination": "5.1.5", + "@turf/helpers": "5.1.5" + }, + "dependencies": { + "@turf/circle": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/circle/-/circle-5.1.5.tgz", + "integrity": "sha1-mxV3g1UIq1L7HBCypQZcuiuHtqU=", + "requires": { + "@turf/destination": "5.1.5", + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/line-chunk": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-chunk/-/line-chunk-5.1.5.tgz", + "integrity": "sha1-kQqFwFwG2dD5w4l3oF4IGNUIXEI=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/length": "5.1.5", + "@turf/line-slice-along": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/line-intersect": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-4.1.0.tgz", + "integrity": "sha1-GvjT1w0mPgJf41tBuGWmJlCLSoQ=", + "requires": { + "@turf/helpers": "4.7.3", + "@turf/invariant": "4.7.3", + "@turf/line-segment": "4.7.3", + "@turf/meta": "4.7.4", + "geojson-rbush": "1.2.0" + }, + "dependencies": { + "@turf/helpers": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-4.7.3.tgz", + "integrity": "sha1-vDEqxDyrPFMqSDFRxMOCxWSUKek=" + }, + "@turf/invariant": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", + "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + } + } + }, + "@turf/line-offset": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-offset/-/line-offset-5.1.5.tgz", + "integrity": "sha1-KrWy8In4yRPiMdmUN4553KkLWh4=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/line-overlap": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-overlap/-/line-overlap-5.1.5.tgz", + "integrity": "sha1-lDxvh6A4bcQ9+sEdKz/5wRLNP2A=", + "requires": { + "@turf/boolean-point-on-line": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-segment": "5.1.5", + "@turf/meta": "5.2.0", + "@turf/nearest-point-on-line": "5.1.5", + "geojson-rbush": "2.1.0" + }, + "dependencies": { + "@turf/line-segment": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", + "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "geojson-rbush": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/geojson-rbush/-/geojson-rbush-2.1.0.tgz", + "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "rbush": "2.0.2" + } + } + } + }, + "@turf/line-segment": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-4.7.3.tgz", + "integrity": "sha1-dx9x+mU9jmu8Wo2JIoMWPpSzTXo=", + "requires": { + "@turf/helpers": "4.7.3", + "@turf/invariant": "4.7.3", + "@turf/meta": "4.7.4" + }, + "dependencies": { + "@turf/helpers": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-4.7.3.tgz", + "integrity": "sha1-vDEqxDyrPFMqSDFRxMOCxWSUKek=" + }, + "@turf/invariant": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", + "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + } + } + }, + "@turf/line-slice": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-slice/-/line-slice-5.1.5.tgz", + "integrity": "sha1-Hs/OFGKjeFeXVM7fRGTN4mgp8rU=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/nearest-point-on-line": "5.1.5" + } + }, + "@turf/line-slice-along": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-slice-along/-/line-slice-along-5.1.5.tgz", + "integrity": "sha1-7drQoh70efKWihG9LdcomiEy6aU=", + "requires": { + "@turf/bearing": "5.1.5", + "@turf/destination": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5" + } + }, + "@turf/line-split": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-split/-/line-split-5.1.5.tgz", + "integrity": "sha1-Wy30w3YZty73JbUWPPmSbVVArLc=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-intersect": "5.1.5", + "@turf/line-segment": "5.1.5", + "@turf/meta": "5.2.0", + "@turf/nearest-point-on-line": "5.1.5", + "@turf/square": "5.1.5", + "@turf/truncate": "5.1.5", + "geojson-rbush": "2.1.0" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/line-intersect": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-5.1.5.tgz", + "integrity": "sha1-DikHGuQDKV5JFyO8SfXPrI0R3fM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-segment": "5.1.5", + "@turf/meta": "5.2.0", + "geojson-rbush": "2.1.0" + } + }, + "@turf/line-segment": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", + "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "geojson-rbush": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/geojson-rbush/-/geojson-rbush-2.1.0.tgz", + "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "rbush": "2.0.2" + } + } + } + }, + "@turf/line-to-polygon": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-to-polygon/-/line-to-polygon-5.1.5.tgz", + "integrity": "sha1-ITz0Gmj4Ikd4ujnTGH3sPouBhlo=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/mask": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/mask/-/mask-5.1.5.tgz", + "integrity": "sha1-mrD+8aJyyY/j70kvn/thggayQtU=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "@turf/union": "5.1.5", + "rbush": "2.0.2" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/meta": { + "version": "4.7.4", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-4.7.4.tgz", + "integrity": "sha1-beLx6YkLj2S2aeS0fAmyCJMGOXc=" + }, + "@turf/midpoint": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/midpoint/-/midpoint-5.1.5.tgz", + "integrity": "sha1-4mH2srDqgSTM7/VSomLdRlydBfA=", + "requires": { + "@turf/bearing": "5.1.5", + "@turf/destination": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5" + } + }, + "@turf/nearest-point": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/nearest-point/-/nearest-point-5.1.5.tgz", + "integrity": "sha1-EgUN5Bw5hEMiTHl43g9iE5ANNPs=", + "requires": { + "@turf/clone": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/nearest-point-on-line": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/nearest-point-on-line/-/nearest-point-on-line-5.1.5.tgz", + "integrity": "sha1-VgauKX8VlHUkvqUaKp71HsG/nDY=", + "requires": { + "@turf/bearing": "5.1.5", + "@turf/destination": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-intersect": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/line-intersect": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-5.1.5.tgz", + "integrity": "sha1-DikHGuQDKV5JFyO8SfXPrI0R3fM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-segment": "5.1.5", + "@turf/meta": "5.2.0", + "geojson-rbush": "2.1.0" + } + }, + "@turf/line-segment": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", + "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "geojson-rbush": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/geojson-rbush/-/geojson-rbush-2.1.0.tgz", + "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "rbush": "2.0.2" + } + } + } + }, + "@turf/nearest-point-to-line": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/@turf/nearest-point-to-line/-/nearest-point-to-line-5.1.6.tgz", + "integrity": "sha512-ZSvDIEiHhifn/vNwLXZI/E8xmEz5yBPqfUR7BVHRZrB1cP7jLhKZvkbidjG//uW8Fr1Ulc+PFOXczLspIcx/lw==", + "requires": { + "@turf/helpers": "6.1.4", + "@turf/invariant": "6.1.2", + "@turf/meta": "6.0.2", + "@turf/point-to-line-distance": "5.1.6", + "object-assign": "4.1.1" + }, + "dependencies": { + "@turf/helpers": { + "version": "6.1.4", + "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-6.1.4.tgz", + "integrity": "sha512-vJvrdOZy1ngC7r3MDA7zIGSoIgyrkWcGnNIEaqn/APmw+bVLF2gAW7HIsdTxd12s5wQMqEpqIQrmrbRRZ0xC7g==" + }, + "@turf/invariant": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-6.1.2.tgz", + "integrity": "sha512-WU08Ph8j0J2jVGlQCKChXoCtI50BB3yEH21V++V0T4cR1T27HKCxkehV2sYMwTierfMBgjwSwDIsxnR4/2mWXg==", + "requires": { + "@turf/helpers": "6.1.4" + } + }, + "@turf/meta": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-6.0.2.tgz", + "integrity": "sha512-VA7HJkx7qF1l3+GNGkDVn2oXy4+QoLP6LktXAaZKjuT1JI0YESat7quUkbCMy4zP9lAUuvS4YMslLyTtr919FA==", + "requires": { + "@turf/helpers": "6.1.4" + } + } + } + }, + "@turf/planepoint": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/planepoint/-/planepoint-5.1.5.tgz", + "integrity": "sha1-GLvfAG91ne9eQsagBsn53oGyt/8=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/point-grid": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/point-grid/-/point-grid-5.1.5.tgz", + "integrity": "sha1-MFFBJI9Quv42zn5mukuX56sjaIc=", + "requires": { + "@turf/boolean-within": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/point-on-feature": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/point-on-feature/-/point-on-feature-5.1.5.tgz", + "integrity": "sha1-MMfwMkMCd8ZBjZbSieRba/shP+c=", + "requires": { + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/center": "5.1.5", + "@turf/explode": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/nearest-point": "5.1.5" + } + }, + "@turf/point-to-line-distance": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/@turf/point-to-line-distance/-/point-to-line-distance-5.1.6.tgz", + "integrity": "sha512-PE3hiTeeDEi4ZLPtI8XAzFYW9nHo1EVsZGm/4ZVV8jo39d3X1oLVHxY3e1PkCmWwRapXy4QLqvnTQ7nU4wspNw==", + "requires": { + "@turf/bearing": "6.0.1", + "@turf/distance": "6.0.1", + "@turf/helpers": "6.1.4", + "@turf/invariant": "6.1.2", + "@turf/meta": "6.0.2", + "@turf/projection": "6.0.1", + "@turf/rhumb-bearing": "6.0.1", + "@turf/rhumb-distance": "6.0.1" + }, + "dependencies": { + "@turf/bearing": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@turf/bearing/-/bearing-6.0.1.tgz", + "integrity": "sha512-mXY1NozqV9EFfBTbUItujwfqfQF0G/Xe2fzvnZle90ekPEUfhi4Dgf5JswJTd96J9LiT8kcd6Jonp5khnx0wIg==", + "requires": { + "@turf/helpers": "6.1.4", + "@turf/invariant": "6.1.2" + } + }, + "@turf/clone": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@turf/clone/-/clone-6.0.2.tgz", + "integrity": "sha512-UVpYPnW3wRj3bPncR6Z2PRbowBk+nEdVWgGewPxrKKLfvswtVtG9n/OIyvbU3E3ZOadBVxTH2uAMEMOz4800FA==", + "requires": { + "@turf/helpers": "6.1.4" + } + }, + "@turf/distance": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@turf/distance/-/distance-6.0.1.tgz", + "integrity": "sha512-q7t7rWIWfkg7MP1Vt4uLjSEhe5rPfCO2JjpKmk7JC+QZKEQkuvHEqy3ejW1iC7Kw5ZcZNR3qdMGGz+6HnVwqvg==", + "requires": { + "@turf/helpers": "6.1.4", + "@turf/invariant": "6.1.2" + } + }, + "@turf/helpers": { + "version": "6.1.4", + "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-6.1.4.tgz", + "integrity": "sha512-vJvrdOZy1ngC7r3MDA7zIGSoIgyrkWcGnNIEaqn/APmw+bVLF2gAW7HIsdTxd12s5wQMqEpqIQrmrbRRZ0xC7g==" + }, + "@turf/invariant": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-6.1.2.tgz", + "integrity": "sha512-WU08Ph8j0J2jVGlQCKChXoCtI50BB3yEH21V++V0T4cR1T27HKCxkehV2sYMwTierfMBgjwSwDIsxnR4/2mWXg==", + "requires": { + "@turf/helpers": "6.1.4" + } + }, + "@turf/meta": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-6.0.2.tgz", + "integrity": "sha512-VA7HJkx7qF1l3+GNGkDVn2oXy4+QoLP6LktXAaZKjuT1JI0YESat7quUkbCMy4zP9lAUuvS4YMslLyTtr919FA==", + "requires": { + "@turf/helpers": "6.1.4" + } + }, + "@turf/projection": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@turf/projection/-/projection-6.0.1.tgz", + "integrity": "sha512-Y3RvGT6I53MjYKLG69e9sMk45wJXcLbrEO1t6P3WQQQGqA2gYhhMJyV41vE2Z2llrJpvs2dDx/tIeQzGd0HHMQ==", + "requires": { + "@turf/clone": "6.0.2", + "@turf/helpers": "6.1.4", + "@turf/meta": "6.0.2" + } + }, + "@turf/rhumb-bearing": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@turf/rhumb-bearing/-/rhumb-bearing-6.0.1.tgz", + "integrity": "sha512-MVBra8OVfjM4+/N0B3o6cBIYg9p/uRKzA9uk05RfrzasEbUL1vdD23LkTooVL74Yw4UxL8BQD9hS5Re2COJFDA==", + "requires": { + "@turf/helpers": "6.1.4", + "@turf/invariant": "6.1.2" + } + }, + "@turf/rhumb-distance": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@turf/rhumb-distance/-/rhumb-distance-6.0.1.tgz", + "integrity": "sha512-3G45DQtQByzzfHFPcCyJdUZFwsd45zfZ7sAb1ddF7mhEj4G70+T2G3GKjInymqDNrbyh2gbG6wQiZSToC8Uf9g==", + "requires": { + "@turf/helpers": "6.1.4", + "@turf/invariant": "6.1.2" + } + } + } + }, + "@turf/points-within-polygon": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/points-within-polygon/-/points-within-polygon-5.1.5.tgz", + "integrity": "sha1-K4VaXfOq2lfC7oIKB1SrlJKKIzc=", + "requires": { + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/polygon-tangents": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/polygon-tangents/-/polygon-tangents-5.1.5.tgz", + "integrity": "sha1-K/AJkUcwJbF44lDcfLmuVAm71lI=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/polygon-to-line": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/polygon-to-line/-/polygon-to-line-5.1.5.tgz", + "integrity": "sha1-I7tEjYTcTGUZmaxhGjbZHFklA2o=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/polygon-to-linestring": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/@turf/polygon-to-linestring/-/polygon-to-linestring-4.1.0.tgz", + "integrity": "sha1-THE9SUG9iKauaGgXNv1WJZbyPhU=", + "requires": { + "@turf/helpers": "4.7.3", + "@turf/invariant": "4.7.3" + }, + "dependencies": { + "@turf/helpers": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-4.7.3.tgz", + "integrity": "sha1-vDEqxDyrPFMqSDFRxMOCxWSUKek=" + }, + "@turf/invariant": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", + "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + } + } + }, + "@turf/polygonize": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/polygonize/-/polygonize-5.1.5.tgz", + "integrity": "sha1-BJP6EYefOdELmtAs5qI+lC0IqjI=", + "requires": { + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/envelope": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/projection": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/projection/-/projection-5.1.5.tgz", + "integrity": "sha1-JFF+7rLzaBa6n3EueubWo2jt91c=", + "requires": { + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/random": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/random/-/random-5.1.5.tgz", + "integrity": "sha1-sy78k0Vgroulfo67UfJBw5+6Lns=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "@turf/rewind": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/rewind/-/rewind-5.1.5.tgz", + "integrity": "sha1-nqPbSmi3PB/R3RH1djGxQ8/vock=", + "requires": { + "@turf/boolean-clockwise": "5.1.5", + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/rhumb-bearing": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/rhumb-bearing/-/rhumb-bearing-5.1.5.tgz", + "integrity": "sha1-rPalAkJ+uMSeGM2mrg7/qwxd3NI=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/rhumb-destination": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/rhumb-destination/-/rhumb-destination-5.1.5.tgz", + "integrity": "sha1-sbKuuSFUfyrAwamUtqEw+SRjx0I=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/rhumb-distance": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/rhumb-distance/-/rhumb-distance-5.1.5.tgz", + "integrity": "sha1-GAaFdiX0IlOE2tQT5p85U4/192U=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0" + } + }, + "@turf/sample": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/sample/-/sample-5.1.5.tgz", + "integrity": "sha1-6ctEikeJzFbuPeLdZ4HiNDQ1tBE=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, + "@turf/sector": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/sector/-/sector-5.1.5.tgz", + "integrity": "sha1-rCu5TBPt1gNPb9wrZwCBNdIPXgc=", + "requires": { + "@turf/circle": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/line-arc": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/circle": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/circle/-/circle-5.1.5.tgz", + "integrity": "sha1-mxV3g1UIq1L7HBCypQZcuiuHtqU=", + "requires": { + "@turf/destination": "5.1.5", + "@turf/helpers": "5.1.5" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/shortest-path": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/shortest-path/-/shortest-path-5.1.5.tgz", + "integrity": "sha1-hUroCW9rw+EwD6ynfz6PZ9j5Nas=", + "requires": { + "@turf/bbox": "5.1.5", + "@turf/bbox-polygon": "5.1.5", + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/clean-coords": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "@turf/transform-scale": "5.1.5" + }, + "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + } + }, + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/simplify": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/simplify/-/simplify-5.1.5.tgz", + "integrity": "sha1-Csjyei60IYGD7dmZjDJ1q+QIuSY=", + "requires": { + "@turf/clean-coords": "5.1.5", + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/square": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/square/-/square-5.1.5.tgz", + "integrity": "sha1-qnsh5gM8ySUsOlvW89iNq9b+0YA=", + "requires": { + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5" + } + }, + "@turf/square-grid": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/square-grid/-/square-grid-5.1.5.tgz", + "integrity": "sha1-G9X3uesU8LYLwjH+/nNR0aMvGlE=", + "requires": { + "@turf/boolean-contains": "5.1.5", + "@turf/boolean-overlap": "5.1.5", + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/intersect": "5.1.6", "@turf/invariant": "5.2.0" } }, - "@turf/helpers": { + "@turf/standard-deviational-ellipse": { "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-5.1.5.tgz", - "integrity": "sha1-FTQFInq5M9AEpbuWQantmZ/L4M8=" + "resolved": "https://registry.npmjs.org/@turf/standard-deviational-ellipse/-/standard-deviational-ellipse-5.1.5.tgz", + "integrity": "sha1-hc0oO14ayljyG9ZkEuQUtW2FIyQ=", + "requires": { + "@turf/center-mean": "5.1.5", + "@turf/ellipse": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "@turf/points-within-polygon": "5.1.5" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } }, - "@turf/inside": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/@turf/inside/-/inside-4.1.0.tgz", - "integrity": "sha1-0zIidYVLcxxNeP/AaFbcWbEgCYU=", + "@turf/tag": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/tag/-/tag-5.1.5.tgz", + "integrity": "sha1-0e4aUIjs/UoUEQGcmCOczypJfSA=", "requires": { - "@turf/invariant": "4.7.3" + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" }, "dependencies": { - "@turf/invariant": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", - "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } } } }, - "@turf/invariant": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-5.2.0.tgz", - "integrity": "sha1-8BUP9ykLOFd7c9CIt5MsHuCqkKc=", + "@turf/tesselate": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/tesselate/-/tesselate-5.1.5.tgz", + "integrity": "sha1-MqWU6cIaAEIKn5DSxD3z4RZgYc0=", + "requires": { + "@turf/helpers": "5.1.5", + "earcut": "2.1.5" + } + }, + "@turf/tin": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/tin/-/tin-5.1.5.tgz", + "integrity": "sha1-KCI+r8X76a6azKgc3P6l0UJMkX0=", "requires": { "@turf/helpers": "5.1.5" } }, - "@turf/line-intersect": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-4.1.0.tgz", - "integrity": "sha1-GvjT1w0mPgJf41tBuGWmJlCLSoQ=", + "@turf/transform-rotate": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/transform-rotate/-/transform-rotate-5.1.5.tgz", + "integrity": "sha1-0Jbt2eMA/jFQadVNjkWMQJIh7fs=", "requires": { - "@turf/helpers": "4.7.3", - "@turf/invariant": "4.7.3", - "@turf/line-segment": "4.7.3", - "@turf/meta": "4.7.4", - "geojson-rbush": "1.2.0" + "@turf/centroid": "5.1.5", + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "@turf/rhumb-bearing": "5.1.5", + "@turf/rhumb-destination": "5.1.5", + "@turf/rhumb-distance": "5.1.5" }, "dependencies": { - "@turf/helpers": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-4.7.3.tgz", - "integrity": "sha1-vDEqxDyrPFMqSDFRxMOCxWSUKek=" - }, - "@turf/invariant": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", - "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } } } }, - "@turf/line-overlap": { + "@turf/transform-scale": { "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/line-overlap/-/line-overlap-5.1.5.tgz", - "integrity": "sha1-lDxvh6A4bcQ9+sEdKz/5wRLNP2A=", + "resolved": "https://registry.npmjs.org/@turf/transform-scale/-/transform-scale-5.1.5.tgz", + "integrity": "sha1-cP064BhWz3uunxWtVhzf6PiQAbk=", "requires": { - "@turf/boolean-point-on-line": "5.1.5", + "@turf/bbox": "5.1.5", + "@turf/center": "5.1.5", + "@turf/centroid": "5.1.5", + "@turf/clone": "5.1.5", "@turf/helpers": "5.1.5", "@turf/invariant": "5.2.0", - "@turf/line-segment": "5.1.5", "@turf/meta": "5.2.0", - "@turf/nearest-point-on-line": "5.1.5", - "geojson-rbush": "2.1.0" + "@turf/rhumb-bearing": "5.1.5", + "@turf/rhumb-destination": "5.1.5", + "@turf/rhumb-distance": "5.1.5" }, "dependencies": { - "@turf/line-segment": { + "@turf/bbox": { "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-5.1.5.tgz", - "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", "requires": { "@turf/helpers": "5.1.5", - "@turf/invariant": "5.2.0", "@turf/meta": "5.2.0" } }, @@ -321,69 +2200,203 @@ "requires": { "@turf/helpers": "5.1.5" } - }, - "geojson-rbush": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/geojson-rbush/-/geojson-rbush-2.1.0.tgz", - "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", - "requires": { - "@turf/helpers": "5.1.5", - "@turf/meta": "5.2.0", - "rbush": "2.0.2" - } } } }, - "@turf/line-segment": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/line-segment/-/line-segment-4.7.3.tgz", - "integrity": "sha1-dx9x+mU9jmu8Wo2JIoMWPpSzTXo=", + "@turf/transform-translate": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/transform-translate/-/transform-translate-5.1.5.tgz", + "integrity": "sha1-Uwolf7Hccmja3Ks05nkB6yo97GM=", "requires": { - "@turf/helpers": "4.7.3", - "@turf/invariant": "4.7.3", - "@turf/meta": "4.7.4" + "@turf/clone": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "@turf/meta": "5.2.0", + "@turf/rhumb-destination": "5.1.5" }, "dependencies": { - "@turf/helpers": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-4.7.3.tgz", - "integrity": "sha1-vDEqxDyrPFMqSDFRxMOCxWSUKek=" - }, - "@turf/invariant": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", - "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } } } }, - "@turf/meta": { - "version": "4.7.4", - "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-4.7.4.tgz", - "integrity": "sha1-beLx6YkLj2S2aeS0fAmyCJMGOXc=" + "@turf/triangle-grid": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/triangle-grid/-/triangle-grid-5.1.5.tgz", + "integrity": "sha1-ezZ2IQhVTBTyjK/zxIsc/ILI3IE=", + "requires": { + "@turf/distance": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/intersect": "5.1.6", + "@turf/invariant": "5.2.0" + } }, - "@turf/nearest-point-on-line": { + "@turf/truncate": { "version": "5.1.5", - "resolved": "https://registry.npmjs.org/@turf/nearest-point-on-line/-/nearest-point-on-line-5.1.5.tgz", - "integrity": "sha1-VgauKX8VlHUkvqUaKp71HsG/nDY=", + "resolved": "https://registry.npmjs.org/@turf/truncate/-/truncate-5.1.5.tgz", + "integrity": "sha1-nu37Oxi6gfLJjT6tCUMcyhiErYk=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0" + }, + "dependencies": { + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } + } + } + }, + "@turf/turf": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/@turf/turf/-/turf-5.1.6.tgz", + "integrity": "sha1-wxIlkoh+0jS3VGi4qMRb+Ib7+PY=", "requires": { + "@turf/along": "5.1.5", + "@turf/area": "5.1.5", + "@turf/bbox": "5.1.5", + "@turf/bbox-clip": "5.1.5", + "@turf/bbox-polygon": "5.1.5", "@turf/bearing": "5.1.5", + "@turf/bezier-spline": "5.1.5", + "@turf/boolean-clockwise": "5.1.5", + "@turf/boolean-contains": "5.1.5", + "@turf/boolean-crosses": "5.1.5", + "@turf/boolean-disjoint": "5.1.6", + "@turf/boolean-equal": "5.1.5", + "@turf/boolean-overlap": "5.1.5", + "@turf/boolean-parallel": "5.1.5", + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/boolean-point-on-line": "5.1.5", + "@turf/boolean-within": "5.1.5", + "@turf/buffer": "5.1.5", + "@turf/center": "5.1.5", + "@turf/center-mean": "5.1.5", + "@turf/center-median": "5.1.5", + "@turf/center-of-mass": "5.1.5", + "@turf/centroid": "5.1.5", + "@turf/circle": "5.1.5", + "@turf/clean-coords": "5.1.5", + "@turf/clone": "5.1.5", + "@turf/clusters": "5.1.5", + "@turf/clusters-dbscan": "5.1.5", + "@turf/clusters-kmeans": "5.1.5", + "@turf/collect": "5.1.5", + "@turf/combine": "5.1.5", + "@turf/concave": "5.1.5", + "@turf/convex": "5.1.5", "@turf/destination": "5.1.5", + "@turf/difference": "5.1.5", + "@turf/dissolve": "5.1.5", "@turf/distance": "5.1.5", + "@turf/ellipse": "5.1.5", + "@turf/envelope": "5.1.5", + "@turf/explode": "5.1.5", + "@turf/flatten": "5.1.5", + "@turf/flip": "5.1.5", + "@turf/great-circle": "5.1.5", "@turf/helpers": "5.1.5", - "@turf/invariant": "5.2.0", + "@turf/hex-grid": "5.1.5", + "@turf/interpolate": "5.1.5", + "@turf/intersect": "5.1.6", + "@turf/invariant": "5.1.5", + "@turf/isobands": "5.1.5", + "@turf/isolines": "5.1.5", + "@turf/kinks": "5.1.5", + "@turf/length": "5.1.5", + "@turf/line-arc": "5.1.5", + "@turf/line-chunk": "5.1.5", "@turf/line-intersect": "5.1.5", - "@turf/meta": "5.2.0" + "@turf/line-offset": "5.1.5", + "@turf/line-overlap": "5.1.5", + "@turf/line-segment": "5.1.5", + "@turf/line-slice": "5.1.5", + "@turf/line-slice-along": "5.1.5", + "@turf/line-split": "5.1.5", + "@turf/line-to-polygon": "5.1.5", + "@turf/mask": "5.1.5", + "@turf/meta": "5.1.6", + "@turf/midpoint": "5.1.5", + "@turf/nearest-point": "5.1.5", + "@turf/nearest-point-on-line": "5.1.5", + "@turf/nearest-point-to-line": "5.1.6", + "@turf/planepoint": "5.1.5", + "@turf/point-grid": "5.1.5", + "@turf/point-on-feature": "5.1.5", + "@turf/point-to-line-distance": "5.1.6", + "@turf/points-within-polygon": "5.1.5", + "@turf/polygon-tangents": "5.1.5", + "@turf/polygon-to-line": "5.1.5", + "@turf/polygonize": "5.1.5", + "@turf/projection": "5.1.5", + "@turf/random": "5.1.5", + "@turf/rewind": "5.1.5", + "@turf/rhumb-bearing": "5.1.5", + "@turf/rhumb-destination": "5.1.5", + "@turf/rhumb-distance": "5.1.5", + "@turf/sample": "5.1.5", + "@turf/sector": "5.1.5", + "@turf/shortest-path": "5.1.5", + "@turf/simplify": "5.1.5", + "@turf/square": "5.1.5", + "@turf/square-grid": "5.1.5", + "@turf/standard-deviational-ellipse": "5.1.5", + "@turf/tag": "5.1.5", + "@turf/tesselate": "5.1.5", + "@turf/tin": "5.1.5", + "@turf/transform-rotate": "5.1.5", + "@turf/transform-scale": "5.1.5", + "@turf/transform-translate": "5.1.5", + "@turf/triangle-grid": "5.1.5", + "@turf/truncate": "5.1.5", + "@turf/union": "5.1.5", + "@turf/unkink-polygon": "5.1.5", + "@turf/voronoi": "5.1.5" }, "dependencies": { + "@turf/bbox": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/bbox/-/bbox-5.1.5.tgz", + "integrity": "sha1-MFHfUUrUxQ9KT5uKLRX9i2hA7aM=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/meta": "5.1.6" + } + }, + "@turf/circle": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/circle/-/circle-5.1.5.tgz", + "integrity": "sha1-mxV3g1UIq1L7HBCypQZcuiuHtqU=", + "requires": { + "@turf/destination": "5.1.5", + "@turf/helpers": "5.1.5" + } + }, + "@turf/invariant": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-5.1.5.tgz", + "integrity": "sha1-9Z9P76CSJLFdzhZR+QPIaNV6JOE=", + "requires": { + "@turf/helpers": "5.1.5" + } + }, "@turf/line-intersect": { "version": "5.1.5", "resolved": "https://registry.npmjs.org/@turf/line-intersect/-/line-intersect-5.1.5.tgz", "integrity": "sha1-DikHGuQDKV5JFyO8SfXPrI0R3fM=", "requires": { "@turf/helpers": "5.1.5", - "@turf/invariant": "5.2.0", + "@turf/invariant": "5.1.5", "@turf/line-segment": "5.1.5", - "@turf/meta": "5.2.0", + "@turf/meta": "5.1.6", "geojson-rbush": "2.1.0" } }, @@ -393,14 +2406,14 @@ "integrity": "sha1-Mgeq7lRqskw9jcPMY/kcdwuAE+U=", "requires": { "@turf/helpers": "5.1.5", - "@turf/invariant": "5.2.0", - "@turf/meta": "5.2.0" + "@turf/invariant": "5.1.5", + "@turf/meta": "5.1.6" } }, "@turf/meta": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", - "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.1.6.tgz", + "integrity": "sha1-wgqGPt7Qhp+yhUje6Ik0G8y0akY=", "requires": { "@turf/helpers": "5.1.5" } @@ -411,33 +2424,53 @@ "integrity": "sha1-O9c745H8ELCuaT2bis6iquC4Oo0=", "requires": { "@turf/helpers": "5.1.5", - "@turf/meta": "5.2.0", + "@turf/meta": "5.1.6", "rbush": "2.0.2" } } } }, - "@turf/polygon-to-linestring": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/@turf/polygon-to-linestring/-/polygon-to-linestring-4.1.0.tgz", - "integrity": "sha1-THE9SUG9iKauaGgXNv1WJZbyPhU=", + "@turf/union": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/union/-/union-5.1.5.tgz", + "integrity": "sha1-UyhbYJQEf8WNlqrA6pCGXsNNRUs=", "requires": { - "@turf/helpers": "4.7.3", - "@turf/invariant": "4.7.3" + "@turf/helpers": "5.1.5", + "turf-jsts": "1.2.3" + } + }, + "@turf/unkink-polygon": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/unkink-polygon/-/unkink-polygon-5.1.5.tgz", + "integrity": "sha1-ewGEfFD7V0riV54Z5Ey6hSbSE8M=", + "requires": { + "@turf/area": "5.1.5", + "@turf/boolean-point-in-polygon": "5.1.5", + "@turf/helpers": "5.1.5", + "@turf/meta": "5.2.0", + "rbush": "2.0.2" }, "dependencies": { - "@turf/helpers": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/helpers/-/helpers-4.7.3.tgz", - "integrity": "sha1-vDEqxDyrPFMqSDFRxMOCxWSUKek=" - }, - "@turf/invariant": { - "version": "4.7.3", - "resolved": "https://registry.npmjs.org/@turf/invariant/-/invariant-4.7.3.tgz", - "integrity": "sha1-U482fSPBE/yEnXDJpSS4Vjh0YB0=" + "@turf/meta": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@turf/meta/-/meta-5.2.0.tgz", + "integrity": "sha1-OxrUhe4MOwsXdRMqMsOE1T5LpT0=", + "requires": { + "@turf/helpers": "5.1.5" + } } } }, + "@turf/voronoi": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/@turf/voronoi/-/voronoi-5.1.5.tgz", + "integrity": "sha1-6FbpQG3MLyXWbdyJhYTifC6/ymY=", + "requires": { + "@turf/helpers": "5.1.5", + "@turf/invariant": "5.2.0", + "d3-voronoi": "1.1.2" + } + }, "JSV": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/JSV/-/JSV-4.0.2.tgz", @@ -452,12 +2485,14 @@ "abbrev": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", - "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" + "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", + "dev": true }, "accepts": { "version": "1.3.7", "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", + "dev": true, "requires": { "mime-types": "2.1.24", "negotiator": "0.6.2" @@ -466,7 +2501,8 @@ "acorn": { "version": "5.2.1", "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.2.1.tgz", - "integrity": "sha512-jG0u7c4Ly+3QkkW18V+NRDN+4bWHdln30NL1ZL2AvFZZmQe/BfopYCtghCKKVBUSetZ4QKcyA0pY6/4Gw8Pv8w==" + "integrity": "sha512-jG0u7c4Ly+3QkkW18V+NRDN+4bWHdln30NL1ZL2AvFZZmQe/BfopYCtghCKKVBUSetZ4QKcyA0pY6/4Gw8Pv8w==", + "dev": true }, "acorn-dynamic-import": { "version": "2.0.2", @@ -519,7 +2555,8 @@ "after": { "version": "0.8.2", "resolved": "https://registry.npmjs.org/after/-/after-0.8.2.tgz", - "integrity": "sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8=" + "integrity": "sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8=", + "dev": true }, "ag-grid": { "version": "3.3.3", @@ -535,6 +2572,7 @@ "version": "4.11.8", "resolved": "https://registry.npmjs.org/ajv/-/ajv-4.11.8.tgz", "integrity": "sha1-gv+wKynmYq5TvcIK8VlHcGc5xTY=", + "dev": true, "requires": { "co": "4.6.0", "json-stable-stringify": "1.0.1" @@ -555,6 +2593,7 @@ "version": "0.1.4", "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", + "dev": true, "requires": { "kind-of": "3.2.2", "longest": "1.0.1", @@ -689,20 +2728,6 @@ } } }, - "aproba": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", - "integrity": "sha1-aALmJk79GMeQobDVF/DyYnvyyUo=" - }, - "are-we-there-yet": { - "version": "1.1.5", - "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", - "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", - "requires": { - "delegates": "1.0.0", - "readable-stream": "2.0.6" - } - }, "argparse": { "version": "1.0.10", "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", @@ -715,17 +2740,20 @@ "arr-diff": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=" + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", + "dev": true }, "arr-flatten": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", - "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", + "dev": true }, "arr-union": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", - "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=" + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", + "dev": true }, "array-equal": { "version": "1.0.0", @@ -754,12 +2782,8 @@ "array-unique": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=" - }, - "arraybuffer.slice": { - "version": "0.0.7", - "resolved": "https://registry.npmjs.org/arraybuffer.slice/-/arraybuffer.slice-0.0.7.tgz", - "integrity": "sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog==" + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", + "dev": true }, "asap": { "version": "2.0.6", @@ -770,6 +2794,7 @@ "version": "0.2.4", "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", + "dev": true, "requires": { "safer-buffer": "2.1.2" } @@ -815,12 +2840,14 @@ "assert-plus": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-0.2.0.tgz", - "integrity": "sha1-104bh+ev/A24qttwIfP+SBAasjQ=" + "integrity": "sha1-104bh+ev/A24qttwIfP+SBAasjQ=", + "dev": true }, "assign-symbols": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", - "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=" + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", + "dev": true }, "ast-traverse": { "version": "0.1.1", @@ -838,6 +2865,7 @@ "version": "2.6.0", "resolved": "https://registry.npmjs.org/async/-/async-2.6.0.tgz", "integrity": "sha512-xAfGg1/NTLBBKlHFmnd7PlmUW9KhVQIUuSrYem9xzFUZy13ScvtyGGejaae9iAVRiRq9+Cx7DPFaAAhCpyxyPw==", + "dev": true, "requires": { "lodash": "4.17.5" } @@ -848,20 +2876,17 @@ "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==", "dev": true }, - "async-limiter": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz", - "integrity": "sha512-jp/uFnooOiO+L211eZOoSyzpOITMXx1rBITauYykG3BRYPu8h0UcxsPNB04RR5vo4Tyz3+ay17tR6JVf9qzYWg==" - }, "asynckit": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", + "dev": true }, "atob": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", - "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==" + "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", + "dev": true }, "attr-accept": { "version": "1.1.3", @@ -888,12 +2913,14 @@ "aws-sign2": { "version": "0.6.0", "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.6.0.tgz", - "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=" + "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=", + "dev": true }, "aws4": { "version": "1.8.0", "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", - "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==" + "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==", + "dev": true }, "axios": { "version": "0.18.0", @@ -2455,25 +4482,23 @@ "to-fast-properties": "1.0.3" } }, - "babylon": { - "version": "7.0.0-beta.19", - "resolved": "https://registry.npmjs.org/babylon/-/babylon-7.0.0-beta.19.tgz", - "integrity": "sha512-Vg0C9s/REX6/WIXN37UKpv5ZhRi6A4pjHlpkE34+8/a6c2W1Q692n3hmc+SZG5lKRnaExLUbxtJ1SVT+KaCQ/A==" - }, "backo2": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz", - "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=" + "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=", + "dev": true }, "balanced-match": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", - "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true }, "base": { "version": "0.11.2", "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "dev": true, "requires": { "cache-base": "1.0.1", "class-utils": "0.3.6", @@ -2488,6 +4513,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, "requires": { "is-descriptor": "1.0.2" } @@ -2496,6 +4522,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -2504,6 +4531,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -2512,6 +4540,7 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, "requires": { "is-accessor-descriptor": "1.0.0", "is-data-descriptor": "1.0.0", @@ -2521,7 +4550,8 @@ "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true } } }, @@ -2540,7 +4570,8 @@ "base64-arraybuffer": { "version": "0.1.5", "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz", - "integrity": "sha1-c5JncZI7Whl0etZmqlzUv5xunOg=" + "integrity": "sha1-c5JncZI7Whl0etZmqlzUv5xunOg=", + "dev": true }, "base64-js": { "version": "1.3.0", @@ -2551,7 +4582,8 @@ "base64id": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/base64id/-/base64id-1.0.0.tgz", - "integrity": "sha1-R2iMuZu2gE8OBtPnY7HDLlfY5rY=" + "integrity": "sha1-R2iMuZu2gE8OBtPnY7HDLlfY5rY=", + "dev": true }, "batch": { "version": "0.6.1", @@ -2568,6 +4600,7 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", + "dev": true, "requires": { "tweetnacl": "0.14.5" } @@ -2576,6 +4609,7 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/better-assert/-/better-assert-1.0.2.tgz", "integrity": "sha1-QIZrnhueC1W0gYlDEeaPr/rrxSI=", + "dev": true, "requires": { "callsite": "1.0.0" } @@ -2585,15 +4619,6 @@ "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==" }, - "binary": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/binary/-/binary-0.3.0.tgz", - "integrity": "sha1-n2BVO8XOjDOG87VTz/R0Yq3sqnk=", - "requires": { - "buffers": "0.1.1", - "chainsaw": "0.1.0" - } - }, "binary-extensions": { "version": "1.13.1", "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", @@ -2629,11 +4654,6 @@ } } }, - "blob": { - "version": "0.0.5", - "resolved": "https://registry.npmjs.org/blob/-/blob-0.0.5.tgz", - "integrity": "sha512-gaqbzQPqOoamawKg0LGVd7SzLgXS+JH61oWprSLH+P+abTczqJbhTR8CmJ2u9/bUYNmHTGJx/UEmn6doAvvuig==" - }, "bluebird": { "version": "3.5.1", "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", @@ -2721,6 +4741,7 @@ "version": "2.10.1", "resolved": "https://registry.npmjs.org/boom/-/boom-2.10.1.tgz", "integrity": "sha1-OciRjO/1eZ+D+UkqhI9iWt0Mdm8=", + "dev": true, "requires": { "hoek": "2.16.3" } @@ -2734,6 +4755,7 @@ "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, "requires": { "balanced-match": "1.0.0", "concat-map": "0.0.1" @@ -2743,6 +4765,7 @@ "version": "2.3.2", "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "dev": true, "requires": { "arr-flatten": "1.1.0", "array-unique": "0.3.2", @@ -2760,6 +4783,7 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, "requires": { "is-extendable": "0.1.1" } @@ -2904,16 +4928,6 @@ "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=", "dev": true }, - "buffers": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/buffers/-/buffers-0.1.1.tgz", - "integrity": "sha1-skV5w77U1tOWru5tmorn9Ugqt7s=" - }, - "builtin-modules": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-2.0.0.tgz", - "integrity": "sha512-3U5kUA5VPsRUA3nofm/BXX7GVHKfxz0hOBAPxXrIvHzlDRkQVqEn6yi8QJegxl4LzOHLdvb7XF5dVawa/VVYBg==" - }, "builtin-status-codes": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", @@ -2930,6 +4944,7 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "dev": true, "requires": { "collection-visit": "1.0.0", "component-emitter": "1.2.1", @@ -2945,7 +4960,8 @@ "callsite": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/callsite/-/callsite-1.0.0.tgz", - "integrity": "sha1-KAOY5dZkvXQDi28JBRU+borxvCA=" + "integrity": "sha1-KAOY5dZkvXQDi28JBRU+borxvCA=", + "dev": true }, "camel-case": { "version": "3.0.0", @@ -2960,7 +4976,8 @@ "camelcase": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", - "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=" + "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=", + "dev": true }, "camelcase-keys": { "version": "2.1.0", @@ -3016,12 +5033,14 @@ "caseless": { "version": "0.12.0", "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", - "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", + "dev": true }, "catharsis": { "version": "0.8.10", "resolved": "https://registry.npmjs.org/catharsis/-/catharsis-0.8.10.tgz", "integrity": "sha512-l2OUaz/3PU3MZylspVFJvwHCVfWyvcduPq4lv3AzZ2pJzZCo7kNKFNyatwujD7XgvGkNAE/Jhhbh2uARNwNkfw==", + "dev": true, "requires": { "lodash": "4.17.11" }, @@ -3029,7 +5048,8 @@ "lodash": { "version": "4.17.11", "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", - "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" + "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", + "dev": true } } }, @@ -3037,6 +5057,7 @@ "version": "0.1.3", "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", + "dev": true, "requires": { "align-text": "0.1.4", "lazy-cache": "1.0.4" @@ -3056,14 +5077,6 @@ "resolved": "https://registry.npmjs.org/chain-function/-/chain-function-1.0.1.tgz", "integrity": "sha512-SxltgMwL9uCko5/ZCLiyG2B7R9fY4pDZUw7hJ4MhirdjBLosoDqkWABi3XMucddHdLiFJMb7PD2MZifZriuMTg==" }, - "chainsaw": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/chainsaw/-/chainsaw-0.1.0.tgz", - "integrity": "sha1-XqtQsor+WAdNDVgpE4iCi15fvJg=", - "requires": { - "traverse": "0.3.9" - } - }, "chalk": { "version": "0.4.0", "resolved": "http://registry.npmjs.org/chalk/-/chalk-0.4.0.tgz", @@ -3197,6 +5210,7 @@ "version": "0.3.6", "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "dev": true, "requires": { "arr-union": "3.1.0", "define-property": "0.2.5", @@ -3208,6 +5222,7 @@ "version": "0.2.5", "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, "requires": { "is-descriptor": "0.1.6" } @@ -3269,6 +5284,7 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", + "dev": true, "requires": { "center-align": "0.1.3", "right-align": "0.1.3", @@ -3278,7 +5294,8 @@ "wordwrap": { "version": "0.0.2", "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", - "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=" + "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=", + "dev": true } } }, @@ -3293,85 +5310,11 @@ "integrity": "sha1-uI+UqCzzi4eR1YBG6kAprYjKmdE=", "dev": true }, - "closure-util": { - "version": "1.26.0", - "resolved": "https://registry.npmjs.org/closure-util/-/closure-util-1.26.0.tgz", - "integrity": "sha512-zpWABEochWrY48soiEttuqJk/OSYscS9PcvKgHvKUefM29+R8rqx5Bp8KIZHR0Nsq1JrNgxg2VTmJ/IsqN5VOA==", - "requires": { - "acorn": "5.2.1", - "async": "2.6.0", - "fs-extra": "4.0.2", - "gaze": "1.1.2", - "get-down": "1.2.0", - "glob": "7.1.2", - "graceful-fs": "4.1.11", - "handlebars": "4.0.11", - "lodash": "4.17.4", - "minimatch": "3.0.4", - "mkdirp": "0.5.1", - "nomnom": "1.8.1", - "npmlog": "4.1.2", - "rimraf": "2.6.2", - "send": "0.16.1", - "socket.io": "2.0.4", - "temp": "0.8.3" - }, - "dependencies": { - "fs-extra": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-4.0.2.tgz", - "integrity": "sha1-+RcExT0bRh+JNFKwwwfZmXZHq2s=", - "requires": { - "graceful-fs": "4.1.11", - "jsonfile": "4.0.0", - "universalify": "0.1.2" - } - }, - "glob": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", - "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", - "requires": { - "fs.realpath": "1.0.0", - "inflight": "1.0.6", - "inherits": "2.0.3", - "minimatch": "3.0.4", - "once": "1.4.0", - "path-is-absolute": "1.0.1" - } - }, - "graceful-fs": { - "version": "4.1.11", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", - "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" - }, - "jsonfile": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", - "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", - "requires": { - "graceful-fs": "4.1.11" - } - }, - "lodash": { - "version": "4.17.4", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", - "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" - }, - "rimraf": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", - "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", - "requires": { - "glob": "7.1.2" - } - } - } - }, "co": { "version": "4.6.0", "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", - "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", + "dev": true }, "coa": { "version": "1.0.4", @@ -3396,6 +5339,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "dev": true, "requires": { "map-visit": "1.0.0", "object-visit": "1.0.1" @@ -3479,6 +5423,7 @@ "version": "1.0.8", "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, "requires": { "delayed-stream": "1.0.0" } @@ -3486,8 +5431,7 @@ "commander": { "version": "2.20.0", "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.0.tgz", - "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==", - "dev": true + "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==" }, "commoner": { "version": "0.10.8", @@ -3542,17 +5486,20 @@ "component-bind": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/component-bind/-/component-bind-1.0.0.tgz", - "integrity": "sha1-AMYIq33Nk4l8AAllGx06jh5zu9E=" + "integrity": "sha1-AMYIq33Nk4l8AAllGx06jh5zu9E=", + "dev": true }, "component-emitter": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", - "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=" + "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", + "dev": true }, "component-inherit": { "version": "0.0.3", "resolved": "https://registry.npmjs.org/component-inherit/-/component-inherit-0.0.3.tgz", - "integrity": "sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM=" + "integrity": "sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM=", + "dev": true }, "compressible": { "version": "2.0.17", @@ -3604,7 +5551,8 @@ "concat-map": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true }, "concat-stream": { "version": "1.5.2", @@ -3616,6 +5564,18 @@ "typedarray": "0.0.6" } }, + "concaveman": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/concaveman/-/concaveman-1.1.1.tgz", + "integrity": "sha1-bCSCWAslI874L8K+wAoEFebmgWI=", + "requires": { + "monotone-convex-hull-2d": "1.0.1", + "point-in-polygon": "1.0.1", + "rbush": "2.0.2", + "robust-orientation": "1.1.3", + "tinyqueue": "1.2.3" + } + }, "connect": { "version": "3.6.6", "resolved": "https://registry.npmjs.org/connect/-/connect-3.6.6.tgz", @@ -3660,11 +5620,6 @@ "date-now": "0.1.4" } }, - "console-control-strings": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", - "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" - }, "constant-case": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-2.0.0.tgz", @@ -3711,7 +5666,8 @@ "cookie": { "version": "0.3.1", "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", - "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" + "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=", + "dev": true }, "cookie-signature": { "version": "1.0.6", @@ -3722,7 +5678,8 @@ "copy-descriptor": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", - "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=" + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", + "dev": true }, "copy-to-clipboard": { "version": "3.2.0", @@ -4017,6 +5974,7 @@ "version": "2.0.5", "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-2.0.5.tgz", "integrity": "sha1-O9/s3GCBR8HGcgL6KR59ylnqo7g=", + "dev": true, "requires": { "boom": "2.10.1" } @@ -4250,6 +6208,14 @@ "resolved": "https://registry.npmjs.org/d3-format/-/d3-format-1.3.2.tgz", "integrity": "sha512-Z18Dprj96ExragQ0DeGi+SYPQ7pPfRMtUXtsg/ChVIKNBCzjO8XYJvRTC1usblx52lqge56V5ect+frYTQc8WQ==" }, + "d3-geo": { + "version": "1.7.1", + "resolved": "https://registry.npmjs.org/d3-geo/-/d3-geo-1.7.1.tgz", + "integrity": "sha512-O4AempWAr+P5qbk2bC2FuN/sDW4z+dN2wDf9QV3bxQt4M5HfOEeXLgJ/UKQW0+o1Dj8BE+L5kiDbdWUMjsmQpw==", + "requires": { + "d3-array": "1.2.4" + } + }, "d3-interpolate": { "version": "1.3.2", "resolved": "https://registry.npmjs.org/d3-interpolate/-/d3-interpolate-1.3.2.tgz", @@ -4298,10 +6264,16 @@ "d3-time": "1.0.11" } }, + "d3-voronoi": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/d3-voronoi/-/d3-voronoi-1.1.2.tgz", + "integrity": "sha1-Fodmfo8TotFYyAwUgMWinLDYlzw=" + }, "dashdash": { "version": "1.14.1", "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "dev": true, "requires": { "assert-plus": "1.0.0" }, @@ -4309,7 +6281,8 @@ "assert-plus": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true } } }, @@ -4345,7 +6318,8 @@ "decamelize": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", - "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true }, "decode-uri-component": { "version": "0.2.0", @@ -4548,38 +6522,6 @@ } } }, - "decompress-zip": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/decompress-zip/-/decompress-zip-0.3.0.tgz", - "integrity": "sha1-rjvLfjTGWHmt/nfhnDD4ZgK0vbA=", - "requires": { - "binary": "0.3.0", - "graceful-fs": "4.1.15", - "mkpath": "0.1.0", - "nopt": "3.0.6", - "q": "1.5.0", - "readable-stream": "1.1.14", - "touch": "0.0.3" - }, - "dependencies": { - "isarray": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", - "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" - }, - "readable-stream": { - "version": "1.1.14", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", - "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", - "requires": { - "core-util-is": "1.0.2", - "inherits": "2.0.3", - "isarray": "0.0.1", - "string_decoder": "0.10.31" - } - } - } - }, "deconstruct-number-format": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/deconstruct-number-format/-/deconstruct-number-format-0.0.1.tgz", @@ -4633,6 +6575,7 @@ "version": "2.0.2", "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "dev": true, "requires": { "is-descriptor": "1.0.2", "isobject": "3.0.1" @@ -4642,6 +6585,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -4650,6 +6594,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -4658,6 +6603,7 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, "requires": { "is-accessor-descriptor": "1.0.0", "is-data-descriptor": "1.0.0", @@ -4667,7 +6613,8 @@ "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true } } }, @@ -4720,12 +6667,8 @@ "delayed-stream": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", - "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" - }, - "delegates": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", - "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true }, "denodeify": { "version": "1.2.1", @@ -4733,10 +6676,16 @@ "integrity": "sha1-OjYof1A05pnnV3kBBSwubJQlFjE=", "dev": true }, + "density-clustering": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/density-clustering/-/density-clustering-1.3.0.tgz", + "integrity": "sha1-3J9ZyPCrl+FiSsZJMP0xlIF9ysU=" + }, "depd": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", - "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" + "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", + "dev": true }, "des.js": { "version": "1.0.0", @@ -4751,7 +6700,8 @@ "destroy": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", - "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" + "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", + "dev": true }, "detect-indent": { "version": "4.0.0", @@ -5270,6 +7220,11 @@ "set-immediate-shim": "1.0.1" } }, + "earcut": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/earcut/-/earcut-2.1.5.tgz", + "integrity": "sha512-QFWC7ywTVLtvRAJTVp8ugsuuGQ5mVqNmJ1cRYeLrSHgP3nycr2RHTJob9OtM0v8ujuoKN0NY1a93J/omeTL1PA==" + }, "easy-table": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/easy-table/-/easy-table-1.1.1.tgz", @@ -5292,6 +7247,7 @@ "version": "0.1.2", "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", + "dev": true, "requires": { "jsbn": "0.1.1", "safer-buffer": "2.1.2" @@ -5300,7 +7256,8 @@ "ee-first": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", - "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" + "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", + "dev": true }, "electron-to-chromium": { "version": "1.3.133", @@ -5349,7 +7306,8 @@ "encodeurl": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", - "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" + "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", + "dev": true }, "encoding": { "version": "0.1.12", @@ -5368,80 +7326,6 @@ "once": "1.4.0" } }, - "engine.io": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-3.1.5.tgz", - "integrity": "sha512-D06ivJkYxyRrcEe0bTpNnBQNgP9d3xog+qZlLbui8EsMr/DouQpf5o9FzJnWYHEYE0YsFHllUv2R1dkgYZXHcA==", - "requires": { - "accepts": "1.3.7", - "base64id": "1.0.0", - "cookie": "0.3.1", - "debug": "3.1.0", - "engine.io-parser": "2.1.3", - "uws": "9.14.0", - "ws": "3.3.3" - }, - "dependencies": { - "debug": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", - "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", - "requires": { - "ms": "2.0.0" - } - }, - "ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" - } - } - }, - "engine.io-client": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-3.1.6.tgz", - "integrity": "sha512-hnuHsFluXnsKOndS4Hv6SvUrgdYx1pk2NqfaDMW+GWdgfU3+/V25Cj7I8a0x92idSpa5PIhJRKxPvp9mnoLsfg==", - "requires": { - "component-emitter": "1.2.1", - "component-inherit": "0.0.3", - "debug": "3.1.0", - "engine.io-parser": "2.1.3", - "has-cors": "1.1.0", - "indexof": "0.0.1", - "parseqs": "0.0.5", - "parseuri": "0.0.5", - "ws": "3.3.3", - "xmlhttprequest-ssl": "1.5.5", - "yeast": "0.1.2" - }, - "dependencies": { - "debug": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", - "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", - "requires": { - "ms": "2.0.0" - } - }, - "ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" - } - } - }, - "engine.io-parser": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-2.1.3.tgz", - "integrity": "sha512-6HXPre2O4Houl7c4g7Ic/XzPnHBvaEmN90vtRO9uLmwtRqQmTOw0QMevL1TOfL2Cpu1VzsaTmMotQgMdkzGkVA==", - "requires": { - "after": "0.8.2", - "arraybuffer.slice": "0.0.7", - "base64-arraybuffer": "0.1.5", - "blob": "0.0.5", - "has-binary2": "1.0.3" - } - }, "enhanced-resolve": { "version": "3.4.1", "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-3.4.1.tgz", @@ -5664,7 +7548,8 @@ "escape-html": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", - "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" + "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", + "dev": true }, "escape-string-regexp": { "version": "1.0.5", @@ -5894,11 +7779,6 @@ "integrity": "sha1-0yOky15awzHOoDNBOpJT4WQ+B8Q=", "dev": true }, - "estree-walker": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.0.tgz", - "integrity": "sha512-peq1RfVAVzr3PU/jL31RaOjUKLoZJpObQWJJ+LgfcxDUifyLZ1RjPQZTl0pzj2uJ45b7A7XpyppXvxdEqzo4rw==" - }, "esutils": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", @@ -5908,7 +7788,8 @@ "etag": { "version": "1.8.1", "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", - "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" + "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", + "dev": true }, "event-emitter": { "version": "0.3.5", @@ -6020,6 +7901,7 @@ "version": "2.1.4", "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "dev": true, "requires": { "debug": "2.6.9", "define-property": "0.2.5", @@ -6034,6 +7916,7 @@ "version": "2.6.9", "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, "requires": { "ms": "2.0.0" } @@ -6042,6 +7925,7 @@ "version": "0.2.5", "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, "requires": { "is-descriptor": "0.1.6" } @@ -6050,6 +7934,7 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, "requires": { "is-extendable": "0.1.1" } @@ -6057,7 +7942,8 @@ "ms": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true } } }, @@ -6281,6 +8167,7 @@ "version": "3.0.2", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "dev": true, "requires": { "assign-symbols": "1.0.0", "is-extendable": "1.0.1" @@ -6290,6 +8177,7 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, "requires": { "is-plain-object": "2.0.4" } @@ -6300,6 +8188,7 @@ "version": "2.0.4", "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "dev": true, "requires": { "array-unique": "0.3.2", "define-property": "1.0.0", @@ -6315,6 +8204,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, "requires": { "is-descriptor": "1.0.2" } @@ -6323,6 +8213,7 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, "requires": { "is-extendable": "0.1.1" } @@ -6331,6 +8222,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -6339,6 +8231,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -6347,6 +8240,7 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, "requires": { "is-accessor-descriptor": "1.0.0", "is-data-descriptor": "1.0.0", @@ -6356,7 +8250,8 @@ "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true } } }, @@ -6375,7 +8270,8 @@ "extsprintf": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", - "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", + "dev": true }, "fast-deep-equal": { "version": "2.0.1", @@ -6543,6 +8439,7 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "dev": true, "requires": { "extend-shallow": "2.0.1", "is-number": "3.0.0", @@ -6554,6 +8451,7 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, "requires": { "is-extendable": "0.1.1" } @@ -6642,7 +8540,8 @@ "for-in": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", - "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", + "dev": true }, "for-own": { "version": "0.1.5", @@ -6653,20 +8552,17 @@ "for-in": "1.0.2" } }, - "foreachasync": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/foreachasync/-/foreachasync-3.0.0.tgz", - "integrity": "sha1-VQKYfchxS+M5IJfzLgBxyd7gfPY=" - }, "forever-agent": { "version": "0.6.1", "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", - "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", + "dev": true }, "form-data": { "version": "2.1.4", "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.1.4.tgz", "integrity": "sha1-M8GDrPGTJ27KqYFDpp6Uv+4XUNE=", + "dev": true, "requires": { "asynckit": "0.4.0", "combined-stream": "1.0.8", @@ -6699,6 +8595,7 @@ "version": "0.2.1", "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "dev": true, "requires": { "map-cache": "0.2.2" } @@ -6706,7 +8603,8 @@ "fresh": { "version": "0.5.2", "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", - "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" + "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", + "dev": true }, "fs-access": { "version": "1.0.1", @@ -6742,7 +8640,8 @@ "fs.realpath": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true }, "fsevents": { "version": "1.2.9", @@ -7344,39 +9243,6 @@ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" }, - "gauge": { - "version": "2.7.4", - "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", - "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", - "requires": { - "aproba": "1.2.0", - "console-control-strings": "1.1.0", - "has-unicode": "2.0.1", - "object-assign": "4.1.1", - "signal-exit": "3.0.2", - "string-width": "1.0.2", - "strip-ansi": "3.0.1", - "wide-align": "1.1.3" - }, - "dependencies": { - "strip-ansi": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", - "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", - "requires": { - "ansi-regex": "2.1.1" - } - } - } - }, - "gaze": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.2.tgz", - "integrity": "sha1-hHIkZ3rbiHDWeSV+0ziP22HkAQU=", - "requires": { - "globule": "1.2.1" - } - }, "generate-function": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.3.1.tgz", @@ -7417,36 +9283,69 @@ "rbush": "2.0.2" } }, - "get-caller-file": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", - "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==", - "dev": true + "geostyler-openlayers-parser": { + "version": "https://github.com/geosolutions-it/geostyler-openlayers-parser/tarball/ms2", + "integrity": "sha512-d8Vmd30MblIjojYabIOV770UXt7a/D58d1Pc4zJK5cHZJQV0J92kTCSCkA12jjGt1ORTUV+3nLsr7wHZG9P1Ig==", + "requires": { + "@terrestris/ol-util": "3.0.0", + "geostyler-style": "1.2.1", + "lodash": "4.17.15" + }, + "dependencies": { + "lodash": { + "version": "4.17.15", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", + "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" + } + } }, - "get-down": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/get-down/-/get-down-1.2.0.tgz", - "integrity": "sha512-SbpdXn+fNmGN6pp/vBALveh3oCbWYTR3wb5qifauPSFhAfAVQ7TMOnAkVzQm4YZD2KABzJB3sA2kmMLaOylA2A==", + "geostyler-sld-parser": { + "version": "https://github.com/geosolutions-it/geostyler-sld-parser/tarball/ms2", + "integrity": "sha512-Moj9mpKXHPuDbJo7Fxt/NhSgG3fH1MTGSNG4OYFsH9Gu3BIz/zlBAsDYGOLEA+J/2VA1YIIZ5ioQ8RHSOYBCfQ==", "requires": { - "decompress-zip": "0.3.0", - "graceful-fs": "4.1.11", - "junk": "2.1.0", - "mout": "1.0.0", - "q": "1.5.0", - "request": "2.81.0", - "request-progress": "3.0.0", - "retry": "0.10.1", - "tar": "3.1.5", - "tmp": "0.0.31" + "geostyler-style": "1.2.1", + "lodash": "4.17.15", + "xml2js": "0.4.19", + "xmldom": "0.1.27" }, "dependencies": { - "graceful-fs": { - "version": "4.1.11", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", - "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" + "lodash": { + "version": "4.17.15", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", + "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" + }, + "xml2js": { + "version": "0.4.19", + "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.19.tgz", + "integrity": "sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q==", + "requires": { + "sax": "1.2.4", + "xmlbuilder": "9.0.7" + } + }, + "xmlbuilder": { + "version": "9.0.7", + "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", + "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=" } } }, + "geostyler-style": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/geostyler-style/-/geostyler-style-1.2.1.tgz", + "integrity": "sha512-GIGOt0/C2MuaI/+gMAfz78VYQp/bdoMOd2e/cCmXZ9a1bZPYJXmy02R7Vrv4TV/Q2zKq/a08UQ72G6CV1vyE+Q==" + }, + "get-caller-file": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", + "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==", + "dev": true + }, + "get-closest": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/get-closest/-/get-closest-0.0.4.tgz", + "integrity": "sha1-JprHdtHmAiqg/Vht1wjop9Miaa8=" + }, "get-stdin": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", @@ -7456,12 +9355,14 @@ "get-value": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", - "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=" + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", + "dev": true }, "getpass": { "version": "0.1.7", "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "dev": true, "requires": { "assert-plus": "1.0.0" }, @@ -7469,7 +9370,8 @@ "assert-plus": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true } } }, @@ -7671,36 +9573,6 @@ "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==", "dev": true }, - "globule": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/globule/-/globule-1.2.1.tgz", - "integrity": "sha512-g7QtgWF4uYSL5/dn71WxubOrS7JVGCnFPEnoeChJmBnyR9Mw8nGoEwOgJL/RC2Te0WhbsEUCejfH8SZNJ+adYQ==", - "requires": { - "glob": "7.1.4", - "lodash": "4.17.11", - "minimatch": "3.0.4" - }, - "dependencies": { - "glob": { - "version": "7.1.4", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", - "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", - "requires": { - "fs.realpath": "1.0.0", - "inflight": "1.0.6", - "inherits": "2.0.3", - "minimatch": "3.0.4", - "once": "1.4.0", - "path-is-absolute": "1.0.1" - } - }, - "lodash": { - "version": "4.17.11", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", - "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" - } - } - }, "graceful-fs": { "version": "4.1.15", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", @@ -7739,6 +9611,7 @@ "version": "4.0.11", "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.0.11.tgz", "integrity": "sha1-Ywo13+ApS8KB7a5v/F0yn8eYLcw=", + "dev": true, "requires": { "async": "1.5.2", "optimist": "0.6.1", @@ -7749,12 +9622,14 @@ "async": { "version": "1.5.2", "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", - "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=" + "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", + "dev": true }, "source-map": { "version": "0.4.4", "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true, "requires": { "amdefine": "0.1.1" } @@ -7764,12 +9639,14 @@ "har-schema": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-1.0.5.tgz", - "integrity": "sha1-0mMTX0MwfALGAq/I/pWXDAFRNp4=" + "integrity": "sha1-0mMTX0MwfALGAq/I/pWXDAFRNp4=", + "dev": true }, "har-validator": { "version": "4.2.1", "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-4.2.1.tgz", "integrity": "sha1-M0gdDxu/9gDdID11gSpqX7oALio=", + "dev": true, "requires": { "ajv": "4.11.8", "har-schema": "1.0.5" @@ -7808,21 +9685,6 @@ } } }, - "has-binary2": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has-binary2/-/has-binary2-1.0.3.tgz", - "integrity": "sha512-G1LWKhDSvhGeAQ8mPVQlqNcOB2sJdwATtZKl2pDKKHfpf/rYj24lkinxf69blJbnsvtqqNU+L3SL50vzZhXOnw==", - "requires": { - "isarray": "2.0.1" - }, - "dependencies": { - "isarray": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", - "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=" - } - } - }, "has-color": { "version": "0.1.7", "resolved": "https://registry.npmjs.org/has-color/-/has-color-0.1.7.tgz", @@ -7831,7 +9693,8 @@ "has-cors": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz", - "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk=" + "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk=", + "dev": true }, "has-flag": { "version": "1.0.0", @@ -7845,15 +9708,11 @@ "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", "dev": true }, - "has-unicode": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", - "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" - }, "has-value": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "dev": true, "requires": { "get-value": "2.0.6", "has-values": "1.0.0", @@ -7864,6 +9723,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "dev": true, "requires": { "is-number": "3.0.0", "kind-of": "4.0.0" @@ -7873,6 +9733,7 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true, "requires": { "is-buffer": "1.1.6" } @@ -7903,6 +9764,7 @@ "version": "3.1.3", "resolved": "https://registry.npmjs.org/hawk/-/hawk-3.1.3.tgz", "integrity": "sha1-B4REvXwWQLD+VA0sm3PVlnjo4cQ=", + "dev": true, "requires": { "boom": "2.10.1", "cryptiles": "2.0.5", @@ -7952,7 +9814,8 @@ "hoek": { "version": "2.16.3", "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", - "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=" + "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=", + "dev": true }, "hoist-non-react-statics": { "version": "1.2.0", @@ -8216,6 +10079,7 @@ "version": "1.6.3", "resolved": "http://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "dev": true, "requires": { "depd": "1.1.2", "inherits": "2.0.3", @@ -8226,7 +10090,8 @@ "statuses": { "version": "1.5.0", "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", - "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" + "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", + "dev": true } } }, @@ -8355,6 +10220,7 @@ "version": "1.1.1", "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.1.1.tgz", "integrity": "sha1-33LiZwZs0Kxn+3at+OE0qPvPkb8=", + "dev": true, "requires": { "assert-plus": "0.2.0", "jsprim": "1.4.1", @@ -8426,12 +10292,14 @@ "indexof": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz", - "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=" + "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=", + "dev": true }, "inflight": { "version": "1.0.6", "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, "requires": { "once": "1.4.0", "wrappy": "1.0.2" @@ -8601,6 +10469,7 @@ "version": "0.1.6", "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, "requires": { "kind-of": "3.2.2" } @@ -8656,6 +10525,7 @@ "version": "0.1.4", "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, "requires": { "kind-of": "3.2.2" } @@ -8670,6 +10540,7 @@ "version": "0.1.6", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "dev": true, "requires": { "is-accessor-descriptor": "0.1.6", "is-data-descriptor": "0.1.4", @@ -8679,7 +10550,8 @@ "kind-of": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", - "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==" + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", + "dev": true } } }, @@ -8726,7 +10598,8 @@ "is-extendable": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", - "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true }, "is-extglob": { "version": "2.1.1", @@ -8790,11 +10663,6 @@ "lower-case": "1.1.4" } }, - "is-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", - "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" - }, "is-my-ip-valid": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-my-ip-valid/-/is-my-ip-valid-1.0.0.tgz", @@ -8824,6 +10692,7 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, "requires": { "kind-of": "3.2.2" } @@ -8844,6 +10713,7 @@ "version": "2.0.4", "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, "requires": { "isobject": "3.0.1" } @@ -8919,7 +10789,8 @@ "is-typedarray": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", - "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", + "dev": true }, "is-upper-case": { "version": "1.1.2", @@ -8939,7 +10810,8 @@ "is-windows": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", - "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==" + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", + "dev": true }, "is-zip": { "version": "1.0.0", @@ -8975,7 +10847,8 @@ "isobject": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "dev": true }, "isomorphic-fetch": { "version": "2.2.1", @@ -8989,7 +10862,8 @@ "isstream": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", - "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", + "dev": true }, "istanbul": { "version": "0.4.5", @@ -9240,18 +11114,11 @@ } } }, - "js2xmlparser": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/js2xmlparser/-/js2xmlparser-3.0.0.tgz", - "integrity": "sha1-P7YOqgicVED5MZ9RdgzNB+JJlzM=", - "requires": { - "xmlcreate": "1.0.2" - } - }, "jsbn": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", - "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true }, "jsdoc": { "version": "https://github.com/geosolutions-it/jsdoc/tarball/fix_acorn_jsx", @@ -9409,7 +11276,8 @@ "json-schema": { "version": "0.2.3", "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", - "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", + "dev": true }, "json-schema-traverse": { "version": "0.4.1", @@ -9420,6 +11288,7 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", + "dev": true, "requires": { "jsonify": "0.0.0" } @@ -9427,7 +11296,8 @@ "json-stringify-safe": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", - "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", + "dev": true }, "json3": { "version": "3.3.2", @@ -9454,7 +11324,8 @@ "jsonify": { "version": "0.0.0", "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", - "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=" + "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", + "dev": true }, "jsonix": { "version": "2.4.1", @@ -9508,6 +11379,7 @@ "version": "1.4.1", "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", + "dev": true, "requires": { "assert-plus": "1.0.0", "extsprintf": "1.3.0", @@ -9518,7 +11390,8 @@ "assert-plus": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true } } }, @@ -9587,11 +11460,6 @@ } } }, - "junk": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/junk/-/junk-2.1.0.tgz", - "integrity": "sha1-9DG0t/By3FAKXxDOf07HGTDnATQ=" - }, "karma": { "version": "1.5.0", "resolved": "https://registry.npmjs.org/karma/-/karma-1.5.0.tgz", @@ -10114,22 +11982,16 @@ "version": "3.2.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, "requires": { "is-buffer": "1.1.6" } }, - "klaw": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/klaw/-/klaw-2.0.0.tgz", - "integrity": "sha1-WcEo4Nxc5BAgEVEZTuucv4WGUPY=", - "requires": { - "graceful-fs": "4.1.15" - } - }, "lazy-cache": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", - "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=" + "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=", + "dev": true }, "lcid": { "version": "1.0.0", @@ -10287,6 +12149,11 @@ "immediate": "3.0.6" } }, + "lineclip": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/lineclip/-/lineclip-1.1.5.tgz", + "integrity": "sha1-K/JgZ9lDVP6r+R5CdoI221YW/RM=" + }, "load-json-file": { "version": "1.1.0", "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", @@ -10581,10 +12448,16 @@ } } }, + "loglevel": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.6.1.tgz", + "integrity": "sha1-4PyVEztu8nbNyIh82vJKpvFW+Po=" + }, "longest": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", - "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=" + "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=", + "dev": true }, "loose-envify": { "version": "1.4.0", @@ -10641,18 +12514,11 @@ "resolved": "https://registry.npmjs.org/lrucache/-/lrucache-1.0.3.tgz", "integrity": "sha1-Ox3tDRuoLhiLm9q6nu5khvhkpDQ=" }, - "magic-string": { - "version": "0.22.5", - "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.22.5.tgz", - "integrity": "sha512-oreip9rJZkzvA8Qzk9HFs8fZGF/u7H/gtrE8EN6RjKJ9kh2HlC+yQ2QezifqTZfGyiuAV0dRv5a+y/8gBb1m9w==", - "requires": { - "vlq": "0.2.3" - } - }, "map-cache": { "version": "0.2.2", "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", - "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=" + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", + "dev": true }, "map-obj": { "version": "1.0.1", @@ -10664,6 +12530,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "dev": true, "requires": { "object-visit": "1.0.1" } @@ -10671,7 +12538,8 @@ "marked": { "version": "0.3.19", "resolved": "https://registry.npmjs.org/marked/-/marked-0.3.19.tgz", - "integrity": "sha512-ea2eGWOqNxPcXv8dyERdSr/6FmzvWwzjMxpfGB/sbMccXoct+xY+YukPD+QTUZwyvK7BZwcr4m21WBOW41pAkg==" + "integrity": "sha512-ea2eGWOqNxPcXv8dyERdSr/6FmzvWwzjMxpfGB/sbMccXoct+xY+YukPD+QTUZwyvK7BZwcr4m21WBOW41pAkg==", + "dev": true }, "matchmedia": { "version": "0.1.2", @@ -10768,6 +12636,7 @@ "version": "3.1.10", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "dev": true, "requires": { "arr-diff": "4.0.0", "array-unique": "0.3.2", @@ -10787,7 +12656,8 @@ "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true } } }, @@ -10804,17 +12674,20 @@ "mime": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", - "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" + "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==", + "dev": true }, "mime-db": { "version": "1.40.0", "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", - "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==" + "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", + "dev": true }, "mime-types": { "version": "2.1.24", "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", + "dev": true, "requires": { "mime-db": "1.40.0" } @@ -10843,6 +12716,7 @@ "version": "3.0.4", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, "requires": { "brace-expansion": "1.1.11" } @@ -10852,27 +12726,11 @@ "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" }, - "minipass": { - "version": "2.3.5", - "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.3.5.tgz", - "integrity": "sha512-Gi1W4k059gyRbyVUZQ4mEqLm0YIUiGYfvxhF6SIlk3ui1WVxMTGfGdQ2SInh3PDrRTVvPKgULkpJtT4RH10+VA==", - "requires": { - "safe-buffer": "5.1.2", - "yallist": "3.0.3" - } - }, - "minizlib": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.2.1.tgz", - "integrity": "sha512-7+4oTUOWKg7AuL3vloEWekXY2/D20cevzsrNT2kGWm+39J9hGTCBv8VI5Pm5lXZ/o3/mdR4f8rflAPhnQb8mPA==", - "requires": { - "minipass": "2.3.5" - } - }, "mixin-deep": { "version": "1.3.1", "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", + "dev": true, "requires": { "for-in": "1.0.2", "is-extendable": "1.0.1" @@ -10882,6 +12740,7 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, "requires": { "is-plain-object": "2.0.4" } @@ -10892,6 +12751,7 @@ "version": "0.5.1", "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "dev": true, "requires": { "minimist": "0.0.8" }, @@ -10899,15 +12759,11 @@ "minimist": { "version": "0.0.8", "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", - "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", + "dev": true } } }, - "mkpath": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/mkpath/-/mkpath-0.1.0.tgz", - "integrity": "sha1-dVSm+Nhxg0zJe1RisSLEwSTW3pE=" - }, "mocha": { "version": "2.4.5", "resolved": "http://registry.npmjs.org/mocha/-/mocha-2.4.5.tgz", @@ -10992,10 +12848,13 @@ "resolved": "http://registry.npmjs.org/moment/-/moment-2.21.0.tgz", "integrity": "sha512-TCZ36BjURTeFTM/CwRcViQlfkMvL1/vFISuNLO5GkcVm1+QHfbSiNqZuWeMFjj1/3+uAjXswgRk30j1kkLYJBQ==" }, - "mout": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/mout/-/mout-1.0.0.tgz", - "integrity": "sha1-m98dSvV9ZtR8s1OmM1oygQmOFQE=" + "monotone-convex-hull-2d": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/monotone-convex-hull-2d/-/monotone-convex-hull-2d-1.0.1.tgz", + "integrity": "sha1-R/Xa6t88Sv03dkuqGqh4ekDu4Iw=", + "requires": { + "robust-orientation": "1.1.3" + } }, "ms": { "version": "2.1.1", @@ -11019,6 +12878,7 @@ "version": "1.2.13", "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", + "dev": true, "requires": { "arr-diff": "4.0.0", "array-unique": "0.3.2", @@ -11036,7 +12896,8 @@ "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true } } }, @@ -11064,7 +12925,8 @@ "negotiator": { "version": "0.6.2", "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", - "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" + "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", + "dev": true }, "neo-async": { "version": "2.6.1", @@ -11220,6 +13082,7 @@ "version": "3.0.6", "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", + "dev": true, "requires": { "abbrev": "1.1.1" } @@ -11268,17 +13131,6 @@ "resolved": "https://registry.npmjs.org/nouislider/-/nouislider-9.2.0.tgz", "integrity": "sha1-6HxQfeKwtNB1A4taQlR8fbvrr2k=" }, - "npmlog": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", - "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", - "requires": { - "are-we-there-yet": "1.1.5", - "console-control-strings": "1.1.0", - "gauge": "2.7.4", - "set-blocking": "2.0.0" - } - }, "nth-check": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.2.tgz", @@ -11314,7 +13166,8 @@ "oauth-sign": { "version": "0.8.2", "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", - "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=" + "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=", + "dev": true }, "object-assign": { "version": "4.1.1", @@ -11324,12 +13177,14 @@ "object-component": { "version": "0.0.3", "resolved": "https://registry.npmjs.org/object-component/-/object-component-0.0.3.tgz", - "integrity": "sha1-8MaapQ78lbhmwYb0AKM3acsvEpE=" + "integrity": "sha1-8MaapQ78lbhmwYb0AKM3acsvEpE=", + "dev": true }, "object-copy": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "dev": true, "requires": { "copy-descriptor": "0.1.1", "define-property": "0.2.5", @@ -11340,6 +13195,7 @@ "version": "0.2.5", "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, "requires": { "is-descriptor": "0.1.6" } @@ -11362,6 +13218,7 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "dev": true, "requires": { "isobject": "3.0.1" } @@ -11392,6 +13249,7 @@ "version": "1.3.0", "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "dev": true, "requires": { "isobject": "3.0.1" } @@ -11421,10 +13279,21 @@ } } }, + "ol": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/ol/-/ol-5.3.0.tgz", + "integrity": "sha512-UrOJGNI5XdYfE9n43RJdsMq25SjI4nIi5Kf0kxi+q6vEknzeRxM/wgYf8FMs7Ss3URuIbsKmetW9dVMOYB/DkQ==", + "requires": { + "pbf": "3.1.0", + "pixelworks": "1.1.0", + "rbush": "2.0.2" + } + }, "on-finished": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", + "dev": true, "requires": { "ee-first": "1.1.1" } @@ -11439,6 +13308,7 @@ "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, "requires": { "wrappy": "1.0.2" } @@ -11449,74 +13319,6 @@ "integrity": "sha1-ofeDj4MUxRbwXs78vEzP4EtO14k=", "dev": true }, - "openlayers": { - "version": "4.6.4", - "resolved": "https://registry.npmjs.org/openlayers/-/openlayers-4.6.4.tgz", - "integrity": "sha512-Oru7/xniirjech7H5zkMQSUj/JUymNveiE4vAwmyjAmcoNyO4zTRD/Pp7BPfxBPuAz45vDl78H1wEQD7RGWkGg==", - "requires": { - "async": "2.6.0", - "closure-util": "1.26.0", - "fs-extra": "4.0.3", - "jsdoc": "3.5.5", - "nomnom": "1.8.1", - "pbf": "3.1.0", - "pixelworks": "1.1.0", - "rbush": "2.0.1", - "rollup": "0.52.3", - "rollup-plugin-cleanup": "2.0.1", - "rollup-plugin-commonjs": "8.4.1", - "rollup-plugin-node-resolve": "3.4.0", - "temp": "0.8.3", - "walk": "2.3.9" - }, - "dependencies": { - "fs-extra": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-4.0.3.tgz", - "integrity": "sha512-q6rbdDd1o2mAnQreO7YADIxf/Whx4AHBiRf6d+/cVT8h44ss+lHgxf1FemcqDnQt9X3ct4McHr+JMGlYSsK7Cg==", - "requires": { - "graceful-fs": "4.1.15", - "jsonfile": "4.0.0", - "universalify": "0.1.2" - } - }, - "jsdoc": { - "version": "3.5.5", - "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-3.5.5.tgz", - "integrity": "sha512-6PxB65TAU4WO0Wzyr/4/YhlGovXl0EVYfpKbpSroSj0qBxT4/xod/l40Opkm38dRHRdQgdeY836M0uVnJQG7kg==", - "requires": { - "babylon": "7.0.0-beta.19", - "bluebird": "3.5.1", - "catharsis": "0.8.10", - "escape-string-regexp": "1.0.5", - "js2xmlparser": "3.0.0", - "klaw": "2.0.0", - "marked": "0.3.19", - "mkdirp": "0.5.1", - "requizzle": "0.2.2", - "strip-json-comments": "2.0.1", - "taffydb": "2.6.2", - "underscore": "1.8.3" - } - }, - "jsonfile": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", - "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", - "requires": { - "graceful-fs": "4.1.15" - } - }, - "rbush": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/rbush/-/rbush-2.0.1.tgz", - "integrity": "sha1-TPrKKMMGS8DudUMaG3mZDode76k=", - "requires": { - "quickselect": "1.1.1" - } - } - } - }, "opn": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/opn/-/opn-4.0.2.tgz", @@ -11531,6 +13333,7 @@ "version": "0.6.1", "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz", "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=", + "dev": true, "requires": { "minimist": "0.0.10", "wordwrap": "0.0.3" @@ -11539,7 +13342,8 @@ "minimist": { "version": "0.0.10", "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.10.tgz", - "integrity": "sha1-3j+YVD2/lggr5IrRoMfNqDYwHc8=" + "integrity": "sha1-3j+YVD2/lggr5IrRoMfNqDYwHc8=", + "dev": true } } }, @@ -11602,7 +13406,8 @@ "os-tmpdir": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true }, "output-file-sync": { "version": "1.1.2", @@ -11726,6 +13531,7 @@ "version": "0.0.5", "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.5.tgz", "integrity": "sha1-1SCKNzjkZ2bikbouoXNoSSGouJ0=", + "dev": true, "requires": { "better-assert": "1.0.2" } @@ -11734,6 +13540,7 @@ "version": "0.0.5", "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.5.tgz", "integrity": "sha1-gCBKUNTbt3m/3G6+J3jZDkvOMgo=", + "dev": true, "requires": { "better-assert": "1.0.2" } @@ -11757,7 +13564,8 @@ "pascalcase": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", - "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=" + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", + "dev": true }, "path-browserify": { "version": "0.0.0", @@ -11789,12 +13597,14 @@ "path-is-absolute": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true }, "path-parse": { "version": "1.0.6", "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", - "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", + "dev": true }, "path-to-regexp": { "version": "1.7.0", @@ -11867,7 +13677,8 @@ "performance-now": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-0.2.0.tgz", - "integrity": "sha1-M+8wxcd9TqIcWlOGnZG1bY8lVeU=" + "integrity": "sha1-M+8wxcd9TqIcWlOGnZG1bY8lVeU=", + "dev": true }, "pify": { "version": "2.3.0", @@ -11908,6 +13719,11 @@ "irregular-plurals": "1.4.0" } }, + "point-in-polygon": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/point-in-polygon/-/point-in-polygon-1.0.1.tgz", + "integrity": "sha1-1Ztk6P7kHElFiqyCtWcYxZV7Kvc=" + }, "portfinder": { "version": "1.0.20", "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.20.tgz", @@ -11945,7 +13761,8 @@ "posix-character-classes": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", - "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=" + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", + "dev": true }, "postcss": { "version": "5.2.16", @@ -12515,7 +14332,8 @@ "punycode": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", - "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true }, "pure-color": { "version": "1.3.0", @@ -12526,7 +14344,8 @@ "q": { "version": "1.5.0", "resolved": "https://registry.npmjs.org/q/-/q-1.5.0.tgz", - "integrity": "sha1-3QG6ydBtMObyGa7LglPunr3DCPE=" + "integrity": "sha1-3QG6ydBtMObyGa7LglPunr3DCPE=", + "dev": true }, "qjobs": { "version": "1.2.0", @@ -12550,7 +14369,8 @@ "qs": { "version": "6.4.0", "resolved": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", - "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=" + "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=", + "dev": true }, "query-string": { "version": "4.3.4", @@ -12576,8 +14396,7 @@ "querystringify": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.1.1.tgz", - "integrity": "sha512-w7fLxIRCRT7U8Qu53jQnJyPkYZIaR4n5151KMfcJlO/A9397Wxb1amJvROTK6TOnp7PfoAmg/qXiNHI+08jRfA==", - "dev": true + "integrity": "sha512-w7fLxIRCRT7U8Qu53jQnJyPkYZIaR4n5151KMfcJlO/A9397Wxb1amJvROTK6TOnp7PfoAmg/qXiNHI+08jRfA==" }, "quickselect": { "version": "1.1.1", @@ -12677,7 +14496,8 @@ "range-parser": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", - "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "dev": true }, "raw-body": { "version": "2.4.0", @@ -14000,6 +15820,7 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "dev": true, "requires": { "extend-shallow": "3.0.2", "safe-regex": "1.1.0" @@ -14099,7 +15920,8 @@ "repeat-element": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", - "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==" + "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", + "dev": true }, "repeat-string": { "version": "1.6.1", @@ -14124,6 +15946,7 @@ "version": "2.81.0", "resolved": "https://registry.npmjs.org/request/-/request-2.81.0.tgz", "integrity": "sha1-xpKJRqDgbF+Nb4qTM0af/aRimKA=", + "dev": true, "requires": { "aws-sign2": "0.6.0", "aws4": "1.8.0", @@ -14149,14 +15972,6 @@ "uuid": "3.0.1" } }, - "request-progress": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/request-progress/-/request-progress-3.0.0.tgz", - "integrity": "sha1-TKdUCBx/7GP1BeT6qCWqBs1mnb4=", - "requires": { - "throttleit": "1.0.0" - } - }, "require-directory": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", @@ -14184,13 +15999,13 @@ "requires-port": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", - "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", - "dev": true + "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=" }, "requizzle": { "version": "0.2.2", "resolved": "https://registry.npmjs.org/requizzle/-/requizzle-0.2.2.tgz", "integrity": "sha512-oJ6y7JcUJkblRGhMByGNcszeLgU0qDxNKFCiUZR1XyzHyVsev+Mxb1tyygxLd1ORsKee1SA5BInFdUwY64GE/A==", + "dev": true, "requires": { "lodash": "4.17.11" }, @@ -14198,7 +16013,8 @@ "lodash": { "version": "4.17.11", "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", - "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" + "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", + "dev": true } } }, @@ -14216,6 +16032,7 @@ "version": "1.10.1", "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.1.tgz", "integrity": "sha512-KuIe4mf++td/eFb6wkaPbMDnP6kObCaEtIDuHOUED6MNUo4K670KZUHuuvYPZDxNF0WVLw49n06M2m2dXphEzA==", + "dev": true, "requires": { "path-parse": "1.0.6" } @@ -14236,17 +16053,14 @@ "resolve-url": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", - "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=" + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", + "dev": true }, "ret": { "version": "0.1.15", "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", - "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==" - }, - "retry": { - "version": "0.10.1", - "resolved": "https://registry.npmjs.org/retry/-/retry-0.10.1.tgz", - "integrity": "sha1-52OI0heZLCUnUCQdPTlW/tmNj/Q=" + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", + "dev": true }, "rgbcolor": { "version": "0.0.4", @@ -14257,6 +16071,7 @@ "version": "0.1.3", "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", + "dev": true, "requires": { "align-text": "0.1.4" } @@ -14280,65 +16095,35 @@ "inherits": "2.0.3" } }, - "rollup": { - "version": "0.52.3", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-0.52.3.tgz", - "integrity": "sha512-cw+vb9NqaTXlwJyb8G+Ve+uhhlVTcl1NKBkfANdeQqVcpZFilQgeNnAnNiu7MwfeXrqiKEGz+3R03a3zeFkmEQ==" - }, - "rollup-plugin-cleanup": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/rollup-plugin-cleanup/-/rollup-plugin-cleanup-2.0.1.tgz", - "integrity": "sha512-Z2UpMe3l2Oo8jzoB2gAWcb3UqIyiGxlh8kKlcs/W53yTPtwdF8RGfhuTx+/kjRlkSc5TC03t3sX3Lj3B40k9Eg==", + "robust-orientation": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/robust-orientation/-/robust-orientation-1.1.3.tgz", + "integrity": "sha1-2v9bANO+TmByLw6cAVbvln8cIEk=", "requires": { - "acorn": "4.0.13", - "magic-string": "0.22.5", - "rollup-pluginutils": "2.6.0" - }, - "dependencies": { - "acorn": { - "version": "4.0.13", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", - "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" - } + "robust-scale": "1.0.2", + "robust-subtract": "1.0.0", + "robust-sum": "1.0.0", + "two-product": "1.0.2" } }, - "rollup-plugin-commonjs": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/rollup-plugin-commonjs/-/rollup-plugin-commonjs-8.4.1.tgz", - "integrity": "sha512-mg+WuD+jlwoo8bJtW3Mvx7Tz6TsIdMsdhuvCnDMoyjh0oxsVgsjB/N0X984RJCWwc5IIiqNVJhXeeITcc73++A==", + "robust-scale": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/robust-scale/-/robust-scale-1.0.2.tgz", + "integrity": "sha1-d1Ey7QlULQKOWLLMecBikLz3jDI=", "requires": { - "acorn": "5.2.1", - "estree-walker": "0.5.2", - "magic-string": "0.22.5", - "resolve": "1.10.1", - "rollup-pluginutils": "2.6.0" - }, - "dependencies": { - "estree-walker": { - "version": "0.5.2", - "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.5.2.tgz", - "integrity": "sha512-XpCnW/AE10ws/kDAs37cngSkvgIR8aN3G0MS85m7dUpuK2EREo9VJ00uvw6Dg/hXEpfsE1I1TvJOJr+Z+TL+ig==" - } + "two-product": "1.0.2", + "two-sum": "1.0.0" } }, - "rollup-plugin-node-resolve": { - "version": "3.4.0", - "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-3.4.0.tgz", - "integrity": "sha512-PJcd85dxfSBWih84ozRtBkB731OjXk0KnzN0oGp7WOWcarAFkVa71cV5hTJg2qpVsV2U8EUwrzHP3tvy9vS3qg==", - "requires": { - "builtin-modules": "2.0.0", - "is-module": "1.0.0", - "resolve": "1.10.1" - } + "robust-subtract": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/robust-subtract/-/robust-subtract-1.0.0.tgz", + "integrity": "sha1-4LFk4e2LpOOl3aRaEgODSNvtPpo=" }, - "rollup-pluginutils": { - "version": "2.6.0", - "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.6.0.tgz", - "integrity": "sha512-aGQwspEF8oPKvg37u3p7h0cYNwmJR1sCBMZGZ5b9qy8HGtETknqjzcxrDRrcAnJNXN18lBH4Q9vZYth/p4n8jQ==", - "requires": { - "estree-walker": "0.6.0", - "micromatch": "3.1.10" - } + "robust-sum": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/robust-sum/-/robust-sum-1.0.0.tgz", + "integrity": "sha1-FmRuUlKStNJdgnV6KGlV4Lv6U9k=" }, "rx": { "version": "2.5.3", @@ -14357,12 +16142,14 @@ "safe-buffer": { "version": "5.1.2", "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true }, "safe-regex": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "dev": true, "requires": { "ret": "0.1.15" } @@ -14449,41 +16236,6 @@ "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", "dev": true }, - "send": { - "version": "0.16.1", - "resolved": "https://registry.npmjs.org/send/-/send-0.16.1.tgz", - "integrity": "sha512-ElCLJdJIKPk6ux/Hocwhk7NFHpI3pVm/IZOYWqUmoxcgeyM+MpxHHKhb8QmlJDX1pU6WrgaHBkVNm73Sv7uc2A==", - "requires": { - "debug": "2.6.9", - "depd": "1.1.2", - "destroy": "1.0.4", - "encodeurl": "1.0.2", - "escape-html": "1.0.3", - "etag": "1.8.1", - "fresh": "0.5.2", - "http-errors": "1.6.3", - "mime": "1.4.1", - "ms": "2.0.0", - "on-finished": "2.3.0", - "range-parser": "1.2.1", - "statuses": "1.3.1" - }, - "dependencies": { - "debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "requires": { - "ms": "2.0.0" - } - }, - "ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" - } - } - }, "sentence-case": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-2.1.1.tgz", @@ -14585,7 +16337,8 @@ "set-blocking": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", - "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true }, "set-immediate-shim": { "version": "1.0.1", @@ -14597,6 +16350,7 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", + "dev": true, "requires": { "extend-shallow": "2.0.1", "is-extendable": "0.1.1", @@ -14608,6 +16362,7 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, "requires": { "is-extendable": "0.1.1" } @@ -14622,7 +16377,8 @@ "setprototypeof": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", - "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", + "dev": true }, "sha.js": { "version": "2.4.11", @@ -14688,7 +16444,8 @@ "signal-exit": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", - "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true }, "simple-fmt": { "version": "0.1.0", @@ -14708,6 +16465,11 @@ "integrity": "sha1-Krt1qt453rXMgVzhDmGRFkhQuvA=", "dev": true }, + "skmeans": { + "version": "0.9.7", + "resolved": "https://registry.npmjs.org/skmeans/-/skmeans-0.9.7.tgz", + "integrity": "sha512-hNj1/oZ7ygsfmPZ7ZfN5MUBRoGg1gtpnImuJBgLO0ljQ67DtJuiQaiYdS4lUA6s0KCwnPhGivtC/WRwIZLkHyg==" + }, "slash": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", @@ -14727,6 +16489,7 @@ "version": "0.8.2", "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "dev": true, "requires": { "base": "0.11.2", "debug": "2.6.9", @@ -14742,6 +16505,7 @@ "version": "2.6.9", "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, "requires": { "ms": "2.0.0" } @@ -14750,6 +16514,7 @@ "version": "0.2.5", "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, "requires": { "is-descriptor": "0.1.6" } @@ -14758,6 +16523,7 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, "requires": { "is-extendable": "0.1.1" } @@ -14765,7 +16531,8 @@ "ms": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true } } }, @@ -14773,6 +16540,7 @@ "version": "2.1.1", "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "dev": true, "requires": { "define-property": "1.0.0", "isobject": "3.0.1", @@ -14783,6 +16551,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, "requires": { "is-descriptor": "1.0.2" } @@ -14791,6 +16560,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -14799,6 +16569,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, "requires": { "kind-of": "6.0.2" } @@ -14807,6 +16578,7 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, "requires": { "is-accessor-descriptor": "1.0.0", "is-data-descriptor": "1.0.0", @@ -14816,7 +16588,8 @@ "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true } } }, @@ -14824,6 +16597,7 @@ "version": "3.0.1", "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "dev": true, "requires": { "kind-of": "3.2.2" } @@ -14832,108 +16606,11 @@ "version": "1.0.9", "resolved": "https://registry.npmjs.org/sntp/-/sntp-1.0.9.tgz", "integrity": "sha1-ZUEYTMkK7qbG57NeJlkIJEPGYZg=", + "dev": true, "requires": { "hoek": "2.16.3" } }, - "socket.io": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-2.0.4.tgz", - "integrity": "sha1-waRZDO/4fs8TxyZS8Eb3FrKeYBQ=", - "requires": { - "debug": "2.6.9", - "engine.io": "3.1.5", - "socket.io-adapter": "1.1.1", - "socket.io-client": "2.0.4", - "socket.io-parser": "3.1.3" - }, - "dependencies": { - "debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "requires": { - "ms": "2.0.0" - } - }, - "ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" - } - } - }, - "socket.io-adapter": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-1.1.1.tgz", - "integrity": "sha1-KoBeihTWNyEk3ZFZrUUC+MsH8Gs=" - }, - "socket.io-client": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-2.0.4.tgz", - "integrity": "sha1-CRilUkBtxeVAs4Dc2Xr8SmQzL44=", - "requires": { - "backo2": "1.0.2", - "base64-arraybuffer": "0.1.5", - "component-bind": "1.0.0", - "component-emitter": "1.2.1", - "debug": "2.6.9", - "engine.io-client": "3.1.6", - "has-cors": "1.1.0", - "indexof": "0.0.1", - "object-component": "0.0.3", - "parseqs": "0.0.5", - "parseuri": "0.0.5", - "socket.io-parser": "3.1.3", - "to-array": "0.1.4" - }, - "dependencies": { - "debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "requires": { - "ms": "2.0.0" - } - }, - "ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" - } - } - }, - "socket.io-parser": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-3.1.3.tgz", - "integrity": "sha512-g0a2HPqLguqAczs3dMECuA1RgoGFPyvDqcbaDEdCWY9g59kdUAz3YRmaJBNKXflrHNwB7Q12Gkf/0CZXfdHR7g==", - "requires": { - "component-emitter": "1.2.1", - "debug": "3.1.0", - "has-binary2": "1.0.3", - "isarray": "2.0.1" - }, - "dependencies": { - "debug": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", - "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", - "requires": { - "ms": "2.0.0" - } - }, - "isarray": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", - "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=" - }, - "ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" - } - } - }, "sockjs": { "version": "0.3.18", "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.18.tgz", @@ -15016,6 +16693,7 @@ "version": "0.5.2", "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", + "dev": true, "requires": { "atob": "2.1.2", "decode-uri-component": "0.2.0", @@ -15036,7 +16714,8 @@ "source-map-url": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", - "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=" + "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", + "dev": true }, "spdx-correct": { "version": "3.1.0", @@ -15167,6 +16846,7 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "dev": true, "requires": { "extend-shallow": "3.0.2" } @@ -15181,6 +16861,7 @@ "version": "1.16.1", "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", + "dev": true, "requires": { "asn1": "0.2.4", "assert-plus": "1.0.0", @@ -15196,7 +16877,8 @@ "assert-plus": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true } } }, @@ -15221,6 +16903,7 @@ "version": "0.1.2", "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "dev": true, "requires": { "define-property": "0.2.5", "object-copy": "0.1.0" @@ -15230,6 +16913,7 @@ "version": "0.2.5", "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, "requires": { "is-descriptor": "0.1.6" } @@ -15239,7 +16923,8 @@ "statuses": { "version": "1.3.1", "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", - "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" + "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=", + "dev": true }, "stream-browserify": { "version": "2.0.2", @@ -15309,8 +16994,7 @@ "strict-uri-encode": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", - "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=", - "dev": true + "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=" }, "string-width": { "version": "1.0.2", @@ -15352,7 +17036,8 @@ "stringstream": { "version": "0.0.6", "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.6.tgz", - "integrity": "sha512-87GEBAkegbBcweToUrdzf3eLhWNg06FJTebl4BVJz/JgWy8CvEr9dRtX5qWphiynMSQlxxi+QqN0z5T32SLlhA==" + "integrity": "sha512-87GEBAkegbBcweToUrdzf3eLhWNg06FJTebl4BVJz/JgWy8CvEr9dRtX5qWphiynMSQlxxi+QqN0z5T32SLlhA==", + "dev": true }, "strip-ansi": { "version": "0.1.1", @@ -15450,7 +17135,8 @@ "strip-json-comments": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", - "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true }, "style-loader": { "version": "0.12.4", @@ -15588,7 +17274,8 @@ "taffydb": { "version": "2.6.2", "resolved": "https://registry.npmjs.org/taffydb/-/taffydb-2.6.2.tgz", - "integrity": "sha1-fLy2S1oUG2ou/CxdLGe04VCyomg=" + "integrity": "sha1-fLy2S1oUG2ou/CxdLGe04VCyomg=", + "dev": true }, "tapable": { "version": "0.2.9", @@ -15596,17 +17283,6 @@ "integrity": "sha512-2wsvQ+4GwBvLPLWsNfLCDYGsW6xb7aeC6utq2Qh0PFwgEy7K7dsma9Jsmb2zSQj7GvYAyUGSntLtsv++GmgL1A==", "dev": true }, - "tar": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/tar/-/tar-3.1.5.tgz", - "integrity": "sha512-TKJKz1fqBOZBaIQ/MGRKU0EnTGmKMLy4ReTRgP10AgtfOWBbj9PBg4MgY80GFpqGbs2EzcIctW5gbwbP4woDYg==", - "requires": { - "minipass": "2.3.5", - "minizlib": "1.2.1", - "mkdirp": "0.5.1", - "yallist": "3.0.3" - } - }, "tar-stream": { "version": "0.4.7", "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-0.4.7.tgz", @@ -15639,22 +17315,6 @@ } } }, - "temp": { - "version": "0.8.3", - "resolved": "https://registry.npmjs.org/temp/-/temp-0.8.3.tgz", - "integrity": "sha1-4Ma8TSa5AxJEEOT+2BEDAU38H1k=", - "requires": { - "os-tmpdir": "1.0.2", - "rimraf": "2.2.8" - }, - "dependencies": { - "rimraf": { - "version": "2.2.8", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.2.8.tgz", - "integrity": "sha1-5Dm+Kq7jJzIZUnMPmaiSnk/FBYI=" - } - } - }, "tether": { "version": "1.4.6", "resolved": "https://registry.npmjs.org/tether/-/tether-1.4.6.tgz", @@ -15671,11 +17331,6 @@ "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", "dev": true }, - "throttleit": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/throttleit/-/throttleit-1.0.0.tgz", - "integrity": "sha1-nnhYNtr0Z0MUWlmEtiaNgoUorGw=" - }, "through": { "version": "2.3.8", "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", @@ -15742,6 +17397,11 @@ "resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.4.1.tgz", "integrity": "sha1-9PrTM0R7wLB9TcjpIJ2POaisd+g=" }, + "tinyqueue": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/tinyqueue/-/tinyqueue-1.2.3.tgz", + "integrity": "sha512-Qz9RgWuO9l8lT+Y9xvbzhPT2efIUIFd69N7eF7tJ9lnQl0iLj1M7peK7IoUGZL9DJHw9XftqLreccfxcQgYLxA==" + }, "title-case": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/title-case/-/title-case-2.1.1.tgz", @@ -15762,6 +17422,7 @@ "version": "0.0.31", "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.31.tgz", "integrity": "sha1-jzirlDjhcxXl29izZX6L+yd65Kc=", + "dev": true, "requires": { "os-tmpdir": "1.0.2" } @@ -15769,7 +17430,8 @@ "to-array": { "version": "0.1.4", "resolved": "https://registry.npmjs.org/to-array/-/to-array-0.1.4.tgz", - "integrity": "sha1-F+bBH3PdTz10zaek/zI46a2b+JA=" + "integrity": "sha1-F+bBH3PdTz10zaek/zI46a2b+JA=", + "dev": true }, "to-arraybuffer": { "version": "1.0.1", @@ -15793,6 +17455,7 @@ "version": "0.3.0", "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "dev": true, "requires": { "kind-of": "3.2.2" } @@ -15801,6 +17464,7 @@ "version": "3.0.2", "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "dev": true, "requires": { "define-property": "2.0.2", "extend-shallow": "3.0.2", @@ -15812,6 +17476,7 @@ "version": "2.1.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "dev": true, "requires": { "is-number": "3.0.0", "repeat-string": "1.6.1" @@ -15828,34 +17493,33 @@ "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", "dev": true }, + "topojson-client": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/topojson-client/-/topojson-client-3.0.0.tgz", + "integrity": "sha1-H5kpOnfvQqRI0DKoGqmCtz82DS8=", + "requires": { + "commander": "2.20.0" + } + }, + "topojson-server": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/topojson-server/-/topojson-server-3.0.0.tgz", + "integrity": "sha1-N4546Hw5cqe1vixdYENptrrmnF4=", + "requires": { + "commander": "2.20.0" + } + }, "toposort": { "version": "0.2.12", "resolved": "https://registry.npmjs.org/toposort/-/toposort-0.2.12.tgz", "integrity": "sha1-x9KYTz1IwhcxXMMtdwiIt3lJHoE=", "dev": true }, - "touch": { - "version": "0.0.3", - "resolved": "https://registry.npmjs.org/touch/-/touch-0.0.3.tgz", - "integrity": "sha1-Ua7z1ElXHU8oel2Hyci0kYGg2x0=", - "requires": { - "nopt": "1.0.10" - }, - "dependencies": { - "nopt": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", - "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", - "requires": { - "abbrev": "1.1.1" - } - } - } - }, "tough-cookie": { "version": "2.3.4", "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.4.tgz", "integrity": "sha512-TZ6TTfI5NtZnuyy/Kecv+CnoROnyXn2DN97LontgQpCwsX2XyLYCC0ENhYkehSOwAp8rTQKc/NUIF7BkQ5rKLA==", + "dev": true, "requires": { "punycode": "1.4.1" } @@ -15866,11 +17530,6 @@ "integrity": "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=", "dev": true }, - "traverse": { - "version": "0.3.9", - "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.3.9.tgz", - "integrity": "sha1-cXuPIgzAu3tE5AUUwisui7xw2Lk=" - }, "trim": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/trim/-/trim-0.0.1.tgz", @@ -15910,6 +17569,7 @@ "version": "0.6.0", "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "dev": true, "requires": { "safe-buffer": "5.1.2" } @@ -16004,6 +17664,11 @@ "resolved": "https://registry.npmjs.org/turf-invariant/-/turf-invariant-3.0.12.tgz", "integrity": "sha1-O5UlOVOZHr2WLdNdT2cEwofejr4=" }, + "turf-jsts": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/turf-jsts/-/turf-jsts-1.2.3.tgz", + "integrity": "sha512-Ja03QIJlPuHt4IQ2FfGex4F4JAr8m3jpaHbFbQrgwr7s7L6U8ocrHiF3J1+wf9jzhGKxvDeaCAnGDot8OjGFyA==" + }, "turf-meta": { "version": "3.0.12", "resolved": "https://registry.npmjs.org/turf-meta/-/turf-meta-3.0.12.tgz", @@ -16045,7 +17710,18 @@ "tweetnacl": { "version": "0.14.5", "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", - "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true + }, + "two-product": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/two-product/-/two-product-1.0.2.tgz", + "integrity": "sha1-Z9ldSyV6kh4stL16+VEfkIhSLqo=" + }, + "two-sum": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/two-sum/-/two-sum-1.0.0.tgz", + "integrity": "sha1-MdPzIjnk9zHsqd+RVeKyl/AIq2Q=" }, "type-check": { "version": "0.3.2", @@ -16080,6 +17756,7 @@ "version": "2.8.29", "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", + "dev": true, "requires": { "source-map": "0.5.7", "uglify-to-browserify": "1.0.2", @@ -16089,12 +17766,8 @@ "uglify-to-browserify": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", - "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=" - }, - "ultron": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.1.1.tgz", - "integrity": "sha512-UIEXBNeYmKptWH6z8ZnqTeS8fV74zG0/eRU9VGkpzz+LIJNs8W/zM/L+7ctCkRrgbNnnR0xxw4bKOr0cW0N0Og==" + "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", + "dev": true }, "uncontrollable": { "version": "4.1.0", @@ -16113,6 +17786,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", + "dev": true, "requires": { "arr-union": "3.1.0", "get-value": "2.0.6", @@ -16124,6 +17798,7 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, "requires": { "is-extendable": "0.1.1" } @@ -16132,6 +17807,7 @@ "version": "0.4.3", "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", + "dev": true, "requires": { "extend-shallow": "2.0.1", "is-extendable": "0.1.1", @@ -16179,6 +17855,7 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "dev": true, "requires": { "has-value": "0.3.1", "isobject": "3.0.1" @@ -16188,6 +17865,7 @@ "version": "0.3.1", "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "dev": true, "requires": { "get-value": "2.0.6", "has-values": "0.1.4", @@ -16198,6 +17876,7 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "dev": true, "requires": { "isarray": "1.0.0" } @@ -16207,7 +17886,8 @@ "has-values": { "version": "0.1.4", "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", - "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=" + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", + "dev": true } } }, @@ -16250,7 +17930,8 @@ "urix": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", - "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=" + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", + "dev": true }, "url": { "version": "0.11.0", @@ -16332,7 +18013,8 @@ "use": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", - "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==" + "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", + "dev": true }, "user-home": { "version": "1.1.1", @@ -16399,12 +18081,6 @@ "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.0.1.tgz", "integrity": "sha1-ZUS7ot/ajBzxfmKaOjBeK7H+5sE=" }, - "uws": { - "version": "9.14.0", - "resolved": "https://registry.npmjs.org/uws/-/uws-9.14.0.tgz", - "integrity": "sha512-HNMztPP5A1sKuVFmdZ6BPVpBQd5bUjNC8EFMFiICK+oho/OQsAJy5hnIx4btMHiOk8j04f/DbIlqnEZ9d72dqg==", - "optional": true - }, "validate-npm-package-license": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", @@ -16415,6 +18091,11 @@ "spdx-expression-parse": "3.0.0" } }, + "validator": { + "version": "10.11.0", + "resolved": "https://registry.npmjs.org/validator/-/validator-10.11.0.tgz", + "integrity": "sha512-X/p3UZerAIsbBfN/IwahhYaBbY68EN/UQBWHtsbXGT5bfrH/p4NQzUCG1kF/rtKaNpnJ7jAu6NGTdSNtyNIXMw==" + }, "value-equal": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/value-equal/-/value-equal-0.2.1.tgz", @@ -16436,6 +18117,7 @@ "version": "1.10.0", "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", + "dev": true, "requires": { "assert-plus": "1.0.0", "core-util-is": "1.0.2", @@ -16445,7 +18127,8 @@ "assert-plus": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true } } }, @@ -16570,11 +18253,6 @@ "propagating-hammerjs": "1.4.6" } }, - "vlq": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/vlq/-/vlq-0.2.3.tgz", - "integrity": "sha512-DRibZL6DsNhIgYQ+wNdWDL2SL3bKPlVrRiBqV5yuMm++op8W4kGFtaQfCs4KEJn0wBZcHVHJ3eoywX8983k1ow==" - }, "vm-browserify": { "version": "0.0.4", "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-0.0.4.tgz", @@ -16598,14 +18276,6 @@ "jsonix": "2.4.1" } }, - "walk": { - "version": "2.3.9", - "resolved": "https://registry.npmjs.org/walk/-/walk-2.3.9.tgz", - "integrity": "sha1-MbTbZnjyrgHDnqn7hyWpAx5Vins=", - "requires": { - "foreachasync": "3.0.0" - } - }, "ware": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/ware/-/ware-1.3.0.tgz", @@ -17137,18 +18807,11 @@ "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8=", "dev": true }, - "wide-align": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", - "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", - "requires": { - "string-width": "1.0.2" - } - }, "window-size": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz", - "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=" + "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=", + "dev": true }, "wkt-parser": { "version": "https://github.com/geosolutions-it/wkt-parser/tarball/mapstore2_fixes", @@ -17157,7 +18820,8 @@ "wordwrap": { "version": "0.0.3", "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", - "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=" + "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", + "dev": true }, "worker-loader": { "version": "1.1.1", @@ -17209,17 +18873,8 @@ "wrappy": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" - }, - "ws": { - "version": "3.3.3", - "resolved": "https://registry.npmjs.org/ws/-/ws-3.3.3.tgz", - "integrity": "sha512-nnWLa/NwZSt4KQJu51MYlCcSQ5g7INpOrOMt4XV8j4dqTXdmlUmSHQ8/oLC069ckre0fRsgfvsKwbTdtKLCDkA==", - "requires": { - "async-limiter": "1.0.0", - "safe-buffer": "5.1.2", - "ultron": "1.1.1" - } + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true }, "wtf-8": { "version": "1.0.0", @@ -17267,11 +18922,6 @@ "lodash": "4.17.5" } }, - "xmlcreate": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/xmlcreate/-/xmlcreate-1.0.2.tgz", - "integrity": "sha1-+mv3YqYKQT+z3Y9LA8WyaSONMI8=" - }, "xmldom": { "version": "0.1.27", "resolved": "https://registry.npmjs.org/xmldom/-/xmldom-0.1.27.tgz", @@ -17282,11 +18932,6 @@ "resolved": "https://registry.npmjs.org/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz", "integrity": "sha1-Z/4HXFwk/vOfnWX197f+dRcZaPw=" }, - "xmlhttprequest-ssl": { - "version": "1.5.5", - "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.5.tgz", - "integrity": "sha1-wodrBhaKrcQOV9l+gRkayPQ5iz4=" - }, "xtend": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", @@ -17299,15 +18944,11 @@ "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=", "dev": true }, - "yallist": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.0.3.tgz", - "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A==" - }, "yargs": { "version": "3.10.0", "resolved": "http://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz", "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", + "dev": true, "requires": { "camelcase": "1.2.1", "cliui": "2.1.0", @@ -17345,7 +18986,8 @@ "yeast": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz", - "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk=" + "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk=", + "dev": true } } } diff --git a/package.json b/package.json index a67946a5ea..d528d3ca9c 100644 --- a/package.json +++ b/package.json @@ -85,6 +85,7 @@ "@mapbox/togeojson": "0.16.0", "@turf/bbox": "4.1.0", "@turf/center": "5.1.5", + "@turf/circle": "6.0.1", "@turf/great-circle": "5.1.5", "@turf/inside": "4.1.0", "@turf/bbox-polygon": "5.1.5", @@ -113,6 +114,8 @@ "eventlistener": "0.0.1", "file-saver": "1.3.3", "fs-extra": "3.0.1", + "geostyler-sld-parser": "https://github.com/geosolutions-it/geostyler-sld-parser/tarball/ms2", + "geostyler-openlayers-parser": "https://github.com/geosolutions-it/geostyler-openlayers-parser/tarball/ms2", "history": "4.6.1", "html2canvas": "0.5.0-beta4", "immutable": "4.0.0-rc.12", @@ -138,7 +141,7 @@ "node-geo-distance": "1.2.0", "object-assign": "4.1.1", "ogc-schemas": "2.6.1", - "openlayers": "4.6.4", + "ol": "5.3.0", "pdfviewer": "0.3.2", "proj4": "https://github.com/geosolutions-it/proj4js/tarball/mapstore2_fixes", "prop-types": "15.6.0", diff --git a/project/custom/templates/index.html b/project/custom/templates/index.html index 847db456db..e2101f9641 100644 --- a/project/custom/templates/index.html +++ b/project/custom/templates/index.html @@ -7,14 +7,12 @@ __PROJECTDESCRIPTION__ - - diff --git a/project/custom/templates/webpack.config.js b/project/custom/templates/webpack.config.js index 3f17a183ec..abe7f9595d 100644 --- a/project/custom/templates/webpack.config.js +++ b/project/custom/templates/webpack.config.js @@ -41,7 +41,6 @@ module.exports = (env) => { "__DEVTOOLS__": !isProduction }), new NormalModuleReplacementPlugin(/leaflet$/, path.join(__dirname, "MapStore2", "web", "client", "libs", "leaflet")), - new NormalModuleReplacementPlugin(/openlayers$/, path.join(__dirname, "MapStore2", "web", "client", "libs", "openlayers")), new NormalModuleReplacementPlugin(/cesium$/, path.join(__dirname, "MapStore2", "web", "client", "libs", "cesium")), new NormalModuleReplacementPlugin(/proj4$/, path.join(__dirname, "MapStore2", "web", "client", "libs", "proj4")), new NoEmitOnErrorsPlugin(), diff --git a/project/standard/templates/index.html b/project/standard/templates/index.html index bb8ee79d50..30249737b6 100644 --- a/project/standard/templates/index.html +++ b/project/standard/templates/index.html @@ -86,13 +86,11 @@ - - diff --git a/project/standard/templates/indexTemplate.html b/project/standard/templates/indexTemplate.html index 7d2a1c4d19..25531bb99f 100644 --- a/project/standard/templates/indexTemplate.html +++ b/project/standard/templates/indexTemplate.html @@ -86,13 +86,11 @@ - - diff --git a/web/client/api/WFS3.js b/web/client/api/WFS3.js new file mode 100644 index 0000000000..69aac58166 --- /dev/null +++ b/web/client/api/WFS3.js @@ -0,0 +1,144 @@ +/* + * Copyright 2019, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +import axios from 'axios'; +import head from 'lodash/head'; +import isString from 'lodash/isString'; +import ConfigUtils from '../utils/ConfigUtils'; + +const capabilitiesCache = {}; + +const collectionToLayer = (collection) => { + const { name, title, extent, links } = collection; + const spatial = extent && extent.spatial || [-180, -90, 180, 90]; + const { href: layerUrl, type: format } = head((links || []).filter(({ rel }) => rel === 'tiles')) || {}; + const { href: tilingSchemes } = head((links || []).filter(({ rel }) => rel === 'tilingSchemes')) || {}; + const { href: tilingScheme } = head((links || []).filter(({ rel }) => rel === 'tilingScheme')) || {}; + return { + name, + title, + type: 'wfs3', + visibility: true, + url: layerUrl, + format, + tilingScheme, + tilingSchemes, + bbox: { + crs: 'EPSG:4326', + bounds: { + minx: spatial[0], + miny: spatial[1], + maxx: spatial[2], + maxy: spatial[3] + } + } + }; +}; + +const searchAndPaginate = (json = {}, startPosition, maxRecords, text, url) => { + const { collections } = json; + const filteredLayers = collections + .filter((layer = {}) => !text + || layer.name && layer.name.toLowerCase().indexOf(text.toLowerCase()) !== -1 + || layer.title && layer.title.toLowerCase().indexOf(text.toLowerCase()) !== -1); + return { + numberOfRecordsMatched: filteredLayers.length, + numberOfRecordsReturned: Math.min(maxRecords, filteredLayers.length), + nextRecord: startPosition + Math.min(maxRecords, filteredLayers.length) + 1, + records: filteredLayers + .filter((layer, index) => index >= startPosition - 1 && index < startPosition - 1 + maxRecords) + .map((collection) => ({ + ...collection, + ...collectionToLayer(collection), + capabilitiesUrl: url + })) + }; +}; + +const parseUrl = function(url) { + const serviceUrl = (url || '').split(/\/wfs3\//)[0]; + return `${serviceUrl}/wfs3/collections`; +}; + +export const getRecords = function(url, startPosition, maxRecords, text) { + const cached = capabilitiesCache[url]; + if (cached && new Date().getTime() < cached.timestamp + (ConfigUtils.getConfigProp('cacheExpire') || 60) * 1000) { + return new Promise((resolve) => { + resolve(searchAndPaginate(cached.data, startPosition, maxRecords, text, url)); + }); + } + return axios.get(parseUrl(url)) + .then(({ data }) => { + capabilitiesCache[url] = { + timestamp: new Date().getTime(), + data + }; + return searchAndPaginate(data, startPosition, maxRecords, text, url); + }); +}; + +export const textSearch = function(url, startPosition, maxRecords, text) { + return getRecords(url, startPosition, maxRecords, text); +}; + +export const getTilingSchemes = (layer) => { + const { tilingSchemes, tilingScheme } = layer; + if (isString(tilingSchemes)) { + return axios.get(tilingSchemes) + .then(({ data }) => { + return data && data.tilingSchemes && data.tilingSchemes.length > 0 + ? axios.all( + data.tilingSchemes.map((tilingSchemeId) => + axios.get(tilingScheme.replace('{tilingSchemeId}', tilingSchemeId)) + .then(({ data: scheme }) => scheme) + .catch(() => null) + ) + ) + .then((schemes) => ({ + tilingSchemes: { + url: tilingSchemes, + schemes: schemes.filter(scheme => scheme) + }, + allowedSRS: schemes + .filter(scheme => scheme) + .reduce((acc, { supportedCRS }) => { + return { + ...acc, + [supportedCRS]: true + }; + }, {}) + })) + : { + tilingSchemes: { + url: tilingSchemes, + schemes: null + }, + allowedSRS: {} + }; + }); + } + return new Promise((resolve) => resolve(tilingSchemes)); +}; + +export const getLayerFromId = (serviceUrl, collectionId) => { + return axios.get(`${parseUrl(serviceUrl)}/${collectionId}`) + .then(({ data: collection }) => { + const layer = collectionToLayer(collection); + return getTilingSchemes(layer) + .then((params) => ({ + ...layer, + ...params + })); + }); +}; + +export const reset = () => { + Object.keys(capabilitiesCache).forEach(key => { + delete capabilitiesCache[key]; + }); +}; diff --git a/web/client/api/__tests__/WFS3-test.js b/web/client/api/__tests__/WFS3-test.js new file mode 100644 index 0000000000..e709702540 --- /dev/null +++ b/web/client/api/__tests__/WFS3-test.js @@ -0,0 +1,252 @@ +/* + * Copyright 2019, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +import expect from 'expect'; +import { + getTilingSchemes, + getLayerFromId, + textSearch, + reset +} from '../WFS3'; +import MockAdapter from 'axios-mock-adapter'; +import axios from '../../libs/ajax'; + +let mockAxios; + +describe('Test WFS3 API', () => { + + beforeEach(done => { + mockAxios = new MockAdapter(axios); + setTimeout(done); + }); + + afterEach(done => { + mockAxios.restore(); + setTimeout(done); + reset(); + }); + + it('test getTilingSchemes', (done) => { + + const TILING_SCHEMES_URL = '/geoserver/wfs3/collections/layer_name/tiles'; + const TILING_SCHEMES_ID = 'GoogleMapsCompatible'; + const TILING_SCHEME = { + type: 'TileMatrixSet', + identifier: 'GoogleMapsCompatible', + title: 'GoogleMapsCompatible', + supportedCRS: 'EPSG:3857', + tileMatrix: [{ + matrixHeight: 1, + matrixWidth: 1, + tileHeight: 256, + tileWidth: 256, + identifier: '0', + scaleDenominator: 559082263.9508929, + topLeftCorner: [ + -20037508.34, + 20037508 + ], + type: 'TileMatrix' + }], + boundingBox: { + crs: 'http://www.opengis.net/def/crs/EPSG/0/3857', + lowerCorner: [ + -20037508.34, + -20037508.34 + ], + upperCorner: [ + 20037508.34, + 20037508.34 + ], + type: 'BoundingBox' + }, + wellKnownScaleSet: 'http://www.opengis.net/def/wkss/OGC/1.0/GoogleMapsCompatible' + }; + + mockAxios.onGet(TILING_SCHEMES_URL).reply(() => { + return [ 200, { tilingSchemes: [ TILING_SCHEMES_ID ] }]; + }); + + mockAxios.onGet(`${TILING_SCHEMES_URL}/${TILING_SCHEMES_ID}`).reply(() => { + return [ 200, TILING_SCHEME]; + }); + + const layer = { + tilingScheme: `${TILING_SCHEMES_URL}/{tilingSchemeId}`, + tilingSchemes: TILING_SCHEMES_URL + }; + + getTilingSchemes(layer) + .then(({ tilingSchemes, allowedSRS }) => { + expect(allowedSRS).toEqual({ 'EPSG:3857': true }); + expect(tilingSchemes).toEqual({ + url: TILING_SCHEMES_URL, + schemes: [ TILING_SCHEME ] + }); + done(); + }); + }); + + it('test getLayerFromId', (done) => { + const SERVICE_URL = '/geoserver/wfs3/collections/'; + const COLLECTIONS_ID = 'layer_name'; + const TILING_SCHEMES_URL = '/geoserver/wfs3/collections/layer_name/tiles'; + const TILING_SCHEMES_ID = 'GoogleMapsCompatible'; + const COLLECTION = { + name: COLLECTIONS_ID, + title: 'Layer Title', + extent: { + spatial: [-180, -90, 180, 90] + }, + links: [ + { + href: '/geoserver/wfs3/collections/layer_name/tiles/{tilingSchemeId}/{level}/{row}/{col}', + rel: 'tiles', + type: 'application/vnd.mapbox-vector-tile' + }, + { + href: '/geoserver/wfs3/collections/layer_name/tiles/{tilingSchemeId}', + rel: 'tilingScheme', + type: 'application/json', + title: '...' + }, + { + href: TILING_SCHEMES_URL, + rel: 'tilingSchemes', + type: 'application/json', + title: '...' + } + ] + }; + + const TILING_SCHEME = { + type: 'TileMatrixSet', + identifier: 'GoogleMapsCompatible', + title: 'GoogleMapsCompatible', + supportedCRS: 'EPSG:3857', + tileMatrix: [{ + matrixHeight: 1, + matrixWidth: 1, + tileHeight: 256, + tileWidth: 256, + identifier: '0', + scaleDenominator: 559082263.9508929, + topLeftCorner: [ + -20037508.34, + 20037508 + ], + type: 'TileMatrix' + }], + boundingBox: { + crs: 'http://www.opengis.net/def/crs/EPSG/0/3857', + lowerCorner: [ + -20037508.34, + -20037508.34 + ], + upperCorner: [ + 20037508.34, + 20037508.34 + ], + type: 'BoundingBox' + }, + wellKnownScaleSet: 'http://www.opengis.net/def/wkss/OGC/1.0/GoogleMapsCompatible' + }; + + mockAxios.onGet(`${SERVICE_URL}${COLLECTIONS_ID}`).reply(() => { + return [ 200, COLLECTION]; + }); + + mockAxios.onGet(TILING_SCHEMES_URL).reply(() => { + return [ 200, { tilingSchemes: [ TILING_SCHEMES_ID ] }]; + }); + + mockAxios.onGet(`${TILING_SCHEMES_URL}/${TILING_SCHEMES_ID}`).reply(() => { + return [ 200, TILING_SCHEME]; + }); + + getLayerFromId(SERVICE_URL, COLLECTIONS_ID) + .then((layer) => { + expect(layer).toEqual({ + name: COLLECTIONS_ID, + title: 'Layer Title', + type: 'wfs3', + visibility: true, + url: '/geoserver/wfs3/collections/layer_name/tiles/{tilingSchemeId}/{level}/{row}/{col}', + format: 'application/vnd.mapbox-vector-tile', + tilingScheme: '/geoserver/wfs3/collections/layer_name/tiles/{tilingSchemeId}', + tilingSchemes: { + url: TILING_SCHEMES_URL, + schemes: [ TILING_SCHEME ] + }, + allowedSRS: { 'EPSG:3857': true }, + bbox: { + crs: 'EPSG:4326', + bounds: { + minx: -180, + miny: -90, + maxx: 180, + maxy: 90 + } + }}); + done(); + }); + }); + it('test textSearch', (done) => { + const TILING_SCHEMES_URL = '/geoserver/wfs3/collections'; + const START_POSITION = 1; + const MAX_RECORDS = 1; + const TEXT = ''; + const COLLECTIONS = [ + { + name: 'layer_name_01', + title: 'layer title 01', + extent: { + spatial: [-180, -90, 180, 90] + }, + links: [] + }, + { + name: 'layer_name_02', + title: 'layer title 02', + extent: { + spatial: [-180, -90, 180, 90] + }, + links: [] + } + ]; + + mockAxios.onGet(TILING_SCHEMES_URL) + .reply(() => { + return [ 200, { collections: COLLECTIONS }]; + }); + textSearch(TILING_SCHEMES_URL, START_POSITION, MAX_RECORDS, TEXT) + .then((res) => { + expect(res).toEqual({ + numberOfRecordsMatched: 2, + numberOfRecordsReturned: 1, + nextRecord: 3, + records: [{ + name: 'layer_name_01', + title: 'layer title 01', + extent: { spatial: [ -180, -90, 180, 90 ] }, + links: [], + type: 'wfs3', + visibility: true, + url: undefined, + format: undefined, + tilingScheme: undefined, + tilingSchemes: undefined, + bbox: { crs: 'EPSG:4326', bounds: { minx: -180, miny: -90, maxx: 180, maxy: 90 } }, + capabilitiesUrl: '/geoserver/wfs3/collections' + }] + }); + done(); + }); + }); +}); + diff --git a/web/client/components/map/__tests__/BaseMap-test.jsx b/web/client/components/map/__tests__/BaseMap-test.jsx index 869ade9b61..96d56e3bd3 100644 --- a/web/client/components/map/__tests__/BaseMap-test.jsx +++ b/web/client/components/map/__tests__/BaseMap-test.jsx @@ -5,12 +5,13 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const ReactDOM = require('react-dom'); -const expect = require('expect'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; + +import BaseMap from '../BaseMap'; +import mapType from '../enhancers/mapType'; -const BaseMap = require('../BaseMap'); -const mapType = require('../enhancers/mapType'); const TestMap = mapType(BaseMap); const LAYER_OSM = { diff --git a/web/client/components/map/cesium/__tests__/Layer-test-chrome.jsx b/web/client/components/map/cesium/__tests__/Layer-test-chrome.jsx index 091c5de49d..ac62eef837 100644 --- a/web/client/components/map/cesium/__tests__/Layer-test-chrome.jsx +++ b/web/client/components/map/cesium/__tests__/Layer-test-chrome.jsx @@ -162,6 +162,63 @@ describe('Cesium layer', () => { expect(map.imageryLayers._layers[0]._imageryProvider._tileProvider._subdomains.length).toBe(1); expect(map.imageryLayers._layers[0]._imageryProvider.proxy.proxy).toExist(); }); + + it('test wms vector formats must change to default image format (image/png)', () => { + const options = { + "type": 'wms', + "visibility": true, + "name": 'osm:vector_tile', + "group": 'Vector', + "url": "http://demo.geo-solutions.it/geoserver/wms" + }; + + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + + expect(layer.layer._tileProvider._url.indexOf('format=image%2Fpng') !== -1).toBe(true); + + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(layer.layer._tileProvider._url.indexOf('format=image%2Fpng') !== -1).toBe(true); + + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(layer.layer._tileProvider._url.indexOf('format=image%2Fpng') !== -1).toBe(true); + + // check if it switches to jpeg + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(layer.layer._tileProvider._url.indexOf('format=image%2Fjpeg') !== -1).toBe(true); + }); + it('wms layer with credits', () => { var options = { "type": "wms", @@ -825,4 +882,73 @@ describe('Cesium layer', () => { expect(cqlFilter).toBe("((\"prop2\" = 'value2')) AND (prop = 'value')"); }); + + + it('test wmts vector formats must change to default image format (image/png)', () => { + const options = { + type: 'wmts', + visibility: true, + name: 'osm:vector_tile', + group: 'Vector', + tileMatrixSet: 'EPSG:900913', + matrixIds: { + 'EPSG:4326': [{ + ranges: { + cols: {max: 0, min: 0}, + rows: {max: 0, min: 0} + } + }] + }, + url: 'http://sample.server/geoserver/gwc/service/wmts' + }; + + const GeoJSON = 'application/json;type=geojson'; + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(layer.layer._format).toBe('image/png'); + + const MVT = 'application/vnd.mapbox-vector-tile'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(layer.layer._format).toBe('image/png'); + + const TopoJSON = 'application/json;type=topojson'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(layer.layer._format).toBe('image/png'); + + // check if it switches to jpeg + const JPEG = 'image/jpeg'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(layer.layer._format).toBe(JPEG); + }); }); diff --git a/web/client/components/map/cesium/plugins/WMSLayer.js b/web/client/components/map/cesium/plugins/WMSLayer.js index fac6a6e1ee..6da659e72e 100644 --- a/web/client/components/map/cesium/plugins/WMSLayer.js +++ b/web/client/components/map/cesium/plugins/WMSLayer.js @@ -18,6 +18,8 @@ const {getAuthenticationParam, getURLs} = require('../../../../utils/LayersUtils const { optionsToVendorParams } = require('../../../../utils/VendorParamsUtils'); const SecurityUtils = require('../../../../utils/SecurityUtils'); +const { isVectorFormat } = require('../../../../utils/VectorTileUtils'); + function splitUrl(originalUrl) { let url = originalUrl; let queryString = ""; @@ -57,7 +59,7 @@ function wmsToCesiumOptionsSingleTile(options) { const params = optionsToVendorParams(options); const parameters = assign({ styles: options.style || "", - format: options.format || 'image/png', + format: isVectorFormat(options.format) && 'image/png' || options.format || 'image/png', transparent: options.transparent !== undefined ? options.transparent : true, opacity: opacity, tiled: options.tiled !== undefined ? options.tiled : true, @@ -94,7 +96,7 @@ function wmsToCesiumOptions(options) { enablePickFeatures: false, parameters: assign({ styles: options.style || "", - format: options.format || 'image/png', + format: isVectorFormat(options.format) && 'image/png' || options.format || 'image/png', transparent: options.transparent !== undefined ? options.transparent : true, opacity: opacity, tiled: options.tiled !== undefined ? options.tiled : true diff --git a/web/client/components/map/cesium/plugins/WMTSLayer.js b/web/client/components/map/cesium/plugins/WMTSLayer.js index d319e89ded..2710da3198 100644 --- a/web/client/components/map/cesium/plugins/WMTSLayer.js +++ b/web/client/components/map/cesium/plugins/WMTSLayer.js @@ -6,15 +6,16 @@ * LICENSE file in the root directory of this source tree. */ -const Layers = require('../../../../utils/cesium/Layers'); -const ConfigUtils = require('../../../../utils/ConfigUtils'); -const ProxyUtils = require('../../../../utils/ProxyUtils'); -const WMTSUtils = require('../../../../utils/WMTSUtils'); -const Cesium = require('../../../../libs/cesium'); -const {getAuthenticationParam, getURLs} = require('../../../../utils/LayersUtils'); -const assign = require('object-assign'); -const { isObject, isArray, slice, get, head} = require('lodash'); -const urlParser = require('url'); +import Layers from '../../../../utils/cesium/Layers'; +import ConfigUtils from '../../../../utils/ConfigUtils'; +import ProxyUtils from '../../../../utils/ProxyUtils'; +import WMTSUtils from '../../../../utils/WMTSUtils'; +import Cesium from '../../../../libs/cesium'; +import { getAuthenticationParam, getURLs } from '../../../../utils/LayersUtils'; +import assign from 'object-assign'; +import { isObject, isArray, slice, get, head} from 'lodash'; +import urlParser from 'url'; +import { isVectorFormat } from '../../../../utils/VectorTileUtils'; function splitUrl(originalUrl) { let url = originalUrl; @@ -112,7 +113,8 @@ function wmtsToCesiumOptions(options) { return assign({ // TODO: multi-domain support, if use {s} switches to RESTFul mode url: head(getURLs(isArray(options.url) ? options.url : [options.url], queryParametersString)), - format: options.format || 'image/png', + // set image format to png if vector to avoid errors while switching between map type + format: isVectorFormat(options.format) && 'image/png' || options.format || 'image/png', isValid, // tileDiscardPolicy: { // isReady: () => true, @@ -148,7 +150,8 @@ const createLayer = options => { }; const updateLayer = (layer, newOptions, oldOptions) => { - if (newOptions.securityToken !== oldOptions.securityToken) { + if (newOptions.securityToken !== oldOptions.securityToken + || oldOptions.format !== newOptions.format) { return createLayer(newOptions); } return null; diff --git a/web/client/components/map/leaflet/DrawSupport.jsx b/web/client/components/map/leaflet/DrawSupport.jsx index c990ccf430..8f7da8c640 100644 --- a/web/client/components/map/leaflet/DrawSupport.jsx +++ b/web/client/components/map/leaflet/DrawSupport.jsx @@ -28,7 +28,7 @@ L.Draw.Polygon.prototype._calculateFinishDistance = function(t) { }; const {isSimpleGeomType, getSimpleGeomType} = require('../../../utils/MapUtils'); -const {boundsToOLExtent} = require('../../../utils/DrawSupportUtils'); +const {boundsToOLExtent} = require('../../../utils/leaflet/DrawSupportUtils'); const assign = require('object-assign'); const CoordinatesUtils = require('../../../utils/CoordinatesUtils'); diff --git a/web/client/components/map/leaflet/__tests__/Layer-test.jsx b/web/client/components/map/leaflet/__tests__/Layer-test.jsx index d531e63f23..ab74aeb5ae 100644 --- a/web/client/components/map/leaflet/__tests__/Layer-test.jsx +++ b/web/client/components/map/leaflet/__tests__/Layer-test.jsx @@ -186,6 +186,78 @@ describe('Leaflet layer', () => { expect(urls.length).toBe(1); }); + it('test wms vector formats must change to default image format (image/png)', () => { + const options = { + type: 'wms', + visibility: true, + name: 'osm:vector_tile', + group: 'Vector', + "url": "http://sample.server/geoserver/wms" + }; + + let layer = ReactDOM.render(, document.getElementById("container")); + expect(layer).toExist(); + let lcount = 0; + map.eachLayer(function() { lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmsParams.format).toBe('image/png'); + + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + lcount = 0; + map.eachLayer(function() { lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmsParams.format).toBe('image/png'); + + + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + lcount = 0; + map.eachLayer(function() { lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmsParams.format).toBe('image/png'); + + // check if it switches to jpeg + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + lcount = 0; + map.eachLayer(function() { lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmsParams.format).toBe('image/jpeg'); + + }); + it('creates a wms elevation layer for leaflet map', () => { var options = { "type": "wms", @@ -924,4 +996,88 @@ describe('Leaflet layer', () => { expect(lcount).toBe(1); expect(layer.layer.wmsParams.CQL_FILTER).toBe("((\"prop2\" = 'value2')) AND (prop = 'value')"); }); + + it('test wmts vector formats must change to default image format (image/png)', () => { + const options = { + type: 'wmts', + visibility: true, + name: 'osm:vector_tile', + group: 'Vector', + tileMatrixSet: [ + { + 'TileMatrix': [], + 'ows:Identifier': 'EPSG:900913', + 'ows:SupportedCRS': 'urn:ogc:def:crs:EPSG::900913' + } + ], + url: 'http://sample.server/geoserver/gwc/service/wmts' + }; + + const GeoJSON = 'application/json;type=geojson'; + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + let lcount = 0; + map.eachLayer(function() {lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmtsParams.format).toBe('image/png'); + + const MVT = 'application/vnd.mapbox-vector-tile'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + lcount = 0; + map.eachLayer(function() {lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmtsParams.format).toBe('image/png'); + + + const TopoJSON = 'application/json;type=topojson'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + lcount = 0; + map.eachLayer(function() {lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmtsParams.format).toBe('image/png'); + + // check if it switches to jpeg + const JPEG = 'image/jpeg'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + lcount = 0; + map.eachLayer(function() {lcount++; }); + expect(lcount).toBe(1); + + expect(layer.layer.wmtsParams.format).toBe(JPEG); + + }); }); diff --git a/web/client/components/map/leaflet/plugins/WMSLayer.js b/web/client/components/map/leaflet/plugins/WMSLayer.js index 3aea7b3cba..ad7e07b3d3 100644 --- a/web/client/components/map/leaflet/plugins/WMSLayer.js +++ b/web/client/components/map/leaflet/plugins/WMSLayer.js @@ -19,6 +19,8 @@ const SecurityUtils = require('../../../../utils/SecurityUtils'); const ElevationUtils = require('../../../../utils/ElevationUtils'); const { creditsToAttribution } = require('../../../../utils/LayersUtils'); +const { isVectorFormat } = require('../../../../utils/VectorTileUtils'); + require('leaflet.nontiledlayer'); L.NonTiledLayer.WMSCustom = L.NonTiledLayer.WMS.extend({ @@ -166,7 +168,7 @@ function wmsToLeafletOptions(options) { attribution: options.credits && creditsToAttribution(options.credits), layers: options.name, styles: options.style || "", - format: options.format || 'image/png', + format: isVectorFormat(options.format) && 'image/png' || options.format || 'image/png', transparent: options.transparent !== undefined ? options.transparent : true, tiled: options.tiled !== undefined ? options.tiled : true, opacity: opacity, diff --git a/web/client/components/map/leaflet/plugins/WMTSLayer.js b/web/client/components/map/leaflet/plugins/WMTSLayer.js index 789a4cfd13..417c3aa0e6 100644 --- a/web/client/components/map/leaflet/plugins/WMTSLayer.js +++ b/web/client/components/map/leaflet/plugins/WMTSLayer.js @@ -6,14 +6,15 @@ * LICENSE file in the root directory of this source tree. */ -const Layers = require('../../../../utils/leaflet/Layers'); -const CoordinatesUtils = require('../../../../utils/CoordinatesUtils'); -const L = require('leaflet'); -const assign = require('object-assign'); -const SecurityUtils = require('../../../../utils/SecurityUtils'); -const WMTSUtils = require('../../../../utils/WMTSUtils'); -const WMTS = require('../../../../utils/leaflet/WMTS'); -const {isArray, isObject, head} = require('lodash'); +import Layers from '../../../../utils/leaflet/Layers'; +import CoordinatesUtils from '../../../../utils/CoordinatesUtils'; +import L from 'leaflet'; +import assign from 'object-assign'; +import SecurityUtils from '../../../../utils/SecurityUtils'; +import WMTSUtils from '../../../../utils/WMTSUtils'; +import WMTS from '../../../../utils/leaflet/WMTS'; +import { isArray, isObject, head } from 'lodash'; +import { isVectorFormat } from '../../../../utils/VectorTileUtils'; L.tileLayer.wmts = function(urls, options, matrixOptions) { return new WMTS(urls, options, matrixOptions); @@ -26,7 +27,8 @@ function wmtsToLeafletOptions(options) { requestEncoding: options.requestEncoding, layer: options.name, style: options.style || "", - format: options.format || 'image/png', + // set image format to png if vector to avoid errors while switching between map type + format: isVectorFormat(options.format) && 'image/png' || options.format || 'image/png', tileMatrixSet: tileMatrixSet, version: options.version || "1.0.0", tileSize: options.tileSize || 256, @@ -60,7 +62,8 @@ const createLayer = options => { }; const updateLayer = (layer, newOptions, oldOptions) => { - if (oldOptions.securityToken !== newOptions.securityToken) { + if (oldOptions.securityToken !== newOptions.securityToken + || oldOptions.format !== newOptions.format) { return createLayer(newOptions); } return null; diff --git a/web/client/components/map/openlayers/DrawSupport.jsx b/web/client/components/map/openlayers/DrawSupport.jsx index 4eec1b25e7..feca6d2086 100644 --- a/web/client/components/map/openlayers/DrawSupport.jsx +++ b/web/client/components/map/openlayers/DrawSupport.jsx @@ -6,22 +6,49 @@ * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const ol = require('openlayers'); -const {concat, head, find, slice, omit, isArray, last, filter, isNil, castArray} = require('lodash'); -const PropTypes = require('prop-types'); -const assign = require('object-assign'); -const uuid = require('uuid'); -const axios = require('axios'); -const {isSimpleGeomType, getSimpleGeomType} = require('../../../utils/MapUtils'); -const {reprojectGeoJson, calculateDistance, reproject} = require('../../../utils/CoordinatesUtils'); -const {createStylesAsync} = require('../../../utils/VectorStyleUtils'); -const wgs84Sphere = new ol.Sphere(6378137); -const {transformPolygonToCircle} = require('../../../utils/DrawSupportUtils'); -const {isCompletePolygon} = require('../../../utils/AnnotationsUtils'); -const VectorStyle = require('./VectorStyle'); -const {parseStyles} = require('./VectorStyle'); -const geojsonFormat = new ol.format.GeoJSON(); +import React from 'react'; +import concat from 'lodash/concat'; +import head from 'lodash/head'; +import find from 'lodash/find'; +import slice from 'lodash/slice'; +import omit from 'lodash/omit'; +import isArray from 'lodash/isArray'; +import last from 'lodash/last'; +import filter from 'lodash/filter'; +import isNil from 'lodash/isNil'; +import castArray from 'lodash/castArray'; + +import PropTypes from 'prop-types'; +import assign from 'object-assign'; +import uuid from 'uuid'; +import axios from 'axios'; +import {isSimpleGeomType, getSimpleGeomType} from '../../../utils/MapUtils'; +import {reprojectGeoJson, calculateDistance, reproject} from '../../../utils/CoordinatesUtils'; +import {createStylesAsync} from '../../../utils/VectorStyleUtils'; +import {transformPolygonToCircle} from '../../../utils/openlayers/DrawSupportUtils'; +import {isCompletePolygon} from '../../../utils/AnnotationsUtils'; +import { parseStyles, getStyle, defaultStyles, getMarkerStyle, getMarkerStyleLegacy } from './VectorStyle'; + +import {GeoJSON} from 'ol/format'; +import Feature from 'ol/Feature'; +import VectorSource from 'ol/source/Vector'; +import VectorLayer from 'ol/layer/Vector'; +import Draw from 'ol/interaction/Draw'; +import { Point, MultiPoint, LineString, MultiLineString, Polygon, MultiPolygon, Circle} from 'ol/geom'; +import GeometryCollection from 'ol/geom/GeometryCollection'; +import {Style, Stroke, Fill, Text} from 'ol/style'; +import CircleStyle from 'ol/style/Circle'; +import Collection from 'ol/Collection'; +import {always, primaryAction, altKeyOnly} from 'ol/events/condition'; +import DoubleClickZoom from 'ol/interaction/DoubleClickZoom'; +import Translate from 'ol/interaction/Translate'; +import Modify from 'ol/interaction/Modify'; +import Select from 'ol/interaction/Select'; +import {unByKey} from 'ol/Observable'; +import {getCenter} from 'ol/extent'; +import {fromCircle, circular} from 'ol/geom/Polygon'; + +const geojsonFormat = new GeoJSON(); /** * Component that allows to draw and edit geometries as (Point, LineString, Polygon, Rectangle, Circle, MultiGeometries) @@ -44,7 +71,7 @@ const geojsonFormat = new ol.format.GeoJSON(); */ // TODO FIX doc -class DrawSupport extends React.Component { +export default class DrawSupport extends React.Component { static propTypes = { map: PropTypes.object, drawOwner: PropTypes.string, @@ -114,7 +141,7 @@ class DrawSupport extends React.Component { } getNewFeature = (newDrawMethod, coordinates, radius, center) => { - return new ol.Feature({ + return new Feature({ geometry: this.createOLGeometry({type: newDrawMethod, coordinates, radius, center}) }); } @@ -131,7 +158,7 @@ class DrawSupport extends React.Component { if (f.style) { let olFeature = this.toOlFeature(f); if (olFeature) { - olFeature.setStyle(f.style ? VectorStyle.getStyle(f) : this.toOlStyle(f.style, f.selected)); + olFeature.setStyle(f.style ? getStyle(f) : this.toOlStyle(f.style, f.selected)); } } }); @@ -162,8 +189,8 @@ class DrawSupport extends React.Component { /** This is a style function that applies array of styles to the features. It takes the style from the features in the props being drawn because - the style array from the geojson feature model is not passed to ol.feature - @param {object} ftOl it is an ol.Feature object + the style array from the geojson feature model is not passed to Feature + @param {object} ftOl it is an Feature object */ layerStyle = (ftOl) => { let originalFeature = head(newProps.features) && find(head(newProps.features).features, ftTemp => ftTemp.properties.id === ftOl.getProperties().id) || null; @@ -174,12 +201,12 @@ class DrawSupport extends React.Component { }); } else { // if the styles is not present in the feature it uses a default one based on the drawMethod basically - return parseStyles({style: VectorStyle.defaultStyles[styleType]}); + return parseStyles({style: defaultStyles[styleType]}); } }; - this.geojson = new ol.format.GeoJSON(); - this.drawSource = new ol.source.Vector(); - this.drawLayer = new ol.layer.Vector({ + this.geojson = new GeoJSON(); + this.drawSource = new VectorSource(); + this.drawLayer = new VectorLayer({ source: this.drawSource, zIndex: 100000000, style: layerStyle @@ -205,9 +232,9 @@ class DrawSupport extends React.Component { let feature; features.forEach((f) => { if (f.type === "FeatureCollection") { - let featuresOL = (new ol.format.GeoJSON()).readFeatures(f); + let featuresOL = (new GeoJSON()).readFeatures(f); featuresOL = featuresOL.map(ft => transformPolygonToCircle(ft, mapCrs)); - this.drawSource = new ol.source.Vector({ + this.drawSource = new VectorSource({ features: featuresOL }); this.drawLayer.setSource(this.drawSource); @@ -221,11 +248,11 @@ class DrawSupport extends React.Component { if (drawMethod === "Circle" && geometry && (geometry.properties && geometry.properties.center || geometry.center)) { center = geometry.properties && geometry.properties.center ? reproject(geometry.properties.center, "EPSG:4326", mapCrs) : geometry.center; center = [center.x, center.y]; - feature = new ol.Feature({ + feature = new Feature({ geometry: this.createOLGeometry({type: "Circle", center, projection: "EPSG:3857", radius: geometry.properties && geometry.properties.radius || geometry.radius}) }); } else { - feature = new ol.Feature({ + feature = new Feature({ geometry: this.createOLGeometry(geometry.geometry ? geometry.geometry : {...geometry, ...geometry.properties, center }) }); } @@ -238,15 +265,15 @@ class DrawSupport extends React.Component { // TODO CHECK THIS WITH FeatureCollection if (features.length === 0 && (options.editEnabled || options.drawEnabled)) { if (options.transformToFeatureCollection) { - this.drawSource = new ol.source.Vector({ - features: (new ol.format.GeoJSON()).readFeatures( + this.drawSource = new VectorSource({ + features: (new GeoJSON()).readFeatures( { type: "FeatureCollection", features: [] }) }); this.drawLayer.setSource(this.drawSource); } else { - feature = new ol.Feature({ + feature = new Feature({ geometry: this.createOLGeometry({type: drawMethod, coordinates: null}) }); this.drawSource.addFeature(feature); @@ -254,8 +281,8 @@ class DrawSupport extends React.Component { } else { if (features[0] && features[0].type === "GeometryCollection" ) { // HERE IT ENTERS WITH EDIT - this.drawSource = new ol.source.Vector({ - features: (new ol.format.GeoJSON()).readFeatures(features[0]) + this.drawSource = new VectorSource({ + features: (new GeoJSON()).readFeatures(features[0]) }); let geoms = this.replacePolygonsWithCircles(this.drawSource.getFeatures()[0]); @@ -265,8 +292,8 @@ class DrawSupport extends React.Component { if (features[0] && features[0].geometry && features[0].geometry.type === "GeometryCollection" ) { // HERE IT ENTERS WITH REPLACE feature = reprojectGeoJson(features[0], options.featureProjection, mapCrs).geometry; - this.drawSource = new ol.source.Vector({ - features: (new ol.format.GeoJSON()).readFeatures(feature) + this.drawSource = new VectorSource({ + features: (new GeoJSON()).readFeatures(feature) }); // TODO remove this props this.drawSource.getFeatures()[0].set("textGeometriesIndexes", features[0].properties && features[0].properties.textGeometriesIndexes); @@ -297,7 +324,7 @@ class DrawSupport extends React.Component { } else { const styleType = this.convertGeometryTypeToStyleType(newProps.drawMethod); // if the styles is not present in the feature it uses a default one based on the drawMethod basically - return parseStyles({style: VectorStyle.defaultStyles[styleType]}); + return parseStyles({style: defaultStyles[styleType]}); } }); } @@ -322,25 +349,23 @@ class DrawSupport extends React.Component { if (this.drawInteraction) { this.removeDrawInteraction(); } - this.drawInteraction = new ol.interaction.Draw(this.drawPropertiesForGeometryType(drawMethod, maxPoints, this.drawSource, newProps)); + this.drawInteraction = new Draw(this.drawPropertiesForGeometryType(drawMethod, maxPoints, this.drawSource, newProps)); this.props.map.disableEventListener('singleclick'); - this.drawInteraction.on('drawstart', function(evt) { - this.sketchFeature = evt.feature; + this.drawInteraction.on('drawstart', () => { if (this.selectInteraction) { this.selectInteraction.getFeatures().clear(); this.selectInteraction.setActive(false); } - }, this); - this.drawInteraction.on('drawend', function(evt) { - this.sketchFeature = evt.feature; - this.sketchFeature.set('id', uuid.v1()); - let feature; - if (this.props.drawMethod === "Circle" && this.sketchFeature.getGeometry().getType() === "Circle") { - const radius = this.sketchFeature.getGeometry().getRadius(); - const center = this.sketchFeature.getGeometry().getCenter(); - this.sketchFeature.setGeometry(this.polygonFromCircle(center, radius)); + }); + this.drawInteraction.on('drawend', (evt) => { + const sketchFeature = evt.feature.clone(); + sketchFeature.set('id', uuid.v1()); + if (this.props.drawMethod === "Circle" && sketchFeature.getGeometry().getType() === "Circle") { + const radius = sketchFeature.getGeometry().getRadius(); + const center = sketchFeature.getGeometry().getCenter(); + sketchFeature.setGeometry(this.polygonFromCircle(center, radius)); } - feature = this.fromOLFeature(this.sketchFeature, startingPoint); + const feature = this.fromOLFeature(sketchFeature, startingPoint); this.props.onEndDrawing(feature, this.props.drawOwner); if (this.props.options.stopAfterDrawing) { @@ -351,7 +376,7 @@ class DrawSupport extends React.Component { this.addSelectInteraction(); this.selectInteraction.setActive(true); } - }, this); + }); this.props.map.addInteraction(this.drawInteraction); this.setDoubleClickZoomEnabled(false); @@ -359,7 +384,7 @@ class DrawSupport extends React.Component { toMulti = (geometry) => { if (geometry.getType() === 'Point') { - return new ol.geom.MultiPoint([geometry.getCoordinates()]); + return new MultiPoint([geometry.getCoordinates()]); } return geometry; }; @@ -367,20 +392,20 @@ class DrawSupport extends React.Component { if (this.drawInteraction) { this.removeDrawInteraction(); } - this.drawInteraction = new ol.interaction.Draw(this.drawPropertiesForGeometryType(getSimpleGeomType(drawMethod), maxPoints, isSimpleGeomType(drawMethod) ? this.drawSource : null, newProps )); + this.drawInteraction = new Draw(this.drawPropertiesForGeometryType(getSimpleGeomType(drawMethod), maxPoints, isSimpleGeomType(drawMethod) ? this.drawSource : null, newProps )); this.props.map.disableEventListener('singleclick'); - this.drawInteraction.on('drawstart', function(evt) { - this.sketchFeature = evt.feature; + this.drawInteraction.on('drawstart', () => { if (this.selectInteraction) { this.selectInteraction.getFeatures().clear(); this.selectInteraction.setActive(false); } - }, this); + }); - this.drawInteraction.on('drawend', function(evt) { - this.sketchFeature = evt.feature; - this.sketchFeature.set('id', uuid.v1()); - let drawnGeom = this.sketchFeature.getGeometry(); + this.drawInteraction.on('drawend', (evt) => { + const sketchFeature = evt.feature.clone(); + const id = uuid.v1(); + sketchFeature.set('id', id); + let drawnGeom = sketchFeature.getGeometry(); let drawnFeatures = this.drawLayer.getSource().getFeatures(); let previousGeometries; let features = this.props.features; @@ -396,8 +421,7 @@ class DrawSupport extends React.Component { newFeature = this.getNewFeature(newDrawMethod, coordinates); // TODO verify center is projected in 4326 and is an array center = reproject(center, this.getMapCrs(), "EPSG:4326", false); - const originalId = newProps && newProps.features && newProps.features.length && newProps.features[0] && newProps.features[0].features && newProps.features[0].features.length && newProps.features[0].features.filter(f => f.properties.isDrawing)[0].properties.id || this.sketchFeature.get("id"); - // this.sketchFeature.set('id', originalId); + const originalId = newProps && newProps.features && newProps.features.length && newProps.features[0] && newProps.features[0].features && newProps.features[0].features.length && newProps.features[0].features.filter(f => f.properties.isDrawing)[0].properties.id || id; newFeature.setProperties({isCircle: true, radius, center: [center.x, center.y], id: originalId}); } else if (drawMethod === "Polygon") { newDrawMethod = this.props.drawMethod; @@ -412,7 +436,7 @@ class DrawSupport extends React.Component { newFeature.setProperties({isText: true, valueText: "."}); } } - // drawnFeatures is array of ol.Feature + // drawnFeatures is array of Feature const previousFeatures = drawnFeatures.length >= 1 ? [...this.replaceCirclesWithPolygonsInFeatureColl(drawnFeatures)] : []; if (!newFeature.getProperties().id) { newFeature.setProperties({id: uuid.v1()}); @@ -420,8 +444,8 @@ class DrawSupport extends React.Component { const newFeatures = [...previousFeatures, newFeature]; // create FeatureCollection externalize as function let newFeatureColl = geojsonFormat.writeFeaturesObject(newFeatures); - const vectorSource = new ol.source.Vector({ - features: (new ol.format.GeoJSON()).readFeatures(newFeatureColl) + const vectorSource = new VectorSource({ + features: (new GeoJSON()).readFeatures(newFeatureColl) }); this.drawLayer.setSource(vectorSource); let feature = reprojectGeoJson(newFeatureColl, this.getMapCrs(), "EPSG:4326"); @@ -438,18 +462,18 @@ class DrawSupport extends React.Component { const newMultiGeom = this.toMulti(this.createOLGeometry({type: newDrawMethod, coordinates})); if (features.length === 1 && features[0] && !features[0].geometry) { previousGeometries = []; - geomCollection = new ol.geom.GeometryCollection([newMultiGeom]); + geomCollection = new GeometryCollection([newMultiGeom]); } else { previousGeometries = this.toMulti(head(drawnFeatures).getGeometry()); if (previousGeometries.getGeometries) { // transform also previous circles into polygon const geoms = this.replaceCirclesWithPolygons(head(drawnFeatures)); - geomCollection = new ol.geom.GeometryCollection([...geoms, newMultiGeom]); + geomCollection = new GeometryCollection([...geoms, newMultiGeom]); } else { - geomCollection = new ol.geom.GeometryCollection([previousGeometries, newMultiGeom]); + geomCollection = new GeometryCollection([previousGeometries, newMultiGeom]); } } - this.sketchFeature.setGeometry(geomCollection); + sketchFeature.setGeometry(geomCollection); } else if (drawMethod === "Text" || drawMethod === "MultiPoint") { let coordinates = drawnGeom.getCoordinates(); @@ -457,17 +481,17 @@ class DrawSupport extends React.Component { let newMultiGeom = this.toMulti(this.createOLGeometry({type: newDrawMethod, coordinates: [coordinates]})); if (features.length === 1 && !features[0].geometry) { previousGeometries = []; - geomCollection = new ol.geom.GeometryCollection([newMultiGeom]); + geomCollection = new GeometryCollection([newMultiGeom]); } else { previousGeometries = this.toMulti(head(drawnFeatures).getGeometry()); if (previousGeometries.getGeometries) { let geoms = this.replaceCirclesWithPolygons(head(drawnFeatures)); - geomCollection = new ol.geom.GeometryCollection([...geoms, newMultiGeom]); + geomCollection = new GeometryCollection([...geoms, newMultiGeom]); } else { - geomCollection = new ol.geom.GeometryCollection([previousGeometries, newMultiGeom]); + geomCollection = new GeometryCollection([previousGeometries, newMultiGeom]); } } - this.sketchFeature.setGeometry(geomCollection); + sketchFeature.setGeometry(geomCollection); } else if (!isSimpleGeomType(drawMethod)) { let newMultiGeom; geomCollection = null; @@ -502,42 +526,42 @@ class DrawSupport extends React.Component { let newGeoms = geoms.map(gg => { return gg.getType() === geomAlreadyPresent.getType() ? geomAlreadyPresent : gg; }); - geomCollection = new ol.geom.GeometryCollection(newGeoms); + geomCollection = new GeometryCollection(newGeoms); } else { if (previousGeometries.getType() === "GeometryCollection") { - geomCollection = new ol.geom.GeometryCollection([...geoms, newMultiGeom]); + geomCollection = new GeometryCollection([...geoms, newMultiGeom]); } else { if (drawMethod === "Text") { - geomCollection = new ol.geom.GeometryCollection([newMultiGeom]); + geomCollection = new GeometryCollection([newMultiGeom]); } else { - geomCollection = new ol.geom.GeometryCollection([previousGeometries, newMultiGeom]); + geomCollection = new GeometryCollection([previousGeometries, newMultiGeom]); } } } - this.sketchFeature.setGeometry(geomCollection); + sketchFeature.setGeometry(geomCollection); } else { - this.sketchFeature.setGeometry(geomAlreadyPresent); + sketchFeature.setGeometry(geomAlreadyPresent); } } let properties = this.props.features[0].properties; if (drawMethod === "Text") { properties = assign({}, this.props.features[0].properties, { textValues: (this.props.features[0].properties.textValues || []).concat(["."]), - textGeometriesIndexes: (this.props.features[0].properties.textGeometriesIndexes || []).concat([this.sketchFeature.getGeometry().getGeometries().length - 1]) + textGeometriesIndexes: (this.props.features[0].properties.textGeometriesIndexes || []).concat([sketchFeature.getGeometry().getGeometries().length - 1]) }); } if (drawMethod === "Circle") { properties = assign({}, properties, { - circles: (this.props.features[0].properties.circles || []).concat([this.sketchFeature.getGeometry().getGeometries().length - 1]) + circles: (this.props.features[0].properties.circles || []).concat([sketchFeature.getGeometry().getGeometries().length - 1]) }); } - let feature = this.fromOLFeature(this.sketchFeature, startingPoint, properties); - const vectorSource = new ol.source.Vector({ - features: (new ol.format.GeoJSON()).readFeatures(feature) + let feature = this.fromOLFeature(sketchFeature, startingPoint, properties); + const vectorSource = new VectorSource({ + features: (new GeoJSON()).readFeatures(feature) }); this.drawLayer.setSource(vectorSource); - let newFeature = reprojectGeoJson(geojsonFormat.writeFeatureObject(this.sketchFeature.clone()), this.getMapCrs(), "EPSG:4326"); + let newFeature = reprojectGeoJson(geojsonFormat.writeFeatureObject(sketchFeature.clone()), this.getMapCrs(), "EPSG:4326"); if (newFeature.geometry.type === "Polygon") { newFeature.geometry.coordinates[0].push(newFeature.geometry.coordinates[0][0]); } @@ -563,7 +587,7 @@ class DrawSupport extends React.Component { } } - }, this); + }); this.props.map.addInteraction(this.drawInteraction); this.setDoubleClickZoomEnabled(false); @@ -573,27 +597,27 @@ class DrawSupport extends React.Component { let drawBaseProps = { source: this.drawSource || source, type: /** @type {ol.geom.GeometryType} */ geometryType, - style: geometryType === "Marker" ? VectorStyle.getMarkerStyle(newProps.style) : new ol.style.Style({ - fill: new ol.style.Fill({ + style: geometryType === "Marker" ? getMarkerStyle(newProps.style) : new Style({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }), - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: 'rgba(0, 0, 0, 0.5)', lineDash: [10, 10], width: 2 }), - image: new ol.style.Circle({ + image: new CircleStyle({ radius: 5, - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: 'rgba(0, 0, 0, 0.7)' }), - fill: new ol.style.Fill({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }) }) }), - features: new ol.Collection(), - condition: ol.events.condition.always + features: new Collection(), + condition: always }; let roiProps = {}; switch (geometryType) { @@ -603,7 +627,7 @@ class DrawSupport extends React.Component { roiProps.geometryFunction = function(coordinates, geometry) { let geom = geometry; if (!geom) { - geom = new ol.geom.Polygon(null); + geom = new Polygon(null); } let start = coordinates[0]; let end = coordinates[1]; @@ -627,7 +651,7 @@ class DrawSupport extends React.Component { roiProps.geometryFunction = (coordinates, geometry) => { let geom = geometry; if (!geom) { - geom = new ol.geom.Polygon(null); + geom = new Polygon(null); geom.setProperties({geodesicCenter: [...coordinates[0]]}, true); } let projection = this.props.map.getView().getProjection().getCode(); @@ -635,7 +659,7 @@ class DrawSupport extends React.Component { return this.reprojectCoordinatesToWGS84(coordinate, projection); }); let radius = calculateDistance(wgs84Coordinates, 'haversine'); - let coords = ol.geom.Polygon.circular(wgs84Sphere, wgs84Coordinates[0], radius, roiProps.maxPoints).clone().transform('EPSG:4326', projection).getCoordinates(); + let coords = circular(wgs84Coordinates[0], radius).clone().transform('EPSG:4326', projection).getCoordinates(); geom.setCoordinates(coords); return geom; }; @@ -669,7 +693,7 @@ class DrawSupport extends React.Component { let interactions = this.props.map.getInteractions(); for (let i = 0; i < interactions.getLength(); i++) { let interaction = interactions.item(i); - if (interaction instanceof ol.interaction.DoubleClickZoom) { + if (interaction instanceof DoubleClickZoom) { interaction.setActive(enabled); break; } @@ -704,7 +728,7 @@ class DrawSupport extends React.Component { this.props.map.removeInteraction(this.translateInteraction); } - this.translateInteraction = new ol.interaction.Translate({ + this.translateInteraction = new Translate({ features: this.selectInteraction.getFeatures() }); this.translateInteraction.setActive(false); @@ -717,10 +741,10 @@ class DrawSupport extends React.Component { this.props.map.removeInteraction(this.modifyInteraction); } - this.modifyInteraction = new ol.interaction.Modify({ + this.modifyInteraction = new Modify({ features: this.selectInteraction.getFeatures(), condition: (e) => { - return ol.events.condition.primaryAction(e) && !ol.events.condition.altKeyOnly(e); + return primaryAction(e) && !altKeyOnly(e); } }); @@ -739,7 +763,7 @@ class DrawSupport extends React.Component { addDrawOrEditInteractions = (newProps) => { if (this.state && this.state.keySingleClickCallback) { - ol.Observable.unByKey(this.state.keySingleClickCallback); + unByKey(this.state.keySingleClickCallback); } const singleClickCallback = (event) => { if (this.drawSource && newProps.options) { @@ -827,7 +851,7 @@ class DrawSupport extends React.Component { olFt = transformPolygonToCircle(olFt, this.getMapCrs()); previousFeatures[previousFtIndex] = olFt; - this.drawSource = new ol.source.Vector({ + this.drawSource = new VectorSource({ features: previousFeatures }); this.drawLayer.setSource(this.drawSource); @@ -889,13 +913,13 @@ class DrawSupport extends React.Component { this.selectFeature(olFt); } } - this.selectInteraction = new ol.interaction.Select({ + this.selectInteraction = new Select({ layers: [this.drawLayer], - features: new ol.Collection(selectedFeature && olFt ? [olFt] : null) + features: new Collection(selectedFeature && olFt ? [olFt] : null) }); if (olFt) { const styleType = this.convertGeometryTypeToStyleType(props.drawMethod); - olFt.setStyle(VectorStyle.getStyle({ ...props, style: {...props.style, type: styleType, highlight: true, useSelectedStyle: props.options.useSelectedStyle }}, false, props.features[0] && props.features[0].properties && props.features[0].properties.valueText && [props.features[0].properties.valueText] || [] )); + olFt.setStyle(getStyle({ ...props, style: {...props.style, type: styleType, highlight: true, useSelectedStyle: props.options.useSelectedStyle }}, false, props.features[0] && props.features[0].properties && props.features[0].properties.valueText && [props.features[0].properties.valueText] || [] )); } this.selectInteraction.on('select', (evt) => { @@ -952,7 +976,6 @@ class DrawSupport extends React.Component { if (this.drawInteraction) { this.props.map.removeInteraction(this.drawInteraction); this.drawInteraction = null; - this.sketchFeature = null; /** Map Singleclick event is dealyed by 250 ms see here * https://openlayers.org/en/latest/apidoc/ol.MapBrowserEvent.html#event:singleclick * This timeout prevents ol map to throw mapClick event that has alredy been managed @@ -994,22 +1017,22 @@ class DrawSupport extends React.Component { }; fromOLFeature = (feature, startingPoint, properties) => { - let geometry = feature.getGeometry(); - let extent = geometry.getExtent(); - let geometryProperties = geometry.getProperties(); + const geometry = feature.getGeometry(); // retrieve geodesic center from properties // it's different from extent center - let center = geometryProperties && geometryProperties.geodesicCenter || ol.extent.getCenter(extent); - let coordinates; - let projection = this.props.map.getView().getProjection().getCode(); - let radius; - let type = geometry.getType(); + const projection = this.props.map.getView().getProjection().getCode(); + const type = geometry.getType(); + // LineString, Polygon, MultiLineString, MultiPolygon if (geometry.getCoordinates) { - coordinates = geometry.getCoordinates(); + const extent = geometry.getExtent(); + const geometryProperties = geometry.getProperties(); + const center = geometryProperties && geometryProperties.geodesicCenter || getCenter(extent); + let coordinates = geometry.getCoordinates(); if (startingPoint) { coordinates = concat(startingPoint, coordinates); geometry.setCoordinates(coordinates); } + let radius; if (this.props.drawMethod === "Circle") { if (this.props.options.geodesic) { const wgs84Coordinates = [[...center], [...coordinates[0][0]]].map((coordinate) => { @@ -1033,13 +1056,14 @@ class DrawSupport extends React.Component { } let geometries = geometry.getGeometries().map((g, i) => { - extent = g.getExtent(); - center = ol.extent.getCenter(extent); - coordinates = g.getCoordinates(); + const extent = g.getExtent(); + const center = getCenter(extent); + let coordinates = g.getCoordinates(); if (startingPoint) { coordinates = concat(startingPoint, coordinates); g.setCoordinates(coordinates); } + let radius; if (properties.circles && properties.circles.indexOf(i) !== -1) { if (this.props.options.geodesic) { const wgs84Coordinates = [[...center], [...coordinates[0][0]]].map((coordinate) => { @@ -1063,13 +1087,12 @@ class DrawSupport extends React.Component { projection: this.getMapCrs() }); }); - type = "GeometryCollection"; return assign({}, { type: "Feature", id: feature.get('id'), style: this.fromOlStyle(feature.getStyle()), geometry: { - type, + type: "GeometryCollection", geometries }, projection @@ -1114,32 +1137,32 @@ class DrawSupport extends React.Component { strokeColor = '#4a90e2'; } strokeColor = this.hexToRgb(strokeColor).concat([style && style.opacity || 1]); - let newStyle = new ol.style.Style({ - fill: new ol.style.Fill({ + let newStyle = new Style({ + fill: new Fill({ color: fillColor }), - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: strokeColor, width: style && (style.strokeWidth || style.weight) ? style.strokeWidth || style.weight : 2 }), - text: new ol.style.Text({ + text: new Text({ text: style && style.text ? style.text : '', - fill: new ol.style.Fill({ color: style && (style.strokeColor || style.color) ? style.strokeColor || style.color : '#000' }), - stroke: new ol.style.Stroke({ color: '#fff', width: 2 }), + fill: new Fill({ color: style && (style.strokeColor || style.color) ? style.strokeColor || style.color : '#000' }), + stroke: new Stroke({ color: '#fff', width: 2 }), font: style && style.fontSize ? style.fontSize + 'px helvetica' : '' }) }); if (type === "GeometryCollection") { - return [...VectorStyle.getMarkerStyleLegacy({ + return [...getMarkerStyleLegacy({ style: { iconGlyph: 'comment', iconShape: 'square', iconColor: 'blue' } }), newStyle]; } if (style && (style.iconUrl || style.iconGlyph)) { - return VectorStyle.getMarkerStyleLegacy({ + return getMarkerStyleLegacy({ style }); } @@ -1175,13 +1198,13 @@ class DrawSupport extends React.Component { filter features to be edited */ const editFilter = props && props.options && props.options.editFilter; - this.modifyFeatureColl = new ol.Collection(filter(this.drawLayer.getSource().getFeatures(), editFilter)); + this.modifyFeatureColl = new Collection(filter(this.drawLayer.getSource().getFeatures(), editFilter)); - this.modifyInteraction = new ol.interaction.Modify({ + this.modifyInteraction = new Modify({ features: this.modifyFeatureColl, condition: (e) => { - return ol.events.condition.primaryAction(e) && !ol.events.condition.altKeyOnly(e); + return primaryAction(e) && !altKeyOnly(e); } }); @@ -1216,8 +1239,8 @@ class DrawSupport extends React.Component { if (this.translateInteraction) { this.props.map.removeInteraction(this.translateInteraction); } - this.translateInteraction = new ol.interaction.Translate({ - features: new ol.Collection(this.drawLayer.getSource().getFeatures()) + this.translateInteraction = new Translate({ + features: new Collection(this.drawLayer.getSource().getFeatures()) }); this.translateInteraction.setActive(false); this.translateInteraction.on('translateend', (e) => { @@ -1250,7 +1273,7 @@ class DrawSupport extends React.Component { createOLGeometry = ({type, coordinates, radius, center, geometries, projection, options = {}}) => { if (type === "GeometryCollection") { - return geometries && geometries.length ? new ol.geom.GeometryCollection(geometries.map(g => this.olGeomFromType({type: g.type}))) : new ol.geom.GeometryCollection([]); + return geometries && geometries.length ? new GeometryCollection(geometries.map(g => this.olGeomFromType({type: g.type}))) : new GeometryCollection([]); } return this.olGeomFromType({type, coordinates, radius, center, projection, options}); }; @@ -1259,11 +1282,11 @@ class DrawSupport extends React.Component { let geometry; switch (type) { - case "Point": case "Marker": case "Text": { geometry = new ol.geom.Point(coordinates ? coordinates : []); break; } - case "LineString": { geometry = new ol.geom.LineString(coordinates ? coordinates : []); break; } - case "MultiPoint": /*case "Text":*/ { geometry = new ol.geom.MultiPoint(coordinates ? coordinates : []); break; } // TODO move text on "Point" - case "MultiLineString": { geometry = new ol.geom.MultiLineString(coordinates ? coordinates : []); break; } - case "MultiPolygon": { geometry = new ol.geom.MultiPolygon(coordinates ? coordinates : []); break; } + case "Point": case "Marker": case "Text": { geometry = new Point(coordinates ? coordinates : []); break; } + case "LineString": { geometry = new LineString(coordinates ? coordinates : []); break; } + case "MultiPoint": /*case "Text":*/ { geometry = new MultiPoint(coordinates ? coordinates : []); break; } // TODO move text on "Point" + case "MultiLineString": { geometry = new MultiLineString(coordinates ? [coordinates] : []); break; } + case "MultiPolygon": { geometry = new MultiPolygon(coordinates ? coordinates : []); break; } // default is Polygon default: { let correctCenter = isArray(center) ? {x: center[0], y: center[1]} : center; @@ -1278,9 +1301,9 @@ class DrawSupport extends React.Component { // TODO simplify, too much use of elvis operator geometry = isCircle ? options.geodesic ? - ol.geom.Polygon.circular(wgs84Sphere, this.reprojectCoordinatesToWGS84([correctCenter.x, correctCenter.y], projection), radius, 100).clone().transform('EPSG:4326', projection) - : ol.geom.Polygon.fromCircle(new ol.geom.Circle([correctCenter.x, correctCenter.y], radius), 100) - : new ol.geom.Polygon(coordinates && isArray(coordinates[0]) ? coordinates : []); + circular(this.reprojectCoordinatesToWGS84([correctCenter.x, correctCenter.y], projection), radius, 100).clone().transform('EPSG:4326', projection) + : fromCircle(new Circle([correctCenter.x, correctCenter.y], radius), 100) + : new Polygon(coordinates && isArray(coordinates[0]) ? coordinates : []); // store geodesic center if (geometry && isCircle && options.geodesic) { @@ -1317,10 +1340,10 @@ class DrawSupport extends React.Component { * @param {number[]} center in 3857 [lon, lat] * @param {number} radius in meters * @param {number} npoints number of sides - * @return {ol.geom.Polygon} the polygon which approximate the circle + * @return {Polygon} the polygon which approximate the circle */ polygonFromCircle = (center, radius, npoints = 100) => { - return ol.geom.Polygon.fromCircle(new ol.geom.Circle(center, radius), npoints); + return fromCircle(new Circle(center, radius), npoints); } polygonCoordsFromCircle = (center, radius, npoints = 100) => { @@ -1329,8 +1352,8 @@ class DrawSupport extends React.Component { /** * replace circles with polygons in feature collection - * @param {ol.Feature[]} features to transform - * @return {ol.Feature[]} features transformed + * @param {Feature[]} features to transform + * @return {Feature[]} features transformed */ replaceCirclesWithPolygonsInFeatureColl = (features) => { return features.map(f => { @@ -1342,8 +1365,8 @@ class DrawSupport extends React.Component { } /** * tranform circle to polygon - * @param {ol.Feature} feature to check if needs to be transformed - * @return {ol.Feature} feature transformed in polygon + * @param {Feature} feature to check if needs to be transformed + * @return {Feature} feature transformed in polygon */ replaceCircleWithPolygon = (feature) => { if (feature.getProperties().isCircle && feature.getGeometry().getType() === "Circle") { @@ -1356,7 +1379,7 @@ class DrawSupport extends React.Component { } /** * replace circles with polygons - * @param {ol.Feature} feature must contain a geometry collection + * @param {Feature} feature must contain a geometry collection * @return {ol.geom.SimpleGeometry[]} geometries */ replaceCirclesWithPolygons = (feature) => { @@ -1378,7 +1401,7 @@ class DrawSupport extends React.Component { } /** * replace polygons with circles - * @param {ol.Feature} feature must contain a geometry collection and property "circles" + * @param {Feature} feature must contain a geometry collection and property "circles" * @return {ol.geom.SimpleGeometry[]} geometries */ replacePolygonsWithCircles = (feature) => { @@ -1389,9 +1412,9 @@ class DrawSupport extends React.Component { } if (feature.getProperties() && feature.getProperties().circles && feature.getProperties().circles.indexOf(i) !== -1) { const extent = g.getExtent(); - const center = ol.extent.getCenter(extent); + const center = getCenter(extent); const radius = this.calculateRadius(center, g.getCoordinates()); - return new ol.geom.Circle(center, radius); + return new Circle(center, radius); } return g; }); @@ -1411,4 +1434,4 @@ class DrawSupport extends React.Component { }); } } -module.exports = DrawSupport; + diff --git a/web/client/components/map/openlayers/Feature.jsx b/web/client/components/map/openlayers/Feature.jsx index c7566df699..d198588679 100644 --- a/web/client/components/map/openlayers/Feature.jsx +++ b/web/client/components/map/openlayers/Feature.jsx @@ -5,17 +5,20 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const PropTypes = require('prop-types'); -var ol = require('openlayers'); -const axios = require('axios'); -const { isEqual, find, castArray } = require('lodash'); -const { parseStyles } = require('./VectorStyle'); -const { transformPolygonToCircle } = require('../../../utils/DrawSupportUtils'); -const { createStylesAsync } = require('../../../utils/VectorStyleUtils'); +import React from 'react'; +import PropTypes from 'prop-types'; +import axios from 'axios'; +import isEqual from 'lodash/isEqual'; +import find from 'lodash/find'; +import castArray from 'lodash/castArray'; -class Feature extends React.Component { +import { parseStyles } from './VectorStyle'; +import { transformPolygonToCircle } from '../../../utils/openlayers/DrawSupportUtils'; +import { createStylesAsync } from '../../../utils/VectorStyleUtils'; +import GeoJSON from 'ol/format/GeoJSON'; + +export default class Feature extends React.Component { static propTypes = { type: PropTypes.string, layerStyle: PropTypes.object, @@ -59,7 +62,7 @@ class Feature extends React.Component { } addFeatures = (props) => { - const format = new ol.format.GeoJSON(); + const format = new GeoJSON(); let ftGeometry = null; let canRender = false; @@ -137,4 +140,3 @@ class Feature extends React.Component { }; } -module.exports = Feature; diff --git a/web/client/components/map/openlayers/HighlightFeatureSupport.jsx b/web/client/components/map/openlayers/HighlightFeatureSupport.jsx index ef770d36db..60cbfa6b6f 100644 --- a/web/client/components/map/openlayers/HighlightFeatureSupport.jsx +++ b/web/client/components/map/openlayers/HighlightFeatureSupport.jsx @@ -1,4 +1,3 @@ -const PropTypes = require('prop-types'); /** * Copyright 2016, GeoSolutions Sas. * All rights reserved. @@ -7,10 +6,14 @@ const PropTypes = require('prop-types'); * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const ol = require('openlayers'); +import PropTypes from 'prop-types'; +import React from 'react'; +import Select from 'ol/interaction/Select'; +import {platformModifierKeyOnly} from 'ol/events/condition'; +import {Style, Stroke, Fill} from 'ol/style'; +import CircleStyle from 'ol/style/Circle'; -class HighlightFeatureSupport extends React.Component { +export default class HighlightFeatureSupport extends React.Component { static propTypes = { map: PropTypes.object, layer: PropTypes.string.isRequired, @@ -112,10 +115,10 @@ class HighlightFeatureSupport extends React.Component { createSelectInteraction = () => { this.createStyle(); - this._selectInteraction = new ol.interaction.Select({ + this._selectInteraction = new Select({ layers: this.layersFilter, style: this._style, - toggleCondition: ol.events.condition.platformModifierKeyOnly + toggleCondition: platformModifierKeyOnly }); this._selectInteraction.on('select', this.selectionChange, this); this.props.map.addInteraction(this._selectInteraction); @@ -143,20 +146,20 @@ class HighlightFeatureSupport extends React.Component { createStyle = () => { let sty = this.props.selectedStyle; let style = { - stroke: new ol.style.Stroke( sty.stroke ? sty.stroke : { + stroke: new Stroke( sty.stroke ? sty.stroke : { color: 'blue', width: 1 }), - fill: new ol.style.Fill(sty.fill ? sty.fill : { + fill: new Fill(sty.fill ? sty.fill : { color: 'blue' }) }; if (sty.type === "Point") { style = { - image: new ol.style.Circle({...style, radius: sty.radius || 5}) + image: new CircleStyle({...style, radius: sty.radius || 5}) }; } - this._style = new ol.style.Style(style); + this._style = new Style(style); }; highlightFeatures = (features) => { @@ -174,4 +177,3 @@ class HighlightFeatureSupport extends React.Component { }; } -module.exports = HighlightFeatureSupport; diff --git a/web/client/components/map/openlayers/Layer.jsx b/web/client/components/map/openlayers/Layer.jsx index 758ed03601..bf8ca1e49a 100644 --- a/web/client/components/map/openlayers/Layer.jsx +++ b/web/client/components/map/openlayers/Layer.jsx @@ -1,4 +1,3 @@ -const PropTypes = require('prop-types'); /** * Copyright 2015, GeoSolutions Sas. * All rights reserved. @@ -6,14 +5,19 @@ const PropTypes = require('prop-types'); * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var React = require('react'); -var Layers = require('../../../utils/openlayers/Layers'); -var CoordinatesUtils = require('../../../utils/CoordinatesUtils'); -var assign = require('object-assign'); -const _ = require('lodash'); -const Rx = require('rxjs'); -class OpenlayersLayer extends React.Component { +import PropTypes from 'prop-types'; +import React from 'react'; +import Layers from '../../../utils/openlayers/Layers'; +import CoordinatesUtils from '../../../utils/CoordinatesUtils'; +import assign from 'object-assign'; +import Rx from 'rxjs'; +import isNumber from 'lodash/isNumber'; +import isArray from 'lodash/isArray'; +import omit from 'lodash/omit'; +import isEqual from 'lodash/isEqual'; + +export default class OpenlayersLayer extends React.Component { static propTypes = { onWarning: PropTypes.func, maxExtent: PropTypes.array, @@ -114,7 +118,7 @@ class OpenlayersLayer extends React.Component { }; generateOpts = (options, position, srs, securityToken) => { - return assign({}, options, _.isNumber(position) ? {zIndex: position} : null, { + return assign({}, options, isNumber(position) ? {zIndex: position} : null, { srs, onError: () => { this.props.onCreationError(options); @@ -134,7 +138,7 @@ class OpenlayersLayer extends React.Component { const layerExtent = options && options.bbox && options.bbox.bounds; const mapBboxPolygon = mapExtent && CoordinatesUtils.reprojectBbox(mapExtent, this.props.srs, 'EPSG:4326'); let layerBboxPolygon = layerExtent && CoordinatesUtils.getExtentFromNormalized(layerExtent, this.props.srs).extent; - if (layerBboxPolygon && layerBboxPolygon.length === 2 && _.isArray(layerBboxPolygon[1])) { + if (layerBboxPolygon && layerBboxPolygon.length === 2 && isArray(layerBboxPolygon[1])) { layerBboxPolygon = layerBboxPolygon[1]; } @@ -166,7 +170,7 @@ class OpenlayersLayer extends React.Component { if (newProps.position === oldProps.position && newProps.srs === oldProps.srs && newProps.securityToken === oldProps.securityToken ) { // check if options are the same, except loading if (newProps.options === oldProps.options) return; - if (_.isEqual( _.omit(newProps.options, ["loading"]), _.omit(oldProps.options, ["loading"]) ) ) { + if (isEqual( omit(newProps.options, ["loading"]), omit(oldProps.options, ["loading"]) ) ) { return; } } @@ -292,5 +296,3 @@ class OpenlayersLayer extends React.Component { return valid; }; } - -module.exports = OpenlayersLayer; diff --git a/web/client/components/map/openlayers/LegacyVectorStyle.js b/web/client/components/map/openlayers/LegacyVectorStyle.js index 203e2e5942..326cf6a443 100644 --- a/web/client/components/map/openlayers/LegacyVectorStyle.js +++ b/web/client/components/map/openlayers/LegacyVectorStyle.js @@ -1,22 +1,27 @@ -var markerIcon = require('./img/marker-icon.png'); -var markerShadow = require('./img/marker-shadow.png'); -var ol = require('openlayers'); -const {last, head} = require('lodash'); +import markerIcon from './img/marker-icon.png'; +import markerShadow from './img/marker-shadow.png'; + +import last from 'lodash/last'; +import head from 'lodash/head'; +import trim from 'lodash/trim'; +import isString from 'lodash/isString'; +import isArray from 'lodash/isArray'; + +import assign from 'object-assign'; + +import {colorToRgbaStr} from '../../../utils/ColorUtils'; +import {set} from '../../../utils/ImmutableUtils'; + +import {Circle, Stroke, Fill, Text, Style, Icon} from 'ol/style'; +import {Point} from 'ol/geom'; +import Icons from '../../../utils/openlayers/Icons'; + const blue = [0, 153, 255, 1]; -const assign = require('object-assign'); -const {trim, isString, isArray} = require('lodash'); -const {colorToRgbaStr} = require('../../../utils/ColorUtils'); -const {set} = require('../../../utils/ImmutableUtils'); -const selectedStyleConfiguration = { - white: [255, 255, 255, 1], - blue: [0, 153, 255, 1], - width: 3 -}; -const image = new ol.style.Circle({ +const image = new Circle({ radius: 5, fill: null, - stroke: new ol.style.Stroke({color: 'red', width: 1}) + stroke: new Stroke({color: 'red', width: 1}) }); /** @@ -25,12 +30,12 @@ const image = new ol.style.Circle({ * @param {number} options.radius radius of the circle * @param {string} options.fillColor ol color for the circle fill style * @param {boolean} options.applyToPolygon tells if this style can be applied to a polygon - * @return {ol.style.Style} style of the point + * @return {Style} style of the point */ -const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPolygon = false} = {}) => new ol.style.Style({ - image: new ol.style.Circle({ +export const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPolygon = false} = {}) => new Style({ + image: new Circle({ radius, - fill: new ol.style.Fill({ + fill: new Fill({ color: fillColor }) }), @@ -41,7 +46,7 @@ const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPoly return null; } let coordinates = type === "Polygon" ? geom.getCoordinates()[0] : geom.getCoordinates(); - return coordinates.length > 1 ? new ol.geom.Point(head(coordinates)) : null; + return coordinates.length > 1 ? new Point(head(coordinates)) : null; } }); @@ -51,12 +56,12 @@ const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPoly * @param {number} options.radius radius of the circle * @param {string} options.fillColor ol color for the circle fill style * @param {boolean} options.applyToPolygon tells if this style can be applied to a polygon - * @return {ol.style.Style} style of the point + * @return {Style} style of the point */ -const lastPointOfPolylineStyle = ({radius = 5, fillColor = 'red', applyToPolygon = false} = {}) => new ol.style.Style({ - image: new ol.style.Circle({ +export const lastPointOfPolylineStyle = ({radius = 5, fillColor = 'red', applyToPolygon = false} = {}) => new Style({ + image: new Circle({ radius, - fill: new ol.style.Fill({ + fill: new Fill({ color: fillColor }) }), @@ -67,40 +72,40 @@ const lastPointOfPolylineStyle = ({radius = 5, fillColor = 'red', applyToPolygon return null; } let coordinates = type === "Polygon" ? geom.getCoordinates()[0] : geom.getCoordinates(); - return new ol.geom.Point(coordinates.length > 3 ? coordinates[coordinates.length - (type === "Polygon" ? 2 : 1)] : last(coordinates)); + return new Point(coordinates.length > 3 ? coordinates[coordinates.length - (type === "Polygon" ? 2 : 1)] : last(coordinates)); } }); /** creates styles to highlight/customize start and end point of a polyline */ -const startEndPolylineStyle = (startPointOptions = {}, endPointOptions = {}) => { +export const startEndPolylineStyle = (startPointOptions = {}, endPointOptions = {}) => { return [firstPointOfPolylineStyle(startPointOptions), lastPointOfPolylineStyle(endPointOptions)]; }; const getTextStyle = (tempStyle, valueText, highlight = false) => { - return new ol.style.Style({ - text: new ol.style.Text({ + return new Style({ + text: new Text({ offsetY: -( 4 * Math.sqrt(tempStyle.fontSize)), // TODO improve this for high font values > 100px textAlign: tempStyle.textAlign || "center", text: valueText || "", font: tempStyle.font, - fill: new ol.style.Fill({ + fill: new Fill({ // WRONG, SETTING A FILL STYLE WITH A COLOR (STROKE) ATTRIBUTE color: colorToRgbaStr(tempStyle.stroke || tempStyle.color || '#000000', tempStyle.opacity || 1) }), // halo - stroke: highlight ? new ol.style.Stroke({ + stroke: highlight ? new Stroke({ color: [255, 255, 255, 1], width: 2 }) : null }), image: highlight ? - new ol.style.Circle({ + new Circle({ radius: 5, fill: null, - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: colorToRgbaStr(tempStyle.color || "#0000FF", tempStyle.opacity || 1), width: tempStyle.weight || 1 }) @@ -108,7 +113,6 @@ const getTextStyle = (tempStyle, valueText, highlight = false) => { }); }; -const Icons = require('../../../utils/openlayers/Icons'); const STYLE_POINT = { color: '#ffcc33', @@ -162,7 +166,7 @@ const STYLE_MARKER = { iconGlyph: "comment" }; -const defaultStyles = { +export const defaultStyles = { "Marker": STYLE_MARKER, "Text": STYLE_TEXT, "Circle": STYLE_CIRCLE, @@ -175,7 +179,7 @@ const defaultStyles = { }; const strokeStyle = (options, defaultsStyle = {color: 'blue', width: 3, lineDash: [6]}) => ({ - stroke: new ol.style.Stroke( + stroke: new Stroke( options.style ? options.style.stroke || { color: options.style.color || defaultsStyle.color, @@ -191,7 +195,7 @@ const strokeStyle = (options, defaultsStyle = {color: 'blue', width: 3, lineDash }); const fillStyle = (options, defaultsStyle = {color: 'rgba(0, 0, 255, 0.1)'}) => ({ - fill: new ol.style.Fill( + fill: new Fill( options.style ? options.style.fill || { color: colorToRgbaStr(options.style.fillColor, options.style.fillOpacity) || defaultsStyle.color @@ -202,76 +206,76 @@ const fillStyle = (options, defaultsStyle = {color: 'rgba(0, 0, 255, 0.1)'}) => }); const defaultOLStyles = { - 'Point': () => [new ol.style.Style({ + 'Point': () => [new Style({ image: image })], - 'LineString': options => [new ol.style.Style(assign({}, + 'LineString': options => [new Style(assign({}, strokeStyle(options, {color: 'blue', width: 3}) ))], - 'MultiLineString': options => [new ol.style.Style(assign({}, + 'MultiLineString': options => [new Style(assign({}, strokeStyle(options, {color: 'blue', width: 3}) ))], - 'MultiPoint': () => [new ol.style.Style({ + 'MultiPoint': () => [new Style({ image: image })], - 'MultiPolygon': options => [new ol.style.Style(assign({}, + 'MultiPolygon': options => [new Style(assign({}, strokeStyle(options), fillStyle(options) ))], - 'Polygon': options => [new ol.style.Style(assign({}, + 'Polygon': options => [new Style(assign({}, strokeStyle(options), fillStyle(options) ))], - 'GeometryCollection': options => [new ol.style.Style(assign({}, + 'GeometryCollection': options => [new Style(assign({}, strokeStyle(options), fillStyle(options), - {image: new ol.style.Circle({ + {image: new Circle({ radius: 10, fill: null, - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: 'magenta' }) }) }))], - 'Circle': () => [new ol.style.Style({ - stroke: new ol.style.Stroke({ + 'Circle': () => [new Style({ + stroke: new Stroke({ color: 'red', width: 2 }), - fill: new ol.style.Fill({ + fill: new Fill({ color: 'rgba(255,0,0,0.2)' }) })], - 'marker': (options) => [new ol.style.Style({ - image: new ol.style.Icon({ + 'marker': (options) => [new Style({ + image: new Icon({ anchor: [14, 41], anchorXUnits: 'pixels', anchorYUnits: 'pixels', src: markerShadow }) -}), new ol.style.Style({ - image: new ol.style.Icon({ +}), new Style({ + image: new Icon({ anchor: [0.5, 1], anchorXUnits: 'fraction', anchorYUnits: 'fraction', src: markerIcon }), - text: new ol.style.Text({ + text: new Text({ text: options.label, scale: 1.25, offsetY: 8, - fill: new ol.style.Fill({color: '#000000'}), - stroke: new ol.style.Stroke({color: '#FFFFFF', width: 2}) + fill: new Fill({color: '#000000'}), + stroke: new Stroke({color: '#FFFFFF', width: 2}) }) })] }; -const styleFunction = function(feature, options) { +export const styleFunction = function(feature, options) { const type = feature.getGeometry().getType(); return defaultOLStyles[type](options && options.style && options.style[type] && {style: {...options.style[type]}} || options || {}); }; -function getMarkerStyle(options) { +export function getMarkerStyle(options) { if (options.style.iconUrl) { return Icons.standard.getIcon(options); } @@ -291,21 +295,21 @@ const getValidStyle = (geomType, options = { style: defaultStyles}, isDrawing, t let tempStyle = options.style[geomType] || options.style; if (geomType === "MultiLineString" || geomType === "LineString") { let styles = [ - new ol.style.Style({ - stroke: options.style.useSelectedStyle ? new ol.style.Stroke({ + new Style({ + stroke: options.style.useSelectedStyle ? new Stroke({ color: [255, 255, 255, 1], width: tempStyle.weight + 2 }) : null }), - new ol.style.Style(tempStyle ? { - stroke: new ol.style.Stroke( tempStyle && tempStyle.stroke ? tempStyle.stroke : { + new Style(tempStyle ? { + stroke: new Stroke( tempStyle && tempStyle.stroke ? tempStyle.stroke : { color: colorToRgbaStr(options.style && tempStyle.color || "#0000FF", tempStyle.opacity || 1), lineDash: options.style.highlight ? [10] : [0], width: tempStyle.weight || 1 }), image: isDrawing ? image : null } : { - stroke: new ol.style.Stroke(defaultStyles[geomType] && defaultStyles[geomType].stroke ? defaultStyles[geomType].stroke : { + stroke: new Stroke(defaultStyles[geomType] && defaultStyles[geomType].stroke ? defaultStyles[geomType].stroke : { color: colorToRgbaStr(options.style && defaultStyles[geomType].color || "#0000FF", defaultStyles[geomType].opacity || 1), lineDash: options.style.highlight ? [10] : [0], width: defaultStyles[geomType].weight || 1 @@ -317,32 +321,32 @@ const getValidStyle = (geomType, options = { style: defaultStyles}, isDrawing, t } if ((geomType === "MultiPoint" || geomType === "Point") && (tempStyle.iconUrl || tempStyle.iconGlyph) ) { - return isDrawing ? new ol.style.Style({ + return isDrawing ? new Style({ image: image }) : getMarkerStyle({style: {...tempStyle, highlight: options.style.highlight || options.style.useSelectedStyle}}); } if (geomType === "Circle" && radius ) { let styles = [ - new ol.style.Style({ - stroke: options.style.useSelectedStyle ? new ol.style.Stroke({ + new Style({ + stroke: options.style.useSelectedStyle ? new Stroke({ color: [255, 255, 255, 1], width: tempStyle.weight + 4 }) : null }), - new ol.style.Style({ - stroke: new ol.style.Stroke( tempStyle && tempStyle.stroke ? tempStyle.stroke : { + new Style({ + stroke: new Stroke( tempStyle && tempStyle.stroke ? tempStyle.stroke : { color: options.style.useSelectedStyle ? blue : colorToRgbaStr(options.style && tempStyle.color || "#0000FF", tempStyle.opacity || 1), lineDash: options.style.highlight ? [10] : [0], width: tempStyle.weight || 1 }), - fill: new ol.style.Fill(tempStyle.fill ? tempStyle.fill : { + fill: new Fill(tempStyle.fill ? tempStyle.fill : { color: colorToRgbaStr(options.style && tempStyle.fillColor || "#0000FF", tempStyle.fillOpacity || 0.2) }) - }), new ol.style.Style({ - image: options.style.useSelectedStyle ? new ol.style.Circle({ + }), new Style({ + image: options.style.useSelectedStyle ? new Circle({ radius: 3, - fill: new ol.style.Fill(tempStyle.fill ? tempStyle.fill : { + fill: new Fill(tempStyle.fill ? tempStyle.fill : { color: blue }) }) : null, @@ -351,7 +355,7 @@ const getValidStyle = (geomType, options = { style: defaultStyles}, isDrawing, t const type = geom.getType(); if (type === "Circle") { let coordinates = geom.getCenter(); - return new ol.geom.Point(coordinates); + return new Point(coordinates); } return null; } @@ -363,20 +367,20 @@ const getValidStyle = (geomType, options = { style: defaultStyles}, isDrawing, t } if (geomType === "MultiPolygon" || geomType === "Polygon") { let styles = [ - new ol.style.Style({ - stroke: options.style.useSelectedStyle ? new ol.style.Stroke({ + new Style({ + stroke: options.style.useSelectedStyle ? new Stroke({ color: [255, 255, 255, 1], width: tempStyle.weight + 2 }) : null }), - new ol.style.Style({ - stroke: new ol.style.Stroke( tempStyle.stroke ? tempStyle.stroke : { + new Style({ + stroke: new Stroke( tempStyle.stroke ? tempStyle.stroke : { color: options.style.useSelectedStyle ? blue : colorToRgbaStr(options.style && tempStyle.color || "#0000FF", tempStyle.opacity || 1), lineDash: options.style.highlight ? [10] : [0], width: tempStyle.weight || 1 }), image: isDrawing ? image : null, - fill: new ol.style.Fill(tempStyle.fill ? tempStyle.fill : { + fill: new Fill(tempStyle.fill ? tempStyle.fill : { color: colorToRgbaStr(options.style && tempStyle.fillColor || "#0000FF", tempStyle.fillOpacity || 1) }) }) @@ -387,7 +391,7 @@ const getValidStyle = (geomType, options = { style: defaultStyles}, isDrawing, t return fallbackStyle; }; -function getStyle(options, isDrawing = false, textValues = []) { +export function getStyle(options, isDrawing = false, textValues = []) { // this is causing max call stack size exceeded because it contains ol functions and it comes from the store // we suggest to remove this behaviour @@ -425,19 +429,19 @@ function getStyle(options, isDrawing = false, textValues = []) { } if (!style && options.style) { style = { - stroke: new ol.style.Stroke( options.style.stroke ? options.style.stroke : { + stroke: new Stroke( options.style.stroke ? options.style.stroke : { color: colorToRgbaStr(options.style && options.style.color || "#0000FF", options.style.opacity || 1), lineDash: options.style.highlight ? [10] : [0], width: options.style.weight || 1 }), - fill: new ol.style.Fill(options.style.fill ? options.style.fill : { + fill: new Fill(options.style.fill ? options.style.fill : { color: colorToRgbaStr(options.style && options.style.fillColor || "#0000FF", options.style.fillOpacity || 1) }) }; if (geomType === "Point") { style = { - image: new ol.style.Circle(assign({}, style, {radius: options.style.radius || 5})) + image: new Circle(assign({}, style, {radius: options.style.radius || 5})) }; } if (options.style.iconUrl || options.style.iconGlyph) { @@ -456,7 +460,7 @@ function getStyle(options, isDrawing = false, textValues = []) { }; return style; } - style = new ol.style.Style(style); + style = new Style(style); /* managing new style structure @@ -503,7 +507,7 @@ function getStyle(options, isDrawing = false, textValues = []) { } if (type === "Point" || type === "MultiPoint") { markerStyles = getMarkerStyle({style: {...options.style[type], highlight: options.style.highlight}}); - return isDrawing ? new ol.style.Style({ + return isDrawing ? new Style({ image: image, geometry: feature.getGeometry() }) : markerStyles.map(m => { @@ -538,14 +542,3 @@ function getStyle(options, isDrawing = false, textValues = []) { } : style || styleFunction; } - -module.exports = { - startEndPolylineStyle, - lastPointOfPolylineStyle, - firstPointOfPolylineStyle, - selectedStyleConfiguration, - getStyle, - getMarkerStyle, - styleFunction, - defaultStyles -}; diff --git a/web/client/components/map/openlayers/Locate.jsx b/web/client/components/map/openlayers/Locate.jsx index 9d79110e9e..093756cfa4 100644 --- a/web/client/components/map/openlayers/Locate.jsx +++ b/web/client/components/map/openlayers/Locate.jsx @@ -1,6 +1,6 @@ -const PropTypes = require('prop-types'); -const React = require('react'); -const OlLocate = require('../../../utils/openlayers/OlLocate'); +import PropTypes from 'prop-types'; +import React from 'react'; +import OlLocate from '../../../utils/openlayers/OlLocate'; const defaultOpt = { follow: true, // follow with zoom and pan the user's location @@ -16,7 +16,7 @@ const defaultOpt = { } }; -class Locate extends React.Component { +export default class Locate extends React.Component { static displayName = 'Locate'; static propTypes = { @@ -80,4 +80,3 @@ class Locate extends React.Component { }; } -module.exports = Locate; diff --git a/web/client/components/map/openlayers/Map.jsx b/web/client/components/map/openlayers/Map.jsx index bf14a92dcc..04f078729d 100644 --- a/web/client/components/map/openlayers/Map.jsx +++ b/web/client/components/map/openlayers/Map.jsx @@ -5,20 +5,39 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const ol = require('openlayers'); -const proj4 = require('proj4').default; -const PropTypes = require('prop-types'); -const React = require('react'); -const assign = require('object-assign'); -const CoordinatesUtils = require('../../../utils/CoordinatesUtils'); -const ConfigUtils = require('../../../utils/ConfigUtils'); -const mapUtils = require('../../../utils/MapUtils'); -const projUtils = require('../../../utils/openlayers/projUtils'); +import { defaults, DragPan, MouseWheelZoom } from 'ol/interaction'; +import { defaults as defaultControls } from 'ol/control'; +import Map from 'ol/Map'; +import View from 'ol/View'; +import { toLonLat } from 'ol/proj'; +import Zoom from 'ol/control/Zoom'; +import Units from 'ol/proj/Units'; -const { isEqual, throttle, isArray, isNil } = require('lodash'); +import { getWidth, getHeight } from 'ol/extent'; -class OpenlayersMap extends React.Component { +import proj4 from 'proj4'; +import { register } from 'ol/proj/proj4.js'; +import PropTypes from 'prop-types'; +import React from 'react'; +import assign from 'object-assign'; + +import CoordinatesUtils from '../../../utils/CoordinatesUtils'; +import ConfigUtils from '../../../utils/ConfigUtils'; +import mapUtils from '../../../utils/MapUtils'; +import projUtils from '../../../utils/openlayers/projUtils'; + +import isEqual from 'lodash/isEqual'; +import throttle from 'lodash/throttle'; +import isArray from 'lodash/isArray'; +import isNil from 'lodash/isNil'; + +import 'ol/ol.css'; + +// add overrides for css +import './mapstore-ol-overrides.css'; + +export default class OpenlayersMap extends React.Component { static propTypes = { id: PropTypes.string, style: PropTypes.object, @@ -67,12 +86,12 @@ class OpenlayersMap extends React.Component { componentDidMount() { this.props.projectionDefs.forEach(p => { - projUtils.addProjections(ol, p.code, p.extent, p.worldExtent, p.axisOrientation || proj4.defs(p.code).axis || 'enu'); + projUtils.addProjections(p.code, p.extent, p.worldExtent, p.axisOrientation || proj4.defs(p.code).axis || 'enu'); }); // It may be a good idea to check if CoordinateUtils also registered the projectionDefs // normally it happens ad application level. let center = CoordinatesUtils.reproject([this.props.center.x, this.props.center.y], 'EPSG:4326', this.props.projection); - ol.proj.setProj4(proj4); + register(proj4); let interactionsOptions = assign(this.props.interactive ? {} : { doubleClickZoom: false, dragPan: false, @@ -84,21 +103,21 @@ class OpenlayersMap extends React.Component { pinchZoom: false }, this.props.mapOptions.interactions); - let interactions = ol.interaction.defaults(assign({ + let interactions = defaults(assign({ dragPan: false, mouseWheelZoom: false }, interactionsOptions, {})); if (interactionsOptions === undefined || interactionsOptions.dragPan === undefined || interactionsOptions.dragPan) { interactions.extend([ - new ol.interaction.DragPan({ kinetic: false }) + new DragPan({ kinetic: false }) ]); } if (interactionsOptions === undefined || interactionsOptions.mouseWheelZoom === undefined || interactionsOptions.mouseWheelZoom) { interactions.extend([ - new ol.interaction.MouseWheelZoom({ duration: 0 }) + new MouseWheelZoom({ duration: 0 }) ]); } - let controls = ol.control.defaults(assign({ + let controls = defaultControls(assign({ zoom: this.props.zoomControl, attributionOptions: assign({ collapsible: false @@ -106,7 +125,7 @@ class OpenlayersMap extends React.Component { target: document.querySelector(this.props.mapOptions.attribution.container) } : {}) }, this.props.mapOptions.controls)); - let map = new ol.Map({ + let map = new Map({ layers: [], controls: controls, interactions: interactions, @@ -133,7 +152,7 @@ class OpenlayersMap extends React.Component { pos[0] = CoordinatesUtils.normalizeLng(pos[0]); } if (this.props.projection === 'EPSG:900913' || this.props.projection === 'EPSG:3857') { - pos = ol.proj.toLonLat(pos, this.props.projection); + pos = toLonLat(pos, this.props.projection); projectionExtent = CoordinatesUtils.reprojectBbox(projectionExtent, this.props.projection, "EPSG:4326"); } // prevent user from clicking outside the projection extent @@ -160,7 +179,7 @@ class OpenlayersMap extends React.Component { if (!this.markerPresent && geom.getType() === "Point") { this.markerPresent = true; layerInfo = layer.get('msId'); - const arr = ol.proj.toLonLat(geom.getFirstCoordinate(), this.props.projection); + const arr = toLonLat(geom.getFirstCoordinate(), this.props.projection); coords = { x: arr[0], y: arr[1] }; } } @@ -207,9 +226,9 @@ class OpenlayersMap extends React.Component { if (newProps.zoomControl !== this.props.zoomControl) { if (newProps.zoomControl) { - this.map.addControl(new ol.control.Zoom()); + this.map.addControl(new Zoom()); } else { - this.map.removeControl(this.map.getControls().getArray().filter((ctl) => ctl instanceof ol.control.Zoom)[0]); + this.map.removeControl(this.map.getControls().getArray().filter((ctl) => ctl instanceof Zoom)[0]); } } @@ -287,12 +306,12 @@ class OpenlayersMap extends React.Component { const projection = this.map.getView().getProjection(); const extent = projection.getExtent(); - const extentWidth = !extent ? 360 * ol.proj.METERS_PER_UNIT[ol.proj.Units.DEGREES] / - ol.proj.METERS_PER_UNIT[projection.getUnits()] : - ol.extent.getWidth(extent); - const extentHeight = !extent ? 360 * ol.proj.METERS_PER_UNIT[ol.proj.Units.DEGREES] / - ol.proj.METERS_PER_UNIT[projection.getUnits()] : - ol.extent.getHeight(extent); + const extentWidth = !extent ? 360 * Units.METERS_PER_UNIT[Units.DEGREES] / + Units.METERS_PER_UNIT[projection.getUnits()] : + getWidth(extent); + const extentHeight = !extent ? 360 * Units.METERS_PER_UNIT[Units.DEGREES] / + Units.METERS_PER_UNIT[projection.getUnits()] : + getHeight(extent); let resX = extentWidth / tileWidth; let resY = extentHeight / tileHeight; @@ -388,7 +407,7 @@ class OpenlayersMap extends React.Component { mouseMoveEvent = (event) => { if (!event.dragging && event.coordinate) { let pos = event.coordinate.slice(); - let coords = ol.proj.toLonLat(pos, this.props.projection); + let coords = toLonLat(pos, this.props.projection); let tLng = coords[0] / 360 % 1 * 360; if (tLng < -180) { tLng = tLng + 360; @@ -415,11 +434,11 @@ class OpenlayersMap extends React.Component { const crs = view.getProjection().getCode(); // some projections are repeated on the x axis // and they need to be updated also if the center is outside of the projection extent - const wrappedProjections = [ 'EPSG:3857', 'EPSG:900913', 'EPSG:4326' ]; + const wrappedProjections = ['EPSG:3857', 'EPSG:900913', 'EPSG:4326']; // prevent user from dragging outside the projection extent if (wrappedProjections.indexOf(crs) !== -1 - || (tempCenter && tempCenter[0] >= projectionExtent[0] && tempCenter[0] <= projectionExtent[2] && - tempCenter[1] >= projectionExtent[1] && tempCenter[1] <= projectionExtent[3])) { + || (tempCenter && tempCenter[0] >= projectionExtent[0] && tempCenter[0] <= projectionExtent[2] && + tempCenter[1] >= projectionExtent[1] && tempCenter[1] <= projectionExtent[3])) { let c = this.normalizeCenter(view.getCenter()); let bbox = view.calculateExtent(this.map.getSize()); let size = { @@ -459,7 +478,7 @@ class OpenlayersMap extends React.Component { zoom: zoom, minZoom: limits.minZoom }, newOptions || {}); - return new ol.View(viewOptions); + return new View(viewOptions); }; _updateMapPositionFromNewProps = (newProps) => { @@ -542,7 +561,3 @@ class OpenlayersMap extends React.Component { }); }; } - -// add overrides for css -require('./mapstore-ol-overrides.css'); -module.exports = OpenlayersMap; diff --git a/web/client/components/map/openlayers/MeasurementSupport.jsx b/web/client/components/map/openlayers/MeasurementSupport.jsx index 90386da0a8..29ab7d5fd1 100644 --- a/web/client/components/map/openlayers/MeasurementSupport.jsx +++ b/web/client/components/map/openlayers/MeasurementSupport.jsx @@ -6,25 +6,39 @@ * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const PropTypes = require('prop-types'); -const {round, isEqual, dropRight, pick} = require('lodash'); -const assign = require('object-assign'); -const ol = require('openlayers'); - -const wgs84Sphere = new ol.Sphere(6378137); -const {reprojectGeoJson, reproject, calculateAzimuth, calculateDistance, transformLineToArcs} = require('../../../utils/CoordinatesUtils'); -const {convertUom, getFormattedBearingValue} = require('../../../utils/MeasureUtils'); -const {set} = require('../../../utils/ImmutableUtils'); -const {startEndPolylineStyle} = require('./VectorStyle'); -const {getMessageById} = require('../../../utils/LocaleUtils'); -const {createOLGeometry} = require('../../../utils/openlayers/DrawUtils'); +import React from 'react'; +import PropTypes from 'prop-types'; +import round from 'lodash/round'; +import isEqual from 'lodash/isEqual'; +import dropRight from 'lodash/dropRight'; +import pick from 'lodash/pick'; + +import assign from 'object-assign'; + +import {reprojectGeoJson, reproject, calculateAzimuth, calculateDistance, transformLineToArcs} from '../../../utils/CoordinatesUtils'; +import {convertUom, getFormattedBearingValue} from '../../../utils/MeasureUtils'; +import {set} from '../../../utils/ImmutableUtils'; +import {startEndPolylineStyle} from './VectorStyle'; +import {getMessageById} from '../../../utils/LocaleUtils'; +import {createOLGeometry} from '../../../utils/openlayers/DrawUtils'; + +import {Polygon, LineString} from 'ol/geom'; +import Overlay from 'ol/Overlay'; +import VectorSource from 'ol/source/Vector'; +import VectorLayer from 'ol/layer/Vector'; +import Feature from 'ol/Feature'; +import {Stroke, Fill, Style} from 'ol/style'; +import CircleStyle from 'ol/style/Circle'; +import Draw from 'ol/interaction/Draw'; +import GeoJSON from 'ol/format/GeoJSON'; +import {unByKey} from 'ol/Observable'; +import {getArea} from 'ol/sphere'; const getProjectionCode = (olMap) => { return olMap.getView().getProjection().getCode(); }; -class MeasurementSupport extends React.Component { +export default class MeasurementSupport extends React.Component { static propTypes = { startEndPoint: PropTypes.object, map: PropTypes.object, @@ -112,15 +126,15 @@ class MeasurementSupport extends React.Component { let geom = this.source.getFeatures()[0].getGeometry(); let output; - if (geom instanceof ol.geom.Polygon) { + if (geom instanceof Polygon) { output = this.formatArea(geom, props); this.tooltipCoord = geom.getInteriorPoint().getCoordinates(); - } else if (geom instanceof ol.geom.LineString) { + } else if (geom instanceof LineString) { output = this.formatLength(geom, props); this.tooltipCoord = geom.getLastCoordinate(); } this.measureTooltipElement.innerHTML = output; - this.measureTooltip = new ol.Overlay({ + this.measureTooltip = new Overlay({ element: this.measureTooltipElement, offset: [0, -7], positioning: 'bottom-center' @@ -144,10 +158,10 @@ class MeasurementSupport extends React.Component { let ft = set("geometry.coordinates", newCoords, features[0]); featuresToReplace = [ft]; } - this.source = new ol.source.Vector(); + this.source = new VectorSource(); featuresToReplace.forEach((geoJSON) => { let geometry = reprojectGeoJson(geoJSON, "EPSG:4326", getProjectionCode(this.props.map)).geometry; - const feature = new ol.Feature({ + const feature = new Feature({ geometry: createOLGeometry(geometry) }); this.source.addFeature(feature); @@ -168,19 +182,19 @@ class MeasurementSupport extends React.Component { this.removeDrawInteraction(); } // create a layer to draw on - this.source = new ol.source.Vector(); + this.source = new VectorSource(); let styles = [ - new ol.style.Style({ - fill: new ol.style.Fill({ + new Style({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }), - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: '#ffcc33', width: 2 }), - image: new ol.style.Circle({ + image: new CircleStyle({ radius: 7, - fill: new ol.style.Fill({ + fill: new Fill({ color: '#ffcc33' }) }) @@ -193,7 +207,7 @@ class MeasurementSupport extends React.Component { startEndPointStyles = startEndPolylineStyle(options.startPointOptions, options.endPointOptions); } - vector = new ol.layer.Vector({ + vector = new VectorLayer({ source: this.source, zIndex: 1000000, style: [...styles, ...startEndPointStyles] @@ -207,38 +221,38 @@ class MeasurementSupport extends React.Component { geometryType = newProps.measurement.geomType; } // create an interaction to draw with - draw = new ol.interaction.Draw({ + draw = new Draw({ source: this.source, type: /** @type {ol.geom.GeometryType} */ geometryType, - style: new ol.style.Style({ - fill: new ol.style.Fill({ + style: new Style({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }), - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: 'rgba(0, 0, 0, 0.5)', lineDash: [10, 10], width: 2 }), - image: new ol.style.Circle({ + image: new CircleStyle({ radius: 5, - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: 'rgba(0, 0, 0, 0.7)' }), - fill: new ol.style.Fill({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }) }) }) }); - this.clickListener = this.props.map.on('click', () => this.updateMeasurementResults(this.props), this); + this.clickListener = this.props.map.on('click', () => this.updateMeasurementResults(this.props)); if (this.props.updateOnMouseMove) { - this.props.map.on('pointermove', () => this.updateMeasurementResults(this.props), this); + this.props.map.on('pointermove', () => this.updateMeasurementResults(this.props)); } - this.props.map.on('pointermove', this.pointerMoveHandler, this); + this.props.map.on('pointermove', (evt) => this.pointerMoveHandler(evt)); - draw.on('drawstart', function(evt) { + draw.on('drawstart', (evt) => { // preserve the sketch feature of the draw controller // to update length/area on drawing a new vertex this.sketchFeature = evt.feature; @@ -256,10 +270,10 @@ class MeasurementSupport extends React.Component { this.listener = this.sketchFeature.getGeometry().on('change', (e) => { let geom = e.target; let output; - if (geom instanceof ol.geom.Polygon) { + if (geom instanceof Polygon) { output = this.formatArea(geom, this.props); this.tooltipCoord = geom.getInteriorPoint().getCoordinates(); - } else if (geom instanceof ol.geom.LineString) { + } else if (geom instanceof LineString) { output = this.formatLength(geom, this.props); this.tooltipCoord = geom.getLastCoordinate(); } @@ -267,12 +281,12 @@ class MeasurementSupport extends React.Component { this.measureTooltipElement.innerHTML = output; this.measureTooltip.setPosition(this.tooltipCoord); } - }, this); + }); this.props.resetGeometry(); - }, this); - draw.on('drawend', function(evt) { + }); + draw.on('drawend', (evt) => { this.drawing = false; - const geojsonFormat = new ol.format.GeoJSON(); + const geojsonFormat = new GeoJSON(); let newFeature = reprojectGeoJson(geojsonFormat.writeFeatureObject(evt.feature.clone()), getProjectionCode(this.props.map), "EPSG:4326"); this.props.changeGeometry(newFeature); if (this.props.measurement.lineMeasureEnabled) { @@ -284,9 +298,9 @@ class MeasurementSupport extends React.Component { if (this.props.measurement.showLabel) { this.measureTooltipElement.className = 'tooltip tooltip-static'; this.measureTooltip.setOffset([0, -7]); - ol.Observable.unByKey(this.listener); + unByKey(this.listener); } - }, this); + }); this.props.map.addInteraction(draw); if (this.props.measurement.showLabel) { @@ -307,7 +321,7 @@ class MeasurementSupport extends React.Component { this.props.map.removeLayer(this.measureLayer); this.sketchFeature = null; this.props.map.un('click', () => this.updateMeasurementResults(this.props), this); - ol.Observable.unByKey(this.clickListener); + unByKey(this.clickListener); if (this.props.updateOnMouseMove) { this.props.map.un('pointermove', () => this.updateMeasurementResults(this.props), this); } @@ -327,9 +341,9 @@ class MeasurementSupport extends React.Component { if (this.sketchFeature && this.drawing) { let geom = (this.sketchFeature.getGeometry()); - if (geom instanceof ol.geom.Polygon) { + if (geom instanceof Polygon) { helpMsg = this.continuePolygonMsg; - } else if (geom instanceof ol.geom.LineString) { + } else if (geom instanceof LineString) { helpMsg = this.continueLineMsg; } } @@ -369,7 +383,7 @@ class MeasurementSupport extends React.Component { this.drawInteraction.finishDrawing(); } } - const geojsonFormat = new ol.format.GeoJSON(); + const geojsonFormat = new GeoJSON(); let feature = reprojectGeoJson(geojsonFormat.writeFeatureObject(this.sketchFeature.clone()), getProjectionCode(props.map), "EPSG:4326"); // it will no longer create 100 points for arcs to put in the state @@ -404,8 +418,8 @@ class MeasurementSupport extends React.Component { calculateGeodesicArea = (coordinates) => { if (coordinates.length >= 4 ) { - let reprojectedCoordinatesIn4326 = this.reprojectedCoordinatesIn4326(coordinates); - return Math.abs(wgs84Sphere.geodesicArea(reprojectedCoordinatesIn4326)); + const reprojectedCoordinatesIn4326 = this.reprojectedCoordinatesIn4326(coordinates); + return Math.abs(getArea(new Polygon([reprojectedCoordinatesIn4326]), { projection: 'EPSG:4326' })); } return 0; }; @@ -417,7 +431,7 @@ class MeasurementSupport extends React.Component { this.removeHelpTooltip(); this.helpTooltipElement = document.createElement('div'); this.helpTooltipElement.className = 'tooltip hidden'; - this.helpTooltip = new ol.Overlay({ + this.helpTooltip = new Overlay({ element: this.helpTooltipElement, offset: [15, 0], positioning: 'center-left' @@ -431,7 +445,7 @@ class MeasurementSupport extends React.Component { this.removeMeasureTooltips(); this.measureTooltipElement = document.createElement('div'); this.measureTooltipElement.className = 'tooltip tooltip-measure'; - this.measureTooltip = new ol.Overlay({ + this.measureTooltip = new Overlay({ element: this.measureTooltipElement, offset: [0, -15], positioning: 'bottom-center' @@ -488,5 +502,3 @@ class MeasurementSupport extends React.Component { } } } - -module.exports = MeasurementSupport; diff --git a/web/client/components/map/openlayers/Overview.jsx b/web/client/components/map/openlayers/Overview.jsx index 6557ae6374..204b0cbb87 100644 --- a/web/client/components/map/openlayers/Overview.jsx +++ b/web/client/components/map/openlayers/Overview.jsx @@ -5,12 +5,13 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const PropTypes = require('prop-types'); -const React = require('react'); -const ol = require('openlayers'); -const Layers = require('../../../utils/openlayers/Layers'); -const assign = require('object-assign'); -const {isFinite} = require('lodash'); +import PropTypes from 'prop-types'; +import React from 'react'; +import Layers from '../../../utils/openlayers/Layers'; +import assign from 'object-assign'; +import isFinite from 'lodash/isFinite'; + +import OverviewMap from 'ol/control/OverviewMap'; require('./overview.css'); @@ -22,7 +23,7 @@ const defaultOpt = { collapsible: true }; -class Overview extends React.Component { +export default class Overview extends React.Component { static displayName = 'Overview'; static propTypes = { @@ -44,7 +45,7 @@ class Overview extends React.Component { olLayers.push(Layers.createLayer(layerOpt.type, layerOpt.options || {})); }); let opt = assign({}, defaultOpt, this.props.overviewOpt, {layers: olLayers}); - this.overview = new ol.control.OverviewMap(opt); + this.overview = new OverviewMap(opt); if (this.props.map) { this.overview.setMap(this.props.map); } @@ -130,5 +131,3 @@ class Overview extends React.Component { this.props.map.getView().fit(extent, mapSize, {nearest: true}); }; } - -module.exports = Overview; diff --git a/web/client/components/map/openlayers/ScaleBar.jsx b/web/client/components/map/openlayers/ScaleBar.jsx index 966ce35219..cfb5d14806 100644 --- a/web/client/components/map/openlayers/ScaleBar.jsx +++ b/web/client/components/map/openlayers/ScaleBar.jsx @@ -6,13 +6,12 @@ * LICENSE file in the root directory of this source tree. */ -const PropTypes = require('prop-types'); -const React = require('react'); -const ol = require('openlayers'); +import PropTypes from 'prop-types'; +import React from 'react'; +import assign from 'object-assign'; +import ScaleLine from 'ol/control/ScaleLine'; -const assign = require('object-assign'); - -class ScaleBar extends React.Component { +export default class ScaleBar extends React.Component { static propTypes = { map: PropTypes.object, className: PropTypes.string, @@ -29,7 +28,7 @@ class ScaleBar extends React.Component { }; componentDidMount() { - this.scalebar = new ol.control.ScaleLine(assign({}, this.props, this.props.container ? { + this.scalebar = new ScaleLine(assign({}, this.props, this.props.container ? { target: document.querySelector(this.props.container) } : {})); if (this.props.map) { @@ -48,4 +47,3 @@ class ScaleBar extends React.Component { } } -module.exports = ScaleBar; diff --git a/web/client/components/map/openlayers/SelectionSupport.jsx b/web/client/components/map/openlayers/SelectionSupport.jsx index 00938e4d3b..fe192287df 100644 --- a/web/client/components/map/openlayers/SelectionSupport.jsx +++ b/web/client/components/map/openlayers/SelectionSupport.jsx @@ -1,4 +1,3 @@ -const PropTypes = require('prop-types'); /** * Copyright 2017, Sourcepole AG. * All rights reserved. @@ -7,10 +6,16 @@ const PropTypes = require('prop-types'); * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -var ol = require('openlayers'); +import PropTypes from 'prop-types'; +import React from 'react'; +import VectorSource from 'ol/source/Vector'; +import VectorLayer from 'ol/layer/Vector'; +import {Style, Fill, Stroke} from 'ol/style'; +import CircleStyle from 'ol/style/Circle'; +import Draw from 'ol/interaction/Draw'; +import DoubleClickZoom from 'ol/interaction/DoubleClickZoom'; -class SelectionSupport extends React.Component { +export default class SelectionSupport extends React.Component { static propTypes = { map: PropTypes.object, projection: PropTypes.string, @@ -42,21 +47,21 @@ class SelectionSupport extends React.Component { this.removeDrawInteraction(); } // create a layer to draw on - let source = new ol.source.Vector(); - let vector = new ol.layer.Vector({ + let source = new VectorSource(); + let vector = new VectorLayer({ source: source, zIndex: 1000000, - style: new ol.style.Style({ - fill: new ol.style.Fill({ + style: new Style({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }), - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: '#ffcc33', width: 2 }), - image: new ol.style.Circle({ + image: new CircleStyle({ radius: 7, - fill: new ol.style.Fill({ + fill: new Fill({ color: '#ffcc33' }) }) @@ -66,40 +71,40 @@ class SelectionSupport extends React.Component { this.props.map.addLayer(vector); // create an interaction to draw with - let draw = new ol.interaction.Draw({ + let draw = new Draw({ source: source, type: /** @type {ol.geom.GeometryType} */ newProps.selection.geomType, - style: new ol.style.Style({ - fill: new ol.style.Fill({ + style: new Style({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }), - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: 'rgba(0, 0, 0, 0.5)', lineDash: [10, 10], width: 2 }), - image: new ol.style.Circle({ + image: new CircleStyle({ radius: 5, - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: 'rgba(0, 0, 0, 0.7)' }), - fill: new ol.style.Fill({ + fill: new Fill({ color: 'rgba(255, 255, 255, 0.2)' }) }) }) }); - draw.on('drawstart', function(evt) { + draw.on('drawstart', (evt) => { // preserv the sketch feature of the draw controller // to update length/area on drawing a new vertex this.sketchFeature = evt.feature; // clear previous sketches source.clear(); - }, this); - draw.on('drawend', function() { + }); + draw.on('drawend', () => { this.updateSelectionState(); - }, this); + }); this.props.map.addInteraction(draw); this.drawInteraction = draw; @@ -140,12 +145,10 @@ class SelectionSupport extends React.Component { let interactions = this.props.map.getInteractions(); for (let i = 0; i < interactions.getLength(); i++) { let interaction = interactions.item(i); - if (interaction instanceof ol.interaction.DoubleClickZoom) { + if (interaction instanceof DoubleClickZoom) { interaction.setActive(enabled); break; } } }; } - -module.exports = SelectionSupport; diff --git a/web/client/components/map/openlayers/SnapshotSupport.jsx b/web/client/components/map/openlayers/SnapshotSupport.jsx index 7da719c5d3..4f38cdded1 100644 --- a/web/client/components/map/openlayers/SnapshotSupport.jsx +++ b/web/client/components/map/openlayers/SnapshotSupport.jsx @@ -6,7 +6,10 @@ * LICENSE file in the root directory of this source tree. */ -module.exports = { - GrabMap: require('./snapshot/GrabMap.jsx'), - Preview: require('./snapshot/Preview.jsx') +import GrabMap from './snapshot/GrabMap.jsx'; +import Preview from './snapshot/Preview.jsx'; + +export default { + GrabMap, + Preview }; diff --git a/web/client/components/map/openlayers/VectorStyle.js b/web/client/components/map/openlayers/VectorStyle.js index 261c7e8610..70158b1ad8 100644 --- a/web/client/components/map/openlayers/VectorStyle.js +++ b/web/client/components/map/openlayers/VectorStyle.js @@ -5,15 +5,40 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const ol = require('openlayers'); -const {isNil, trim, isString, isArray, castArray, head, last, find, isObject} = require('lodash'); -const {colorToRgbaStr} = require('../../../utils/ColorUtils'); -const {reproject, transformLineToArcs} = require('../../../utils/CoordinatesUtils'); -const Icons = require('../../../utils/openlayers/Icons'); -const { +import isNil from 'lodash/isNil'; +import trim from 'lodash/trim'; +import isString from 'lodash/isString'; +import isArray from 'lodash/isArray'; +import castArray from 'lodash/castArray'; +import head from 'lodash/head'; +import last from 'lodash/last'; +import find from 'lodash/find'; +import isObject from 'lodash/isObject'; + +import {colorToRgbaStr} from '../../../utils/ColorUtils'; +import {reproject, transformLineToArcs} from '../../../utils/CoordinatesUtils'; +import Icons from '../../../utils/openlayers/Icons'; +import { isMarkerStyle, isTextStyle, isStrokeStyle, isFillStyle, isCircleStyle, isSymbolStyle, registerGeometryFunctions, geometryFunctions -} = require('../../../utils/VectorStyleUtils'); +} from '../../../utils/VectorStyleUtils'; + +import CircleStyle from 'ol/style/Circle'; +import {Stroke, Fill, Text, Style} from 'ol/style'; +import {Point, LineString} from 'ol/geom'; + +import {Promise} from 'es6-promise'; +import axios from '../../../libs/ajax'; + +import { getStyleParser } from '../../../utils/VectorStyleUtils'; +import OlStyleParser from 'geostyler-openlayers-parser'; + +const olStyleParser = new OlStyleParser(); + +import { + getStyle as getStyleLegacy, getMarkerStyle as getMarkerStyleLegacyFun, + startEndPolylineStyle as startEndPolylineStyleLegacy, defaultStyles as defaultStylesLegacy} from './LegacyVectorStyle'; + const selectedStyle = { white: [255, 255, 255, 1], blue: [0, 153, 255, 1], @@ -26,8 +51,8 @@ const selectedStyle = { * @param {object} ol.Fill object * @return if a circle style is passed then return it available for ol.style.Image */ -const getCircleStyle = (style = {}, stroke = null, fill = null) => { - return isCircleStyle(style) ? new ol.style.Circle({ +export const getCircleStyle = (style = {}, stroke = null, fill = null) => { + return isCircleStyle(style) ? new CircleStyle({ stroke, fill, radius: style.radius || 5 @@ -39,7 +64,7 @@ const getCircleStyle = (style = {}, stroke = null, fill = null) => { * @param {object} style to convert * @return array of ol.Style */ -const getMarkerStyle = (style) => { +export const getMarkerStyle = (style) => { if (isMarkerStyle(style)) { if (style.iconUrl) { return Icons.standard.getIcon({style}); @@ -54,10 +79,10 @@ const getMarkerStyle = (style) => { /** * converts a style object * @param {object} style to convert - * @return an ol.style.Stroke style + * @return an Stroke style */ -const getStrokeStyle = (style = {}) => { - return isStrokeStyle(style) ? new ol.style.Stroke(style.stroke && isObject(style.stroke) ? style.stroke : { // not sure about this ternary expr +export const getStrokeStyle = (style = {}) => { + return isStrokeStyle(style) ? new Stroke(style.stroke && isObject(style.stroke) ? style.stroke : { // not sure about this ternary expr color: style.highlight ? selectedStyle.blue : colorToRgbaStr(style.color || style.stroke || "#0000FF", isNil(style.opacity) ? 1 : style.opacity), width: isNil(style.weight) ? 1 : style.weight, lineDash: isString(style.dashArray) && trim(style.dashArray).split(' ') || isArray(style.dashArray) && style.dashArray || [0], @@ -70,10 +95,10 @@ const getStrokeStyle = (style = {}) => { /** * converts a style object * @param {object} style to convert - * @return an ol.style.Fill style + * @return an Fill style */ -const getFillStyle = (style = {}) => { - return isFillStyle(style) ? new ol.style.Fill(style.fill && isObject(style.fill) ? style.fill : { // not sure about this ternary expr +export const getFillStyle = (style = {}) => { + return isFillStyle(style) ? new Fill(style.fill && isObject(style.fill) ? style.fill : { // not sure about this ternary expr color: colorToRgbaStr(style.fillColor || "#0000FF", isNil(style.fillOpacity) ? 1 : style.fillOpacity) }) : null; }; @@ -81,28 +106,28 @@ const getFillStyle = (style = {}) => { /** * converts a style object * @param {object} style to convert - * @param {object} stroke ol.style.Stroke ready to use - * @param {object} fill ol.style.Fill ready to use - * @return an ol.style.Text style + * @param {object} stroke Stroke ready to use + * @param {object} fill Fill ready to use + * @return an Text style */ -const getTextStyle = (style = {}, stroke = null, fill = null, feature) => { - return isTextStyle(style) ? new ol.style.Text({ +export const getTextStyle = (style = {}, stroke = null, fill = null, feature) => { + return isTextStyle(style) ? new Text({ fill, offsetY: style.offsetY || -( 4 * Math.sqrt(style.fontSize)), // TODO improve this for high font values > 100px textAlign: style.textAlign || "center", text: style.label || feature && feature.properties && feature.properties.valueText || "New", font: style.font || "Arial", // halo - stroke: style.highlight ? new ol.style.Stroke({ + stroke: style.highlight ? new Stroke({ color: [255, 255, 255, 1], width: 2 }) : stroke, // this should be another rule for the small circle image: style.highlight ? - new ol.style.Circle({ + new CircleStyle({ radius: 5, fill: null, - stroke: new ol.style.Stroke({ + stroke: new Stroke({ color: colorToRgbaStr(style.color || "#0000FF", style.opacity || 1), width: style.weight || 1 }) @@ -117,12 +142,12 @@ const getTextStyle = (style = {}, stroke = null, fill = null, feature) => { * @param {number} options.radius radius of the circle * @param {string} options.fillColor ol color for the circle fill style * @param {boolean} options.applyToPolygon tells if this style can be applied to a polygon - * @return {ol.style.Style} style of the point + * @return {Style} style of the point */ -const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPolygon = false} = {}) => new ol.style.Style({ - image: new ol.style.Circle({ +export const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPolygon = false} = {}) => new Style({ + image: new CircleStyle({ radius, - fill: new ol.style.Fill({ + fill: new Fill({ color: fillColor }) }), @@ -133,7 +158,7 @@ const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPoly return null; } let coordinates = type === "Polygon" ? geom.getCoordinates()[0] : geom.getCoordinates(); - return coordinates.length > 1 ? new ol.geom.Point(head(coordinates)) : null; + return coordinates.length > 1 ? new Point(head(coordinates)) : null; } }); @@ -143,12 +168,12 @@ const firstPointOfPolylineStyle = ({radius = 5, fillColor = 'green', applyToPoly * @param {number} options.radius radius of the circle * @param {string} options.fillColor ol color for the circle fill style * @param {boolean} options.applyToPolygon tells if this style can be applied to a polygon - * @return {ol.style.Style} style of the point + * @return {Style} style of the point */ -const lastPointOfPolylineStyle = ({radius = 5, fillColor = 'red', applyToPolygon = false} = {}) => new ol.style.Style({ - image: new ol.style.Circle({ +export const lastPointOfPolylineStyle = ({radius = 5, fillColor = 'red', applyToPolygon = false} = {}) => new Style({ + image: new CircleStyle({ radius, - fill: new ol.style.Fill({ + fill: new Fill({ color: fillColor }) }), @@ -159,14 +184,14 @@ const lastPointOfPolylineStyle = ({radius = 5, fillColor = 'red', applyToPolygon return null; } let coordinates = type === "Polygon" ? geom.getCoordinates()[0] : geom.getCoordinates(); - return new ol.geom.Point(coordinates.length > 3 ? coordinates[coordinates.length - (type === "Polygon" ? 2 : 1)] : last(coordinates)); + return new Point(coordinates.length > 3 ? coordinates[coordinates.length - (type === "Polygon" ? 2 : 1)] : last(coordinates)); } }); /** creates styles to highlight/customize start and end point of a polyline */ -const addDefaultStartEndPoints = (styles = [], startPointOptions = {radius: 3, fillColor: "green", applyToPolygon: true}, endPointOptions = {radius: 3, fillColor: "red", applyToPolygon: true}) => { +export const addDefaultStartEndPoints = (styles = [], startPointOptions = {radius: 3, fillColor: "green", applyToPolygon: true}, endPointOptions = {radius: 3, fillColor: "red", applyToPolygon: true}) => { let points = []; if (!find(styles, s => s.geometry === "startPoint" && s.filtering)) { points.push(firstPointOfPolylineStyle({...startPointOptions})); @@ -177,13 +202,13 @@ const addDefaultStartEndPoints = (styles = [], startPointOptions = {radius: 3, f return points; }; -const centerPoint = (feature) => { +export const centerPoint = (feature) => { const geometry = feature.getGeometry(); const extent = geometry.getExtent(); let center = geometry.getCenter && geometry.getCenter() || [extent[2] - extent[0], extent[3] - extent[1]]; - return new ol.geom.Point(center); + return new Point(center); }; -const lineToArc = (feature) => { +export const lineToArc = (feature) => { const type = feature.getGeometry().getType(); if (type === "LineString" || type === "MultiPoint") { let coordinates = feature.getGeometry().getCoordinates(); @@ -191,25 +216,25 @@ const lineToArc = (feature) => { const point = reproject(c, "EPSG:3857", "EPSG:4326"); return [point.x, point .y]; })); - return new ol.geom.LineString(coordinates.map(c => { + return new LineString(coordinates.map(c => { const point = reproject(c, "EPSG:4326", "EPSG:3857"); return [point.x, point .y]; })); } return feature.getGeometry(); }; -const startPoint = (feature) => { +export const startPoint = (feature) => { const geom = feature.getGeometry(); const type = geom.getType(); let coordinates = type === "Polygon" ? geom.getCoordinates()[0] : geom.getCoordinates(); - return coordinates.length > 1 ? new ol.geom.Point(head(coordinates)) : null; + return coordinates.length > 1 ? new Point(head(coordinates)) : null; }; -const endPoint = (feature) => { +export const endPoint = (feature) => { const geom = feature.getGeometry(); const type = geom.getType(); let coordinates = type === "Polygon" ? geom.getCoordinates()[0] : geom.getCoordinates(); - return new ol.geom.Point(coordinates.length > 3 ? coordinates[coordinates.length - (type === "Polygon" ? 2 : 1)] : last(coordinates)); + return new Point(coordinates.length > 3 ? coordinates[coordinates.length - (type === "Polygon" ? 2 : 1)] : last(coordinates)); }; registerGeometryFunctions("centerPoint", centerPoint, "Point"); @@ -220,7 +245,7 @@ registerGeometryFunctions("endPoint", endPoint, "Point"); /** if a geom expression is present then return the corresponding function */ -const getGeometryTrasformation = (style = {}) => { +export const getGeometryTrasformation = (style = {}) => { return style.geometry ? // then parse the geom_expression and return true or false (feature) => { @@ -229,14 +254,14 @@ const getGeometryTrasformation = (style = {}) => { } : (f) => f.getGeometry(); }; -const getFilter = (style = {}) => { +export const getFilter = (style = {}) => { return !isNil(style.filtering) ? // then parse the filter_expression and return true or false style.filtering : true; // if no filter is defined, it returns true }; -const parseStyleToOl = (feature = {properties: {}}, style = {}, tempStyles = []) => { +export const parseStyleToOl = (feature = {properties: {}}, style = {}, tempStyles = []) => { const filtering = getFilter(style, feature); if (filtering) { const stroke = getStrokeStyle(style); @@ -259,7 +284,7 @@ const parseStyleToOl = (feature = {properties: {}}, style = {}, tempStyles = []) const zIndex = style.zIndex; // if filter is defined and true (default value) - const finalStyle = new ol.style.Style({ + const finalStyle = new Style({ geometry: getGeometryTrasformation(style), image, text, @@ -269,12 +294,12 @@ const parseStyleToOl = (feature = {properties: {}}, style = {}, tempStyles = []) }); return [finalStyle].concat(feature && feature.properties && feature.properties.canEdit && !feature.properties.isCircle ? addDefaultStartEndPoints(tempStyles) : []); } - return new ol.style.Style({}); + return new Style({}); // if not do not return anything }; -const parseStyles = (feature = {properties: {}}) => { +export const parseStyles = (feature = {properties: {}}) => { let styles = feature.style; if (styles) { let tempStyles = isArray(styles) ? styles : castArray(styles); @@ -285,24 +310,23 @@ const parseStyles = (feature = {properties: {}}) => { return []; }; -/* importing legacy functions, do not use them if possible */ -module.exports = { - getStyle: require('./LegacyVectorStyle').getStyle, - getMarkerStyleLegacy: require('./LegacyVectorStyle').getMarkerStyle, - startEndPolylineStyle: require('./LegacyVectorStyle').startEndPolylineStyle, - defaultStyles: require('./LegacyVectorStyle').defaultStyles, - getCircleStyle, - getMarkerStyle, - getStrokeStyle, - getFillStyle, - getTextStyle, - firstPointOfPolylineStyle, - lastPointOfPolylineStyle, - centerPoint, - startPoint, - endPoint, - getGeometryTrasformation, - getFilter, - parseStyleToOl, - parseStyles + +export const getStyle = (options, isDrawing = false, textValues = []) => { + if (options.style && options.style.url) { + return axios.get(options.style.url).then(response => { + return getStyleParser(options.style.format).readStyle(response.data) + .then(style => olStyleParser.writeStyle(style)); + }); + } + const style = getStyleLegacy(options, isDrawing, textValues); + if (options.asPromise) { + return new Promise((resolve) => { + resolve(style); + }); + } + return style; }; + +export const getMarkerStyleLegacy = getMarkerStyleLegacyFun; +export const startEndPolylineStyle = startEndPolylineStyleLegacy; +export const defaultStyles = defaultStylesLegacy; diff --git a/web/client/components/map/openlayers/__tests__/DrawSupport-test.jsx b/web/client/components/map/openlayers/__tests__/DrawSupport-test.jsx index 15a414c3b1..e554eea8cc 100644 --- a/web/client/components/map/openlayers/__tests__/DrawSupport-test.jsx +++ b/web/client/components/map/openlayers/__tests__/DrawSupport-test.jsx @@ -5,23 +5,26 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const ReactDOM = require('react-dom'); -const expect = require('expect'); -const ol = require('openlayers'); -const assign = require('object-assign'); -const DrawSupport = require('../DrawSupport'); -const {DEFAULT_ANNOTATIONS_STYLES} = require('../../../../utils/AnnotationsUtils'); -const {circle, geomCollFeature} = require('../../../../test-resources/drawsupport/features'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; +import assign from 'object-assign'; +import DrawSupport from '../DrawSupport'; +import {DEFAULT_ANNOTATIONS_STYLES} from '../../../../utils/AnnotationsUtils'; +import {circle, geomCollFeature} from '../../../../test-resources/drawsupport/features'; + +import {Map, View, Feature} from 'ol'; +import {Point, Circle, Polygon, LineString, MultiLineString} from 'ol/geom'; +import Collection from 'ol/Collection'; const viewOptions = { projection: 'EPSG:3857', center: [0, 0], zoom: 5 }; -let olMap = new ol.Map({ +let olMap = new Map({ target: "map", - view: new ol.View(viewOptions) + view: new View(viewOptions) }); olMap.disableEventListener = () => {}; @@ -77,9 +80,9 @@ describe('Test DrawSupport', () => { afterEach((done) => { document.body.innerHTML = ''; - olMap = new ol.Map({ + olMap = new Map({ target: "map", - view: new ol.View(viewOptions) + view: new View(viewOptions) }); olMap.disableEventListener = () => {}; @@ -226,8 +229,8 @@ describe('Test DrawSupport', () => { , document.getElementById("container")); - const feature = new ol.Feature({ - geometry: new ol.geom.Point(13.0, 43.0), + const feature = new Feature({ + geometry: new Point(13.0, 43.0), name: 'My Point' }); support.selectInteraction.dispatchEvent({ @@ -256,8 +259,8 @@ describe('Test DrawSupport', () => { ReactDOM.render( , document.getElementById("container")); - const feature = new ol.Feature({ - geometry: new ol.geom.Point(13.0, 43.0), + const feature = new Feature({ + geometry: new Point(13.0, 43.0), name: 'My Point' }); support.translateInteraction.dispatchEvent({ @@ -372,8 +375,8 @@ describe('Test DrawSupport', () => { }) }) }; - const feature = new ol.Feature({ - geometry: new ol.geom.Point(13.0, 43.0), + const feature = new Feature({ + geometry: new Point(13.0, 43.0), name: 'My Point' }); const spyEnd = expect.spyOn(testHandlers, "onEndDrawing"); @@ -410,8 +413,8 @@ describe('Test DrawSupport', () => { }) }) }; - const feature = new ol.Feature({ - geometry: new ol.geom.Circle([13.0, 43.0], 100), + const feature = new Feature({ + geometry: new Circle([13.0, 43.0], 100), name: 'My Point' }); const spyEnd = expect.spyOn(testHandlers, "onEndDrawing"); @@ -451,8 +454,8 @@ describe('Test DrawSupport', () => { }) }) }; - const feature = new ol.Feature({ - geometry: new ol.geom.Point(13.0, 43.0), + const feature = new Feature({ + geometry: new Point(13.0, 43.0), name: 'My Point' }); const spyEnd = expect.spyOn(testHandlers, "onEndDrawing"); @@ -1151,8 +1154,8 @@ describe('Test DrawSupport', () => { 'name': "some name" } }; - const feature = new ol.Feature({ - geometry: new ol.geom.Point(13.0, 43.0), + const feature = new Feature({ + geometry: new Point(13.0, 43.0), name: 'My Point' }); const spyEnd = expect.spyOn(testHandlers, "onEndDrawing"); @@ -1205,8 +1208,8 @@ describe('Test DrawSupport', () => { 'name': "some name" } }; - const feature = new ol.Feature({ - geometry: new ol.geom.Point(13.0, 43.0), + const feature = new Feature({ + geometry: new Point(13.0, 43.0), name: 'My Point' }); const spyEnd = expect.spyOn(testHandlers, "onEndDrawing"); @@ -1346,8 +1349,8 @@ describe('Test DrawSupport', () => { }) }; - const simplifiedCircle = new ol.Feature({ - geometry: new ol.geom.Polygon([[ + const simplifiedCircle = new Feature({ + geometry: new Polygon([[ [1260844.6064174946, 5858067.29727681], [1260960.7874218025, 5857951.114737838], [1260844.6064174946, 5857834.9352681665], @@ -1739,8 +1742,8 @@ describe('Test DrawSupport', () => { const radius = 1000; support.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.Circle(center, radius) + feature: new Feature({ + geometry: new Circle(center, radius) }) }); const drawOwner = null; @@ -1782,8 +1785,8 @@ describe('Test DrawSupport', () => { const coordinate = [1300, 4300]; support.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.Point(coordinate) + feature: new Feature({ + geometry: new Point(coordinate) }) }); const drawOwner = null; @@ -1824,8 +1827,8 @@ describe('Test DrawSupport', () => { expect(support).toExist(); support.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.Polygon([[[1300, 4300], [8, 9], [8, 59]]]) + feature: new Feature({ + geometry: new Polygon([[[1300, 4300], [8, 9], [8, 59]]]) }) }); const drawOwner = null; @@ -1865,8 +1868,8 @@ describe('Test DrawSupport', () => { expect(support).toExist(); support.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.LineString([[1300, 4300], [8, 9], [8, 59]]) + feature: new Feature({ + geometry: new LineString([[1300, 4300], [8, 9], [8, 59]]) }) }); const drawOwner = null; @@ -1905,8 +1908,8 @@ describe('Test DrawSupport', () => { const radius = 1000; support.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.Circle(center, radius) + feature: new Feature({ + geometry: new Circle(center, radius) }) }); expect(spyOnGeometryChanged).toHaveBeenCalled(); @@ -1941,8 +1944,8 @@ describe('Test DrawSupport', () => { expect(support).toExist(); support.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.MultiLineString([[[1300, 4300], [8, 9], [8, 59]]]) + feature: new Feature({ + geometry: new MultiLineString([[[1300, 4300], [8, 9], [8, 59]]]) }) }); expect(spyOnGeometryChanged).toHaveBeenCalled(); @@ -1976,8 +1979,8 @@ describe('Test DrawSupport', () => { expect(support).toExist(); support.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.Point([1300, 4300]) + feature: new Feature({ + geometry: new Point([1300, 4300]) }) }); expect(spyOnGeometryChanged).toHaveBeenCalled(); @@ -2008,8 +2011,8 @@ describe('Test DrawSupport', () => { } }); expect(support).toExist(); - const feature = new ol.Feature({ - geometry: new ol.geom.Point(13.0, 43.0), + const feature = new Feature({ + geometry: new Point(13.0, 43.0), name: 'My Point' }); support.selectInteraction.dispatchEvent({ @@ -2037,9 +2040,9 @@ describe('Test DrawSupport', () => { const radius = 1000; support.modifyInteraction.dispatchEvent({ type: 'modifyend', - features: new ol.Collection( - [new ol.Feature({ - geometry: new ol.geom.Circle(center, radius) + features: new Collection( + [new Feature({ + geometry: new Circle(center, radius) })] ) }); @@ -2070,9 +2073,9 @@ describe('Test DrawSupport', () => { const radius = 1000; support.modifyInteraction.dispatchEvent({ type: 'modifyend', - features: new ol.Collection( - [new ol.Feature({ - geometry: new ol.geom.Circle(center, radius) + features: new Collection( + [new Feature({ + geometry: new Circle(center, radius) })] ) }); diff --git a/web/client/components/map/openlayers/__tests__/Feature-test.jsx b/web/client/components/map/openlayers/__tests__/Feature-test.jsx index 5781f19edc..7ace89074c 100644 --- a/web/client/components/map/openlayers/__tests__/Feature-test.jsx +++ b/web/client/components/map/openlayers/__tests__/Feature-test.jsx @@ -5,14 +5,17 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const ReactDOM = require('react-dom'); -const ol = require('openlayers'); -const Feature = require('../Feature.jsx'); -const expect = require('expect'); -require('../../../../utils/openlayers/Layers'); -const {DEFAULT_ANNOTATIONS_STYLES} = require('../../../../utils/AnnotationsUtils'); -require('../plugins/VectorLayer'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; +import Feature from '../Feature'; +import '../../../../utils/openlayers/Layers'; +import {DEFAULT_ANNOTATIONS_STYLES} from '../../../../utils/AnnotationsUtils'; +import '../plugins/VectorLayer'; + +import { Map, View } from 'ol'; +import VectorSource from 'ol/source/Vector'; +import VectorLayer from 'ol/layer/Vector'; describe('Test Feature', () => { document.body.innerHTML = '
'; @@ -20,16 +23,16 @@ describe('Test Feature', () => { beforeEach((done) => { document.body.innerHTML = '
'; - map = new ol.Map({ + map = new Map({ layers: [ ], - controls: ol.control.defaults({ - attributionOptions: /** @type {olx.control.AttributionOptions} */ { + /*controls: ol.control.defaults({ + attributionOptions: { collapsible: false } - }), + }),*/ target: 'map', - view: new ol.View({ + view: new View({ center: [0, 0], zoom: 5 }) @@ -73,11 +76,11 @@ describe('Test Feature', () => { ] } }; - const source = new ol.source.Vector({ + const source = new VectorSource({ features: [] }); const msId = "some value"; - let container = new ol.layer.Vector({ + let container = new VectorLayer({ msId, source: source, visible: true, @@ -126,11 +129,11 @@ describe('Test Feature', () => { ] } }; - const source = new ol.source.Vector({ + const source = new VectorSource({ features: [] }); const msId = "some value"; - let container = new ol.layer.Vector({ + let container = new VectorLayer({ msId, source: source, visible: true, @@ -189,11 +192,11 @@ describe('Test Feature', () => { ] } }; - const source = new ol.source.Vector({ + const source = new VectorSource({ features: [] }); const msId = "some value"; - let container = new ol.layer.Vector({ + let container = new VectorLayer({ msId, source: source, visible: true, @@ -290,10 +293,10 @@ describe('Test Feature', () => { ] } }; - const source = new ol.source.Vector({ + const source = new VectorSource({ features: [] }); - let container = new ol.layer.Vector({ + let container = new VectorLayer({ source: source, visible: true, zIndex: 1 @@ -402,11 +405,11 @@ describe('Test Feature', () => { ] } }; - const source = new ol.source.Vector({ + const source = new VectorSource({ features: [] }); const msId = "some value"; - let container = new ol.layer.Vector({ + let container = new VectorLayer({ msId, source: source, visible: true, diff --git a/web/client/components/map/openlayers/__tests__/HighlightFeatureSupport-test.jsx b/web/client/components/map/openlayers/__tests__/HighlightFeatureSupport-test.jsx index f4825543f4..13dcdcfdbb 100644 --- a/web/client/components/map/openlayers/__tests__/HighlightFeatureSupport-test.jsx +++ b/web/client/components/map/openlayers/__tests__/HighlightFeatureSupport-test.jsx @@ -6,11 +6,18 @@ * LICENSE file in the root directory of this source tree. */ -const expect = require('expect'); -const React = require('react'); -const ReactDOM = require('react-dom'); -let ol = require('openlayers'); -const HighlightFeatureSupport = require('../HighlightFeatureSupport'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; + +import HighlightFeatureSupport from '../HighlightFeatureSupport'; + +import GeoJSON from 'ol/format/GeoJSON'; + +import { Map, View } from 'ol'; + +import VectorSource from 'ol/source/Vector'; +import VectorLayer from 'ol/layer/Vector'; let createVectorLayer = function(options) { let features; @@ -19,14 +26,14 @@ let createVectorLayer = function(options) { if (Array.isArray(options.features)) { featureCollection = { "type": "FeatureCollection", features: featureCollection}; } - features = (new ol.format.GeoJSON()).readFeatures(featureCollection); + features = (new GeoJSON()).readFeatures(featureCollection); features.forEach((f) => f.getGeometry().transform('EPSG:4326', options.crs || 'EPSG:3857')); } - const source = new ol.source.Vector({ + const source = new VectorSource({ features: features }); - return new ol.layer.Vector({ + return new VectorLayer({ msId: options.id, source: source, zIndex: options.zIndex @@ -72,9 +79,9 @@ describe('HighlightFeatureSupport Ol', () => { center: [0, 0], zoom: 5 }; - var map = new ol.Map({ + var map = new Map({ target: "map", - view: new ol.View(viewOptions) + view: new View(viewOptions) }); let vector = createVectorLayer(layer); map.addLayer(vector); diff --git a/web/client/components/map/openlayers/__tests__/Layer-test.jsx b/web/client/components/map/openlayers/__tests__/Layer-test.jsx index 1d8ee8d04d..c39ea21ea5 100644 --- a/web/client/components/map/openlayers/__tests__/Layer-test.jsx +++ b/web/client/components/map/openlayers/__tests__/Layer-test.jsx @@ -5,25 +5,33 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var React = require('react'); -var ReactDOM = require('react-dom'); -var ol = require('openlayers'); -var OpenlayersLayer = require('../Layer.jsx'); -var expect = require('expect'); -var assign = require('object-assign'); -require('../../../../utils/openlayers/Layers'); -require('../plugins/OSMLayer'); -require('../plugins/WMSLayer'); -require('../plugins/WMTSLayer'); -require('../plugins/GoogleLayer'); -require('../plugins/BingLayer'); -require('../plugins/MapQuest'); -require('../plugins/VectorLayer'); -require('../plugins/GraticuleLayer'); -require('../plugins/OverlayLayer'); - -const SecurityUtils = require('../../../../utils/SecurityUtils'); -const ConfigUtils = require('../../../../utils/ConfigUtils'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; +import OpenlayersLayer from '../Layer'; + +import assign from 'object-assign'; +import '../../../../utils/openlayers/Layers'; +import '../plugins/OSMLayer'; +import '../plugins/WMSLayer'; +import '../plugins/WMTSLayer'; +import '../plugins/GoogleLayer'; +import '../plugins/BingLayer'; +import '../plugins/MapQuest'; +import '../plugins/VectorLayer'; +import '../plugins/GraticuleLayer'; +import '../plugins/OverlayLayer'; + +import SecurityUtils from '../../../../utils/SecurityUtils'; +import ConfigUtils from '../../../../utils/ConfigUtils'; + +import { Map, View } from 'ol'; +import { defaults as defaultControls } from 'ol/control'; + +import axios from "../../../../libs/ajax"; +import MockAdapter from "axios-mock-adapter"; + +let mockAxios; const sampleTileMatrixConfig900913 = { "matrixIds": { @@ -150,17 +158,18 @@ describe('Openlayers layer', () => { let map; beforeEach(() => { + mockAxios = new MockAdapter(axios); document.body.innerHTML = '
'; - map = new ol.Map({ + map = new Map({ layers: [ ], - controls: ol.control.defaults({ - attributionOptions: /** @type {olx.control.AttributionOptions} */ { + controls: defaultControls({ + attributionOptions: { collapsible: false } }), target: 'map', - view: new ol.View({ + view: new View({ center: [0, 0], zoom: 5 }) @@ -168,6 +177,7 @@ describe('Openlayers layer', () => { }); afterEach(() => { + mockAxios.restore(); map.setTarget(null); document.body.innerHTML = ''; }); @@ -270,6 +280,151 @@ describe('Openlayers layer', () => { expect(map.getLayers().item(0).getSource().getAttributions()).toNotExist(); }); + it('test wms vector formats', () => { + const options = { + "type": 'wms', + "visibility": true, + "name": 'osm:vector_tile', + "group": 'Vector', + "url": "http://sample.server/geoserver/wms" + }; + + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('GeoJSON'); + + layer = ReactDOM.render(, document.getElementById("container")); + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('MVT'); + + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('TopoJSON'); + }); + + it('test wms vector formats styles are applied', (done) => { + const options = { + "type": 'wms', + "visibility": true, + "name": 'osm:vector_tile', + "group": 'Vector', + "url": "http://sample.server/geoserver/wms", + "vectorStyle": { + "color": "#ff0000", + "fillColor": "#ffff00", + "fillOpacity": 0.5 + } + }; + + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('GeoJSON'); + setTimeout(() => { + const style = layer.layer.getStyle(); + expect(style).toExist(); + expect(style.getStroke().getColor()).toBe('rgb(255, 0, 0)'); + expect(style.getFill().getColor()).toBe('rgba(255, 255, 0, 0.5)'); + done(); + }, 0); + }); + + it('test wms vector formats remote styles are applied', (done) => { + const SLD = ` + + + Simple Polygon + + Simple Polygon + + + + + #FF0000 + 2 + + + #FFFF00 + 0.5 + + + + + + + `; + mockAxios.onGet().reply(200, SLD); + const options = { + "type": 'wms', + "visibility": true, + "name": 'osm:vector_tile', + "group": 'Vector', + "url": "http://sample.server/geoserver/wms", + "vectorStyle": { + "url": "http://mystyle", + "format": "sld" + } + }; + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('GeoJSON'); + setTimeout(() => { + const style = layer.layer.getStyle(); + expect(style).toExist(); + expect(style.getStroke().getColor()).toBe('#FF0000'); + expect(style.getFill().getColor()).toBe('rgba(255, 255, 0, 0.5)'); + done(); + }, 0); + }); + it('wms layer attribution with credits - create and update layer', () => { const TEXT1 = "some attribution"; const TEXT2 = "some other attibution"; @@ -294,13 +449,12 @@ describe('Openlayers layer', () => { , document.getElementById("container")); - expect(layer).toExist(); // check creation expect(map.getLayers().getLength()).toBe(1); expect(map.getLayers().item(0).getSource().urls.length).toBe(1); expect(map.getLayers().item(0).getSource().getAttributions()).toExist(); - expect(map.getLayers().item(0).getSource().getAttributions()[0].getHTML()).toBe(TEXT1); + expect(map.getLayers().item(0).getSource().getAttributions()()[0]).toBe(TEXT1); // check remove ReactDOM.render( { , document.getElementById("container")); expect(map.getLayers().item(0).getSource().getAttributions()).toExist(); - expect(map.getLayers().item(0).getSource().getAttributions()[0].getHTML()).toBe(TEXT2); + expect(map.getLayers().item(0).getSource().getAttributions()()[0]).toBe(TEXT2); // check content update ReactDOM.render( , document.getElementById("container")); expect(map.getLayers().item(0).getSource().getAttributions()).toExist(); - expect(map.getLayers().item(0).getSource().getAttributions()[0].getHTML()).toBe(TEXT1); + expect(map.getLayers().item(0).getSource().getAttributions()()[0]).toBe(TEXT1); // check complex contents ReactDOM.render( , document.getElementById("container")); expect(map.getLayers().item(0).getSource().getAttributions()).toExist(); - expect(map.getLayers().item(0).getSource().getAttributions()[0].getHTML()).toBe(''); + expect(map.getLayers().item(0).getSource().getAttributions()()[0]).toBe(''); }); it('creates a wms elevation layer for openlayers map', () => { @@ -1702,4 +1856,140 @@ describe('Openlayers layer', () => { expect(layer.layer.getSource().getParams().CQL_FILTER).toBe("((\"prop2\" = 'value2')) AND (prop = 'value')"); }); + + + it('test wmts vector formats', () => { + + const options = { + type: 'wmts', + visibility: true, + name: 'osm:vector_tile', + group: 'Vector', + tileMatrixSet: [ + { + 'TileMatrix': [], + 'ows:Identifier': 'EPSG:900913', + 'ows:SupportedCRS': 'urn:ogc:def:crs:EPSG::900913' + } + ], + url: 'http://sample.server/geoserver/gwc/service/wmts' + }; + + const GeoJSON = 'application/json;type=geojson'; + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('GeoJSON'); + + + const MVT = 'application/vnd.mapbox-vector-tile'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('MVT'); + + const TopoJSON = 'application/json;type=topojson'; + layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('TopoJSON'); + + }); + + it('test render a wfs3 layer', () => { + + const options = { + id: 'layer_id', + name: 'layer_name', + title: 'Layer Title', + type: 'wfs3', + visibility: true, + url: '/geoserver/wfs3/collections/layer_name/tiles/{tilingSchemeId}/{level}/{row}/{col}', + format: 'application/vnd.mapbox-vector-tile', + tilingScheme: '/geoserver/wfs3/collections/layer_name/tiles/{tilingSchemeId}', + tilingSchemes: { + url: '/geoserver/wfs3/collections/layer_name/tiles', + schemes: [ + { + type: 'TileMatrixSet', + identifier: 'GoogleMapsCompatible', + title: 'GoogleMapsCompatible', + supportedCRS: 'EPSG:3857', + tileMatrix: [{ + matrixHeight: 1, + matrixWidth: 1, + tileHeight: 256, + tileWidth: 256, + identifier: '0', + scaleDenominator: 559082263.9508929, + topLeftCorner: [ + -20037508.34, + 20037508 + ], + type: 'TileMatrix' + }], + boundingBox: { + crs: 'http://www.opengis.net/def/crs/EPSG/0/3857', + lowerCorner: [ + -20037508.34, + -20037508.34 + ], + upperCorner: [ + 20037508.34, + 20037508.34 + ], + type: 'BoundingBox' + }, + wellKnownScaleSet: 'http://www.opengis.net/def/wkss/OGC/1.0/GoogleMapsCompatible' + } + ] + }, + bbox: { + crs: 'EPSG:4326', + bounds: { + minx: -156.2575, + miny: -90, + maxx: 123.33333333333333, + maxy: 46.5475 + } + }, + allowedSRS: { + 'EPSG:3857': true + } + }; + + let layer = ReactDOM.render(, document.getElementById("container")); + + expect(layer).toExist(); + expect(map.getLayers().getLength()).toBe(1); + expect(layer.layer.getType()).toBe('VECTOR_TILE'); + expect(layer.layer.getSource().format_.constructor.name).toBe('MVT'); + }); }); diff --git a/web/client/components/map/openlayers/__tests__/LegacyVectorStyle-test.js b/web/client/components/map/openlayers/__tests__/LegacyVectorStyle-test.js index 06c5175a89..0cc3f631e1 100644 --- a/web/client/components/map/openlayers/__tests__/LegacyVectorStyle-test.js +++ b/web/client/components/map/openlayers/__tests__/LegacyVectorStyle-test.js @@ -5,11 +5,15 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const expect = require('expect'); -const LegacyVectorStyle = require('../LegacyVectorStyle'); -const ol = require('openlayers'); -const {geomCollFeature} = require('../../../../test-resources/drawsupport/features'); -const {DEFAULT_ANNOTATIONS_STYLES} = require('../../../../utils/AnnotationsUtils'); +import expect from 'expect'; +import { getStyle, styleFunction, firstPointOfPolylineStyle, lastPointOfPolylineStyle, startEndPolylineStyle } from '../LegacyVectorStyle'; + +import {geomCollFeature} from '../../../../test-resources/drawsupport/features'; +import {DEFAULT_ANNOTATIONS_STYLES} from '../../../../utils/AnnotationsUtils'; + +import Feature from 'ol/Feature'; +import {Point, LineString, MultiLineString, Polygon, MultiPolygon} from 'ol/geom'; +import GeometryCollection from 'ol/geom/GeometryCollection'; describe('Test LegacyVectorStyle', () => { beforeEach((done) => { @@ -23,7 +27,7 @@ describe('Test LegacyVectorStyle', () => { }); it('simple point style', () => { - const style = LegacyVectorStyle.getStyle({ + const style = getStyle({ style: { type: 'Point', "Point": { @@ -36,7 +40,7 @@ describe('Test LegacyVectorStyle', () => { }); it('style name', () => { - const style = LegacyVectorStyle.getStyle({ + const style = getStyle({ type: 'Point', iconUrl: 'myurl' }); @@ -51,7 +55,7 @@ describe('Test LegacyVectorStyle', () => { }, name: 'My Point' }; - const style = LegacyVectorStyle.getStyle({ + const style = getStyle({ features: [feature], style: { radius: 10, @@ -65,13 +69,13 @@ describe('Test LegacyVectorStyle', () => { it('test styleFunction with LineString', () => { - const lineString = new ol.Feature({ - geometry: new ol.geom.LineString([ + const lineString = new Feature({ + geometry: new LineString([ [100.0, 0.0], [101.0, 1.0] ]) }); - let olStyle = LegacyVectorStyle.styleFunction(lineString); + let olStyle = styleFunction(lineString); let olStroke = olStyle[0].getStroke(); expect(olStroke.getColor()).toBe('blue'); @@ -84,7 +88,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(lineString, options); + olStyle = styleFunction(lineString, options); olStroke = olStyle[0].getStroke(); expect(olStroke.getColor()).toBe('#3388ff'); @@ -101,7 +105,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(lineString, optionsWithFeatureType); + olStyle = styleFunction(lineString, optionsWithFeatureType); olStroke = olStyle[0].getStroke(); expect(olStroke.getColor()).toBe('#ffaa33'); @@ -111,14 +115,14 @@ describe('Test LegacyVectorStyle', () => { it('test styleFunction with MultiLineString', () => { - const multiLineString = new ol.Feature({ - geometry: new ol.geom.MultiLineString([ + const multiLineString = new Feature({ + geometry: new MultiLineString([ [ [100.0, 0.0], [101.0, 1.0] ], [ [102.0, 2.0], [103.0, 3.0] ] ]) }); - let olStyle = LegacyVectorStyle.styleFunction(multiLineString); + let olStyle = styleFunction(multiLineString); let olStroke = olStyle[0].getStroke(); expect(olStroke.getColor()).toBe('blue'); @@ -131,7 +135,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(multiLineString, options); + olStyle = styleFunction(multiLineString, options); olStroke = olStyle[0].getStroke(); expect(olStroke.getColor()).toBe('#3388ff'); @@ -148,7 +152,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(multiLineString, optionsWithFeatureType); + olStyle = styleFunction(multiLineString, optionsWithFeatureType); olStroke = olStyle[0].getStroke(); expect(olStroke.getColor()).toBe('#ffaa33'); @@ -158,13 +162,13 @@ describe('Test LegacyVectorStyle', () => { it('test styleFunction with Polygon', () => { - const polygon = new ol.Feature({ - geometry: new ol.geom.Polygon([ + const polygon = new Feature({ + geometry: new Polygon([ [ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0], [100.0, 1.0], [100.0, 0.0] ] ]) }); - let olStyle = LegacyVectorStyle.styleFunction(polygon); + let olStyle = styleFunction(polygon); let olFill = olStyle[0].getFill(); let olStroke = olStyle[0].getStroke(); @@ -183,7 +187,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(polygon, options); + olStyle = styleFunction(polygon, options); olFill = olStyle[0].getFill(); olStroke = olStyle[0].getStroke(); @@ -208,7 +212,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(polygon, optionsWithFeatureType); + olStyle = styleFunction(polygon, optionsWithFeatureType); olFill = olStyle[0].getFill(); olStroke = olStyle[0].getStroke(); @@ -221,8 +225,8 @@ describe('Test LegacyVectorStyle', () => { it('test styleFunction with MultiPolygon', () => { - const multiPolygon = new ol.Feature({ - geometry: new ol.geom.MultiPolygon([ + const multiPolygon = new Feature({ + geometry: new MultiPolygon([ [ [ [102.0, 2.0], [103.0, 2.0], [103.0, 3.0], [102.0, 3.0], [102.0, 2.0] ] ], @@ -233,7 +237,7 @@ describe('Test LegacyVectorStyle', () => { ]) }); - let olStyle = LegacyVectorStyle.styleFunction(multiPolygon); + let olStyle = styleFunction(multiPolygon); let olFill = olStyle[0].getFill(); let olStroke = olStyle[0].getStroke(); @@ -252,7 +256,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(multiPolygon, options); + olStyle = styleFunction(multiPolygon, options); olFill = olStyle[0].getFill(); olStroke = olStyle[0].getStroke(); @@ -277,7 +281,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(multiPolygon, optionsWithFeatureType); + olStyle = styleFunction(multiPolygon, optionsWithFeatureType); olFill = olStyle[0].getFill(); olStroke = olStyle[0].getStroke(); @@ -289,31 +293,31 @@ describe('Test LegacyVectorStyle', () => { }); it('test firstPointOfPolylineStyle defaults', () => { - let olStyle = LegacyVectorStyle.firstPointOfPolylineStyle(); + let olStyle = firstPointOfPolylineStyle(); expect(olStyle.getImage().getRadius()).toBe(5); expect(olStyle.getImage().getFill().getColor()).toBe("green"); }); it('test lastPointOfPolylineStyle defaults', () => { - let olStyle = LegacyVectorStyle.lastPointOfPolylineStyle(); + let olStyle = lastPointOfPolylineStyle(); expect(olStyle.getImage().getRadius()).toBe(5); expect(olStyle.getImage().getFill().getColor()).toBe("red"); }); it('test firstPointOfPolylineStyle {radius: 4}', () => { - let olStyle = LegacyVectorStyle.firstPointOfPolylineStyle({radius: 4}); + let olStyle = firstPointOfPolylineStyle({radius: 4}); expect(olStyle.getImage().getRadius()).toBe(4); expect(olStyle.getImage().getFill().getColor()).toBe("green"); }); it('test lastPointOfPolylineStyle {radius: 4}', () => { - let olStyle = LegacyVectorStyle.lastPointOfPolylineStyle({radius: 4}); + let olStyle = lastPointOfPolylineStyle({radius: 4}); expect(olStyle.getImage().getRadius()).toBe(4); expect(olStyle.getImage().getFill().getColor()).toBe("red"); }); it('test startEndPolylineStyle defaults', () => { - let styles = LegacyVectorStyle.startEndPolylineStyle(); + let styles = startEndPolylineStyle(); expect(styles[0].getImage().getRadius()).toBe(5); expect(styles[0].getImage().getFill().getColor()).toBe("green"); expect(styles[1].getImage().getRadius()).toBe(5); @@ -322,7 +326,7 @@ describe('Test LegacyVectorStyle', () => { it('test styleFunction with GeometryCollection', () => { - const multiPolygon = new ol.geom.MultiPolygon([ + const multiPolygon = new MultiPolygon([ [ [ [102.0, 2.0], [103.0, 2.0], [103.0, 3.0], [102.0, 3.0], [102.0, 2.0] ] ], @@ -332,11 +336,11 @@ describe('Test LegacyVectorStyle', () => { ] ]); - const geometryCollection = new ol.Feature({ - geometry: new ol.geom.GeometryCollection([multiPolygon]) + const geometryCollection = new Feature({ + geometry: new GeometryCollection([multiPolygon]) }); - let olStyle = LegacyVectorStyle.styleFunction(geometryCollection); + let olStyle = styleFunction(geometryCollection); let olFill = olStyle[0].getFill(); let olStroke = olStyle[0].getStroke(); @@ -356,7 +360,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(geometryCollection, options); + olStyle = styleFunction(geometryCollection, options); olFill = olStyle[0].getFill(); olStroke = olStyle[0].getStroke(); @@ -381,7 +385,7 @@ describe('Test LegacyVectorStyle', () => { } }; - olStyle = LegacyVectorStyle.styleFunction(geometryCollection, optionsWithFeatureType); + olStyle = styleFunction(geometryCollection, optionsWithFeatureType); olFill = olStyle[0].getFill(); olStroke = olStyle[0].getStroke(); @@ -392,7 +396,7 @@ describe('Test LegacyVectorStyle', () => { }); it('test getStyle with GeometryCollection', () => { - const styleFunc = LegacyVectorStyle.getStyle({ + const styleFunc = getStyle({ features: [geomCollFeature], style: { color: "ff0000", @@ -402,11 +406,11 @@ describe('Test LegacyVectorStyle', () => { }, false, ["textValue"]); expect(styleFunc).toExist(); - const styleGenerated = styleFunc(new ol.Feature({ - geometry: new ol.geom.GeometryCollection([ - new ol.geom.LineString([[1, 2], [1, 3]]), - new ol.geom.Polygon([[1, 2], [1, 3], [1, 1], [1, 2]]), - new ol.geom.Point([1, 20]) + const styleGenerated = styleFunc(new Feature({ + geometry: new GeometryCollection([ + new LineString([[1, 2], [1, 3]]), + new Polygon([[1, 2], [1, 3], [1, 1], [1, 2]]), + new Point([1, 20]) ]) })); expect(styleGenerated).toExist(); diff --git a/web/client/components/map/openlayers/__tests__/Locate-test.jsx b/web/client/components/map/openlayers/__tests__/Locate-test.jsx index 96a5401e14..5382e8ca9d 100644 --- a/web/client/components/map/openlayers/__tests__/Locate-test.jsx +++ b/web/client/components/map/openlayers/__tests__/Locate-test.jsx @@ -5,28 +5,29 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var expect = require('expect'); -var React = require('react'); -var ReactDOM = require('react-dom'); -var ol = require('openlayers'); -var Locate = require('../Locate'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; +import Locate from '../Locate'; + +import { Map, View } from 'ol'; describe('Openlayers Locate component', () => { let map; beforeEach((done) => { document.body.innerHTML = '
'; - map = new ol.Map({ + map = new Map({ layers: [ ], - controls: ol.control.defaults({ - attributionOptions: /** @type {olx.control.AttributionOptions} */ { + /*controls: ol.control.defaults({ + attributionOptions: { collapsible: false } - }), + }),*/ target: 'map', - view: new ol.View({ + view: new View({ center: [0, 0], zoom: 5 }) diff --git a/web/client/components/map/openlayers/__tests__/Map-test.jsx b/web/client/components/map/openlayers/__tests__/Map-test.jsx index fa4c3af952..1fe5fc916c 100644 --- a/web/client/components/map/openlayers/__tests__/Map-test.jsx +++ b/web/client/components/map/openlayers/__tests__/Map-test.jsx @@ -5,18 +5,25 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const ReactDOM = require('react-dom'); -const OpenlayersMap = require('../Map.jsx'); -const OpenlayersLayer = require('../Layer.jsx'); -const expect = require('expect'); -const assign = require('object-assign'); -const ol = require('openlayers'); -const proj = require('proj4').default; -const mapUtils = require('../../../../utils/MapUtils'); -require('../../../../utils/openlayers/Layers'); -require('../plugins/OSMLayer'); -require('../plugins/VectorLayer'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; +import OpenlayersLayer from '../Layer'; +import OpenlayersMap from '../Map'; + +import assign from 'object-assign'; + +import proj from 'proj4'; +import MapUtils from '../../../../utils/MapUtils'; + +import '../../../../utils/openlayers/Layers'; +import '../plugins/OSMLayer'; +import '../plugins/VectorLayer'; + +import {get, transform} from 'ol/proj'; + +import Feature from 'ol/Feature'; +import {Point, Polygon} from 'ol/geom'; describe('OpenlayersMap', () => { @@ -109,7 +116,7 @@ describe('OpenlayersMap', () => { const map = ReactDOM.render(comp, document.getElementById("map")); expect(map).toExist(); expect(map.map.getView().getProjection().getCode()).toBe('EPSG:25830'); - expect(ol.proj.get('EPSG:25830')).toExist(); + expect(get('EPSG:25830')).toExist(); }); it('custom projection with axisOrientation', () => { @@ -136,8 +143,8 @@ describe('OpenlayersMap', () => { const map = ReactDOM.render(comp, document.getElementById("map")); expect(map).toExist(); expect(map.map.getView().getProjection().getCode()).toBe('EPSG:31468'); - expect(ol.proj.get('EPSG:31468')).toExist(); - expect(ol.proj.get('EPSG:31468').getAxisOrientation()).toBe('neu'); + expect(get('EPSG:31468')).toExist(); + expect(get('EPSG:31468').getAxisOrientation()).toBe('neu'); }); it('check if the handler for "click" event is called with elevation', () => { @@ -262,8 +269,8 @@ describe('OpenlayersMap', () => { setTimeout(() => { map.map.forEachFeatureAtPixel = (pixel, callback) => { callback.call(null, { - feature: new ol.Feature({ - geometry: new ol.geom.Point([10.3, 43.9]), + feature: new Feature({ + geometry: new Point([10.3, 43.9]), name: 'My Point' }), getGeometry: () => { @@ -299,8 +306,8 @@ describe('OpenlayersMap', () => { setTimeout(() => { map.map.forEachFeatureAtPixel = (pixel, callback) => { callback.call(null, { - feature: new ol.Feature({ - geometry: new ol.geom.Point([10.3, 43.9]), + feature: new Feature({ + geometry: new Point([10.3, 43.9]), name: 'My Point' }), getGeometry: () => { @@ -335,8 +342,8 @@ describe('OpenlayersMap', () => { setTimeout(() => { map.map.forEachFeatureAtPixel = (pixel, callback) => { callback.call(null, { - feature: new ol.Feature({ - geometry: new ol.geom.Polygon([ [0, 0], [0, 1], [1, 1], [1, 0], [0, 0] ]), + feature: new Feature({ + geometry: new Polygon([ [0, 0], [0, 1], [1, 1], [1, 0], [0, 0] ]), name: 'My Point' }), getGeometry: () => { @@ -375,8 +382,8 @@ describe('OpenlayersMap', () => { setTimeout(() => { map.map.forEachFeatureAtPixel = (pixel, callback) => { callback.call(null, { - feature: new ol.Feature({ - geometry: new ol.geom.Polygon([ [0, 0], [0, 1], [1, 1], [1, 0], [0, 0] ]), + feature: new Feature({ + geometry: new Polygon([ [0, 0], [0, 1], [1, 1], [1, 0], [0, 0] ]), name: 'My Point' }), getGeometry: () => { @@ -416,8 +423,8 @@ describe('OpenlayersMap', () => { setTimeout(() => { map.map.forEachFeatureAtPixel = (pixel, callback) => { callback.call(null, { - feature: new ol.Feature({ - geometry: new ol.geom.Point([43.0, 10]), + feature: new Feature({ + geometry: new Point([43.0, 10]), name: 'My Point' }), getGeometry: () => { @@ -534,7 +541,7 @@ describe('OpenlayersMap', () => { expect(spy.calls[1].arguments[3].width).toExist(); done(); }); - olMap.getView().setCenter(ol.proj.transform([10, 44], 'EPSG:4326', 'EPSG:3857')); + olMap.getView().setCenter(transform([10, 44], 'EPSG:4326', 'EPSG:3857')); olMap.dispatchEvent('moveend'); }); @@ -705,7 +712,7 @@ describe('OpenlayersMap', () => { // instanciating the map that will be used to compute the bounfing box let map = ReactDOM.render(, document.getElementById("map")); // computing the bounding box for the new center and the new zoom - const bbox = mapUtils.getBbox({y: 44, x: 10}, 5); + const bbox = MapUtils.getBbox({y: 44, x: 10}, 5); // update the map with the new center and the new zoom so we can check our computed bouding box map = ReactDOM.render(, document.getElementById("map")); const mapBbox = map.map.getView().calculateExtent(map.map.getSize()); @@ -724,10 +731,10 @@ describe('OpenlayersMap', () => { }); it('test GET_PIXEL_FROM_COORDINATES_HOOK/GET_COORDINATES_FROM_PIXEL_HOOK hook registration', () => { - mapUtils.registerHook(mapUtils.GET_PIXEL_FROM_COORDINATES_HOOK, undefined); - mapUtils.registerHook(mapUtils.GET_COORDINATES_FROM_PIXEL_HOOK, undefined); - let getPixelFromCoordinates = mapUtils.getHook(mapUtils.GET_PIXEL_FROM_COORDINATES_HOOK); - let getCoordinatesFromPixel = mapUtils.getHook(mapUtils.GET_COORDINATES_FROM_PIXEL_HOOK); + MapUtils.registerHook(MapUtils.GET_PIXEL_FROM_COORDINATES_HOOK, undefined); + MapUtils.registerHook(MapUtils.GET_COORDINATES_FROM_PIXEL_HOOK, undefined); + let getPixelFromCoordinates = MapUtils.getHook(MapUtils.GET_PIXEL_FROM_COORDINATES_HOOK); + let getCoordinatesFromPixel = MapUtils.getHook(MapUtils.GET_COORDINATES_FROM_PIXEL_HOOK); expect(getPixelFromCoordinates).toNotExist(); expect(getCoordinatesFromPixel).toNotExist(); @@ -735,13 +742,13 @@ describe('OpenlayersMap', () => { document.getElementById("map")); expect(map).toExist(); - getPixelFromCoordinates = mapUtils.getHook(mapUtils.GET_PIXEL_FROM_COORDINATES_HOOK); - getCoordinatesFromPixel = mapUtils.getHook(mapUtils.GET_COORDINATES_FROM_PIXEL_HOOK); + getPixelFromCoordinates = MapUtils.getHook(MapUtils.GET_PIXEL_FROM_COORDINATES_HOOK); + getCoordinatesFromPixel = MapUtils.getHook(MapUtils.GET_COORDINATES_FROM_PIXEL_HOOK); expect(getPixelFromCoordinates).toExist(); expect(getCoordinatesFromPixel).toExist(); }); it('test ZOOM_TO_EXTENT_HOOK', (done) => { - mapUtils.registerHook(mapUtils.ZOOM_TO_EXTENT_HOOK, undefined); + MapUtils.registerHook(MapUtils.ZOOM_TO_EXTENT_HOOK, undefined); const testHandlers = { onMapViewChanges: () => { } @@ -786,7 +793,7 @@ describe('OpenlayersMap', () => { }); expect(map).toExist(); - const hook = mapUtils.getHook(mapUtils.ZOOM_TO_EXTENT_HOOK); + const hook = MapUtils.getHook(MapUtils.ZOOM_TO_EXTENT_HOOK); expect(hook).toExist(); hook([0, 0, 20, 20], { crs: "EPSG:4326", duration: 0 }); olMap.dispatchEvent('moveend'); @@ -810,7 +817,7 @@ describe('OpenlayersMap', () => { * To avoid this, zoom to max resolution extent. * TODO: improve this to manage all degenerated bounding boxes. */ - mapUtils.registerHook(mapUtils.ZOOM_TO_EXTENT_HOOK, undefined); + MapUtils.registerHook(MapUtils.ZOOM_TO_EXTENT_HOOK, undefined); const testHandlers = { onMapViewChanges: () => { } @@ -841,7 +848,7 @@ describe('OpenlayersMap', () => { }); expect(map).toExist(); - const hook = mapUtils.getHook(mapUtils.ZOOM_TO_EXTENT_HOOK); + const hook = MapUtils.getHook(MapUtils.ZOOM_TO_EXTENT_HOOK); expect(hook).toExist(); hook([-180, -90, 180, 90], { crs: "EPSG:4326", duration: 0 }); olMap.dispatchEvent('moveend'); @@ -856,7 +863,7 @@ describe('OpenlayersMap', () => { * To avoid this, zoom to max resolution extent. * TODO: improve this to manage all degenerated bounding boxes. */ - mapUtils.registerHook(mapUtils.ZOOM_TO_EXTENT_HOOK, undefined); + MapUtils.registerHook(MapUtils.ZOOM_TO_EXTENT_HOOK, undefined); const testHandlers = { onMapViewChanges: () => { } @@ -889,7 +896,7 @@ describe('OpenlayersMap', () => { }); expect(map).toExist(); - const hook = mapUtils.getHook(mapUtils.ZOOM_TO_EXTENT_HOOK); + const hook = MapUtils.getHook(MapUtils.ZOOM_TO_EXTENT_HOOK); expect(hook).toExist(); hook([1, 1, 1, 1], { crs: "EPSG:4326", duration: 0 }); olMap.dispatchEvent('moveend'); diff --git a/web/client/components/map/openlayers/__tests__/MeasurementSupport-test.jsx b/web/client/components/map/openlayers/__tests__/MeasurementSupport-test.jsx index 08fef654f8..3a60f964bb 100644 --- a/web/client/components/map/openlayers/__tests__/MeasurementSupport-test.jsx +++ b/web/client/components/map/openlayers/__tests__/MeasurementSupport-test.jsx @@ -6,17 +6,21 @@ * LICENSE file in the root directory of this source tree. */ -const expect = require('expect'); -const React = require('react'); -const ReactDOM = require('react-dom'); -const ol = require('openlayers'); -const {round} = require('lodash'); -const MeasurementSupport = require('../MeasurementSupport'); -const { +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; + +import round from 'lodash/round'; +import MeasurementSupport from '../MeasurementSupport'; + +import { lineFeature, lineFeature3, polyFeatureClosed -} = require('../../../../test-resources/drawsupport/features'); +} from '../../../../test-resources/drawsupport/features'; + +import { Map, View, Feature } from 'ol'; +import {LineString} from 'ol/geom'; describe('Openlayers MeasurementSupport', () => { let msNode; @@ -27,9 +31,9 @@ describe('Openlayers MeasurementSupport', () => { center: [0, 0], zoom: 5 }; - let map = new ol.Map({ + let map = new Map({ target: "map", - view: new ol.View(viewOptions) + view: new View(viewOptions) }); const uom = { length: {unit: 'm', label: 'm'}, @@ -83,9 +87,9 @@ describe('Openlayers MeasurementSupport', () => { document.body.innerHTML = ''; msNode = undefined; expect.restoreSpies(); - map = new ol.Map({ + map = new Map({ target: "map", - view: new ol.View(viewOptions) + view: new View(viewOptions) }); setTimeout(done); }); @@ -192,7 +196,7 @@ describe('Openlayers MeasurementSupport', () => { expect(spyUpdateMeasures.calls.length).toBe(1); const measureState = spyUpdateMeasures.calls[0].arguments[0]; expect(measureState).toExist(); - expect(round(measureState.area, 2)).toBe(49490132941.51); + expect(round(measureState.area, 2)).toBe(49379574502.64); expect(measureState.bearing).toBe(0); }); @@ -214,15 +218,15 @@ describe('Openlayers MeasurementSupport', () => { }); cmp.drawInteraction.dispatchEvent({ type: 'drawstart', - feature: new ol.Feature({ - geometry: new ol.geom.LineString([[13.0, 43.0], [13.0, 40.0]]), + feature: new Feature({ + geometry: new LineString([[13.0, 43.0], [13.0, 40.0]]), name: 'My line with 2 points' }) }); cmp.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.LineString([[13.0, 43.0], [13.0, 40.0], [11.0, 41.0]]), + feature: new Feature({ + geometry: new LineString([[13.0, 43.0], [13.0, 40.0], [11.0, 41.0]]), name: 'My line with 3 points' }) }); @@ -249,15 +253,15 @@ describe('Openlayers MeasurementSupport', () => { }); cmp.drawInteraction.dispatchEvent({ type: 'drawstart', - feature: new ol.Feature({ - geometry: new ol.geom.LineString([[13.0, 43.0], [13.0, 40.0]]), + feature: new Feature({ + geometry: new LineString([[13.0, 43.0], [13.0, 40.0]]), name: 'My line with 2 points' }) }); cmp.drawInteraction.dispatchEvent({ type: 'drawend', - feature: new ol.Feature({ - geometry: new ol.geom.LineString([[13.0, 43.0], [13.0, 40.0], [11.0, 41.0]]), + feature: new Feature({ + geometry: new LineString([[13.0, 43.0], [13.0, 40.0], [11.0, 41.0]]), name: 'My line with 3 points' }) }); diff --git a/web/client/components/map/openlayers/__tests__/Overview-test.jsx b/web/client/components/map/openlayers/__tests__/Overview-test.jsx index 949c75777c..6e5a719db6 100644 --- a/web/client/components/map/openlayers/__tests__/Overview-test.jsx +++ b/web/client/components/map/openlayers/__tests__/Overview-test.jsx @@ -5,27 +5,28 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const expect = require('expect'); -const React = require('react'); -const ReactDOM = require('react-dom'); -const ol = require('openlayers'); -const Overview = require('../Overview'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; +import Overview from '../Overview'; + +import { Map, View } from 'ol'; describe('Openlayers Overview component', () => { let map; beforeEach((done) => { document.body.innerHTML = '
'; - map = new ol.Map({ + map = new Map({ layers: [ ], - controls: ol.control.defaults({ - attributionOptions: /** @type {olx.control.AttributionOptions} */ { + /*controls: ol.control.defaults({ + attributionOptions: { collapsible: false } - }), + }),*/ target: 'map', - view: new ol.View({ + view: new View({ center: [0, 0], zoom: 5 }) diff --git a/web/client/components/map/openlayers/__tests__/ScaleBar-test.jsx b/web/client/components/map/openlayers/__tests__/ScaleBar-test.jsx index b533ccc4fa..a7ce04e08b 100644 --- a/web/client/components/map/openlayers/__tests__/ScaleBar-test.jsx +++ b/web/client/components/map/openlayers/__tests__/ScaleBar-test.jsx @@ -5,26 +5,27 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var React = require('react'); -var ReactDOM = require('react-dom'); -var ol = require('openlayers'); -var ScaleBar = require('../ScaleBar'); -var expect = require('expect'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import expect from 'expect'; +import ScaleBar from '../ScaleBar'; + +import { Map, View } from 'ol'; describe('Openlayers ScaleBar component', () => { let map; beforeEach((done) => { document.body.innerHTML = '
'; - map = new ol.Map({ + map = new Map({ layers: [ ], - controls: ol.control.defaults({ - attributionOptions: /** @type {olx.control.AttributionOptions} */ { + /*controls: ol.control.defaults({ + attributionOptions: { collapsible: false } - }), + }),*/ target: 'map', - view: new ol.View({ + view: new View({ center: [0, 0], zoom: 5 }) diff --git a/web/client/components/map/openlayers/__tests__/VectorStyle-test.js b/web/client/components/map/openlayers/__tests__/VectorStyle-test.js index cc84de2bd3..2cd49c5771 100644 --- a/web/client/components/map/openlayers/__tests__/VectorStyle-test.js +++ b/web/client/components/map/openlayers/__tests__/VectorStyle-test.js @@ -5,8 +5,8 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const expect = require('expect'); -const { +import expect from 'expect'; +import { getCircleStyle, getMarkerStyle, getStrokeStyle, @@ -14,22 +14,36 @@ const { getTextStyle, getGeometryTrasformation, getFilter, - parseStyles -} = require('../VectorStyle'); -const ol = require('openlayers'); -const {isArray} = require('lodash'); -const baseImageUrl = require('../../../mapcontrols/annotations/img/markers_default.png'); -const shadowImageUrl = require('../../../mapcontrols/annotations/img/markers_shadow.png'); -const MarkerUtils = require('../../../../utils/MarkerUtils'); -const {colorToRgbaStr} = require('../../../../utils/ColorUtils'); + parseStyles, + getStyle +} from '../VectorStyle'; + +import isArray from 'lodash/isArray'; +import baseImageUrl from '../../../mapcontrols/annotations/img/markers_default.png'; +import shadowImageUrl from '../../../mapcontrols/annotations/img/markers_shadow.png'; +import MarkerUtils from '../../../../utils/MarkerUtils'; +import {colorToRgbaStr} from '../../../../utils/ColorUtils'; + +import {Stroke, Fill} from 'ol/style'; + +import Feature from 'ol/Feature'; +import {Point, MultiPoint, Polygon} from 'ol/geom'; + +import axios from "../../../../libs/ajax"; +import MockAdapter from "axios-mock-adapter"; + +let mockAxios; + const glyphs = MarkerUtils.getGlyphs('fontawesome'); describe('Test VectorStyle', () => { beforeEach((done) => { + mockAxios = new MockAdapter(axios); document.body.innerHTML = '
'; setTimeout(done); }); afterEach((done) => { + mockAxios.restore(); document.body.innerHTML = ''; setTimeout(done); }); @@ -57,11 +71,11 @@ describe('Test VectorStyle', () => { const strokeStyle = { color: "#223366" }; - const stroke = new ol.style.Stroke(strokeStyle); + const stroke = new Stroke(strokeStyle); const fillStyle = { color: "#998877" }; - const fill = new ol.style.Fill(fillStyle); + const fill = new Fill(fillStyle); const olStyle = getCircleStyle({ radius: 800 }, @@ -306,7 +320,7 @@ describe('Test VectorStyle', () => { Options are: - remove it - test it more, on ol they say that some defaults are applied, but it is not the case - (https://openlayers.org/en/v4.6.5/apidoc/ol.style.Stroke.html) + (https://openlayers.org/en/v4.6.5/apidoc/Stroke.html) */ const strokeStyle = { color: "#ffffff", @@ -450,9 +464,9 @@ describe('Test VectorStyle', () => { }; const geomFunc = getGeometryTrasformation(markerStyle); expect(geomFunc).toNotBe(null); - const feature = new ol.Feature({ - geometry: new ol.geom.Point([1, 2]), - labelPoint: new ol.geom.Point([1, 1]), + const feature = new Feature({ + geometry: new Point([1, 2]), + labelPoint: new Point([1, 1]), name: 'My Polygon' }); expect(geomFunc(feature).getType()).toBe("Point"); @@ -466,9 +480,9 @@ describe('Test VectorStyle', () => { }; const geomFunc = getGeometryTrasformation(markerStyle); expect(geomFunc).toNotBe(null); - const feature = new ol.Feature({ - geometry: new ol.geom.Polygon([[[1, 2], [2, 2], [3, 2], [1, 2]]]), - labelPoint: new ol.geom.Point([1, 1]), + const feature = new Feature({ + geometry: new Polygon([[[1, 2], [2, 2], [3, 2], [1, 2]]]), + labelPoint: new Point([1, 1]), name: 'My Polygon' }); expect(geomFunc(feature).getType()).toBe("Point"); @@ -480,9 +494,9 @@ describe('Test VectorStyle', () => { }; const geomFunc = getGeometryTrasformation(markerStyle); expect(geomFunc).toNotBe(null); - const feature = new ol.Feature({ - geometry: new ol.geom.MultiPoint([[1, 2], [2, 2], [3, 2], [1, 2]]), - labelPoint: new ol.geom.Point([1, 1]), + const feature = new Feature({ + geometry: new MultiPoint([[1, 2], [2, 2], [3, 2], [1, 2]]), + labelPoint: new Point([1, 1]), name: 'My Polygon' }); expect(geomFunc(feature).getType()).toBe("LineString"); @@ -494,9 +508,9 @@ describe('Test VectorStyle', () => { }; const geomFunc = getGeometryTrasformation(markerStyle); expect(geomFunc).toNotBe(null); - const feature = new ol.Feature({ - geometry: new ol.geom.Polygon([[[1, 2], [2, 2], [3, 2], [1, 2]]]), - labelPoint: new ol.geom.Point([1, 1]), + const feature = new Feature({ + geometry: new Polygon([[[1, 2], [2, 2], [3, 2], [1, 2]]]), + labelPoint: new Point([1, 1]), name: 'My Polygon' }); expect(geomFunc(feature).getType()).toBe("Polygon"); @@ -555,4 +569,76 @@ describe('Test VectorStyle', () => { expect(isArray(olStyles)).toBe(true); expect(olStyles.length).toBe(3); }); + it('getStyle is compatible with legacy get style', () => { + const style = getStyle({ + style: { + type: 'Point', + "Point": { + iconGlyph: "comment" + } + } + }, true); + expect(style).toExist(); + expect(style.getImage()).toExist(); + // TODO: add more tests from LegacyVectorStyle here + }); + it('getStyle can return a promise', (done) => { + const stylePromise = getStyle({ + asPromise: true, + style: { + type: 'Point', + "Point": { + iconGlyph: "comment" + } + } + }, true); + stylePromise.then(style => { + expect(style).toExist(); + expect(style.getImage()).toExist(); + done(); + }); + }); + it('getStyle supports remote styles', (done) => { + const SLD = ` + + + Simple Point + + SLD Cook Book: Simple Point + + + + + + circle + + #FF0000 + + + 6 + + + + + + + `; + mockAxios.onGet().reply(200, SLD); + const stylePromise = getStyle({ + style: { + url: "http://styleurl", + format: "sld" + } + }, true); + stylePromise.then(style => { + expect(style).toExist(); + expect(style.getImage()).toExist(); + done(); + }); + }); }); diff --git a/web/client/components/map/openlayers/index.js b/web/client/components/map/openlayers/index.js index 319c6d6046..6259b765c3 100644 --- a/web/client/components/map/openlayers/index.js +++ b/web/client/components/map/openlayers/index.js @@ -1,9 +1,9 @@ module.exports = { - LLayer: require('./Layer.jsx'), - Locate: require('./Locate.jsx'), - LMap: require('./Map.jsx'), - MeasurementSupport: require('./MeasurementSupport'), - Overview: require('./Overview'), - ScaleBar: require('./ScaleBar'), - Feature: require('./Feature') + LLayer: require('./Layer.jsx').default, + Locate: require('./Locate.jsx').default, + LMap: require('./Map.jsx').default, + MeasurementSupport: require('./MeasurementSupport').default, + Overview: require('./Overview').default, + ScaleBar: require('./ScaleBar').default, + Feature: require('./Feature').default }; diff --git a/web/client/components/map/openlayers/plugins/BingLayer.js b/web/client/components/map/openlayers/plugins/BingLayer.js index e23d91196b..2564a209d9 100644 --- a/web/client/components/map/openlayers/plugins/BingLayer.js +++ b/web/client/components/map/openlayers/plugins/BingLayer.js @@ -6,8 +6,9 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); +import Layers from '../../../../utils/openlayers/Layers'; +import TileLayer from 'ol/layer/Tile'; +import BingMaps from 'ol/source/BingMaps'; const checkLoaded = (layer, options) => { if (layer.getSource && layer.getSource().getState() === 'error') { @@ -24,12 +25,12 @@ Layers.registerType('bing', { create: (options) => { var key = options.apiKey; var maxNativeZoom = options.maxNativeZoom || 19; - const layer = new ol.layer.Tile({ + const layer = new TileLayer({ preload: Infinity, opacity: options.opacity !== undefined ? options.opacity : 1, zIndex: options.zIndex, visible: options.visibility, - source: new ol.source.BingMaps({ + source: new BingMaps({ key: key, imagerySet: options.name, maxZoom: maxNativeZoom diff --git a/web/client/components/map/openlayers/plugins/GoogleLayer.js b/web/client/components/map/openlayers/plugins/GoogleLayer.js index e63e93fdc4..74b680757a 100644 --- a/web/client/components/map/openlayers/plugins/GoogleLayer.js +++ b/web/client/components/map/openlayers/plugins/GoogleLayer.js @@ -6,17 +6,17 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); -var React = require('react'); - -var layersMap; -var rendererItem; -var gmaps = {}; -var isTouchSupported = 'ontouchstart' in window; -var startEvent = isTouchSupported ? 'touchstart' : 'mousedown'; -var moveEvent = isTouchSupported ? 'touchmove' : 'mousemove'; -var endEvent = isTouchSupported ? 'touchend' : 'mouseup'; +import Layers from '../../../../utils/openlayers/Layers'; +import React from 'react'; +import {transform} from 'ol/proj'; + +let layersMap; +let rendererItem; +let gmaps = {}; +let isTouchSupported = 'ontouchstart' in window; +let startEvent = isTouchSupported ? 'touchstart' : 'mousedown'; +let moveEvent = isTouchSupported ? 'touchmove' : 'mousemove'; +let endEvent = isTouchSupported ? 'touchend' : 'mouseup'; Layers.registerType('google', { create: (options, map, mapId) => { @@ -44,7 +44,7 @@ Layers.registerType('google', { let mapContainer = document.getElementById(mapId + 'gmaps'); let setCenter = function() { if (mapContainer.style.visibility !== 'hidden') { - const center = ol.proj.transform(map.getView().getCenter(), 'EPSG:3857', 'EPSG:4326'); + const center = transform(map.getView().getCenter(), 'EPSG:3857', 'EPSG:4326'); gmaps[mapId].setCenter(new google.maps.LatLng(center[1], center[0])); } }; @@ -193,7 +193,7 @@ Layers.registerType('google', { let google = window.google; if (!oldOptions.visibility && newOptions.visibility) { let view = map.getView(); - const center = ol.proj.transform(view.getCenter(), 'EPSG:3857', 'EPSG:4326'); + const center = transform(view.getCenter(), 'EPSG:3857', 'EPSG:4326'); gmaps[mapId].setCenter(new google.maps.LatLng(center[1], center[0])); gmaps[mapId].setZoom(view.getZoom()); } diff --git a/web/client/components/map/openlayers/plugins/GraticuleLayer.js b/web/client/components/map/openlayers/plugins/GraticuleLayer.js index 26912579b1..c6ec9be91b 100644 --- a/web/client/components/map/openlayers/plugins/GraticuleLayer.js +++ b/web/client/components/map/openlayers/plugins/GraticuleLayer.js @@ -6,14 +6,15 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); +import Layers from '../../../../utils/openlayers/Layers'; +import Graticule from 'ol/Graticule'; +import {Stroke} from 'ol/style'; Layers.registerType('graticule', { create: (options, map) => { - let graticule = new ol.Graticule({ - strokeStyle: options.style || new ol.style.Stroke({ + let graticule = new Graticule({ + strokeStyle: options.style || new Stroke({ color: 'rgba(255,120,0,0.9)', width: 2, lineDash: [0.5, 4] diff --git a/web/client/components/map/openlayers/plugins/MapQuest.js b/web/client/components/map/openlayers/plugins/MapQuest.js index 06941c06c4..731aad8e17 100644 --- a/web/client/components/map/openlayers/plugins/MapQuest.js +++ b/web/client/components/map/openlayers/plugins/MapQuest.js @@ -6,7 +6,7 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); +import Layers from '../../../../utils/openlayers/Layers'; Layers.registerType('mapquest', { create: (options) => { diff --git a/web/client/components/map/openlayers/plugins/MarkerLayer.js b/web/client/components/map/openlayers/plugins/MarkerLayer.js index 0362d5b99f..457a50f528 100644 --- a/web/client/components/map/openlayers/plugins/MarkerLayer.js +++ b/web/client/components/map/openlayers/plugins/MarkerLayer.js @@ -6,13 +6,13 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); -var assign = require('object-assign'); -var defaultIcon = require('../img/marker-icon.png'); +import Layers from '../../../../utils/openlayers/Layers'; +import assign from 'object-assign'; +import defaultIcon from '../img/marker-icon.png'; +import {Style, Icon} from 'ol/style'; -var icon = new ol.style.Style({ - image: new ol.style.Icon(/** @type {olx.style.IconOptions} */ { +const icon = new Style({ + image: new Icon(/** @type {olx.style.IconOptions} */ { anchor: [0.5, 1], anchorXUnits: 'fraction', anchorYUnits: 'fraction', @@ -22,11 +22,13 @@ var icon = new ol.style.Style({ }); const defaultStyles = { - 'Point': [new ol.style.Style({ + 'Point': [new Style({ image: icon })]}; - +/** + * @deprecated use VectorLayer + */ Layers.registerType('marker', { create: (options, map, mapId) => { return Layers.createLayer('vector', assign(options, {style: () => { return defaultStyles.Point; }}), map, mapId); diff --git a/web/client/components/map/openlayers/plugins/OSMLayer.js b/web/client/components/map/openlayers/plugins/OSMLayer.js index 0e08ff051f..927ee8c307 100644 --- a/web/client/components/map/openlayers/plugins/OSMLayer.js +++ b/web/client/components/map/openlayers/plugins/OSMLayer.js @@ -6,16 +6,17 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); +import Layers from '../../../../utils/openlayers/Layers'; +import OSM from 'ol/source/OSM'; +import TileLayer from 'ol/layer/Tile'; Layers.registerType('osm', { create: (options) => { - return new ol.layer.Tile({ + return new TileLayer({ opacity: options.opacity !== undefined ? options.opacity : 1, visible: options.visibility, zIndex: options.zIndex, - source: new ol.source.OSM() + source: new OSM() }); } }); diff --git a/web/client/components/map/openlayers/plugins/OverlayLayer.js b/web/client/components/map/openlayers/plugins/OverlayLayer.js index 58709b8fc4..fe0c95e54d 100644 --- a/web/client/components/map/openlayers/plugins/OverlayLayer.js +++ b/web/client/components/map/openlayers/plugins/OverlayLayer.js @@ -6,9 +6,9 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); -var eventListener = require('eventlistener'); +import Layers from '../../../../utils/openlayers/Layers'; +import eventListener from 'eventlistener'; +import Overlay from 'ol/Overlay'; const removeIds = (items) => { if (items.length !== 0) { @@ -50,7 +50,7 @@ Layers.registerType('overlay', { const original = document.getElementById(options.id); const cloned = cloneOriginalOverlay(original, options); document.body.appendChild(cloned); - const overlay = new ol.Overlay({ + const overlay = new Overlay({ id: options.id, element: cloned, autoPan: options.autoPan || false, diff --git a/web/client/components/map/openlayers/plugins/TileProviderLayer.js b/web/client/components/map/openlayers/plugins/TileProviderLayer.js index 54f5c45879..10223293ef 100644 --- a/web/client/components/map/openlayers/plugins/TileProviderLayer.js +++ b/web/client/components/map/openlayers/plugins/TileProviderLayer.js @@ -5,12 +5,13 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var assign = require('object-assign'); -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); -var TileProvider = require('../../../../utils/TileConfigProvider'); -var CoordinatesUtils = require('../../../../utils/CoordinatesUtils'); -const { getUrls, template } = require('../../../../utils/TileProviderUtils'); +import assign from 'object-assign'; +import Layers from '../../../../utils/openlayers/Layers'; +import TileProvider from '../../../../utils/TileConfigProvider'; +import CoordinatesUtils from '../../../../utils/CoordinatesUtils'; +import { getUrls, template } from '../../../../utils/TileProviderUtils'; +import XYZ from 'ol/source/XYZ'; +import TileLayer from 'ol/layer/Tile'; /*eslint-disable */ function lBoundsToOlExtent(bounds, destPrj){ @@ -22,11 +23,11 @@ function tileXYZToOpenlayersOptions(options) { let urls = options.url.match(/(\{s\})/) ? getUrls(options) : [template(options.url, options)]; let sourceOpt = assign({}, { urls: urls, - attributions: options.attribution ? [new ol.Attribution({ html: options.attribution})] : [], + attributions: options.attribution ? [options.attribution] : [], maxZoom: options.maxZoom ? options.maxZoom : 18, minZoom: options.minZoom ? options.minZoom : 0 // dosen't affect ol layer rendering UNSUPPORTED }); - let source = new ol.source.XYZ(sourceOpt); + let source = new XYZ(sourceOpt); let olOpt = assign({}, { opacity: options.opacity !== undefined ? options.opacity : 1, visible: options.visibility !== false, @@ -40,6 +41,6 @@ Layers.registerType('tileprovider', { create: (options) => { let [url, opt] = TileProvider.getLayerConfig(options.provider, options); opt.url = url; - return new ol.layer.Tile(tileXYZToOpenlayersOptions(opt)); + return new TileLayer(tileXYZToOpenlayersOptions(opt)); } }); diff --git a/web/client/components/map/openlayers/plugins/VectorLayer.js b/web/client/components/map/openlayers/plugins/VectorLayer.js index 923aca31e5..bc16037cae 100644 --- a/web/client/components/map/openlayers/plugins/VectorLayer.js +++ b/web/client/components/map/openlayers/plugins/VectorLayer.js @@ -6,22 +6,23 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -const VectorStyle = require('../VectorStyle'); -var ol = require('openlayers'); -const {isEqual} = require('lodash'); +import Layers from '../../../../utils/openlayers/Layers'; +import {getStyle} from '../VectorStyle'; +import isEqual from 'lodash/isEqual'; +import VectorSource from 'ol/source/Vector'; +import VectorLayer from 'ol/layer/Vector'; Layers.registerType('vector', { create: (options) => { let features = []; - const source = new ol.source.Vector({ + const source = new VectorSource({ features: features }); - const style = VectorStyle.getStyle(options); + const style = getStyle(options); - return new ol.layer.Vector({ + return new VectorLayer({ msId: options.id, source: source, visible: options.visibility !== false, @@ -39,7 +40,7 @@ Layers.registerType('vector', { } if (!isEqual(oldOptions.style, newOptions.style)) { - layer.setStyle(VectorStyle.getStyle(newOptions)); + layer.setStyle(getStyle(newOptions)); } }, render: () => { diff --git a/web/client/components/map/openlayers/plugins/WFS3Layer.js b/web/client/components/map/openlayers/plugins/WFS3Layer.js new file mode 100644 index 0000000000..29afb747f9 --- /dev/null +++ b/web/client/components/map/openlayers/plugins/WFS3Layer.js @@ -0,0 +1,128 @@ +/** + * Copyright 2018, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +import head from 'lodash/head'; +import urlParser from 'url'; + +import CoordinatesUtils from '../../../../utils/CoordinatesUtils'; +import MapUtils from '../../../../utils/MapUtils'; +import Layers from '../../../../utils/openlayers/Layers'; +import SecurityUtils from '../../../../utils/SecurityUtils'; + +import {get, getTransform} from 'ol/proj'; +import {applyTransform} from 'ol/extent'; +import TileGrid from 'ol/tilegrid/TileGrid'; +import VectorTileLayer from 'ol/layer/VectorTile'; +import VectorTile from 'ol/source/VectorTile'; +import MVT from 'ol/format/MVT'; + +import { isVectorFormat } from '../../../../utils/VectorTileUtils'; +import { OL_VECTOR_FORMATS, applyStyle } from '../../../../utils/openlayers/VectorTileUtils'; + +const createLayer = (options) => { + + const srs = CoordinatesUtils.normalizeSRS(options.srs || 'EPSG:3857', options.allowedSRS); + const projection = get(srs); + const metersPerUnit = projection.getMetersPerUnit(); + + const tilingScheme = head(options.tilingSchemes + && options.tilingSchemes.schemes + && options.tilingSchemes.schemes.filter(({ supportedCRS }) => supportedCRS === srs)); + + const { identifier: tilingSchemeId, tileMatrix, boundingBox } = tilingScheme || {}; + const scales = tileMatrix && tileMatrix.map(({ scaleDenominator }) => scaleDenominator); + const mapResolutions = MapUtils.getResolutions(); + + const scaleToResolution = s => s * 0.28E-3 / metersPerUnit; + const matrixResolutions = options.resolutions || scales && scales.map(scaleToResolution); + const resolutions = matrixResolutions || mapResolutions; + + const switchOriginXY = projection.getAxisOrientation().substr(0, 2) === 'ne'; + const origins = tileMatrix && tileMatrix + .map(({ topLeftCorner } = {}) => topLeftCorner) + .map(([ x, y ] = []) => switchOriginXY ? [y, x] : [x, y]); + + const tileSizes = tileMatrix && tileMatrix + .map(({tileWidth, tileHeight}) => [tileWidth, tileHeight]); + + const bbox = options.bbox; + + const extent = bbox + ? applyTransform([ + parseFloat(bbox.bounds.minx), + parseFloat(bbox.bounds.miny), + parseFloat(bbox.bounds.maxx), + parseFloat(bbox.bounds.maxy) + ], getTransform(bbox.crs, options.srs)) + : null; + + const tileGridExtent = boundingBox && boundingBox.lowerCorner && boundingBox.upperCorner + ? [ + ...boundingBox.lowerCorner, + ...boundingBox.upperCorner + ] + : null; + + const tileGrid = new TileGrid({ + extent: tileGridExtent, + minZoom: 0, + origins, + origin: !origins ? [20037508.3428, -20037508.3428] : undefined, + resolutions, + tileSizes, + tileSize: !tileSizes ? [256, 256] : undefined + }); + + let url = (options.url || '') + .replace(/\{tilingSchemeId\}/, tilingSchemeId) + .replace(/\{level\}/, '{z}') + .replace(/\{row\}/, '{y}') + .replace(/\{col\}/, '{x}'); + + let queryParameters = { }; + SecurityUtils.addAuthenticationParameter(url, queryParameters, options.securityToken); + + const layerUrl = decodeURI(url); + const queryParametersString = urlParser.format({ query: { ...queryParameters } }); + + const Format = isVectorFormat(options.format) && OL_VECTOR_FORMATS[options.format] || MVT; + + const source = new VectorTile({ + format: new Format({ + dataProjection: srs, + layerName: '_layer_' + }), + tileGrid, + url: layerUrl + queryParametersString + }); + + const layer = new VectorTileLayer({ + extent, + msId: options.id, + source: source, + visible: options.visibility !== false, + zIndex: options.zIndex + }); + + applyStyle(options.vectorStyle, layer); + + return layer; +}; +Layers.registerType('wfs3', { + create: createLayer, + update: (layer, newOptions, oldOptions) => { + if (oldOptions.securityToken !== newOptions.securityToken + || oldOptions.srs !== newOptions.srs) { + return createLayer(newOptions); + } + return null; + }, + render: () => { + return null; + } +}); diff --git a/web/client/components/map/openlayers/plugins/WMSLayer.js b/web/client/components/map/openlayers/plugins/WMSLayer.js index 4d9c91ffbe..3c4d246ea6 100644 --- a/web/client/components/map/openlayers/plugins/WMSLayer.js +++ b/web/client/components/map/openlayers/plugins/WMSLayer.js @@ -5,21 +5,38 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const Message = require('../../../../components/I18N/Message'); -const Layers = require('../../../../utils/openlayers/Layers'); -const ol = require('openlayers'); -const {isNil, union} = require('lodash'); -const objectAssign = require('object-assign'); -const CoordinatesUtils = require('../../../../utils/CoordinatesUtils'); -const ProxyUtils = require('../../../../utils/ProxyUtils'); -const { isArray, castArray } = require('lodash'); -const {optionsToVendorParams} = require('../../../../utils/VendorParamsUtils'); -const SecurityUtils = require('../../../../utils/SecurityUtils'); -const { creditsToAttribution } = require('../../../../utils/LayersUtils'); +import React from 'react'; +import Message from '../../../../components/I18N/Message'; +import Layers from '../../../../utils/openlayers/Layers'; +import isNil from 'lodash/isNil'; +import isEqual from 'lodash/isEqual'; +import union from 'lodash/union'; +import isArray from 'lodash/isArray'; +import assign from 'object-assign'; + +import CoordinatesUtils from '../../../../utils/CoordinatesUtils'; +import ProxyUtils from '../../../../utils/ProxyUtils'; + +import {optionsToVendorParams} from '../../../../utils/VendorParamsUtils'; +import SecurityUtils from '../../../../utils/SecurityUtils'; +import { creditsToAttribution } from '../../../../utils/LayersUtils'; + +import MapUtils from '../../../../utils/MapUtils'; +import ElevationUtils from '../../../../utils/ElevationUtils'; + +import ImageLayer from 'ol/layer/Image'; +import ImageWMS from 'ol/source/ImageWMS'; +import {get} from 'ol/proj'; +import TileGrid from 'ol/tilegrid/TileGrid'; +import TileLayer from 'ol/layer/Tile'; +import TileWMS from 'ol/source/TileWMS'; + +import VectorTileSource from 'ol/source/VectorTile'; +import VectorTileLayer from 'ol/layer/VectorTile'; + +import { isVectorFormat } from '../../../../utils/VectorTileUtils'; +import { OL_VECTOR_FORMATS, applyStyle } from '../../../../utils/openlayers/VectorTileUtils'; -const mapUtils = require('../../../../utils/MapUtils'); -const ElevationUtils = require('../../../../utils/ElevationUtils'); /** @param {object} options of the layer @return the Openlayers options from the layers ones and/or default. @@ -28,7 +45,7 @@ const ElevationUtils = require('../../../../utils/ElevationUtils'); function wmsToOpenlayersOptions(options) { const params = optionsToVendorParams(options); // NOTE: can we use opacity to manage visibility? - const result = objectAssign({}, options.baseParams, { + const result = assign({}, options.baseParams, { LAYERS: options.name, STYLES: options.style || "", FORMAT: options.format || 'image/png', @@ -37,7 +54,7 @@ function wmsToOpenlayersOptions(options) { CRS: CoordinatesUtils.normalizeSRS(options.srs || 'EPSG:3857', options.allowedSRS), TILED: !isNil(options.tiled) ? options.tiled : true, VERSION: options.version || "1.3.0" - }, objectAssign( + }, assign( {}, (options._v_ ? {_v_: options._v_} : {}), (params || {}) @@ -76,11 +93,10 @@ function elevationLoadFunction(forceProxy, imageTile, src) { function addTileLoadFunction(sourceOptions, options) { if (options.useForElevation) { - return objectAssign({}, sourceOptions, { tileLoadFunction: elevationLoadFunction.bind(null, [options.forceProxy]) }); - // return objectAssign({}, sourceOptions, { tileLoadFunction: (imageTile, src) => { imageTile.getImage().src = src; } }); + return assign({}, sourceOptions, { tileLoadFunction: elevationLoadFunction.bind(null, [options.forceProxy]) }); } if (options.forceProxy) { - return objectAssign({}, sourceOptions, {tileLoadFunction: proxyTileLoadFunction}); + return assign({}, sourceOptions, {tileLoadFunction: proxyTileLoadFunction}); } return sourceOptions; } @@ -114,155 +130,182 @@ function getElevation(pos) { return ; } } -const toOLAttributions = credits => credits && creditsToAttribution(credits) ? castArray(creditsToAttribution(credits)) : undefined; +const toOLAttributions = credits => credits && creditsToAttribution(credits) || undefined; -Layers.registerType('wms', { - create: (options, map) => { - const urls = getWMSURLs(isArray(options.url) ? options.url : [options.url]); - const queryParameters = wmsToOpenlayersOptions(options) || {}; - urls.forEach(url => SecurityUtils.addAuthenticationParameter(url, queryParameters, options.securityToken)); - if (options.singleTile) { - return new ol.layer.Image({ - opacity: options.opacity !== undefined ? options.opacity : 1, - visible: options.visibility !== false, - zIndex: options.zIndex, - source: new ol.source.ImageWMS({ - url: urls[0], - attributions: toOLAttributions(options.credits), - params: queryParameters, - ratio: options.ratio || 1 - }) - }); - } - const mapSrs = map && map.getView() && map.getView().getProjection() && map.getView().getProjection().getCode() || 'EPSG:3857'; - const extent = ol.proj.get(CoordinatesUtils.normalizeSRS(options.srs || mapSrs, options.allowedSRS)).getExtent(); - const sourceOptions = addTileLoadFunction({ - attributions: toOLAttributions(options.credits), - urls: urls, - params: queryParameters, - tileGrid: new ol.tilegrid.TileGrid({ - extent: extent, - resolutions: mapUtils.getResolutions(), - tileSize: options.tileSize ? options.tileSize : 256, - origin: options.origin ? options.origin : [extent[0], extent[1]] - }) - }, options); - const layer = new ol.layer.Tile({ +const createLayer = (options, map) => { + const urls = getWMSURLs(isArray(options.url) ? options.url : [options.url]); + const queryParameters = wmsToOpenlayersOptions(options) || {}; + urls.forEach(url => SecurityUtils.addAuthenticationParameter(url, queryParameters, options.securityToken)); + + const vectorFormat = isVectorFormat(options.format); + + if (options.singleTile && !vectorFormat) { + return new ImageLayer({ opacity: options.opacity !== undefined ? options.opacity : 1, visible: options.visibility !== false, zIndex: options.zIndex, - source: new ol.source.TileWMS(sourceOptions) + source: new ImageWMS({ + url: urls[0], + attributions: toOLAttributions(options.credits), + params: queryParameters, + ratio: options.ratio || 1 + }) }); - layer.set('map', map); - if (options.useForElevation) { - layer.set('nodata', options.nodata); - layer.set('getElevation', getElevation.bind(layer)); + } + const mapSrs = map && map.getView() && map.getView().getProjection() && map.getView().getProjection().getCode() || 'EPSG:3857'; + const extent = get(CoordinatesUtils.normalizeSRS(options.srs || mapSrs, options.allowedSRS)).getExtent(); + const sourceOptions = addTileLoadFunction({ + attributions: toOLAttributions(options.credits), + urls: urls, + params: queryParameters, + tileGrid: new TileGrid({ + extent: extent, + resolutions: MapUtils.getResolutions(), + tileSize: options.tileSize ? options.tileSize : 256, + origin: options.origin ? options.origin : [extent[0], extent[1]] + }) + }, options); + const wmsSource = new TileWMS({ ...sourceOptions }); + const layerConfig = { + opacity: options.opacity !== undefined ? options.opacity : 1, + visible: options.visibility !== false, + zIndex: options.zIndex + }; + let layer; + if (vectorFormat) { + layer = new VectorTileLayer({ + ...layerConfig, + source: new VectorTileSource({ + ...sourceOptions, + format: new OL_VECTOR_FORMATS[options.format]({ + layerName: '_layer_' + }), + tileUrlFunction: (tileCoord, pixelRatio, projection) => wmsSource.tileUrlFunction(tileCoord, pixelRatio, projection) + }) + }); + } else { + layer = new TileLayer({ + ...layerConfig, + source: wmsSource + }); + } + layer.set('map', map); + if (vectorFormat) { + layer.set('wmsSource', wmsSource); + if (options.vectorStyle) { + applyStyle(options.vectorStyle, layer); } - return layer; - }, + } + if (options.useForElevation) { + layer.set('nodata', options.nodata); + layer.set('getElevation', getElevation.bind(layer)); + } + return layer; +}; + +const mustCreateNewLayer = (oldOptions, newOptions) => { + return (oldOptions.singleTile !== newOptions.singleTile + || oldOptions.securityToken !== newOptions.securityToken + || oldOptions.ratio !== newOptions.ratio + // no way to remove attribution when credits are removed, so have re-create the layer is needed. Seems to be solved in OL v5.3.0, due to the ol commit 9b8232f65b391d5d381d7a99a7cd070fc36696e9 (https://github.com/openlayers/openlayers/pull/7329) + || oldOptions.credits !== newOptions.credits && !newOptions.credits + || isVectorFormat(oldOptions.format) !== isVectorFormat(newOptions.format) + || isVectorFormat(oldOptions.format) && isVectorFormat(newOptions.format) && oldOptions.format !== newOptions.format + ); +}; + +Layers.registerType('wms', { + create: createLayer, update: (layer, newOptions, oldOptions, map) => { - if (oldOptions && layer && layer.getSource() && layer.getSource().updateParams) { - let changed = false; + const newIsVector = isVectorFormat(newOptions.format); + + if (mustCreateNewLayer(oldOptions, newOptions)) { + // TODO: do we need to clean anything before re-creating stuff from scratch? + return createLayer(newOptions, map); + } + let needsRefresh = false; + if (newIsVector && newOptions.vectorStyle && !isEqual(newOptions.vectorStyle, oldOptions.vectorStyle || {})) { + applyStyle(newOptions.vectorStyle, layer); + needsRefresh = true; + } + + const wmsSource = layer.get('wmsSource') || layer.getSource(); + const vectorSource = newIsVector ? layer.getSource() : null; + + if (oldOptions.srs !== newOptions.srs) { + const extent = get(CoordinatesUtils.normalizeSRS(newOptions.srs, newOptions.allowedSRS)).getExtent(); + if (newOptions.singleTile && !newIsVector) { + layer.setExtent(extent); + } else { + const tileGrid = new TileGrid({ + extent: extent, + resolutions: MapUtils.getResolutions(), + tileSize: newOptions.tileSize ? newOptions.tileSize : 256, + origin: newOptions.origin ? newOptions.origin : [extent[0], extent[1]] + }); + wmsSource.tileGrid = tileGrid; + if (vectorSource) { + vectorSource.tileGrid = tileGrid; + } + } + needsRefresh = true; + } + + if (oldOptions.credits !== newOptions.credits && newOptions.credits) { + wmsSource.setAttributions(toOLAttributions(newOptions.credits)); + needsRefresh = true; + } + + let changed = false; + let oldParams; + let newParams; + if (oldOptions && wmsSource && wmsSource.updateParams) { if (oldOptions.params && newOptions.params) { changed = union( - Object.keys(oldOptions.params), - Object.keys(newOptions.params) - ).reduce((found, param) => { - if (newOptions.params[param] !== oldOptions.params[param]) { - return true; - } - return found; - }, false); + Object.keys(oldOptions.params), + Object.keys(newOptions.params) + ).reduce((found, param) => { + if (newOptions.params[param] !== oldOptions.params[param]) { + return true; + } + return found; + }, false); } else if ((!oldOptions.params && newOptions.params) || (oldOptions.params && !newOptions.params)) { changed = true; } - let oldParams = wmsToOpenlayersOptions(oldOptions); - let newParams = wmsToOpenlayersOptions(newOptions); + oldParams = wmsToOpenlayersOptions(oldOptions); + newParams = wmsToOpenlayersOptions(newOptions); changed = changed || ["LAYERS", "STYLES", "FORMAT", "TRANSPARENT", "TILED", "VERSION", "_v_", "CQL_FILTER", "SLD", "VIEWPARAMS"].reduce((found, param) => { if (oldParams[param] !== newParams[param]) { return true; } return found; }, false); - if (oldOptions.srs !== newOptions.srs) { - const extent = ol.proj.get(CoordinatesUtils.normalizeSRS(newOptions.srs, newOptions.allowedSRS)).getExtent(); - layer.getSource().tileGrid = new ol.tilegrid.TileGrid({ - extent: extent, - resolutions: mapUtils.getResolutions(), - tileSize: newOptions.tileSize ? newOptions.tileSize : 256, - origin: newOptions.origin ? newOptions.origin : [extent[0], extent[1]] - }); + + needsRefresh = needsRefresh || changed; + } + + if (needsRefresh) { + // forces tile cache drop + // this prevents old cached tiles at lower zoom levels to be + // rendered during new params load, but causes a blink glitch. + // TODO: find out a way to refresh only once to clear lower zoom level cache. + if (wmsSource.refresh) { + wmsSource.refresh(); + } + if (vectorSource) { + vectorSource.clear(); + vectorSource.refresh(); } if (changed) { - const params = objectAssign(newParams, SecurityUtils.addAuthenticationToSLD(optionsToVendorParams(newOptions) || {}, newOptions)); - const source = layer.getSource(); - // forces tile cache drop - // this prevents old cached tiles at lower zoom levels to be - // rendered during new params load, but causes a blink glitch. - // TODO: find out a way to refresh only once to clear lower zoom level cache. - if (layer.getSource().refresh ) { - layer.getSource().refresh(); - } - source.updateParams(objectAssign(params, Object.keys(oldParams || {}).reduce((previous, key) => { - return params[key] ? previous : objectAssign(previous, { + const params = assign(newParams, SecurityUtils.addAuthenticationToSLD(optionsToVendorParams(newOptions) || {}, newOptions)); + + wmsSource.updateParams(assign(params, Object.keys(oldParams || {}).reduce((previous, key) => { + return params[key] ? previous : assign(previous, { [key]: undefined }); }, {}))); - - } - if (oldOptions.credits !== newOptions.credits && newOptions.credits) { - layer.getSource().setAttributions(toOLAttributions(newOptions.credits)); - } - if (oldOptions.singleTile !== newOptions.singleTile - || oldOptions.securityToken !== newOptions.securityToken - || oldOptions.ratio !== newOptions.ratio - // no way to remove attribution when credits are removed, so have re-create the layer is needed. Seems to be solved in OL v5.3.0, due to the ol commit 9b8232f65b391d5d381d7a99a7cd070fc36696e9 (https://github.com/openlayers/openlayers/pull/7329) - || oldOptions.credits !== newOptions.credits && !newOptions.credits - ) { - const urls = getWMSURLs(isArray(newOptions.url) ? newOptions.url : [newOptions.url]); - const queryParameters = wmsToOpenlayersOptions(newOptions) || {}; - urls.forEach(url => SecurityUtils.addAuthenticationParameter(url, queryParameters, newOptions.securityToken)); - let newLayer; - if (newOptions.singleTile) { - // return the Image Layer with the related source - newLayer = new ol.layer.Image({ - opacity: newOptions.opacity !== undefined ? newOptions.opacity : 1, - visible: newOptions.visibility !== false, - zIndex: newOptions.zIndex, - source: new ol.source.ImageWMS({ - attributions: toOLAttributions(newOptions.credits), - url: urls[0], - params: queryParameters, - ratio: newOptions.ratio || 1 - }) - }); - } else { - // return the Tile Layer with the related source - const mapSrs = map && map.getView() && map.getView().getProjection() && map.getView().getProjection().getCode() || 'EPSG:3857'; - const extent = ol.proj.get(CoordinatesUtils.normalizeSRS(newOptions.srs || mapSrs, newOptions.allowedSRS)).getExtent(); - newLayer = new ol.layer.Tile({ - opacity: newOptions.opacity !== undefined ? newOptions.opacity : 1, - visible: newOptions.visibility !== false, - zIndex: newOptions.zIndex, - source: new ol.source.TileWMS(objectAssign({ - attributions: toOLAttributions(newOptions.credits), - urls: urls, - params: queryParameters, - tileGrid: new ol.tilegrid.TileGrid({ - // TODO: custom grid sets extents - extent: extent, - // TODO: custom grid sets resolutions and tile size (needed to generate resolutions) - resolutions: mapUtils.getResolutions(), - tileSize: newOptions.tileSize ? newOptions.tileSize : 256, - // TODO: GWC grid sets with `alignTopLeft=true` may require `extent[0], extent[3]` - origin: newOptions.origin ? newOptions.origin : [extent[0], extent[1]] - }) - }, newOptions.forceProxy ? {tileLoadFunction: proxyTileLoadFunction} : {})) - }); - } - return newLayer; } - return null; } } }); diff --git a/web/client/components/map/openlayers/plugins/WMTSLayer.js b/web/client/components/map/openlayers/plugins/WMTSLayer.js index b83ebe6227..ffb614617c 100644 --- a/web/client/components/map/openlayers/plugins/WMTSLayer.js +++ b/web/client/components/map/openlayers/plugins/WMTSLayer.js @@ -6,15 +6,37 @@ * LICENSE file in the root directory of this source tree. */ -var Layers = require('../../../../utils/openlayers/Layers'); -var ol = require('openlayers'); -const { castArray, head, last } = require('lodash'); -const SecurityUtils = require('../../../../utils/SecurityUtils'); -const WMTSUtils = require('../../../../utils/WMTSUtils'); -const CoordinatesUtils = require('../../../../utils/CoordinatesUtils'); -const mapUtils = require('../../../../utils/MapUtils'); -const assign = require('object-assign'); -const urlParser = require('url'); +import Layers from '../../../../utils/openlayers/Layers'; + +import castArray from 'lodash/castArray'; +import head from 'lodash/head'; +import last from 'lodash/last'; + +import SecurityUtils from '../../../../utils/SecurityUtils'; +import WMTSUtils from '../../../../utils/WMTSUtils'; +import CoordinatesUtils from '../../../../utils/CoordinatesUtils'; +import MapUtils from '../../../../utils/MapUtils'; +import { isVectorFormat} from '../../../../utils/VectorTileUtils'; +import urlParser from 'url'; + +import {get, getTransform} from 'ol/proj'; +import {applyTransform} from 'ol/extent'; +import TileLayer from 'ol/layer/Tile'; +import VectorTileLayer from 'ol/layer/VectorTile'; +import WMTS from 'ol/source/WMTS'; +import VectorTile from 'ol/source/VectorTile'; +import WMTSTileGrid from 'ol/tilegrid/WMTS'; +import MVT from 'ol/format/MVT'; +import GeoJSON from 'ol/format/GeoJSON'; +import TopoJSON from 'ol/format/TopoJSON'; + +import { getStyle } from '../VectorStyle'; + +const OL_VECTOR_FORMATS = { + 'application/vnd.mapbox-vector-tile': MVT, + 'application/json;type=geojson': GeoJSON, + 'application/json;type=topojson': TopoJSON +}; function getWMSURLs(urls) { return urls.map((url) => url.split("\?")[0]); @@ -24,12 +46,12 @@ const createLayer = options => { // options.urls is an alternative name of URL. const urls = getWMSURLs(castArray(options.url)); const srs = CoordinatesUtils.normalizeSRS(options.srs || 'EPSG:3857', options.allowedSRS); - const projection = ol.proj.get(srs); + const projection = get(srs); const metersPerUnit = projection.getMetersPerUnit(); const tilMatrixSetName = WMTSUtils.getTileMatrixSet(options.tileMatrixSet, srs, options.allowedSRS, options.matrixIds); const tileMatrixSet = head(options.tileMatrixSet.filter(tM => tM['ows:Identifier'] === tilMatrixSetName)); const scales = tileMatrixSet && tileMatrixSet.TileMatrix.map(t => t.ScaleDenominator); - const mapResolutions = mapUtils.getResolutions(); + const mapResolutions = MapUtils.getResolutions(); /* * WMTS assumes a DPI 90.7 instead of 96 as documented in the WMTSCapabilities document: * "The tile matrix set that has scale values calculated based on the dpi defined by OGC specification @@ -55,12 +77,12 @@ const createLayer = options => { const bbox = options.bbox; const extent = bbox - ? ol.extent.applyTransform([ + ? applyTransform([ parseFloat(bbox.bounds.minx), parseFloat(bbox.bounds.miny), parseFloat(bbox.bounds.maxx), parseFloat(bbox.bounds.maxy) - ], ol.proj.getTransform(bbox.crs, options.srs)) + ], getTransform(bbox.crs, options.srs)) : null; let queryParameters = {}; @@ -75,36 +97,59 @@ const createLayer = options => { // Temporary fix for https://github.com/openlayers/openlayers/issues/8700 . It should be solved in OL 5.3.0 // it's exclusive so the map lower resolution that draws the image in less then 0.5 pixels have to be the maxResolution const maxResolution = options.maxResolution || last(mapResolutions.filter((r = []) => resolutions[0] / r * TILE_SIZE < 0.5)); - return new ol.layer.Tile({ + const format = (options.availableFormats || []).indexOf(options.format) !== -1 && options.format + || !options.availableFormats && options.format || 'image/png'; + const isVector = isVectorFormat(format); + + const wmtsOptions = { + requestEncoding, + urls: urls.map(u => u + queryParametersString), + layer: options.name, + version: options.version || "1.0.0", + matrixSet: tilMatrixSetName, + format, + style: options.style, + tileGrid: new WMTSTileGrid({ + origins, + origin: !origins ? [20037508.3428, -20037508.3428] : undefined, // Either origin or origins must be configured, never both. + // extent: extent, + resolutions, + matrixIds, + // TODO: matrixLimits from ranges + tileSize: options.tileSize || [TILE_SIZE, TILE_SIZE] + }), + wrapX: true + }; + + const wmtsSource = new WMTS(wmtsOptions); + const Layer = isVector ? VectorTileLayer : TileLayer; + const wmtsLayer = new Layer({ opacity: options.opacity !== undefined ? options.opacity : 1, zIndex: options.zIndex, extent: extent, maxResolution, visible: options.visibility !== false, - source: new ol.source.WMTS(assign({ - requestEncoding, - urls: urls.map(u => u + queryParametersString), - layer: options.name, - version: options.version || "1.0.0", - matrixSet: tilMatrixSetName, - format: options.format || 'image/png', - style: options.style, - tileGrid: new ol.tilegrid.WMTS({ - origins, - origin: !origins ? [20037508.3428, -20037508.3428] : undefined, // Either origin or origins must be configured, never both. - // extent: extent, - resolutions, - matrixIds, - // TODO: matrixLimits from ranges - tileSize: options.tileSize || [TILE_SIZE, TILE_SIZE] - }), - wrapX: true - })) + source: isVector + ? new VectorTile({ + ...wmtsOptions, + format: new OL_VECTOR_FORMATS[options.format]({ + dataProjection: srs + }), + tileUrlFunction: (...args) => wmtsSource.tileUrlFunction(...args) + }) + : wmtsSource }); + + if (isVector) wmtsLayer.setStyle(getStyle(options)); + + return wmtsLayer; }; const updateLayer = (layer, newOptions, oldOptions) => { - if (oldOptions.securityToken !== newOptions.securityToken || oldOptions.srs !== newOptions.srs) { + if (oldOptions.securityToken !== newOptions.securityToken + || oldOptions.srs !== newOptions.srs + || oldOptions.format !== newOptions.format + || oldOptions.style !== newOptions.style) { return createLayer(newOptions); } return null; diff --git a/web/client/components/map/openlayers/plugins/index.js b/web/client/components/map/openlayers/plugins/index.js index 614c5d53dd..96079a765d 100644 --- a/web/client/components/map/openlayers/plugins/index.js +++ b/web/client/components/map/openlayers/plugins/index.js @@ -7,14 +7,15 @@ */ module.exports = { - BingLayer: require('./BingLayer'), - GoogleLayer: require('./GoogleLayer'), - GraticuleLayer: require('./GraticuleLayer'), - MapQuest: require('./MapQuest'), - OSMLayer: require('./OSMLayer'), - OverlayLayer: require('./OverlayLayer'), - TileProviderLayer: require('./TileProviderLayer'), - VectorLayer: require('./VectorLayer'), - WMSLayer: require('./WMSLayer'), - WMTSLayer: require('./WMTSLayer') + BingLayer: require('./BingLayer').default, + GoogleLayer: require('./GoogleLayer').default, + GraticuleLayer: require('./GraticuleLayer').default, + MapQuest: require('./MapQuest').default, + OSMLayer: require('./OSMLayer').default, + OverlayLayer: require('./OverlayLayer').default, + TileProviderLayer: require('./TileProviderLayer').default, + VectorLayer: require('./VectorLayer').default, + WFS3Layer: require('./WFS3Layer').default, + WMSLayer: require('./WMSLayer').default, + WMTSLayer: require('./WMTSLayer').default }; diff --git a/web/client/components/map/openlayers/snapshot/GrabMap.jsx b/web/client/components/map/openlayers/snapshot/GrabMap.jsx index 52c42e4cc7..76b4a03abc 100644 --- a/web/client/components/map/openlayers/snapshot/GrabMap.jsx +++ b/web/client/components/map/openlayers/snapshot/GrabMap.jsx @@ -1,4 +1,3 @@ -const PropTypes = require('prop-types'); /** * Copyright 2015, GeoSolutions Sas. * All rights reserved. @@ -6,14 +5,17 @@ const PropTypes = require('prop-types'); * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var React = require('react'); -var {LMap, +import PropTypes from 'prop-types'; +import React from 'react'; +import {LMap, LLayer, Feature -} = require('../index'); -const assign = require('object-assign'); -const ConfigUtils = require('../../../../utils/ConfigUtils'); -require("./snapshotMapStyle.css"); +} from '../index'; +import assign from 'object-assign'; +import ConfigUtils from '../../../../utils/ConfigUtils'; +import './snapshotMapStyle.css'; + +import '../../../map/openlayers/plugins/index'; /** * GrabMap for OpenLayers map generate a fake-map, hidden, and waits for the @@ -21,7 +23,7 @@ require("./snapshotMapStyle.css"); * In order to avoid cross origin issues, the allowTaint property have to be set * to false if you are not sure that the items come from the same orgin. */ -class GrabOlMap extends React.Component { +export default class GrabOlMap extends React.Component { static propTypes = { id: PropTypes.node, config: ConfigUtils.PropTypes.config, @@ -154,7 +156,3 @@ class GrabOlMap extends React.Component { }; } - -require('../../../map/openlayers/plugins/index'); - -module.exports = GrabOlMap; diff --git a/web/client/components/map/openlayers/snapshot/Preview.jsx b/web/client/components/map/openlayers/snapshot/Preview.jsx index 87ca4d216d..02a51adf3e 100644 --- a/web/client/components/map/openlayers/snapshot/Preview.jsx +++ b/web/client/components/map/openlayers/snapshot/Preview.jsx @@ -1,4 +1,3 @@ -const PropTypes = require('prop-types'); /** * Copyright 2015, GeoSolutions Sas. * All rights reserved. @@ -6,10 +5,11 @@ const PropTypes = require('prop-types'); * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const React = require('react'); -const ConfigUtils = require('../../../../utils/ConfigUtils'); -const ProxyUtils = require('../../../../utils/ProxyUtils'); -const {isEqual} = require('lodash'); +import PropTypes from 'prop-types'; +import React from 'react'; +import ConfigUtils from '../../../../utils/ConfigUtils'; +import ProxyUtils from '../../../../utils/ProxyUtils'; +import isEqual from 'lodash/isEqual'; /** * Preview for OpenLayers map generate is a fast system to get the image @@ -17,7 +17,7 @@ const {isEqual} = require('lodash'); * if it is not tainted, this can be used also to generate snapshot * (extracting the image URL from the canvas). */ -class GrabLMap extends React.Component { +export default class GrabLMap extends React.Component { static propTypes = { config: ConfigUtils.PropTypes.config, layers: PropTypes.array, @@ -166,5 +166,3 @@ class GrabLMap extends React.Component { return this.refs.canvas.toDataURL(); }; } - -module.exports = GrabLMap; diff --git a/web/client/components/map/openlayers/snapshot/__tests__/GrabMap-test.jsx b/web/client/components/map/openlayers/snapshot/__tests__/GrabMap-test.jsx index 79344600a4..52f2a71a4d 100644 --- a/web/client/components/map/openlayers/snapshot/__tests__/GrabMap-test.jsx +++ b/web/client/components/map/openlayers/snapshot/__tests__/GrabMap-test.jsx @@ -5,11 +5,11 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var expect = require('expect'); +import expect from 'expect'; -var React = require('react'); -var ReactDOM = require('react-dom'); -var GrabMap = require('../GrabMap'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import GrabMap from '../GrabMap'; describe("the OL GrabMap component", () => { beforeEach((done) => { @@ -27,11 +27,6 @@ describe("the OL GrabMap component", () => { const tb = ReactDOM.render(, document.getElementById("snap")); expect(tb).toExist(); }); - /* it('component update', () => { - let tb = ReactDOM.render(, document.getElementById("snap")); - expect(tb).toExist(); - tb = ReactDOM.render(, document.getElementById("snap")); - });*/ it('component snapshot img creation', (done) => { let layers = [{ "source": "mapquest", diff --git a/web/client/components/map/openlayers/snapshot/__tests__/Preview-test.jsx b/web/client/components/map/openlayers/snapshot/__tests__/Preview-test.jsx index ce7e4fd290..beda56b6fe 100644 --- a/web/client/components/map/openlayers/snapshot/__tests__/Preview-test.jsx +++ b/web/client/components/map/openlayers/snapshot/__tests__/Preview-test.jsx @@ -5,16 +5,16 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -var expect = require('expect'); +import expect from 'expect'; -var React = require('react'); -var ReactDOM = require('react-dom'); -var GrabMap = require('../Preview'); -var OLMap = require('../../../../map/openlayers/Map.jsx'); +import React from 'react'; +import ReactDOM from 'react-dom'; +import GrabMap from '../Preview'; +import OLMap from '../../../../map/openlayers/Map'; -require('../../../../../utils/openlayers/Layers'); -require('../../../../map/openlayers/plugins/OSMLayer'); +import '../../../../../utils/openlayers/Layers'; +import '../../../../map/openlayers/plugins/OSMLayer'; describe("test the OL Snapshot Preview component", () => { beforeEach((done) => { diff --git a/web/client/components/map/plugins/openlayers.js b/web/client/components/map/plugins/openlayers.js index 3047538d1e..6161de8727 100644 --- a/web/client/components/map/plugins/openlayers.js +++ b/web/client/components/map/plugins/openlayers.js @@ -9,14 +9,14 @@ module.exports = () => { require('../openlayers/plugins/index'); return { - Map: require('../openlayers/Map'), - Layer: require('../openlayers/Layer'), - Feature: require('../openlayers/Feature'), - Locate: require('../openlayers/Locate'), - MeasurementSupport: require('../openlayers/MeasurementSupport'), - Overview: require('../openlayers/Overview'), - ScaleBar: require('../openlayers/ScaleBar'), - DrawSupport: require('../openlayers/DrawSupport') + Map: require('../openlayers/Map').default, + Layer: require('../openlayers/Layer').default, + Feature: require('../openlayers/Feature').default, + Locate: require('../openlayers/Locate').default, + MeasurementSupport: require('../openlayers/MeasurementSupport').default, + Overview: require('../openlayers/Overview').default, + ScaleBar: require('../openlayers/ScaleBar').default, + DrawSupport: require('../openlayers/DrawSupport').default }; }; diff --git a/web/client/components/mapcontrols/Snapshot/SnapshotSupport.jsx b/web/client/components/mapcontrols/Snapshot/SnapshotSupport.jsx index 8bb84c6d73..18ec4c1f93 100644 --- a/web/client/components/mapcontrols/Snapshot/SnapshotSupport.jsx +++ b/web/client/components/mapcontrols/Snapshot/SnapshotSupport.jsx @@ -7,5 +7,6 @@ */ module.exports = (mapType) => { - return require('../../map/' + mapType + '/SnapshotSupport'); + const SnapshotSupport = require('../../map/' + mapType + '/SnapshotSupport'); + return SnapshotSupport.default || SnapshotSupport; }; diff --git a/web/client/components/print/MapPreview.jsx b/web/client/components/print/MapPreview.jsx index 629b611520..c47b41ede6 100644 --- a/web/client/components/print/MapPreview.jsx +++ b/web/client/components/print/MapPreview.jsx @@ -57,10 +57,11 @@ class MapPreview extends React.Component { }; componentWillMount() { - PMap = require('../map/' + this.props.mapType + '/Map'); - Layer = require('../map/' + this.props.mapType + '/Layer'); + const mapComponents = require('../map/' + this.props.mapType + '/index'); + PMap = mapComponents.LMap; + Layer = mapComponents.LLayer; + Feature = mapComponents.Feature; require('../map/' + this.props.mapType + '/plugins/index'); - Feature = require('../map/' + this.props.mapType + '/index').Feature; } getRatio = () => { diff --git a/web/client/examples/api/index.html b/web/client/examples/api/index.html index 80ca465dd0..d87b48f0ef 100644 --- a/web/client/examples/api/index.html +++ b/web/client/examples/api/index.html @@ -7,7 +7,6 @@ - @@ -18,7 +17,6 @@ - diff --git a/web/client/index.html b/web/client/index.html index 2dba99399b..c0fff91c0c 100644 --- a/web/client/index.html +++ b/web/client/index.html @@ -86,13 +86,11 @@ - - diff --git a/web/client/indexTemplate.html b/web/client/indexTemplate.html index bab93731bc..53e736f90c 100644 --- a/web/client/indexTemplate.html +++ b/web/client/indexTemplate.html @@ -86,13 +86,11 @@ - - diff --git a/web/client/plugins/MapImport.jsx b/web/client/plugins/MapImport.jsx index 8201aa59e2..ac1f8382f1 100644 --- a/web/client/plugins/MapImport.jsx +++ b/web/client/plugins/MapImport.jsx @@ -18,6 +18,7 @@ const {toggleControl} = require('../actions/controls'); const assign = require('object-assign'); const {Glyphicon} = require('react-bootstrap'); +const {mapTypeSelector} = require('../selectors/maptype'); module.exports = { MapImportPlugin: assign({loadPlugin: (resolve) => { @@ -32,7 +33,8 @@ module.exports = { bbox: state.mapimport && state.mapimport.bbox || null, success: state.mapimport && state.mapimport.success || null, errors: state.mapimport && state.mapimport.errors || null, - shapeStyle: state.style || {} + shapeStyle: state.style || {}, + mapType: mapTypeSelector(state) } ), { setLayers, diff --git a/web/client/plugins/Snapshot.jsx b/web/client/plugins/Snapshot.jsx index 1b559080f6..4d83699eb4 100644 --- a/web/client/plugins/Snapshot.jsx +++ b/web/client/plugins/Snapshot.jsx @@ -14,6 +14,7 @@ const {onCreateSnapshot, changeSnapshotState, saveImage, onRemoveSnapshot, onSna const {mapSelector} = require('../selectors/map'); const {layersSelector} = require('../selectors/layers'); +const {mapTypeSelector} = require('../selectors/maptype'); const {toggleControl} = require('../actions/controls'); @@ -23,12 +24,14 @@ const {Glyphicon} = require('react-bootstrap'); const snapshotSelector = createSelector([ mapSelector, + mapTypeSelector, layersSelector, (state) => state.controls && state.controls.toolbar && state.controls.toolbar.active === "snapshot" || state.controls.snapshot && state.controls.snapshot.enabled, (state) => state.browser, (state) => state.snapshot || {queue: []} -], (map, layers, active, browser, snapshot) => ({ +], (map, mapType, layers, active, browser, snapshot) => ({ map, + mapType, layers, active, browser, diff --git a/web/client/plugins/map/openlayers/index.js b/web/client/plugins/map/openlayers/index.js index 5e025686ff..1986ecdb8d 100644 --- a/web/client/plugins/map/openlayers/index.js +++ b/web/client/plugins/map/openlayers/index.js @@ -11,14 +11,14 @@ const addI18NProps = require('../../../components/I18N/enhancers/addI18NProps'); const addFormatNumber = addI18NProps(['formatNumber']); module.exports = { - LMap: require('../../../components/map/openlayers/Map'), - Layer: require('../../../components/map/openlayers/Layer'), - Feature: require('../../../components/map/openlayers/Feature'), - Locate: require('../../../components/map/openlayers/Locate'), - MeasurementSupport: addFormatNumber(require('../../../components/map/openlayers/MeasurementSupport')), - Overview: require('../../../components/map/openlayers/Overview'), - ScaleBar: require('../../../components/map/openlayers/ScaleBar'), - DrawSupport: require('../../../components/map/openlayers/DrawSupport'), - HighlightFeatureSupport: require('../../../components/map/openlayers/HighlightFeatureSupport'), - SelectionSupport: require('../../../components/map/openlayers/SelectionSupport') + LMap: require('../../../components/map/openlayers/Map').default, + Layer: require('../../../components/map/openlayers/Layer').default, + Feature: require('../../../components/map/openlayers/Feature').default, + Locate: require('../../../components/map/openlayers/Locate').default, + MeasurementSupport: addFormatNumber(require('../../../components/map/openlayers/MeasurementSupport').default), + Overview: require('../../../components/map/openlayers/Overview').default, + ScaleBar: require('../../../components/map/openlayers/ScaleBar').default, + DrawSupport: require('../../../components/map/openlayers/DrawSupport').default, + HighlightFeatureSupport: require('../../../components/map/openlayers/HighlightFeatureSupport').default, + SelectionSupport: require('../../../components/map/openlayers/SelectionSupport').default }; diff --git a/web/client/reducers/annotations.js b/web/client/reducers/annotations.js index df3d4ac139..3d537cf302 100644 --- a/web/client/reducers/annotations.js +++ b/web/client/reducers/annotations.js @@ -7,8 +7,9 @@ */ const assign = require('object-assign'); -const ol = require('openlayers'); -const {reproject, reprojectGeoJson, transformLineToArcs} = require('../utils/CoordinatesUtils'); +const {transformLineToArcs} = require('../utils/CoordinatesUtils'); + +const circle = require('@turf/circle').default; const {PURGE_MAPINFO_RESULTS} = require('../actions/mapInfo'); const {TOGGLE_CONTROL} = require('../actions/controls'); @@ -75,35 +76,29 @@ function annotations(state = { validationErrors: {} }, action) { let features; if (selected.properties.isCircle) { - let center = !isNil(coordinates) ? validCoordinates[0] : state.selected.properties.center; + let centerCoords = !isNil(coordinates) ? validCoordinates[0] : state.selected.properties.center; selected = assign({}, {...selected, properties: { - ...state.selected.properties, center, radius: !isNil(radius) ? radius : selected.properties.radius + ...state.selected.properties, center: centerCoords, radius: !isNil(radius) ? radius : selected.properties.radius }}); features = state.editing.features.map(f => { return f.properties.id === state.selected.properties.id ? selected : f; }); - selected = {...selected, geometry: {coordinates: center, type: "Circle"}}; - let centerOL; - let c = [[[]]]; + selected = { ...selected, geometry: { coordinates: centerCoords, type: "Circle"}}; + let center; + let c = { + type: 'Polygon', + coordinates: [[[]]] + }; // polygonGeom setting if (validateCoordsArray(selected.properties.center)) { - centerOL = reproject(selected.properties.center, "EPSG:4326", "EPSG:3857"); - c = ol.geom.Polygon.fromCircle(new ol.geom.Circle([centerOL.x, centerOL.y], radius), 100).getCoordinates(); + center = selected.properties.center; + c = circle(center, radius * 1000, { steps: 100 }).geometry; } else { selected = set("properties.center", [], selected); } - // need to change the polygon coords after radius changes, but this implementation is ugly. is using ol to do that, maybe we need to refactor this - let feature = { - type: "Feature", - geometry: { - type: "Polygon", - coordinates: c - } - }; - let projFt = reprojectGeoJson(feature, "EPSG:3857", "EPSG:4326"); - selected = set("properties.polygonGeom", projFt.geometry, selected); + selected = set("properties.polygonGeom", c, selected); } else if (selected.properties.isText) { let c = !isNil(coordinates) ? validCoordinates[0] : state.selected.geometry.coordinates; selected = assign({}, {...selected, @@ -235,20 +230,11 @@ function annotations(state = { validationErrors: {} }, action) { }), selected); selected = set("properties.center", action.components[0], selected); selected = set("geometry.coordinates", action.components[0], selected); - let center = reproject(selected.properties.center, "EPSG:4326", "EPSG:3857"); // need to change the polygon coords after radius changes // but this implementation is ugly. is using openlayers to do that and maybe we need to refactor this - let coordinates = ol.geom.Polygon.fromCircle(new ol.geom.Circle([center.x, center.y], action.radius), 100).getCoordinates(); - let feature = { - type: "Feature", - geometry: { - type: "Polygon", - coordinates - } - }; - let projFt = reprojectGeoJson(feature, "EPSG:3857", "EPSG:4326"); - selected = set("properties.polygonGeom", projFt.geometry, selected); + let feature = circle(selected.properties.center, action.radius * 1000, { steps: 100 }); + selected = set("properties.polygonGeom", feature.geometry, selected); let ftChangedIndex = findIndex(state.editing.features, (f) => f.properties.id === state.selected.properties.id); const selectedGeoJSON = set("geometry", selected.properties.polygonGeom, selected); diff --git a/web/client/simple.html b/web/client/simple.html index 8a42685c82..ef2cd9af94 100644 --- a/web/client/simple.html +++ b/web/client/simple.html @@ -7,11 +7,9 @@ MapStore HomePage - - diff --git a/web/client/utils/DrawSupportUtils.jsx b/web/client/utils/DrawSupportUtils.jsx deleted file mode 100644 index e6ce24e679..0000000000 --- a/web/client/utils/DrawSupportUtils.jsx +++ /dev/null @@ -1,79 +0,0 @@ -/* - * Copyright 2017, GeoSolutions Sas. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. -*/ - -/** - * Utils used in DrawSupport for leaflet and openlayers -*/ - -const ol = require('openlayers'); -const {isArray} = require('lodash'); -const {reproject} = require('./CoordinatesUtils'); - -/** - * Transforms a leaflet bounds object into an array. - * @prop {object} the bounds - * @return the array [minx, miny, maxx, maxy] -*/ -const boundsToOLExtent = (bounds) => { - return [bounds.getWest(), bounds.getSouth(), bounds.getEast(), bounds.getNorth()]; -}; - -/** - * @return a feature extracted from leaflet layer used in queryform -*/ -const fromLeafletFeatureToQueryform = (layer) => { - let geoJesonFt = layer.toGeoJSON(); - let bounds = layer.getBounds(); - let extent = boundsToOLExtent(bounds); - let center = bounds.getCenter(); - let radius = layer.getRadius ? layer.getRadius() : 0; - let coordinates = geoJesonFt.features[0].geometry.coordinates; - let projection = "EPSG:4326"; - let type = geoJesonFt.features[0].geometry.type; - - // Geometry respect query form panel needs - return { - type, - extent, - center, - coordinates, - radius, - projection - }; -}; -const calculateRadius = (center, coordinates) => { - return isArray(coordinates) && isArray(coordinates[0]) && isArray(coordinates[0][0]) ? Math.sqrt(Math.pow(center[0] - coordinates[0][0][0], 2) + Math.pow(center[1] - coordinates[0][0][1], 2)) : 100; -}; - -const transformPolygonToCircle = (feature, mapCrs) => { - - if (!feature.getGeometry() || feature.getGeometry().getType() !== "Polygon" || feature.getProperties().center && feature.getProperties().center.length === 0) { - return feature; - } - if (feature.getProperties() && feature.getProperties().isCircle && feature.getProperties().center && feature.getProperties().center[0] && feature.getProperties().center[1]) { - // center must be a valid point - const extent = feature.getGeometry().getExtent(); - let center; - if (feature.getProperties().center) { - center = reproject(feature.getProperties().center, "EPSG:4326", mapCrs); - center = [center.x, center.y]; - } else { - center = ol.extent.getCenter(extent); - } - const radius = feature.getProperties().radius || calculateRadius(center, feature.getGeometry().getCoordinates()); - feature.setGeometry(new ol.geom.Circle(center, radius)); - return feature; - } - return feature; -}; - -module.exports = { - transformPolygonToCircle, - boundsToOLExtent, - fromLeafletFeatureToQueryform -}; diff --git a/web/client/utils/StyleUtils.js b/web/client/utils/StyleUtils.js index b417af104c..6b4b517b90 100644 --- a/web/client/utils/StyleUtils.js +++ b/web/client/utils/StyleUtils.js @@ -7,7 +7,8 @@ */ module.exports = (mapType) => { + const StyleUtils = require('./' + mapType + '/StyleUtils'); return { - toVectorStyle: require('./' + mapType + '/StyleUtils') + toVectorStyle: StyleUtils.default || StyleUtils }; }; diff --git a/web/client/utils/VectorStyleUtils.js b/web/client/utils/VectorStyleUtils.js index 5c29a7417b..cabc8e3e3f 100644 --- a/web/client/utils/VectorStyleUtils.js +++ b/web/client/utils/VectorStyleUtils.js @@ -10,6 +10,10 @@ const {isNil} = require('lodash'); const {set} = require('./ImmutableUtils'); const {colorToRgbaStr} = require('./ColorUtils'); const axios = require('axios'); +const SLDParser = require('geostyler-sld-parser').default; +const StyleParsers = { + sld: new SLDParser() +}; /** * checks if there is at least one attrbute in the object @@ -326,6 +330,10 @@ const createStylesAsync = (styles = []) => { }); }; +const getStyleParser = (format = 'sld') => { + return StyleParsers[format]; +}; + module.exports = { getGeometryFunction, SymbolsStyles, @@ -348,5 +356,6 @@ module.exports = { isFillStyle, getSymbolsStyles, setSymbolsStyles, - createStylesAsync + createStylesAsync, + getStyleParser }; diff --git a/web/client/utils/VectorTileUtils.js b/web/client/utils/VectorTileUtils.js new file mode 100644 index 0000000000..09cbfc8803 --- /dev/null +++ b/web/client/utils/VectorTileUtils.js @@ -0,0 +1,15 @@ +/* + * Copyright 2019, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +export const VECTOR_FORMATS = [ + 'application/vnd.mapbox-vector-tile', + 'application/json;type=geojson', + 'application/json;type=topojson' +]; + +export const isVectorFormat = (format) => VECTOR_FORMATS.indexOf(format) !== -1; diff --git a/web/client/utils/__tests__/VectorStyleUtils-test.js b/web/client/utils/__tests__/VectorStyleUtils-test.js index 233afeff2d..ec320ef088 100644 --- a/web/client/utils/__tests__/VectorStyleUtils-test.js +++ b/web/client/utils/__tests__/VectorStyleUtils-test.js @@ -29,7 +29,8 @@ const { createSvgUrl, createStylesAsync, setSymbolsStyles, - getSymbolsStyles + getSymbolsStyles, + getStyleParser } = require("../VectorStyleUtils"); const LENGTH_OF_OBJECT_DATA_URL = "blob:http://localhost:9876/87844744-f879-4f5b-90bc-2cc6e70ba3cd".length; @@ -406,4 +407,10 @@ describe("VectorStyleUtils ", () => { expect(results[1].fillColor).toBe("#FF00FF"); }); }); + it('getStyleParser returns parsers for supported style formats', () => { + expect(getStyleParser('sld')).toExist(); + expect(getStyleParser('sld').readStyle).toExist(); + expect(getStyleParser('sld').writeStyle).toExist(); + expect(getStyleParser('css')).toNotExist(); + }); }); diff --git a/web/client/utils/__tests__/VectorTileUtils-test.js b/web/client/utils/__tests__/VectorTileUtils-test.js new file mode 100644 index 0000000000..26c0de691a --- /dev/null +++ b/web/client/utils/__tests__/VectorTileUtils-test.js @@ -0,0 +1,36 @@ +/* + * Copyright 2019, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +import expect from 'expect'; +import { isVectorFormat } from '../VectorTileUtils'; + +describe('VectorTileUtils', () => { + it('test isVectorFormat with vector formats', () => { + const MVT = 'application/vnd.mapbox-vector-tile'; + expect(isVectorFormat(MVT)).toBe(true); + + const GeoJSON = 'application/json;type=geojson'; + expect(isVectorFormat(GeoJSON)).toBe(true); + + const TopoJSON = 'application/json;type=topojson'; + expect(isVectorFormat(TopoJSON)).toBe(true); + }); + it('test isVectorFormat with image formats', () => { + const PNG = 'image/png'; + expect(isVectorFormat(PNG)).toBe(false); + + const PNG8 = 'image/png8'; + expect(isVectorFormat(PNG8)).toBe(false); + + const JPEG = 'image/jpeg'; + expect(isVectorFormat(JPEG)).toBe(false); + + const GIF = 'image/gif'; + expect(isVectorFormat(GIF)).toBe(false); + }); +}); diff --git a/web/client/utils/leaflet/DrawSupportUtils.js b/web/client/utils/leaflet/DrawSupportUtils.js new file mode 100644 index 0000000000..673100500d --- /dev/null +++ b/web/client/utils/leaflet/DrawSupportUtils.js @@ -0,0 +1,45 @@ +/* + * Copyright 2017, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. +*/ + +/** + * Utils used in DrawSupport for leaflet +*/ + +/** + * Transforms a leaflet bounds object into an array. + * @prop {object} the bounds + * @return the array [minx, miny, maxx, maxy] +*/ +export const boundsToOLExtent = (bounds) => { + return [bounds.getWest(), bounds.getSouth(), bounds.getEast(), bounds.getNorth()]; +}; + +/** + * @return a feature extracted from leaflet layer used in queryform +*/ +export const fromLeafletFeatureToQueryform = (layer) => { + let geoJesonFt = layer.toGeoJSON(); + let bounds = layer.getBounds(); + let extent = boundsToOLExtent(bounds); + let center = bounds.getCenter(); + let radius = layer.getRadius ? layer.getRadius() : 0; + let coordinates = geoJesonFt.features[0].geometry.coordinates; + let projection = "EPSG:4326"; + let type = geoJesonFt.features[0].geometry.type; + + // Geometry respect query form panel needs + return { + type, + extent, + center, + coordinates, + radius, + projection + }; +}; + diff --git a/web/client/utils/__tests__/DrawSupportUtils-test.js b/web/client/utils/leaflet/__tests__/DrawSupportUtils-test.js similarity index 100% rename from web/client/utils/__tests__/DrawSupportUtils-test.js rename to web/client/utils/leaflet/__tests__/DrawSupportUtils-test.js diff --git a/web/client/utils/leaflet/test/WMTS-test.js b/web/client/utils/leaflet/__tests__/WMTS-test.js similarity index 100% rename from web/client/utils/leaflet/test/WMTS-test.js rename to web/client/utils/leaflet/__tests__/WMTS-test.js diff --git a/web/client/utils/openlayers/DrawSupportUtils.js b/web/client/utils/openlayers/DrawSupportUtils.js new file mode 100644 index 0000000000..10c7a5f4fb --- /dev/null +++ b/web/client/utils/openlayers/DrawSupportUtils.js @@ -0,0 +1,39 @@ +/* + * Copyright 2019, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. +*/ + +import isArray from 'lodash/isArray'; +import { reproject } from '../CoordinatesUtils'; + +import { getCenter } from 'ol/extent'; +import { Circle } from 'ol/geom'; + +const calculateRadius = (center, coordinates) => { + return isArray(coordinates) && isArray(coordinates[0]) && isArray(coordinates[0][0]) ? Math.sqrt(Math.pow(center[0] - coordinates[0][0][0], 2) + Math.pow(center[1] - coordinates[0][0][1], 2)) : 100; +}; + +export const transformPolygonToCircle = (feature, mapCrs) => { + + if (!feature.getGeometry() || feature.getGeometry().getType() !== "Polygon" || feature.getProperties().center && feature.getProperties().center.length === 0) { + return feature; + } + if (feature.getProperties() && feature.getProperties().isCircle && feature.getProperties().center && feature.getProperties().center[0] && feature.getProperties().center[1]) { + // center must be a valid point + const extent = feature.getGeometry().getExtent(); + let center; + if (feature.getProperties().center) { + center = reproject(feature.getProperties().center, "EPSG:4326", mapCrs); + center = [center.x, center.y]; + } else { + center = getCenter(extent); + } + const radius = feature.getProperties().radius || calculateRadius(center, feature.getGeometry().getCoordinates()); + feature.setGeometry(new Circle(center, radius)); + return feature; + } + return feature; +}; diff --git a/web/client/utils/openlayers/DrawUtils.js b/web/client/utils/openlayers/DrawUtils.js index 187fae6130..7df5a2f35c 100644 --- a/web/client/utils/openlayers/DrawUtils.js +++ b/web/client/utils/openlayers/DrawUtils.js @@ -6,24 +6,26 @@ * LICENSE file in the root directory of this source tree. */ -let ol = require('openlayers'); -module.exports = { - createOLGeometry: ({type, coordinates, radius, center} = {}) => { - let geometry; - switch (type) { - case "Point": { geometry = new ol.geom.Point(coordinates ? coordinates : []); break; } - case "LineString": { geometry = new ol.geom.LineString(coordinates ? coordinates : []); break; } - case "MultiPoint": { geometry = new ol.geom.MultiPoint(coordinates ? coordinates : []); break; } - case "MultiLineString": { geometry = new ol.geom.MultiLineString(coordinates ? coordinates : []); break; } - case "MultiPolygon": { geometry = new ol.geom.MultiPolygon(coordinates ? coordinates : []); break; } - // defaults is Polygon / Circle - default: { geometry = radius && center ? - ol.geom.Polygon.fromCircle(new ol.geom.Circle([center.x, center.y], radius), 100) : new ol.geom.Polygon(coordinates ? coordinates : []); - } +import {Point, LineString, MultiPoint, MultiLineString, Polygon, MultiPolygon, Circle} from 'ol/geom'; +import {fromCircle} from 'ol/geom/Polygon'; + +export const createOLGeometry = ({ type, coordinates, radius, center } = {}) => { + let geometry; + switch (type) { + case "Point": { geometry = new Point(coordinates ? coordinates : []); break; } + case "LineString": { geometry = new LineString(coordinates ? coordinates : []); break; } + case "MultiPoint": { geometry = new MultiPoint(coordinates ? coordinates : []); break; } + case "MultiLineString": { geometry = new MultiLineString(coordinates ? coordinates : []); break; } + case "MultiPolygon": { geometry = new MultiPolygon(coordinates ? coordinates : []); break; } + // defaults is Polygon / Circle + default: { + geometry = radius && center ? + fromCircle(new Circle([center.x, center.y], radius), 100) : new Polygon(coordinates ? coordinates : []); } - return geometry; - }, - isPolygon: (feature = {}) => { - return feature && feature.geometry && feature.geometry.type === "Polygon"; } + return geometry; +}; + +export const isPolygon = (feature = {}) => { + return feature && feature.geometry && feature.geometry.type === "Polygon"; }; diff --git a/web/client/utils/openlayers/Icons.js b/web/client/utils/openlayers/Icons.js index bca51ba6ba..03880fa5a0 100644 --- a/web/client/utils/openlayers/Icons.js +++ b/web/client/utils/openlayers/Icons.js @@ -6,40 +6,45 @@ * LICENSE file in the root directory of this source tree. */ -const ol = require('openlayers'); +import MarkerUtils from '../MarkerUtils'; + +import isArray from 'lodash/isArray'; +import isNumber from 'lodash/isNumber'; +import isNil from 'lodash/isNil'; + +import {Text, Fill, Style, Icon} from 'ol/style'; -const MarkerUtils = require('../MarkerUtils'); const markers = MarkerUtils.markers.extra; const extraMarker = markers.icons[0]; const extraMarkerShadow = markers.icons[1]; const glyphs = MarkerUtils.getGlyphs('fontawesome'); -const {isArray, isNumber, isNil} = require('lodash'); -const getHighlishtStyle = ({highlight, rotation = 0}) => (highlight ? [new ol.style.Style({ - text: new ol.style.Text({ + +const getHighlishtStyle = ({highlight, rotation = 0}) => (highlight ? [new Style({ + text: new Text({ rotation, text: '\ue165', font: '18px mapstore2', offsetY: -markers.size[1] - 10, - fill: new ol.style.Fill({color: '#FF00FF'}) + fill: new Fill({color: '#FF00FF'}) }) })] : []); -module.exports = { +export default { extra: { getIcon: (options = {}) => { const rotation = !isNil(options.style && options.style.rotation) ? options.style.rotation : 0; - return [new ol.style.Style({ - image: new ol.style.Icon(({ + return [new Style({ + image: new Icon(({ rotation, anchor: [12, 12], anchorXUnits: 'pixels', anchorYUnits: 'pixels', src: extraMarkerShadow })) - }), new ol.style.Style({ - image: new ol.style.Icon({ + }), new Style({ + image: new Icon({ rotation, src: extraMarker, anchor: [markers.size[0] / 2, markers.size[1]], @@ -48,12 +53,12 @@ module.exports = { size: markers.size, offset: [markers.colors.indexOf(options.style.iconColor || 'blue') * markers.size[0], markers.shapes.indexOf(options.style.iconShape || 'circle') * markers.size[1]] }), - text: new ol.style.Text({ + text: new Text({ rotation, text: glyphs[options.style.iconGlyph], font: '14px FontAwesome', offsetY: -markers.size[1] * 2 / 3, - fill: new ol.style.Fill({color: '#FFFFFF'}) + fill: new Fill({color: '#FFFFFF'}) }) })].concat(getHighlishtStyle(options.style)); @@ -63,8 +68,8 @@ module.exports = { getIcon: ({style, iconAnchor }) => { const rotation = !isNil(style && style.rotation) ? style.rotation : 0; const anchor = style.iconAnchor || iconAnchor; - let markerStyle = [new ol.style.Style({ - image: new ol.style.Icon(({ + let markerStyle = [new Style({ + image: new Icon(({ anchor: anchor || [0.5, 1], anchorXUnits: style.anchorXUnits || (( anchor || anchor === 0) ? 'pixels' : 'fraction'), anchorYUnits: style.anchorYUnits || (( anchor || anchor === 0) ? 'pixels' : 'fraction'), @@ -75,8 +80,8 @@ module.exports = { })) })]; if (style.shadowUrl) { - markerStyle = [new ol.style.Style({ - image: new ol.style.Icon({ + markerStyle = [new Style({ + image: new Icon({ anchor: [12, 41], anchorXUnits: 'pixels', anchorYUnits: 'pixels', diff --git a/web/client/utils/openlayers/Layers.js b/web/client/utils/openlayers/Layers.js index 06e6f8dadc..f2901f2f4a 100644 --- a/web/client/utils/openlayers/Layers.js +++ b/web/client/utils/openlayers/Layers.js @@ -8,74 +8,87 @@ const layerTypes = {}; -var Layers = { +export const registerType = function(type, impl) { + layerTypes[type] = impl; +}; - registerType: function(type, impl) { - layerTypes[type] = impl; - }, +export const createLayer = function(type, options, map, mapId) { + var layerCreator = layerTypes[type]; + if (layerCreator) { + return layerCreator.create(options, map, mapId); + } + return null; +}; - createLayer: function(type, options, map, mapId) { - var layerCreator = layerTypes[type]; - if (layerCreator) { - return layerCreator.create(options, map, mapId); +export const updateLayer = function(type, layer, newOptions, oldOptions, map, mapId) { + var layerCreator = layerTypes[type]; + if (layerCreator && layerCreator.update) { + return layerCreator.update(layer, newOptions, oldOptions, map, mapId); + } else if (oldOptions && layer && layer.getSource() && layer.getSource().updateParams) { + // old method, keept for compatibility. + // TODO move it in specific layerCreator where possibile + let changed = false; + if (oldOptions.params && newOptions.params) { + changed = Object.keys(oldOptions.params).reduce((found, param) => { + if (newOptions.params[param] !== oldOptions.params[param]) { + return true; + } + return found; + }, false); + } else if (!oldOptions.params && newOptions.params) { + changed = true; } - return null; - }, - updateLayer: function(type, layer, newOptions, oldOptions, map, mapId) { - var layerCreator = layerTypes[type]; - if (layerCreator && layerCreator.update) { - return layerCreator.update(layer, newOptions, oldOptions, map, mapId); - } else if (oldOptions && layer && layer.getSource() && layer.getSource().updateParams) { - // old method, keept for compatibility. - // TODO move it in specific layerCreator where possibile - let changed = false; - if (oldOptions.params && newOptions.params) { - changed = Object.keys(oldOptions.params).reduce((found, param) => { - if (newOptions.params[param] !== oldOptions.params[param]) { - return true; - } - return found; - }, false); - } else if (!oldOptions.params && newOptions.params) { - changed = true; - } - if (changed) { - layer.getSource().updateParams(newOptions.params); - } - } - }, - removeLayer: function(type, options, map, mapId, layer) { - var layerCreator = layerTypes[type]; - if (layerCreator && layerCreator.remove) { - return layerCreator.remove(options, map, mapId, layer); - } - return null; - }, - renderLayer: function(type, options, map, mapId, layer) { - var layerCreator = layerTypes[type]; - if (layerCreator && layerCreator.render) { - return layerCreator.render(options, map, mapId, layer); - } - return null; - }, - isValid(type, layer) { - var layerCreator = layerTypes[type]; - if (layerCreator && layerCreator.isValid) { - return layerCreator.isValid(layer); + if (changed) { + layer.getSource().updateParams(newOptions.params); } - return true; - }, - isSupported(type) { - return !!layerTypes[type]; - }, - isCompatible(type, options) { - const layerCreator = layerTypes[type]; - if (layerCreator && layerCreator.isCompatible) { - return layerCreator.isCompatible(options); - } - return true; } }; -module.exports = Layers; +export const removeLayer = function(type, options, map, mapId, layer) { + var layerCreator = layerTypes[type]; + if (layerCreator && layerCreator.remove) { + return layerCreator.remove(options, map, mapId, layer); + } + return null; +}; + +export const renderLayer = function(type, options, map, mapId, layer) { + var layerCreator = layerTypes[type]; + if (layerCreator && layerCreator.render) { + return layerCreator.render(options, map, mapId, layer); + } + return null; +}; + +export const isValid = function(type, layer) { + var layerCreator = layerTypes[type]; + if (layerCreator && layerCreator.isValid) { + return layerCreator.isValid(layer); + } + return true; +}; + +export const isSupported = function(type) { + return !!layerTypes[type]; +}; + +export const isCompatible = function(type, options) { + const layerCreator = layerTypes[type]; + if (layerCreator && layerCreator.isCompatible) { + return layerCreator.isCompatible(options); + } + return true; +}; + +export default { + registerType, + createLayer, + updateLayer, + removeLayer, + renderLayer, + isValid, + isSupported, + isCompatible +}; + diff --git a/web/client/utils/openlayers/OlLocate.js b/web/client/utils/openlayers/OlLocate.js index fd20f7e8f7..7d09ef4e95 100644 --- a/web/client/utils/openlayers/OlLocate.js +++ b/web/client/utils/openlayers/OlLocate.js @@ -6,13 +6,26 @@ * LICENSE file in the root directory of this source tree. */ -var ol = require('openlayers'); -var popUp = require('./OlPopUp')(); -var assign = require('object-assign'); +import olPopUp from './OlPopUp'; +import assign from 'object-assign'; +import {inherits} from 'ol'; +import BaseObject from 'ol/Object'; +import Overlay from 'ol/Overlay'; +import Feature from 'ol/Feature'; +import VectorSource from 'ol/source/Vector'; +import VectorLayer from 'ol/layer/Vector'; +import Geolocation from 'ol/Geolocation'; +import {Point, Circle} from 'ol/geom'; +import GeometryCollection from 'ol/geom/GeometryCollection'; +import {Style, Fill, Stroke} from 'ol/style'; +import CircleStyle from 'ol/style/Circle'; -var OlLocate = function(map, optOptions) { - ol.Object.call(this, {state: "DISABLED"}); +const popUp = olPopUp(); + + +const OlLocate = function(map, optOptions) { + BaseObject.call(this, {state: "DISABLED"}); this.map = map; let defOptions = { drawCircle: true, // draw accuracy circle @@ -41,43 +54,48 @@ var OlLocate = function(map, optOptions) { }; this.options = assign({}, defOptions, optOptions || {} ); - this.geolocate = new ol.Geolocation({ + this.geolocate = new Geolocation({ projection: this.map.getView().getProjection(), trackingOptions: this.options.locateOptions }); - this.geolocate.on('change:position', this._updatePosFt, this); + this.updateHandler = this._updatePosFt.bind(this); + this.geolocate.on('change:position', this.updateHandler); this.popup = popUp; this.popup.hidden = true; this.popCnt = popUp.getElementsByClassName("ol-popup-cnt")[0]; - this.overlay = new ol.Overlay({ + this.overlay = new Overlay({ element: this.popup, positioning: 'top-center', stopEvent: false }); - this.layer = new ol.layer.Vector({ - source: new ol.source.Vector({useSpatialIndex: false})}); - this.posFt = new ol.Feature({ + this.layer = new VectorLayer({ + source: new VectorSource({useSpatialIndex: false})}); + this.posFt = new Feature({ geometry: this.geolocate.getAccuracyGeometry(), name: 'position', id: '_locate-pos'}); this.posFt.setStyle(this.options.locateStyle); this.layer.getSource().addFeature(this.posFt); + + this.clickHandler = this.mapClick.bind(this); + this.stopHandler = this.stopFollow.bind(this); + this.errorHandler = this.options.onLocationError.bind(this); }; -ol.inherits(OlLocate, ol.Object); +inherits(OlLocate, BaseObject); OlLocate.prototype.start = function() { - this.geolocate.on('error', this.options.onLocationError, this); + this.geolocate.on('error', this.errorHandler); this.follow = this.options.follow; this.geolocate.setTracking(true); this.layer.setMap(this.map); this.map.addOverlay(this.overlay); if (this.options.showPopup) { - this.map.on('click', this.mapClick, this); - this.map.on('touch', this.mapClick, this); + this.map.on('click', this.clickHandler); + this.map.on('touch', this.clickHandler); } if (this.options.stopFollowingOnDrag) { - this.map.on('pointerdrag', this.stopFollow, this); + this.map.on('pointerdrag', this.stopHandler); } if (!this.p) { this.set("state", "LOCATING"); @@ -88,24 +106,24 @@ OlLocate.prototype.start = function() { OlLocate.prototype.startFollow = function() { this.follow = true; if (this.options.stopFollowingOnDrag) { - this.map.on('pointerdrag', this.stopFollow, this); + this.map.on('pointerdrag', this.stopHandler); } if (this.p) { this._updatePosFt(); } }; OlLocate.prototype.stop = function() { - this.geolocate.un('error', this.options.onLocationError, this); + this.geolocate.un('error', this.errorHandler); this.geolocate.setTracking(false); this.popup.hide = true; this.map.removeOverlay(this.overlay); this.layer.setMap( null ); if (this.options.showPopup) { - this.map.un('click', this.mapClick); - this.map.un('touch', this.mapClick); + this.map.un('click', this.clickHandler); + this.map.un('touch', this.clickHandler); } if (this.options.stopFollowingOnDrag && !this.follow) { - this.map.un('pointerdrag', this.stopFollow, this); + this.map.un('pointerdrag', this.stopHandler); } this.set("state", "DISABLED"); }; @@ -113,7 +131,7 @@ OlLocate.prototype.stop = function() { OlLocate.prototype.stopFollow = function() { this.follow = false; - this.map.un('pointerdrag', this.stopFollow, this); + this.map.un('pointerdrag', this.stopHandler); this.set("state", "ENABLED"); }; @@ -125,12 +143,12 @@ OlLocate.prototype._updatePosFt = function() { } let p = this.geolocate.getPosition(); this.p = p; - let point = new ol.geom.Point([parseFloat(p[0]), parseFloat(p[1])]); + let point = new Point([parseFloat(p[0]), parseFloat(p[1])]); if (this.options.drawCircle) { - let accuracy = new ol.geom.Circle([parseFloat(p[0]), parseFloat(p[1])], this.geolocate.getAccuracy()); - this.posFt.setGeometry(new ol.geom.GeometryCollection([point, accuracy])); + let accuracy = new Circle([parseFloat(p[0]), parseFloat(p[1])], this.geolocate.getAccuracy()); + this.posFt.setGeometry(new GeometryCollection([point, accuracy])); } else { - this.posFt.setGeometry(new ol.geom.GeometryCollection([point])); + this.posFt.setGeometry(new GeometryCollection([point])); } if (!this.popup.hidden) { this._updatePopUpCnt(); @@ -185,14 +203,14 @@ OlLocate.prototype.mapClick = function(evt) { }; OlLocate.prototype._getDefaultStyles = function() { - return new ol.style.Style({ - image: new ol.style.Circle({ + return new Style({ + image: new CircleStyle({ radius: 6, - fill: new ol.style.Fill({color: 'rgba(42,147,238,0.7)'}), - stroke: new ol.style.Stroke({color: 'rgba(19,106,236,1)', width: 2}) + fill: new Fill({color: 'rgba(42,147,238,0.7)'}), + stroke: new Stroke({color: 'rgba(19,106,236,1)', width: 2}) }), - fill: new ol.style.Fill({color: 'rgba(19,106,236,0.15)'}), - stroke: new ol.style.Stroke({color: 'rgba(19,106,236,1)', width: 2}) + fill: new Fill({color: 'rgba(19,106,236,0.15)'}), + stroke: new Stroke({color: 'rgba(19,106,236,1)', width: 2}) }); }; @@ -200,4 +218,4 @@ OlLocate.prototype.setStrings = function(newStrings) { this.options.strings = assign({}, this.options.strings, newStrings); }; -module.exports = OlLocate; +export default OlLocate; diff --git a/web/client/utils/openlayers/OlPopUp.js b/web/client/utils/openlayers/OlPopUp.js index 3d17d259d5..331eed0985 100644 --- a/web/client/utils/openlayers/OlPopUp.js +++ b/web/client/utils/openlayers/OlPopUp.js @@ -6,9 +6,9 @@ * LICENSE file in the root directory of this source tree. */ -require('./olPopUp.css'); +import './olPopUp.css'; -let popUp = function() { +export default function() { let pop = document.createElement('div'); pop.setAttribute("class", "ol-popup"); let popDismis = document.createElement('a'); @@ -29,5 +29,4 @@ let popUp = function() { pop.appendChild(popCntWrap); pop.appendChild(popTipWrap); return pop; -}; -module.exports = popUp; +} diff --git a/web/client/utils/openlayers/StyleUtils.js b/web/client/utils/openlayers/StyleUtils.js index c21543bda7..4926ee7944 100644 --- a/web/client/utils/openlayers/StyleUtils.js +++ b/web/client/utils/openlayers/StyleUtils.js @@ -5,8 +5,9 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const assign = require('object-assign'); -const ol = require('openlayers'); +import assign from 'object-assign'; +import {Style, Stroke, Fill} from 'ol/style'; +import CircleStyle from 'ol/style/Circle'; const getColor = function(color) { return `rgba(${ color.r }, ${ color.g }, ${ color.b }, ${ color.a })`; @@ -29,18 +30,18 @@ const toVectorStyle = function(layer, style) { color: getColor(style.color), fillColor: getColor(style.fill) }; - let stroke = new ol.style.Stroke({ + let stroke = new Stroke({ color: getColor(style.color), width: style.width }); - let fill = new ol.style.Fill({ + let fill = new Fill({ color: getColor(style.fill) }); switch (getGeomType(layer)) { case 'Polygon': case 'MultiPolygon': { // TODO clear this, it goes in maximum call stack size exceeded - newLayer.nativeStyle = new ol.style.Style({ + newLayer.nativeStyle = new Style({ stroke: stroke, fill: fill }); @@ -50,7 +51,7 @@ const toVectorStyle = function(layer, style) { case 'LineString': { // TODO clear this, it goes in maximum call stack size exceeded - newLayer.nativeStyle = new ol.style.Style({ + newLayer.nativeStyle = new Style({ stroke: stroke }); break; @@ -58,8 +59,8 @@ const toVectorStyle = function(layer, style) { case 'Point': case 'MultiPoint': { // TODO clear this, it goes in maximum call stack size exceeded - newLayer.nativeStyle = new ol.style.Style({ - image: new ol.style.Circle({ + newLayer.nativeStyle = new Style({ + image: new CircleStyle({ radius: style.radius, fill: fill, stroke: stroke @@ -68,11 +69,11 @@ const toVectorStyle = function(layer, style) { } case 'GeometryCollection': { // TODO clear this, it goes in maximum call stack size exceeded - newLayer.nativeStyle = new ol.style.Style({ + newLayer.nativeStyle = new Style({ radius: style.radius, stroke: stroke, fill: fill, - image: new ol.style.Circle({ + image: new CircleStyle({ radius: style.radius, fill: fill, stroke: stroke @@ -88,4 +89,4 @@ const toVectorStyle = function(layer, style) { return newLayer; }; -module.exports = toVectorStyle; +export default toVectorStyle; diff --git a/web/client/utils/openlayers/VectorTileUtils.js b/web/client/utils/openlayers/VectorTileUtils.js new file mode 100644 index 0000000000..669edf2d6f --- /dev/null +++ b/web/client/utils/openlayers/VectorTileUtils.js @@ -0,0 +1,26 @@ +/* + * Copyright 2019, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +import MVT from 'ol/format/MVT'; +import GeoJSON from 'ol/format/GeoJSON'; +import TopoJSON from 'ol/format/TopoJSON'; +import { getStyle } from '../../components/map/openlayers/VectorStyle'; + +export const OL_VECTOR_FORMATS = { + 'application/vnd.mapbox-vector-tile': MVT, + 'application/json;type=geojson': GeoJSON, + 'application/json;type=topojson': TopoJSON +}; + +export const applyStyle = (vectorStyle, layer) => { + getStyle({ asPromise: true, style: vectorStyle }).then((style) => { + layer.setStyle(style); + }).catch(() => { + // TODO: error notifications + }); +}; diff --git a/web/client/utils/openlayers/__tests__/Icons-test.js b/web/client/utils/openlayers/__tests__/Icons-test.js index cc625f6976..23b6e0d846 100644 --- a/web/client/utils/openlayers/__tests__/Icons-test.js +++ b/web/client/utils/openlayers/__tests__/Icons-test.js @@ -6,7 +6,7 @@ * LICENSE file in the root directory of this source tree. */ -import * as Icons from '../Icons'; +import Icons from '../Icons'; import expect from 'expect'; describe('Icons openlayers styles', () => { @@ -39,7 +39,6 @@ describe('Icons openlayers styles', () => { expect(iconImage.getOrigin()).toEqual([72, 46]); expect(iconImage.getRotation()).toEqual(1); expect(iconImage.getSize()).toEqual([36, 46]); - expect(iconImage.getSnapToPixel()).toEqual(true); expect(new RegExp("/web/client/components/mapcontrols/annotations/img/markers_default.png").test(iconImage.getSrc())).toEqual(true); const iconText = icon.getText(); expect(iconText).toExist(); @@ -91,7 +90,6 @@ describe('Icons openlayers styles', () => { expect(iconImage.getOrigin()).toEqual([0, 0]); expect(iconImage.getRotation()).toEqual(1); expect(iconImage.getSize()).toEqual([14, 14]); - expect(iconImage.getSnapToPixel()).toEqual(true); }); it('test standard getIcon iconUrl, yes shadow, yes highlight', () => { const getIcon = Icons.standard.getIcon; @@ -119,7 +117,6 @@ describe('Icons openlayers styles', () => { expect(iconImage.getOrigin()).toEqual([0, 0]); expect(iconImage.getRotation()).toEqual(1); expect(iconImage.getSize()).toEqual([14, 14]); - expect(iconImage.getSnapToPixel()).toEqual(true); const highlightStyle = styles[2]; expect(highlightStyle).toExist(); const highlightStyleText = highlightStyle.getText(); diff --git a/web/client/utils/openlayers/__tests__/VectorTileUtils-test.js b/web/client/utils/openlayers/__tests__/VectorTileUtils-test.js new file mode 100644 index 0000000000..0d01ef9cf5 --- /dev/null +++ b/web/client/utils/openlayers/__tests__/VectorTileUtils-test.js @@ -0,0 +1,18 @@ +/* + * Copyright 2019, GeoSolutions Sas. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. + */ + +import expect from 'expect'; +import { OL_VECTOR_FORMATS } from '../VectorTileUtils'; + +describe('VectorTileUtils openlayers', () => { + it('test OL_VECTOR_FORMATS contains entry for all supported formats', () => { + expect(OL_VECTOR_FORMATS['application/vnd.mapbox-vector-tile']).toExist(); + expect(OL_VECTOR_FORMATS['application/json;type=geojson']).toExist(); + expect(OL_VECTOR_FORMATS['application/json;type=topojson']).toExist(); + }); +}); diff --git a/web/client/utils/openlayers/projUtils.js b/web/client/utils/openlayers/projUtils.js index e82ab99818..547940e9ec 100644 --- a/web/client/utils/openlayers/projUtils.js +++ b/web/client/utils/openlayers/projUtils.js @@ -5,13 +5,15 @@ * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. */ -const projUtils = { + +import {addProjection, Projection} from 'ol/proj'; +export default { /** * function needed in openlayer for adding new projection */ - addProjections: function(ol, code, extent, worldExtent, axisOrientation) { - ol.proj.addProjection(new ol.proj.Projection({ + addProjections: function(code, extent, worldExtent, axisOrientation) { + addProjection(new Projection({ code, extent, worldExtent, @@ -20,5 +22,3 @@ const projUtils = { ); } }; - -module.exports = projUtils;