UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

208 lines (206 loc) 30.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; exports.getDatasetAttributesFromVectorTile = getDatasetAttributesFromVectorTile; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _commonUtils = require("@kepler.gl/common-utils"); var _constants = require("@kepler.gl/constants"); var _table = require("@kepler.gl/table"); var _useFetchVectorTileMetadata = _interopRequireDefault(require("../../hooks/use-fetch-vector-tile-metadata")); var _common = require("../../common"); var _templateObject, _templateObject2; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } var TilesetInputContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n grid-template-rows: repeat(3, 1fr);\n row-gap: 18px;\n font-size: 12px;\n"]))); var TilesetInputDescription = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n text-align: center;\n color: ", ";\n font-size: 11px;\n"])), function (props) { return props.theme.AZURE200; }); function getDatasetAttributesFromVectorTile(_ref) { var name = _ref.name, dataUrl = _ref.dataUrl, metadataUrl = _ref.metadataUrl; return { name: name, type: _constants.DatasetType.VECTOR_TILE, metadata: { type: _constants.REMOTE_TILE, remoteTileFormat: (0, _commonUtils.isPMTilesUrl)(dataUrl) ? _constants.RemoteTileFormat.PMTILES : _constants.RemoteTileFormat.MVT, tilesetDataUrl: dataUrl, tilesetMetadataUrl: metadataUrl } }; } var TilesetVectorForm = function TilesetVectorForm(_ref2) { var setResponse = _ref2.setResponse; var _useState = (0, _react.useState)(''), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), tileName = _useState2[0], setTileName = _useState2[1]; var _useState3 = (0, _react.useState)(''), _useState4 = (0, _slicedToArray2["default"])(_useState3, 2), tileUrl = _useState4[0], setTileUrl = _useState4[1]; var _useState5 = (0, _react.useState)(''), _useState6 = (0, _slicedToArray2["default"])(_useState5, 2), metadataUrl = _useState6[0], setMetadataUrl = _useState6[1]; var _useState7 = (0, _react.useState)(null), _useState8 = (0, _slicedToArray2["default"])(_useState7, 2), initialFetchError = _useState8[0], setInitialFetchError = _useState8[1]; var onTileNameChange = (0, _react.useCallback)(function (event) { event.preventDefault(); setTileName(event.target.value); }, [setTileName]); var onTileMetaUrlChange = (0, _react.useCallback)(function (event) { event.preventDefault(); setMetadataUrl(event.target.value); }, [setMetadataUrl]); var onTileUrlChange = (0, _react.useCallback)( /*#__PURE__*/function () { var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(event) { var newTileUrl, usePMTiles, potentialMetadataUrl, resp; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: event.preventDefault(); newTileUrl = event.target.value; setTileUrl(newTileUrl); usePMTiles = (0, _commonUtils.isPMTilesUrl)(newTileUrl); potentialMetadataUrl = usePMTiles ? newTileUrl : (0, _table.getMetaUrl)(newTileUrl); if (!(!metadataUrl && potentialMetadataUrl)) { _context.next = 17; break; } if (!usePMTiles) { _context.next = 10; break; } _context.t0 = { ok: true }; _context.next = 13; break; case 10: _context.next = 12; return fetch(potentialMetadataUrl); case 12: _context.t0 = _context.sent; case 13: resp = _context.t0; if (resp.ok) { setInitialFetchError(null); setMetadataUrl(potentialMetadataUrl); } else { setInitialFetchError(new Error("Metadata loading failed: ".concat(resp.status, " ").concat(resp.statusText))); } _context.next = 18; break; case 17: setInitialFetchError(null); case 18: if (!tileName) { setTileName(newTileUrl.split('/').pop() || newTileUrl); } case 19: case "end": return _context.stop(); } }, _callee); })); return function (_x) { return _ref3.apply(this, arguments); }; }(), [setTileUrl, tileName, setMetadataUrl, metadataUrl]); var process = (0, _react.useMemo)(function () { return function (value) { return (0, _table.parseVectorMetadata)(value, { tileUrl: metadataUrl }); }; }, [metadataUrl]); var _useFetchVectorTileMe = (0, _useFetchVectorTileMetadata["default"])({ metadataUrl: metadataUrl, tilesetUrl: tileUrl, remoteTileFormat: (0, _commonUtils.isPMTilesUrl)(metadataUrl) ? _constants.RemoteTileFormat.PMTILES : _constants.RemoteTileFormat.MVT, process: process }), metadata = _useFetchVectorTileMe.data, loading = _useFetchVectorTileMe.loading, metaError = _useFetchVectorTileMe.error; // reset initial fetch error if the metadata is available if (metadata && initialFetchError) { setInitialFetchError(null); } (0, _react.useEffect)(function () { if (tileName && tileUrl) { if ((metadata === null || metadata === void 0 ? void 0 : metadata.pmtilesType) === _constants.PMTilesType.RASTER) { return setResponse({ metadata: metadata, dataset: null, loading: loading, error: new Error('For .pmtiles in raster format, please use the Raster Tile form.') }); } var dataset = getDatasetAttributesFromVectorTile({ name: tileName, dataUrl: tileUrl, metadataUrl: metadataUrl !== null && metadataUrl !== void 0 ? metadataUrl : undefined }); setResponse({ metadata: metadata, dataset: dataset, loading: loading, error: metaError || initialFetchError }); } else { setResponse({ metadata: metadata, dataset: null, loading: loading, error: metaError || initialFetchError }); } }, [setResponse, metadata, loading, metaError, initialFetchError, tileUrl, tileName, metadataUrl]); (0, _react.useEffect)(function () { if (metadata) { var name = metadata.name; if (name) { setTileName(name); } } }, [metadata]); return /*#__PURE__*/_react["default"].createElement(TilesetInputContainer, null, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("label", { htmlFor: "tileset-name" }, "Name"), /*#__PURE__*/_react["default"].createElement(_common.InputLight, { id: "tileset-name", placeholder: "Name your tileset", value: tileName, onChange: onTileNameChange })), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("label", { htmlFor: "tile-url" }, "Tileset URL"), /*#__PURE__*/_react["default"].createElement(_common.InputLight, { id: "tile-url", placeholder: "Tileset URL", value: tileUrl, onChange: onTileUrlChange }), /*#__PURE__*/_react["default"].createElement(TilesetInputDescription, null, "Requires {x}, {y}, {z} placeholders in URL or .pmtile extension.")), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("label", { htmlFor: "tile-metadata" }, "Tileset metadata URL"), /*#__PURE__*/_react["default"].createElement(_common.InputLight, { id: "tile-metadata", placeholder: "Tileset metadata", value: metadataUrl !== null && metadataUrl !== void 0 ? metadataUrl : undefined, onChange: onTileMetaUrlChange }), /*#__PURE__*/_react["default"].createElement(TilesetInputDescription, null, "Optional, but recommended. Supports json, txt"))); }; var _default = exports["default"] = TilesetVectorForm; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_commonUtils","_constants","_table","_useFetchVectorTileMetadata","_common","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TilesetInputContainer","styled","div","_taggedTemplateLiteral2","TilesetInputDescription","props","theme","AZURE200","getDatasetAttributesFromVectorTile","_ref","name","dataUrl","metadataUrl","type","DatasetType","VECTOR_TILE","metadata","REMOTE_TILE","remoteTileFormat","isPMTilesUrl","RemoteTileFormat","PMTILES","MVT","tilesetDataUrl","tilesetMetadataUrl","TilesetVectorForm","_ref2","setResponse","_useState","useState","_useState2","_slicedToArray2","tileName","setTileName","_useState3","_useState4","tileUrl","setTileUrl","_useState5","_useState6","setMetadataUrl","_useState7","_useState8","initialFetchError","setInitialFetchError","onTileNameChange","useCallback","event","preventDefault","target","value","onTileMetaUrlChange","onTileUrlChange","_ref3","_asyncToGenerator2","_regenerator","mark","_callee","newTileUrl","usePMTiles","potentialMetadataUrl","resp","wrap","_callee$","_context","prev","next","getMetaUrl","t0","ok","fetch","sent","Error","concat","status","statusText","split","pop","stop","_x","apply","arguments","process","useMemo","parseVectorMetadata","_useFetchVectorTileMe","useFetchVectorTileMetadata","tilesetUrl","data","loading","metaError","error","useEffect","pmtilesType","PMTilesType","RASTER","dataset","undefined","createElement","htmlFor","InputLight","id","placeholder","onChange","_default","exports"],"sources":["../../../src/modals/tilesets-modals/tileset-vector-form.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useEffect, useState, useMemo} from 'react';\nimport styled from 'styled-components';\n\nimport {isPMTilesUrl} from '@kepler.gl/common-utils';\nimport {\n  DatasetType,\n  PMTilesType,\n  RemoteTileFormat,\n  VectorTileDatasetMetadata,\n  REMOTE_TILE\n} from '@kepler.gl/constants';\nimport {TileJSON} from '@loaders.gl/mvt';\nimport {PMTilesMetadata} from '@loaders.gl/pmtiles';\nimport {getMetaUrl, parseVectorMetadata, VectorTileMetadata} from '@kepler.gl/table';\nimport {Merge} from '@kepler.gl/types';\n\nimport {default as useFetchVectorTileMetadata} from '../../hooks/use-fetch-vector-tile-metadata';\nimport {DatasetCreationAttributes, MetaResponse} from './common';\nimport {InputLight} from '../../common';\n\nconst TilesetInputContainer = styled.div`\n  display: grid;\n  grid-template-rows: repeat(3, 1fr);\n  row-gap: 18px;\n  font-size: 12px;\n`;\n\nconst TilesetInputDescription = styled.div`\n  text-align: center;\n  color: ${props => props.theme.AZURE200};\n  font-size: 11px;\n`;\n\nexport type VectorTilesetFormData = {\n  name: string;\n  dataUrl: string;\n  metadataUrl?: string;\n};\n\nexport type VectorTileDatasetCreationAttributes = Merge<\n  DatasetCreationAttributes,\n  {\n    metadata: VectorTileDatasetMetadata;\n  }\n>;\n\nexport function getDatasetAttributesFromVectorTile({\n  name,\n  dataUrl,\n  metadataUrl\n}: VectorTilesetFormData): VectorTileDatasetCreationAttributes {\n  return {\n    name,\n    type: DatasetType.VECTOR_TILE,\n    metadata: {\n      type: REMOTE_TILE,\n      remoteTileFormat: isPMTilesUrl(dataUrl) ? RemoteTileFormat.PMTILES : RemoteTileFormat.MVT,\n      tilesetDataUrl: dataUrl,\n      tilesetMetadataUrl: metadataUrl\n    }\n  };\n}\n\ntype TilesetVectorFormProps = {\n  setResponse: (response: MetaResponse) => void;\n};\n\nconst TilesetVectorForm: React.FC<TilesetVectorFormProps> = ({setResponse}) => {\n  const [tileName, setTileName] = useState<string>('');\n  const [tileUrl, setTileUrl] = useState<string>('');\n  const [metadataUrl, setMetadataUrl] = useState<string | null>('');\n  const [initialFetchError, setInitialFetchError] = useState<Error | null>(null);\n\n  const onTileNameChange = useCallback(\n    (event: React.ChangeEvent<HTMLInputElement>) => {\n      event.preventDefault();\n      setTileName(event.target.value);\n    },\n    [setTileName]\n  );\n\n  const onTileMetaUrlChange = useCallback(\n    (event: React.ChangeEvent<HTMLInputElement>) => {\n      event.preventDefault();\n      setMetadataUrl(event.target.value);\n    },\n    [setMetadataUrl]\n  );\n\n  const onTileUrlChange = useCallback(\n    async (event: React.ChangeEvent<HTMLInputElement>) => {\n      event.preventDefault();\n      const newTileUrl = event.target.value;\n      setTileUrl(newTileUrl);\n\n      const usePMTiles = isPMTilesUrl(newTileUrl);\n      const potentialMetadataUrl = usePMTiles ? newTileUrl : getMetaUrl(newTileUrl);\n      if (!metadataUrl && potentialMetadataUrl) {\n        // check if URL exists before setting it as the metadata URL\n        // Note: The {method: HEAD} request often fails, likely due to individual storage settings.\n        const resp = usePMTiles ? ({ok: true} as Response) : await fetch(potentialMetadataUrl);\n        if (resp.ok) {\n          setInitialFetchError(null);\n          setMetadataUrl(potentialMetadataUrl);\n        } else {\n          setInitialFetchError(\n            new Error(`Metadata loading failed: ${resp.status} ${resp.statusText}`)\n          );\n        }\n      } else {\n        setInitialFetchError(null);\n      }\n      if (!tileName) {\n        setTileName(newTileUrl.split('/').pop() || newTileUrl);\n      }\n    },\n    [setTileUrl, tileName, setMetadataUrl, metadataUrl]\n  );\n\n  const process = useMemo(() => {\n    return (value: PMTilesMetadata | TileJSON) =>\n      parseVectorMetadata(value, {tileUrl: metadataUrl});\n  }, [metadataUrl]);\n\n  const {\n    data: metadata,\n    loading,\n    error: metaError\n  } = useFetchVectorTileMetadata({\n    metadataUrl,\n    tilesetUrl: tileUrl,\n    remoteTileFormat: isPMTilesUrl(metadataUrl) ? RemoteTileFormat.PMTILES : RemoteTileFormat.MVT,\n    process\n  });\n\n  // reset initial fetch error if the metadata is available\n  if (metadata && initialFetchError) {\n    setInitialFetchError(null);\n  }\n\n  useEffect(() => {\n    if (tileName && tileUrl) {\n      if (metadata?.pmtilesType === PMTilesType.RASTER) {\n        return setResponse({\n          metadata,\n          dataset: null,\n          loading,\n          error: new Error('For .pmtiles in raster format, please use the Raster Tile form.')\n        });\n      }\n\n      const dataset = getDatasetAttributesFromVectorTile({\n        name: tileName,\n        dataUrl: tileUrl,\n        metadataUrl: metadataUrl ?? undefined\n      });\n      setResponse({\n        metadata,\n        dataset,\n        loading,\n        error: metaError || initialFetchError\n      });\n    } else {\n      setResponse({\n        metadata,\n        dataset: null,\n        loading,\n        error: metaError || initialFetchError\n      });\n    }\n  }, [\n    setResponse,\n    metadata,\n    loading,\n    metaError,\n    initialFetchError,\n    tileUrl,\n    tileName,\n    metadataUrl\n  ]);\n\n  useEffect(() => {\n    if (metadata) {\n      const name = (metadata as VectorTileMetadata).name;\n      if (name) {\n        setTileName(name);\n      }\n    }\n  }, [metadata]);\n\n  return (\n    <TilesetInputContainer>\n      <div>\n        <label htmlFor=\"tileset-name\">Name</label>\n        <InputLight\n          id=\"tileset-name\"\n          placeholder=\"Name your tileset\"\n          value={tileName}\n          onChange={onTileNameChange}\n        />\n      </div>\n      <div>\n        <label htmlFor=\"tile-url\">Tileset URL</label>\n        <InputLight\n          id=\"tile-url\"\n          placeholder=\"Tileset URL\"\n          value={tileUrl}\n          onChange={onTileUrlChange}\n        />\n        <TilesetInputDescription>\n          Requires &#123;x&#125;, &#123;y&#125;, &#123;z&#125; placeholders in URL or .pmtile\n          extension.\n        </TilesetInputDescription>\n      </div>\n      <div>\n        <label htmlFor=\"tile-metadata\">Tileset metadata URL</label>\n        <InputLight\n          id=\"tile-metadata\"\n          placeholder=\"Tileset metadata\"\n          value={metadataUrl ?? undefined}\n          onChange={onTileMetaUrlChange}\n        />\n        <TilesetInputDescription>\n          Optional, but recommended. Supports json, txt\n        </TilesetInputDescription>\n      </div>\n    </TilesetInputContainer>\n  );\n};\n\nexport default TilesetVectorForm;\n"],"mappings":"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","ignoreList":[]}