UNPKG

kepler.gl

Version:

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

274 lines (273 loc) 48.2 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.LayerLabelEditor = exports.HeaderWarning = exports.DragHandle = void 0; exports.LayerPanelHeaderActionSectionFactory = LayerPanelHeaderActionSectionFactory; exports.LayerTitleSectionFactory = LayerTitleSectionFactory; exports["default"] = void 0; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _styledComponents = _interopRequireWildcard(require("styled-components")); var _panelHeaderAction = _interopRequireDefault(require("../panel-header-action")); var _styledComponents2 = require("../../common/styled-components"); var _icons = require("../../common/icons"); var _localization = require("@kepler.gl/localization"); var _constants = require("@kepler.gl/constants"); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } var getBorderCss = function getBorderCss(status) { return (0, _styledComponents.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n border-top: 2px solid ", ";\n border-bottom: 2px solid ", ";\n border-right: 2px solid ", ";\n "])), function (_ref) { var theme = _ref.theme; return theme.notificationColors[status]; }, function (_ref2) { var theme = _ref2.theme; return theme.notificationColors[status]; }, function (_ref3) { var theme = _ref3.theme; return theme.notificationColors[status]; }); }; var StyledLayerPanelHeader = (0, _styledComponents["default"])(_styledComponents2.StyledPanelHeader)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", "px;\n position: relative;\n align-items: stretch;\n\n .layer__remove-layer {\n opacity: 0;\n }\n\n .layer__drag-handle__placeholder {\n height: 20px;\n padding: 10px;\n }\n\n ", "\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.warning ? getBorderCss('warning') : props.isValid ? '' : getBorderCss('error'); }, function (props) { return props.theme.panelBackgroundHover; }); var HeaderLabelSection = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n flex-grow: 1;\n align-items: stretch;\n // leave space for eye and collapse icon\n padding-right: 50px;\n"])), function (props) { return props.theme.textColor; }); var HeaderActionSection = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: absolute;\n height: 100%;\n align-items: stretch;\n right: 10px;\n pointer-events: ", ";\n &:hover {\n .layer-panel__header__actions__hidden {\n opacity: 1;\n background-color: ", ";\n }\n }\n"])), function (props) { return props.isEditingLabel ? 'none' : 'all'; }, function (props) { return props.theme.panelBackgroundHover; }); // Hiden actions only show up on hover var StyledPanelHeaderHiddenActions = _styledComponents["default"].div.attrs({ className: 'layer-panel__header__actions__hidden' })(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n opacity: 0;\n display: flex;\n align-items: center;\n background-color: ", ";\n transition: opacity 0.4s ease, background-color 0.4s ease;\n\n &:hover {\n opacity: 1;\n }\n"])), function (props) { return props.isConfigActive ? props.theme.panelBackgroundHover : props.theme.panelBackground; }); var StyledDragHandle = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (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 = exports.DragHandle = function DragHandle(_ref4) { var className = _ref4.className, listeners = _ref4.listeners, children = _ref4.children; return /*#__PURE__*/_react["default"].createElement(StyledDragHandle, (0, _extends2["default"])({ className: className }, listeners ? listeners : {}), children); }; var noOp = function noOp(event) { event.stopPropagation(); event.preventDefault(); }; var LayerLabelEditor = exports.LayerLabelEditor = function LayerLabelEditor(_ref5) { var layerId = _ref5.layerId, label = _ref5.label, onEdit = _ref5.onEdit, onFocus = _ref5.onFocus, onBlur = _ref5.onBlur; return /*#__PURE__*/_react["default"].createElement(_styledComponents2.InlineInput, { type: "text", className: "layer__title__editor", "data-testid": _constants.dataTestIds.layerTitleEditor, value: label, onClick: noOp, onChange: onEdit, onFocus: onFocus, onBlur: onBlur, id: "".concat(layerId, ":input-layer-label") }); }; function LayerTitleSectionFactory() { var StyledLayerTitleSection = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 4px;\n flex-grow: 1;\n align-items: center;\n display: flex;\n .layer__title__inner {\n flex-grow: 1;\n }\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(_ref6) { var layerType = _ref6.layerType, layerId = _ref6.layerId, label = _ref6.label, onUpdateLayerLabel = _ref6.onUpdateLayerLabel, onFocus = _ref6.onFocus, onBlur = _ref6.onBlur; 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, onFocus: onFocus, onBlur: onBlur }), /*#__PURE__*/_react["default"].createElement("div", { className: "layer__title__type" }, layerType && /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "layer.type.".concat(layerType.toLowerCase()) })))); }; return LayerTitleSection; } LayerPanelHeaderActionSectionFactory.deps = [_panelHeaderAction["default"]]; function LayerPanelHeaderActionSectionFactory(PanelHeaderAction) { var LayerPanelHeaderActionSection = function LayerPanelHeaderActionSection(props) { var isConfigActive = props.isConfigActive, allowDuplicate = props.allowDuplicate, isVisible = props.isVisible, isValid = props.isValid, layerId = props.layerId, onToggleVisibility = props.onToggleVisibility, onResetIsValid = props.onResetIsValid, onToggleEnableConfig = props.onToggleEnableConfig, onDuplicateLayer = props.onDuplicateLayer, onRemoveLayer = props.onRemoveLayer, onZoomToLayer = props.onZoomToLayer, _props$showRemoveLaye = props.showRemoveLayer, showRemoveLayer = _props$showRemoveLaye === void 0 ? true : _props$showRemoveLaye, isEditingLabel = props.isEditingLabel, _props$actionIcons = props.actionIcons, actionIcons = _props$actionIcons === void 0 ? defaultActionIcons : _props$actionIcons; return /*#__PURE__*/_react["default"].createElement(HeaderActionSection, { className: "layer-panel__header__actions", isEditingLabel: isEditingLabel }, /*#__PURE__*/_react["default"].createElement(StyledPanelHeaderHiddenActions, { isConfigActive: isConfigActive }, showRemoveLayer ? /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { className: "layer__remove-layer", testId: "remove-layer-action", id: layerId, tooltip: 'tooltip.removeLayer', onClick: onRemoveLayer, tooltipType: "error", IconComponent: actionIcons.remove }) : null, /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { className: "layer__duplicate", id: layerId, tooltip: 'tooltip.duplicateLayer', onClick: onDuplicateLayer, IconComponent: actionIcons.duplicate, disabled: !allowDuplicate }), /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { className: "layer__zoom-to-layer", id: layerId, tooltip: 'tooltip.zoomToLayer', onClick: onZoomToLayer, IconComponent: actionIcons.crosshairs })), isValid ? /*#__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__is-valid-refresh", id: layerId, tooltip: 'tooltip.resetAfterError', onClick: onResetIsValid, IconComponent: actionIcons.resetIsValid }), /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { className: (0, _classnames["default"])('layer__enable-config ', { 'is-open': isConfigActive }), id: layerId, tooltip: 'tooltip.layerSettings', onClick: onToggleEnableConfig, IconComponent: actionIcons.enableConfig })); }; return LayerPanelHeaderActionSection; } var StyledHeaderWaring = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n right: -9px;\n top: calc(50% - 9px);\n color: ", ";\n"])), function (_ref7) { var theme = _ref7.theme; return theme.notificationColors.warning; }); var HeaderWarning = exports.HeaderWarning = function HeaderWarning(_ref8) { var warning = _ref8.warning, id = _ref8.id; return /*#__PURE__*/_react["default"].createElement(StyledHeaderWaring, null, /*#__PURE__*/_react["default"].createElement(_icons.WarningSign, { "data-tip": true, "data-for": "layer-".concat(id, "-warning"), height: "16px" }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, { id: "layer-".concat(id, "-warning"), type: "warning", effect: "solid", textColor: "black" }, warning)); }; var defaultActionIcons = { remove: _icons.Trash, visible: _icons.EyeSeen, hidden: _icons.EyeUnseen, enableConfig: _icons.ArrowDown, duplicate: _icons.Copy, resetIsValid: _icons.Reset, crosshairs: _icons.Crosshairs }; LayerPanelHeaderFactory.deps = [LayerTitleSectionFactory, LayerPanelHeaderActionSectionFactory]; function LayerPanelHeaderFactory(LayerTitleSection, LayerPanelHeaderActionSection) { var LayerPanelHeader = function LayerPanelHeader(props) { var isConfigActive = props.isConfigActive, _props$isDragNDropEna = props.isDragNDropEnabled, isDragNDropEnabled = _props$isDragNDropEna === void 0 ? true : _props$isDragNDropEna, isValid = props.isValid, warning = props.warning, label = props.label, layerId = props.layerId, layerType = props.layerType, labelRCGColorValues = props.labelRCGColorValues, onUpdateLayerLabel = props.onUpdateLayerLabel, onToggleEnableConfig = props.onToggleEnableConfig, listeners = props.listeners; var _useState = (0, _react.useState)(false), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), isEditingLabel = _useState2[0], setIsEditingLabel = _useState2[1]; return /*#__PURE__*/_react["default"].createElement(StyledLayerPanelHeader, { className: (0, _classnames["default"])('layer-panel__header', { 'sort--handle': !isConfigActive }), isValid: isValid, warning: warning, active: isConfigActive, labelRCGColorValues: labelRCGColorValues, onClick: onToggleEnableConfig }, warning ? /*#__PURE__*/_react["default"].createElement(HeaderWarning, { warning: warning, id: layerId }) : null, /*#__PURE__*/_react["default"].createElement(HeaderLabelSection, { className: "layer-panel__header__content" }, isDragNDropEnabled ? /*#__PURE__*/_react["default"].createElement(DragHandle, { className: "layer__drag-handle", listeners: listeners }, /*#__PURE__*/_react["default"].createElement(_icons.VertDots, { height: "20px" })) : /*#__PURE__*/_react["default"].createElement("div", { className: "layer__drag-handle__placeholder" }), /*#__PURE__*/_react["default"].createElement(LayerTitleSection, { layerId: layerId, label: label, onUpdateLayerLabel: onUpdateLayerLabel, layerType: layerType, onFocus: function onFocus() { setIsEditingLabel(true); }, onBlur: function onBlur() { setIsEditingLabel(false); } })), /*#__PURE__*/_react["default"].createElement(LayerPanelHeaderActionSection, (0, _extends2["default"])({}, props, { isEditingLabel: isEditingLabel }))); }; return LayerPanelHeader; } var _default = exports["default"] = LayerPanelHeaderFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_styledComponents","_panelHeaderAction","_styledComponents2","_icons","_localization","_constants","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","getBorderCss","status","css","_taggedTemplateLiteral2","_ref","theme","notificationColors","_ref2","_ref3","StyledLayerPanelHeader","styled","StyledPanelHeader","props","layerPanelHeaderHeight","warning","isValid","panelBackgroundHover","HeaderLabelSection","div","textColor","HeaderActionSection","isEditingLabel","StyledPanelHeaderHiddenActions","attrs","className","isConfigActive","panelBackground","StyledDragHandle","textColorHl","DragHandle","exports","_ref4","listeners","children","createElement","_extends2","noOp","event","stopPropagation","preventDefault","LayerLabelEditor","_ref5","layerId","label","onEdit","onFocus","onBlur","InlineInput","type","dataTestIds","layerTitleEditor","value","onClick","onChange","id","concat","LayerTitleSectionFactory","StyledLayerTitleSection","subtextColor","LayerTitleSection","_ref6","layerType","onUpdateLayerLabel","FormattedMessage","toLowerCase","LayerPanelHeaderActionSectionFactory","deps","PanelHeaderActionFactory","PanelHeaderAction","LayerPanelHeaderActionSection","allowDuplicate","isVisible","onToggleVisibility","onResetIsValid","onToggleEnableConfig","onDuplicateLayer","onRemoveLayer","onZoomToLayer","_props$showRemoveLaye","showRemoveLayer","_props$actionIcons","actionIcons","defaultActionIcons","testId","tooltip","tooltipType","IconComponent","remove","duplicate","disabled","crosshairs","visible","hidden","resetIsValid","classnames","enableConfig","StyledHeaderWaring","_ref7","HeaderWarning","_ref8","WarningSign","height","Tooltip","effect","Trash","EyeSeen","EyeUnseen","ArrowDown","Copy","Reset","Crosshairs","LayerPanelHeaderFactory","LayerPanelHeader","_props$isDragNDropEna","isDragNDropEnabled","labelRCGColorValues","_useState","useState","_useState2","_slicedToArray2","setIsEditingLabel","active","VertDots","_default"],"sources":["../../../src/side-panel/layer-panel/layer-panel-header.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {\n  useState,\n  ComponentType,\n  MouseEventHandler,\n  MouseEvent,\n  ChangeEventHandler\n} from 'react';\nimport classnames from 'classnames';\nimport styled, {css} from 'styled-components';\nimport PanelHeaderActionFactory from '../panel-header-action';\nimport {Tooltip} from '../../common/styled-components';\nimport {\n  Copy,\n  ArrowDown,\n  EyeSeen,\n  EyeUnseen,\n  Trash,\n  VertDots,\n  WarningSign,\n  Reset,\n  Crosshairs\n} from '../../common/icons';\n\nimport {InlineInput, StyledPanelHeader} from '../../common/styled-components';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {dataTestIds} from '@kepler.gl/constants';\nimport {RGBColor} from '@kepler.gl/types';\nimport {BaseProps} from '../../common/icons';\n\nexport type LayerLabelEditorProps = {\n  layerId: string;\n  label?: string;\n  onEdit: ChangeEventHandler;\n  onFocus: ChangeEventHandler;\n  onBlur: ChangeEventHandler;\n};\n\nexport type LayerTitleSectionProps = {\n  layerType?: string | null;\n  layerId: string;\n  label?: string;\n  onUpdateLayerLabel: ChangeEventHandler;\n  onFocus: ChangeEventHandler;\n  onBlur: ChangeEventHandler;\n};\n\nexport type LayerPanelHeaderProps = {\n  layerId: string;\n  isVisible: boolean;\n  isValid: boolean;\n  onToggleVisibility: MouseEventHandler;\n  onUpdateLayerLabel: ChangeEventHandler;\n  onToggleEnableConfig: MouseEventHandler;\n  onRemoveLayer: MouseEventHandler;\n  onZoomToLayer: MouseEventHandler;\n  onDuplicateLayer: MouseEventHandler;\n  onResetIsValid: MouseEventHandler;\n  isConfigActive: boolean;\n  showRemoveLayer?: boolean;\n  label?: string;\n  layerType?: string | null;\n  allowDuplicate?: boolean;\n  isDragNDropEnabled?: boolean;\n  warning?: boolean;\n  labelRCGColorValues?: RGBColor | null;\n  actionIcons?: {\n    remove: ComponentType<Partial<BaseProps>>;\n    visible: ComponentType<Partial<BaseProps>>;\n    hidden: ComponentType<Partial<BaseProps>>;\n    enableConfig: ComponentType<Partial<BaseProps>>;\n    resetIsValid: ComponentType<Partial<BaseProps>>;\n    duplicate: ComponentType<Partial<BaseProps>>;\n    crosshairs: ComponentType<Partial<BaseProps>>;\n  };\n  listeners?: React.ElementType;\n};\n\ntype HeaderActionSectionProps = {\n  isEditingLabel: boolean;\n};\n\nexport type LayerPanelHeaderActionSectionProps = LayerPanelHeaderProps & HeaderActionSectionProps;\n\nconst getBorderCss = status =>\n  css`\n    border-top: 2px solid ${({theme}) => theme.notificationColors[status]};\n    border-bottom: 2px solid ${({theme}) => theme.notificationColors[status]};\n    border-right: 2px solid ${({theme}) => theme.notificationColors[status]};\n  `;\n\nconst StyledLayerPanelHeader = styled(StyledPanelHeader)`\n  height: ${props => props.theme.layerPanelHeaderHeight}px;\n  position: relative;\n  align-items: stretch;\n\n  .layer__remove-layer {\n    opacity: 0;\n  }\n\n  .layer__drag-handle__placeholder {\n    height: 20px;\n    padding: 10px;\n  }\n\n  ${props => (props.warning ? getBorderCss('warning') : props.isValid ? '' : getBorderCss('error'))}\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  flex-grow: 1;\n  align-items: stretch;\n  // leave space for eye and collapse icon\n  padding-right: 50px;\n`;\n\nconst HeaderActionSection = styled.div<HeaderActionSectionProps>`\n  display: flex;\n  position: absolute;\n  height: 100%;\n  align-items: stretch;\n  right: 10px;\n  pointer-events: ${props => (props.isEditingLabel ? 'none' : 'all')};\n  &:hover {\n    .layer-panel__header__actions__hidden {\n      opacity: 1;\n      background-color: ${props => props.theme.panelBackgroundHover};\n    }\n  }\n`;\n\ntype StyledPanelHeaderHiddenActionsProps = {\n  isConfigActive: LayerPanelHeaderProps['isConfigActive'];\n};\n\n// Hiden actions only show up on hover\nconst StyledPanelHeaderHiddenActions = styled.div.attrs({\n  className: 'layer-panel__header__actions__hidden'\n})<StyledPanelHeaderHiddenActionsProps>`\n  opacity: 0;\n  display: flex;\n  align-items: center;\n  background-color: ${props =>\n    props.isConfigActive ? props.theme.panelBackgroundHover : props.theme.panelBackground};\n  transition: opacity 0.4s ease, background-color 0.4s ease;\n\n  &:hover {\n    opacity: 1;\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: React.FC<{\n  className?: string;\n  listeners?: any;\n  children?: React.ReactNode;\n}> = ({className, listeners, children}) => (\n  <StyledDragHandle className={className} {...(listeners ? listeners : {})}>\n    {children}\n  </StyledDragHandle>\n);\n\nconst noOp = (event: MouseEvent) => {\n  event.stopPropagation();\n  event.preventDefault();\n};\n\nexport const LayerLabelEditor: React.FC<LayerLabelEditorProps> = ({\n  layerId,\n  label,\n  onEdit,\n  onFocus,\n  onBlur\n}) => (\n  <InlineInput\n    type=\"text\"\n    className=\"layer__title__editor\"\n    data-testid={dataTestIds.layerTitleEditor}\n    value={label}\n    onClick={noOp}\n    onChange={onEdit}\n    onFocus={onFocus}\n    onBlur={onBlur}\n    id={`${layerId}:input-layer-label`}\n  />\n);\n\nexport function LayerTitleSectionFactory() {\n  const StyledLayerTitleSection = styled.div`\n    margin-left: 4px;\n    flex-grow: 1;\n    align-items: center;\n    display: flex;\n    .layer__title__inner {\n      flex-grow: 1;\n    }\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: React.FC<LayerTitleSectionProps> = ({\n    layerType,\n    layerId,\n    label,\n    onUpdateLayerLabel,\n    onFocus,\n    onBlur\n  }) => (\n    <StyledLayerTitleSection className=\"layer__title\">\n      <div>\n        <LayerLabelEditor\n          layerId={layerId}\n          label={label}\n          onEdit={onUpdateLayerLabel}\n          onFocus={onFocus}\n          onBlur={onBlur}\n        />\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\nLayerPanelHeaderActionSectionFactory.deps = [PanelHeaderActionFactory];\n\nexport function LayerPanelHeaderActionSectionFactory(\n  PanelHeaderAction: ReturnType<typeof PanelHeaderActionFactory>\n) {\n  const LayerPanelHeaderActionSection: React.FC<LayerPanelHeaderActionSectionProps> = (\n    props: LayerPanelHeaderActionSectionProps\n  ) => {\n    const {\n      isConfigActive,\n      allowDuplicate,\n      isVisible,\n      isValid,\n      layerId,\n      onToggleVisibility,\n      onResetIsValid,\n      onToggleEnableConfig,\n      onDuplicateLayer,\n      onRemoveLayer,\n      onZoomToLayer,\n      showRemoveLayer = true,\n      isEditingLabel,\n      // TODO: may not contain all necessary icons for all actions, e.g. actionIcons.duplicate. Need to to merge rather than replace\n      actionIcons = defaultActionIcons\n    } = props;\n    return (\n      <HeaderActionSection className=\"layer-panel__header__actions\" isEditingLabel={isEditingLabel}>\n        <StyledPanelHeaderHiddenActions isConfigActive={isConfigActive}>\n          {showRemoveLayer ? (\n            <PanelHeaderAction\n              className=\"layer__remove-layer\"\n              testId=\"remove-layer-action\"\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__duplicate\"\n            id={layerId}\n            tooltip={'tooltip.duplicateLayer'}\n            onClick={onDuplicateLayer}\n            IconComponent={actionIcons.duplicate}\n            disabled={!allowDuplicate}\n          />\n          <PanelHeaderAction\n            className=\"layer__zoom-to-layer\"\n            id={layerId}\n            tooltip={'tooltip.zoomToLayer'}\n            onClick={onZoomToLayer}\n            IconComponent={actionIcons.crosshairs}\n          />\n        </StyledPanelHeaderHiddenActions>\n        {isValid ? (\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        ) : (\n          <PanelHeaderAction\n            className=\"layer__is-valid-refresh\"\n            id={layerId}\n            tooltip={'tooltip.resetAfterError'}\n            onClick={onResetIsValid}\n            IconComponent={actionIcons.resetIsValid}\n          />\n        )}\n\n        <PanelHeaderAction\n          className={classnames('layer__enable-config ', {\n            'is-open': isConfigActive\n          })}\n          id={layerId}\n          tooltip={'tooltip.layerSettings'}\n          onClick={onToggleEnableConfig}\n          IconComponent={actionIcons.enableConfig}\n        />\n      </HeaderActionSection>\n    );\n  };\n\n  return LayerPanelHeaderActionSection;\n}\n\nconst StyledHeaderWaring = styled.div`\n  position: absolute;\n  right: -9px;\n  top: calc(50% - 9px);\n  color: ${({theme}) => theme.notificationColors.warning};\n`;\n\nexport const HeaderWarning = ({warning, id}) => (\n  <StyledHeaderWaring>\n    <WarningSign data-tip data-for={`layer-${id}-warning`} height=\"16px\" />\n    <Tooltip id={`layer-${id}-warning`} type=\"warning\" effect=\"solid\" textColor=\"black\">\n      {warning}\n    </Tooltip>\n  </StyledHeaderWaring>\n);\n\nconst defaultActionIcons = {\n  remove: Trash,\n  visible: EyeSeen,\n  hidden: EyeUnseen,\n  enableConfig: ArrowDown,\n  duplicate: Copy,\n  resetIsValid: Reset,\n  crosshairs: Crosshairs\n};\n\nLayerPanelHeaderFactory.deps = [LayerTitleSectionFactory, LayerPanelHeaderActionSectionFactory];\n\nfunction LayerPanelHeaderFactory(\n  LayerTitleSection: ReturnType<typeof LayerTitleSectionFactory>,\n  LayerPanelHeaderActionSection: ReturnType<typeof LayerPanelHeaderActionSectionFactory>\n) {\n  const LayerPanelHeader: React.FC<LayerPanelHeaderProps> = props => {\n    const {\n      isConfigActive,\n      isDragNDropEnabled = true,\n      isValid,\n      warning,\n      label,\n      layerId,\n      layerType,\n      labelRCGColorValues,\n      onUpdateLayerLabel,\n      onToggleEnableConfig,\n      listeners\n    } = props;\n    const [isEditingLabel, setIsEditingLabel] = useState(false);\n    return (\n      <StyledLayerPanelHeader\n        className={classnames('layer-panel__header', {\n          'sort--handle': !isConfigActive\n        })}\n        isValid={isValid}\n        warning={warning}\n        active={isConfigActive}\n        labelRCGColorValues={labelRCGColorValues}\n        onClick={onToggleEnableConfig}\n      >\n        {warning ? <HeaderWarning warning={warning} id={layerId} /> : null}\n        <HeaderLabelSection className=\"layer-panel__header__content\">\n          {isDragNDropEnabled ? (\n            <DragHandle className=\"layer__drag-handle\" listeners={listeners}>\n              <VertDots height=\"20px\" />\n            </DragHandle>\n          ) : (\n            <div className=\"layer__drag-handle__placeholder\" />\n          )}\n          <LayerTitleSection\n            layerId={layerId}\n            label={label}\n            onUpdateLayerLabel={onUpdateLayerLabel}\n            layerType={layerType}\n            onFocus={() => {\n              setIsEditingLabel(true);\n            }}\n            onBlur={() => {\n              setIsEditingLabel(false);\n            }}\n          />\n        </HeaderLabelSection>\n        <LayerPanelHeaderActionSection {...props} isEditingLabel={isEditingLabel} />\n      </StyledLayerPanelHeader>\n    );\n  };\n\n  return LayerPanelHeader;\n}\n\nexport default LayerPanelHeaderFactory;\n"],"mappings":"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","ignoreList":[]}