kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
214 lines (210 loc) • 39 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.StyledSidePanelContent = void 0;
exports["default"] = SidePanelFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _constants = require("@kepler.gl/constants");
var _icons = require("./common/icons");
var _sideBar = _interopRequireDefault(require("./side-panel/side-bar"));
var _panelHeader = _interopRequireDefault(require("./side-panel/panel-header"));
var _panelToggle = _interopRequireDefault(require("./side-panel/panel-toggle"));
var _layerManager = _interopRequireDefault(require("./side-panel/layer-manager"));
var _filterManager = _interopRequireDefault(require("./side-panel/filter-manager"));
var _interactionManager = _interopRequireDefault(require("./side-panel/interaction-manager"));
var _mapManager = _interopRequireDefault(require("./side-panel/map-manager"));
var _customPanel = _interopRequireDefault(require("./side-panel/custom-panel"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _templateObject; // 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; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
var StyledSidePanelContent = exports.StyledSidePanelContent = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n flex-grow: 1;\n padding: ", "px;\n overflow-y: scroll;\n overflow-x: hidden;\n\n .side-panel__content__inner {\n display: flex;\n height: 100%;\n flex-direction: column;\n }\n"])), function (props) {
return props.theme.sidePanelScrollBar;
}, function (props) {
return props.theme.sidePanelInnerPadding;
});
SidePanelFactory.deps = [_sideBar["default"], _panelHeader["default"], _panelToggle["default"], _layerManager["default"], _filterManager["default"], _interactionManager["default"], _mapManager["default"], _customPanel["default"]];
/**
* Vertical sidebar containing input components for the rendering layers
*/
function SidePanelFactory(Sidebar, PanelHeader, PanelToggle, LayerManager, FilterManager, InteractionManager, MapManager, CustomPanels) {
// inject components
var SIDEBAR_COMPONENTS = {
layer: LayerManager,
filter: FilterManager,
interaction: InteractionManager,
map: MapManager
};
var SIDEBAR_ICONS = {
layer: _icons.Layers,
filter: _icons.FilterFunnel,
interaction: _icons.Settings,
map: _icons.CursorClick
};
// We should defined sidebar panels here but keeping them for backward compatible
var defaultSidePanels = _constants.SIDEBAR_PANELS.map(function (component) {
return _objectSpread(_objectSpread({}, component), {}, {
component: SIDEBAR_COMPONENTS[component.id],
iconComponent: SIDEBAR_ICONS[component.id]
});
});
var fullPanels = [].concat((0, _toConsumableArray2["default"])(defaultSidePanels), (0, _toConsumableArray2["default"])(CustomPanels.panels || []));
var getCustomPanelProps = CustomPanels.getProps || function () {
return {};
};
// eslint-disable-next-line max-statements
var SidePanel = function SidePanel(props) {
var appName = props.appName,
appWebsite = props.appWebsite,
_props$availableProvi = props.availableProviders,
availableProviders = _props$availableProvi === void 0 ? {} : _props$availableProvi,
datasets = props.datasets,
filters = props.filters,
layers = props.layers,
layerBlending = props.layerBlending,
overlayBlending = props.overlayBlending,
layerClasses = props.layerClasses,
layerOrder = props.layerOrder,
interactionConfig = props.interactionConfig,
_props$panels = props.panels,
panels = _props$panels === void 0 ? fullPanels : _props$panels,
_props$mapInfo = props.mapInfo,
mapInfo = _props$mapInfo === void 0 ? {} : _props$mapInfo,
mapSaved = props.mapSaved,
mapStateActions = props.mapStateActions,
mapStyle = props.mapStyle,
mapStyleActions = props.mapStyleActions,
onSaveMap = props.onSaveMap,
uiState = props.uiState,
uiStateActions = props.uiStateActions,
visStateActions = props.visStateActions,
version = props.version,
width = props.width;
var openDeleteModal = uiStateActions.openDeleteModal,
toggleModal = uiStateActions.toggleModal,
toggleSidePanel = uiStateActions.toggleSidePanel;
var activeSidePanel = uiState.activeSidePanel;
var setMapInfo = visStateActions.setMapInfo,
showDatasetTable = visStateActions.showDatasetTable,
updateTableColor = visStateActions.updateTableColor;
var hasShare = availableProviders.hasShare,
hasStorage = availableProviders.hasStorage;
var title = mapInfo.title;
var isOpen = Boolean(activeSidePanel);
var _onOpenOrClose = (0, _react.useCallback)(function () {
return toggleSidePanel(activeSidePanel ? '' : 'layer');
}, [activeSidePanel, toggleSidePanel]);
var onClickExportImage = (0, _react.useCallback)(function () {
return toggleModal(_constants.EXPORT_IMAGE_ID);
}, [toggleModal]);
var onClickExportData = (0, _react.useCallback)(function () {
return toggleModal(_constants.EXPORT_DATA_ID);
}, [toggleModal]);
var onClickExportMap = (0, _react.useCallback)(function () {
return toggleModal(_constants.EXPORT_MAP_ID);
}, [toggleModal]);
var onClickSaveToStorage = (0, _react.useCallback)(function () {
return toggleModal(mapSaved ? _constants.OVERWRITE_MAP_ID : _constants.SAVE_MAP_ID);
}, [mapSaved, toggleModal]);
var onClickSaveAsToStorage = (0, _react.useCallback)(function () {
setMapInfo({
title: "".concat(title || 'Kepler.gl', " (Copy)")
});
toggleModal(_constants.SAVE_MAP_ID);
}, [title, setMapInfo, toggleModal]);
var onClickShareMap = (0, _react.useCallback)(function () {
return toggleModal(_constants.SHARE_MAP_ID);
}, [toggleModal]);
var onShowDatasetTable = (0, _react.useCallback)(function (dataId) {
return showDatasetTable(dataId);
}, [showDatasetTable]);
var onUpdateTableColor = (0, _react.useCallback)(function (dataId, newColor) {
return updateTableColor(dataId, newColor);
}, [updateTableColor]);
var onShowAddDataModal = (0, _react.useCallback)(function () {
return toggleModal(_constants.ADD_DATA_ID);
}, [toggleModal]);
var onShowAddMapStyleModal = (0, _react.useCallback)(function () {
return toggleModal(_constants.ADD_MAP_STYLE_ID);
}, [toggleModal]);
var onRemoveDataset = (0, _react.useCallback)(function (dataId) {
return openDeleteModal(dataId);
}, [openDeleteModal]);
var currentPanel = (0, _react.useMemo)(function () {
return panels.find(function (_ref) {
var id = _ref.id;
return id === activeSidePanel;
}) || null;
}, [activeSidePanel, panels]);
var customPanelProps = (0, _react.useMemo)(function () {
return getCustomPanelProps(props);
}, [props]);
var PanelComponent = currentPanel === null || currentPanel === void 0 ? void 0 : currentPanel.component;
return /*#__PURE__*/_react["default"].createElement(Sidebar, {
width: width,
isOpen: isOpen,
shouldShowCollapseButton: uiState.isSidePanelCloseButtonVisible,
minifiedWidth: 0,
onOpenOrClose: _onOpenOrClose
}, /*#__PURE__*/_react["default"].createElement(PanelHeader, {
appName: appName,
version: version,
appWebsite: appWebsite,
visibleDropdown: uiState.visibleDropdown,
showExportDropdown: uiStateActions.showExportDropdown,
hideExportDropdown: uiStateActions.hideExportDropdown,
onExportImage: onClickExportImage,
onExportData: onClickExportData,
onExportMap: onClickExportMap,
onSaveMap: hasStorage ? onSaveMap : undefined,
onSaveToStorage: hasStorage ? onClickSaveToStorage : null,
onSaveAsToStorage: hasStorage && mapSaved ? onClickSaveAsToStorage : null,
onShareMap: hasShare ? onClickShareMap : null
}), /*#__PURE__*/_react["default"].createElement(PanelToggle, {
panels: panels,
activePanel: activeSidePanel,
togglePanel: uiStateActions.toggleSidePanel
}), /*#__PURE__*/_react["default"].createElement(StyledSidePanelContent, {
className: "side-panel__content"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "side-panel__content__inner"
}, PanelComponent ? /*#__PURE__*/_react["default"].createElement(PanelComponent, {
datasets: datasets,
filters: filters,
layers: layers,
layerClasses: layerClasses,
layerOrder: layerOrder,
layerBlending: layerBlending,
overlayBlending: overlayBlending,
mapStyle: mapStyle,
mapStyleActions: mapStyleActions,
mapStateActions: mapStateActions,
interactionConfig: interactionConfig,
removeDataset: onRemoveDataset,
showDatasetTable: onShowDatasetTable,
updateTableColor: onUpdateTableColor,
showAddDataModal: onShowAddDataModal,
showAddMapStyleModal: onShowAddMapStyleModal,
uiStateActions: uiStateActions,
visStateActions: visStateActions,
panelMetadata: currentPanel,
panelListView: (currentPanel === null || currentPanel === void 0 ? void 0 : currentPanel.id) === 'layer' ? uiState.layerPanelListView : (currentPanel === null || currentPanel === void 0 ? void 0 : currentPanel.id) === 'filter' ? uiState.filterPanelListView : null
}) : null, /*#__PURE__*/_react["default"].createElement(CustomPanels, (0, _extends2["default"])({}, customPanelProps, {
activeSidePanel: activeSidePanel,
updateTableColor: onUpdateTableColor
})))));
};
SidePanel.defaultPanels = fullPanels;
return SidePanel;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_constants","_icons","_sideBar","_interopRequireDefault","_panelHeader","_panelToggle","_layerManager","_filterManager","_interactionManager","_mapManager","_customPanel","_styledComponents","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","StyledSidePanelContent","exports","styled","div","_taggedTemplateLiteral2","props","theme","sidePanelScrollBar","sidePanelInnerPadding","SidePanelFactory","deps","SidebarFactory","PanelHeaderFactory","PanelToggleFactory","LayerManagerFactory","FilterManagerFactory","InteractionManagerFactory","MapManagerFactory","CustomPanelsFactory","Sidebar","PanelHeader","PanelToggle","LayerManager","FilterManager","InteractionManager","MapManager","CustomPanels","SIDEBAR_COMPONENTS","layer","interaction","map","SIDEBAR_ICONS","Layers","FilterFunnel","Settings","CursorClick","defaultSidePanels","SIDEBAR_PANELS","component","id","iconComponent","fullPanels","concat","_toConsumableArray2","panels","getCustomPanelProps","getProps","SidePanel","appName","appWebsite","_props$availableProvi","availableProviders","datasets","filters","layers","layerBlending","overlayBlending","layerClasses","layerOrder","interactionConfig","_props$panels","_props$mapInfo","mapInfo","mapSaved","mapStateActions","mapStyle","mapStyleActions","onSaveMap","uiState","uiStateActions","visStateActions","version","width","openDeleteModal","toggleModal","toggleSidePanel","activeSidePanel","setMapInfo","showDatasetTable","updateTableColor","hasShare","hasStorage","title","isOpen","Boolean","_onOpenOrClose","useCallback","onClickExportImage","EXPORT_IMAGE_ID","onClickExportData","EXPORT_DATA_ID","onClickExportMap","EXPORT_MAP_ID","onClickSaveToStorage","OVERWRITE_MAP_ID","SAVE_MAP_ID","onClickSaveAsToStorage","onClickShareMap","SHARE_MAP_ID","onShowDatasetTable","dataId","onUpdateTableColor","newColor","onShowAddDataModal","ADD_DATA_ID","onShowAddMapStyleModal","ADD_MAP_STYLE_ID","onRemoveDataset","currentPanel","useMemo","find","_ref","customPanelProps","PanelComponent","createElement","shouldShowCollapseButton","isSidePanelCloseButtonVisible","minifiedWidth","onOpenOrClose","visibleDropdown","showExportDropdown","hideExportDropdown","onExportImage","onExportData","onExportMap","undefined","onSaveToStorage","onSaveAsToStorage","onShareMap","activePanel","togglePanel","className","removeDataset","showAddDataModal","showAddMapStyleModal","panelMetadata","panelListView","layerPanelListView","filterPanelListView","_extends2","defaultPanels"],"sources":["../src/side-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\n\nimport {\n  EXPORT_DATA_ID,\n  EXPORT_MAP_ID,\n  SHARE_MAP_ID,\n  SIDEBAR_PANELS,\n  OVERWRITE_MAP_ID,\n  SAVE_MAP_ID,\n  EXPORT_IMAGE_ID,\n  ADD_DATA_ID,\n  ADD_MAP_STYLE_ID\n} from '@kepler.gl/constants';\n\nimport {CursorClick, Layers, FilterFunnel, Settings} from './common/icons';\n\nimport SidebarFactory from './side-panel/side-bar';\nimport PanelHeaderFactory from './side-panel/panel-header';\nimport PanelToggleFactory from './side-panel/panel-toggle';\nimport LayerManagerFactory from './side-panel/layer-manager';\nimport FilterManagerFactory from './side-panel/filter-manager';\nimport InteractionManagerFactory from './side-panel/interaction-manager';\nimport MapManagerFactory from './side-panel/map-manager';\nimport CustomPanelsFactory from './side-panel/custom-panel';\n\nimport styled from 'styled-components';\nimport {SidePanelProps, SidePanelItem} from './types';\n\nexport const StyledSidePanelContent = styled.div`\n  ${props => props.theme.sidePanelScrollBar};\n  flex-grow: 1;\n  padding: ${props => props.theme.sidePanelInnerPadding}px;\n  overflow-y: scroll;\n  overflow-x: hidden;\n\n  .side-panel__content__inner {\n    display: flex;\n    height: 100%;\n    flex-direction: column;\n  }\n`;\n\nSidePanelFactory.deps = [\n  SidebarFactory,\n  PanelHeaderFactory,\n  PanelToggleFactory,\n  LayerManagerFactory,\n  FilterManagerFactory,\n  InteractionManagerFactory,\n  MapManagerFactory,\n  CustomPanelsFactory\n];\n\n/**\n * Vertical sidebar containing input components for the rendering layers\n */\nexport default function SidePanelFactory(\n  Sidebar: ReturnType<typeof SidebarFactory>,\n  PanelHeader: ReturnType<typeof PanelHeaderFactory>,\n  PanelToggle: ReturnType<typeof PanelToggleFactory>,\n  LayerManager: ReturnType<typeof LayerManagerFactory>,\n  FilterManager: ReturnType<typeof FilterManagerFactory>,\n  InteractionManager: ReturnType<typeof InteractionManagerFactory>,\n  MapManager: ReturnType<typeof MapManagerFactory>,\n  CustomPanels: ReturnType<typeof CustomPanelsFactory>\n) {\n  // inject components\n  const SIDEBAR_COMPONENTS = {\n    layer: LayerManager,\n    filter: FilterManager,\n    interaction: InteractionManager,\n    map: MapManager\n  };\n\n  const SIDEBAR_ICONS = {\n    layer: Layers,\n    filter: FilterFunnel,\n    interaction: Settings,\n    map: CursorClick\n  };\n\n  // We should defined sidebar panels here but keeping them for backward compatible\n  const defaultSidePanels: SidePanelItem[] = SIDEBAR_PANELS.map(component => ({\n    ...component,\n    component: SIDEBAR_COMPONENTS[component.id],\n    iconComponent: SIDEBAR_ICONS[component.id]\n  }));\n\n  const fullPanels = [...defaultSidePanels, ...(CustomPanels.panels || [])];\n\n  const getCustomPanelProps = CustomPanels.getProps || (() => ({}));\n\n  // eslint-disable-next-line max-statements\n  const SidePanel: React.FC<SidePanelProps> & {defaultPanels: SidePanelProps['panels']} = (\n    props: SidePanelProps\n  ) => {\n    const {\n      appName,\n      appWebsite,\n      availableProviders = {},\n      datasets,\n      filters,\n      layers,\n      layerBlending,\n      overlayBlending,\n      layerClasses,\n      layerOrder,\n      interactionConfig,\n      panels = fullPanels,\n      mapInfo = {},\n      mapSaved,\n      mapStateActions,\n      mapStyle,\n      mapStyleActions,\n      onSaveMap,\n      uiState,\n      uiStateActions,\n      visStateActions,\n      version,\n      width\n    } = props;\n    const {openDeleteModal, toggleModal, toggleSidePanel} = uiStateActions;\n    const {activeSidePanel} = uiState;\n    const {setMapInfo, showDatasetTable, updateTableColor} = visStateActions;\n    const {hasShare, hasStorage} = availableProviders;\n\n    const {title} = mapInfo;\n\n    const isOpen = Boolean(activeSidePanel);\n\n    const _onOpenOrClose = useCallback(\n      () => toggleSidePanel(activeSidePanel ? '' : 'layer'),\n      [activeSidePanel, toggleSidePanel]\n    );\n\n    const onClickExportImage = useCallback(() => toggleModal(EXPORT_IMAGE_ID), [toggleModal]);\n    const onClickExportData = useCallback(() => toggleModal(EXPORT_DATA_ID), [toggleModal]);\n    const onClickExportMap = useCallback(() => toggleModal(EXPORT_MAP_ID), [toggleModal]);\n    const onClickSaveToStorage = useCallback(\n      () => toggleModal(mapSaved ? OVERWRITE_MAP_ID : SAVE_MAP_ID),\n      [mapSaved, toggleModal]\n    );\n    const onClickSaveAsToStorage = useCallback(() => {\n      setMapInfo({\n        title: `${title || 'Kepler.gl'} (Copy)`\n      });\n\n      toggleModal(SAVE_MAP_ID);\n    }, [title, setMapInfo, toggleModal]);\n    const onClickShareMap = useCallback(() => toggleModal(SHARE_MAP_ID), [toggleModal]);\n    const onShowDatasetTable = useCallback(dataId => showDatasetTable(dataId), [showDatasetTable]);\n    const onUpdateTableColor = useCallback(\n      (dataId, newColor) => updateTableColor(dataId, newColor),\n      [updateTableColor]\n    );\n    const onShowAddDataModal = useCallback(() => toggleModal(ADD_DATA_ID), [toggleModal]);\n    const onShowAddMapStyleModal = useCallback(() => toggleModal(ADD_MAP_STYLE_ID), [toggleModal]);\n    const onRemoveDataset = useCallback(dataId => openDeleteModal(dataId), [openDeleteModal]);\n\n    const currentPanel = useMemo(\n      () => panels.find(({id}) => id === activeSidePanel) || null,\n      [activeSidePanel, panels]\n    );\n\n    const customPanelProps = useMemo(() => getCustomPanelProps(props), [props]) as Record<\n      string,\n      any\n    >;\n    const PanelComponent = currentPanel?.component;\n\n    return (\n      <Sidebar\n        width={width}\n        isOpen={isOpen}\n        shouldShowCollapseButton={uiState.isSidePanelCloseButtonVisible}\n        minifiedWidth={0}\n        onOpenOrClose={_onOpenOrClose}\n      >\n        <PanelHeader\n          appName={appName}\n          version={version}\n          appWebsite={appWebsite}\n          visibleDropdown={uiState.visibleDropdown}\n          showExportDropdown={uiStateActions.showExportDropdown}\n          hideExportDropdown={uiStateActions.hideExportDropdown}\n          onExportImage={onClickExportImage}\n          onExportData={onClickExportData}\n          onExportMap={onClickExportMap}\n          onSaveMap={hasStorage ? onSaveMap : undefined}\n          onSaveToStorage={hasStorage ? onClickSaveToStorage : null}\n          onSaveAsToStorage={hasStorage && mapSaved ? onClickSaveAsToStorage : null}\n          onShareMap={hasShare ? onClickShareMap : null}\n        />\n        {/* the next two components should be moved into one */}\n        {/* but i am keeping them because of backward compatibility */}\n        <PanelToggle\n          panels={panels}\n          activePanel={activeSidePanel}\n          togglePanel={uiStateActions.toggleSidePanel}\n        />\n        <StyledSidePanelContent className=\"side-panel__content\">\n          <div className=\"side-panel__content__inner\">\n            {PanelComponent ? (\n              <PanelComponent\n                datasets={datasets}\n                filters={filters}\n                layers={layers}\n                layerClasses={layerClasses}\n                layerOrder={layerOrder}\n                layerBlending={layerBlending}\n                overlayBlending={overlayBlending}\n                mapStyle={mapStyle}\n                mapStyleActions={mapStyleActions}\n                mapStateActions={mapStateActions}\n                interactionConfig={interactionConfig}\n                removeDataset={onRemoveDataset}\n                showDatasetTable={onShowDatasetTable}\n                updateTableColor={onUpdateTableColor}\n                showAddDataModal={onShowAddDataModal}\n                showAddMapStyleModal={onShowAddMapStyleModal}\n                uiStateActions={uiStateActions}\n                visStateActions={visStateActions}\n                panelMetadata={currentPanel}\n                panelListView={\n                  currentPanel?.id === 'layer'\n                    ? uiState.layerPanelListView\n                    : currentPanel?.id === 'filter'\n                    ? uiState.filterPanelListView\n                    : null\n                }\n              />\n            ) : null}\n            <CustomPanels\n              {...customPanelProps}\n              activeSidePanel={activeSidePanel}\n              updateTableColor={onUpdateTableColor}\n            />\n          </div>\n        </StyledSidePanelContent>\n      </Sidebar>\n    );\n  };\n\n  SidePanel.defaultPanels = fullPanels;\n  return SidePanel;\n}\n"],"mappings":"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","ignoreList":[]}