UNPKG

kepler.gl

Version:

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

212 lines (175 loc) 21.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.DragHandle = exports.defaultProps = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(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 _reactIntl = require("react-intl"); function _templateObject5() { var data = (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"]); _templateObject5 = function _templateObject5() { return data; }; return data; } function _templateObject4() { var data = (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"]); _templateObject4 = function _templateObject4() { return data; }; return data; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\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"]); _templateObject = function _templateObject() { return data; }; return data; } 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, 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(), function (props) { return props.theme.panelBackgroundHover; }); var HeaderLabelSection = _styledComponents["default"].div(_templateObject2(), function (props) { return props.theme.textColor; }); var HeaderActionSection = _styledComponents["default"].div(_templateObject3()); var LayerTitleSection = _styledComponents["default"].div(_templateObject4(), function (props) { return props.theme.subtextColor; }); var StyledDragHandle = _styledComponents["default"].div(_templateObject5(), function (props) { return props.theme.textColorHl; }); var DragHandle = (0, _reactSortableHoc.sortableHandle)(function (_ref) { var className = _ref.className, children = _ref.children; return _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 _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") }); }; function LayerPanelHeaderFactory() { var LayerPanelHeader = function LayerPanelHeader(_ref3) { var isConfigActive = _ref3.isConfigActive, isDragNDropEnabled = _ref3.isDragNDropEnabled, isVisible = _ref3.isVisible, label = _ref3.label, layerId = _ref3.layerId, layerType = _ref3.layerType, labelRCGColorValues = _ref3.labelRCGColorValues, onToggleVisibility = _ref3.onToggleVisibility, onUpdateLayerLabel = _ref3.onUpdateLayerLabel, onToggleEnableConfig = _ref3.onToggleEnableConfig, onRemoveLayer = _ref3.onRemoveLayer, showRemoveLayer = _ref3.showRemoveLayer; return _react["default"].createElement(StyledLayerPanelHeader, { className: (0, _classnames["default"])('layer-panel__header', { 'sort--handle': !isConfigActive }), active: isConfigActive, labelRCGColorValues: labelRCGColorValues, onClick: onToggleEnableConfig }, _react["default"].createElement(HeaderLabelSection, { className: "layer-panel__header__content" }, isDragNDropEnabled && _react["default"].createElement(DragHandle, { className: "layer__drag-handle" }, _react["default"].createElement(_icons.VertDots, { height: "20px" })), _react["default"].createElement(LayerTitleSection, { className: "layer__title" }, _react["default"].createElement("div", null, _react["default"].createElement(LayerLabelEditor, { layerId: layerId, label: label, onEdit: onUpdateLayerLabel }), _react["default"].createElement("div", { className: "layer__title__type" }, layerType && _react["default"].createElement(_reactIntl.FormattedMessage, { id: "layer.type.".concat(layerType.toLowerCase()) }))))), _react["default"].createElement(HeaderActionSection, { className: "layer-panel__header__actions" }, showRemoveLayer ? _react["default"].createElement(_panelHeaderAction["default"], { className: "layer__remove-layer", id: layerId, tooltip: 'tooltip.removeLayer', onClick: onRemoveLayer, tooltipType: "error", IconComponent: _icons.Trash }) : null, _react["default"].createElement(_panelHeaderAction["default"], { className: "layer__visibility-toggle", id: layerId, tooltip: isVisible ? 'tooltip.hideLayer' : 'tooltip.showLayer', onClick: onToggleVisibility, IconComponent: isVisible ? _icons.EyeSeen : _icons.EyeUnseen }), _react["default"].createElement(_panelHeaderAction["default"], { className: "layer__enable-config", id: layerId, tooltip: 'tooltip.layerSettings', onClick: onToggleEnableConfig, IconComponent: _icons.ArrowDown }))); }; 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","isConfigActive","showRemoveLayer","label","layerType","isDragNDropEnabled","labelRCGColorValues","arrayOf","number","defaultProps","StyledLayerPanelHeader","StyledPanelHeader","props","theme","panelBackgroundHover","HeaderLabelSection","styled","div","textColor","HeaderActionSection","LayerTitleSection","subtextColor","StyledDragHandle","textColorHl","DragHandle","className","children","LayerLabelEditor","onEdit","e","stopPropagation","LayerPanelHeaderFactory","LayerPanelHeader","toLowerCase","Trash","EyeSeen","EyeUnseen","ArrowDown"],"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 from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\nimport {sortableHandle} from 'react-sortable-hoc';\nimport PanelHeaderAction from 'components/side-panel/panel-header-action';\nimport {ArrowDown, EyeSeen, EyeUnseen, Trash, VertDots} from 'components/common/icons';\n\nimport {InlineInput, StyledPanelHeader} from 'components/common/styled-components';\nimport {FormattedMessage} from 'react-intl';\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  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  .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 LayerTitleSection = 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\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\nconst 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\nfunction LayerPanelHeaderFactory() {\n  const LayerPanelHeader = ({\n    isConfigActive,\n    isDragNDropEnabled,\n    isVisible,\n    label,\n    layerId,\n    layerType,\n    labelRCGColorValues,\n    onToggleVisibility,\n    onUpdateLayerLabel,\n    onToggleEnableConfig,\n    onRemoveLayer,\n    showRemoveLayer\n  }) => (\n    <StyledLayerPanelHeader\n      className={classnames('layer-panel__header', {\n        'sort--handle': !isConfigActive\n      })}\n      active={isConfigActive}\n      labelRCGColorValues={labelRCGColorValues}\n      onClick={onToggleEnableConfig}\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 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        </LayerTitleSection>\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={Trash}\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 ? EyeSeen : EyeUnseen}\n        />\n        <PanelHeaderAction\n          className=\"layer__enable-config\"\n          id={layerId}\n          tooltip={'tooltip.layerSettings'}\n          onClick={onToggleEnableConfig}\n          IconComponent={ArrowDown}\n        />\n      </HeaderActionSection>\n    </StyledLayerPanelHeader>\n  );\n\n  LayerPanelHeader.propTypes = propTypes;\n  LayerPanelHeader.defaultProps = defaultProps;\n\n  return LayerPanelHeader;\n}\n\nexport default LayerPanelHeaderFactory;\n"]}