kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
158 lines (155 loc) • 27.4 kB
JavaScript
;
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 _tilesetIcon = _interopRequireDefault(require("./tileset-icon"));
var _tilesetVectorForm = _interopRequireDefault(require("./tileset-vector-form"));
var _tilesetRasterForm = _interopRequireDefault(require("./tileset-raster-form"));
var _tilesetWmsForm = _interopRequireDefault(require("./tileset-wms-form"));
var _tilesetTile3dForm = _interopRequireDefault(require("./tileset-tile3d-form"));
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6; // 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 WIDTH_ICON = '70px';
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 grid-gap: 20px;\n background-color: ", ";\n"])), function (props) {
return props.theme.WHITE;
});
var TilesetTypeContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n grid-template-columns: repeat(5, ", ");\n column-gap: 10px;\n margin-bottom: 20px;\n"])), WIDTH_ICON);
var MetaContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (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(_templateObject5 || (_templateObject5 = (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 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 color: ", ";\n font-size: 11px;\n font-family: ", ";\n max-width: 600px;\n"])), function (props) {
return props.theme.selectBorderColorLT;
}, function (props) {
return props.height;
}, function (props) {
return props.width;
}, function (props) {
return props.theme.textColorLT;
}, function (props) {
return props.theme.fontFamily;
});
var StyledHeaderMessage = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 14px;\n"])), function (props) {
return props.theme.textColorLT;
});
var TILE_TYPES = [{
id: 'vectorTile',
label: 'Vector Tile',
Icon: _layers.VectorTileIcon,
Component: _tilesetVectorForm["default"]
}, {
id: 'rasterTile',
label: 'Raster Tile',
Icon: _layers.RasterTileIcon,
Component: _tilesetRasterForm["default"]
}, {
id: 'wms',
label: 'WMS',
Icon: _layers.WMSLayerIcon,
Component: _tilesetWmsForm["default"]
}, {
id: 'tile3d',
label: '3D Tile',
Icon: _layers.Tile3DLayerIcon,
Component: _tilesetTile3dForm["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;
var _useState = (0, _react.useState)(0),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
typeIndex = _useState2[0],
setTypeIndex = _useState2[1];
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]);
// temp patch to hide raster tile layer while in development
var enableRasterTileLayer = (0, _utils.getApplicationConfig)().enableRasterTileLayer;
var enableWMSLayer = (0, _utils.getApplicationConfig)().enableWMSLayer;
// Filter tile types based on application config
var tileTypes = (0, _react.useMemo)(function () {
var types = TILE_TYPES.filter(function (tileType) {
if (tileType.id === 'rasterTile') {
return enableRasterTileLayer;
}
if (tileType.id === 'wms') {
return enableWMSLayer;
}
return true; // Include all other types by default
});
return types;
}, [enableRasterTileLayer, enableWMSLayer]);
var CurrentForm = tileTypes[typeIndex].Component;
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, "Tileset Type"), /*#__PURE__*/_react["default"].createElement(TilesetTypeContainer, {
className: "tileset-type"
}, tileTypes.map(function (tileType, index) {
return /*#__PURE__*/_react["default"].createElement(_tilesetIcon["default"], {
key: tileType.label,
name: tileType.label,
Icon: /*#__PURE__*/_react["default"].createElement(tileType.Icon, {
height: WIDTH_ICON
}),
onClick: function onClick() {
return setTypeIndex(index);
},
selected: typeIndex === index
});
})), /*#__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","_tilesetIcon","_tilesetVectorForm","_tilesetRasterForm","_tilesetWmsForm","_tilesetTile3dForm","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","WIDTH_ICON","LoadTilesetTabContainer","styled","div","_taggedTemplateLiteral2","props","theme","AZURE","Container","WHITE","TilesetTypeContainer","MetaContainer","_ref","editorBackground","MetaInnerContainer","selectBorderColorLT","height","width","textColorLT","fontFamily","StyledHeaderMessage","TILE_TYPES","id","label","Icon","VectorTileIcon","Component","TilesetVectorForm","RasterTileIcon","TilesetRasterForm","WMSLayerIcon","TilesetWMSForm","Tile3DLayerIcon","TilesetTile3DForm","isReady","response","dataset","loading","error","LoadTilesetTabFactory","LoadTilesetTab","_ref2","onTilesetAdded","isAddingDatasets","_useState","useState","_useState2","_slicedToArray2","typeIndex","setTypeIndex","_useState3","_useState4","setResponse","data","metadata","jsonDataText","useMemo","JSON","stringify","createTileDataset","useCallback","enableRasterTileLayer","getApplicationConfig","enableWMSLayer","tileTypes","types","filter","tileType","CurrentForm","createElement","className","map","index","key","name","onClick","selected","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, RasterTileIcon, WMSLayerIcon, Tile3DLayerIcon} from '@kepler.gl/layers';\nimport {getError, getApplicationConfig} from '@kepler.gl/utils';\n\nimport {MetaResponse} from './common';\nimport LoadDataFooter from './load-data-footer';\nimport TilesetIcon from './tileset-icon';\nimport TilesetVectorForm from './tileset-vector-form';\nimport TilesetRasterForm from './tileset-raster-form';\n\nimport TilesetWMSForm from './tileset-wms-form';\nimport TilesetTile3DForm from './tileset-tile3d-form';\n\nconst WIDTH_ICON = '70px';\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  grid-gap: 20px;\n  background-color: ${props => props.theme.WHITE};\n`;\n\nconst TilesetTypeContainer = styled.div`\n  display: grid;\n  grid-template-columns: repeat(5, ${WIDTH_ICON});\n  column-gap: 10px;\n  margin-bottom: 20px;\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  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  color: ${props => props.theme.textColorLT};\n  font-size: 11px;\n  font-family: ${props => props.theme.fontFamily};\n  max-width: 600px;\n`;\n\nconst StyledHeaderMessage = styled.div`\n  color: ${props => props.theme.textColorLT};\n  font-size: 14px;\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    id: 'rasterTile',\n    label: 'Raster Tile',\n    Icon: RasterTileIcon,\n    Component: TilesetRasterForm\n  },\n  {\n    id: 'wms',\n    label: 'WMS',\n    Icon: WMSLayerIcon,\n    Component: TilesetWMSForm\n  },\n  {\n    id: 'tile3d',\n    label: '3D Tile',\n    Icon: Tile3DLayerIcon,\n    Component: TilesetTile3DForm\n  }\n];\n\nfunction isReady(response) {\n  return response.dataset && !response.loading && !response.error;\n}\n\nfunction LoadTilesetTabFactory() {\n  const LoadTilesetTab: React.FC<LoadTilesetTabProps> = ({onTilesetAdded, isAddingDatasets}) => {\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    // temp patch to hide raster tile layer while in development\n    const enableRasterTileLayer = getApplicationConfig().enableRasterTileLayer;\n    const enableWMSLayer = getApplicationConfig().enableWMSLayer;\n\n    // Filter tile types based on application config\n    const tileTypes = useMemo(() => {\n      const types = TILE_TYPES.filter(tileType => {\n        if (tileType.id === 'rasterTile') {\n          return enableRasterTileLayer;\n        }\n        if (tileType.id === 'wms') {\n          return enableWMSLayer;\n        }\n        return true; // Include all other types by default\n      });\n      return types;\n    }, [enableRasterTileLayer, enableWMSLayer]);\n\n    const CurrentForm = tileTypes[typeIndex].Component;\n\n    return (\n      <LoadTilesetTabContainer>\n        <Container>\n          <div>\n            <StyledHeaderMessage>Tileset Type</StyledHeaderMessage>\n\n            <TilesetTypeContainer className=\"tileset-type\">\n              {tileTypes.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            <div>\n              <CurrentForm setResponse={setResponse} />\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":"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","ignoreList":[]}