@deephaven/dashboard 1.2.1-plotly-rc.3 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BasePanel.js.map +1 -1
- package/dist/Dashboard.js.map +1 -1
- package/dist/DashboardConstants.js.map +1 -1
- package/dist/DashboardEvents.js.map +1 -1
- package/dist/DashboardLayout.js.map +1 -1
- package/dist/DashboardPanelWrapper.js.map +1 -1
- package/dist/DashboardPlugin.js.map +1 -1
- package/dist/DashboardUtils.js.map +1 -1
- package/dist/LazyDashboard.js.map +1 -1
- package/dist/NavigationEvent.js.map +1 -1
- package/dist/PanelContextMenu.js.map +1 -1
- package/dist/PanelErrorBoundary.css.map +1 -1
- package/dist/PanelErrorBoundary.js.map +1 -1
- package/dist/PanelEvent.js.map +1 -1
- package/dist/PanelManager.js.map +1 -1
- package/dist/PanelPlaceholder.css.map +1 -1
- package/dist/PanelPlaceholder.js.map +1 -1
- package/dist/RenameDialog.js.map +1 -1
- package/dist/TabEvent.js.map +1 -1
- package/dist/declaration.d.js.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/layout/GLPropTypes.js.map +1 -1
- package/dist/layout/GoldenLayout.css.map +1 -1
- package/dist/layout/LayoutManagerContext.js.map +1 -1
- package/dist/layout/LayoutUtils.js.map +1 -1
- package/dist/layout/index.js.map +1 -1
- package/dist/layout/useDashboardPanel.js.map +1 -1
- package/dist/layout/useLayoutManager.js.map +1 -1
- package/dist/layout/useListener.js.map +1 -1
- package/dist/layout/usePanelRegistration.js.map +1 -1
- package/dist/redux/actionTypes.js.map +1 -1
- package/dist/redux/actions.js.map +1 -1
- package/dist/redux/hooks.js.map +1 -1
- package/dist/redux/index.js.map +1 -1
- package/dist/redux/reducers/dashboardData.js.map +1 -1
- package/dist/redux/reducers/index.js.map +1 -1
- package/dist/redux/selectors.js.map +1 -1
- package/dist/useDashboardId.js.map +1 -1
- package/dist/useDhId.js.map +1 -1
- package/dist/useFiber.js.map +1 -1
- package/dist/usePanelId.js.map +1 -1
- package/package.json +10 -10
package/dist/PanelManager.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PanelManager.js","names":["Log","PanelEvent","listenForCycleToNextStack","listenForCycleToPreviousStack","listenForCycleToNextTab","listenForCycleToPreviousTab","LayoutUtils","isReactComponentConfig","isWrappedComponent","log","module","CycleDirection","PanelManager","constructor","layout","hydrateComponent","arguments","length","undefined","name","props","dehydrateComponent","config","openedMap","Map","closed","onPanelsUpdated","_defineProperty","handleFocus","bind","handleMount","handleUnmount","handleReopen","handleReopenLast","handleCycleToNextStack","handleCycleToPreviousStack","handleCycleToNextTab","handleCycleToPreviousTab","handleDeleted","handleClosed","handleControlClose","navigationEventListenerRemovers","startListening","eventHub","on","FOCUS","MOUNT","UNMOUNT","REOPEN","REOPEN_LAST","DELETE","CLOSED","CLOSE","push","stopListening","off","forEach","remover","getClosedPanelConfigsOfType","typeString","filter","panel","component","getOpenedPanels","Array","from","values","getOpenedPanelConfigs","map","glContainer","getComponentConfigFromContainer","getOpenedPanelConfigsOfType","getOpenedPanelById","panelId","get","getContainerByPanelId","_ref","stack","getStackForConfig","root","id","getContentItemInStack","getLastUsedPanel","matcher","opened","i","getLastUsedPanelOfType","type","getLastUsedPanelOfTypes","types","some","WrappedComponent","updatePanel","getIdFromPanel","error","debug2","concat","delete","set","removePanel","has","debug","removeClosedPanelConfig","panelConfig","index","findIndex","closedConfig","splice","sendUpdate","cycleStack","direction","allStacks","getAllStackContainers","focusedIndex","getFocusedStackIndex","targetStack","activeContentIndex","activeItemIndex","activeContentItem","contentItems","setActiveContentItem","targetIndex","Next","Previous","cycleTab","_focusedStack$config$","focusedStack","getFocusedStack","targetContentItem","replaceConfig","_objectSpread","parentStackId","getStackById","openComponent","_LayoutUtils$getStack","stackId","getConfig","addClosedPanel","closeComponent","dehydratedConfig","_LayoutUtils$getStack2"],"sources":["../src/PanelManager.ts"],"sourcesContent":["import { type ComponentType } from 'react';\nimport type GoldenLayout from '@deephaven/golden-layout';\nimport type {\n Container,\n ContentItem,\n ItemConfig,\n ReactComponentConfig,\n} from '@deephaven/golden-layout';\nimport Log from '@deephaven/log';\nimport PanelEvent from './PanelEvent';\nimport {\n listenForCycleToNextStack,\n listenForCycleToPreviousStack,\n listenForCycleToNextTab,\n listenForCycleToPreviousTab,\n} from './NavigationEvent';\nimport LayoutUtils, { isReactComponentConfig } from './layout/LayoutUtils';\nimport {\n isWrappedComponent,\n type PanelComponent,\n type PanelComponentType,\n type PanelProps,\n} from './DashboardPlugin';\n\nconst log = Log.module('PanelManager');\n\nenum CycleDirection {\n Next,\n Previous,\n}\n\nexport type PanelHydraterFunction = (\n name: string,\n props: PanelProps\n) => PanelProps;\n\nexport type PanelDehydraterFunction = (\n name: string,\n config: ReactComponentConfig\n) => ReactComponentConfig;\n\nexport type ClosedPanel = ReactComponentConfig & {\n /**\n * The stack the component is in.\n */\n parentStackId?: string | string[];\n};\n\nexport type ClosedPanels = ClosedPanel[];\n\nexport type OpenedPanelMap = Map<string | string[], PanelComponent>;\n\nexport type PanelsUpdateData = {\n closed: ClosedPanels;\n openedMap: OpenedPanelMap;\n};\n\nexport type PanelsUpdateCallback = (panelUpdateData: PanelsUpdateData) => void;\n\n/**\n * Class to keep track of which panels are open, have been closed, and also events to close panels.\n */\nclass PanelManager {\n static MAX_CLOSED_PANEL_COUNT = 100;\n\n layout: GoldenLayout;\n\n hydrateComponent: PanelHydraterFunction;\n\n dehydrateComponent: PanelDehydraterFunction;\n\n onPanelsUpdated: PanelsUpdateCallback;\n\n closed: ClosedPanels;\n\n openedMap: OpenedPanelMap;\n\n navigationEventListenerRemovers: (() => void)[];\n\n /**\n * @param layout The GoldenLayout object to attach to\n * @param hydrateComponent Function to hydrate a panel from a dehydrated state\n * @param dehydrateComponent Function to dehydrate a panel\n * @param openedMap Map of opened panels\n * @param closed Array of closed panels in a dehydrated state\n * @param onPanelsUpdated Triggered when the panels are updated\n */\n constructor(\n layout: GoldenLayout,\n hydrateComponent: PanelHydraterFunction = (name, props) => props,\n dehydrateComponent: PanelDehydraterFunction = (name, config) => config,\n openedMap: OpenedPanelMap = new Map(),\n closed: ClosedPanel[] = [],\n onPanelsUpdated: PanelsUpdateCallback = () => undefined\n ) {\n this.handleFocus = this.handleFocus.bind(this);\n this.handleMount = this.handleMount.bind(this);\n // Panel can be unmounted on error but still keep the tab until it's closed\n // Use PanelEvent.MOUNT/UNMOUNT to track open (active) panels\n // and PanelEvent.CLOSED for cleanup (delete links, add panel to closed panels list, etc)\n this.handleUnmount = this.handleUnmount.bind(this);\n this.handleReopen = this.handleReopen.bind(this);\n this.handleReopenLast = this.handleReopenLast.bind(this);\n this.handleCycleToNextStack = this.handleCycleToNextStack.bind(this);\n this.handleCycleToPreviousStack =\n this.handleCycleToPreviousStack.bind(this);\n this.handleCycleToNextTab = this.handleCycleToNextTab.bind(this);\n this.handleCycleToPreviousTab = this.handleCycleToPreviousTab.bind(this);\n this.handleDeleted = this.handleDeleted.bind(this);\n this.handleClosed = this.handleClosed.bind(this);\n this.handleControlClose = this.handleControlClose.bind(this);\n\n this.layout = layout;\n this.hydrateComponent = hydrateComponent;\n this.dehydrateComponent = dehydrateComponent;\n this.onPanelsUpdated = onPanelsUpdated;\n\n // Store the opened and closed panels\n this.openedMap = new Map(openedMap);\n\n // Closed panels are stored in their dehydrated state\n this.closed = [...closed];\n\n // Store the navigation event listener removers\n this.navigationEventListenerRemovers = [];\n\n this.startListening();\n }\n\n startListening(): void {\n const { eventHub } = this.layout;\n eventHub.on(PanelEvent.FOCUS, this.handleFocus);\n eventHub.on(PanelEvent.MOUNT, this.handleMount);\n eventHub.on(PanelEvent.UNMOUNT, this.handleUnmount);\n eventHub.on(PanelEvent.REOPEN, this.handleReopen);\n eventHub.on(PanelEvent.REOPEN_LAST, this.handleReopenLast);\n eventHub.on(PanelEvent.DELETE, this.handleDeleted);\n eventHub.on(PanelEvent.CLOSED, this.handleClosed);\n eventHub.on(PanelEvent.CLOSE, this.handleControlClose);\n // PanelEvent.OPEN should be listened to by plugins to open a panel\n\n this.navigationEventListenerRemovers.push(\n listenForCycleToNextStack(eventHub, this.handleCycleToNextStack)\n );\n this.navigationEventListenerRemovers.push(\n listenForCycleToPreviousStack(eventHub, this.handleCycleToPreviousStack)\n );\n this.navigationEventListenerRemovers.push(\n listenForCycleToNextTab(eventHub, this.handleCycleToNextTab)\n );\n this.navigationEventListenerRemovers.push(\n listenForCycleToPreviousTab(eventHub, this.handleCycleToPreviousTab)\n );\n }\n\n stopListening(): void {\n const { eventHub } = this.layout;\n eventHub.off(PanelEvent.FOCUS, this.handleFocus);\n eventHub.off(PanelEvent.MOUNT, this.handleMount);\n eventHub.off(PanelEvent.UNMOUNT, this.handleUnmount);\n eventHub.off(PanelEvent.REOPEN, this.handleReopen);\n eventHub.off(PanelEvent.REOPEN_LAST, this.handleReopenLast);\n eventHub.off(PanelEvent.DELETE, this.handleDeleted);\n eventHub.off(PanelEvent.CLOSED, this.handleClosed);\n eventHub.off(PanelEvent.CLOSE, this.handleControlClose);\n\n this.navigationEventListenerRemovers.forEach(remover => remover());\n this.navigationEventListenerRemovers = [];\n }\n\n getClosedPanelConfigsOfType(typeString: string): ClosedPanels {\n return this.closed.filter(panel => panel.component === typeString);\n }\n\n getOpenedPanels(): PanelComponent[] {\n return Array.from(this.openedMap.values());\n }\n\n getOpenedPanelConfigs(): (ItemConfig | null)[] {\n return this.getOpenedPanels().map(panel => {\n const { glContainer } = panel.props;\n return LayoutUtils.getComponentConfigFromContainer(glContainer);\n });\n }\n\n getOpenedPanelConfigsOfType(typeString: string): ReactComponentConfig[] {\n return this.getOpenedPanelConfigs().filter(\n config =>\n config != null &&\n isReactComponentConfig(config) &&\n config.component === typeString\n ) as ReactComponentConfig[];\n }\n\n getOpenedPanelById(panelId: string | string[]): PanelComponent | undefined {\n return this.openedMap.get(panelId);\n }\n\n getContainerByPanelId(panelId: string | string[]): ContentItem | null {\n const stack = LayoutUtils.getStackForConfig(this.layout.root, {\n id: panelId,\n });\n return (\n (stack && LayoutUtils.getContentItemInStack(stack, { id: panelId })) ??\n null\n );\n }\n\n getLastUsedPanel<T extends PanelComponent = PanelComponent>(\n matcher: (panel: PanelComponent) => boolean\n ): T | undefined {\n const opened = this.getOpenedPanels();\n for (let i = opened.length - 1; i >= 0; i -= 1) {\n const panel = opened[i];\n if (matcher == null || matcher(panel)) {\n return panel as T;\n }\n }\n\n return undefined;\n }\n\n getLastUsedPanelOfType<\n P extends PanelProps = PanelProps,\n C extends ComponentType<P> = ComponentType<P>,\n >(type: PanelComponentType<P, C>): PanelComponent<P> | undefined {\n return this.getLastUsedPanelOfTypes([type]);\n }\n\n getLastUsedPanelOfTypes<\n P extends PanelProps = PanelProps,\n C extends ComponentType<P> = ComponentType<P>,\n >(types: PanelComponentType<P, C>[]): PanelComponent<P> | undefined {\n return this.getLastUsedPanel(panel =>\n types.some(\n type =>\n (isWrappedComponent(type) &&\n panel instanceof type.WrappedComponent) ||\n (!isWrappedComponent(type) && panel instanceof type)\n )\n );\n }\n\n updatePanel(panel: PanelComponent): void {\n const panelId = LayoutUtils.getIdFromPanel(panel);\n if (panelId == null) {\n log.error('updatePanel Panel did not have an ID', panel);\n return;\n }\n log.debug2(`Updating panel ID ${panelId} in open panels map`);\n // Delete the entry before it's set to maintain correct ordering in the open panels map.\n // The last updated (focused) panel should be the last inserted.\n // Deleting the entry from the map directly instead of calling this.removePanel to skip the checks.\n this.openedMap.delete(panelId);\n this.openedMap.set(panelId, panel);\n }\n\n removePanel(panel: PanelComponent): void {\n const panelId = LayoutUtils.getIdFromPanel(panel);\n if (panelId == null) {\n log.error('removePanel Panel did not have an ID', panel);\n return;\n }\n if (!this.openedMap.has(panelId)) {\n log.error(`Missing panel ID ${panelId} in open panels map`);\n return;\n }\n if (this.openedMap.get(panelId) !== panel) {\n // We mount a new panel before un-mounting the existing one\n // when replacing existing panels in openComponent/openComponentInStack.\n // Skip map delete if the panelId entry already refers to the new panel.\n log.debug(\n `Panel argument doesn't match the open panels map entry for ${panelId}, removePanel ignored`\n );\n return;\n }\n log.debug2(`Removing panel ID ${panelId} from open panels map`);\n this.openedMap.delete(panelId);\n }\n\n removeClosedPanelConfig(panelConfig: ClosedPanel): void {\n const index = this.closed.findIndex(\n closedConfig =>\n closedConfig === panelConfig ||\n (closedConfig.id != null &&\n panelConfig.id != null &&\n closedConfig.id === panelConfig.id)\n );\n if (index >= 0) {\n this.closed.splice(index, 1);\n }\n }\n\n handleFocus(panel: PanelComponent): void {\n log.debug2('Focus: ', panel);\n this.updatePanel(panel);\n }\n\n handleMount(panel: PanelComponent): void {\n log.debug2('Mount: ', panel);\n this.updatePanel(panel);\n this.sendUpdate();\n }\n\n handleUnmount(panel: PanelComponent): void {\n log.debug2('Unmount: ', panel);\n this.removePanel(panel);\n this.sendUpdate();\n }\n\n cycleStack(direction: CycleDirection): void {\n const allStacks = LayoutUtils.getAllStackContainers(this.layout);\n if (allStacks.length <= 1) {\n return;\n }\n\n const focusedIndex = LayoutUtils.getFocusedStackIndex(allStacks);\n\n // If no stack is focused, activate the first stack's content item\n if (focusedIndex === -1) {\n const targetStack = allStacks[0];\n const activeContentIndex = targetStack.config.activeItemIndex;\n const activeContentItem =\n activeContentIndex != null\n ? targetStack.contentItems[activeContentIndex]\n : targetStack.contentItems[0];\n\n targetStack.setActiveContentItem(activeContentItem, true);\n return;\n }\n\n const targetIndex =\n direction === CycleDirection.Next\n ? (focusedIndex + 1) % allStacks.length\n : (focusedIndex - 1 + allStacks.length) % allStacks.length;\n const targetStack = allStacks[targetIndex];\n\n const activeContentIndex = targetStack.config.activeItemIndex;\n const activeContentItem =\n activeContentIndex != null\n ? targetStack.contentItems[activeContentIndex]\n : targetStack.contentItems[0];\n\n targetStack.setActiveContentItem(activeContentItem, true);\n }\n\n handleCycleToNextStack(): void {\n this.cycleStack(CycleDirection.Next);\n }\n\n handleCycleToPreviousStack(): void {\n this.cycleStack(CycleDirection.Previous);\n }\n\n cycleTab(direction: CycleDirection): void {\n const focusedStack = LayoutUtils.getFocusedStack(this.layout);\n if (focusedStack === undefined) {\n return;\n }\n const { contentItems } = focusedStack;\n\n if (contentItems.length <= 1) {\n return;\n }\n\n const activeItemIndex = focusedStack.config.activeItemIndex ?? 0;\n const targetIndex =\n direction === CycleDirection.Next\n ? (activeItemIndex + 1) % contentItems.length\n : (activeItemIndex - 1 + contentItems.length) % contentItems.length;\n\n const targetContentItem = contentItems[targetIndex];\n focusedStack.setActiveContentItem(targetContentItem, true);\n }\n\n handleCycleToNextTab(): void {\n this.cycleTab(CycleDirection.Next);\n }\n\n handleCycleToPreviousTab(): void {\n this.cycleTab(CycleDirection.Previous);\n }\n\n /**\n *\n * @param panelConfig The config to hydrate and load\n * @param replaceConfig The config to place\n */\n handleReopen(\n panelConfig: ClosedPanel,\n replaceConfig?: Partial<ItemConfig>\n ): void {\n log.debug2('Reopen:', panelConfig, replaceConfig);\n\n this.removeClosedPanelConfig(panelConfig);\n // Don't need to send an update yet, it will get sent when component is mounted\n\n // Rehydrate the panel before adding it back\n const { component } = panelConfig;\n let { props } = panelConfig;\n props = this.hydrateComponent(component, props);\n\n const config = {\n ...panelConfig,\n props,\n };\n\n const { root } = this.layout;\n const stack =\n panelConfig.parentStackId === undefined\n ? undefined\n : LayoutUtils.getStackById(root, panelConfig.parentStackId);\n LayoutUtils.openComponent({\n root,\n config,\n replaceConfig,\n stack: stack ?? undefined,\n });\n }\n\n /**\n *\n * @param glContainer Only reopen panels that were closed from the stack of this container, if defined\n */\n handleReopenLast(glContainer?: Container): void {\n if (this.closed.length === 0) return;\n if (glContainer === undefined) {\n this.handleReopen(this.closed[this.closed.length - 1]);\n return;\n }\n\n const stackId = LayoutUtils.getStackForConfig(\n this.layout.root,\n glContainer.getConfig()\n )?.config.id;\n for (let i = this.closed.length - 1; i >= 0; i -= 1) {\n const panelConfig = this.closed[i];\n if (panelConfig.parentStackId === stackId) {\n this.handleReopen(panelConfig);\n return;\n }\n }\n }\n\n handleDeleted(panelConfig: ClosedPanel): void {\n log.debug2('Deleted:', panelConfig);\n\n this.removeClosedPanelConfig(panelConfig);\n\n this.sendUpdate();\n }\n\n handleClosed(panelId: string, glContainer: Container): void {\n // Panel component should be already unmounted at this point\n // so the emitted event sends the container object instead of the panel.\n log.debug2('Closed: ', panelId);\n this.addClosedPanel(glContainer);\n this.sendUpdate();\n }\n\n handleControlClose(id: string): void {\n const config = { id };\n const { root } = this.layout;\n LayoutUtils.closeComponent(root, config);\n }\n\n addClosedPanel(glContainer: Container): void {\n const { root } = this.layout;\n const config = LayoutUtils.getComponentConfigFromContainer(glContainer);\n if (config && isReactComponentConfig(config)) {\n const dehydratedConfig = this.dehydrateComponent(\n config.component,\n config\n );\n if (dehydratedConfig != null) {\n (dehydratedConfig as ClosedPanel).parentStackId =\n LayoutUtils.getStackForConfig(root, config)?.config.id;\n this.closed.push(dehydratedConfig);\n }\n }\n }\n\n sendUpdate(): void {\n const { closed, openedMap } = this;\n this.onPanelsUpdated({\n closed: [...closed],\n openedMap: new Map(openedMap),\n });\n }\n}\n\nexport default PanelManager;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"PanelManager.js","names":["Log","PanelEvent","listenForCycleToNextStack","listenForCycleToPreviousStack","listenForCycleToNextTab","listenForCycleToPreviousTab","LayoutUtils","isReactComponentConfig","isWrappedComponent","log","module","CycleDirection","PanelManager","constructor","layout","hydrateComponent","arguments","length","undefined","name","props","dehydrateComponent","config","openedMap","Map","closed","onPanelsUpdated","_defineProperty","handleFocus","bind","handleMount","handleUnmount","handleReopen","handleReopenLast","handleCycleToNextStack","handleCycleToPreviousStack","handleCycleToNextTab","handleCycleToPreviousTab","handleDeleted","handleClosed","handleControlClose","navigationEventListenerRemovers","startListening","eventHub","on","FOCUS","MOUNT","UNMOUNT","REOPEN","REOPEN_LAST","DELETE","CLOSED","CLOSE","push","stopListening","off","forEach","remover","getClosedPanelConfigsOfType","typeString","filter","panel","component","getOpenedPanels","Array","from","values","getOpenedPanelConfigs","map","glContainer","getComponentConfigFromContainer","getOpenedPanelConfigsOfType","getOpenedPanelById","panelId","get","getContainerByPanelId","_ref","stack","getStackForConfig","root","id","getContentItemInStack","getLastUsedPanel","matcher","opened","i","getLastUsedPanelOfType","type","getLastUsedPanelOfTypes","types","some","WrappedComponent","updatePanel","getIdFromPanel","error","debug2","concat","delete","set","removePanel","has","debug","removeClosedPanelConfig","panelConfig","index","findIndex","closedConfig","splice","sendUpdate","cycleStack","direction","allStacks","getAllStackContainers","focusedIndex","getFocusedStackIndex","targetStack","activeContentIndex","activeItemIndex","activeContentItem","contentItems","setActiveContentItem","targetIndex","Next","Previous","cycleTab","_focusedStack$config$","focusedStack","getFocusedStack","targetContentItem","replaceConfig","_objectSpread","parentStackId","getStackById","openComponent","_LayoutUtils$getStack","stackId","getConfig","addClosedPanel","closeComponent","dehydratedConfig","_LayoutUtils$getStack2"],"sources":["../src/PanelManager.ts"],"sourcesContent":["import { type ComponentType } from 'react';\nimport type GoldenLayout from '@deephaven/golden-layout';\nimport type {\n Container,\n ContentItem,\n ItemConfig,\n ReactComponentConfig,\n} from '@deephaven/golden-layout';\nimport Log from '@deephaven/log';\nimport PanelEvent from './PanelEvent';\nimport {\n listenForCycleToNextStack,\n listenForCycleToPreviousStack,\n listenForCycleToNextTab,\n listenForCycleToPreviousTab,\n} from './NavigationEvent';\nimport LayoutUtils, { isReactComponentConfig } from './layout/LayoutUtils';\nimport {\n isWrappedComponent,\n type PanelComponent,\n type PanelComponentType,\n type PanelProps,\n} from './DashboardPlugin';\n\nconst log = Log.module('PanelManager');\n\nenum CycleDirection {\n Next,\n Previous,\n}\n\nexport type PanelHydraterFunction = (\n name: string,\n props: PanelProps\n) => PanelProps;\n\nexport type PanelDehydraterFunction = (\n name: string,\n config: ReactComponentConfig\n) => ReactComponentConfig;\n\nexport type ClosedPanel = ReactComponentConfig & {\n /**\n * The stack the component is in.\n */\n parentStackId?: string | string[];\n};\n\nexport type ClosedPanels = ClosedPanel[];\n\nexport type OpenedPanelMap = Map<string | string[], PanelComponent>;\n\nexport type PanelsUpdateData = {\n closed: ClosedPanels;\n openedMap: OpenedPanelMap;\n};\n\nexport type PanelsUpdateCallback = (panelUpdateData: PanelsUpdateData) => void;\n\n/**\n * Class to keep track of which panels are open, have been closed, and also events to close panels.\n */\nclass PanelManager {\n static MAX_CLOSED_PANEL_COUNT = 100;\n\n layout: GoldenLayout;\n\n hydrateComponent: PanelHydraterFunction;\n\n dehydrateComponent: PanelDehydraterFunction;\n\n onPanelsUpdated: PanelsUpdateCallback;\n\n closed: ClosedPanels;\n\n openedMap: OpenedPanelMap;\n\n navigationEventListenerRemovers: (() => void)[];\n\n /**\n * @param layout The GoldenLayout object to attach to\n * @param hydrateComponent Function to hydrate a panel from a dehydrated state\n * @param dehydrateComponent Function to dehydrate a panel\n * @param openedMap Map of opened panels\n * @param closed Array of closed panels in a dehydrated state\n * @param onPanelsUpdated Triggered when the panels are updated\n */\n constructor(\n layout: GoldenLayout,\n hydrateComponent: PanelHydraterFunction = (name, props) => props,\n dehydrateComponent: PanelDehydraterFunction = (name, config) => config,\n openedMap: OpenedPanelMap = new Map(),\n closed: ClosedPanel[] = [],\n onPanelsUpdated: PanelsUpdateCallback = () => undefined\n ) {\n this.handleFocus = this.handleFocus.bind(this);\n this.handleMount = this.handleMount.bind(this);\n // Panel can be unmounted on error but still keep the tab until it's closed\n // Use PanelEvent.MOUNT/UNMOUNT to track open (active) panels\n // and PanelEvent.CLOSED for cleanup (delete links, add panel to closed panels list, etc)\n this.handleUnmount = this.handleUnmount.bind(this);\n this.handleReopen = this.handleReopen.bind(this);\n this.handleReopenLast = this.handleReopenLast.bind(this);\n this.handleCycleToNextStack = this.handleCycleToNextStack.bind(this);\n this.handleCycleToPreviousStack =\n this.handleCycleToPreviousStack.bind(this);\n this.handleCycleToNextTab = this.handleCycleToNextTab.bind(this);\n this.handleCycleToPreviousTab = this.handleCycleToPreviousTab.bind(this);\n this.handleDeleted = this.handleDeleted.bind(this);\n this.handleClosed = this.handleClosed.bind(this);\n this.handleControlClose = this.handleControlClose.bind(this);\n\n this.layout = layout;\n this.hydrateComponent = hydrateComponent;\n this.dehydrateComponent = dehydrateComponent;\n this.onPanelsUpdated = onPanelsUpdated;\n\n // Store the opened and closed panels\n this.openedMap = new Map(openedMap);\n\n // Closed panels are stored in their dehydrated state\n this.closed = [...closed];\n\n // Store the navigation event listener removers\n this.navigationEventListenerRemovers = [];\n\n this.startListening();\n }\n\n startListening(): void {\n const { eventHub } = this.layout;\n eventHub.on(PanelEvent.FOCUS, this.handleFocus);\n eventHub.on(PanelEvent.MOUNT, this.handleMount);\n eventHub.on(PanelEvent.UNMOUNT, this.handleUnmount);\n eventHub.on(PanelEvent.REOPEN, this.handleReopen);\n eventHub.on(PanelEvent.REOPEN_LAST, this.handleReopenLast);\n eventHub.on(PanelEvent.DELETE, this.handleDeleted);\n eventHub.on(PanelEvent.CLOSED, this.handleClosed);\n eventHub.on(PanelEvent.CLOSE, this.handleControlClose);\n // PanelEvent.OPEN should be listened to by plugins to open a panel\n\n this.navigationEventListenerRemovers.push(\n listenForCycleToNextStack(eventHub, this.handleCycleToNextStack)\n );\n this.navigationEventListenerRemovers.push(\n listenForCycleToPreviousStack(eventHub, this.handleCycleToPreviousStack)\n );\n this.navigationEventListenerRemovers.push(\n listenForCycleToNextTab(eventHub, this.handleCycleToNextTab)\n );\n this.navigationEventListenerRemovers.push(\n listenForCycleToPreviousTab(eventHub, this.handleCycleToPreviousTab)\n );\n }\n\n stopListening(): void {\n const { eventHub } = this.layout;\n eventHub.off(PanelEvent.FOCUS, this.handleFocus);\n eventHub.off(PanelEvent.MOUNT, this.handleMount);\n eventHub.off(PanelEvent.UNMOUNT, this.handleUnmount);\n eventHub.off(PanelEvent.REOPEN, this.handleReopen);\n eventHub.off(PanelEvent.REOPEN_LAST, this.handleReopenLast);\n eventHub.off(PanelEvent.DELETE, this.handleDeleted);\n eventHub.off(PanelEvent.CLOSED, this.handleClosed);\n eventHub.off(PanelEvent.CLOSE, this.handleControlClose);\n\n this.navigationEventListenerRemovers.forEach(remover => remover());\n this.navigationEventListenerRemovers = [];\n }\n\n getClosedPanelConfigsOfType(typeString: string): ClosedPanels {\n return this.closed.filter(panel => panel.component === typeString);\n }\n\n getOpenedPanels(): PanelComponent[] {\n return Array.from(this.openedMap.values());\n }\n\n getOpenedPanelConfigs(): (ItemConfig | null)[] {\n return this.getOpenedPanels().map(panel => {\n const { glContainer } = panel.props;\n return LayoutUtils.getComponentConfigFromContainer(glContainer);\n });\n }\n\n getOpenedPanelConfigsOfType(typeString: string): ReactComponentConfig[] {\n return this.getOpenedPanelConfigs().filter(\n config =>\n config != null &&\n isReactComponentConfig(config) &&\n config.component === typeString\n ) as ReactComponentConfig[];\n }\n\n getOpenedPanelById(panelId: string | string[]): PanelComponent | undefined {\n return this.openedMap.get(panelId);\n }\n\n getContainerByPanelId(panelId: string | string[]): ContentItem | null {\n const stack = LayoutUtils.getStackForConfig(this.layout.root, {\n id: panelId,\n });\n return (\n (stack && LayoutUtils.getContentItemInStack(stack, { id: panelId })) ??\n null\n );\n }\n\n getLastUsedPanel<T extends PanelComponent = PanelComponent>(\n matcher: (panel: PanelComponent) => boolean\n ): T | undefined {\n const opened = this.getOpenedPanels();\n for (let i = opened.length - 1; i >= 0; i -= 1) {\n const panel = opened[i];\n if (matcher == null || matcher(panel)) {\n return panel as T;\n }\n }\n\n return undefined;\n }\n\n getLastUsedPanelOfType<\n P extends PanelProps = PanelProps,\n C extends ComponentType<P> = ComponentType<P>,\n >(type: PanelComponentType<P, C>): PanelComponent<P> | undefined {\n return this.getLastUsedPanelOfTypes([type]);\n }\n\n getLastUsedPanelOfTypes<\n P extends PanelProps = PanelProps,\n C extends ComponentType<P> = ComponentType<P>,\n >(types: PanelComponentType<P, C>[]): PanelComponent<P> | undefined {\n return this.getLastUsedPanel(panel =>\n types.some(\n type =>\n (isWrappedComponent(type) &&\n panel instanceof type.WrappedComponent) ||\n (!isWrappedComponent(type) && panel instanceof type)\n )\n );\n }\n\n updatePanel(panel: PanelComponent): void {\n const panelId = LayoutUtils.getIdFromPanel(panel);\n if (panelId == null) {\n log.error('updatePanel Panel did not have an ID', panel);\n return;\n }\n log.debug2(`Updating panel ID ${panelId} in open panels map`);\n // Delete the entry before it's set to maintain correct ordering in the open panels map.\n // The last updated (focused) panel should be the last inserted.\n // Deleting the entry from the map directly instead of calling this.removePanel to skip the checks.\n this.openedMap.delete(panelId);\n this.openedMap.set(panelId, panel);\n }\n\n removePanel(panel: PanelComponent): void {\n const panelId = LayoutUtils.getIdFromPanel(panel);\n if (panelId == null) {\n log.error('removePanel Panel did not have an ID', panel);\n return;\n }\n if (!this.openedMap.has(panelId)) {\n log.error(`Missing panel ID ${panelId} in open panels map`);\n return;\n }\n if (this.openedMap.get(panelId) !== panel) {\n // We mount a new panel before un-mounting the existing one\n // when replacing existing panels in openComponent/openComponentInStack.\n // Skip map delete if the panelId entry already refers to the new panel.\n log.debug(\n `Panel argument doesn't match the open panels map entry for ${panelId}, removePanel ignored`\n );\n return;\n }\n log.debug2(`Removing panel ID ${panelId} from open panels map`);\n this.openedMap.delete(panelId);\n }\n\n removeClosedPanelConfig(panelConfig: ClosedPanel): void {\n const index = this.closed.findIndex(\n closedConfig =>\n closedConfig === panelConfig ||\n (closedConfig.id != null &&\n panelConfig.id != null &&\n closedConfig.id === panelConfig.id)\n );\n if (index >= 0) {\n this.closed.splice(index, 1);\n }\n }\n\n handleFocus(panel: PanelComponent): void {\n log.debug2('Focus: ', panel);\n this.updatePanel(panel);\n }\n\n handleMount(panel: PanelComponent): void {\n log.debug2('Mount: ', panel);\n this.updatePanel(panel);\n this.sendUpdate();\n }\n\n handleUnmount(panel: PanelComponent): void {\n log.debug2('Unmount: ', panel);\n this.removePanel(panel);\n this.sendUpdate();\n }\n\n cycleStack(direction: CycleDirection): void {\n const allStacks = LayoutUtils.getAllStackContainers(this.layout);\n if (allStacks.length <= 1) {\n return;\n }\n\n const focusedIndex = LayoutUtils.getFocusedStackIndex(allStacks);\n\n // If no stack is focused, activate the first stack's content item\n if (focusedIndex === -1) {\n const targetStack = allStacks[0];\n const activeContentIndex = targetStack.config.activeItemIndex;\n const activeContentItem =\n activeContentIndex != null\n ? targetStack.contentItems[activeContentIndex]\n : targetStack.contentItems[0];\n\n targetStack.setActiveContentItem(activeContentItem, true);\n return;\n }\n\n const targetIndex =\n direction === CycleDirection.Next\n ? (focusedIndex + 1) % allStacks.length\n : (focusedIndex - 1 + allStacks.length) % allStacks.length;\n const targetStack = allStacks[targetIndex];\n\n const activeContentIndex = targetStack.config.activeItemIndex;\n const activeContentItem =\n activeContentIndex != null\n ? targetStack.contentItems[activeContentIndex]\n : targetStack.contentItems[0];\n\n targetStack.setActiveContentItem(activeContentItem, true);\n }\n\n handleCycleToNextStack(): void {\n this.cycleStack(CycleDirection.Next);\n }\n\n handleCycleToPreviousStack(): void {\n this.cycleStack(CycleDirection.Previous);\n }\n\n cycleTab(direction: CycleDirection): void {\n const focusedStack = LayoutUtils.getFocusedStack(this.layout);\n if (focusedStack === undefined) {\n return;\n }\n const { contentItems } = focusedStack;\n\n if (contentItems.length <= 1) {\n return;\n }\n\n const activeItemIndex = focusedStack.config.activeItemIndex ?? 0;\n const targetIndex =\n direction === CycleDirection.Next\n ? (activeItemIndex + 1) % contentItems.length\n : (activeItemIndex - 1 + contentItems.length) % contentItems.length;\n\n const targetContentItem = contentItems[targetIndex];\n focusedStack.setActiveContentItem(targetContentItem, true);\n }\n\n handleCycleToNextTab(): void {\n this.cycleTab(CycleDirection.Next);\n }\n\n handleCycleToPreviousTab(): void {\n this.cycleTab(CycleDirection.Previous);\n }\n\n /**\n *\n * @param panelConfig The config to hydrate and load\n * @param replaceConfig The config to place\n */\n handleReopen(\n panelConfig: ClosedPanel,\n replaceConfig?: Partial<ItemConfig>\n ): void {\n log.debug2('Reopen:', panelConfig, replaceConfig);\n\n this.removeClosedPanelConfig(panelConfig);\n // Don't need to send an update yet, it will get sent when component is mounted\n\n // Rehydrate the panel before adding it back\n const { component } = panelConfig;\n let { props } = panelConfig;\n props = this.hydrateComponent(component, props);\n\n const config = {\n ...panelConfig,\n props,\n };\n\n const { root } = this.layout;\n const stack =\n panelConfig.parentStackId === undefined\n ? undefined\n : LayoutUtils.getStackById(root, panelConfig.parentStackId);\n LayoutUtils.openComponent({\n root,\n config,\n replaceConfig,\n stack: stack ?? undefined,\n });\n }\n\n /**\n *\n * @param glContainer Only reopen panels that were closed from the stack of this container, if defined\n */\n handleReopenLast(glContainer?: Container): void {\n if (this.closed.length === 0) return;\n if (glContainer === undefined) {\n this.handleReopen(this.closed[this.closed.length - 1]);\n return;\n }\n\n const stackId = LayoutUtils.getStackForConfig(\n this.layout.root,\n glContainer.getConfig()\n )?.config.id;\n for (let i = this.closed.length - 1; i >= 0; i -= 1) {\n const panelConfig = this.closed[i];\n if (panelConfig.parentStackId === stackId) {\n this.handleReopen(panelConfig);\n return;\n }\n }\n }\n\n handleDeleted(panelConfig: ClosedPanel): void {\n log.debug2('Deleted:', panelConfig);\n\n this.removeClosedPanelConfig(panelConfig);\n\n this.sendUpdate();\n }\n\n handleClosed(panelId: string, glContainer: Container): void {\n // Panel component should be already unmounted at this point\n // so the emitted event sends the container object instead of the panel.\n log.debug2('Closed: ', panelId);\n this.addClosedPanel(glContainer);\n this.sendUpdate();\n }\n\n handleControlClose(id: string): void {\n const config = { id };\n const { root } = this.layout;\n LayoutUtils.closeComponent(root, config);\n }\n\n addClosedPanel(glContainer: Container): void {\n const { root } = this.layout;\n const config = LayoutUtils.getComponentConfigFromContainer(glContainer);\n if (config && isReactComponentConfig(config)) {\n const dehydratedConfig = this.dehydrateComponent(\n config.component,\n config\n );\n if (dehydratedConfig != null) {\n (dehydratedConfig as ClosedPanel).parentStackId =\n LayoutUtils.getStackForConfig(root, config)?.config.id;\n this.closed.push(dehydratedConfig);\n }\n }\n }\n\n sendUpdate(): void {\n const { closed, openedMap } = this;\n this.onPanelsUpdated({\n closed: [...closed],\n openedMap: new Map(openedMap),\n });\n }\n}\n\nexport default PanelManager;\n"],"mappings":";;;;;AAQA,OAAOA,GAAG,MAAM,gBAAgB;AAAC,OAC1BC,UAAU;AAAA,SAEfC,yBAAyB,EACzBC,6BAA6B,EAC7BC,uBAAuB,EACvBC,2BAA2B;AAAA,OAEtBC,WAAW,IAAIC,sBAAsB;AAAA,SAE1CC,kBAAkB;AAMpB,IAAMC,GAAG,GAAGT,GAAG,CAACU,MAAM,CAAC,cAAc,CAAC;AAAC,IAElCC,cAAc;AAAA,WAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;AAAA,GAAdA,cAAc,KAAdA,cAAc;AAiCnB;AACA;AACA;AACA,MAAMC,YAAY,CAAC;EAiBjB;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CACTC,MAAoB,EAMpB;IAAA,IALAC,gBAAuC,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAACG,IAAI,EAAEC,KAAK,KAAKA,KAAK;IAAA,IAChEC,kBAA2C,GAAAL,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAACG,IAAI,EAAEG,MAAM,KAAKA,MAAM;IAAA,IACtEC,SAAyB,GAAAP,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,IAAIQ,GAAG,CAAC,CAAC;IAAA,IACrCC,MAAqB,GAAAT,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,EAAE;IAAA,IAC1BU,eAAqC,GAAAV,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,MAAME,SAAS;IAAAS,eAAA;IAAAA,eAAA;IAAAA,eAAA;IAAAA,eAAA;IAAAA,eAAA;IAAAA,eAAA;IAAAA,eAAA;IAEvD,IAAI,CAACC,WAAW,GAAG,IAAI,CAACA,WAAW,CAACC,IAAI,CAAC,IAAI,CAAC;IAC9C,IAAI,CAACC,WAAW,GAAG,IAAI,CAACA,WAAW,CAACD,IAAI,CAAC,IAAI,CAAC;IAC9C;IACA;IACA;IACA,IAAI,CAACE,aAAa,GAAG,IAAI,CAACA,aAAa,CAACF,IAAI,CAAC,IAAI,CAAC;IAClD,IAAI,CAACG,YAAY,GAAG,IAAI,CAACA,YAAY,CAACH,IAAI,CAAC,IAAI,CAAC;IAChD,IAAI,CAACI,gBAAgB,GAAG,IAAI,CAACA,gBAAgB,CAACJ,IAAI,CAAC,IAAI,CAAC;IACxD,IAAI,CAACK,sBAAsB,GAAG,IAAI,CAACA,sBAAsB,CAACL,IAAI,CAAC,IAAI,CAAC;IACpE,IAAI,CAACM,0BAA0B,GAC7B,IAAI,CAACA,0BAA0B,CAACN,IAAI,CAAC,IAAI,CAAC;IAC5C,IAAI,CAACO,oBAAoB,GAAG,IAAI,CAACA,oBAAoB,CAACP,IAAI,CAAC,IAAI,CAAC;IAChE,IAAI,CAACQ,wBAAwB,GAAG,IAAI,CAACA,wBAAwB,CAACR,IAAI,CAAC,IAAI,CAAC;IACxE,IAAI,CAACS,aAAa,GAAG,IAAI,CAACA,aAAa,CAACT,IAAI,CAAC,IAAI,CAAC;IAClD,IAAI,CAACU,YAAY,GAAG,IAAI,CAACA,YAAY,CAACV,IAAI,CAAC,IAAI,CAAC;IAChD,IAAI,CAACW,kBAAkB,GAAG,IAAI,CAACA,kBAAkB,CAACX,IAAI,CAAC,IAAI,CAAC;IAE5D,IAAI,CAACf,MAAM,GAAGA,MAAM;IACpB,IAAI,CAACC,gBAAgB,GAAGA,gBAAgB;IACxC,IAAI,CAACM,kBAAkB,GAAGA,kBAAkB;IAC5C,IAAI,CAACK,eAAe,GAAGA,eAAe;;IAEtC;IACA,IAAI,CAACH,SAAS,GAAG,IAAIC,GAAG,CAACD,SAAS,CAAC;;IAEnC;IACA,IAAI,CAACE,MAAM,GAAG,CAAC,GAAGA,MAAM,CAAC;;IAEzB;IACA,IAAI,CAACgB,+BAA+B,GAAG,EAAE;IAEzC,IAAI,CAACC,cAAc,CAAC,CAAC;EACvB;EAEAA,cAAcA,CAAA,EAAS;IACrB,IAAM;MAAEC;IAAS,CAAC,GAAG,IAAI,CAAC7B,MAAM;IAChC6B,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAAC4C,KAAK,EAAE,IAAI,CAACjB,WAAW,CAAC;IAC/Ce,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAAC6C,KAAK,EAAE,IAAI,CAAChB,WAAW,CAAC;IAC/Ca,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAAC8C,OAAO,EAAE,IAAI,CAAChB,aAAa,CAAC;IACnDY,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAAC+C,MAAM,EAAE,IAAI,CAAChB,YAAY,CAAC;IACjDW,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAACgD,WAAW,EAAE,IAAI,CAAChB,gBAAgB,CAAC;IAC1DU,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAACiD,MAAM,EAAE,IAAI,CAACZ,aAAa,CAAC;IAClDK,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAACkD,MAAM,EAAE,IAAI,CAACZ,YAAY,CAAC;IACjDI,QAAQ,CAACC,EAAE,CAAC3C,UAAU,CAACmD,KAAK,EAAE,IAAI,CAACZ,kBAAkB,CAAC;IACtD;;IAEA,IAAI,CAACC,+BAA+B,CAACY,IAAI,CACvCnD,yBAAyB,CAACyC,QAAQ,EAAE,IAAI,CAACT,sBAAsB,CACjE,CAAC;IACD,IAAI,CAACO,+BAA+B,CAACY,IAAI,CACvClD,6BAA6B,CAACwC,QAAQ,EAAE,IAAI,CAACR,0BAA0B,CACzE,CAAC;IACD,IAAI,CAACM,+BAA+B,CAACY,IAAI,CACvCjD,uBAAuB,CAACuC,QAAQ,EAAE,IAAI,CAACP,oBAAoB,CAC7D,CAAC;IACD,IAAI,CAACK,+BAA+B,CAACY,IAAI,CACvChD,2BAA2B,CAACsC,QAAQ,EAAE,IAAI,CAACN,wBAAwB,CACrE,CAAC;EACH;EAEAiB,aAAaA,CAAA,EAAS;IACpB,IAAM;MAAEX;IAAS,CAAC,GAAG,IAAI,CAAC7B,MAAM;IAChC6B,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAAC4C,KAAK,EAAE,IAAI,CAACjB,WAAW,CAAC;IAChDe,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAAC6C,KAAK,EAAE,IAAI,CAAChB,WAAW,CAAC;IAChDa,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAAC8C,OAAO,EAAE,IAAI,CAAChB,aAAa,CAAC;IACpDY,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAAC+C,MAAM,EAAE,IAAI,CAAChB,YAAY,CAAC;IAClDW,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAACgD,WAAW,EAAE,IAAI,CAAChB,gBAAgB,CAAC;IAC3DU,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAACiD,MAAM,EAAE,IAAI,CAACZ,aAAa,CAAC;IACnDK,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAACkD,MAAM,EAAE,IAAI,CAACZ,YAAY,CAAC;IAClDI,QAAQ,CAACY,GAAG,CAACtD,UAAU,CAACmD,KAAK,EAAE,IAAI,CAACZ,kBAAkB,CAAC;IAEvD,IAAI,CAACC,+BAA+B,CAACe,OAAO,CAACC,OAAO,IAAIA,OAAO,CAAC,CAAC,CAAC;IAClE,IAAI,CAAChB,+BAA+B,GAAG,EAAE;EAC3C;EAEAiB,2BAA2BA,CAACC,UAAkB,EAAgB;IAC5D,OAAO,IAAI,CAAClC,MAAM,CAACmC,MAAM,CAACC,KAAK,IAAIA,KAAK,CAACC,SAAS,KAAKH,UAAU,CAAC;EACpE;EAEAI,eAAeA,CAAA,EAAqB;IAClC,OAAOC,KAAK,CAACC,IAAI,CAAC,IAAI,CAAC1C,SAAS,CAAC2C,MAAM,CAAC,CAAC,CAAC;EAC5C;EAEAC,qBAAqBA,CAAA,EAA0B;IAC7C,OAAO,IAAI,CAACJ,eAAe,CAAC,CAAC,CAACK,GAAG,CAACP,KAAK,IAAI;MACzC,IAAM;QAAEQ;MAAY,CAAC,GAAGR,KAAK,CAACzC,KAAK;MACnC,OAAOd,WAAW,CAACgE,+BAA+B,CAACD,WAAW,CAAC;IACjE,CAAC,CAAC;EACJ;EAEAE,2BAA2BA,CAACZ,UAAkB,EAA0B;IACtE,OAAO,IAAI,CAACQ,qBAAqB,CAAC,CAAC,CAACP,MAAM,CACxCtC,MAAM,IACJA,MAAM,IAAI,IAAI,IACdf,sBAAsB,CAACe,MAAM,CAAC,IAC9BA,MAAM,CAACwC,SAAS,KAAKH,UACzB,CAAC;EACH;EAEAa,kBAAkBA,CAACC,OAA0B,EAA8B;IACzE,OAAO,IAAI,CAAClD,SAAS,CAACmD,GAAG,CAACD,OAAO,CAAC;EACpC;EAEAE,qBAAqBA,CAACF,OAA0B,EAAsB;IAAA,IAAAG,IAAA;IACpE,IAAMC,KAAK,GAAGvE,WAAW,CAACwE,iBAAiB,CAAC,IAAI,CAAChE,MAAM,CAACiE,IAAI,EAAE;MAC5DC,EAAE,EAAEP;IACN,CAAC,CAAC;IACF,QAAAG,IAAA,GACGC,KAAK,IAAIvE,WAAW,CAAC2E,qBAAqB,CAACJ,KAAK,EAAE;MAAEG,EAAE,EAAEP;IAAQ,CAAC,CAAC,cAAAG,IAAA,cAAAA,IAAA,GACnE,IAAI;EAER;EAEAM,gBAAgBA,CACdC,OAA2C,EAC5B;IACf,IAAMC,MAAM,GAAG,IAAI,CAACrB,eAAe,CAAC,CAAC;IACrC,KAAK,IAAIsB,CAAC,GAAGD,MAAM,CAACnE,MAAM,GAAG,CAAC,EAAEoE,CAAC,IAAI,CAAC,EAAEA,CAAC,IAAI,CAAC,EAAE;MAC9C,IAAMxB,MAAK,GAAGuB,MAAM,CAACC,CAAC,CAAC;MACvB,IAAIF,OAAO,IAAI,IAAI,IAAIA,OAAO,CAACtB,MAAK,CAAC,EAAE;QACrC,OAAOA,MAAK;MACd;IACF;IAEA,OAAO3C,SAAS;EAClB;EAEAoE,sBAAsBA,CAGpBC,IAA8B,EAAiC;IAC/D,OAAO,IAAI,CAACC,uBAAuB,CAAC,CAACD,IAAI,CAAC,CAAC;EAC7C;EAEAC,uBAAuBA,CAGrBC,KAAiC,EAAiC;IAClE,OAAO,IAAI,CAACP,gBAAgB,CAACrB,KAAK,IAChC4B,KAAK,CAACC,IAAI,CACRH,IAAI,IACD/E,kBAAkB,CAAC+E,IAAI,CAAC,IACvB1B,KAAK,YAAY0B,IAAI,CAACI,gBAAgB,IACvC,CAACnF,kBAAkB,CAAC+E,IAAI,CAAC,IAAI1B,KAAK,YAAY0B,IACnD,CACF,CAAC;EACH;EAEAK,WAAWA,CAAC/B,KAAqB,EAAQ;IACvC,IAAMY,OAAO,GAAGnE,WAAW,CAACuF,cAAc,CAAChC,KAAK,CAAC;IACjD,IAAIY,OAAO,IAAI,IAAI,EAAE;MACnBhE,GAAG,CAACqF,KAAK,CAAC,sCAAsC,EAAEjC,KAAK,CAAC;MACxD;IACF;IACApD,GAAG,CAACsF,MAAM,sBAAAC,MAAA,CAAsBvB,OAAO,wBAAqB,CAAC;IAC7D;IACA;IACA;IACA,IAAI,CAAClD,SAAS,CAAC0E,MAAM,CAACxB,OAAO,CAAC;IAC9B,IAAI,CAAClD,SAAS,CAAC2E,GAAG,CAACzB,OAAO,EAAEZ,KAAK,CAAC;EACpC;EAEAsC,WAAWA,CAACtC,KAAqB,EAAQ;IACvC,IAAMY,OAAO,GAAGnE,WAAW,CAACuF,cAAc,CAAChC,KAAK,CAAC;IACjD,IAAIY,OAAO,IAAI,IAAI,EAAE;MACnBhE,GAAG,CAACqF,KAAK,CAAC,sCAAsC,EAAEjC,KAAK,CAAC;MACxD;IACF;IACA,IAAI,CAAC,IAAI,CAACtC,SAAS,CAAC6E,GAAG,CAAC3B,OAAO,CAAC,EAAE;MAChChE,GAAG,CAACqF,KAAK,qBAAAE,MAAA,CAAqBvB,OAAO,wBAAqB,CAAC;MAC3D;IACF;IACA,IAAI,IAAI,CAAClD,SAAS,CAACmD,GAAG,CAACD,OAAO,CAAC,KAAKZ,KAAK,EAAE;MACzC;MACA;MACA;MACApD,GAAG,CAAC4F,KAAK,+DAAAL,MAAA,CACuDvB,OAAO,0BACvE,CAAC;MACD;IACF;IACAhE,GAAG,CAACsF,MAAM,sBAAAC,MAAA,CAAsBvB,OAAO,0BAAuB,CAAC;IAC/D,IAAI,CAAClD,SAAS,CAAC0E,MAAM,CAACxB,OAAO,CAAC;EAChC;EAEA6B,uBAAuBA,CAACC,WAAwB,EAAQ;IACtD,IAAMC,KAAK,GAAG,IAAI,CAAC/E,MAAM,CAACgF,SAAS,CACjCC,YAAY,IACVA,YAAY,KAAKH,WAAW,IAC3BG,YAAY,CAAC1B,EAAE,IAAI,IAAI,IACtBuB,WAAW,CAACvB,EAAE,IAAI,IAAI,IACtB0B,YAAY,CAAC1B,EAAE,KAAKuB,WAAW,CAACvB,EACtC,CAAC;IACD,IAAIwB,KAAK,IAAI,CAAC,EAAE;MACd,IAAI,CAAC/E,MAAM,CAACkF,MAAM,CAACH,KAAK,EAAE,CAAC,CAAC;IAC9B;EACF;EAEA5E,WAAWA,CAACiC,KAAqB,EAAQ;IACvCpD,GAAG,CAACsF,MAAM,CAAC,SAAS,EAAElC,KAAK,CAAC;IAC5B,IAAI,CAAC+B,WAAW,CAAC/B,KAAK,CAAC;EACzB;EAEA/B,WAAWA,CAAC+B,KAAqB,EAAQ;IACvCpD,GAAG,CAACsF,MAAM,CAAC,SAAS,EAAElC,KAAK,CAAC;IAC5B,IAAI,CAAC+B,WAAW,CAAC/B,KAAK,CAAC;IACvB,IAAI,CAAC+C,UAAU,CAAC,CAAC;EACnB;EAEA7E,aAAaA,CAAC8B,KAAqB,EAAQ;IACzCpD,GAAG,CAACsF,MAAM,CAAC,WAAW,EAAElC,KAAK,CAAC;IAC9B,IAAI,CAACsC,WAAW,CAACtC,KAAK,CAAC;IACvB,IAAI,CAAC+C,UAAU,CAAC,CAAC;EACnB;EAEAC,UAAUA,CAACC,SAAyB,EAAQ;IAC1C,IAAMC,SAAS,GAAGzG,WAAW,CAAC0G,qBAAqB,CAAC,IAAI,CAAClG,MAAM,CAAC;IAChE,IAAIiG,SAAS,CAAC9F,MAAM,IAAI,CAAC,EAAE;MACzB;IACF;IAEA,IAAMgG,YAAY,GAAG3G,WAAW,CAAC4G,oBAAoB,CAACH,SAAS,CAAC;;IAEhE;IACA,IAAIE,YAAY,KAAK,CAAC,CAAC,EAAE;MACvB,IAAME,YAAW,GAAGJ,SAAS,CAAC,CAAC,CAAC;MAChC,IAAMK,mBAAkB,GAAGD,YAAW,CAAC7F,MAAM,CAAC+F,eAAe;MAC7D,IAAMC,kBAAiB,GACrBF,mBAAkB,IAAI,IAAI,GACtBD,YAAW,CAACI,YAAY,CAACH,mBAAkB,CAAC,GAC5CD,YAAW,CAACI,YAAY,CAAC,CAAC,CAAC;MAEjCJ,YAAW,CAACK,oBAAoB,CAACF,kBAAiB,EAAE,IAAI,CAAC;MACzD;IACF;IAEA,IAAMG,WAAW,GACfX,SAAS,KAAKnG,cAAc,CAAC+G,IAAI,GAC7B,CAACT,YAAY,GAAG,CAAC,IAAIF,SAAS,CAAC9F,MAAM,GACrC,CAACgG,YAAY,GAAG,CAAC,GAAGF,SAAS,CAAC9F,MAAM,IAAI8F,SAAS,CAAC9F,MAAM;IAC9D,IAAMkG,WAAW,GAAGJ,SAAS,CAACU,WAAW,CAAC;IAE1C,IAAML,kBAAkB,GAAGD,WAAW,CAAC7F,MAAM,CAAC+F,eAAe;IAC7D,IAAMC,iBAAiB,GACrBF,kBAAkB,IAAI,IAAI,GACtBD,WAAW,CAACI,YAAY,CAACH,kBAAkB,CAAC,GAC5CD,WAAW,CAACI,YAAY,CAAC,CAAC,CAAC;IAEjCJ,WAAW,CAACK,oBAAoB,CAACF,iBAAiB,EAAE,IAAI,CAAC;EAC3D;EAEApF,sBAAsBA,CAAA,EAAS;IAC7B,IAAI,CAAC2E,UAAU,CAAClG,cAAc,CAAC+G,IAAI,CAAC;EACtC;EAEAvF,0BAA0BA,CAAA,EAAS;IACjC,IAAI,CAAC0E,UAAU,CAAClG,cAAc,CAACgH,QAAQ,CAAC;EAC1C;EAEAC,QAAQA,CAACd,SAAyB,EAAQ;IAAA,IAAAe,qBAAA;IACxC,IAAMC,YAAY,GAAGxH,WAAW,CAACyH,eAAe,CAAC,IAAI,CAACjH,MAAM,CAAC;IAC7D,IAAIgH,YAAY,KAAK5G,SAAS,EAAE;MAC9B;IACF;IACA,IAAM;MAAEqG;IAAa,CAAC,GAAGO,YAAY;IAErC,IAAIP,YAAY,CAACtG,MAAM,IAAI,CAAC,EAAE;MAC5B;IACF;IAEA,IAAMoG,eAAe,IAAAQ,qBAAA,GAAGC,YAAY,CAACxG,MAAM,CAAC+F,eAAe,cAAAQ,qBAAA,cAAAA,qBAAA,GAAI,CAAC;IAChE,IAAMJ,WAAW,GACfX,SAAS,KAAKnG,cAAc,CAAC+G,IAAI,GAC7B,CAACL,eAAe,GAAG,CAAC,IAAIE,YAAY,CAACtG,MAAM,GAC3C,CAACoG,eAAe,GAAG,CAAC,GAAGE,YAAY,CAACtG,MAAM,IAAIsG,YAAY,CAACtG,MAAM;IAEvE,IAAM+G,iBAAiB,GAAGT,YAAY,CAACE,WAAW,CAAC;IACnDK,YAAY,CAACN,oBAAoB,CAACQ,iBAAiB,EAAE,IAAI,CAAC;EAC5D;EAEA5F,oBAAoBA,CAAA,EAAS;IAC3B,IAAI,CAACwF,QAAQ,CAACjH,cAAc,CAAC+G,IAAI,CAAC;EACpC;EAEArF,wBAAwBA,CAAA,EAAS;IAC/B,IAAI,CAACuF,QAAQ,CAACjH,cAAc,CAACgH,QAAQ,CAAC;EACxC;;EAEA;AACF;AACA;AACA;AACA;EACE3F,YAAYA,CACVuE,WAAwB,EACxB0B,aAAmC,EAC7B;IACNxH,GAAG,CAACsF,MAAM,CAAC,SAAS,EAAEQ,WAAW,EAAE0B,aAAa,CAAC;IAEjD,IAAI,CAAC3B,uBAAuB,CAACC,WAAW,CAAC;IACzC;;IAEA;IACA,IAAM;MAAEzC;IAAU,CAAC,GAAGyC,WAAW;IACjC,IAAI;MAAEnF;IAAM,CAAC,GAAGmF,WAAW;IAC3BnF,KAAK,GAAG,IAAI,CAACL,gBAAgB,CAAC+C,SAAS,EAAE1C,KAAK,CAAC;IAE/C,IAAME,MAAM,GAAA4G,aAAA,CAAAA,aAAA,KACP3B,WAAW;MACdnF;IAAK,EACN;IAED,IAAM;MAAE2D;IAAK,CAAC,GAAG,IAAI,CAACjE,MAAM;IAC5B,IAAM+D,KAAK,GACT0B,WAAW,CAAC4B,aAAa,KAAKjH,SAAS,GACnCA,SAAS,GACTZ,WAAW,CAAC8H,YAAY,CAACrD,IAAI,EAAEwB,WAAW,CAAC4B,aAAa,CAAC;IAC/D7H,WAAW,CAAC+H,aAAa,CAAC;MACxBtD,IAAI;MACJzD,MAAM;MACN2G,aAAa;MACbpD,KAAK,EAAEA,KAAK,aAALA,KAAK,cAALA,KAAK,GAAI3D;IAClB,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;AACA;EACEe,gBAAgBA,CAACoC,WAAuB,EAAQ;IAAA,IAAAiE,qBAAA;IAC9C,IAAI,IAAI,CAAC7G,MAAM,CAACR,MAAM,KAAK,CAAC,EAAE;IAC9B,IAAIoD,WAAW,KAAKnD,SAAS,EAAE;MAC7B,IAAI,CAACc,YAAY,CAAC,IAAI,CAACP,MAAM,CAAC,IAAI,CAACA,MAAM,CAACR,MAAM,GAAG,CAAC,CAAC,CAAC;MACtD;IACF;IAEA,IAAMsH,OAAO,IAAAD,qBAAA,GAAGhI,WAAW,CAACwE,iBAAiB,CAC3C,IAAI,CAAChE,MAAM,CAACiE,IAAI,EAChBV,WAAW,CAACmE,SAAS,CAAC,CACxB,CAAC,cAAAF,qBAAA,uBAHeA,qBAAA,CAGbhH,MAAM,CAAC0D,EAAE;IACZ,KAAK,IAAIK,CAAC,GAAG,IAAI,CAAC5D,MAAM,CAACR,MAAM,GAAG,CAAC,EAAEoE,CAAC,IAAI,CAAC,EAAEA,CAAC,IAAI,CAAC,EAAE;MACnD,IAAMkB,WAAW,GAAG,IAAI,CAAC9E,MAAM,CAAC4D,CAAC,CAAC;MAClC,IAAIkB,WAAW,CAAC4B,aAAa,KAAKI,OAAO,EAAE;QACzC,IAAI,CAACvG,YAAY,CAACuE,WAAW,CAAC;QAC9B;MACF;IACF;EACF;EAEAjE,aAAaA,CAACiE,WAAwB,EAAQ;IAC5C9F,GAAG,CAACsF,MAAM,CAAC,UAAU,EAAEQ,WAAW,CAAC;IAEnC,IAAI,CAACD,uBAAuB,CAACC,WAAW,CAAC;IAEzC,IAAI,CAACK,UAAU,CAAC,CAAC;EACnB;EAEArE,YAAYA,CAACkC,OAAe,EAAEJ,WAAsB,EAAQ;IAC1D;IACA;IACA5D,GAAG,CAACsF,MAAM,CAAC,UAAU,EAAEtB,OAAO,CAAC;IAC/B,IAAI,CAACgE,cAAc,CAACpE,WAAW,CAAC;IAChC,IAAI,CAACuC,UAAU,CAAC,CAAC;EACnB;EAEApE,kBAAkBA,CAACwC,EAAU,EAAQ;IACnC,IAAM1D,MAAM,GAAG;MAAE0D;IAAG,CAAC;IACrB,IAAM;MAAED;IAAK,CAAC,GAAG,IAAI,CAACjE,MAAM;IAC5BR,WAAW,CAACoI,cAAc,CAAC3D,IAAI,EAAEzD,MAAM,CAAC;EAC1C;EAEAmH,cAAcA,CAACpE,WAAsB,EAAQ;IAC3C,IAAM;MAAEU;IAAK,CAAC,GAAG,IAAI,CAACjE,MAAM;IAC5B,IAAMQ,MAAM,GAAGhB,WAAW,CAACgE,+BAA+B,CAACD,WAAW,CAAC;IACvE,IAAI/C,MAAM,IAAIf,sBAAsB,CAACe,MAAM,CAAC,EAAE;MAC5C,IAAMqH,gBAAgB,GAAG,IAAI,CAACtH,kBAAkB,CAC9CC,MAAM,CAACwC,SAAS,EAChBxC,MACF,CAAC;MACD,IAAIqH,gBAAgB,IAAI,IAAI,EAAE;QAAA,IAAAC,sBAAA;QAC3BD,gBAAgB,CAAiBR,aAAa,IAAAS,sBAAA,GAC7CtI,WAAW,CAACwE,iBAAiB,CAACC,IAAI,EAAEzD,MAAM,CAAC,cAAAsH,sBAAA,uBAA3CA,sBAAA,CAA6CtH,MAAM,CAAC0D,EAAE;QACxD,IAAI,CAACvD,MAAM,CAAC4B,IAAI,CAACsF,gBAAgB,CAAC;MACpC;IACF;EACF;EAEA/B,UAAUA,CAAA,EAAS;IACjB,IAAM;MAAEnF,MAAM;MAAEF;IAAU,CAAC,GAAG,IAAI;IAClC,IAAI,CAACG,eAAe,CAAC;MACnBD,MAAM,EAAE,CAAC,GAAGA,MAAM,CAAC;MACnBF,SAAS,EAAE,IAAIC,GAAG,CAACD,SAAS;IAC9B,CAAC,CAAC;EACJ;AACF;AAACI,eAAA,CA3aKf,YAAY,4BACgB,GAAG;AA4arC,eAAeA,YAAY"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sourceRoot":"","sources":["../../../node_modules/@deephaven/components/scss/custom.scss","../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss","../src/PanelPlaceholder.scss","../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;AC3LA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGA;EACE,SCPO","file":"PanelPlaceholder.css","sourcesContent":["/* stylelint-disable scss/at-import-no-partial-leading-underscore */\n// Consumers should be able to resolve bootstrap/ to node_modules/bootstrap\n\n//Make bootstrap functions available for use in overrides\n@import 'bootstrap/scss/_functions.scss';\n@import './bootstrap_overrides.scss';\n\n//_variable imports come after bootstrap default overrides,\n// makes all other variables and mixins from bootstrap available\n/// with just importing customer.scss\n@import 'bootstrap/scss/_variables.scss';\n@import 'bootstrap/scss/_mixins.scss';\n\n//New variables come after imports\n@import './new_variables.scss';\n@import './util.scss';\n","// Styling overrides for bootstrap\n@use 'sass:map';\n\n// Override / set color variables\n$red: var(--dh-color-visual-red);\n$orange: var(--dh-color-visual-orange);\n$yellow: var(--dh-color-visual-yellow);\n$green: var(--dh-color-visual-green);\n$blue: var(--dh-color-visual-blue);\n$purple: var(--dh-color-visual-purple);\n\n// Fallback colors are used if theme isn't loaded\n// this is required for error messages if the API doesn't load\n\n//Define our Gray scale\n$gray-100: var(--dh-color-gray-900, #fcfcfa);\n$gray-200: var(--dh-color-gray-800);\n$gray-300: var(--dh-color-gray-700);\n$gray-400: var(--dh-color-gray-600);\n$gray-500: var(--dh-color-gray-500);\n// intentional duplicate, scale doesn't line up otherwise\n// as we have gray-850 and spectrum doesn't and it is needed\n$gray-600: var(--dh-color-gray-500);\n$gray-700: var(--dh-color-gray-400);\n$gray-800: var(--dh-color-gray-300);\n$gray-850: var(--dh-color-gray-200);\n$gray-900: var(--dh-color-gray-75);\n$black: var(--dh-color-black, #1a171a);\n$white: var(--dh-color-white, #f0f0ee);\n\n//Define some UI colors\n$interfacegray: var(--dh-color-content-bg, #2d2a2e);\n$interfaceblue: var(--dh-color-accent-bg);\n$interfacewhite: $white;\n$interfaceblack: $black;\n$content-bg: var(--dh-color-content-bg, #2d2a2e);\n$background: var(--dh-color-bg, #1a171a);\n$foreground: var(--dh-color-fg, #f0f0ee);\n\n// Extend default Bootstrap $grays map\n$grays-custom: (\n '850': $gray-850,\n);\n$grays: () !default;\n$grays: map-merge($grays, $grays-custom);\n\n// Extend default Bootstrap $colors map\n$colors-custom: (\n 'black': $black,\n);\n$colors: () !default;\n$colors: map-merge($colors, $colors-custom);\n\n// Override default Bootstrap $theme-colors map by mapping each key to itself.\n// These will then be re-mapped inside of `button-outline-variant` and\n// `button-outline-variant` mixins in `bootstrap_override_mixins_buttons.scss`\n$theme-colors-self-map: ();\n@each $key\n in (\n 'primary',\n 'secondary',\n 'success',\n 'info',\n 'warning',\n 'danger',\n 'light',\n 'dark'\n )\n{\n $theme-colors-self-map: map.set($theme-colors-self-map, $key, $key);\n}\n$theme-colors: () !default;\n$theme-colors: map-merge($theme-colors, $theme-colors-self-map);\n\n// Used by bootstrap_override_mixins_buttons.scss to map Bootstrap colors to\n// DH semantic colors\n$bootstrap-dh-semantic-map: (\n 'primary': 'accent',\n 'secondary': 'neutral',\n 'success': 'positive',\n 'info': 'info',\n 'warning': 'notice',\n 'danger': 'negative',\n // We shouldn't be using these, but mapping so they work with our custom\n // `color-yiq` mixin. If we find a way to remove $light + $dark that are\n // defined in Bootstrap _variables.scss, we should remove these\n 'light': 'neutral',\n 'dark': 'neutral',\n);\n\n//Set default colors\n$body-bg: $black;\n$body-color: $interfacewhite;\n\n// Set brand colors\n$primary: var(--dh-color-accent-bg);\n$primary-hover: var(--dh-color-accent-hover-bg);\n$primary-dark: var(--dh-color-accent-down-bg);\n$secondary: var(--dh-color-neutral-bg);\n$secondary-hover: var(--dh-color-neutral-hover-bg);\n$success: $green;\n$info: $yellow;\n$warning: $orange;\n$danger: var(--dh-color-negative-bg);\n$danger-hover: var(--dh-color-negative-hover-bg);\n// We really don't want to use $light or $dark variables, but Bootstrap defines\n// them in _variables.scss. Explicitly setting them to ensure we are in control\n// of their values. If we can find a way to remove them, we should\n$light: var(--dh-color-gray-light);\n$dark: var(--dh-color-gray-dark);\n// Bootstrap doesn't define $mid, and we want to move away from this particular\n// semantic. Should be deleted by #1635\n$mid: var(--dh-color-gray-mid);\n\n$semantic-colors: (\n 'primary-hover': $primary-hover,\n 'primary-dark': $primary-dark,\n 'mid': $mid,\n 'content-bg': $interfacegray,\n 'background': $interfaceblack,\n 'foreground': $interfacewhite,\n 'secondary-hover': $secondary-hover,\n 'danger-hover': $danger-hover,\n);\n\n$component-active-bg: $primary;\n$theme-color-interval: 9%;\n$yiq-contrasted-threshold: 180;\n\n// Override fonts\n$font-family-sans-serif:\n 'Fira Sans',\n -apple-system,\n blinkmacsystemfont,\n 'Segoe UI',\n 'Roboto',\n 'Helvetica Neue',\n arial,\n sans-serif; //fira sans then native system ui fallbacks\n$font-family-monospace: 'Fira Mono', menlo, monaco, consolas, 'Liberation Mono',\n 'Courier New', monospace;\n$font-family-base: $font-family-sans-serif;\n\n$headings-font-weight: 400;\n\n//Text overides\n$text-muted: $gray-400;\n\n//Style Selection highlight color\n$text-select-color: var(--dh-color-text-highlight);\n\n//Grid variables, same value as default just making easily accessible\n$grid-gutter-width: 30px;\n\n//Visual Overrides\n$border-radius: 4px;\n$box-shadow: 0 0.1rem 1rem var(--dh-color-dropshadow);\n\n//Override Btn\n$btn-border-radius: 4rem;\n$btn-padding-x: 1.5rem;\n$btn-transition:\n color 0.12s ease-in-out,\n background-color 0.12s ease-in-out,\n border-color 0.12s ease-in-out,\n box-shadow 0.12s ease-in-out; //default 0.15 is too long\n$btn-border-width: 2px;\n$btn-font-weight: var(--spectrum-global-font-weight-bold);\n$btn-line-height: 1.3;\n\n//Override Inputs\n$input-bg: var(--dh-color-input-bg);\n$input-disabled-bg: var(--dh-color-input-disabled-bg);\n$input-color: var(--dh-color-input-fg);\n$input-border-color: var(--dh-color-input-border);\n$input-placeholder-color: var(--dh-color-input-placeholder);\n$input-focus-border-color: var(--dh-color-input-focus-border);\n\n$input-btn-focus-width: 0.2rem;\n$input-btn-focus-color: color-mix(\n in srgb,\n var(--dh-color-accent) 35%,\n transparent\n);\n$input-btn-focus-box-shadow: 0 0 0 $input-btn-focus-width $input-btn-focus-color;\n$input-btn-line-height: 1.3;\n// Bootstrap uses a calc expression to determine the input height (calc(line-height + 2*padding-y + border)).\n// The padding-y value has to be in rem to match units as it is a SASS calc.\n// Using 0.42145rem with 1.3 line height gets us to spectrum's 32px.\n/* stylelint-disable-next-line number-max-precision */\n$input-btn-padding-y: 0.42145rem;\n\n//checkbox\n$custom-control-indicator-bg: var(--dh-color-input-bg);\n$custom-control-indicator-border-color: var(--dh-color-input-border);\n$custom-checkbox-indicator-border-radius: 2px;\n$custom-control-indicator-border-width: 2px;\n$custom-control-indicator-active-bg: var(--dh-color-input-bg);\n$custom-control-indicator-active-border-color: var(--dh-color-input-fg);\n$custom-control-indicator-checked-bg: var(--dh-color-input-fg);\n$custom-control-indicator-checked-color: black; // used as mask fill color\n$custom-checkbox-indicator-indeterminate-bg: var(--dh-color-input-fg);\n$custom-control-indicator-bg-size: 75% 75%;\n$custom-control-indicator-disabled-bg: var(--dh-color-input-disabled-bg);\n$custom-control-indicator-checked-disabled-bg: var(\n --dh-color-input-disabled-bg\n);\n$custom-control-label-disabled-color: var(--dh-color-input-disabled-fg);\n\n// The $custom-select-indicator variable is used by Bootstrap to provide the\n// icon for the select dropdown. Inline svgs can't use CSS variables, so we hard\n// code the color to #929192 (the default value of --dh-color-gray-600). PR #1651\n// overrides this icon altogether for known dropdowns, so technically we may not\n// need this, but it's here in case there are any remaining instances.\n$custom-select-indicator-color: #929192;\n$custom-select-bg: var(--dh-color-selector-bg);\n$custom-select-bg-size: 16px 16px;\n//dhSort icon encoded\n$custom-select-indicator: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$custom-select-indicator-color}' d='M4 7l-.4-.8 4-3.7h.8l4 3.7-.4.8H4zm0 2l-.4.8 4 3.7h.8l4-3.7L12 9H4z'/%3E%3C/svg%3E\"),\n '#',\n '%23'\n);\n$custom-select-focus-box-shadow: $input-btn-focus-box-shadow;\n$custom-select-disabled-color: $gray-500;\n$custom-select-disabled-bg: $gray-800;\n\n//modal\n$modal-content-bg: $content-bg;\n$modal-content-border-width: 0;\n$modal-md: 550px;\n$close-color: var(--dh-color-text);\n$close-text-shadow: none;\n\n// Toast notification\n$toast-bg: var(--dh-color-accent-100);\n$toast-color: var(--dh-color-text);\n$toast-error-bg: var(--dh-color-negative-bg);\n$toast-error-color: var(--dh-color-text);\n\n//tooltips\n$tooltip-bg: var(--dh-color-tooltip-bg);\n$tooltip-color: var(--dh-color-tooltip-fg);\n$tooltip-box-shadow: 0 0.1rem 1.5rem 0.1rem var(--dh-color-tooltip-box-shadow);\n\n//drowdowns\n$dropdown-bg: $gray-600;\n$dropdown-link-color: $foreground;\n$dropdown-link-hover-color: $foreground;\n$dropdown-link-hover-bg: var(--dh-color-item-list-hover-bg);\n$dropdown-divider-bg: $gray-700;\n\n//context menus\n$contextmenu-bg: var(--dh-color-popover-bg);\n$contextmenu-color: var(--dh-color-text);\n$contextmenu-disabled-color: var(--dh-color-input-disabled-fg);\n$contextmenu-keyboard-selected-bg: var(--dh-color-keyboard-selected-bg);\n$contextmenu-selected-bg: var(--dh-color-item-list-hover-bg);\n$contextmenu-selected-color: var(--dh-color-item-list-selected-fg);\n\n//hr\n$hr-border-color: var(--dh-color-hr);\n\n//links\n$link-color: $gray-400;\n$link-hover-color: $foreground;\n\n//progress-bar\n$progress-bg: $gray-600;\n$progress-border-radius: 1rem;\n\n// Set global options\n$enable-shadows: false;\n$enable-gradients: false;\n$enable-print-styles: false; //I don't think anyone should expect to \"print\" this app.\n\n// Transition times\n$transition: 0.15s;\n$transition-mid: 0.2s;\n$transition-long: 0.3s;\n$transition-slow: 0.6s;\n\n//form-validation icon, uses vsWarning icon encoded here as svg\n$form-feedback-icon-invalid-color: $danger;\n$form-feedback-icon-invalid: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cg fill='none'%3E%3Cg fill='#{$form-feedback-icon-invalid-color}'%3E%3Cpath d='M7.56 1h.88l6.54 12.26-.44.74H1.44L1 13.26 7.56 1zM8 2.28 2.28 13H13.7L8 2.28zM8.625 12v-1h-1.25v1h1.25zm-1.25-2V6h1.25v4h-1.25z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E \"),\n '#',\n '%23'\n);\n\n// This section of variables is not consumed directly by DH, but they need to be\n// defined for sass to compile _variables\n$table-dark-bg: $gray-800;\n$table-dark-accent-bg: var(--dh-color-highlight-hover);\n$table-dark-hover-bg: var(--dh-color-highlight-active);\n$table-dark-border-color: $gray-700;\n$popover-bg: var(--dh-color-tooltip-bg);\n$popover-border-color: var(--dh-color-overlay-modal-bg);\n$popover-header-bg: #000;\n$popover-arrow-outer-color: var(--dh-color-dropshadow);\n$custom-range-thumb-active-bg: var(--dh-color-accent-1100);\n","@import '@deephaven/components/scss/custom.scss';\n\n.panel-placeholder {\n display: flex;\n flex-direction: column;\n justify-content: center;\n min-height: 100%;\n max-height: 100%;\n text-align: center;\n overflow: hidden;\n\n // add padding on an inner wrapper so it is included in max height of parent\n div {\n padding: $spacer-3;\n }\n}\n","@use 'sass:math';\n\n//Set of spacer variables from the spacer map\n$spacer-0: map-get($spacers, 0); //0\n$spacer-1: map-get($spacers, 1);\n$spacer-2: map-get($spacers, 2);\n$spacer-3: map-get($spacers, 3);\n$spacer-4: map-get($spacers, 4);\n$spacer-5: map-get($spacers, 5);\n\n//Marching Ants for golden layout dropzone and drag and drop\n//top bottom, left right.\n//create 4 background images that are 50% color 1, 50% color 2 using graidents, two veritical, two horizontal\n//size them to ant-size and thickness\n//position those images along the egdes and make top/bottom repeat-x and left/right repeat-y\n//then offest each of those background positions by ant-size in animation to make them march.\n$ant-size: 8px;\n$ant-thickness: 1px;\n\n@mixin ants-base($color-1: black, $color-2: white) {\n background-image: linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%);\n background-size:\n $ant-size $ant-thickness,\n $ant-size $ant-thickness,\n $ant-thickness $ant-size,\n $ant-thickness $ant-size;\n background-position:\n 0 top,\n 0 bottom,\n left 0,\n right 0;\n background-repeat: repeat-x, repeat-x, repeat-y, repeat-y;\n animation: march 0.5s;\n animation-timing-function: linear;\n animation-iteration-count: infinite;\n}\n\n@mixin drag-stack($pseudo-element) {\n &::#{$pseudo-element} {\n content: ' ';\n background: $primary;\n box-shadow: $box-shadow;\n border-radius: $border-radius;\n position: absolute;\n height: 100%;\n width: 100%;\n @content;\n }\n}\n\n$focus-bg-transparency: 12%;\n$hover-bg-transparency: 14%;\n$active-bg-transparency: 28%;\n$exception-transparency: 28%;\n"]}
|
|
1
|
+
{"version":3,"sourceRoot":"","sources":["../../../node_modules/@deephaven/components/scss/custom.scss","../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss","../src/PanelPlaceholder.scss","../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;AC3LA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGA;EACE,SCPO","file":"PanelPlaceholder.css","sourcesContent":["/* stylelint-disable scss/at-import-no-partial-leading-underscore */\n// Consumers should be able to resolve bootstrap/ to node_modules/bootstrap\n\n//Make bootstrap functions available for use in overrides\n@import 'bootstrap/scss/_functions.scss';\n@import './bootstrap_overrides.scss';\n\n//_variable imports come after bootstrap default overrides,\n// makes all other variables and mixins from bootstrap available\n/// with just importing customer.scss\n@import 'bootstrap/scss/_variables.scss';\n@import 'bootstrap/scss/_mixins.scss';\n\n//New variables come after imports\n@import './new_variables.scss';\n@import './util.scss';\n","// Styling overrides for bootstrap\n@use 'sass:map';\n\n// Override / set color variables\n$red: var(--dh-color-visual-red);\n$orange: var(--dh-color-visual-orange);\n$yellow: var(--dh-color-visual-yellow);\n$green: var(--dh-color-visual-green);\n$blue: var(--dh-color-visual-blue);\n$purple: var(--dh-color-visual-purple);\n\n// Fallback colors are used if theme isn't loaded\n// this is required for error messages if the API doesn't load\n\n//Define our Gray scale\n$gray-100: var(--dh-color-gray-900, #fcfcfa);\n$gray-200: var(--dh-color-gray-800);\n$gray-300: var(--dh-color-gray-700);\n$gray-400: var(--dh-color-gray-600);\n$gray-500: var(--dh-color-gray-500);\n// intentional duplicate, scale doesn't line up otherwise\n// as we have gray-850 and spectrum doesn't and it is needed\n$gray-600: var(--dh-color-gray-500);\n$gray-700: var(--dh-color-gray-400);\n$gray-800: var(--dh-color-gray-300);\n$gray-850: var(--dh-color-gray-200);\n$gray-900: var(--dh-color-gray-75);\n$black: var(--dh-color-black, #1a171a);\n$white: var(--dh-color-white, #f0f0ee);\n\n//Define some UI colors\n$interfacegray: var(--dh-color-content-bg, #2d2a2e);\n$interfaceblue: var(--dh-color-accent-bg);\n$interfacewhite: $white;\n$interfaceblack: $black;\n$content-bg: var(--dh-color-content-bg, #2d2a2e);\n$background: var(--dh-color-bg, #1a171a);\n$foreground: var(--dh-color-fg, #f0f0ee);\n\n// Extend default Bootstrap $grays map\n$grays-custom: (\n '850': $gray-850,\n);\n$grays: () !default;\n$grays: map-merge($grays, $grays-custom);\n\n// Extend default Bootstrap $colors map\n$colors-custom: (\n 'black': $black,\n);\n$colors: () !default;\n$colors: map-merge($colors, $colors-custom);\n\n// Override default Bootstrap $theme-colors map by mapping each key to itself.\n// These will then be re-mapped inside of `button-outline-variant` and\n// `button-outline-variant` mixins in `bootstrap_override_mixins_buttons.scss`\n$theme-colors-self-map: ();\n@each $key\n in (\n 'primary',\n 'secondary',\n 'success',\n 'info',\n 'warning',\n 'danger',\n 'light',\n 'dark'\n )\n{\n $theme-colors-self-map: map.set($theme-colors-self-map, $key, $key);\n}\n$theme-colors: () !default;\n$theme-colors: map-merge($theme-colors, $theme-colors-self-map);\n\n// Used by bootstrap_override_mixins_buttons.scss to map Bootstrap colors to\n// DH semantic colors\n$bootstrap-dh-semantic-map: (\n 'primary': 'accent',\n 'secondary': 'neutral',\n 'success': 'positive',\n 'info': 'info',\n 'warning': 'notice',\n 'danger': 'negative',\n // We shouldn't be using these, but mapping so they work with our custom\n // `color-yiq` mixin. If we find a way to remove $light + $dark that are\n // defined in Bootstrap _variables.scss, we should remove these\n 'light': 'neutral',\n 'dark': 'neutral',\n);\n\n//Set default colors\n$body-bg: $black;\n$body-color: $interfacewhite;\n\n// Set brand colors\n$primary: var(--dh-color-accent-bg);\n$primary-hover: var(--dh-color-accent-hover-bg);\n$primary-dark: var(--dh-color-accent-down-bg);\n$secondary: var(--dh-color-neutral-bg);\n$secondary-hover: var(--dh-color-neutral-hover-bg);\n$success: $green;\n$info: $yellow;\n$warning: $orange;\n$danger: var(--dh-color-negative-bg);\n$danger-hover: var(--dh-color-negative-hover-bg);\n// We really don't want to use $light or $dark variables, but Bootstrap defines\n// them in _variables.scss. Explicitly setting them to ensure we are in control\n// of their values. If we can find a way to remove them, we should\n$light: var(--dh-color-gray-light);\n$dark: var(--dh-color-gray-dark);\n// Bootstrap doesn't define $mid, and we want to move away from this particular\n// semantic. Should be deleted by #1635\n$mid: var(--dh-color-gray-mid);\n\n$semantic-colors: (\n 'primary-hover': $primary-hover,\n 'primary-dark': $primary-dark,\n 'mid': $mid,\n 'content-bg': $interfacegray,\n 'background': $interfaceblack,\n 'foreground': $interfacewhite,\n 'secondary-hover': $secondary-hover,\n 'danger-hover': $danger-hover,\n);\n\n$component-active-bg: $primary;\n$theme-color-interval: 9%;\n$yiq-contrasted-threshold: 180;\n\n// Override fonts\n$font-family-sans-serif:\n 'Fira Sans',\n -apple-system,\n blinkmacsystemfont,\n 'Segoe UI',\n 'Roboto',\n 'Helvetica Neue',\n arial,\n sans-serif; //fira sans then native system ui fallbacks\n$font-family-monospace: 'Fira Mono', menlo, monaco, consolas, 'Liberation Mono',\n 'Courier New', monospace;\n$font-family-base: $font-family-sans-serif;\n\n$headings-font-weight: 400;\n\n//Text overides\n$text-muted: $gray-400;\n\n//Style Selection highlight color\n$text-select-color: var(--dh-color-text-highlight);\n\n//Grid variables, same value as default just making easily accessible\n$grid-gutter-width: 30px;\n\n//Visual Overrides\n$border-radius: 4px;\n$box-shadow: 0 0.1rem 1rem var(--dh-color-dropshadow);\n\n//Override Btn\n$btn-border-radius: 4rem;\n$btn-padding-x: 1.5rem;\n$btn-transition:\n color 0.12s ease-in-out,\n background-color 0.12s ease-in-out,\n border-color 0.12s ease-in-out,\n box-shadow 0.12s ease-in-out; //default 0.15 is too long\n$btn-border-width: 2px;\n$btn-font-weight: var(--spectrum-global-font-weight-bold);\n$btn-line-height: 1.3;\n\n//Override Inputs\n$input-bg: var(--dh-color-input-bg);\n$input-disabled-bg: var(--dh-color-input-disabled-bg);\n$input-color: var(--dh-color-input-fg);\n$input-border-color: var(--dh-color-input-border);\n$input-placeholder-color: var(--dh-color-input-placeholder);\n$input-focus-border-color: var(--dh-color-input-focus-border);\n\n$input-btn-focus-width: 0.2rem;\n$input-btn-focus-color: color-mix(\n in srgb,\n var(--dh-color-accent) 35%,\n transparent\n);\n$input-btn-focus-box-shadow: 0 0 0 $input-btn-focus-width $input-btn-focus-color;\n$input-btn-line-height: 1.3;\n// Bootstrap uses a calc expression to determine the input height (calc(line-height + 2*padding-y + border)).\n// The padding-y value has to be in rem to match units as it is a SASS calc.\n// Using 0.42145rem with 1.3 line height gets us to spectrum's 32px.\n/* stylelint-disable-next-line number-max-precision */\n$input-btn-padding-y: 0.42145rem;\n\n//checkbox\n$custom-control-indicator-bg: var(--dh-color-input-bg);\n$custom-control-indicator-border-color: var(--dh-color-input-border);\n$custom-checkbox-indicator-border-radius: 2px;\n$custom-control-indicator-border-width: 2px;\n$custom-control-indicator-active-bg: var(--dh-color-input-bg);\n$custom-control-indicator-active-border-color: var(--dh-color-input-fg);\n$custom-control-indicator-checked-bg: var(--dh-color-input-fg);\n$custom-control-indicator-checked-color: black; // used as mask fill color\n$custom-checkbox-indicator-indeterminate-bg: var(--dh-color-input-fg);\n$custom-control-indicator-bg-size: 75% 75%;\n$custom-control-indicator-disabled-bg: var(--dh-color-input-disabled-bg);\n$custom-control-indicator-checked-disabled-bg: var(\n --dh-color-input-disabled-bg\n);\n$custom-control-label-disabled-color: var(--dh-color-input-disabled-fg);\n\n// The $custom-select-indicator variable is used by Bootstrap to provide the\n// icon for the select dropdown. Inline svgs can't use CSS variables, so we hard\n// code the color to #929192 (the default value of --dh-color-gray-600). PR #1651\n// overrides this icon altogether for known dropdowns, so technically we may not\n// need this, but it's here in case there are any remaining instances.\n$custom-select-indicator-color: #929192;\n$custom-select-bg: var(--dh-color-selector-bg);\n$custom-select-bg-size: 16px 16px;\n//dhSort icon encoded\n$custom-select-indicator: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$custom-select-indicator-color}' d='M4 7l-.4-.8 4-3.7h.8l4 3.7-.4.8H4zm0 2l-.4.8 4 3.7h.8l4-3.7L12 9H4z'/%3E%3C/svg%3E\"),\n '#',\n '%23'\n);\n$custom-select-focus-box-shadow: $input-btn-focus-box-shadow;\n$custom-select-disabled-color: $gray-500;\n$custom-select-disabled-bg: $gray-800;\n\n//modal\n$modal-content-bg: $content-bg;\n$modal-content-border-width: 0;\n$modal-md: 550px;\n$close-color: var(--dh-color-text);\n$close-text-shadow: none;\n\n// Toast notification\n$toast-bg: var(--dh-color-accent-100);\n$toast-color: var(--dh-color-text);\n$toast-error-bg: var(--dh-color-negative-bg);\n$toast-error-color: var(--dh-color-text);\n\n//tooltips\n$tooltip-bg: var(--dh-color-tooltip-bg);\n$tooltip-color: var(--dh-color-tooltip-fg);\n$tooltip-box-shadow: 0 0.1rem 1.5rem 0.1rem var(--dh-color-tooltip-box-shadow);\n\n//drowdowns\n$dropdown-bg: $gray-600;\n$dropdown-link-color: $foreground;\n$dropdown-link-hover-color: $foreground;\n$dropdown-link-hover-bg: var(--dh-color-item-list-hover-bg);\n$dropdown-divider-bg: $gray-700;\n\n//context menus\n$contextmenu-bg: var(--dh-color-popover-bg);\n$contextmenu-color: var(--dh-color-text);\n$contextmenu-disabled-color: var(--dh-color-text-disabled);\n$contextmenu-keyboard-selected-bg: var(--dh-color-keyboard-selected-bg);\n$contextmenu-selected-bg: var(--dh-color-item-list-hover-bg);\n$contextmenu-selected-color: var(--dh-color-item-list-selected-fg);\n\n//hr\n$hr-border-color: var(--dh-color-hr);\n\n//links\n$link-color: $gray-400;\n$link-hover-color: $foreground;\n\n//progress-bar\n$progress-bg: $gray-600;\n$progress-border-radius: 1rem;\n\n// Set global options\n$enable-shadows: false;\n$enable-gradients: false;\n$enable-print-styles: false; //I don't think anyone should expect to \"print\" this app.\n\n// Transition times\n$transition: 0.15s;\n$transition-mid: 0.2s;\n$transition-long: 0.3s;\n$transition-slow: 0.6s;\n\n//form-validation icon, uses vsWarning icon encoded here as svg\n$form-feedback-icon-invalid-color: $danger;\n$form-feedback-icon-invalid: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cg fill='none'%3E%3Cg fill='#{$form-feedback-icon-invalid-color}'%3E%3Cpath d='M7.56 1h.88l6.54 12.26-.44.74H1.44L1 13.26 7.56 1zM8 2.28 2.28 13H13.7L8 2.28zM8.625 12v-1h-1.25v1h1.25zm-1.25-2V6h1.25v4h-1.25z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E \"),\n '#',\n '%23'\n);\n\n// This section of variables is not consumed directly by DH, but they need to be\n// defined for sass to compile _variables\n$table-dark-bg: $gray-800;\n$table-dark-accent-bg: var(--dh-color-highlight-hover);\n$table-dark-hover-bg: var(--dh-color-highlight-active);\n$table-dark-border-color: $gray-700;\n$popover-bg: var(--dh-color-tooltip-bg);\n$popover-border-color: var(--dh-color-overlay-modal-bg);\n$popover-header-bg: #000;\n$popover-arrow-outer-color: var(--dh-color-dropshadow);\n$custom-range-thumb-active-bg: var(--dh-color-accent-1100);\n","@import '@deephaven/components/scss/custom.scss';\n\n.panel-placeholder {\n display: flex;\n flex-direction: column;\n justify-content: center;\n min-height: 100%;\n max-height: 100%;\n text-align: center;\n overflow: hidden;\n\n // add padding on an inner wrapper so it is included in max height of parent\n div {\n padding: $spacer-3;\n }\n}\n","@use 'sass:math';\n\n//Set of spacer variables from the spacer map\n$spacer-0: map-get($spacers, 0); //0\n$spacer-1: map-get($spacers, 1);\n$spacer-2: map-get($spacers, 2);\n$spacer-3: map-get($spacers, 3);\n$spacer-4: map-get($spacers, 4);\n$spacer-5: map-get($spacers, 5);\n\n//Marching Ants for golden layout dropzone and drag and drop\n//top bottom, left right.\n//create 4 background images that are 50% color 1, 50% color 2 using graidents, two veritical, two horizontal\n//size them to ant-size and thickness\n//position those images along the egdes and make top/bottom repeat-x and left/right repeat-y\n//then offest each of those background positions by ant-size in animation to make them march.\n$ant-size: 8px;\n$ant-thickness: 1px;\n\n@mixin ants-base($color-1: black, $color-2: white) {\n background-image: linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%);\n background-size:\n $ant-size $ant-thickness,\n $ant-size $ant-thickness,\n $ant-thickness $ant-size,\n $ant-thickness $ant-size;\n background-position:\n 0 top,\n 0 bottom,\n left 0,\n right 0;\n background-repeat: repeat-x, repeat-x, repeat-y, repeat-y;\n animation: march 0.5s;\n animation-timing-function: linear;\n animation-iteration-count: infinite;\n}\n\n@mixin drag-stack($pseudo-element) {\n &::#{$pseudo-element} {\n content: ' ';\n background: $primary;\n box-shadow: $box-shadow;\n border-radius: $border-radius;\n position: absolute;\n height: 100%;\n width: 100%;\n @content;\n }\n}\n\n$focus-bg-transparency: 12%;\n$hover-bg-transparency: 14%;\n$active-bg-transparency: 28%;\n$exception-transparency: 28%;\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PanelPlaceholder.js","names":["React","LayoutUtils","jsxs","_jsxs","jsx","_jsx","PanelPlaceholder","forwardRef","props","ref","component","getComponentNameFromPanel","className","children","displayName"],"sources":["../src/PanelPlaceholder.tsx"],"sourcesContent":["import React, { type ForwardedRef } from 'react';\nimport './PanelPlaceholder.scss';\nimport LayoutUtils from './layout/LayoutUtils';\nimport { type PanelProps } from './DashboardPlugin';\n\n/**\n * Displays a placeholder for unregistered panel types.\n */\nconst PanelPlaceholder = React.forwardRef(\n (props: PanelProps, ref: ForwardedRef<HTMLDivElement>) => {\n const component = LayoutUtils.getComponentNameFromPanel({ props });\n return (\n <div ref={ref} className=\"panel-placeholder\">\n <div>Component "{component}" is not registered.</div>\n </div>\n );\n }\n);\n\nPanelPlaceholder.displayName = 'PanelPlaceholder';\n\nexport default PanelPlaceholder;\n"],"mappings":"AAAA,OAAOA,KAAK,MAA6B,OAAO;AAAC;AAAA,OAE1CC,WAAW;AAAA,SAAAC,IAAA,IAAAC,KAAA;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAGlB;AACA;AACA;AACA,IAAMC,gBAAgB,gBAAGN,KAAK,CAACO,UAAU,CACvC,CAACC,KAAiB,EAAEC,GAAiC,KAAK;EACxD,IAAMC,SAAS,GAAGT,WAAW,CAACU,yBAAyB,CAAC;IAAEH;EAAM,CAAC,CAAC;EAClE,oBACEH,IAAA;IAAKI,GAAG,EAAEA,GAAI;IAACG,SAAS,EAAC,mBAAmB;IAAAC,QAAA,eAC1CV,KAAA;MAAAU,QAAA,GAAK,cAAgB,EAACH,SAAS,EAAC,uBAAyB;IAAA,CAAK;EAAC,CAC5D,CAAC;AAEV,CACF,CAAC;AAEDJ,gBAAgB,CAACQ,WAAW,GAAG,kBAAkB;AAEjD,eAAeR,gBAAgB"
|
|
1
|
+
{"version":3,"file":"PanelPlaceholder.js","names":["React","LayoutUtils","jsxs","_jsxs","jsx","_jsx","PanelPlaceholder","forwardRef","props","ref","component","getComponentNameFromPanel","className","children","displayName"],"sources":["../src/PanelPlaceholder.tsx"],"sourcesContent":["import React, { type ForwardedRef } from 'react';\nimport './PanelPlaceholder.scss';\nimport LayoutUtils from './layout/LayoutUtils';\nimport { type PanelProps } from './DashboardPlugin';\n\n/**\n * Displays a placeholder for unregistered panel types.\n */\nconst PanelPlaceholder = React.forwardRef(\n (props: PanelProps, ref: ForwardedRef<HTMLDivElement>) => {\n const component = LayoutUtils.getComponentNameFromPanel({ props });\n return (\n <div ref={ref} className=\"panel-placeholder\">\n <div>Component "{component}" is not registered.</div>\n </div>\n );\n }\n);\n\nPanelPlaceholder.displayName = 'PanelPlaceholder';\n\nexport default PanelPlaceholder;\n"],"mappings":"AAAA,OAAOA,KAAK,MAA6B,OAAO;AAAC;AAAA,OAE1CC,WAAW;AAAA,SAAAC,IAAA,IAAAC,KAAA;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAGlB;AACA;AACA;AACA,IAAMC,gBAAgB,gBAAGN,KAAK,CAACO,UAAU,CACvC,CAACC,KAAiB,EAAEC,GAAiC,KAAK;EACxD,IAAMC,SAAS,GAAGT,WAAW,CAACU,yBAAyB,CAAC;IAAEH;EAAM,CAAC,CAAC;EAClE,oBACEH,IAAA;IAAKI,GAAG,EAAEA,GAAI;IAACG,SAAS,EAAC,mBAAmB;IAAAC,QAAA,eAC1CV,KAAA;MAAAU,QAAA,GAAK,cAAgB,EAACH,SAAS,EAAC,uBAAyB;IAAA,CAAK;EAAC,CAC5D,CAAC;AAEV,CACF,CAAC;AAEDJ,gBAAgB,CAACQ,WAAW,GAAG,kBAAkB;AAEjD,eAAeR,gBAAgB"}
|
package/dist/RenameDialog.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RenameDialog.js","names":["React","PureComponent","classNames","Button","Popper","jsxs","_jsxs","jsx","_jsx","RenameDialog","constructor","props","_defineProperty","handleRenameDialogOpened","bind","handleRenameInputChange","handleRenameCancel","handleRenameSubmit","renameInputRef","createRef","value","state","valueWasValidated","componentDidUpdate","prevProps","isShown","prevIsShown","resetState","setState","_this$renameInputRef","_this$renameInputRef$","current","focus","event","target","onCancel","stopPropagation","preventDefault","newTitle","trim","undefined","onSubmit","renderRenameDialog","isShared","isOwner","itemType","className","noValidate","role","onMouseDown","onMouseUp","children","htmlFor","concat","type","id","ref","onChange","required","kind","onClick","render","onEntered","onExited","options","placement","interactive","closeOnBlur"],"sources":["../src/RenameDialog.tsx"],"sourcesContent":["import React, {\n type ChangeEvent,\n type FormEvent,\n PureComponent,\n type ReactElement,\n type RefObject,\n} from 'react';\nimport classNames from 'classnames';\nimport { Button, Popper } from '@deephaven/components';\n\ninterface RenameDialogProps {\n isShared: boolean;\n isOwner: boolean;\n isShown: boolean;\n itemType: string;\n onSubmit: (title: string) => void;\n onCancel: () => void;\n value?: string | null;\n}\n\ninterface RenameDialogState {\n value?: string | null;\n valueWasValidated: boolean;\n}\n\nexport default class RenameDialog extends PureComponent<\n RenameDialogProps,\n RenameDialogState\n> {\n static defaultProps = {\n isShared: false,\n isOwner: true,\n itemType: 'Item',\n value: '',\n };\n\n constructor(props: RenameDialogProps) {\n super(props);\n\n this.handleRenameDialogOpened = this.handleRenameDialogOpened.bind(this);\n this.handleRenameInputChange = this.handleRenameInputChange.bind(this);\n this.handleRenameCancel = this.handleRenameCancel.bind(this);\n this.handleRenameSubmit = this.handleRenameSubmit.bind(this);\n\n this.renameInputRef = React.createRef();\n\n const { value } = props;\n\n this.state = {\n value,\n valueWasValidated: false,\n };\n }\n\n componentDidUpdate(prevProps: RenameDialogProps): void {\n const { isShown: prevIsShown } = prevProps;\n const { isShown } = this.props;\n // Reset the state on dialog shown and not on the `value` prop change\n // so the input keeps the internal value while the dialog is open.\n // Useful in case the `value` prop update is triggered externally\n // i.e. by someone else renaming the same shared dashboard\n if (isShown && !prevIsShown) {\n this.resetState();\n }\n }\n\n renameInputRef: RefObject<HTMLInputElement>;\n\n resetState(): void {\n const { value } = this.props;\n this.setState({ value, valueWasValidated: false });\n }\n\n handleRenameDialogOpened(): void {\n this.renameInputRef?.current?.focus();\n }\n\n handleRenameInputChange(event: ChangeEvent<HTMLInputElement>): void {\n this.setState({ value: event.target.value });\n }\n\n handleRenameCancel(): void {\n const { onCancel } = this.props;\n onCancel();\n }\n\n handleRenameSubmit(event: FormEvent<HTMLFormElement>): void {\n event.stopPropagation();\n event.preventDefault();\n const { value } = this.state;\n const newTitle = value?.trim();\n if (newTitle !== undefined && newTitle !== '') {\n const { onSubmit } = this.props;\n onSubmit(newTitle);\n } else {\n this.setState({ value: newTitle, valueWasValidated: true });\n }\n }\n\n renderRenameDialog(): ReactElement {\n const { isShared, isOwner, itemType } = this.props;\n const { value, valueWasValidated } = this.state;\n\n return (\n <form\n className={classNames('p-3', { 'was-validated': valueWasValidated })}\n onSubmit={this.handleRenameSubmit}\n noValidate\n role=\"presentation\"\n onMouseDown={event => {\n // block events in the NewTabScreen ItemList\n event.stopPropagation();\n }}\n onMouseUp={event => {\n event.stopPropagation();\n }}\n >\n <div className=\"form-group\">\n <label htmlFor={`rename-dialog-${itemType}-input`}>\n Rename {itemType}\n </label>\n <input\n type=\"text\"\n className=\"form-control\"\n id={`rename-dialog-${itemType}-input`}\n value={value ?? undefined}\n ref={this.renameInputRef}\n onChange={this.handleRenameInputChange}\n required\n />\n <div className=\"invalid-feedback\">\n {itemType} name cannot be empty\n </div>\n {(isShared || !isOwner) && (\n <div className=\"pt-2\">\n Renaming this {itemType} will rename for all users.\n </div>\n )}\n </div>\n\n <div className=\"text-right\">\n <Button\n kind=\"secondary\"\n className=\"mr-2\"\n onClick={this.handleRenameCancel}\n >\n Cancel\n </Button>\n <Button kind=\"primary\" type=\"submit\">\n Rename\n </Button>\n </div>\n </form>\n );\n }\n\n render(): ReactElement {\n const { isShown, onCancel } = this.props;\n return (\n <Popper\n isShown={isShown}\n onEntered={this.handleRenameDialogOpened}\n onExited={onCancel}\n options={{\n placement: 'bottom',\n }}\n interactive\n closeOnBlur\n >\n {this.renderRenameDialog()}\n </Popper>\n );\n }\n}\n"],"mappings":"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"
|
|
1
|
+
{"version":3,"file":"RenameDialog.js","names":["React","PureComponent","classNames","Button","Popper","jsxs","_jsxs","jsx","_jsx","RenameDialog","constructor","props","_defineProperty","handleRenameDialogOpened","bind","handleRenameInputChange","handleRenameCancel","handleRenameSubmit","renameInputRef","createRef","value","state","valueWasValidated","componentDidUpdate","prevProps","isShown","prevIsShown","resetState","setState","_this$renameInputRef","_this$renameInputRef$","current","focus","event","target","onCancel","stopPropagation","preventDefault","newTitle","trim","undefined","onSubmit","renderRenameDialog","isShared","isOwner","itemType","className","noValidate","role","onMouseDown","onMouseUp","children","htmlFor","concat","type","id","ref","onChange","required","kind","onClick","render","onEntered","onExited","options","placement","interactive","closeOnBlur"],"sources":["../src/RenameDialog.tsx"],"sourcesContent":["import React, {\n type ChangeEvent,\n type FormEvent,\n PureComponent,\n type ReactElement,\n type RefObject,\n} from 'react';\nimport classNames from 'classnames';\nimport { Button, Popper } from '@deephaven/components';\n\ninterface RenameDialogProps {\n isShared: boolean;\n isOwner: boolean;\n isShown: boolean;\n itemType: string;\n onSubmit: (title: string) => void;\n onCancel: () => void;\n value?: string | null;\n}\n\ninterface RenameDialogState {\n value?: string | null;\n valueWasValidated: boolean;\n}\n\nexport default class RenameDialog extends PureComponent<\n RenameDialogProps,\n RenameDialogState\n> {\n static defaultProps = {\n isShared: false,\n isOwner: true,\n itemType: 'Item',\n value: '',\n };\n\n constructor(props: RenameDialogProps) {\n super(props);\n\n this.handleRenameDialogOpened = this.handleRenameDialogOpened.bind(this);\n this.handleRenameInputChange = this.handleRenameInputChange.bind(this);\n this.handleRenameCancel = this.handleRenameCancel.bind(this);\n this.handleRenameSubmit = this.handleRenameSubmit.bind(this);\n\n this.renameInputRef = React.createRef();\n\n const { value } = props;\n\n this.state = {\n value,\n valueWasValidated: false,\n };\n }\n\n componentDidUpdate(prevProps: RenameDialogProps): void {\n const { isShown: prevIsShown } = prevProps;\n const { isShown } = this.props;\n // Reset the state on dialog shown and not on the `value` prop change\n // so the input keeps the internal value while the dialog is open.\n // Useful in case the `value` prop update is triggered externally\n // i.e. by someone else renaming the same shared dashboard\n if (isShown && !prevIsShown) {\n this.resetState();\n }\n }\n\n renameInputRef: RefObject<HTMLInputElement>;\n\n resetState(): void {\n const { value } = this.props;\n this.setState({ value, valueWasValidated: false });\n }\n\n handleRenameDialogOpened(): void {\n this.renameInputRef?.current?.focus();\n }\n\n handleRenameInputChange(event: ChangeEvent<HTMLInputElement>): void {\n this.setState({ value: event.target.value });\n }\n\n handleRenameCancel(): void {\n const { onCancel } = this.props;\n onCancel();\n }\n\n handleRenameSubmit(event: FormEvent<HTMLFormElement>): void {\n event.stopPropagation();\n event.preventDefault();\n const { value } = this.state;\n const newTitle = value?.trim();\n if (newTitle !== undefined && newTitle !== '') {\n const { onSubmit } = this.props;\n onSubmit(newTitle);\n } else {\n this.setState({ value: newTitle, valueWasValidated: true });\n }\n }\n\n renderRenameDialog(): ReactElement {\n const { isShared, isOwner, itemType } = this.props;\n const { value, valueWasValidated } = this.state;\n\n return (\n <form\n className={classNames('p-3', { 'was-validated': valueWasValidated })}\n onSubmit={this.handleRenameSubmit}\n noValidate\n role=\"presentation\"\n onMouseDown={event => {\n // block events in the NewTabScreen ItemList\n event.stopPropagation();\n }}\n onMouseUp={event => {\n event.stopPropagation();\n }}\n >\n <div className=\"form-group\">\n <label htmlFor={`rename-dialog-${itemType}-input`}>\n Rename {itemType}\n </label>\n <input\n type=\"text\"\n className=\"form-control\"\n id={`rename-dialog-${itemType}-input`}\n value={value ?? undefined}\n ref={this.renameInputRef}\n onChange={this.handleRenameInputChange}\n required\n />\n <div className=\"invalid-feedback\">\n {itemType} name cannot be empty\n </div>\n {(isShared || !isOwner) && (\n <div className=\"pt-2\">\n Renaming this {itemType} will rename for all users.\n </div>\n )}\n </div>\n\n <div className=\"text-right\">\n <Button\n kind=\"secondary\"\n className=\"mr-2\"\n onClick={this.handleRenameCancel}\n >\n Cancel\n </Button>\n <Button kind=\"primary\" type=\"submit\">\n Rename\n </Button>\n </div>\n </form>\n );\n }\n\n render(): ReactElement {\n const { isShown, onCancel } = this.props;\n return (\n <Popper\n isShown={isShown}\n onEntered={this.handleRenameDialogOpened}\n onExited={onCancel}\n options={{\n placement: 'bottom',\n }}\n interactive\n closeOnBlur\n >\n {this.renderRenameDialog()}\n </Popper>\n );\n }\n}\n"],"mappings":";;;AAAA,OAAOA,KAAK,IAGVC,aAAa,QAGR,OAAO;AACd,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,EAAEC,MAAM,QAAQ,uBAAuB;AAAC,SAAAC,IAAA,IAAAC,KAAA;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAiBvD,eAAe,MAAMC,YAAY,SAASR,aAAa,CAGrD;EAQAS,WAAWA,CAACC,KAAwB,EAAE;IACpC,KAAK,CAACA,KAAK,CAAC;IAACC,eAAA;IAEb,IAAI,CAACC,wBAAwB,GAAG,IAAI,CAACA,wBAAwB,CAACC,IAAI,CAAC,IAAI,CAAC;IACxE,IAAI,CAACC,uBAAuB,GAAG,IAAI,CAACA,uBAAuB,CAACD,IAAI,CAAC,IAAI,CAAC;IACtE,IAAI,CAACE,kBAAkB,GAAG,IAAI,CAACA,kBAAkB,CAACF,IAAI,CAAC,IAAI,CAAC;IAC5D,IAAI,CAACG,kBAAkB,GAAG,IAAI,CAACA,kBAAkB,CAACH,IAAI,CAAC,IAAI,CAAC;IAE5D,IAAI,CAACI,cAAc,gBAAGlB,KAAK,CAACmB,SAAS,CAAC,CAAC;IAEvC,IAAM;MAAEC;IAAM,CAAC,GAAGT,KAAK;IAEvB,IAAI,CAACU,KAAK,GAAG;MACXD,KAAK;MACLE,iBAAiB,EAAE;IACrB,CAAC;EACH;EAEAC,kBAAkBA,CAACC,SAA4B,EAAQ;IACrD,IAAM;MAAEC,OAAO,EAAEC;IAAY,CAAC,GAAGF,SAAS;IAC1C,IAAM;MAAEC;IAAQ,CAAC,GAAG,IAAI,CAACd,KAAK;IAC9B;IACA;IACA;IACA;IACA,IAAIc,OAAO,IAAI,CAACC,WAAW,EAAE;MAC3B,IAAI,CAACC,UAAU,CAAC,CAAC;IACnB;EACF;EAIAA,UAAUA,CAAA,EAAS;IACjB,IAAM;MAAEP;IAAM,CAAC,GAAG,IAAI,CAACT,KAAK;IAC5B,IAAI,CAACiB,QAAQ,CAAC;MAAER,KAAK;MAAEE,iBAAiB,EAAE;IAAM,CAAC,CAAC;EACpD;EAEAT,wBAAwBA,CAAA,EAAS;IAAA,IAAAgB,oBAAA,EAAAC,qBAAA;IAC/B,CAAAD,oBAAA,OAAI,CAACX,cAAc,cAAAW,oBAAA,wBAAAC,qBAAA,GAAnBD,oBAAA,CAAqBE,OAAO,cAAAD,qBAAA,uBAA5BA,qBAAA,CAA8BE,KAAK,CAAC,CAAC;EACvC;EAEAjB,uBAAuBA,CAACkB,KAAoC,EAAQ;IAClE,IAAI,CAACL,QAAQ,CAAC;MAAER,KAAK,EAAEa,KAAK,CAACC,MAAM,CAACd;IAAM,CAAC,CAAC;EAC9C;EAEAJ,kBAAkBA,CAAA,EAAS;IACzB,IAAM;MAAEmB;IAAS,CAAC,GAAG,IAAI,CAACxB,KAAK;IAC/BwB,QAAQ,CAAC,CAAC;EACZ;EAEAlB,kBAAkBA,CAACgB,KAAiC,EAAQ;IAC1DA,KAAK,CAACG,eAAe,CAAC,CAAC;IACvBH,KAAK,CAACI,cAAc,CAAC,CAAC;IACtB,IAAM;MAAEjB;IAAM,CAAC,GAAG,IAAI,CAACC,KAAK;IAC5B,IAAMiB,QAAQ,GAAGlB,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEmB,IAAI,CAAC,CAAC;IAC9B,IAAID,QAAQ,KAAKE,SAAS,IAAIF,QAAQ,KAAK,EAAE,EAAE;MAC7C,IAAM;QAAEG;MAAS,CAAC,GAAG,IAAI,CAAC9B,KAAK;MAC/B8B,QAAQ,CAACH,QAAQ,CAAC;IACpB,CAAC,MAAM;MACL,IAAI,CAACV,QAAQ,CAAC;QAAER,KAAK,EAAEkB,QAAQ;QAAEhB,iBAAiB,EAAE;MAAK,CAAC,CAAC;IAC7D;EACF;EAEAoB,kBAAkBA,CAAA,EAAiB;IACjC,IAAM;MAAEC,QAAQ;MAAEC,OAAO;MAAEC;IAAS,CAAC,GAAG,IAAI,CAAClC,KAAK;IAClD,IAAM;MAAES,KAAK;MAAEE;IAAkB,CAAC,GAAG,IAAI,CAACD,KAAK;IAE/C,oBACEf,KAAA;MACEwC,SAAS,EAAE5C,UAAU,CAAC,KAAK,EAAE;QAAE,eAAe,EAAEoB;MAAkB,CAAC,CAAE;MACrEmB,QAAQ,EAAE,IAAI,CAACxB,kBAAmB;MAClC8B,UAAU;MACVC,IAAI,EAAC,cAAc;MACnBC,WAAW,EAAEhB,KAAK,IAAI;QACpB;QACAA,KAAK,CAACG,eAAe,CAAC,CAAC;MACzB,CAAE;MACFc,SAAS,EAAEjB,KAAK,IAAI;QAClBA,KAAK,CAACG,eAAe,CAAC,CAAC;MACzB,CAAE;MAAAe,QAAA,gBAEF7C,KAAA;QAAKwC,SAAS,EAAC,YAAY;QAAAK,QAAA,gBACzB7C,KAAA;UAAO8C,OAAO,mBAAAC,MAAA,CAAmBR,QAAQ,WAAS;UAAAM,QAAA,GAAC,SAC1C,EAACN,QAAQ;QAAA,CACX,CAAC,eACRrC,IAAA;UACE8C,IAAI,EAAC,MAAM;UACXR,SAAS,EAAC,cAAc;UACxBS,EAAE,mBAAAF,MAAA,CAAmBR,QAAQ,WAAS;UACtCzB,KAAK,EAAEA,KAAK,aAALA,KAAK,cAALA,KAAK,GAAIoB,SAAU;UAC1BgB,GAAG,EAAE,IAAI,CAACtC,cAAe;UACzBuC,QAAQ,EAAE,IAAI,CAAC1C,uBAAwB;UACvC2C,QAAQ;QAAA,CACT,CAAC,eACFpD,KAAA;UAAKwC,SAAS,EAAC,kBAAkB;UAAAK,QAAA,GAC9BN,QAAQ,EAAC,uBACZ;QAAA,CAAK,CAAC,EACL,CAACF,QAAQ,IAAI,CAACC,OAAO,kBACpBtC,KAAA;UAAKwC,SAAS,EAAC,MAAM;UAAAK,QAAA,GAAC,gBACN,EAACN,QAAQ,EAAC,6BAC1B;QAAA,CAAK,CACN;MAAA,CACE,CAAC,eAENvC,KAAA;QAAKwC,SAAS,EAAC,YAAY;QAAAK,QAAA,gBACzB3C,IAAA,CAACL,MAAM;UACLwD,IAAI,EAAC,WAAW;UAChBb,SAAS,EAAC,MAAM;UAChBc,OAAO,EAAE,IAAI,CAAC5C,kBAAmB;UAAAmC,QAAA,EAClC;QAED,CAAQ,CAAC,eACT3C,IAAA,CAACL,MAAM;UAACwD,IAAI,EAAC,SAAS;UAACL,IAAI,EAAC,QAAQ;UAAAH,QAAA,EAAC;QAErC,CAAQ,CAAC;MAAA,CACN,CAAC;IAAA,CACF,CAAC;EAEX;EAEAU,MAAMA,CAAA,EAAiB;IACrB,IAAM;MAAEpC,OAAO;MAAEU;IAAS,CAAC,GAAG,IAAI,CAACxB,KAAK;IACxC,oBACEH,IAAA,CAACJ,MAAM;MACLqB,OAAO,EAAEA,OAAQ;MACjBqC,SAAS,EAAE,IAAI,CAACjD,wBAAyB;MACzCkD,QAAQ,EAAE5B,QAAS;MACnB6B,OAAO,EAAE;QACPC,SAAS,EAAE;MACb,CAAE;MACFC,WAAW;MACXC,WAAW;MAAAhB,QAAA,EAEV,IAAI,CAACT,kBAAkB,CAAC;IAAC,CACpB,CAAC;EAEb;AACF;AAAC9B,eAAA,CApJoBH,YAAY,kBAIT;EACpBkC,QAAQ,EAAE,KAAK;EACfC,OAAO,EAAE,IAAI;EACbC,QAAQ,EAAE,MAAM;EAChBzB,KAAK,EAAE;AACT,CAAC"}
|
package/dist/TabEvent.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TabEvent.js","names":["TabEvent","Object","freeze","focus","blur"],"sources":["../src/TabEvent.ts"],"sourcesContent":["const TabEvent = Object.freeze({\n focus: 'TabEvent.focus',\n blur: 'TabEvent.blur',\n});\n\nexport default TabEvent;\n"],"mappings":"AAAA,IAAMA,QAAQ,GAAGC,MAAM,CAACC,MAAM,CAAC;EAC7BC,KAAK,EAAE,gBAAgB;EACvBC,IAAI,EAAE;AACR,CAAC,CAAC;AAEF,eAAeJ,QAAQ"
|
|
1
|
+
{"version":3,"file":"TabEvent.js","names":["TabEvent","Object","freeze","focus","blur"],"sources":["../src/TabEvent.ts"],"sourcesContent":["const TabEvent = Object.freeze({\n focus: 'TabEvent.focus',\n blur: 'TabEvent.blur',\n});\n\nexport default TabEvent;\n"],"mappings":"AAAA,IAAMA,QAAQ,GAAGC,MAAM,CAACC,MAAM,CAAC;EAC7BC,KAAK,EAAE,gBAAgB;EACvBC,IAAI,EAAE;AACR,CAAC,CAAC;AAEF,eAAeJ,QAAQ"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"declaration.d.js","names":[],"sources":["../src/declaration.d.ts"],"sourcesContent":["declare module '*.module.scss' {\n const content: Record<string, string>;\n export default content;\n}\n\ndeclare module '*.scss';\n"],"mappings":""
|
|
1
|
+
{"version":3,"file":"declaration.d.js","names":[],"sources":["../src/declaration.d.ts"],"sourcesContent":["declare module '*.module.scss' {\n const content: Record<string, string>;\n export default content;\n}\n\ndeclare module '*.scss';\n"],"mappings":""}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["Dashboard","default","DashboardUtils","BasePanel","Panel","PanelErrorBoundary","PanelManager","TabEvent"],"sources":["../src/index.ts"],"sourcesContent":["import Dashboard from './Dashboard';\n\nexport default Dashboard;\n\nexport * from './Dashboard';\nexport * from './DashboardConstants';\nexport * from './DashboardEvents';\nexport * from './DashboardPlugin';\nexport * from './DashboardLayout';\nexport * from './DashboardUtils';\nexport { default as DashboardUtils } from './DashboardUtils';\nexport * from './LazyDashboard';\nexport * from './layout';\nexport * from './redux';\nexport {\n type BasePanelProps,\n default as BasePanel,\n // Alias for BasePanel\n default as Panel,\n} from './BasePanel';\nexport * from './PanelManager';\nexport * from './PanelEvent';\nexport * from './NavigationEvent';\nexport { default as PanelErrorBoundary } from './PanelErrorBoundary';\nexport { default as PanelManager } from './PanelManager';\nexport { default as TabEvent } from './TabEvent';\nexport * from './useDashboardId';\nexport * from './useDhId';\nexport * from './usePanelId';\n"],"mappings":"OAAOA,SAAS;AAEhB,eAAeA,SAAS;AAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAQhBC,OAAO,IAAIC,cAAc;AAAA;AAAA;AAAA;AAAA,SAMhCD,OAAO,IAAIE,SAAS;AACpB;AACAF,OAAO,IAAIG,KAAK;AAAA;AAAA;AAAA;AAAA,SAKTH,OAAO,IAAII,kBAAkB;AAAA,SAC7BJ,OAAO,IAAIK,YAAY;AAAA,SACvBL,OAAO,IAAIM,QAAQ;AAAA;AAAA;AAAA"
|
|
1
|
+
{"version":3,"file":"index.js","names":["Dashboard","default","DashboardUtils","BasePanel","Panel","PanelErrorBoundary","PanelManager","TabEvent"],"sources":["../src/index.ts"],"sourcesContent":["import Dashboard from './Dashboard';\n\nexport default Dashboard;\n\nexport * from './Dashboard';\nexport * from './DashboardConstants';\nexport * from './DashboardEvents';\nexport * from './DashboardPlugin';\nexport * from './DashboardLayout';\nexport * from './DashboardUtils';\nexport { default as DashboardUtils } from './DashboardUtils';\nexport * from './LazyDashboard';\nexport * from './layout';\nexport * from './redux';\nexport {\n type BasePanelProps,\n default as BasePanel,\n // Alias for BasePanel\n default as Panel,\n} from './BasePanel';\nexport * from './PanelManager';\nexport * from './PanelEvent';\nexport * from './NavigationEvent';\nexport { default as PanelErrorBoundary } from './PanelErrorBoundary';\nexport { default as PanelManager } from './PanelManager';\nexport { default as TabEvent } from './TabEvent';\nexport * from './useDashboardId';\nexport * from './useDhId';\nexport * from './usePanelId';\n"],"mappings":"OAAOA,SAAS;AAEhB,eAAeA,SAAS;AAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAQhBC,OAAO,IAAIC,cAAc;AAAA;AAAA;AAAA;AAAA,SAMhCD,OAAO,IAAIE,SAAS;AACpB;AACAF,OAAO,IAAIG,KAAK;AAAA;AAAA;AAAA;AAAA,SAKTH,OAAO,IAAII,kBAAkB;AAAA,SAC7BJ,OAAO,IAAIK,YAAY;AAAA,SACvBL,OAAO,IAAIM,QAAQ;AAAA;AAAA;AAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GLPropTypes.js","names":["PropTypes","Container","shape","on","func","off","isHidden","bool","tab","header","tabs","arrayOf","contentItem","title","string","setTitle","close","EventHub","emit","Layout","registerComponent","root","addChild","eventHub","GLPropTypes","Object","freeze"],"sources":["../../src/layout/GLPropTypes.ts"],"sourcesContent":["import PropTypes from 'prop-types';\n\nconst Container = PropTypes.shape({\n on: PropTypes.func,\n off: PropTypes.func,\n isHidden: PropTypes.bool,\n tab: PropTypes.shape({\n header: PropTypes.shape({\n tabs: PropTypes.arrayOf(\n PropTypes.shape({\n contentItem: PropTypes.shape({}),\n })\n ),\n }),\n }),\n title: PropTypes.string,\n setTitle: PropTypes.func,\n close: PropTypes.func,\n});\n\nconst EventHub = PropTypes.shape({\n on: PropTypes.func,\n off: PropTypes.func,\n emit: PropTypes.func,\n});\n\nconst Layout = PropTypes.shape({\n registerComponent: PropTypes.func,\n root: PropTypes.shape({ addChild: PropTypes.func }),\n on: PropTypes.func,\n off: PropTypes.func,\n eventHub: EventHub,\n});\n\nconst GLPropTypes = Object.freeze({ Container, EventHub, Layout });\n\nexport default GLPropTypes;\n"],"mappings":"AAAA,OAAOA,SAAS,MAAM,YAAY;AAElC,IAAMC,SAAS,GAAGD,SAAS,CAACE,KAAK,CAAC;EAChCC,EAAE,EAAEH,SAAS,CAACI,IAAI;EAClBC,GAAG,EAAEL,SAAS,CAACI,IAAI;EACnBE,QAAQ,EAAEN,SAAS,CAACO,IAAI;EACxBC,GAAG,EAAER,SAAS,CAACE,KAAK,CAAC;IACnBO,MAAM,EAAET,SAAS,CAACE,KAAK,CAAC;MACtBQ,IAAI,EAAEV,SAAS,CAACW,OAAO,CACrBX,SAAS,CAACE,KAAK,CAAC;QACdU,WAAW,EAAEZ,SAAS,CAACE,KAAK,CAAC,CAAC,CAAC;MACjC,CAAC,CACH;IACF,CAAC;EACH,CAAC,CAAC;EACFW,KAAK,EAAEb,SAAS,CAACc,MAAM;EACvBC,QAAQ,EAAEf,SAAS,CAACI,IAAI;EACxBY,KAAK,EAAEhB,SAAS,CAACI;AACnB,CAAC,CAAC;AAEF,IAAMa,QAAQ,GAAGjB,SAAS,CAACE,KAAK,CAAC;EAC/BC,EAAE,EAAEH,SAAS,CAACI,IAAI;EAClBC,GAAG,EAAEL,SAAS,CAACI,IAAI;EACnBc,IAAI,EAAElB,SAAS,CAACI;AAClB,CAAC,CAAC;AAEF,IAAMe,MAAM,GAAGnB,SAAS,CAACE,KAAK,CAAC;EAC7BkB,iBAAiB,EAAEpB,SAAS,CAACI,IAAI;EACjCiB,IAAI,EAAErB,SAAS,CAACE,KAAK,CAAC;IAAEoB,QAAQ,EAAEtB,SAAS,CAACI;EAAK,CAAC,CAAC;EACnDD,EAAE,EAAEH,SAAS,CAACI,IAAI;EAClBC,GAAG,EAAEL,SAAS,CAACI,IAAI;EACnBmB,QAAQ,EAAEN;AACZ,CAAC,CAAC;AAEF,IAAMO,WAAW,GAAGC,MAAM,CAACC,MAAM,CAAC;EAAEzB,SAAS;EAAEgB,QAAQ;EAAEE;AAAO,CAAC,CAAC;AAElE,eAAeK,WAAW"
|
|
1
|
+
{"version":3,"file":"GLPropTypes.js","names":["PropTypes","Container","shape","on","func","off","isHidden","bool","tab","header","tabs","arrayOf","contentItem","title","string","setTitle","close","EventHub","emit","Layout","registerComponent","root","addChild","eventHub","GLPropTypes","Object","freeze"],"sources":["../../src/layout/GLPropTypes.ts"],"sourcesContent":["import PropTypes from 'prop-types';\n\nconst Container = PropTypes.shape({\n on: PropTypes.func,\n off: PropTypes.func,\n isHidden: PropTypes.bool,\n tab: PropTypes.shape({\n header: PropTypes.shape({\n tabs: PropTypes.arrayOf(\n PropTypes.shape({\n contentItem: PropTypes.shape({}),\n })\n ),\n }),\n }),\n title: PropTypes.string,\n setTitle: PropTypes.func,\n close: PropTypes.func,\n});\n\nconst EventHub = PropTypes.shape({\n on: PropTypes.func,\n off: PropTypes.func,\n emit: PropTypes.func,\n});\n\nconst Layout = PropTypes.shape({\n registerComponent: PropTypes.func,\n root: PropTypes.shape({ addChild: PropTypes.func }),\n on: PropTypes.func,\n off: PropTypes.func,\n eventHub: EventHub,\n});\n\nconst GLPropTypes = Object.freeze({ Container, EventHub, Layout });\n\nexport default GLPropTypes;\n"],"mappings":"AAAA,OAAOA,SAAS,MAAM,YAAY;AAElC,IAAMC,SAAS,GAAGD,SAAS,CAACE,KAAK,CAAC;EAChCC,EAAE,EAAEH,SAAS,CAACI,IAAI;EAClBC,GAAG,EAAEL,SAAS,CAACI,IAAI;EACnBE,QAAQ,EAAEN,SAAS,CAACO,IAAI;EACxBC,GAAG,EAAER,SAAS,CAACE,KAAK,CAAC;IACnBO,MAAM,EAAET,SAAS,CAACE,KAAK,CAAC;MACtBQ,IAAI,EAAEV,SAAS,CAACW,OAAO,CACrBX,SAAS,CAACE,KAAK,CAAC;QACdU,WAAW,EAAEZ,SAAS,CAACE,KAAK,CAAC,CAAC,CAAC;MACjC,CAAC,CACH;IACF,CAAC;EACH,CAAC,CAAC;EACFW,KAAK,EAAEb,SAAS,CAACc,MAAM;EACvBC,QAAQ,EAAEf,SAAS,CAACI,IAAI;EACxBY,KAAK,EAAEhB,SAAS,CAACI;AACnB,CAAC,CAAC;AAEF,IAAMa,QAAQ,GAAGjB,SAAS,CAACE,KAAK,CAAC;EAC/BC,EAAE,EAAEH,SAAS,CAACI,IAAI;EAClBC,GAAG,EAAEL,SAAS,CAACI,IAAI;EACnBc,IAAI,EAAElB,SAAS,CAACI;AAClB,CAAC,CAAC;AAEF,IAAMe,MAAM,GAAGnB,SAAS,CAACE,KAAK,CAAC;EAC7BkB,iBAAiB,EAAEpB,SAAS,CAACI,IAAI;EACjCiB,IAAI,EAAErB,SAAS,CAACE,KAAK,CAAC;IAAEoB,QAAQ,EAAEtB,SAAS,CAACI;EAAK,CAAC,CAAC;EACnDD,EAAE,EAAEH,SAAS,CAACI,IAAI;EAClBC,GAAG,EAAEL,SAAS,CAACI,IAAI;EACnBmB,QAAQ,EAAEN;AACZ,CAAC,CAAC;AAEF,IAAMO,WAAW,GAAGC,MAAM,CAACC,MAAM,CAAC;EAAEzB,SAAS;EAAEgB,QAAQ;EAAEE;AAAO,CAAC,CAAC;AAElE,eAAeK,WAAW"}
|