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
JavaScript
;
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"]}