UNPKG

kepler.gl

Version:

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

115 lines (111 loc) 21.6 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; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _reactJsonPretty = _interopRequireDefault(require("react-json-pretty")); var _reactVirtualized = require("react-virtualized"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _layers = require("@kepler.gl/layers"); var _utils = require("@kepler.gl/utils"); var _loadDataFooter = _interopRequireDefault(require("./load-data-footer")); var _tilesetVectorForm = _interopRequireDefault(require("./tileset-vector-form")); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project // import TilesetIcon from './tileset-icon'; 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; } // const WIDTH_ICON = '62px'; var LoadTilesetTabContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n"])), function (props) { return props.theme.AZURE; }); var Container = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n grid-template-columns: repeat(2, minmax(0, 1fr));\n background-color: ", ";\n"])), function (props) { return props.theme.WHITE; }); /* const TilesetTypeContainer = styled.div` display: grid; grid-template-columns: repeat(4, ${WIDTH_ICON}); `; */ var MetaContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n max-height: 400px;\n background-color: ", ";\n"])), function (_ref) { var theme = _ref.theme; return theme.editorBackground; }); var MetaInnerContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n border: 1px solid ", ";\n background-color: white;\n border-radius: 2px;\n display: inline-block;\n font: inherit;\n line-height: 1.5em;\n padding: 0.5em 3.5em 0.5em 1em;\n margin-left: 10px;\n box-sizing: border-box;\n overflow-y: scroll;\n overflow-x: auto;\n white-space: pre-wrap;\n word-wrap: break-word;\n height: ", "px;\n width: ", "px;\n max-width: 600px;\n"])), function (props) { return props.theme.selectBorderColorLT; }, function (props) { return props.height; }, function (props) { return props.width; }); var StyledHeaderMessage = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 14px;\n margin-bottom: 12px;\n"])), function (props) { return props.theme.textColorLT; }); var TILE_TYPES = [{ id: 'vectorTile', label: 'Vector Tile', Icon: _layers.VectorTileIcon, Component: _tilesetVectorForm["default"] }]; function isReady(response) { return response.dataset && !response.loading && !response.error; } function LoadTilesetTabFactory() { var LoadTilesetTab = function LoadTilesetTab(_ref2) { var onTilesetAdded = _ref2.onTilesetAdded, isAddingDatasets = _ref2.isAddingDatasets, intl = _ref2.intl; var _useState = (0, _react.useState)(0), _useState2 = (0, _slicedToArray2["default"])(_useState, 1), typeIndex /* , setTypeIndex*/ = _useState2[0]; var _useState3 = (0, _react.useState)({}), _useState4 = (0, _slicedToArray2["default"])(_useState3, 2), response = _useState4[0], setResponse = _useState4[1]; var error = response.error; var loading = response.loading; var data = response.metadata; var jsonDataText = (0, _react.useMemo)(function () { return JSON.stringify(data, null, 2); }, [data]); var createTileDataset = (0, _react.useCallback)(function () { var dataset = response.dataset, metadata = response.metadata; if (dataset) { onTilesetAdded(dataset, metadata); } }, [onTilesetAdded, response]); var CurrentForm = TILE_TYPES[typeIndex].Component; var tilesetHeaderMessage = "".concat(intl.formatMessage({ id: 'tilesetSetup.header' })); return /*#__PURE__*/_react["default"].createElement(LoadTilesetTabContainer, null, /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(StyledHeaderMessage, null, tilesetHeaderMessage), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(CurrentForm, { setResponse: setResponse }))), /*#__PURE__*/_react["default"].createElement(MetaContainer, null, data && /*#__PURE__*/_react["default"].createElement(_reactVirtualized.AutoSizer, null, function (_ref3) { var height = _ref3.height, width = _ref3.width; return /*#__PURE__*/_react["default"].createElement(MetaInnerContainer, { height: height, width: width }, /*#__PURE__*/_react["default"].createElement(_reactJsonPretty["default"], { id: "json-pretty", json: jsonDataText })); }))), /*#__PURE__*/_react["default"].createElement(_loadDataFooter["default"], { disabled: Boolean(error) || !isReady(response), isLoading: loading || isAddingDatasets, onConfirm: createTileDataset, confirmText: "tilesetSetup.addTilesetText", errorText: error && (0, _utils.getError)(error) })); }; return LoadTilesetTab; } var _default = exports["default"] = LoadTilesetTabFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactJsonPretty","_interopRequireDefault","_reactVirtualized","_styledComponents","_layers","_utils","_loadDataFooter","_tilesetVectorForm","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","LoadTilesetTabContainer","styled","div","_taggedTemplateLiteral2","props","theme","AZURE","Container","WHITE","MetaContainer","_ref","editorBackground","MetaInnerContainer","selectBorderColorLT","height","width","StyledHeaderMessage","textColorLT","TILE_TYPES","id","label","Icon","VectorTileIcon","Component","TilesetVectorForm","isReady","response","dataset","loading","error","LoadTilesetTabFactory","LoadTilesetTab","_ref2","onTilesetAdded","isAddingDatasets","intl","_useState","useState","_useState2","_slicedToArray2","typeIndex","_useState3","_useState4","setResponse","data","metadata","jsonDataText","useMemo","JSON","stringify","createTileDataset","useCallback","CurrentForm","tilesetHeaderMessage","concat","formatMessage","createElement","AutoSizer","_ref3","json","disabled","Boolean","isLoading","onConfirm","confirmText","errorText","getError","_default","exports"],"sources":["../../../src/modals/tilesets-modals/load-tileset.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo, useState} from 'react';\nimport {IntlShape} from 'react-intl';\nimport JSONPretty from 'react-json-pretty';\nimport {AutoSizer} from 'react-virtualized';\nimport styled from 'styled-components';\n\nimport {VectorTileIcon} from '@kepler.gl/layers';\nimport {getError} from '@kepler.gl/utils';\n\nimport {MetaResponse} from './common';\nimport LoadDataFooter from './load-data-footer';\n// import TilesetIcon from './tileset-icon';\nimport TilesetVectorForm from './tileset-vector-form';\n\n// const WIDTH_ICON = '62px';\n\nconst LoadTilesetTabContainer = styled.div`\n  color: ${props => props.theme.AZURE};\n`;\n\nconst Container = styled.div`\n  display: grid;\n  grid-template-columns: repeat(2, minmax(0, 1fr));\n  background-color: ${props => props.theme.WHITE};\n`;\n\n/*\nconst TilesetTypeContainer = styled.div`\n  display: grid;\n  grid-template-columns: repeat(4, ${WIDTH_ICON});\n`;\n*/\n\nconst MetaContainer = styled.div`\n  display: flex;\n  max-height: 400px;\n  background-color: ${({theme}) => theme.editorBackground};\n`;\n\nexport interface MetaInnerContainerProps {\n  width: number;\n  height: number;\n}\n\nconst MetaInnerContainer = styled.div<MetaInnerContainerProps>`\n  position: relative;\n  border: 1px solid ${props => props.theme.selectBorderColorLT};\n  background-color: white;\n  border-radius: 2px;\n  display: inline-block;\n  font: inherit;\n  line-height: 1.5em;\n  padding: 0.5em 3.5em 0.5em 1em;\n  margin-left: 10px;\n  box-sizing: border-box;\n  overflow-y: scroll;\n  overflow-x: auto;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n  height: ${props => props.height}px;\n  width: ${props => props.width}px;\n  max-width: 600px;\n`;\n\nconst StyledHeaderMessage = styled.div`\n  color: ${props => props.theme.textColorLT};\n  font-size: 14px;\n  margin-bottom: 12px;\n`;\n\ntype LoadTilesetTabProps = {\n  meta: {[key: string]: any};\n  isAddingDatasets: boolean;\n  onTilesetAdded: (tilesetInfo: any, metadata?: any) => void;\n  intl: IntlShape;\n};\n\nconst TILE_TYPES = [\n  {\n    id: 'vectorTile',\n    label: 'Vector Tile',\n    Icon: VectorTileIcon,\n    Component: TilesetVectorForm\n  }\n];\n\nfunction isReady(response) {\n  return response.dataset && !response.loading && !response.error;\n}\n\nfunction LoadTilesetTabFactory() {\n  const LoadTilesetTab: React.FC<LoadTilesetTabProps> = ({\n    onTilesetAdded,\n    isAddingDatasets,\n    intl\n  }) => {\n    const [typeIndex /* , setTypeIndex*/] = useState<number>(0);\n    const [response, setResponse] = useState<MetaResponse>({});\n\n    const error = response.error;\n    const loading = response.loading;\n    const data = response.metadata;\n    const jsonDataText = useMemo(() => JSON.stringify(data, null, 2), [data]);\n\n    const createTileDataset = useCallback(() => {\n      const {dataset, metadata} = response;\n      if (dataset) {\n        onTilesetAdded(dataset, metadata);\n      }\n    }, [onTilesetAdded, response]);\n\n    const CurrentForm = TILE_TYPES[typeIndex].Component;\n\n    const tilesetHeaderMessage = `${intl.formatMessage({\n      id: 'tilesetSetup.header'\n    })}`;\n\n    return (\n      <LoadTilesetTabContainer>\n        <Container>\n          <div>\n            <StyledHeaderMessage>{tilesetHeaderMessage}</StyledHeaderMessage>\n            {/** \n            <div>\n              <label htmlFor=\"tileset-type\">Tileset Type</label>\n            </div>\n             * Enable once we support different vector layers\n            <TilesetTypeContainer className=\"tileset-type\">\n              {TILE_TYPES.map((tileType, index) => (\n                <TilesetIcon\n                  key={tileType.label}\n                  name={tileType.label}\n                  Icon={<tileType.Icon height={WIDTH_ICON} />}\n                  onClick={() => setTypeIndex(index)}\n                  selected={typeIndex === index}\n                />\n              ))}\n            </TilesetTypeContainer>\n            */}\n            <div>\n              <CurrentForm setResponse={setResponse} />\n              {/** \n              {error && <div>{getError(error)}</div>}\n              */}\n            </div>\n          </div>\n          <MetaContainer>\n            {data && (\n              <AutoSizer>\n                {({height, width}) => (\n                  <MetaInnerContainer height={height} width={width}>\n                    <JSONPretty id=\"json-pretty\" json={jsonDataText} />\n                  </MetaInnerContainer>\n                )}\n              </AutoSizer>\n            )}\n          </MetaContainer>\n        </Container>\n        <LoadDataFooter\n          disabled={Boolean(error) || !isReady(response)}\n          isLoading={loading || isAddingDatasets}\n          onConfirm={createTileDataset}\n          confirmText=\"tilesetSetup.addTilesetText\"\n          errorText={error && getError(error)}\n        />\n      </LoadTilesetTabContainer>\n    );\n  };\n\n  return LoadTilesetTab;\n}\n\nexport default LoadTilesetTabFactory;\n"],"mappings":";;;;;;;;;;AAGA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAEA,IAAAC,gBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAH,OAAA;AACA,IAAAI,iBAAA,GAAAF,sBAAA,CAAAF,OAAA;AAEA,IAAAK,OAAA,GAAAL,OAAA;AACA,IAAAM,MAAA,GAAAN,OAAA;AAGA,IAAAO,eAAA,GAAAL,sBAAA,CAAAF,OAAA;AAEA,IAAAQ,kBAAA,GAAAN,sBAAA,CAAAF,OAAA;AAAsD,IAAAS,eAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAftD;AACA;AAaA;AAAA,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAhB,wBAAAgB,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAGA;;AAEA,IAAMW,uBAAuB,GAAGC,4BAAM,CAACC,GAAG,CAAA3B,eAAA,KAAAA,eAAA,OAAA4B,uBAAA,uCAC/B,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACC,KAAK;AAAA,EACpC;AAED,IAAMC,SAAS,GAAGN,4BAAM,CAACC,GAAG,CAAA1B,gBAAA,KAAAA,gBAAA,OAAA2B,uBAAA,yHAGN,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACG,KAAK;AAAA,EAC/C;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA,IAAMC,aAAa,GAAGR,4BAAM,CAACC,GAAG,CAAAzB,gBAAA,KAAAA,gBAAA,OAAA0B,uBAAA,0FAGV,UAAAO,IAAA;EAAA,IAAEL,KAAK,GAAAK,IAAA,CAALL,KAAK;EAAA,OAAMA,KAAK,CAACM,gBAAgB;AAAA,EACxD;AAOD,IAAMC,kBAAkB,GAAGX,4BAAM,CAACC,GAAG,CAAAxB,gBAAA,KAAAA,gBAAA,OAAAyB,uBAAA,6aAEf,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACQ,mBAAmB;AAAA,GAalD,UAAAT,KAAK;EAAA,OAAIA,KAAK,CAACU,MAAM;AAAA,GACtB,UAAAV,KAAK;EAAA,OAAIA,KAAK,CAACW,KAAK;AAAA,EAE9B;AAED,IAAMC,mBAAmB,GAAGf,4BAAM,CAACC,GAAG,CAAAvB,gBAAA,KAAAA,gBAAA,OAAAwB,uBAAA,mFAC3B,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACY,WAAW;AAAA,EAG1C;AASD,IAAMC,UAAU,GAAG,CACjB;EACEC,EAAE,EAAE,YAAY;EAChBC,KAAK,EAAE,aAAa;EACpBC,IAAI,EAAEC,sBAAc;EACpBC,SAAS,EAAEC;AACb,CAAC,CACF;AAED,SAASC,OAAOA,CAACC,QAAQ,EAAE;EACzB,OAAOA,QAAQ,CAACC,OAAO,IAAI,CAACD,QAAQ,CAACE,OAAO,IAAI,CAACF,QAAQ,CAACG,KAAK;AACjE;AAEA,SAASC,qBAAqBA,CAAA,EAAG;EAC/B,IAAMC,cAA6C,GAAG,SAAhDA,cAA6CA,CAAAC,KAAA,EAI7C;IAAA,IAHJC,cAAc,GAAAD,KAAA,CAAdC,cAAc;MACdC,gBAAgB,GAAAF,KAAA,CAAhBE,gBAAgB;MAChBC,IAAI,GAAAH,KAAA,CAAJG,IAAI;IAEJ,IAAAC,SAAA,GAAwC,IAAAC,eAAQ,EAAS,CAAC,CAAC;MAAAC,UAAA,OAAAC,eAAA,aAAAH,SAAA;MAApDI,SAAS,CAAC,sBAAAF,UAAA;IACjB,IAAAG,UAAA,GAAgC,IAAAJ,eAAQ,EAAe,CAAC,CAAC,CAAC;MAAAK,UAAA,OAAAH,eAAA,aAAAE,UAAA;MAAnDf,QAAQ,GAAAgB,UAAA;MAAEC,WAAW,GAAAD,UAAA;IAE5B,IAAMb,KAAK,GAAGH,QAAQ,CAACG,KAAK;IAC5B,IAAMD,OAAO,GAAGF,QAAQ,CAACE,OAAO;IAChC,IAAMgB,IAAI,GAAGlB,QAAQ,CAACmB,QAAQ;IAC9B,IAAMC,YAAY,GAAG,IAAAC,cAAO,EAAC;MAAA,OAAMC,IAAI,CAACC,SAAS,CAACL,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;IAAA,GAAE,CAACA,IAAI,CAAC,CAAC;IAEzE,IAAMM,iBAAiB,GAAG,IAAAC,kBAAW,EAAC,YAAM;MAC1C,IAAOxB,OAAO,GAAcD,QAAQ,CAA7BC,OAAO;QAAEkB,QAAQ,GAAInB,QAAQ,CAApBmB,QAAQ;MACxB,IAAIlB,OAAO,EAAE;QACXM,cAAc,CAACN,OAAO,EAAEkB,QAAQ,CAAC;MACnC;IACF,CAAC,EAAE,CAACZ,cAAc,EAAEP,QAAQ,CAAC,CAAC;IAE9B,IAAM0B,WAAW,GAAGlC,UAAU,CAACsB,SAAS,CAAC,CAACjB,SAAS;IAEnD,IAAM8B,oBAAoB,MAAAC,MAAA,CAAMnB,IAAI,CAACoB,aAAa,CAAC;MACjDpC,EAAE,EAAE;IACN,CAAC,CAAC,CAAE;IAEJ,oBACEvD,MAAA,YAAA4F,aAAA,CAACxD,uBAAuB,qBACtBpC,MAAA,YAAA4F,aAAA,CAACjD,SAAS,qBACR3C,MAAA,YAAA4F,aAAA,2BACE5F,MAAA,YAAA4F,aAAA,CAACxC,mBAAmB,QAAEqC,oBAA0C,CAAC,eAkBjEzF,MAAA,YAAA4F,aAAA,2BACE5F,MAAA,YAAA4F,aAAA,CAACJ,WAAW;MAACT,WAAW,EAAEA;IAAY,CAAE,CAIrC,CACF,CAAC,eACN/E,MAAA,YAAA4F,aAAA,CAAC/C,aAAa,QACXmC,IAAI,iBACHhF,MAAA,YAAA4F,aAAA,CAACvF,iBAAA,CAAAwF,SAAS,QACP,UAAAC,KAAA;MAAA,IAAE5C,MAAM,GAAA4C,KAAA,CAAN5C,MAAM;QAAEC,KAAK,GAAA2C,KAAA,CAAL3C,KAAK;MAAA,oBACdnD,MAAA,YAAA4F,aAAA,CAAC5C,kBAAkB;QAACE,MAAM,EAAEA,MAAO;QAACC,KAAK,EAAEA;MAAM,gBAC/CnD,MAAA,YAAA4F,aAAA,CAACzF,gBAAA,WAAU;QAACoD,EAAE,EAAC,aAAa;QAACwC,IAAI,EAAEb;MAAa,CAAE,CAChC,CAAC;IAAA,CAEd,CAEA,CACN,CAAC,eACZlF,MAAA,YAAA4F,aAAA,CAACnF,eAAA,WAAc;MACbuF,QAAQ,EAAEC,OAAO,CAAChC,KAAK,CAAC,IAAI,CAACJ,OAAO,CAACC,QAAQ,CAAE;MAC/CoC,SAAS,EAAElC,OAAO,IAAIM,gBAAiB;MACvC6B,SAAS,EAAEb,iBAAkB;MAC7Bc,WAAW,EAAC,6BAA6B;MACzCC,SAAS,EAAEpC,KAAK,IAAI,IAAAqC,eAAQ,EAACrC,KAAK;IAAE,CACrC,CACsB,CAAC;EAE9B,CAAC;EAED,OAAOE,cAAc;AACvB;AAAC,IAAAoC,QAAA,GAAAC,OAAA,cAEctC,qBAAqB","ignoreList":[]}