UNPKG

kepler.gl.geoiq

Version:

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

176 lines (152 loc) 22.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = 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 _loadingSpinner = _interopRequireDefault(require("../../common/loading-spinner")); var _layer = _interopRequireDefault(require("react-map-gl/dist/es5/components/layer")); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5; var propTypes = { // required id: _propTypes["default"].string.isRequired, isDragNDropEnabled: _propTypes["default"].bool, isVisible: _propTypes["default"].bool.isRequired, label: _propTypes["default"].string.isRequired, onToggleVisibility: _propTypes["default"].func.isRequired, // optional className: _propTypes["default"].string, idx: _propTypes["default"].number, isConfigActive: _propTypes["default"].bool, labelRCGColorValues: _propTypes["default"].arrayOf(_propTypes["default"].number), onUpdateLayerLabel: _propTypes["default"].func, onRemoveLayer: _propTypes["default"].func }; var defaultProps = { isDragNDropEnabled: true, showRemoveLayer: true }; var StyledLayerPanelHeader = (0, _styledComponents["default"])(_styledComponents2.StyledPanelHeader)(_templateObject || (_templateObject = (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 .layer__enable-config {\n color: #494c52;\n }\n }\n"])), function (props) { return props.theme.panelBackgroundHover; }); var HeaderLabelSection = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n width: 100%;\n color: ", ";\n"])), function (props) { return props.theme.textColor; }); var HeaderActionSection = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n"]))); var LayerTitleSection = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 12px;\n width: 100%;\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 StyledDragHandle = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (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) ); }); var LayerPanelHeader = function LayerPanelHeader(_ref2) { var className = _ref2.className, idx = _ref2.idx, isConfigActive = _ref2.isConfigActive, isDragNDropEnabled = _ref2.isDragNDropEnabled, isVisible = _ref2.isVisible, label = _ref2.label, layerId = _ref2.layerId, layerType = _ref2.layerType, labelRCGColorValues = _ref2.labelRCGColorValues, onToggleVisibility = _ref2.onToggleVisibility, onUpdateLayerLabel = _ref2.onUpdateLayerLabel, onToggleEnableConfig = _ref2.onToggleEnableConfig, onRemoveLayer = _ref2.onRemoveLayer, showRemoveLayer = _ref2.showRemoveLayer, apiCallLoader = _ref2.apiCallLoader, showLoader = _ref2.showLoader; return (/*#__PURE__*/_react["default"].createElement(StyledLayerPanelHeader, { className: (0, _classnames["default"])('layer-panel__header', { 'sort--handle': !isConfigActive }), active: isConfigActive, labelRCGColorValues: labelRCGColorValues, onClick: onToggleEnableConfig }, /*#__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(_panelHeaderAction["default"], { className: "layer__visibility-toggle", id: layerId, tooltip: isVisible ? 'hide layer' : 'show layer', onClick: onToggleVisibility, IconComponent: isVisible ? _icons.EyeSeen : _icons.EyeUnseen, active: isVisible, flush: true }), /*#__PURE__*/_react["default"].createElement(LayerTitleSection, { className: "layer__title" }, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(LayerLabelEditor, { label: label, onEdit: onUpdateLayerLabel }), /*#__PURE__*/_react["default"].createElement("div", { className: "layer__title__type" }, layerType)))), layerType === 'boundary' || layerType === 'pincode' ? apiCallLoader && /*#__PURE__*/_react["default"].createElement("div", { style: { padding: '5px' } }, /*#__PURE__*/_react["default"].createElement(_loadingSpinner["default"], { size: 20 })) : null, showLoader && apiCallLoader && /*#__PURE__*/_react["default"].createElement("div", { style: { padding: '5px' } }, /*#__PURE__*/_react["default"].createElement(_loadingSpinner["default"], { size: 20 })), /*#__PURE__*/_react["default"].createElement(HeaderActionSection, { className: "layer-panel__header__actions" }, showRemoveLayer ? /*#__PURE__*/_react["default"].createElement(_panelHeaderAction["default"], { className: "layer__remove-layer", id: layerId, tooltip: 'Remove layer', onClick: onRemoveLayer, tooltipType: "error", IconComponent: _icons.Trash }) : null, /*#__PURE__*/_react["default"].createElement(_panelHeaderAction["default"], { className: "layer__enable-config", id: layerId, tooltip: 'Layer settings', onClick: onToggleEnableConfig, IconComponent: _icons.ArrowDown }))) ); }; var LayerLabelEditor = function LayerLabelEditor(_ref3) { var label = _ref3.label, onEdit = _ref3.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: "input-layer-label" }) ); }; LayerPanelHeader.propTypes = propTypes; LayerPanelHeader.defaultProps = defaultProps; var _default = exports["default"] = LayerPanelHeader; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-panel-header.js"],"names":["propTypes","id","PropTypes","string","isRequired","isDragNDropEnabled","bool","isVisible","label","onToggleVisibility","func","className","idx","number","isConfigActive","labelRCGColorValues","arrayOf","onUpdateLayerLabel","onRemoveLayer","defaultProps","showRemoveLayer","StyledLayerPanelHeader","StyledPanelHeader","props","theme","panelBackgroundHover","HeaderLabelSection","styled","div","textColor","HeaderActionSection","LayerTitleSection","subtextColor","StyledDragHandle","textColorHl","DragHandle","children","LayerPanelHeader","layerId","layerType","onToggleEnableConfig","apiCallLoader","showLoader","EyeSeen","EyeUnseen","padding","Trash","ArrowDown","LayerLabelEditor","onEdit","e","stopPropagation"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 {\n  EyeSeen,\n  EyeUnseen,\n  VertDots,\n  ArrowDown,\n  Trash\n} from 'components/common/icons';\n\nimport {\n  InlineInput,\n  StyledPanelHeader\n} from 'components/common/styled-components';\n\nimport LoadingSpinner from 'components/common/loading-spinner';\nimport layer from 'react-map-gl/dist/es5/components/layer';\n\nconst propTypes = {\n  // required\n  id: PropTypes.string.isRequired,\n  isDragNDropEnabled: PropTypes.bool,\n  isVisible: PropTypes.bool.isRequired,\n  label: PropTypes.string.isRequired,\n  onToggleVisibility: PropTypes.func.isRequired,\n\n  // optional\n  className: PropTypes.string,\n  idx: PropTypes.number,\n  isConfigActive: PropTypes.bool,\n  labelRCGColorValues: PropTypes.arrayOf(PropTypes.number),\n  onUpdateLayerLabel: PropTypes.func,\n  onRemoveLayer: PropTypes.func\n};\n\nconst 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    .layer__enable-config {\n      color: #494c52;\n    }\n  }\n`;\n\nconst HeaderLabelSection = styled.div`\n  display: flex;\n  width: 100%;\n  color: ${props => props.theme.textColor};\n`;\n\nconst HeaderActionSection = styled.div`\n  display: flex;\n`;\n\nconst LayerTitleSection = styled.div`\n  margin-left: 12px;\n  width: 100%;\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\nconst DragHandle = sortableHandle(({className, children}) => (\n  <StyledDragHandle className={className}>{children}</StyledDragHandle>\n));\n\nconst LayerPanelHeader = ({\n  className,\n  idx,\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  apiCallLoader,\n  showLoader\n}) => {\n  return (\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        <PanelHeaderAction\n          className=\"layer__visibility-toggle\"\n          id={layerId}\n          tooltip={isVisible ? 'hide layer' : 'show layer'}\n          onClick={onToggleVisibility}\n          IconComponent={isVisible ? EyeSeen : EyeUnseen}\n          active={isVisible}\n          flush\n        />\n        <LayerTitleSection className=\"layer__title\">\n          <div>\n            <LayerLabelEditor label={label} onEdit={onUpdateLayerLabel} />\n            <div className=\"layer__title__type\">{layerType}</div>\n          </div>\n        </LayerTitleSection>\n      </HeaderLabelSection>\n\n      {layerType === 'boundary' || layerType === 'pincode'\n        ? apiCallLoader && (\n            <div style={{padding: '5px'}}>\n              <LoadingSpinner size={20} />\n            </div>\n          )\n        : null}\n\n      {showLoader && apiCallLoader && (\n        <div style={{padding: '5px'}}>\n          <LoadingSpinner size={20} />\n        </div>\n      )}\n      <HeaderActionSection className=\"layer-panel__header__actions\">\n        {showRemoveLayer ? (\n          <PanelHeaderAction\n            className=\"layer__remove-layer\"\n            id={layerId}\n            tooltip={'Remove layer'}\n            onClick={onRemoveLayer}\n            tooltipType=\"error\"\n            IconComponent={Trash}\n          />\n        ) : null}\n        <PanelHeaderAction\n          className=\"layer__enable-config\"\n          id={layerId}\n          tooltip={'Layer settings'}\n          onClick={onToggleEnableConfig}\n          IconComponent={ArrowDown}\n        />\n      </HeaderActionSection>\n    </StyledLayerPanelHeader>\n  );\n};\n\nconst LayerLabelEditor = ({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=\"input-layer-label\"\n  />\n);\n\nLayerPanelHeader.propTypes = propTypes;\nLayerPanelHeader.defaultProps = defaultProps;\n\nexport default LayerPanelHeader;\n"]}