UNPKG

kepler.gl.geoiq

Version:

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

308 lines (259 loc) 37.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.AddDataButtonFactory = AddDataButtonFactory; exports.AddExternalDataButtonFactory = AddExternalDataButtonFactory; exports["default"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _propTypes = _interopRequireDefault(require("prop-types")); var _reactSortableHoc = require("react-sortable-hoc"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _reselect = require("reselect"); var _dataUtils = require("../../utils/data-utils"); var _layerPanel = _interopRequireDefault(require("./layer-panel/layer-panel")); var _sourceDataCatalog = _interopRequireDefault(require("./common/source-data-catalog")); var _icons = require("../common/icons"); var _itemSelector = _interopRequireDefault(require("../common/item-selector/item-selector")); var _styledComponents2 = require("../common/styled-components"); var _defaultSettings = require("../../constants/default-settings"); var _templateObject; function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } // make sure the element is always visible while is being dragged // item being dragged is appended in body, here to reset its global style var SortableStyledItem = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n z-index: ", ";\n\n &.sorting {\n pointer-events: none;\n }\n\n &.sorting-layers .layer-panel__header {\n background-color: ", ";\n font-family: ", ";\n font-weight: ", ";\n font-size: ", ";\n line-height: ", ";\n width: 100%;\n *,\n *:before,\n *:after {\n box-sizing: border-box;\n }\n .layer__drag-handle {\n opacity: 1;\n color: ", ";\n }\n }\n"])), function (props) { return props.theme.dropdownWrapperZ + 1; }, function (props) { return props.theme.panelBackgroundHover; }, function (props) { return props.theme.fontFamily; }, function (props) { return props.theme.fontWeight; }, function (props) { return props.theme.fontSize; }, function (props) { return props.theme.lineHeight; }, function (props) { return props.theme.textColorHl; }); function AddDataButtonFactory() { var AddDataButton = function AddDataButton(_ref) { var onClick = _ref.onClick, isInactive = _ref.isInactive; return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { onClick: onClick, isInactive: !isInactive, width: "105px", secondary: true }, /*#__PURE__*/_react["default"].createElement(_icons.Add, { height: "12px" }), "Add Data") ); }; return AddDataButton; } function AddExternalDataButtonFactory() { var AddExternalDataButton = function AddExternalDataButton(_ref2) { var onClick = _ref2.onClick, isInactive = _ref2.isInactive; return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { onClick: onClick, isInactive: !isInactive, width: "135", margin: '0px 0px 0px 16px', secondary: true }, /*#__PURE__*/_react["default"].createElement(_icons.Add, { height: "12px" }), "Add Ext. Data") ); }; return AddExternalDataButton; } LayerManagerFactory.deps = [AddDataButtonFactory, AddExternalDataButtonFactory, _layerPanel["default"], _sourceDataCatalog["default"]]; function LayerManagerFactory(AddDataButton, AddExternalDataButton, LayerPanel, SourceDataCatalog) { var _class, _temp; // By wrapping layer panel using a sortable element we don't have to implement the drag and drop logic into the panel itself; // Developers can provide any layer panel implementation and it will still be sortable var SortableItem = (0, _reactSortableHoc.sortableElement)(function (_ref3) { var children = _ref3.children, isSorting = _ref3.isSorting; return (/*#__PURE__*/_react["default"].createElement(SortableStyledItem, { className: (0, _classnames["default"])('sortable-layer-items', { sorting: isSorting }) }, children) ); }); var SortableContainer = (0, _reactSortableHoc.sortableContainer)(function (_ref4) { var children = _ref4.children; return (/*#__PURE__*/_react["default"].createElement("div", null, children) ); }); return _temp = _class = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(LayerManager, _Component); var _super = _createSuper(LayerManager); function LayerManager() { var _this; (0, _classCallCheck2["default"])(this, LayerManager); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _super.call.apply(_super, [this].concat(args)); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { isSorting: false }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "layerClassSelector", function (props) { return props.layerClasses; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "layerTypeOptionsSelector", (0, _reselect.createSelector)(_this.layerClassSelector, function (layerClasses) { return Object.keys(layerClasses).map(function (key) { var layer = new layerClasses[key](); return { id: key, label: layer.name, icon: layer.layerIcon }; }); })); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_addEmptyNewLayer", function () { _this.props.addLayer(); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_handleSort", function (_ref5) { var oldIndex = _ref5.oldIndex, newIndex = _ref5.newIndex; _this.props.updateLayerOrder((0, _dataUtils.arrayMove)(_this.props.layerOrder, oldIndex, newIndex)); _this.setState({ isSorting: false }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onSortStart", function () { _this.setState({ isSorting: true }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateBeforeSortStart", function (_ref6) { var index = _ref6.index; // if layer config is active, close it var _this$props = _this.props, layerOrder = _this$props.layerOrder, layers = _this$props.layers, layerConfigChange = _this$props.layerConfigChange; var layerIdx = layerOrder[index]; if (layers[layerIdx].config.isConfigActive) { layerConfigChange(layers[layerIdx], { isConfigActive: false }); } }); return _this; } (0, _createClass2["default"])(LayerManager, [{ key: "render", value: function render() { var _this2 = this; var _this$props2 = this.props, layers = _this$props2.layers, datasets = _this$props2.datasets, layerOrder = _this$props2.layerOrder, openModal = _this$props2.openModal, mapState = _this$props2.mapState, filters = _this$props2.filters, isPublic = _this$props2.isPublic; var defaultDataset = Object.keys(datasets)[0]; var layerTypeOptions = this.layerTypeOptionsSelector(this.props); var layerActions = { layerColorUIChange: this.props.layerColorUIChange, layerConfigChange: this.props.layerConfigChange, layerVisualChannelConfigChange: this.props.layerVisualChannelConfigChange, layerTypeChange: this.props.layerTypeChange, layerVisConfigChange: this.props.layerVisConfigChange, layerTextLabelChange: this.props.layerTextLabelChange, removeLayer: this.props.removeLayer, updateLayerData: this.props.updateLayerData }; var panelProps = { datasets: datasets, openModal: openModal, layerTypeOptions: layerTypeOptions, mapState: mapState, filters: filters }; return (/*#__PURE__*/_react["default"].createElement("div", { className: "layer-manager" }, /*#__PURE__*/_react["default"].createElement(SourceDataCatalog, { datasets: datasets, showDatasetTable: isPublic ? this.props.showDatasetTable : false, removeDataset: this.props.removeDataset, showDeleteDataset: true }), isPublic && /*#__PURE__*/_react["default"].createElement(AddDataButton, { onClick: this.props.showAddDataModal, isInactive: !defaultDataset }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelDivider, null), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(SortableContainer, { onSortEnd: this._handleSort, onSortStart: this._onSortStart, updateBeforeSortStart: this._updateBeforeSortStart, lockAxis: "y", helperClass: "sorting-layers", useDragHandle: true }, layerOrder.map(function (layerIdx, index) { return (/*#__PURE__*/_react["default"].createElement(SortableItem, { key: "layer-".concat(layerIdx), index: index, isSorting: _this2.state.isSorting }, /*#__PURE__*/_react["default"].createElement(LayerPanel, (0, _extends2["default"])({}, panelProps, layerActions, { sortData: layerIdx, key: layers[layerIdx].id, idx: layerIdx, layer: layers[layerIdx] }))) ); }))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, defaultDataset ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { onClick: this._addEmptyNewLayer, width: "105px" }, /*#__PURE__*/_react["default"].createElement(_icons.Add, { height: "12px" }), "Add Layer") : null)) ); } }]); return LayerManager; }(_react.Component), (0, _defineProperty2["default"])(_class, "propTypes", { datasets: _propTypes["default"].object.isRequired, layerBlending: _propTypes["default"].string.isRequired, layerClasses: _propTypes["default"].object.isRequired, layers: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired, // functions addLayer: _propTypes["default"].func.isRequired, layerColorUIChange: _propTypes["default"].func.isRequired, layerConfigChange: _propTypes["default"].func.isRequired, layerTextLabelChange: _propTypes["default"].func.isRequired, layerVisualChannelConfigChange: _propTypes["default"].func.isRequired, layerTypeChange: _propTypes["default"].func.isRequired, layerVisConfigChange: _propTypes["default"].func.isRequired, openModal: _propTypes["default"].func.isRequired, removeLayer: _propTypes["default"].func.isRequired, removeDataset: _propTypes["default"].func.isRequired, showDatasetTable: _propTypes["default"].func.isRequired, updateLayerBlending: _propTypes["default"].func.isRequired, updateLayerOrder: _propTypes["default"].func.isRequired, updateLayerData: _propTypes["default"].func.isRequired, axiosAPICAll: _propTypes["default"].func.isRequired }), _temp; } var _default = exports["default"] = LayerManagerFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/layer-manager.js"],"names":["SortableStyledItem","styled","div","props","theme","dropdownWrapperZ","panelBackgroundHover","fontFamily","fontWeight","fontSize","lineHeight","textColorHl","AddDataButtonFactory","AddDataButton","onClick","isInactive","AddExternalDataButtonFactory","AddExternalDataButton","LayerManagerFactory","deps","LayerPanelFactory","SourceDataCatalogFactory","LayerPanel","SourceDataCatalog","SortableItem","children","isSorting","sorting","SortableContainer","layerClasses","layerClassSelector","Object","keys","map","key","layer","id","label","name","icon","layerIcon","addLayer","oldIndex","newIndex","updateLayerOrder","layerOrder","setState","index","layers","layerConfigChange","layerIdx","config","isConfigActive","datasets","openModal","mapState","filters","isPublic","defaultDataset","layerTypeOptions","layerTypeOptionsSelector","layerActions","layerColorUIChange","layerVisualChannelConfigChange","layerTypeChange","layerVisConfigChange","layerTextLabelChange","removeLayer","updateLayerData","panelProps","showDatasetTable","removeDataset","showAddDataModal","_handleSort","_onSortStart","_updateBeforeSortStart","state","_addEmptyNewLayer","Component","PropTypes","object","isRequired","layerBlending","string","arrayOf","any","func","updateLayerBlending","axiosAPICAll"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component} from 'react';\nimport classnames from 'classnames';\n\nimport PropTypes from 'prop-types';\nimport {sortableContainer, sortableElement} from 'react-sortable-hoc';\nimport styled from 'styled-components';\nimport {createSelector} from 'reselect';\nimport {arrayMove} from 'utils/data-utils';\n\nimport LayerPanelFactory from './layer-panel/layer-panel';\nimport SourceDataCatalogFactory from './common/source-data-catalog';\nimport {Add} from 'components/common/icons';\nimport ItemSelector from 'components/common/item-selector/item-selector';\nimport {\n  PanelLabel,\n  SidePanelDivider,\n  SidePanelSection,\n  Button\n} from 'components/common/styled-components';\n\nimport {LAYER_BLENDINGS} from 'constants/default-settings';\n\n// make sure the element is always visible while is being dragged\n// item being dragged is appended in body, here to reset its global style\nconst SortableStyledItem = styled.div`\n  z-index: ${props => props.theme.dropdownWrapperZ + 1};\n\n  &.sorting {\n    pointer-events: none;\n  }\n\n  &.sorting-layers .layer-panel__header {\n    background-color: ${props => props.theme.panelBackgroundHover};\n    font-family: ${props => props.theme.fontFamily};\n    font-weight: ${props => props.theme.fontWeight};\n    font-size: ${props => props.theme.fontSize};\n    line-height: ${props => props.theme.lineHeight};\n    width: 100%;\n    *,\n    *:before,\n    *:after {\n      box-sizing: border-box;\n    }\n    .layer__drag-handle {\n      opacity: 1;\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nexport function AddDataButtonFactory() {\n  const AddDataButton = ({onClick, isInactive}) => (\n    <Button onClick={onClick} isInactive={!isInactive} width=\"105px\" secondary>\n      <Add height=\"12px\" />\n      Add Data\n    </Button>\n  );\n  return AddDataButton;\n}\n\nexport function AddExternalDataButtonFactory() {\n  const AddExternalDataButton = ({onClick, isInactive}) => (\n    <Button\n      onClick={onClick}\n      isInactive={!isInactive}\n      width=\"135\"\n      margin={'0px 0px 0px 16px'}\n      secondary\n    >\n      <Add height=\"12px\" />\n      Add Ext. Data\n    </Button>\n  );\n  return AddExternalDataButton;\n}\n\nLayerManagerFactory.deps = [\n  AddDataButtonFactory,\n  AddExternalDataButtonFactory,\n  LayerPanelFactory,\n  SourceDataCatalogFactory\n];\n\nfunction LayerManagerFactory(\n  AddDataButton,\n  AddExternalDataButton,\n  LayerPanel,\n  SourceDataCatalog\n) {\n  // By wrapping layer panel using a sortable element we don't have to implement the drag and drop logic into the panel itself;\n  // Developers can provide any layer panel implementation and it will still be sortable\n  const SortableItem = sortableElement(({children, isSorting}) => {\n    return (\n      <SortableStyledItem\n        className={classnames('sortable-layer-items', {sorting: isSorting})}\n      >\n        {children}\n      </SortableStyledItem>\n    );\n  });\n\n  const SortableContainer = sortableContainer(({children}) => {\n    return <div>{children}</div>;\n  });\n\n  return class LayerManager extends Component {\n    static propTypes = {\n      datasets: PropTypes.object.isRequired,\n      layerBlending: PropTypes.string.isRequired,\n      layerClasses: PropTypes.object.isRequired,\n      layers: PropTypes.arrayOf(PropTypes.any).isRequired,\n      // functions\n      addLayer: PropTypes.func.isRequired,\n      layerColorUIChange: PropTypes.func.isRequired,\n      layerConfigChange: PropTypes.func.isRequired,\n      layerTextLabelChange: PropTypes.func.isRequired,\n      layerVisualChannelConfigChange: PropTypes.func.isRequired,\n      layerTypeChange: PropTypes.func.isRequired,\n      layerVisConfigChange: PropTypes.func.isRequired,\n      openModal: PropTypes.func.isRequired,\n      removeLayer: PropTypes.func.isRequired,\n      removeDataset: PropTypes.func.isRequired,\n      showDatasetTable: PropTypes.func.isRequired,\n      updateLayerBlending: PropTypes.func.isRequired,\n      updateLayerOrder: PropTypes.func.isRequired,\n      updateLayerData: PropTypes.func.isRequired,\n      axiosAPICAll: PropTypes.func.isRequired\n    };\n    state = {\n      isSorting: false\n    };\n\n    layerClassSelector = props => props.layerClasses;\n    layerTypeOptionsSelector = createSelector(\n      this.layerClassSelector,\n      layerClasses =>\n        Object.keys(layerClasses).map(key => {\n          const layer = new layerClasses[key]();\n          return {\n            id: key,\n            label: layer.name,\n            icon: layer.layerIcon\n          };\n        })\n    );\n\n    _addEmptyNewLayer = () => {\n      this.props.addLayer();\n    };\n\n    _handleSort = ({oldIndex, newIndex}) => {\n      this.props.updateLayerOrder(\n        arrayMove(this.props.layerOrder, oldIndex, newIndex)\n      );\n      this.setState({isSorting: false});\n    };\n\n    _onSortStart = () => {\n      this.setState({isSorting: true});\n    };\n\n    _updateBeforeSortStart = ({index}) => {\n      // if layer config is active, close it\n      const {layerOrder, layers, layerConfigChange} = this.props;\n      const layerIdx = layerOrder[index];\n      if (layers[layerIdx].config.isConfigActive) {\n        layerConfigChange(layers[layerIdx], {isConfigActive: false});\n      }\n    };\n\n    render() {\n      const {\n        layers,\n        datasets,\n        layerOrder,\n        openModal,\n        mapState,\n        filters,\n        isPublic\n      } = this.props;\n      const defaultDataset = Object.keys(datasets)[0];\n      const layerTypeOptions = this.layerTypeOptionsSelector(this.props);\n      const layerActions = {\n        layerColorUIChange: this.props.layerColorUIChange,\n        layerConfigChange: this.props.layerConfigChange,\n        layerVisualChannelConfigChange: this.props\n          .layerVisualChannelConfigChange,\n        layerTypeChange: this.props.layerTypeChange,\n        layerVisConfigChange: this.props.layerVisConfigChange,\n        layerTextLabelChange: this.props.layerTextLabelChange,\n        removeLayer: this.props.removeLayer,\n        updateLayerData: this.props.updateLayerData\n      };\n\n      const panelProps = {\n        datasets,\n        openModal,\n        layerTypeOptions,\n        mapState,\n        filters\n      };\n\n      return (\n        <div className=\"layer-manager\">\n          <SourceDataCatalog\n            datasets={datasets}\n            showDatasetTable={isPublic ? this.props.showDatasetTable : false}\n            removeDataset={this.props.removeDataset}\n            showDeleteDataset\n          />\n\n          {isPublic && (\n            <AddDataButton\n              onClick={this.props.showAddDataModal}\n              isInactive={!defaultDataset}\n            />\n          )}\n\n          {/* <AddExternalDataButton\n            onClick={this.props.showAddExternalDataModal}\n            isInactive={!defaultDataset}\n          /> */}\n          <SidePanelDivider />\n          <SidePanelSection>\n            <SortableContainer\n              onSortEnd={this._handleSort}\n              onSortStart={this._onSortStart}\n              updateBeforeSortStart={this._updateBeforeSortStart}\n              lockAxis=\"y\"\n              helperClass=\"sorting-layers\"\n              useDragHandle\n            >\n              {layerOrder.map((layerIdx, index) => (\n                <SortableItem\n                  key={`layer-${layerIdx}`}\n                  index={index}\n                  isSorting={this.state.isSorting}\n                >\n                  <LayerPanel\n                    {...panelProps}\n                    {...layerActions}\n                    sortData={layerIdx}\n                    key={layers[layerIdx].id}\n                    idx={layerIdx}\n                    layer={layers[layerIdx]}\n                  />\n                </SortableItem>\n              ))}\n            </SortableContainer>\n          </SidePanelSection>\n          <SidePanelSection>\n            {defaultDataset ? (\n              <Button onClick={this._addEmptyNewLayer} width=\"105px\">\n                <Add height=\"12px\" />\n                Add Layer\n              </Button>\n            ) : null}\n          </SidePanelSection>\n        </div>\n      );\n    }\n  };\n}\n\nexport default LayerManagerFactory;\n"]}