UNPKG

kepler.gl

Version:

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

316 lines (265 loc) 39.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); 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 _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 _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 _localization = require("../../localization"); 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 _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; } } 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(_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 /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "layerBlending.title" })), /*#__PURE__*/_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 || (_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 *,\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(_ref2) { var onClick = _ref2.onClick, isInactive = _ref2.isInactive; return /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { className: "add-data-button", onClick: onClick, isInactive: !isInactive, width: "105px", secondary: true }, /*#__PURE__*/_react["default"].createElement(_icons.Add, { height: "12px" }), /*#__PURE__*/_react["default"].createElement(_localization.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 /*#__PURE__*/_react["default"].createElement(SortableStyledItem, { className: (0, _classnames["default"])('sortable-layer-items', { sorting: isSorting }) }, children); }); var WrappedSortableContainer = (0, _reactSortableHoc.SortableContainer)(function (_ref4) { var children = _ref4.children; return /*#__PURE__*/_react["default"].createElement("div", null, children); }); var LayerManager = /*#__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, requireData: layer.requireData }; }); })); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_addEmptyNewLayer", function () { var visStateActions = _this.props.visStateActions; visStateActions.addLayer(); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_handleSort", function (_ref5) { var oldIndex = _ref5.oldIndex, newIndex = _ref5.newIndex; var visStateActions = _this.props.visStateActions; visStateActions.reorderLayer((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, visStateActions = _this$props.visStateActions; var layerIdx = layerOrder[index]; if (layers[layerIdx].config.isConfigActive) { visStateActions.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, intl = _this$props2.intl, layerOrder = _this$props2.layerOrder, showAddDataModal = _this$props2.showAddDataModal, showDatasetTable = _this$props2.showDatasetTable, removeDataset = _this$props2.removeDataset, uiStateActions = _this$props2.uiStateActions, visStateActions = _this$props2.visStateActions; var openModal = uiStateActions.toggleModal; var defaultDataset = Object.keys(datasets)[0]; var layerTypeOptions = this.layerTypeOptionsSelector(this.props); var layerActions = { layerColorUIChange: visStateActions.layerColorUIChange, layerConfigChange: visStateActions.layerConfigChange, layerVisualChannelConfigChange: visStateActions.layerVisualChannelConfigChange, layerTypeChange: visStateActions.layerTypeChange, layerVisConfigChange: visStateActions.layerVisConfigChange, layerTextLabelChange: visStateActions.layerTextLabelChange, removeLayer: visStateActions.removeLayer, duplicateLayer: visStateActions.duplicateLayer }; var panelProps = { datasets: datasets, openModal: openModal, layerTypeOptions: layerTypeOptions }; return /*#__PURE__*/_react["default"].createElement("div", { className: "layer-manager" }, /*#__PURE__*/_react["default"].createElement(SourceDataCatalog, { datasets: datasets, showDatasetTable: showDatasetTable, removeDataset: removeDataset, showDeleteDataset: true }), /*#__PURE__*/_react["default"].createElement(AddDataButton, { onClick: showAddDataModal, isInactive: !defaultDataset }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelDivider, null), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(WrappedSortableContainer, { onSortEnd: this._handleSort, onSortStart: this._onSortStart, updateBeforeSortStart: this._updateBeforeSortStart, lockAxis: "y", helperClass: "sorting-layers", useDragHandle: true }, layerOrder.map(function (layerIdx, index) { return !layers[layerIdx].config.hidden && /*#__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, { className: "add-layer-button", onClick: this._addEmptyNewLayer, width: "105px" }, /*#__PURE__*/_react["default"].createElement(_icons.Add, { height: "12px" }), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'layerManager.addLayer' })) : null), /*#__PURE__*/_react["default"].createElement(LayerBlendingSelector, { layerBlending: this.props.layerBlending, updateLayerBlending: visStateActions.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, visStateActions: _propTypes["default"].object.isRequired, // functions removeDataset: _propTypes["default"].func.isRequired, showDatasetTable: _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","WrappedSortableContainer","LayerManager","layerClasses","layerClassSelector","map","key","layer","name","icon","layerIcon","requireData","visStateActions","addLayer","oldIndex","newIndex","reorderLayer","layerOrder","setState","index","layers","layerIdx","config","isConfigActive","layerConfigChange","datasets","showAddDataModal","showDatasetTable","removeDataset","uiStateActions","openModal","toggleModal","defaultDataset","layerTypeOptions","layerTypeOptionsSelector","layerActions","layerColorUIChange","layerVisualChannelConfigChange","layerTypeChange","layerVisConfigChange","layerTextLabelChange","removeLayer","duplicateLayer","panelProps","_handleSort","_onSortStart","_updateBeforeSortStart","hidden","state","_addEmptyNewLayer","Component","PropTypes","object","isRequired","string","arrayOf","any","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 {injectIntl} from 'react-intl';\nimport {FormattedMessage} from 'localization';\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 WrappedSortableContainer = 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      visStateActions: PropTypes.object.isRequired,\n      // functions\n      removeDataset: PropTypes.func.isRequired,\n      showDatasetTable: 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          requireData: layer.requireData\n        };\n      })\n    );\n\n    _addEmptyNewLayer = () => {\n      const {visStateActions} = this.props;\n      visStateActions.addLayer();\n    };\n\n    _handleSort = ({oldIndex, newIndex}) => {\n      const {visStateActions} = this.props;\n      visStateActions.reorderLayer(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, visStateActions} = this.props;\n      const layerIdx = layerOrder[index];\n      if (layers[layerIdx].config.isConfigActive) {\n        visStateActions.layerConfigChange(layers[layerIdx], {isConfigActive: false});\n      }\n    };\n\n    render() {\n      const {\n        layers,\n        datasets,\n        intl,\n        layerOrder,\n        showAddDataModal,\n        showDatasetTable,\n        removeDataset,\n        uiStateActions,\n        visStateActions\n      } = this.props;\n      const {toggleModal: openModal} = uiStateActions;\n      const defaultDataset = Object.keys(datasets)[0];\n      const layerTypeOptions = this.layerTypeOptionsSelector(this.props);\n\n      const layerActions = {\n        layerColorUIChange: visStateActions.layerColorUIChange,\n        layerConfigChange: visStateActions.layerConfigChange,\n        layerVisualChannelConfigChange: visStateActions.layerVisualChannelConfigChange,\n        layerTypeChange: visStateActions.layerTypeChange,\n        layerVisConfigChange: visStateActions.layerVisConfigChange,\n        layerTextLabelChange: visStateActions.layerTextLabelChange,\n        removeLayer: visStateActions.removeLayer,\n        duplicateLayer: visStateActions.duplicateLayer\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={showDatasetTable}\n            removeDataset={removeDataset}\n            showDeleteDataset\n          />\n          <AddDataButton onClick={showAddDataModal} isInactive={!defaultDataset} />\n          <SidePanelDivider />\n          <SidePanelSection>\n            <WrappedSortableContainer\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(\n                (layerIdx, index) =>\n                  !layers[layerIdx].config.hidden && (\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              )}\n            </WrappedSortableContainer>\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={visStateActions.updateLayerBlending}\n            intl={intl}\n          />\n        </div>\n      );\n    }\n  }\n  return injectIntl(LayerManager);\n}\n\nexport default LayerManagerFactory;\n"]}