UNPKG

kepler.gl

Version:

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

180 lines (177 loc) 41 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.EffectPanelHeaderActionSectionFactory = EffectPanelHeaderActionSectionFactory; exports.defaultProps = exports["default"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); 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 _styledComponents = _interopRequireDefault(require("styled-components")); var _constants = require("@kepler.gl/constants"); var _panelHeaderAction = _interopRequireDefault(require("../side-panel/panel-header-action")); var _icons = require("../common/icons"); var _styledComponents2 = require("../common/styled-components"); var _defaultEffectIcons, _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7; // 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 defaultProps = exports.defaultProps = { isDragNDropEnabled: true }; var defaultActionIcons = { remove: _icons.Trash, visible: _icons.EyeSeen, hidden: _icons.EyeUnseen, enableConfig: _icons.ArrowDown, disableConfig: _icons.ArrowUp }; var defaultEffectIcons = (_defaultEffectIcons = {}, (0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])(_defaultEffectIcons, _constants.LIGHT_AND_SHADOW_EFFECT.type, _icons.LightAndShadowEffectIcon), _constants.POSTPROCESSING_EFFECTS.ink.type, _icons.InkEffectIcon), _constants.POSTPROCESSING_EFFECTS.brightnessContrast.type, _icons.BrightnessContrastEffectIcon), _constants.POSTPROCESSING_EFFECTS.hueSaturation.type, _icons.HueSaturationEffectIcon), _constants.POSTPROCESSING_EFFECTS.vibrance.type, _icons.VibranceEffectIcon), _constants.POSTPROCESSING_EFFECTS.sepia.type, _icons.SepiaEffectIcon), _constants.POSTPROCESSING_EFFECTS.dotScreen.type, _icons.DotScreenEffectIcon), _constants.POSTPROCESSING_EFFECTS.colorHalftone.type, _icons.ColorHalftoneEffectIcon), _constants.POSTPROCESSING_EFFECTS.noise.type, _icons.NoiseEffectIcon), _constants.POSTPROCESSING_EFFECTS.triangleBlur.type, _icons.TriangleBlurEffectIcon), (0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])((0, _defineProperty2["default"])(_defaultEffectIcons, _constants.POSTPROCESSING_EFFECTS.zoomBlur.type, _icons.ZoomBlurEffectIcon), _constants.POSTPROCESSING_EFFECTS.tiltShift.type, _icons.TiltShiftEffectIcon), _constants.POSTPROCESSING_EFFECTS.edgeWork.type, _icons.EdgeWorkEffectIcon), _constants.POSTPROCESSING_EFFECTS.vignette.type, _icons.VignetteEffectIcon), _constants.POSTPROCESSING_EFFECTS.magnify.type, _icons.MagnifyEffectIcon), _constants.POSTPROCESSING_EFFECTS.hexagonalPixelate.type, _icons.HexagonalPixelateEffectIcon), _constants.DISTANCE_FOG_TYPE, _icons.DistanceFogEffectIcon), _constants.SURFACE_FOG_TYPE, _icons.SurfaceFogEffectIcon)); var StyledEffectPanelHeader = (0, _styledComponents["default"])(_styledComponents2.StyledPanelHeader)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n height: ", "px;\n position: relative;\n align-items: stretch;\n\n .effect__drag-handle {\n margin-left: -5px;\n color: ", ";\n }\n\n .effect__drag-handle__placeholder {\n height: 20px;\n padding: 0px;\n margin: 10px 10px 10px 5px;\n }\n\n &:hover {\n cursor: pointer;\n background-color: ", ";\n .effect__drag-handle {\n opacity: 1;\n }\n }\n\n border-left: 3px solid ", ";\n"])), function (props) { return props.theme.effectPanelHeaderHeight; }, function (props) { return props.theme.textColor; }, function (props) { return props.theme.panelBackgroundHover; }, function (props) { return props.theme.panelBackgroundHover; }); var HeaderActionSection = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: absolute;\n height: 100%;\n align-items: stretch;\n right: 10px;\n &:hover {\n .effect-panel__header__actions__hidden {\n opacity: 1;\n background-color: ", ";\n }\n }\n"])), function (props) { return props.theme.panelBackgroundHover; }); // Hiden actions only show up on hover var StyledPanelHeaderHiddenActions = _styledComponents["default"].div.attrs({ className: 'effect-panel__header__actions__hidden' })(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n opacity: 0;\n display: flex;\n align-items: center;\n transition: opacity 0.4s ease, background-color 0.4s ease;\n background-color: ", ";\n\n &:hover {\n opacity: 1;\n }\n"])), function (props) { return props.isConfigActive ? props.theme.panelBackgroundHover : props.theme.panelBackground; }); 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 &:hover {\n cursor: move;\n opacity: 1;\n color: ", ";\n }\n"])), function (props) { return props.theme.textColorHl; }); var DragHandle = function DragHandle(_ref) { var className = _ref.className, listeners = _ref.listeners, children = _ref.children; return /*#__PURE__*/_react["default"].createElement(StyledDragHandle, (0, _extends2["default"])({ className: className }, listeners), children); }; EffectPanelHeaderActionSectionFactory.deps = [_panelHeaderAction["default"]]; function EffectPanelHeaderActionSectionFactory(PanelHeaderAction) { var EffectPanelHeaderActionSection = function EffectPanelHeaderActionSection(props) { var effectId = props.effectId, isEnabled = props.isEnabled, isConfigActive = props.isConfigActive, onToggleEnabled = props.onToggleEnabled, onRemoveEffect = props.onRemoveEffect, onToggleEnableConfig = props.onToggleEnableConfig, actionItems = props.actionItems, _props$actionIcons = props.actionIcons, actionIcons = _props$actionIcons === void 0 ? defaultActionIcons : _props$actionIcons; var effectActionItems = (0, _react.useMemo)(function () { return actionItems !== null && actionItems !== void 0 ? actionItems : [{ key: 'remove-effect', isHidden: true, tooltip: 'tooltip.removeEffect', tooltipType: 'error', onClick: onRemoveEffect, icon: actionIcons.remove }, { key: 'visibility-toggle', tooltip: isEnabled ? 'tooltip.disableEffect' : 'tooltip.enabledEffect', onClick: onToggleEnabled, icon: isEnabled ? actionIcons.visible : actionIcons.hidden }, { key: 'enable-config', classNames: { 'is-open': isConfigActive }, tooltip: 'tooltip.effectSettings', onClick: onToggleEnableConfig, icon: actionIcons.enableConfig }]; }, [actionItems, actionIcons, isEnabled, isConfigActive, onRemoveEffect, onToggleEnabled, onToggleEnableConfig]); return /*#__PURE__*/_react["default"].createElement(HeaderActionSection, { className: "effect-panel__header__actions" }, /*#__PURE__*/_react["default"].createElement(StyledPanelHeaderHiddenActions, { isConfigActive: isConfigActive }, effectActionItems.filter(function (item) { return Boolean(item.isHidden); }).map(function (item) { return /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { key: item.key, className: "effect__".concat(item.key), testId: "".concat(item.key, "-action"), id: effectId, tooltip: item.tooltip, onClick: item.onClick, tooltipType: item.tooltipType, IconComponent: item.icon }); })), effectActionItems.filter(function (item) { return !item.isHidden; }).map(function (item) { return /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { key: item.key, className: (0, _classnames["default"])("effect__".concat(item.key), item.classNames), testId: "".concat(item.key, "-action"), id: effectId, tooltip: item.tooltip, onClick: item.onClick, tooltipType: item.tooltipType, IconComponent: item.icon }); })); }; return EffectPanelHeaderActionSection; } var StyledEffectTitleSection = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 8px;\n flex-grow: 1;\n align-items: center;\n display: flex;\n color: ", ";\n"])), function (props) { return props.theme.textColor; }); var IconPlaceholder = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n width: 20px;\n height: 20px;\n"]))); var EffectIconWrapper = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: 18px;\n margin: auto;\n color: ", ";\n"])), function (props) { return props.theme.textColor; }); EffectPanelHeaderFactory.deps = [EffectPanelHeaderActionSectionFactory]; function EffectPanelHeaderFactory(EffectPanelHeaderActionSection) { var EffectPanelHeader = function EffectPanelHeader(props) { var isConfigActive = props.isConfigActive, _props$isDragNDropEna = props.isDragNDropEnabled, isDragNDropEnabled = _props$isDragNDropEna === void 0 ? true : _props$isDragNDropEna, type = props.type, onToggleEnableConfig = props.onToggleEnableConfig, listeners = props.listeners, _props$showSortHandle = props.showSortHandle, showSortHandle = _props$showSortHandle === void 0 ? true : _props$showSortHandle; var label = (0, _react.useMemo)(function () { var description = _constants.EFFECT_DESCRIPTIONS.find(function (_description) { return _description.type === type; }); return (description === null || description === void 0 ? void 0 : description.name) || 'Effect'; }, [type]); var EffectIcon = defaultEffectIcons[type]; return /*#__PURE__*/_react["default"].createElement(StyledEffectPanelHeader, { className: (0, _classnames["default"])('effect-panel__header', { 'sort--handle': !isConfigActive }), active: isConfigActive, onClick: onToggleEnableConfig }, isDragNDropEnabled ? /*#__PURE__*/_react["default"].createElement(DragHandle, { className: "effect__drag-handle", listeners: listeners }, showSortHandle ? /*#__PURE__*/_react["default"].createElement(_icons.VertDots, { height: "20px" }) : /*#__PURE__*/_react["default"].createElement(IconPlaceholder, null)) : /*#__PURE__*/_react["default"].createElement("div", { className: "effect__drag-handle__placeholder" }), /*#__PURE__*/_react["default"].createElement(EffectIconWrapper, null, EffectIcon ? /*#__PURE__*/_react["default"].createElement(EffectIcon, { height: "18px" }) : null), /*#__PURE__*/_react["default"].createElement(StyledEffectTitleSection, null, label), /*#__PURE__*/_react["default"].createElement(EffectPanelHeaderActionSection, props)); }; return EffectPanelHeader; } var _default = exports["default"] = EffectPanelHeaderFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_styledComponents","_constants","_panelHeaderAction","_icons","_styledComponents2","_defaultEffectIcons","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","defaultProps","exports","isDragNDropEnabled","defaultActionIcons","remove","Trash","visible","EyeSeen","hidden","EyeUnseen","enableConfig","ArrowDown","disableConfig","ArrowUp","defaultEffectIcons","_defineProperty2","LIGHT_AND_SHADOW_EFFECT","type","LightAndShadowEffectIcon","POSTPROCESSING_EFFECTS","ink","InkEffectIcon","brightnessContrast","BrightnessContrastEffectIcon","hueSaturation","HueSaturationEffectIcon","vibrance","VibranceEffectIcon","sepia","SepiaEffectIcon","dotScreen","DotScreenEffectIcon","colorHalftone","ColorHalftoneEffectIcon","noise","NoiseEffectIcon","triangleBlur","TriangleBlurEffectIcon","zoomBlur","ZoomBlurEffectIcon","tiltShift","TiltShiftEffectIcon","edgeWork","EdgeWorkEffectIcon","vignette","VignetteEffectIcon","magnify","MagnifyEffectIcon","hexagonalPixelate","HexagonalPixelateEffectIcon","DISTANCE_FOG_TYPE","DistanceFogEffectIcon","SURFACE_FOG_TYPE","SurfaceFogEffectIcon","StyledEffectPanelHeader","styled","StyledPanelHeader","_taggedTemplateLiteral2","props","theme","effectPanelHeaderHeight","textColor","panelBackgroundHover","HeaderActionSection","div","StyledPanelHeaderHiddenActions","attrs","className","isConfigActive","panelBackground","StyledDragHandle","textColorHl","DragHandle","_ref","listeners","children","createElement","_extends2","EffectPanelHeaderActionSectionFactory","deps","PanelHeaderActionFactory","PanelHeaderAction","EffectPanelHeaderActionSection","effectId","isEnabled","onToggleEnabled","onRemoveEffect","onToggleEnableConfig","actionItems","_props$actionIcons","actionIcons","effectActionItems","useMemo","key","isHidden","tooltip","tooltipType","onClick","icon","classNames","filter","item","Boolean","map","concat","testId","id","IconComponent","classnames","StyledEffectTitleSection","IconPlaceholder","EffectIconWrapper","EffectPanelHeaderFactory","EffectPanelHeader","_props$isDragNDropEna","_props$showSortHandle","showSortHandle","label","description","EFFECT_DESCRIPTIONS","find","_description","name","EffectIcon","active","VertDots","height","_default"],"sources":["../../src/effects/effect-panel-header.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo} from 'react';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\n\nimport {\n  EFFECT_DESCRIPTIONS,\n  LIGHT_AND_SHADOW_EFFECT,\n  POSTPROCESSING_EFFECTS,\n  DISTANCE_FOG_TYPE,\n  SURFACE_FOG_TYPE\n} from '@kepler.gl/constants';\n\nimport PanelHeaderActionFactory, {PanelHeaderActionIcon} from '../side-panel/panel-header-action';\nimport {\n  ArrowDown,\n  ArrowUp,\n  EyeSeen,\n  EyeUnseen,\n  Trash,\n  VertDots,\n  LightAndShadowEffectIcon,\n  InkEffectIcon,\n  BrightnessContrastEffectIcon,\n  HueSaturationEffectIcon,\n  VibranceEffectIcon,\n  SepiaEffectIcon,\n  DotScreenEffectIcon,\n  ColorHalftoneEffectIcon,\n  NoiseEffectIcon,\n  TriangleBlurEffectIcon,\n  ZoomBlurEffectIcon,\n  TiltShiftEffectIcon,\n  EdgeWorkEffectIcon,\n  VignetteEffectIcon,\n  MagnifyEffectIcon,\n  HexagonalPixelateEffectIcon,\n  DistanceFogEffectIcon,\n  SurfaceFogEffectIcon,\n  BaseProps\n} from '../common/icons';\nimport {StyledPanelHeader} from '../common/styled-components';\n\nexport type ActionItem = {\n  key: string;\n  isHidden?: boolean;\n  tooltip: string;\n  classNames?: Record<string, boolean>;\n  icon: PanelHeaderActionIcon;\n  tooltipType?: 'error';\n  onClick: () => void;\n};\n\nexport type EffectPanelHeaderProps = {\n  type: string;\n  listeners: any;\n  effectId: string;\n  isEnabled: boolean;\n  isConfigActive: boolean;\n  isJsonEditorActive: boolean;\n  showSortHandle?: boolean;\n  isDragNDropEnabled: boolean;\n  onToggleEnabled: () => void;\n  onRemoveEffect: () => void;\n  onToggleEnableConfig: () => void;\n  actionIcons?: {\n    remove: React.ComponentType<Partial<BaseProps>>;\n    visible: React.ComponentType<Partial<BaseProps>>;\n    hidden: React.ComponentType<Partial<BaseProps>>;\n    enableConfig: React.ComponentType<Partial<BaseProps>>;\n    disableConfig: React.ComponentType<Partial<BaseProps>>;\n  };\n  actionItems?: ActionItem[];\n};\n\nexport const defaultProps = {\n  isDragNDropEnabled: true\n};\n\nconst defaultActionIcons = {\n  remove: Trash,\n  visible: EyeSeen,\n  hidden: EyeUnseen,\n  enableConfig: ArrowDown,\n  disableConfig: ArrowUp\n};\n\nconst defaultEffectIcons = {\n  [LIGHT_AND_SHADOW_EFFECT.type]: LightAndShadowEffectIcon,\n  [POSTPROCESSING_EFFECTS.ink.type]: InkEffectIcon,\n  [POSTPROCESSING_EFFECTS.brightnessContrast.type]: BrightnessContrastEffectIcon,\n  [POSTPROCESSING_EFFECTS.hueSaturation.type]: HueSaturationEffectIcon,\n  [POSTPROCESSING_EFFECTS.vibrance.type]: VibranceEffectIcon,\n  [POSTPROCESSING_EFFECTS.sepia.type]: SepiaEffectIcon,\n  [POSTPROCESSING_EFFECTS.dotScreen.type]: DotScreenEffectIcon,\n  [POSTPROCESSING_EFFECTS.colorHalftone.type]: ColorHalftoneEffectIcon,\n  [POSTPROCESSING_EFFECTS.noise.type]: NoiseEffectIcon,\n  [POSTPROCESSING_EFFECTS.triangleBlur.type]: TriangleBlurEffectIcon,\n  [POSTPROCESSING_EFFECTS.zoomBlur.type]: ZoomBlurEffectIcon,\n  [POSTPROCESSING_EFFECTS.tiltShift.type]: TiltShiftEffectIcon,\n  [POSTPROCESSING_EFFECTS.edgeWork.type]: EdgeWorkEffectIcon,\n  [POSTPROCESSING_EFFECTS.vignette.type]: VignetteEffectIcon,\n  [POSTPROCESSING_EFFECTS.magnify.type]: MagnifyEffectIcon,\n  [POSTPROCESSING_EFFECTS.hexagonalPixelate.type]: HexagonalPixelateEffectIcon,\n  [DISTANCE_FOG_TYPE]: DistanceFogEffectIcon,\n  [SURFACE_FOG_TYPE]: SurfaceFogEffectIcon\n};\n\nconst StyledEffectPanelHeader = styled(StyledPanelHeader)`\n  height: ${props => props.theme.effectPanelHeaderHeight}px;\n  position: relative;\n  align-items: stretch;\n\n  .effect__drag-handle {\n    margin-left: -5px;\n    color: ${props => props.theme.textColor};\n  }\n\n  .effect__drag-handle__placeholder {\n    height: 20px;\n    padding: 0px;\n    margin: 10px 10px 10px 5px;\n  }\n\n  &:hover {\n    cursor: pointer;\n    background-color: ${props => props.theme.panelBackgroundHover};\n    .effect__drag-handle {\n      opacity: 1;\n    }\n  }\n\n  border-left: 3px solid ${props => props.theme.panelBackgroundHover};\n`;\n\nconst HeaderActionSection = styled.div`\n  display: flex;\n  position: absolute;\n  height: 100%;\n  align-items: stretch;\n  right: 10px;\n  &:hover {\n    .effect-panel__header__actions__hidden {\n      opacity: 1;\n      background-color: ${props => props.theme.panelBackgroundHover};\n    }\n  }\n`;\n\n// Hiden actions only show up on hover\ntype StyledPanelHeaderHiddenActionsProps = {isConfigActive: boolean};\nconst StyledPanelHeaderHiddenActions = styled.div.attrs({\n  className: 'effect-panel__header__actions__hidden'\n})<StyledPanelHeaderHiddenActionsProps>`\n  opacity: 0;\n  display: flex;\n  align-items: center;\n  transition: opacity 0.4s ease, background-color 0.4s ease;\n  background-color: ${props =>\n    props.isConfigActive ? props.theme.panelBackgroundHover : props.theme.panelBackground};\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  &:hover {\n    cursor: move;\n    opacity: 1;\n    color: ${props => props.theme.textColorHl};\n  }\n`;\n\nconst DragHandle = ({className, listeners, children}) => (\n  <StyledDragHandle className={className} {...listeners}>\n    {children}\n  </StyledDragHandle>\n);\n\nEffectPanelHeaderActionSectionFactory.deps = [PanelHeaderActionFactory];\n\nexport function EffectPanelHeaderActionSectionFactory(\n  PanelHeaderAction: ReturnType<typeof PanelHeaderActionFactory>\n): React.FC<EffectPanelHeaderProps> {\n  const EffectPanelHeaderActionSection = (props: EffectPanelHeaderProps) => {\n    const {\n      effectId,\n      isEnabled,\n      isConfigActive,\n      onToggleEnabled,\n      onRemoveEffect,\n      onToggleEnableConfig,\n      actionItems,\n      actionIcons = defaultActionIcons\n    } = props;\n\n    const effectActionItems: ActionItem[] = useMemo(\n      () =>\n        actionItems ?? [\n          {\n            key: 'remove-effect',\n            isHidden: true,\n            tooltip: 'tooltip.removeEffect',\n            tooltipType: 'error',\n            onClick: onRemoveEffect,\n            icon: actionIcons.remove\n          },\n          {\n            key: 'visibility-toggle',\n            tooltip: isEnabled ? 'tooltip.disableEffect' : 'tooltip.enabledEffect',\n            onClick: onToggleEnabled,\n            icon: isEnabled ? actionIcons.visible : actionIcons.hidden\n          },\n          {\n            key: 'enable-config',\n            classNames: {'is-open': isConfigActive},\n            tooltip: 'tooltip.effectSettings',\n            onClick: onToggleEnableConfig,\n            icon: actionIcons.enableConfig\n          }\n        ],\n      [\n        actionItems,\n        actionIcons,\n        isEnabled,\n        isConfigActive,\n        onRemoveEffect,\n        onToggleEnabled,\n        onToggleEnableConfig\n      ]\n    );\n\n    return (\n      <HeaderActionSection className=\"effect-panel__header__actions\">\n        <StyledPanelHeaderHiddenActions isConfigActive={isConfigActive}>\n          {effectActionItems\n            .filter((item: ActionItem) => Boolean(item.isHidden))\n            .map((item: ActionItem) => (\n              <PanelHeaderAction\n                key={item.key}\n                className={`effect__${item.key}`}\n                testId={`${item.key}-action`}\n                id={effectId}\n                tooltip={item.tooltip}\n                onClick={item.onClick}\n                tooltipType={item.tooltipType}\n                IconComponent={item.icon}\n              />\n            ))}\n        </StyledPanelHeaderHiddenActions>\n        {effectActionItems\n          .filter((item: ActionItem) => !item.isHidden)\n          .map((item: ActionItem) => (\n            <PanelHeaderAction\n              key={item.key}\n              className={classnames(`effect__${item.key}`, item.classNames)}\n              testId={`${item.key}-action`}\n              id={effectId}\n              tooltip={item.tooltip}\n              onClick={item.onClick}\n              tooltipType={item.tooltipType}\n              IconComponent={item.icon}\n            />\n          ))}\n      </HeaderActionSection>\n    );\n  };\n\n  return EffectPanelHeaderActionSection;\n}\n\nconst StyledEffectTitleSection = styled.div`\n  margin-left: 8px;\n  flex-grow: 1;\n  align-items: center;\n  display: flex;\n  color: ${props => props.theme.textColor};\n`;\n\nconst IconPlaceholder = styled.div`\n  width: 20px;\n  height: 20px;\n`;\n\nconst EffectIconWrapper = styled.div`\n  height: 18px;\n  margin: auto;\n  color: ${props => props.theme.textColor};\n`;\n\nEffectPanelHeaderFactory.deps = [EffectPanelHeaderActionSectionFactory];\n\nfunction EffectPanelHeaderFactory(\n  EffectPanelHeaderActionSection: ReturnType<typeof EffectPanelHeaderActionSectionFactory>\n): React.FC<EffectPanelHeaderProps> {\n  const EffectPanelHeader = (props: EffectPanelHeaderProps) => {\n    const {\n      isConfigActive,\n      isDragNDropEnabled = true,\n      type,\n      onToggleEnableConfig,\n      listeners,\n      showSortHandle = true\n    } = props;\n\n    const label = useMemo(() => {\n      const description = EFFECT_DESCRIPTIONS.find(_description => _description.type === type);\n      return description?.name || 'Effect';\n    }, [type]);\n\n    const EffectIcon = defaultEffectIcons[type];\n\n    return (\n      <StyledEffectPanelHeader\n        className={classnames('effect-panel__header', {\n          'sort--handle': !isConfigActive\n        })}\n        active={isConfigActive}\n        onClick={onToggleEnableConfig}\n      >\n        {isDragNDropEnabled ? (\n          <DragHandle className=\"effect__drag-handle\" listeners={listeners}>\n            {showSortHandle ? <VertDots height=\"20px\" /> : <IconPlaceholder />}\n          </DragHandle>\n        ) : (\n          <div className=\"effect__drag-handle__placeholder\" />\n        )}\n\n        <EffectIconWrapper>{EffectIcon ? <EffectIcon height=\"18px\" /> : null}</EffectIconWrapper>\n\n        <StyledEffectTitleSection>{label}</StyledEffectTitleSection>\n\n        <EffectPanelHeaderActionSection {...props} />\n      </StyledEffectPanelHeader>\n    );\n  };\n\n  return EffectPanelHeader;\n}\n\nexport default EffectPanelHeaderFactory;\n"],"mappings":"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","ignoreList":[]}