diff --git a/maps_dashboards/package-lock.json b/maps_dashboards/package-lock.json index b786a608..3a8f5faa 100644 --- a/maps_dashboards/package-lock.json +++ b/maps_dashboards/package-lock.json @@ -76,6 +76,26 @@ "resolved": "https://registry.npmjs.org/@types/pbf/-/pbf-3.0.2.tgz", "integrity": "sha512-EDrLIPaPXOZqDjrkzxxbX7UlJSeQVgah3i0aA4pOSzmK9zq3BIh7/MZIQxED7slJByvKM4Gc6Hypyu2lJzh3SQ==" }, + "@types/wellknown": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/@types/wellknown/-/wellknown-0.5.4.tgz", + "integrity": "sha512-zcsf4oHeEcvpvWhDOB1+qNK04oFJtsmv7Otb1Vy8w8GAqQkgRrVkI/C76PdwtpiT216aM1SbhkKgKWzGLhHKng==" + }, + "concat-stream": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.5.2.tgz", + "integrity": "sha512-H6xsIBfQ94aESBG8jGHXQ7i5AEpy5ZeVaLDOisDICiTCKpqEfr34/KmTrspKQNoLKNu9gTkovlpQcUi630AKiQ==", + "requires": { + "inherits": "~2.0.1", + "readable-stream": "~2.0.0", + "typedarray": "~0.0.5" + } + }, + "core-util-is": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", + "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" + }, "csscolorparser": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/csscolorparser/-/csscolorparser-1.0.3.tgz", @@ -116,11 +136,21 @@ "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, "ini": { "version": "1.3.8", "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" + }, "isexe": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", @@ -191,6 +221,11 @@ "resolved": "https://registry.npmjs.org/potpack/-/potpack-1.0.2.tgz", "integrity": "sha512-choctRBIV9EMT9WGAZHn3V7t0Z2pMQyl0EZE6pFc/6ml3ssw7Dlf/oAOvFwjm1HVsqfQN8GfeFyJ+d8tRzqueQ==" }, + "process-nextick-args": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", + "integrity": "sha512-yN0WQmuCX63LP/TMvAg31nvT6m4vDqJEiiv2CAZqWOGNWutc9DfDk1NPYYmKUFmaVM2UwDowH4u5AHWYP/jxKw==" + }, "protocol-buffers-schema": { "version": "3.6.0", "resolved": "https://registry.npmjs.org/protocol-buffers-schema/-/protocol-buffers-schema-3.6.0.tgz", @@ -201,6 +236,19 @@ "resolved": "https://registry.npmjs.org/quickselect/-/quickselect-2.0.0.tgz", "integrity": "sha512-RKJ22hX8mHe3Y6wH/N3wCM6BWtjaxIyyUIkpHOvfFnxdI4yD4tBXEBKSbriGujF6jnSVkJrffuo6vxACiSSxIw==" }, + "readable-stream": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.0.6.tgz", + "integrity": "sha512-TXcFfb63BQe1+ySzsHZI/5v1aJPCShfqvWJ64ayNImXMsN1Cd0YGk/wm8KB7/OeessgPc9QvS9Zou8QTkFzsLw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "~1.0.0", + "process-nextick-args": "~1.0.6", + "string_decoder": "~0.10.x", + "util-deprecate": "~1.0.1" + } + }, "resolve-protobuf-schema": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/resolve-protobuf-schema/-/resolve-protobuf-schema-2.1.0.tgz", @@ -209,6 +257,11 @@ "protocol-buffers-schema": "^3.3.1" } }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ==" + }, "supercluster": { "version": "7.1.5", "resolved": "https://registry.npmjs.org/supercluster/-/supercluster-7.1.5.tgz", @@ -222,10 +275,15 @@ "resolved": "https://registry.npmjs.org/tinyqueue/-/tinyqueue-2.0.3.tgz", "integrity": "sha512-ppJZNDuKGgxzkHihX8v9v9G5f+18gzaTfrukGrq6ueg0lmH4nqVnA2IPG0AEH3jKEk2GRJCUhDoqpoiw3PHLBA==" }, - "uuid": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-9.0.0.tgz", - "integrity": "sha512-MXcSTerfPa4uqyzStbRoTgt5XIe3x5+42+q1sDuy3R5MDk66URdLMOZe5aPX/SQd+kuYAh0FdP/pO28IkQyTeg==" + "typedarray": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.7.tgz", + "integrity": "sha512-ueeb9YybpjhivjbHP2LdFDAjbS948fGEPj+ACAMs4xCMmh72OCOMQWBQKlaN4ZNQ04yfLSDLSx1tGRIoWimObQ==" + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" }, "vt-pbf": { "version": "3.1.3", @@ -237,6 +295,15 @@ "pbf": "^3.2.1" } }, + "wellknown": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/wellknown/-/wellknown-0.5.0.tgz", + "integrity": "sha512-za5vTLuPF9nmrVOovYQwNEWE/PwJCM+yHMAj4xN1WWUvtq9OElsvKiPL0CR9rO8xhrYqL7NpI7IknqR8r6eYOg==", + "requires": { + "concat-stream": "~1.5.0", + "minimist": "~1.2.0" + } + }, "which": { "version": "1.3.1", "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", diff --git a/maps_dashboards/package.json b/maps_dashboards/package.json index 8b56ebe9..248b8264 100644 --- a/maps_dashboards/package.json +++ b/maps_dashboards/package.json @@ -8,8 +8,10 @@ "osd": "node ../../scripts/osd" }, "dependencies": { + "@types/wellknown": "^0.5.4", "maplibre-gl": "^2.4.0", + "prettier": "^2.1.1", "uuid": "3.3.2", - "prettier": "^2.1.1" + "wellknown": "^0.5.0" } } diff --git a/maps_dashboards/public/model/documentLayerFunctions.ts b/maps_dashboards/public/model/documentLayerFunctions.ts index 30683b5f..33bf6b82 100644 --- a/maps_dashboards/public/model/documentLayerFunctions.ts +++ b/maps_dashboards/public/model/documentLayerFunctions.ts @@ -4,6 +4,7 @@ */ import { Map as Maplibre } from 'maplibre-gl'; +import { parse } from 'wellknown'; import { DocumentLayerSpecification } from './mapLayerType'; import { convertGeoPointToGeoJSON, isGeoJSON } from '../utils/geo_formater'; import { getMaplibreBeforeLayerId, layerExistInMbSource } from './layersFunctions'; @@ -22,11 +23,22 @@ const openSearchGeoJSONMap = new Map([ ['geometrycollection', 'GeometryCollection'], ]); -const GeoJSONMaplibreMap = new Map([ - ['Point', 'circle'], - ['LineString', 'line'], - ['Polygon', 'fill'], -]); +const buildLayerSuffix = (layerId: string, mapLibreType: string) => { + if (mapLibreType.toLowerCase() === 'circle') { + return layerId; + } + if (mapLibreType.toLowerCase() === 'line') { + return layerId + '-line'; + } + if (mapLibreType.toLowerCase() === 'fill') { + return layerId + '-fill'; + } + if (mapLibreType.toLowerCase() === 'fill-outline') { + return layerId + '-outline'; + } + // if unknown type is found, use layerId as default + return layerId; +}; const getFieldValue = (data: any, name: string) => { if (!name) { @@ -57,11 +69,20 @@ const buildGeometry = (fieldType: string, location: any) => { coordinates: location.coordinates, }; } + + if (typeof location === 'string') { + // Check if location is WKT format + const geometry = parse(location); + if (geometry) { + return geometry; + } + } + // Geopoint supports other format like object, string, array, if (fieldType === 'geo_point') { // convert other supported formats to GeoJSON return convertGeoPointToGeoJSON(location); } - // We don't support non-geo-json format for geo_shape yet + // We don't support any other format return undefined; }; @@ -108,118 +129,205 @@ const addNewLayer = ( ) => { const maplibreInstance = maplibreRef.current; const mbLayerBeforeId = getMaplibreBeforeLayerId(layerConfig, maplibreRef, beforeLayerId); - const addGeoPointLayer = () => { + const addLineLayer = ( + documentLayerConfig: DocumentLayerSpecification, + beforeId: string | undefined + ) => { + const lineLayerId = buildLayerSuffix(documentLayerConfig.id, 'line'); maplibreInstance?.addLayer( { - id: layerConfig.id, + id: lineLayerId, + type: 'line', + source: documentLayerConfig.id, + filter: ['==', '$type', 'LineString'], + paint: { + 'line-color': documentLayerConfig.style?.fillColor, + 'line-opacity': documentLayerConfig.opacity / 100, + 'line-width': documentLayerConfig.style?.borderThickness, + }, + }, + beforeId + ); + maplibreInstance?.setLayoutProperty(lineLayerId, 'visibility', documentLayerConfig.visibility); + }; + + const addCircleLayer = ( + documentLayerConfig: DocumentLayerSpecification, + beforeId: string | undefined + ) => { + const circleLayerId = buildLayerSuffix(documentLayerConfig.id, 'circle'); + maplibreInstance?.addLayer( + { + id: circleLayerId, type: 'circle', source: layerConfig.id, + filter: ['==', '$type', 'Point'], paint: { - 'circle-radius': layerConfig.style?.markerSize, - 'circle-color': layerConfig.style?.fillColor, - 'circle-opacity': layerConfig.opacity / 100, - 'circle-stroke-width': layerConfig.style?.borderThickness, - 'circle-stroke-color': layerConfig.style?.borderColor, + 'circle-radius': documentLayerConfig.style?.markerSize, + 'circle-color': documentLayerConfig.style?.fillColor, + 'circle-opacity': documentLayerConfig.opacity / 100, + 'circle-stroke-width': documentLayerConfig.style?.borderThickness, + 'circle-stroke-color': documentLayerConfig.style?.borderColor, }, }, - mbLayerBeforeId + beforeId + ); + maplibreInstance?.setLayoutProperty( + circleLayerId, + 'visibility', + documentLayerConfig.visibility ); - maplibreInstance?.setLayoutProperty(layerConfig.id, 'visibility', layerConfig.visibility); }; - const addGeoShapeLayer = (source: any) => { - source.features.map((feature: any, index: number) => { - const mbType = GeoJSONMaplibreMap.get(feature.geometry.type); - const mbLayerId = `${layerConfig.id}-${index}`; - if (mbType === 'circle') { - maplibreInstance?.addLayer( - { - id: mbLayerId, - type: 'circle', - source: layerConfig.id, - filter: ['==', '$type', 'Point'], - paint: { - 'circle-radius': layerConfig.style?.markerSize, - 'circle-color': layerConfig.style?.fillColor, - 'circle-opacity': layerConfig.opacity / 100, - 'circle-stroke-width': layerConfig.style?.borderThickness, - 'circle-stroke-color': layerConfig.style?.borderColor, - }, - }, - mbLayerBeforeId - ); - maplibreInstance?.setLayoutProperty(mbLayerId, 'visibility', layerConfig.visibility); - } else if (mbType === 'line') { - maplibreInstance?.addLayer( - { - id: mbLayerId, - type: 'line', - source: layerConfig.id, - filter: ['==', '$type', 'LineString'], - paint: { - 'line-color': layerConfig.style?.fillColor, - 'line-opacity': layerConfig.opacity / 100, - 'line-width': layerConfig.style?.borderThickness, - }, - }, - mbLayerBeforeId - ); - maplibreInstance?.setLayoutProperty(mbLayerId, 'visibility', layerConfig.visibility); - } else if (mbType === 'fill') { - const polygonBorderLayerId = `${mbLayerId}-border`; - maplibreInstance?.addLayer( - { - id: mbLayerId, - type: 'fill', - source: layerConfig.id, - filter: ['==', '$type', 'Polygon'], - paint: { - 'fill-color': layerConfig.style?.fillColor, - 'fill-opacity': layerConfig.opacity / 100, - 'fill-outline-color': layerConfig.style?.borderColor, - }, - }, - mbLayerBeforeId - ); - maplibreInstance?.setLayoutProperty(mbLayerId, 'visibility', layerConfig.visibility); - // Add boarder for polygon - maplibreInstance?.addLayer( - { - id: polygonBorderLayerId, - type: 'line', - source: layerConfig.id, - filter: ['==', '$type', 'Polygon'], - paint: { - 'line-color': layerConfig.style?.borderColor, - 'line-opacity': layerConfig.opacity / 100, - 'line-width': layerConfig.style?.borderThickness, - }, - }, - mbLayerBeforeId - ); - maplibreInstance?.setLayoutProperty( - polygonBorderLayerId, - 'visibility', - layerConfig.visibility - ); - } - }); + const addFillLayer = ( + documentLayerConfig: DocumentLayerSpecification, + beforeId: string | undefined + ) => { + const fillLayerId = buildLayerSuffix(documentLayerConfig.id, 'fill'); + maplibreInstance?.addLayer( + { + id: fillLayerId, + type: 'fill', + source: layerConfig.id, + filter: ['==', '$type', 'Polygon'], + paint: { + 'fill-color': documentLayerConfig.style?.fillColor, + 'fill-opacity': documentLayerConfig.opacity / 100, + }, + }, + beforeId + ); + maplibreInstance?.setLayoutProperty(fillLayerId, 'visibility', documentLayerConfig.visibility); + // Due to limitations on WebGL, fill can't render outlines with width wider than 1, + // so we have to create another style layer with type=line to apply width. + const outlineId = buildLayerSuffix(documentLayerConfig.id, 'fill-outline'); + maplibreInstance?.addLayer( + { + id: outlineId, + type: 'line', + source: layerConfig.id, + filter: ['==', '$type', 'Polygon'], + paint: { + 'line-color': layerConfig.style?.borderColor, + 'line-opacity': layerConfig.opacity / 100, + 'line-width': layerConfig.style?.borderThickness, + }, + }, + beforeId + ); + maplibreInstance?.setLayoutProperty(outlineId, 'visibility', layerConfig.visibility); }; + if (maplibreInstance) { const source = getLayerSource(data, layerConfig); maplibreInstance.addSource(layerConfig.id, { type: 'geojson', data: source, }); + addCircleLayer(layerConfig, mbLayerBeforeId); const geoFieldType = getGeoFieldType(layerConfig); - if (geoFieldType === 'geo_point') { - addGeoPointLayer(); - } else { - addGeoShapeLayer(source); + if (geoFieldType === 'geo_shape') { + addLineLayer(layerConfig, mbLayerBeforeId); + addFillLayer(layerConfig, mbLayerBeforeId); } } }; +const updateCircleLayer = ( + maplibreInstance: Maplibre, + documentLayerConfig: DocumentLayerSpecification +) => { + const circleLayerId = buildLayerSuffix(documentLayerConfig.id, 'circle'); + const circleLayerStyle = documentLayerConfig.style; + maplibreInstance?.setLayerZoomRange( + circleLayerId, + documentLayerConfig.zoomRange[0], + documentLayerConfig.zoomRange[1] + ); + maplibreInstance?.setPaintProperty( + circleLayerId, + 'circle-opacity', + documentLayerConfig.opacity / 100 + ); + maplibreInstance?.setPaintProperty(circleLayerId, 'circle-color', circleLayerStyle?.fillColor); + maplibreInstance?.setPaintProperty( + circleLayerId, + 'circle-stroke-color', + circleLayerStyle?.borderColor + ); + maplibreInstance?.setPaintProperty( + circleLayerId, + 'circle-stroke-width', + circleLayerStyle?.borderThickness + ); + maplibreInstance?.setPaintProperty(circleLayerId, 'circle-radius', circleLayerStyle?.markerSize); +}; + +const updateLineLayer = ( + maplibreInstance: Maplibre, + documentLayerConfig: DocumentLayerSpecification +) => { + const lineLayerId = buildLayerSuffix(documentLayerConfig.id, 'line'); + maplibreInstance?.setLayerZoomRange( + lineLayerId, + documentLayerConfig.zoomRange[0], + documentLayerConfig.zoomRange[1] + ); + maplibreInstance?.setPaintProperty( + lineLayerId, + 'line-opacity', + documentLayerConfig.opacity / 100 + ); + maplibreInstance?.setPaintProperty( + lineLayerId, + 'line-color', + documentLayerConfig.style?.fillColor + ); + maplibreInstance?.setPaintProperty( + lineLayerId, + 'line-width', + documentLayerConfig.style?.borderThickness + ); +}; + +const updateFillLayer = ( + maplibreInstance: Maplibre, + documentLayerConfig: DocumentLayerSpecification +) => { + const fillLayerId = buildLayerSuffix(documentLayerConfig.id, 'fill'); + maplibreInstance?.setLayerZoomRange( + fillLayerId, + documentLayerConfig.zoomRange[0], + documentLayerConfig.zoomRange[1] + ); + maplibreInstance?.setPaintProperty( + fillLayerId, + 'fill-opacity', + documentLayerConfig.opacity / 100 + ); + maplibreInstance?.setPaintProperty( + fillLayerId, + 'fill-color', + documentLayerConfig.style?.fillColor + ); + maplibreInstance?.setPaintProperty( + fillLayerId, + 'fill-outline-color', + documentLayerConfig.style?.borderColor + ); + const outlineLayerId = buildLayerSuffix(documentLayerConfig.id, 'fill-outline'); + maplibreInstance?.setPaintProperty( + outlineLayerId, + 'line-color', + documentLayerConfig.style?.borderColor + ); + maplibreInstance?.setPaintProperty( + outlineLayerId, + 'line-width', + documentLayerConfig.style?.borderThickness + ); +}; + const updateLayerConfig = ( layerConfig: DocumentLayerSpecification, maplibreRef: MaplibreRef, @@ -232,116 +340,11 @@ const updateLayerConfig = ( // @ts-ignore dataSource.setData(getLayerSource(data, layerConfig)); } + updateCircleLayer(maplibreInstance, layerConfig); const geoFieldType = getGeoFieldType(layerConfig); - if (geoFieldType === 'geo_point') { - maplibreInstance?.setLayerZoomRange( - layerConfig.id, - layerConfig.zoomRange[0], - layerConfig.zoomRange[1] - ); - maplibreInstance?.setPaintProperty( - layerConfig.id, - 'circle-opacity', - layerConfig.opacity / 100 - ); - maplibreInstance?.setPaintProperty( - layerConfig.id, - 'circle-color', - layerConfig.style?.fillColor - ); - maplibreInstance?.setPaintProperty( - layerConfig.id, - 'circle-stroke-color', - layerConfig.style?.borderColor - ); - maplibreInstance?.setPaintProperty( - layerConfig.id, - 'circle-stroke-width', - layerConfig.style?.borderThickness - ); - maplibreInstance?.setPaintProperty( - layerConfig.id, - 'circle-radius', - layerConfig.style?.markerSize - ); - } else { - getCurrentStyleLayers(maplibreRef).forEach((layer) => { - if (layer.id.includes(layerConfig.id)) { - maplibreInstance.setLayerZoomRange( - layer.id, - layerConfig.zoomRange[0], - layerConfig.zoomRange[1] - ); - if (layer.type === 'circle') { - maplibreInstance?.setPaintProperty( - layer.id, - 'circle-opacity', - layerConfig.opacity / 100 - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'circle-color', - layerConfig.style?.fillColor - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'circle-stroke-color', - layerConfig.style?.borderColor - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'circle-stroke-width', - layerConfig.style?.borderThickness - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'circle-radius', - layerConfig.style?.markerSize - ); - } else if (layer.type === 'line') { - if (layer.id.includes('border')) { - maplibreInstance?.setPaintProperty( - layer.id, - 'line-color', - layerConfig.style?.borderColor - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'line-width', - layerConfig.style?.borderThickness - ); - } else { - maplibreInstance?.setPaintProperty( - layer.id, - 'line-opacity', - layerConfig.opacity / 100 - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'line-color', - layerConfig.style?.fillColor - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'line-width', - layerConfig.style?.borderThickness - ); - } - } else if (layer.type === 'fill') { - maplibreInstance?.setPaintProperty(layer.id, 'fill-opacity', layerConfig.opacity / 100); - maplibreInstance?.setPaintProperty( - layer.id, - 'fill-color', - layerConfig.style?.fillColor - ); - maplibreInstance?.setPaintProperty( - layer.id, - 'fill-outline-color', - layerConfig.style?.borderColor - ); - } - } - }); + if (geoFieldType === 'geo_shape') { + updateLineLayer(maplibreInstance, layerConfig); + updateFillLayer(maplibreInstance, layerConfig); } } }; diff --git a/maps_dashboards/public/utils/geo_formater.ts b/maps_dashboards/public/utils/geo_formater.ts index 2af1933c..2c0c274b 100644 --- a/maps_dashboards/public/utils/geo_formater.ts +++ b/maps_dashboards/public/utils/geo_formater.ts @@ -50,6 +50,6 @@ export function convertGeoPointToGeoJSON(location: any) { if (values && (values.length === 2 || values.length === 3)) { return buildGeoJSONOfTypePoint(parseFloat(values[1].trim()), parseFloat(values[0].trim())); } - // TODO Geopoint as geohash & WKT Format + // TODO Geopoint as geohash return undefined; } diff --git a/maps_dashboards/yarn.lock b/maps_dashboards/yarn.lock index 818b5a9f..ec921ff9 100644 --- a/maps_dashboards/yarn.lock +++ b/maps_dashboards/yarn.lock @@ -71,6 +71,25 @@ resolved "https://registry.yarnpkg.com/@types/pbf/-/pbf-3.0.2.tgz#8d291ad68b4b8c533e96c174a2e3e6399a59ed61" integrity sha512-EDrLIPaPXOZqDjrkzxxbX7UlJSeQVgah3i0aA4pOSzmK9zq3BIh7/MZIQxED7slJByvKM4Gc6Hypyu2lJzh3SQ== +"@types/wellknown@^0.5.4": + version "0.5.4" + resolved "https://registry.yarnpkg.com/@types/wellknown/-/wellknown-0.5.4.tgz#1f12a2ca9cda236673272688b7549a30f0c9e3bb" + integrity sha512-zcsf4oHeEcvpvWhDOB1+qNK04oFJtsmv7Otb1Vy8w8GAqQkgRrVkI/C76PdwtpiT216aM1SbhkKgKWzGLhHKng== + +concat-stream@~1.5.0: + version "1.5.2" + resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.5.2.tgz#708978624d856af41a5a741defdd261da752c266" + integrity sha512-H6xsIBfQ94aESBG8jGHXQ7i5AEpy5ZeVaLDOisDICiTCKpqEfr34/KmTrspKQNoLKNu9gTkovlpQcUi630AKiQ== + dependencies: + inherits "~2.0.1" + readable-stream "~2.0.0" + typedarray "~0.0.5" + +core-util-is@~1.0.0: + version "1.0.3" + resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.3.tgz#a6042d3634c2b27e9328f837b965fac83808db85" + integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== + csscolorparser@~1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/csscolorparser/-/csscolorparser-1.0.3.tgz#b34f391eea4da8f3e98231e2ccd8df9c041f171b" @@ -110,11 +129,21 @@ ieee754@^1.1.12: resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== +inherits@~2.0.1: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + ini@^1.3.5: version "1.3.8" resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== +isarray@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" + integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== + isexe@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" @@ -165,6 +194,11 @@ minimist@^1.2.6: resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== +minimist@~1.2.0: + version "1.2.7" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.7.tgz#daa1c4d91f507390437c6a8bc01078e7000c4d18" + integrity sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g== + murmurhash-js@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/murmurhash-js/-/murmurhash-js-1.0.0.tgz#b06278e21fc6c37fa5313732b0412bcb6ae15f51" @@ -188,6 +222,11 @@ prettier@^2.1.1: resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.7.1.tgz#e235806850d057f97bb08368a4f7d899f7760c64" integrity sha512-ujppO+MkdPqoVINuDFDRLClm7D78qbDt0/NR+wp5FqEZOoTNAjPHWj17QRhu7geIHJfcNhRk1XVQmF8Bp3ye+g== +process-nextick-args@~1.0.6: + version "1.0.7" + resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-1.0.7.tgz#150e20b756590ad3f91093f25a4f2ad8bff30ba3" + integrity sha512-yN0WQmuCX63LP/TMvAg31nvT6m4vDqJEiiv2CAZqWOGNWutc9DfDk1NPYYmKUFmaVM2UwDowH4u5AHWYP/jxKw== + protocol-buffers-schema@^3.3.1: version "3.6.0" resolved "https://registry.yarnpkg.com/protocol-buffers-schema/-/protocol-buffers-schema-3.6.0.tgz#77bc75a48b2ff142c1ad5b5b90c94cd0fa2efd03" @@ -198,6 +237,18 @@ quickselect@^2.0.0: resolved "https://registry.yarnpkg.com/quickselect/-/quickselect-2.0.0.tgz#f19680a486a5eefb581303e023e98faaf25dd018" integrity sha512-RKJ22hX8mHe3Y6wH/N3wCM6BWtjaxIyyUIkpHOvfFnxdI4yD4tBXEBKSbriGujF6jnSVkJrffuo6vxACiSSxIw== +readable-stream@~2.0.0: + version "2.0.6" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.0.6.tgz#8f90341e68a53ccc928788dacfcd11b36eb9b78e" + integrity sha512-TXcFfb63BQe1+ySzsHZI/5v1aJPCShfqvWJ64ayNImXMsN1Cd0YGk/wm8KB7/OeessgPc9QvS9Zou8QTkFzsLw== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.1" + isarray "~1.0.0" + process-nextick-args "~1.0.6" + string_decoder "~0.10.x" + util-deprecate "~1.0.1" + resolve-protobuf-schema@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/resolve-protobuf-schema/-/resolve-protobuf-schema-2.1.0.tgz#9ca9a9e69cf192bbdaf1006ec1973948aa4a3758" @@ -205,6 +256,11 @@ resolve-protobuf-schema@^2.1.0: dependencies: protocol-buffers-schema "^3.3.1" +string_decoder@~0.10.x: + version "0.10.31" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94" + integrity sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ== + supercluster@^7.1.5: version "7.1.5" resolved "https://registry.yarnpkg.com/supercluster/-/supercluster-7.1.5.tgz#65a6ce4a037a972767740614c19051b64b8be5a3" @@ -217,6 +273,16 @@ tinyqueue@^2.0.3: resolved "https://registry.yarnpkg.com/tinyqueue/-/tinyqueue-2.0.3.tgz#64d8492ebf39e7801d7bd34062e29b45b2035f08" integrity sha512-ppJZNDuKGgxzkHihX8v9v9G5f+18gzaTfrukGrq6ueg0lmH4nqVnA2IPG0AEH3jKEk2GRJCUhDoqpoiw3PHLBA== +typedarray@~0.0.5: + version "0.0.7" + resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.7.tgz#799207136a37f3b3efb8c66c40010d032714dc73" + integrity sha512-ueeb9YybpjhivjbHP2LdFDAjbS948fGEPj+ACAMs4xCMmh72OCOMQWBQKlaN4ZNQ04yfLSDLSx1tGRIoWimObQ== + +util-deprecate@~1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" + integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== + uuid@3.3.2: version "3.3.2" resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.3.2.tgz#1b4af4955eb3077c501c23872fc6513811587131" @@ -231,6 +297,14 @@ vt-pbf@^3.1.3: "@mapbox/vector-tile" "^1.3.1" pbf "^3.2.1" +wellknown@^0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/wellknown/-/wellknown-0.5.0.tgz#09ae9871fa826cf0a6ec1537ef00c379d78d7101" + integrity sha512-za5vTLuPF9nmrVOovYQwNEWE/PwJCM+yHMAj4xN1WWUvtq9OElsvKiPL0CR9rO8xhrYqL7NpI7IknqR8r6eYOg== + dependencies: + concat-stream "~1.5.0" + minimist "~1.2.0" + which@^1.3.1: version "1.3.1" resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a"