UNPKG

kepler.gl

Version:

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

322 lines (271 loc) 38.5 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.AddDataButtonFactory = AddDataButtonFactory; 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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); 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 _reactIntl = require("react-intl"); 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"); function _templateObject() { var data = (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 *,\n *:before,\n *:after {\n box-sizing: border-box;\n }\n .layer__drag-handle {\n opacity: 1;\n color: ", ";\n }\n }\n"]); _templateObject = function _templateObject() { return data; }; return data; } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var LayerBlendingSelector = function LayerBlendingSelector(_ref) { var layerBlending = _ref.layerBlending, updateLayerBlending = _ref.updateLayerBlending, intl = _ref.intl; var labeledLayerBlendings = Object.keys(_defaultSettings.LAYER_BLENDINGS).reduce(function (acc, current) { return _objectSpread({}, acc, (0, _defineProperty2["default"])({}, intl.formatMessage({ id: _defaultSettings.LAYER_BLENDINGS[current].label }), current)); }, {}); var onChange = (0, _react.useCallback)(function (blending) { return updateLayerBlending(labeledLayerBlendings[blending]); }, [updateLayerBlending, labeledLayerBlendings]); return _react["default"].createElement(_styledComponents2.SidePanelSection, null, _react["default"].createElement(_styledComponents2.PanelLabel, null, _react["default"].createElement(_reactIntl.FormattedMessage, { id: "layerBlending.title" })), _react["default"].createElement(_itemSelector["default"], { selectedItems: intl.formatMessage({ id: _defaultSettings.LAYER_BLENDINGS[layerBlending].label }), options: Object.keys(labeledLayerBlendings), multiSelect: false, searchable: false, onChange: onChange })); }; // 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(), 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(_ref2) { var onClick = _ref2.onClick, isInactive = _ref2.isInactive; return _react["default"].createElement(_styledComponents2.Button, { className: "add-data-button", onClick: onClick, isInactive: !isInactive, width: "105px", secondary: true }, _react["default"].createElement(_icons.Add, { height: "12px" }), _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'layerManager.addData' })); }; return AddDataButton; } LayerManagerFactory.deps = [AddDataButtonFactory, _layerPanel["default"], _sourceDataCatalog["default"]]; function LayerManagerFactory(AddDataButton, LayerPanel, SourceDataCatalog) { // 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 _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 _react["default"].createElement("div", null, children); }); var LayerManager = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(LayerManager, _Component); function LayerManager() { var _getPrototypeOf2; 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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(LayerManager)).call.apply(_getPrototypeOf2, [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, intl = _this$props2.intl; 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 }; var panelProps = { datasets: datasets, openModal: openModal, layerTypeOptions: layerTypeOptions }; return _react["default"].createElement("div", { className: "layer-manager" }, _react["default"].createElement(SourceDataCatalog, { datasets: datasets, showDatasetTable: this.props.showDatasetTable, removeDataset: this.props.removeDataset, showDeleteDataset: true }), _react["default"].createElement(AddDataButton, { onClick: this.props.showAddDataModal, isInactive: !defaultDataset }), _react["default"].createElement(_styledComponents2.SidePanelDivider, null), _react["default"].createElement(_styledComponents2.SidePanelSection, null, _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 _react["default"].createElement(SortableItem, { key: "layer-".concat(layerIdx), index: index, isSorting: _this2.state.isSorting }, _react["default"].createElement(LayerPanel, (0, _extends2["default"])({}, panelProps, layerActions, { sortData: layerIdx, key: layers[layerIdx].id, idx: layerIdx, layer: layers[layerIdx] }))); }))), _react["default"].createElement(_styledComponents2.SidePanelSection, null, defaultDataset ? _react["default"].createElement(_styledComponents2.Button, { className: "add-layer-button", onClick: this._addEmptyNewLayer, width: "105px" }, _react["default"].createElement(_icons.Add, { height: "12px" }), _react["default"].createElement(_reactIntl.FormattedMessage, { id: 'layerManager.addLayer' })) : null), _react["default"].createElement(LayerBlendingSelector, { layerBlending: this.props.layerBlending, updateLayerBlending: this.props.updateLayerBlending, intl: intl })); } }]); return LayerManager; }(_react.Component); (0, _defineProperty2["default"])(LayerManager, "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 }); return (0, _reactIntl.injectIntl)(LayerManager); } var _default = LayerManagerFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/layer-manager.js"],"names":["LayerBlendingSelector","layerBlending","updateLayerBlending","intl","labeledLayerBlendings","Object","keys","LAYER_BLENDINGS","reduce","acc","current","formatMessage","id","label","onChange","blending","SortableStyledItem","styled","div","props","theme","dropdownWrapperZ","panelBackgroundHover","fontFamily","fontWeight","fontSize","lineHeight","textColorHl","AddDataButtonFactory","AddDataButton","onClick","isInactive","LayerManagerFactory","deps","LayerPanelFactory","SourceDataCatalogFactory","LayerPanel","SourceDataCatalog","SortableItem","children","isSorting","sorting","SortableContainer","LayerManager","layerClasses","layerClassSelector","map","key","layer","name","icon","layerIcon","addLayer","oldIndex","newIndex","updateLayerOrder","layerOrder","setState","index","layers","layerConfigChange","layerIdx","config","isConfigActive","datasets","openModal","defaultDataset","layerTypeOptions","layerTypeOptionsSelector","layerActions","layerColorUIChange","layerVisualChannelConfigChange","layerTypeChange","layerVisConfigChange","layerTextLabelChange","removeLayer","panelProps","showDatasetTable","removeDataset","showAddDataModal","_handleSort","_onSortStart","_updateBeforeSortStart","state","_addEmptyNewLayer","Component","PropTypes","object","isRequired","string","arrayOf","any","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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, useCallback} 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 {FormattedMessage, injectIntl} from 'react-intl';\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  Button,\n  PanelLabel,\n  SidePanelDivider,\n  SidePanelSection\n} from 'components/common/styled-components';\n\nimport {LAYER_BLENDINGS} from 'constants/default-settings';\n\nconst LayerBlendingSelector = ({layerBlending, updateLayerBlending, intl}) => {\n  const labeledLayerBlendings = Object.keys(LAYER_BLENDINGS).reduce(\n    (acc, current) => ({\n      ...acc,\n      [intl.formatMessage({id: LAYER_BLENDINGS[current].label})]: current\n    }),\n    {}\n  );\n\n  const onChange = useCallback(blending => updateLayerBlending(labeledLayerBlendings[blending]), [\n    updateLayerBlending,\n    labeledLayerBlendings\n  ]);\n\n  return (\n    <SidePanelSection>\n      <PanelLabel>\n        <FormattedMessage id=\"layerBlending.title\" />\n      </PanelLabel>\n      <ItemSelector\n        selectedItems={intl.formatMessage({id: LAYER_BLENDINGS[layerBlending].label})}\n        options={Object.keys(labeledLayerBlendings)}\n        multiSelect={false}\n        searchable={false}\n        onChange={onChange}\n      />\n    </SidePanelSection>\n  );\n};\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    *,\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\n      className=\"add-data-button\"\n      onClick={onClick}\n      isInactive={!isInactive}\n      width=\"105px\"\n      secondary\n    >\n      <Add height=\"12px\" />\n      <FormattedMessage id={'layerManager.addData'} />\n    </Button>\n  );\n\n  return AddDataButton;\n}\n\nLayerManagerFactory.deps = [AddDataButtonFactory, LayerPanelFactory, SourceDataCatalogFactory];\n\nfunction LayerManagerFactory(AddDataButton, LayerPanel, SourceDataCatalog) {\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 className={classnames('sortable-layer-items', {sorting: isSorting})}>\n        {children}\n      </SortableStyledItem>\n    );\n  });\n\n  const SortableContainer = sortableContainer(({children}) => {\n    return <div>{children}</div>;\n  });\n\n  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    };\n    state = {\n      isSorting: false\n    };\n\n    layerClassSelector = props => props.layerClasses;\n    layerTypeOptionsSelector = createSelector(this.layerClassSelector, 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(arrayMove(this.props.layerOrder, oldIndex, newIndex));\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 {layers, datasets, layerOrder, openModal, intl} = this.props;\n      const defaultDataset = Object.keys(datasets)[0];\n      const layerTypeOptions = this.layerTypeOptionsSelector(this.props);\n\n      const layerActions = {\n        layerColorUIChange: this.props.layerColorUIChange,\n        layerConfigChange: this.props.layerConfigChange,\n        layerVisualChannelConfigChange: this.props.layerVisualChannelConfigChange,\n        layerTypeChange: this.props.layerTypeChange,\n        layerVisConfigChange: this.props.layerVisConfigChange,\n        layerTextLabelChange: this.props.layerTextLabelChange,\n        removeLayer: this.props.removeLayer\n      };\n\n      const panelProps = {\n        datasets,\n        openModal,\n        layerTypeOptions\n      };\n\n      return (\n        <div className=\"layer-manager\">\n          <SourceDataCatalog\n            datasets={datasets}\n            showDatasetTable={this.props.showDatasetTable}\n            removeDataset={this.props.removeDataset}\n            showDeleteDataset\n          />\n          <AddDataButton onClick={this.props.showAddDataModal} isInactive={!defaultDataset} />\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 className=\"add-layer-button\" onClick={this._addEmptyNewLayer} width=\"105px\">\n                <Add height=\"12px\" />\n                <FormattedMessage id={'layerManager.addLayer'} />\n              </Button>\n            ) : null}\n          </SidePanelSection>\n          <LayerBlendingSelector\n            layerBlending={this.props.layerBlending}\n            updateLayerBlending={this.props.updateLayerBlending}\n            intl={intl}\n          />\n        </div>\n      );\n    }\n  }\n  return injectIntl(LayerManager);\n}\n\nexport default LayerManagerFactory;\n"]}