kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
222 lines (190 loc) • 27.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.LayerTitleSectionFactory = LayerTitleSectionFactory;
exports["default"] = exports.LayerLabelEditor = exports.DragHandle = exports.defaultProps = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactSortableHoc = require("react-sortable-hoc");
var _panelHeaderAction = _interopRequireDefault(require("../panel-header-action"));
var _icons = require("../../common/icons");
var _styledComponents2 = require("../../common/styled-components");
var _localization = require("../../../localization");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
var propTypes = {
// required
layerId: _propTypes["default"].string.isRequired,
isVisible: _propTypes["default"].bool.isRequired,
onToggleVisibility: _propTypes["default"].func.isRequired,
onUpdateLayerLabel: _propTypes["default"].func.isRequired,
onToggleEnableConfig: _propTypes["default"].func.isRequired,
onRemoveLayer: _propTypes["default"].func.isRequired,
onDuplicateLayer: _propTypes["default"].func.isRequired,
isConfigActive: _propTypes["default"].bool.isRequired,
// optional
showRemoveLayer: _propTypes["default"].bool,
label: _propTypes["default"].string,
layerType: _propTypes["default"].string,
isDragNDropEnabled: _propTypes["default"].bool,
labelRCGColorValues: _propTypes["default"].arrayOf(_propTypes["default"].number)
};
var defaultProps = {
isDragNDropEnabled: true,
showRemoveLayer: true
};
exports.defaultProps = defaultProps;
var StyledLayerPanelHeader = (0, _styledComponents["default"])(_styledComponents2.StyledPanelHeader)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n height: ", "px;\n .layer__remove-layer {\n opacity: 0;\n }\n :hover {\n cursor: pointer;\n background-color: ", ";\n\n .layer__drag-handle {\n opacity: 1;\n }\n\n .layer__remove-layer {\n opacity: 1;\n }\n }\n"])), function (props) {
return props.theme.layerPanelHeaderHeight;
}, function (props) {
return props.theme.panelBackgroundHover;
});
var HeaderLabelSection = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n"])), function (props) {
return props.theme.textColor;
});
var HeaderActionSection = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n"])));
var StyledDragHandle = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n opacity: 0;\n z-index: 1000;\n\n :hover {\n cursor: move;\n opacity: 1;\n color: ", ";\n }\n"])), function (props) {
return props.theme.textColorHl;
});
var DragHandle = (0, _reactSortableHoc.SortableHandle)(function (_ref) {
var className = _ref.className,
children = _ref.children;
return /*#__PURE__*/_react["default"].createElement(StyledDragHandle, {
className: className
}, children);
});
exports.DragHandle = DragHandle;
var LayerLabelEditor = function LayerLabelEditor(_ref2) {
var layerId = _ref2.layerId,
label = _ref2.label,
onEdit = _ref2.onEdit;
return /*#__PURE__*/_react["default"].createElement(_styledComponents2.InlineInput, {
type: "text",
className: "layer__title__editor",
value: label,
onClick: function onClick(e) {
e.stopPropagation();
},
onChange: onEdit,
id: "".concat(layerId, ":input-layer-label")
});
};
exports.LayerLabelEditor = LayerLabelEditor;
function LayerTitleSectionFactory() {
var StyledLayerTitleSection = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 4px;\n\n .layer__title__type {\n color: ", ";\n font-size: 10px;\n line-height: 12px;\n letter-spacing: 0.37px;\n text-transform: capitalize;\n }\n "])), function (props) {
return props.theme.subtextColor;
});
var LayerTitleSection = function LayerTitleSection(_ref3) {
var layerType = _ref3.layerType,
layerId = _ref3.layerId,
label = _ref3.label,
onUpdateLayerLabel = _ref3.onUpdateLayerLabel;
return /*#__PURE__*/_react["default"].createElement(StyledLayerTitleSection, {
className: "layer__title"
}, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(LayerLabelEditor, {
layerId: layerId,
label: label,
onEdit: onUpdateLayerLabel
}), /*#__PURE__*/_react["default"].createElement("div", {
className: "layer__title__type"
}, layerType && /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "layer.type.".concat(layerType.toLowerCase())
}))));
};
return LayerTitleSection;
}
LayerPanelHeaderFactory.deps = [LayerTitleSectionFactory, _panelHeaderAction["default"]];
var defaultActionIcons = {
remove: _icons.Trash,
visible: _icons.EyeSeen,
hidden: _icons.EyeUnseen,
enableConfig: _icons.ArrowDown,
duplicate: _icons.Copy
};
function LayerPanelHeaderFactory(LayerTitleSection, PanelHeaderAction) {
var LayerPanelHeader = function LayerPanelHeader(_ref4) {
var isConfigActive = _ref4.isConfigActive,
isDragNDropEnabled = _ref4.isDragNDropEnabled,
isVisible = _ref4.isVisible,
label = _ref4.label,
layerId = _ref4.layerId,
layerType = _ref4.layerType,
labelRCGColorValues = _ref4.labelRCGColorValues,
onToggleVisibility = _ref4.onToggleVisibility,
onUpdateLayerLabel = _ref4.onUpdateLayerLabel,
onToggleEnableConfig = _ref4.onToggleEnableConfig,
onDuplicateLayer = _ref4.onDuplicateLayer,
onRemoveLayer = _ref4.onRemoveLayer,
showRemoveLayer = _ref4.showRemoveLayer,
_ref4$actionIcons = _ref4.actionIcons,
actionIcons = _ref4$actionIcons === void 0 ? defaultActionIcons : _ref4$actionIcons;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
isOpen = _useState2[0],
setOpen = _useState2[1];
var toggleLayerConfigurator = function toggleLayerConfigurator(e) {
setOpen(!isOpen);
onToggleEnableConfig(e);
};
return /*#__PURE__*/_react["default"].createElement(StyledLayerPanelHeader, {
className: (0, _classnames["default"])('layer-panel__header', {
'sort--handle': !isConfigActive
}),
active: isConfigActive,
labelRCGColorValues: labelRCGColorValues,
onClick: toggleLayerConfigurator
}, /*#__PURE__*/_react["default"].createElement(HeaderLabelSection, {
className: "layer-panel__header__content"
}, isDragNDropEnabled && /*#__PURE__*/_react["default"].createElement(DragHandle, {
className: "layer__drag-handle"
}, /*#__PURE__*/_react["default"].createElement(_icons.VertDots, {
height: "20px"
})), /*#__PURE__*/_react["default"].createElement(LayerTitleSection, {
layerId: layerId,
label: label,
onUpdateLayerLabel: onUpdateLayerLabel,
layerType: layerType
})), /*#__PURE__*/_react["default"].createElement(HeaderActionSection, {
className: "layer-panel__header__actions"
}, showRemoveLayer ? /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
className: "layer__remove-layer",
id: layerId,
tooltip: 'tooltip.removeLayer',
onClick: onRemoveLayer,
tooltipType: "error",
IconComponent: actionIcons.remove
}) : null, /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
className: "layer__visibility-toggle",
id: layerId,
tooltip: isVisible ? 'tooltip.hideLayer' : 'tooltip.showLayer',
onClick: onToggleVisibility,
IconComponent: isVisible ? actionIcons.visible : actionIcons.hidden
}), /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
className: "layer__duplicate",
id: layerId,
tooltip: 'tooltip.duplicateLayer',
onClick: onDuplicateLayer,
IconComponent: actionIcons.duplicate
}), /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
className: (0, _classnames["default"])('layer__enable-config ', {
'is-open': isOpen
}),
id: layerId,
tooltip: 'tooltip.layerSettings',
onClick: toggleLayerConfigurator,
IconComponent: actionIcons.enableConfig
})));
};
LayerPanelHeader.propTypes = propTypes;
LayerPanelHeader.defaultProps = defaultProps;
return LayerPanelHeader;
}
var _default = LayerPanelHeaderFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-panel-header.js"],"names":["propTypes","layerId","PropTypes","string","isRequired","isVisible","bool","onToggleVisibility","func","onUpdateLayerLabel","onToggleEnableConfig","onRemoveLayer","onDuplicateLayer","isConfigActive","showRemoveLayer","label","layerType","isDragNDropEnabled","labelRCGColorValues","arrayOf","number","defaultProps","StyledLayerPanelHeader","StyledPanelHeader","props","theme","layerPanelHeaderHeight","panelBackgroundHover","HeaderLabelSection","styled","div","textColor","HeaderActionSection","StyledDragHandle","textColorHl","DragHandle","className","children","LayerLabelEditor","onEdit","e","stopPropagation","LayerTitleSectionFactory","StyledLayerTitleSection","subtextColor","LayerTitleSection","toLowerCase","LayerPanelHeaderFactory","deps","PanelHeaderActionFactory","defaultActionIcons","remove","Trash","visible","EyeSeen","hidden","EyeUnseen","enableConfig","ArrowDown","duplicate","Copy","PanelHeaderAction","LayerPanelHeader","actionIcons","isOpen","setOpen","toggleLayerConfigurator"],"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, {useState} from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\nimport {SortableHandle} from 'react-sortable-hoc';\nimport PanelHeaderActionFactory from 'components/side-panel/panel-header-action';\nimport {Copy, ArrowDown, EyeSeen, EyeUnseen, Trash, VertDots} from 'components/common/icons';\n\nimport {InlineInput, StyledPanelHeader} from 'components/common/styled-components';\nimport {FormattedMessage} from 'localization';\n\nconst propTypes = {\n  // required\n  layerId: PropTypes.string.isRequired,\n  isVisible: PropTypes.bool.isRequired,\n  onToggleVisibility: PropTypes.func.isRequired,\n  onUpdateLayerLabel: PropTypes.func.isRequired,\n  onToggleEnableConfig: PropTypes.func.isRequired,\n  onRemoveLayer: PropTypes.func.isRequired,\n  onDuplicateLayer: PropTypes.func.isRequired,\n  isConfigActive: PropTypes.bool.isRequired,\n\n  // optional\n  showRemoveLayer: PropTypes.bool,\n  label: PropTypes.string,\n  layerType: PropTypes.string,\n  isDragNDropEnabled: PropTypes.bool,\n  labelRCGColorValues: PropTypes.arrayOf(PropTypes.number)\n};\n\nexport const defaultProps = {\n  isDragNDropEnabled: true,\n  showRemoveLayer: true\n};\n\nconst StyledLayerPanelHeader = styled(StyledPanelHeader)`\n  height: ${props => props.theme.layerPanelHeaderHeight}px;\n  .layer__remove-layer {\n    opacity: 0;\n  }\n  :hover {\n    cursor: pointer;\n    background-color: ${props => props.theme.panelBackgroundHover};\n\n    .layer__drag-handle {\n      opacity: 1;\n    }\n\n    .layer__remove-layer {\n      opacity: 1;\n    }\n  }\n`;\n\nconst HeaderLabelSection = styled.div`\n  display: flex;\n  color: ${props => props.theme.textColor};\n`;\n\nconst HeaderActionSection = styled.div`\n  display: flex;\n`;\n\nconst StyledDragHandle = styled.div`\n  display: flex;\n  align-items: center;\n  opacity: 0;\n  z-index: 1000;\n\n  :hover {\n    cursor: move;\n    opacity: 1;\n    color: ${props => props.theme.textColorHl};\n  }\n`;\n\nexport const DragHandle = SortableHandle(({className, children}) => (\n  <StyledDragHandle className={className}>{children}</StyledDragHandle>\n));\n\nexport const LayerLabelEditor = ({layerId, label, onEdit}) => (\n  <InlineInput\n    type=\"text\"\n    className=\"layer__title__editor\"\n    value={label}\n    onClick={e => {\n      e.stopPropagation();\n    }}\n    onChange={onEdit}\n    id={`${layerId}:input-layer-label`}\n  />\n);\n\nexport function LayerTitleSectionFactory() {\n  const StyledLayerTitleSection = styled.div`\n    margin-left: 4px;\n\n    .layer__title__type {\n      color: ${props => props.theme.subtextColor};\n      font-size: 10px;\n      line-height: 12px;\n      letter-spacing: 0.37px;\n      text-transform: capitalize;\n    }\n  `;\n  const LayerTitleSection = ({layerType, layerId, label, onUpdateLayerLabel}) => (\n    <StyledLayerTitleSection className=\"layer__title\">\n      <div>\n        <LayerLabelEditor layerId={layerId} label={label} onEdit={onUpdateLayerLabel} />\n        <div className=\"layer__title__type\">\n          {layerType && <FormattedMessage id={`layer.type.${layerType.toLowerCase()}`} />}\n        </div>\n      </div>\n    </StyledLayerTitleSection>\n  );\n  return LayerTitleSection;\n}\n\nLayerPanelHeaderFactory.deps = [LayerTitleSectionFactory, PanelHeaderActionFactory];\nconst defaultActionIcons = {\n  remove: Trash,\n  visible: EyeSeen,\n  hidden: EyeUnseen,\n  enableConfig: ArrowDown,\n  duplicate: Copy\n};\nfunction LayerPanelHeaderFactory(LayerTitleSection, PanelHeaderAction) {\n  const LayerPanelHeader = ({\n    isConfigActive,\n    isDragNDropEnabled,\n    isVisible,\n    label,\n    layerId,\n    layerType,\n    labelRCGColorValues,\n    onToggleVisibility,\n    onUpdateLayerLabel,\n    onToggleEnableConfig,\n    onDuplicateLayer,\n    onRemoveLayer,\n    showRemoveLayer,\n    actionIcons = defaultActionIcons\n  }) => {\n    const [isOpen, setOpen] = useState(false);\n    const toggleLayerConfigurator = e => {\n      setOpen(!isOpen);\n      onToggleEnableConfig(e);\n    };\n    return (\n      <StyledLayerPanelHeader\n        className={classnames('layer-panel__header', {\n          'sort--handle': !isConfigActive\n        })}\n        active={isConfigActive}\n        labelRCGColorValues={labelRCGColorValues}\n        onClick={toggleLayerConfigurator}\n      >\n        <HeaderLabelSection className=\"layer-panel__header__content\">\n          {isDragNDropEnabled && (\n            <DragHandle className=\"layer__drag-handle\">\n              <VertDots height=\"20px\" />\n            </DragHandle>\n          )}\n          <LayerTitleSection\n            layerId={layerId}\n            label={label}\n            onUpdateLayerLabel={onUpdateLayerLabel}\n            layerType={layerType}\n          />\n        </HeaderLabelSection>\n        <HeaderActionSection className=\"layer-panel__header__actions\">\n          {showRemoveLayer ? (\n            <PanelHeaderAction\n              className=\"layer__remove-layer\"\n              id={layerId}\n              tooltip={'tooltip.removeLayer'}\n              onClick={onRemoveLayer}\n              tooltipType=\"error\"\n              IconComponent={actionIcons.remove}\n            />\n          ) : null}\n          <PanelHeaderAction\n            className=\"layer__visibility-toggle\"\n            id={layerId}\n            tooltip={isVisible ? 'tooltip.hideLayer' : 'tooltip.showLayer'}\n            onClick={onToggleVisibility}\n            IconComponent={isVisible ? actionIcons.visible : actionIcons.hidden}\n          />\n          <PanelHeaderAction\n            className=\"layer__duplicate\"\n            id={layerId}\n            tooltip={'tooltip.duplicateLayer'}\n            onClick={onDuplicateLayer}\n            IconComponent={actionIcons.duplicate}\n          />\n          <PanelHeaderAction\n            className={classnames('layer__enable-config ', {\n              'is-open': isOpen\n            })}\n            id={layerId}\n            tooltip={'tooltip.layerSettings'}\n            onClick={toggleLayerConfigurator}\n            IconComponent={actionIcons.enableConfig}\n          />\n        </HeaderActionSection>\n      </StyledLayerPanelHeader>\n    );\n  };\n\n  LayerPanelHeader.propTypes = propTypes;\n  LayerPanelHeader.defaultProps = defaultProps;\n\n  return LayerPanelHeader;\n}\n\nexport default LayerPanelHeaderFactory;\n"]}