@deephaven/dashboard-core-plugins 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/ChartBuilderPlugin.js.map +1 -1
- package/dist/ChartBuilderPluginConfig.js.map +1 -1
- package/dist/ChartPanelPlugin.js.map +1 -1
- package/dist/ChartPluginConfig.js.map +1 -1
- package/dist/ChartWidgetPlugin.js.map +1 -1
- package/dist/ConsolePlugin.js.map +1 -1
- package/dist/FilterEvents.js.map +1 -1
- package/dist/FilterPlugin.js.map +1 -1
- package/dist/FilterPluginConfig.js.map +1 -1
- package/dist/GridPanelPlugin.js.map +1 -1
- package/dist/GridPluginConfig.js.map +1 -1
- package/dist/GridWidgetPlugin.js.map +1 -1
- package/dist/LinkerPlugin.js.map +1 -1
- package/dist/LinkerPluginConfig.js.map +1 -1
- package/dist/MarkdownPlugin.js.map +1 -1
- package/dist/MarkdownPluginConfig.js.map +1 -1
- package/dist/PandasPanelPlugin.js.map +1 -1
- package/dist/PandasPluginConfig.js.map +1 -1
- package/dist/PandasWidgetPlugin.js.map +1 -1
- package/dist/TablePluginWrapper.js.map +1 -1
- package/dist/WidgetLoaderPlugin.js.map +1 -1
- package/dist/WidgetLoaderPluginConfig.js.map +1 -1
- package/dist/controls/ControlType.js.map +1 -1
- package/dist/controls/dropdown-filter/DropdownFilter.css.map +1 -1
- package/dist/controls/dropdown-filter/DropdownFilter.js.map +1 -1
- package/dist/controls/input-filter/InputFilter.css.map +1 -1
- package/dist/controls/input-filter/InputFilter.js.map +1 -1
- package/dist/controls/markdown/MarkdownContainer.js.map +1 -1
- package/dist/controls/markdown/MarkdownEditor.js.map +1 -1
- package/dist/controls/markdown/MarkdownStartPage.js.map +1 -1
- package/dist/controls/markdown/MarkdownUtils.js.map +1 -1
- package/dist/events/ChartEvent.js.map +1 -1
- package/dist/events/ConsoleEvent.js.map +1 -1
- package/dist/events/InputFilterEvent.js.map +1 -1
- package/dist/events/IrisGridEvent.js.map +1 -1
- package/dist/events/MarkdownEvent.js.map +1 -1
- package/dist/events/NotebookEvent.js.map +1 -1
- package/dist/events/PQEvent.js.map +1 -1
- package/dist/events/PandasEvent.js.map +1 -1
- package/dist/events/TabEventMap.js.map +1 -1
- package/dist/events/index.js.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/linker/ColumnSelectionValidator.js.map +1 -1
- package/dist/linker/Linker.js.map +1 -1
- package/dist/linker/LinkerEvent.js.map +1 -1
- package/dist/linker/LinkerLink.css.map +1 -1
- package/dist/linker/LinkerLink.js.map +1 -1
- package/dist/linker/LinkerOverlayContent.css.map +1 -1
- package/dist/linker/LinkerOverlayContent.js.map +1 -1
- package/dist/linker/LinkerUtils.js.map +1 -1
- package/dist/linker/ToolType.js.map +1 -1
- package/dist/linker/index.js.map +1 -1
- package/dist/panels/ChartColumnSelectorOverlay.css.map +1 -1
- package/dist/panels/ChartColumnSelectorOverlay.js.map +1 -1
- package/dist/panels/ChartFilterOverlay.css.map +1 -1
- package/dist/panels/ChartFilterOverlay.js.map +1 -1
- package/dist/panels/ChartPanel.css.map +1 -1
- package/dist/panels/ChartPanel.js.map +1 -1
- package/dist/panels/ChartPanelUtils.js.map +1 -1
- package/dist/panels/CommandHistoryPanel.css.map +1 -1
- package/dist/panels/CommandHistoryPanel.js.map +1 -1
- package/dist/panels/ConsolePanel.css.map +1 -1
- package/dist/panels/ConsolePanel.js.map +1 -1
- package/dist/panels/CorePanel.js.map +1 -1
- package/dist/panels/DropdownFilterPanel.css.map +1 -1
- package/dist/panels/DropdownFilterPanel.js.map +1 -1
- package/dist/panels/FileExplorerPanel.js.map +1 -1
- package/dist/panels/FilterSetManager.css.map +1 -1
- package/dist/panels/FilterSetManager.js.map +1 -1
- package/dist/panels/FilterSetManagerPanel.css.map +1 -1
- package/dist/panels/FilterSetManagerPanel.js.map +1 -1
- package/dist/panels/InputFilterPanel.js.map +1 -1
- package/dist/panels/IrisGridPanel.css.map +1 -1
- package/dist/panels/IrisGridPanel.js.map +1 -1
- package/dist/panels/IrisGridPanelTooltip.js.map +1 -1
- package/dist/panels/IrisGridPanelTypes.js.map +1 -1
- package/dist/panels/LogPanel.css.map +1 -1
- package/dist/panels/LogPanel.js.map +1 -1
- package/dist/panels/MarkdownNotebook.css.map +1 -1
- package/dist/panels/MarkdownNotebook.js.map +1 -1
- package/dist/panels/MarkdownPanel.css.map +1 -1
- package/dist/panels/MarkdownPanel.js.map +1 -1
- package/dist/panels/MockFileStorage.js.map +1 -1
- package/dist/panels/MockFileStorageTable.js.map +1 -1
- package/dist/panels/NotebookPanel.css.map +1 -1
- package/dist/panels/NotebookPanel.js.map +1 -1
- package/dist/panels/PandasPanel.css.map +1 -1
- package/dist/panels/PandasPanel.js.map +1 -1
- package/dist/panels/PandasReloadButton.js.map +1 -1
- package/dist/panels/WidgetPanel.css.map +1 -1
- package/dist/panels/WidgetPanel.js.map +1 -1
- package/dist/panels/WidgetPanelTooltip.css.map +1 -1
- package/dist/panels/WidgetPanelTooltip.js.map +1 -1
- package/dist/panels/WidgetPanelTypes.js.map +1 -1
- package/dist/panels/index.js.map +1 -1
- package/dist/prop-types/CommonPropTypes.js.map +1 -1
- package/dist/prop-types/UIPropTypes.js.map +1 -1
- package/dist/prop-types/index.js.map +1 -1
- package/dist/redux/actions.js.map +1 -1
- package/dist/redux/index.js.map +1 -1
- package/dist/redux/selectors.js.map +1 -1
- package/dist/useChartLinker.js.map +1 -1
- package/dist/useConfigureRuff.js.map +1 -1
- package/dist/useDashboardColumnFilters.js.map +1 -1
- package/dist/useGridLinker.js.map +1 -1
- package/dist/useHydrateGrid.js.map +1 -1
- package/dist/useIrisGridModel.js.map +1 -1
- package/dist/useLoadTablePlugin.js.map +1 -1
- package/dist/useTablePlugin.js.map +1 -1
- package/package.json +24 -24
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartColumnSelectorOverlay.js","names":["React","classNames","SocketedButton","jsx","_jsx","jsxs","_jsxs","ChartColumnSelectorOverlay","_ref","columns","onColumnSelected","onMouseEnter","onMouseLeave","className","children","map","column","makeButtonClassName","name","onClick","disabled","isValid","isLinked","isActive","columnName","concat","defaultProps","undefined"],"sources":["../../src/panels/ChartColumnSelectorOverlay.tsx"],"sourcesContent":["import React, { type MouseEventHandler, type ReactElement } from 'react';\nimport classNames from 'classnames';\nimport { SocketedButton } from '@deephaven/components';\nimport './ChartColumnSelectorOverlay.scss';\n\nexport interface SelectorColumn {\n name: string;\n type: string;\n isValid: boolean;\n isActive: boolean;\n}\n\ninterface ChartColumnSelectorOverlayProps {\n columns: SelectorColumn[];\n onColumnSelected: (name: string) => void;\n onMouseEnter?: (column: SelectorColumn) => void;\n onMouseLeave?: MouseEventHandler<HTMLButtonElement>;\n}\n\nfunction ChartColumnSelectorOverlay({\n columns,\n onColumnSelected,\n onMouseEnter,\n onMouseLeave,\n}: ChartColumnSelectorOverlayProps): ReactElement {\n return (\n <div className=\"chart-panel-overlay chart-column-selector-overlay\">\n <div className={classNames('chart-panel-overlay-content')}>\n <div className=\"info-message\">\n This plot requires a filter control to be added to the layout or a\n table link to be created on the following columns:\n </div>\n <div className=\"waiting-column-select-list\">\n {columns.map(column => (\n <SocketedButton\n key={column.name}\n className={classNames(\n 'btn-chart-column-selector',\n ChartColumnSelectorOverlay.makeButtonClassName(column.name)\n )}\n onClick={() => onColumnSelected(column.name)}\n onMouseEnter={() => {\n if (onMouseEnter) onMouseEnter(column);\n }}\n onMouseLeave={onMouseLeave}\n disabled={!column.isValid}\n isLinked={column.isActive}\n >\n {column.name}\n </SocketedButton>\n ))}\n </div>\n </div>\n </div>\n );\n}\n\nChartColumnSelectorOverlay.makeButtonClassName = (columnName: string) =>\n `btn-chart-column-selector-${columnName}`;\n\nChartColumnSelectorOverlay.defaultProps = {\n onMouseEnter: (): void => undefined,\n onMouseLeave: (): void => undefined,\n};\n\nexport default ChartColumnSelectorOverlay;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAqD,OAAO;AACxE,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,cAAc,QAAQ,uBAAuB;AAAC;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAAA,SAAAC,IAAA,IAAAC,KAAA;AAiBvD,SAASC,0BAA0BA,CAAAC,IAAA,EAKe;EAAA,IALd;IAClCC,OAAO;IACPC,gBAAgB;IAChBC,YAAY,EAAZA,aAAY;IACZC;EAC+B,CAAC,GAAAJ,IAAA;EAChC,oBACEJ,IAAA;IAAKS,SAAS,EAAC,mDAAmD;IAAAC,QAAA,eAChER,KAAA;MAAKO,SAAS,EAAEZ,UAAU,CAAC,6BAA6B,CAAE;MAAAa,QAAA,gBACxDV,IAAA;QAAKS,SAAS,EAAC,cAAc;QAAAC,QAAA,EAAC;MAG9B,CAAK,CAAC,eACNV,IAAA;QAAKS,SAAS,EAAC,4BAA4B;QAAAC,QAAA,EACxCL,OAAO,CAACM,GAAG,CAACC,MAAM,iBACjBZ,IAAA,CAACF,cAAc;UAEbW,SAAS,EAAEZ,UAAU,CACnB,2BAA2B,EAC3BM,0BAA0B,CAACU,mBAAmB,CAACD,MAAM,CAACE,IAAI,CAC5D,CAAE;UACFC,OAAO,EAAEA,CAAA,KAAMT,gBAAgB,CAACM,MAAM,CAACE,IAAI,CAAE;UAC7CP,YAAY,EAAEA,CAAA,KAAM;YAClB,IAAIA,aAAY,EAAEA,aAAY,CAACK,MAAM,CAAC;UACxC,CAAE;UACFJ,YAAY,EAAEA,YAAa;UAC3BQ,QAAQ,EAAE,CAACJ,MAAM,CAACK,OAAQ;UAC1BC,QAAQ,EAAEN,MAAM,CAACO,QAAS;UAAAT,QAAA,EAEzBE,MAAM,CAACE;QAAI,GAbPF,MAAM,CAACE,IAcE,CACjB;MAAC,CACC,CAAC;IAAA,CACH;EAAC,CACH,CAAC;AAEV;AAEAX,0BAA0B,CAACU,mBAAmB,GAAIO,UAAkB,iCAAAC,MAAA,CACrCD,UAAU,CAAE;AAE3CjB,0BAA0B,CAACmB,YAAY,GAAG;EACxCf,YAAY,EAAEA,CAAA,KAAYgB,SAAS;EACnCf,YAAY,EAAEA,CAAA,KAAYe;AAC5B,CAAC;AAED,eAAepB,0BAA0B"
|
|
1
|
+
{"version":3,"file":"ChartColumnSelectorOverlay.js","names":["React","classNames","SocketedButton","jsx","_jsx","jsxs","_jsxs","ChartColumnSelectorOverlay","_ref","columns","onColumnSelected","onMouseEnter","onMouseLeave","className","children","map","column","makeButtonClassName","name","onClick","disabled","isValid","isLinked","isActive","columnName","concat","defaultProps","undefined"],"sources":["../../src/panels/ChartColumnSelectorOverlay.tsx"],"sourcesContent":["import React, { type MouseEventHandler, type ReactElement } from 'react';\nimport classNames from 'classnames';\nimport { SocketedButton } from '@deephaven/components';\nimport './ChartColumnSelectorOverlay.scss';\n\nexport interface SelectorColumn {\n name: string;\n type: string;\n isValid: boolean;\n isActive: boolean;\n}\n\ninterface ChartColumnSelectorOverlayProps {\n columns: SelectorColumn[];\n onColumnSelected: (name: string) => void;\n onMouseEnter?: (column: SelectorColumn) => void;\n onMouseLeave?: MouseEventHandler<HTMLButtonElement>;\n}\n\nfunction ChartColumnSelectorOverlay({\n columns,\n onColumnSelected,\n onMouseEnter,\n onMouseLeave,\n}: ChartColumnSelectorOverlayProps): ReactElement {\n return (\n <div className=\"chart-panel-overlay chart-column-selector-overlay\">\n <div className={classNames('chart-panel-overlay-content')}>\n <div className=\"info-message\">\n This plot requires a filter control to be added to the layout or a\n table link to be created on the following columns:\n </div>\n <div className=\"waiting-column-select-list\">\n {columns.map(column => (\n <SocketedButton\n key={column.name}\n className={classNames(\n 'btn-chart-column-selector',\n ChartColumnSelectorOverlay.makeButtonClassName(column.name)\n )}\n onClick={() => onColumnSelected(column.name)}\n onMouseEnter={() => {\n if (onMouseEnter) onMouseEnter(column);\n }}\n onMouseLeave={onMouseLeave}\n disabled={!column.isValid}\n isLinked={column.isActive}\n >\n {column.name}\n </SocketedButton>\n ))}\n </div>\n </div>\n </div>\n );\n}\n\nChartColumnSelectorOverlay.makeButtonClassName = (columnName: string) =>\n `btn-chart-column-selector-${columnName}`;\n\nChartColumnSelectorOverlay.defaultProps = {\n onMouseEnter: (): void => undefined,\n onMouseLeave: (): void => undefined,\n};\n\nexport default ChartColumnSelectorOverlay;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAqD,OAAO;AACxE,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,cAAc,QAAQ,uBAAuB;AAAC;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAAA,SAAAC,IAAA,IAAAC,KAAA;AAiBvD,SAASC,0BAA0BA,CAAAC,IAAA,EAKe;EAAA,IALd;IAClCC,OAAO;IACPC,gBAAgB;IAChBC,YAAY,EAAZA,aAAY;IACZC;EAC+B,CAAC,GAAAJ,IAAA;EAChC,oBACEJ,IAAA;IAAKS,SAAS,EAAC,mDAAmD;IAAAC,QAAA,eAChER,KAAA;MAAKO,SAAS,EAAEZ,UAAU,CAAC,6BAA6B,CAAE;MAAAa,QAAA,gBACxDV,IAAA;QAAKS,SAAS,EAAC,cAAc;QAAAC,QAAA,EAAC;MAG9B,CAAK,CAAC,eACNV,IAAA;QAAKS,SAAS,EAAC,4BAA4B;QAAAC,QAAA,EACxCL,OAAO,CAACM,GAAG,CAACC,MAAM,iBACjBZ,IAAA,CAACF,cAAc;UAEbW,SAAS,EAAEZ,UAAU,CACnB,2BAA2B,EAC3BM,0BAA0B,CAACU,mBAAmB,CAACD,MAAM,CAACE,IAAI,CAC5D,CAAE;UACFC,OAAO,EAAEA,CAAA,KAAMT,gBAAgB,CAACM,MAAM,CAACE,IAAI,CAAE;UAC7CP,YAAY,EAAEA,CAAA,KAAM;YAClB,IAAIA,aAAY,EAAEA,aAAY,CAACK,MAAM,CAAC;UACxC,CAAE;UACFJ,YAAY,EAAEA,YAAa;UAC3BQ,QAAQ,EAAE,CAACJ,MAAM,CAACK,OAAQ;UAC1BC,QAAQ,EAAEN,MAAM,CAACO,QAAS;UAAAT,QAAA,EAEzBE,MAAM,CAACE;QAAI,GAbPF,MAAM,CAACE,IAcE,CACjB;MAAC,CACC,CAAC;IAAA,CACH;EAAC,CACH,CAAC;AAEV;AAEAX,0BAA0B,CAACU,mBAAmB,GAAIO,UAAkB,iCAAAC,MAAA,CACrCD,UAAU,CAAE;AAE3CjB,0BAA0B,CAACmB,YAAY,GAAG;EACxCf,YAAY,EAAEA,CAAA,KAAYgB,SAAS;EACnCf,YAAY,EAAEA,CAAA,KAAYe;AAC5B,CAAC;AAED,eAAepB,0BAA0B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sourceRoot":"","sources":["../../../../node_modules/@deephaven/components/scss/custom.scss","../../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss","../../src/panels/ChartFilterOverlay.scss","../../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;ACtLI;EACE,YCHK;EDIL,eCFK;;ADKH;EACE,cCRC;EDSD,ODPF;;ACWE;EACE,ODDD;;ACMP;EACE,eCnBK;EDoBL,cCpBK;;ADuBL;AAAA;EAEE","file":"ChartFilterOverlay.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$chart-filter-column-valid-color: $green;\n$chart-filter-column-invalid-color: $gray-400;\n\n.chart-filter-overlay {\n .chart-filter-overlay-content {\n .waiting-filter-list {\n margin-top: $spacer-2;\n margin-bottom: $spacer-4;\n\n .waiting-filter-item {\n svg {\n margin-right: $spacer-2;\n color: $chart-filter-column-valid-color;\n }\n\n &.is-invalid {\n svg {\n color: $chart-filter-column-invalid-color;\n }\n }\n }\n }\n .btn {\n margin-bottom: $spacer-3;\n margin-right: $spacer-3;\n }\n &.chart-filter-waiting-filter {\n .info-message,\n .waiting-filter-list {\n text-align: left;\n }\n }\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/panels/ChartFilterOverlay.scss","../../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;ACtLI;EACE,YCHK;EDIL,eCFK;;ADKH;EACE,cCRC;EDSD,ODPF;;ACWE;EACE,ODDD;;ACMP;EACE,eCnBK;EDoBL,cCpBK;;ADuBL;AAAA;EAEE","file":"ChartFilterOverlay.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$chart-filter-column-valid-color: $green;\n$chart-filter-column-invalid-color: $gray-400;\n\n.chart-filter-overlay {\n .chart-filter-overlay-content {\n .waiting-filter-list {\n margin-top: $spacer-2;\n margin-bottom: $spacer-4;\n\n .waiting-filter-item {\n svg {\n margin-right: $spacer-2;\n color: $chart-filter-column-valid-color;\n }\n\n &.is-invalid {\n svg {\n color: $chart-filter-column-invalid-color;\n }\n }\n }\n }\n .btn {\n margin-bottom: $spacer-3;\n margin-right: $spacer-3;\n }\n &.chart-filter-waiting-filter {\n .info-message,\n .waiting-filter-list {\n text-align: left;\n }\n }\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":"ChartFilterOverlay.js","names":["React","useCallback","useMemo","PropTypes","classNames","FontAwesomeIcon","Button","vsPass","vsWarning","TextUtils","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","ChartFilterOverlay","_ref","columnMap","inputFilterMap","linkedColumnMap","onAdd","onOpenLinker","waitingFilterMap","waitingInputMap","inputMessage","waitingColumns","Array","from","keys","needsInputFilterValue","find","columnName","get","needsLinkValue","columnsText","join","map","item","concat","columns","values","handleAddClick","event","stopPropagation","preventDefault","handleOpenLinker","isWaitingFilters","size","isWaitingInput","className","children","column","isColumnWaiting","has","name","icon","kind","onClick","propTypes","instanceOf","Map","isRequired","func"],"sources":["../../src/panels/ChartFilterOverlay.tsx"],"sourcesContent":["import React, {\n type MouseEvent,\n type ReactElement,\n useCallback,\n useMemo,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { Button } from '@deephaven/components';\nimport { vsPass, vsWarning } from '@deephaven/icons';\nimport { TextUtils } from '@deephaven/utils';\nimport { type ColumnName, type InputFilter } from '@deephaven/iris-grid';\nimport './ChartFilterOverlay.scss';\n\nexport type ColumnMap = Map<ColumnName, { name: string; type: string }>;\n\ninterface ChartFilterOverlayProps {\n columnMap: ColumnMap;\n inputFilterMap: Map<ColumnName, InputFilter>;\n linkedColumnMap: Map<string, unknown>;\n onAdd: (columns: InputFilter[]) => void;\n onOpenLinker: () => void;\n waitingFilterMap: Map<string, InputFilter>;\n waitingInputMap: Map<ColumnName, unknown>;\n}\n\nfunction ChartFilterOverlay({\n columnMap,\n inputFilterMap,\n linkedColumnMap,\n onAdd,\n onOpenLinker,\n waitingFilterMap,\n waitingInputMap,\n}: ChartFilterOverlayProps): ReactElement {\n const inputMessage = useMemo(() => {\n const waitingColumns = Array.from(waitingInputMap.keys());\n const needsInputFilterValue = waitingColumns.find(\n (columnName: ColumnName) => inputFilterMap.get(columnName) != null\n );\n const needsLinkValue = waitingColumns.find(\n columnName => linkedColumnMap.get(columnName) != null\n );\n const columnsText = TextUtils.join(waitingColumns.map(item => `\"${item}\"`));\n if (\n needsInputFilterValue != null &&\n needsInputFilterValue &&\n needsLinkValue != null &&\n needsLinkValue\n ) {\n return `Use a filter control or linked table to set a value for ${columnsText}`;\n }\n if (needsInputFilterValue != null && needsInputFilterValue) {\n return `Set a filter control value for ${columnsText}`;\n }\n return `Double click a row in a linked table to set a value for ${columnsText}`;\n }, [inputFilterMap, linkedColumnMap, waitingInputMap]);\n\n const columns = useMemo(() => Array.from(columnMap.values()), [columnMap]);\n\n const handleAddClick = useCallback(\n (event: MouseEvent<HTMLButtonElement>) => {\n event.stopPropagation();\n event.preventDefault();\n\n onAdd(Array.from(waitingFilterMap.values()));\n },\n [onAdd, waitingFilterMap]\n );\n\n const handleOpenLinker = useCallback(\n event => {\n event.stopPropagation();\n event.preventDefault();\n\n onOpenLinker();\n },\n [onOpenLinker]\n );\n\n const isWaitingFilters = waitingFilterMap.size > 0;\n const isWaitingInput = !isWaitingFilters && waitingInputMap.size > 0;\n\n return (\n <div className=\"chart-panel-overlay chart-filter-overlay\">\n <div\n className={classNames(\n 'chart-panel-overlay-content chart-filter-overlay-content',\n { 'chart-filter-waiting-filter': isWaitingFilters },\n { 'chart-filter-waiting-input': isWaitingInput }\n )}\n >\n {isWaitingFilters && (\n <>\n <div className=\"info-message\">\n This plot requires a filter control to be added to the layout or a\n table link to be created on the following columns:\n </div>\n <div className=\"waiting-filter-list\">\n {columns.map(column => {\n const isColumnWaiting = waitingFilterMap.has(column.name);\n const icon = isColumnWaiting ? vsWarning : vsPass;\n return (\n <div\n key={column.name}\n className={classNames('waiting-filter-item', {\n 'is-invalid': isColumnWaiting,\n })}\n >\n <FontAwesomeIcon icon={icon} />\n {column.name}\n </div>\n );\n })}\n </div>\n <div>\n <Button kind=\"primary\" onClick={handleAddClick}>\n Add Input Filters\n </Button>\n <Button kind=\"primary\" onClick={handleOpenLinker}>\n Open Linker Tool\n </Button>\n </div>\n </>\n )}\n {isWaitingInput && (\n <>\n <div className=\"info-message\">Waiting for User Input</div>\n <div className=\"\">{inputMessage}</div>\n </>\n )}\n </div>\n </div>\n );\n}\n\nChartFilterOverlay.propTypes = {\n columnMap: PropTypes.instanceOf(Map).isRequired,\n inputFilterMap: PropTypes.instanceOf(Map).isRequired,\n linkedColumnMap: PropTypes.instanceOf(Map).isRequired,\n onAdd: PropTypes.func.isRequired,\n onOpenLinker: PropTypes.func.isRequired,\n waitingFilterMap: PropTypes.instanceOf(Map).isRequired,\n waitingInputMap: PropTypes.instanceOf(Map).isRequired,\n};\n\nexport default ChartFilterOverlay;\n"],"mappings":"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"
|
|
1
|
+
{"version":3,"file":"ChartFilterOverlay.js","names":["React","useCallback","useMemo","PropTypes","classNames","FontAwesomeIcon","Button","vsPass","vsWarning","TextUtils","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","ChartFilterOverlay","_ref","columnMap","inputFilterMap","linkedColumnMap","onAdd","onOpenLinker","waitingFilterMap","waitingInputMap","inputMessage","waitingColumns","Array","from","keys","needsInputFilterValue","find","columnName","get","needsLinkValue","columnsText","join","map","item","concat","columns","values","handleAddClick","event","stopPropagation","preventDefault","handleOpenLinker","isWaitingFilters","size","isWaitingInput","className","children","column","isColumnWaiting","has","name","icon","kind","onClick","propTypes","instanceOf","Map","isRequired","func"],"sources":["../../src/panels/ChartFilterOverlay.tsx"],"sourcesContent":["import React, {\n type MouseEvent,\n type ReactElement,\n useCallback,\n useMemo,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { Button } from '@deephaven/components';\nimport { vsPass, vsWarning } from '@deephaven/icons';\nimport { TextUtils } from '@deephaven/utils';\nimport { type ColumnName, type InputFilter } from '@deephaven/iris-grid';\nimport './ChartFilterOverlay.scss';\n\nexport type ColumnMap = Map<ColumnName, { name: string; type: string }>;\n\ninterface ChartFilterOverlayProps {\n columnMap: ColumnMap;\n inputFilterMap: Map<ColumnName, InputFilter>;\n linkedColumnMap: Map<string, unknown>;\n onAdd: (columns: InputFilter[]) => void;\n onOpenLinker: () => void;\n waitingFilterMap: Map<string, InputFilter>;\n waitingInputMap: Map<ColumnName, unknown>;\n}\n\nfunction ChartFilterOverlay({\n columnMap,\n inputFilterMap,\n linkedColumnMap,\n onAdd,\n onOpenLinker,\n waitingFilterMap,\n waitingInputMap,\n}: ChartFilterOverlayProps): ReactElement {\n const inputMessage = useMemo(() => {\n const waitingColumns = Array.from(waitingInputMap.keys());\n const needsInputFilterValue = waitingColumns.find(\n (columnName: ColumnName) => inputFilterMap.get(columnName) != null\n );\n const needsLinkValue = waitingColumns.find(\n columnName => linkedColumnMap.get(columnName) != null\n );\n const columnsText = TextUtils.join(waitingColumns.map(item => `\"${item}\"`));\n if (\n needsInputFilterValue != null &&\n needsInputFilterValue &&\n needsLinkValue != null &&\n needsLinkValue\n ) {\n return `Use a filter control or linked table to set a value for ${columnsText}`;\n }\n if (needsInputFilterValue != null && needsInputFilterValue) {\n return `Set a filter control value for ${columnsText}`;\n }\n return `Double click a row in a linked table to set a value for ${columnsText}`;\n }, [inputFilterMap, linkedColumnMap, waitingInputMap]);\n\n const columns = useMemo(() => Array.from(columnMap.values()), [columnMap]);\n\n const handleAddClick = useCallback(\n (event: MouseEvent<HTMLButtonElement>) => {\n event.stopPropagation();\n event.preventDefault();\n\n onAdd(Array.from(waitingFilterMap.values()));\n },\n [onAdd, waitingFilterMap]\n );\n\n const handleOpenLinker = useCallback(\n event => {\n event.stopPropagation();\n event.preventDefault();\n\n onOpenLinker();\n },\n [onOpenLinker]\n );\n\n const isWaitingFilters = waitingFilterMap.size > 0;\n const isWaitingInput = !isWaitingFilters && waitingInputMap.size > 0;\n\n return (\n <div className=\"chart-panel-overlay chart-filter-overlay\">\n <div\n className={classNames(\n 'chart-panel-overlay-content chart-filter-overlay-content',\n { 'chart-filter-waiting-filter': isWaitingFilters },\n { 'chart-filter-waiting-input': isWaitingInput }\n )}\n >\n {isWaitingFilters && (\n <>\n <div className=\"info-message\">\n This plot requires a filter control to be added to the layout or a\n table link to be created on the following columns:\n </div>\n <div className=\"waiting-filter-list\">\n {columns.map(column => {\n const isColumnWaiting = waitingFilterMap.has(column.name);\n const icon = isColumnWaiting ? vsWarning : vsPass;\n return (\n <div\n key={column.name}\n className={classNames('waiting-filter-item', {\n 'is-invalid': isColumnWaiting,\n })}\n >\n <FontAwesomeIcon icon={icon} />\n {column.name}\n </div>\n );\n })}\n </div>\n <div>\n <Button kind=\"primary\" onClick={handleAddClick}>\n Add Input Filters\n </Button>\n <Button kind=\"primary\" onClick={handleOpenLinker}>\n Open Linker Tool\n </Button>\n </div>\n </>\n )}\n {isWaitingInput && (\n <>\n <div className=\"info-message\">Waiting for User Input</div>\n <div className=\"\">{inputMessage}</div>\n </>\n )}\n </div>\n </div>\n );\n}\n\nChartFilterOverlay.propTypes = {\n columnMap: PropTypes.instanceOf(Map).isRequired,\n inputFilterMap: PropTypes.instanceOf(Map).isRequired,\n linkedColumnMap: PropTypes.instanceOf(Map).isRequired,\n onAdd: PropTypes.func.isRequired,\n onOpenLinker: PropTypes.func.isRequired,\n waitingFilterMap: PropTypes.instanceOf(Map).isRequired,\n waitingInputMap: PropTypes.instanceOf(Map).isRequired,\n};\n\nexport default ChartFilterOverlay;\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sourceRoot":"","sources":["../../../../node_modules/@deephaven/components/scss/custom.scss","../../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss","../../src/panels/ChartPanel.scss","../../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;ACtLA;EACE;;AAKE;EACE;;AAIF;EACE,SAjB6B;;;AAsBnC;EACE,kBArBiB;EAsBjB;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA,WAvCwB;EAwCxB,QCvCO;;ADyCP;EACE,WA7CsB","file":"ChartPanel.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$chart-panel-disconnected-opacity: 0.18;\n$overlay-message-font-size: 1.2rem;\n$overlay-scrim-bg: bg-opacity(80);\n$overlay-content-max-width: 450px;\n\n.iris-chart-panel {\n overflow: hidden;\n\n &.disconnected,\n &.inactive,\n &.input-required {\n .chart-container {\n filter: grayscale(100%);\n }\n }\n &.disconnected {\n .chart-container {\n opacity: $chart-panel-disconnected-opacity;\n }\n }\n}\n\n.chart-panel-overlay {\n background-color: $overlay-scrim-bg;\n backdrop-filter: blur(1px);\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n display: flex;\n text-align: center;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n overflow: auto;\n\n .chart-panel-overlay-content {\n display: flex;\n flex-direction: column;\n justify-content: center;\n white-space: pre-line;\n max-width: $overlay-content-max-width;\n margin: $spacer-3;\n\n .info-message {\n font-size: $overlay-message-font-size;\n }\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/panels/ChartPanel.scss","../../../../node_modules/@deephaven/components/scss/new_variables.scss"],"names":[],"mappings":"AAAA;AC6LA;ACtLA;EACE;;AAKE;EACE;;AAIF;EACE,SAjB6B;;;AAsBnC;EACE,kBArBiB;EAsBjB;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA,WAvCwB;EAwCxB,QCvCO;;ADyCP;EACE,WA7CsB","file":"ChartPanel.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$chart-panel-disconnected-opacity: 0.18;\n$overlay-message-font-size: 1.2rem;\n$overlay-scrim-bg: bg-opacity(80);\n$overlay-content-max-width: 450px;\n\n.iris-chart-panel {\n overflow: hidden;\n\n &.disconnected,\n &.inactive,\n &.input-required {\n .chart-container {\n filter: grayscale(100%);\n }\n }\n &.disconnected {\n .chart-container {\n opacity: $chart-panel-disconnected-opacity;\n }\n }\n}\n\n.chart-panel-overlay {\n background-color: $overlay-scrim-bg;\n backdrop-filter: blur(1px);\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n display: flex;\n text-align: center;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n overflow: auto;\n\n .chart-panel-overlay-content {\n display: flex;\n flex-direction: column;\n justify-content: center;\n white-space: pre-line;\n max-width: $overlay-content-max-width;\n margin: $spacer-3;\n\n .info-message {\n font-size: $overlay-message-font-size;\n }\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":"ChartPanel.js","names":["React","Component","classNames","memoize","connect","debounce","Chart","ChartModelFactory","isFigureChartModel","getOpenedPanelMapForDashboard","LayoutUtils","IrisGridUtils","FadeTransition","Log","getActiveTool","getSettings","setActiveTool","setActiveToolAction","assertNotNull","Pending","PromiseUtils","TextUtils","WidgetPanel","ToolType","InputFilterEvent","getColumnSelectionValidatorForDashboard","getInputFiltersForDashboard","getIsolatedLinkerPanelIdForDashboard","getLinksForDashboard","getTableMapForDashboard","setDashboardIsolatedLinkerPanelId","setDashboardIsolatedLinkerPanelIdAction","ChartFilterOverlay","ChartColumnSelectorOverlay","isChartPanelFigureMetadata","isChartPanelTableMetadata","emitFilterColumnsChanged","emitLinkPointSelected","jsx","_jsx","jsxs","_jsxs","log","module","UPDATE_MODEL_DEBOUNCE","hasInputFilter","panel","inputFilters","hasPanelState","panelState","ChartPanel","constructor","props","_defineProperty","isFilterRequired","columnMap","filterMap","Map","waitingInputMap","forEach","filter","name","delete","linkedColumnMap","inputFilterMap","waitingFilterMap","value","column","i","length","inputFilter","type","get","set","links","panelId","getIdFromPanel","link","columnName","start","has","end","columnSelectionValidator","Array","from","values","map","isValid","isActive","metadata","table","_metadata$figure","figure","_metadata$name","_objectSpread","handleColumnSelected","bind","handleColumnMouseEnter","handleColumnMouseLeave","handleDisconnect","handleReconnect","handleFilterAdd","handleHide","handleError","handleLoadError","handleLoadSuccess","handleSettingsChanged","handleOpenLinker","handleShow","handleSourceColumnChange","handleSourceFilterChange","handleSourceSortChange","handleTabBlur","handleTabFocus","handleUpdate","updateModelFromSource","handleClearAllFilters","panelContainer","createRef","pending","filterValueMap","settings","state","error","undefined","isDisconnected","isLoading","isLoaded","isLinked","model","componentDidMount","isHidden","setState","initModel","componentDidUpdate","prevProps","prevState","source","makeModel","pruneFilterMaps","updateChangedInputFilters","updateFilters","updatePanelState","updateSettings","startListeningToSource","stopListeningToSource","componentWillUnmount","cancel","add","resolved","close","then","debug","dh","addEventListener","Table","EVENT_CUSTOMCOLUMNSCHANGED","EVENT_FILTERCHANGED","EVENT_SORTCHANGED","removeEventListener","loadModelIfNecessary","glContainer","glEventHub","_ref","Error","columns","openInputFilter","localDashboardId","LINKER","sendColumnChange","updateColumnFilters","prevModel","updateInputFilters","size","isCanceled","debug2","makeFigureFromSettings","setFigure","catch","sourcePanel","tableSettings","sourcePanelState","extractTableSettings","update","_ref2","prevSettings","setActive","_ref3","emit","OPEN_INPUT","title","concat","isValueShown","createNewStack","focusElement","getFilterColumnMap","getCoordinateForColumn","_element$getBoundingC","className","makeButtonClassName","current","element","querySelector","rect","getBoundingClientRect","width","height","x","left","y","bottom","setFilterMap","filterMapParam","_updatedFilterMap","updatedFilterMap","_ref4","columnType","filterList","unsetFilterValue","getInputFilterColumnMap","_inputFilterMap$get","filterValue","inputFilterValue","prevInputFilters","deletedInputFilters","prevInputFilter","find","deleteInputFilters","changedInputFilters","includes","forceUpdate","arguments","needsUpdate","linkValue","_ref5","getWaitingInputMap","setFilter","defaultTitle","getDefaultTitle","filterTitle","join","entries","_ref6","setTitle","newState","render","isLinkerActive","Plotly","containerRef","getLinkedColumnMap","getWaitingFilterMap","errorMessage","isWaitingForFilter","isSelectingColumn","descriptor","getWidgetPanelDescriptor","componentPanel","onHide","onClearAllFilters","onShow","onTabBlur","onTabFocus","children","ref","onDisconnect","onReconnect","onUpdate","onError","onSettingsChanged","in","mountOnEnter","unmountOnExit","onAdd","onOpenLinker","getSelectorColumns","onColumnSelected","onMouseEnter","onMouseLeave","mapStateToProps","ownProps","sourcePanelId","panelTableMap","openedPanelMap","activeTool","isolatedLinkerPanelId","ConnectedChartPanel","forwardRef"],"sources":["../../src/panels/ChartPanel.tsx"],"sourcesContent":["import React, { Component, type ReactElement, type RefObject } from 'react';\nimport classNames from 'classnames';\nimport memoize from 'memoize-one';\nimport { connect } from 'react-redux';\nimport debounce from 'lodash.debounce';\nimport {\n Chart,\n type ChartModel,\n ChartModelFactory,\n type ChartModelSettings,\n type FilterMap,\n isFigureChartModel,\n} from '@deephaven/chart';\nimport type PlotlyType from 'plotly.js';\nimport {\n type DashboardPanelProps,\n getOpenedPanelMapForDashboard,\n LayoutUtils,\n type PanelComponent,\n type PanelMetadata,\n type PanelProps,\n} from '@deephaven/dashboard';\nimport {\n IrisGridUtils,\n type InputFilter,\n type ColumnName,\n type TableSettings,\n} from '@deephaven/iris-grid';\nimport type { dh } from '@deephaven/jsapi-types';\nimport { FadeTransition } from '@deephaven/components';\nimport Log from '@deephaven/log';\nimport {\n getActiveTool,\n getSettings,\n type RootState,\n setActiveTool as setActiveToolAction,\n type WorkspaceSettings,\n} from '@deephaven/redux';\nimport {\n assertNotNull,\n Pending,\n PromiseUtils,\n TextUtils,\n} from '@deephaven/utils';\nimport WidgetPanel from './WidgetPanel';\nimport ToolType from '../linker/ToolType';\nimport { InputFilterEvent } from '../events';\nimport {\n getColumnSelectionValidatorForDashboard,\n getInputFiltersForDashboard,\n getIsolatedLinkerPanelIdForDashboard,\n getLinksForDashboard,\n getTableMapForDashboard,\n setDashboardIsolatedLinkerPanelId as setDashboardIsolatedLinkerPanelIdAction,\n} from '../redux';\nimport ChartFilterOverlay, { type ColumnMap } from './ChartFilterOverlay';\nimport ChartColumnSelectorOverlay, {\n type SelectorColumn,\n} from './ChartColumnSelectorOverlay';\nimport './ChartPanel.scss';\nimport { type Link, type LinkFilterMap } from '../linker/LinkerUtils';\nimport { type PanelState as IrisGridPanelState } from './IrisGridPanel';\nimport {\n isChartPanelFigureMetadata,\n isChartPanelTableMetadata,\n} from './ChartPanelUtils';\nimport { type ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';\nimport { type WidgetPanelDescriptor } from './WidgetPanelTypes';\nimport { emitFilterColumnsChanged } from '../FilterEvents';\nimport { emitLinkPointSelected } from '../linker/LinkerEvent';\n\nconst log = Log.module('ChartPanel');\nconst UPDATE_MODEL_DEBOUNCE = 150;\n\nexport type InputFilterMap = Map<string, InputFilter>;\n\nexport type LinkedColumnMap = Map<string, { name: string; type: string }>;\n\n/** @deprecated Use `PanelMetadata` instead, providing a `name` instead of `figure` */\nexport interface ChartPanelFigureMetadata extends PanelMetadata {\n /**\n * @deprecated use `name` instead\n */\n figure?: string;\n}\n\nexport interface ChartPanelTableMetadata extends PanelMetadata {\n table: string;\n sourcePanelId: string;\n settings: {\n isLinked: boolean;\n title: string;\n xAxis: string;\n series: string[];\n type: keyof dh.plot.SeriesPlotStyle;\n };\n tableSettings: TableSettings;\n}\n\nexport type ChartPanelMetadata =\n | PanelMetadata\n | ChartPanelFigureMetadata\n | ChartPanelTableMetadata;\n\ntype Settings = Record<string, unknown>;\n\nexport interface GLChartPanelState {\n filterValueMap?: [string, unknown][];\n settings: Partial<ChartModelSettings>;\n tableSettings?: TableSettings;\n irisGridState?: {\n advancedFilters: unknown;\n quickFilters: unknown;\n sorts: unknown;\n };\n irisGridPanelState?: {\n partitionColumns: string[];\n partitions: unknown[];\n };\n table?: string;\n figure?: string;\n}\ninterface OwnProps extends DashboardPanelProps {\n metadata: ChartPanelMetadata;\n /** Function to build the ChartModel used by this ChartPanel. Can return a promise. */\n makeModel: () => Promise<ChartModel>;\n localDashboardId: string;\n Plotly?: typeof PlotlyType;\n /**\n * The plot container div.\n * The ref will be undefined on initial render if the chart needs to be loaded.\n */\n containerRef?: React.Ref<HTMLDivElement>;\n\n panelState?: GLChartPanelState;\n}\n\ninterface StateProps {\n inputFilters: InputFilter[];\n links: Link[];\n isLinkerActive: boolean;\n source?: dh.Table;\n sourcePanel?: PanelComponent;\n columnSelectionValidator?: ColumnSelectionValidator;\n settings: Partial<WorkspaceSettings>;\n}\n\ninterface DispatchProps {\n setActiveTool: (tool: string) => void;\n setDashboardIsolatedLinkerPanelId: (\n id: string,\n secondParam: undefined\n ) => void;\n}\n\ninterface ChartPanelState {\n settings: Partial<ChartModelSettings>;\n error?: unknown;\n isActive: boolean;\n isDisconnected: boolean;\n isLoading: boolean;\n isLoaded: boolean;\n isLinked: boolean;\n\n /**\n * Map of all non-empty filters applied to the chart.\n * Initialize the filter map to the previously stored values; input filters will be applied after load.\n */\n filterMap: FilterMap;\n /**\n * Map of filter values set from links, stored in panelState.\n * Combined with inputFilters to get applied filters (filterMap).\n */\n filterValueMap: FilterMap;\n model?: ChartModel;\n columnMap: ColumnMap;\n\n // eslint-disable-next-line react/no-unused-state\n panelState?: GLChartPanelState;\n}\n\ninterface LoadState {\n isLoading: boolean;\n}\n\nfunction hasInputFilter(\n panel: PanelProps\n): panel is PanelProps & { inputFilters: InputFilter[] } {\n return (\n (panel as PanelProps & { inputFilters: InputFilter[] }).inputFilters != null\n );\n}\n\nfunction hasPanelState(\n panel: unknown\n): panel is { panelState: IrisGridPanelState } {\n return (panel as { panelState: IrisGridPanelState }).panelState != null;\n}\n\nexport type ChartPanelProps = OwnProps &\n StateProps &\n DispatchProps &\n React.RefAttributes<ChartPanel>;\n\nexport class ChartPanel extends Component<ChartPanelProps, ChartPanelState> {\n static defaultProps = {\n columnSelectionValidator: null,\n isLinkerActive: false,\n source: null,\n sourcePanel: null,\n panelState: null,\n settings: {},\n containerRef: null,\n };\n\n static displayName = 'ChartPanel';\n\n static COMPONENT = 'ChartPanel';\n\n constructor(props: ChartPanelProps) {\n super(props);\n\n this.handleColumnSelected = this.handleColumnSelected.bind(this);\n this.handleColumnMouseEnter = this.handleColumnMouseEnter.bind(this);\n this.handleColumnMouseLeave = this.handleColumnMouseLeave.bind(this);\n this.handleDisconnect = this.handleDisconnect.bind(this);\n this.handleReconnect = this.handleReconnect.bind(this);\n this.handleFilterAdd = this.handleFilterAdd.bind(this);\n this.handleHide = this.handleHide.bind(this);\n this.handleError = this.handleError.bind(this);\n this.handleLoadError = this.handleLoadError.bind(this);\n this.handleLoadSuccess = this.handleLoadSuccess.bind(this);\n this.handleSettingsChanged = this.handleSettingsChanged.bind(this);\n this.handleOpenLinker = this.handleOpenLinker.bind(this);\n this.handleShow = this.handleShow.bind(this);\n this.handleSourceColumnChange = this.handleSourceColumnChange.bind(this);\n this.handleSourceFilterChange = this.handleSourceFilterChange.bind(this);\n this.handleSourceSortChange = this.handleSourceSortChange.bind(this);\n this.handleTabBlur = this.handleTabBlur.bind(this);\n this.handleTabFocus = this.handleTabFocus.bind(this);\n this.handleUpdate = this.handleUpdate.bind(this);\n this.updateModelFromSource = debounce(\n this.updateModelFromSource.bind(this),\n UPDATE_MODEL_DEBOUNCE\n );\n this.handleClearAllFilters = this.handleClearAllFilters.bind(this);\n\n this.panelContainer = React.createRef();\n this.pending = new Pending();\n\n const { metadata, panelState } = props;\n const { filterValueMap = [], settings = {} } = panelState ?? {};\n\n this.state = {\n settings,\n error: undefined,\n isActive: false,\n isDisconnected: false,\n isLoading: false,\n isLoaded: false,\n isLinked:\n metadata != null &&\n isChartPanelTableMetadata(metadata) &&\n metadata.settings.isLinked,\n\n // Map of all non-empty filters applied to the chart.\n // Initialize the filter map to the previously stored values; input filters will be applied after load.\n filterMap: new Map(filterValueMap),\n // Map of filter values set from links, stored in panelState.\n // Combined with inputFilters to get applied filters (filterMap).\n filterValueMap: new Map(filterValueMap),\n model: undefined,\n columnMap: new Map(),\n\n // eslint-disable-next-line react/no-unused-state\n panelState,\n };\n }\n\n componentDidMount(): void {\n if (!this.isHidden()) {\n this.setState({ isActive: true });\n this.initModel();\n }\n }\n\n componentDidUpdate(\n prevProps: ChartPanelProps,\n prevState: ChartPanelState\n ): void {\n const { inputFilters, source, makeModel } = this.props;\n const { columnMap, model, filterMap, filterValueMap, isLinked, settings } =\n this.state;\n\n if (makeModel !== prevProps.makeModel) {\n this.initModel();\n }\n\n if (model == null) {\n return;\n }\n\n if (columnMap !== prevState.columnMap) {\n this.pruneFilterMaps();\n }\n\n if (inputFilters !== prevProps.inputFilters) {\n this.updateChangedInputFilters(inputFilters, prevProps.inputFilters);\n }\n\n if (filterMap !== prevState.filterMap) {\n this.updateFilters();\n } else if (filterValueMap !== prevState.filterValueMap) {\n this.updatePanelState();\n }\n\n if (settings !== prevState.settings && isFigureChartModel(model)) {\n model.updateSettings(settings);\n this.updatePanelState();\n }\n\n if (isLinked !== prevState.isLinked) {\n if (source) {\n if (isLinked) {\n this.startListeningToSource(source);\n this.updateModelFromSource();\n } else {\n this.stopListeningToSource(source);\n }\n }\n } else if (isLinked && source !== prevProps.source) {\n if (prevProps.source) {\n this.stopListeningToSource(prevProps.source);\n }\n if (source) {\n this.startListeningToSource(source);\n this.updateModelFromSource();\n }\n }\n }\n\n componentWillUnmount(): void {\n this.pending.cancel();\n\n const { model } = this.state;\n const { source } = this.props;\n if (model != null && source) {\n this.stopListeningToSource(source);\n }\n }\n\n panelContainer: RefObject<HTMLDivElement>;\n\n pending: Pending;\n\n initModel(): void {\n this.setState({\n isLoading: true,\n isLoaded: false,\n error: undefined,\n isDisconnected: false,\n });\n\n const { makeModel } = this.props;\n\n this.pending.cancel();\n\n this.pending\n .add(makeModel(), resolved => {\n resolved.close();\n })\n .then(this.handleLoadSuccess, this.handleLoadError);\n }\n\n getWaitingInputMap = memoize(\n (\n isFilterRequired: boolean,\n columnMap: ColumnMap,\n filterMap: FilterMap\n ): Map<string, { name: string; type: string }> => {\n if (!isFilterRequired) {\n return new Map();\n }\n const waitingInputMap = new Map(columnMap);\n filterMap.forEach((filter, name) => {\n waitingInputMap.delete(name);\n });\n return waitingInputMap;\n }\n );\n\n getWaitingFilterMap = memoize(\n (\n isFilterRequired: boolean,\n columnMap: ColumnMap,\n filterMap: FilterMap,\n linkedColumnMap: LinkedColumnMap,\n inputFilterMap: InputFilterMap\n ) => {\n if (!isFilterRequired) {\n return new Map();\n }\n\n const waitingFilterMap = new Map(columnMap);\n filterMap.forEach((filter, name) => {\n waitingFilterMap.delete(name);\n });\n inputFilterMap.forEach((value, name) => {\n waitingFilterMap.delete(name);\n });\n linkedColumnMap.forEach((column, name) => {\n waitingFilterMap.delete(name);\n });\n return waitingFilterMap;\n }\n );\n\n getInputFilterColumnMap = memoize(\n (columnMap: ColumnMap, inputFilters: InputFilter[]) => {\n const inputFilterMap = new Map<string, InputFilter>();\n for (let i = 0; i < inputFilters.length; i += 1) {\n const inputFilter = inputFilters[i];\n const { name, type } = inputFilter;\n const column = columnMap.get(name);\n if (column != null && column.type === type) {\n inputFilterMap.set(name, inputFilter);\n }\n }\n return inputFilterMap;\n }\n );\n\n getLinkedColumnMap = memoize((columnMap: ColumnMap, links: Link[]) => {\n const linkedColumnMap = new Map<string, { name: string; type: string }>();\n const panelId = LayoutUtils.getIdFromPanel(this);\n for (let i = 0; i < links.length; i += 1) {\n const link = links[i];\n let columnName = null;\n if (\n link.start != null &&\n link.start.panelId === panelId &&\n columnMap.has(link.start.columnName)\n ) {\n columnName = link.start.columnName;\n } else if (\n link.end &&\n link.end.panelId === panelId &&\n columnMap.has(link.end.columnName)\n ) {\n columnName = link.end.columnName;\n }\n\n if (columnName != null && columnMap.has(columnName)) {\n const column = columnMap.get(columnName);\n assertNotNull(column);\n linkedColumnMap.set(columnName, column);\n }\n }\n return linkedColumnMap;\n });\n\n getSelectorColumns = memoize(\n (\n columnMap: ColumnMap,\n linkedColumnMap: LinkedColumnMap,\n columnSelectionValidator?: ColumnSelectionValidator\n ) =>\n Array.from(columnMap.values()).map(column => ({\n name: column.name,\n type: column.type,\n isValid: columnSelectionValidator\n ? columnSelectionValidator(this, column, { type: 'chartLink' })\n : false,\n isActive: linkedColumnMap.has(column.name),\n }))\n );\n\n getWidgetPanelDescriptor = memoize(\n (metadata: ChartPanelProps['metadata']): WidgetPanelDescriptor => {\n let name = 'Chart';\n if (isChartPanelTableMetadata(metadata)) {\n name = metadata.table;\n } else if (isChartPanelFigureMetadata(metadata)) {\n name = metadata.figure ?? name;\n } else {\n name = metadata.name ?? name;\n }\n return {\n ...metadata,\n type: 'Chart',\n name,\n };\n }\n );\n\n startListeningToSource(table: dh.Table): void {\n log.debug('startListeningToSource', table);\n const { model } = this.state;\n assertNotNull(model);\n const { dh } = model;\n table.addEventListener(\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n this.handleSourceColumnChange\n );\n table.addEventListener(\n dh.Table.EVENT_FILTERCHANGED,\n this.handleSourceFilterChange\n );\n table.addEventListener(\n dh.Table.EVENT_SORTCHANGED,\n this.handleSourceSortChange\n );\n }\n\n stopListeningToSource(table: dh.Table): void {\n log.debug('stopListeningToSource', table);\n const { model } = this.state;\n assertNotNull(model);\n const { dh } = model;\n table.removeEventListener(\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n this.handleSourceColumnChange\n );\n table.removeEventListener(\n dh.Table.EVENT_FILTERCHANGED,\n this.handleSourceFilterChange\n );\n table.removeEventListener(\n dh.Table.EVENT_SORTCHANGED,\n this.handleSourceSortChange\n );\n }\n\n loadModelIfNecessary(): void {\n const { isActive, isLoaded, isLoading } = this.state;\n if (isActive && !isLoaded && !isLoading) {\n this.initModel();\n }\n }\n\n isHidden(): boolean {\n const { glContainer } = this.props;\n const { isHidden } = glContainer;\n return isHidden;\n }\n\n handleColumnSelected(columnName: string): void {\n const { glEventHub } = this.props;\n const { columnMap } = this.state;\n const panelId = LayoutUtils.getIdFromPanel(this);\n assertNotNull(panelId);\n const column = columnMap.get(columnName);\n if (column == null) {\n return;\n }\n emitLinkPointSelected(glEventHub, panelId, column, {\n type: 'chartLink',\n });\n }\n\n handleColumnMouseEnter({ type, name }: SelectorColumn): void {\n const { columnSelectionValidator } = this.props;\n log.debug('handleColumnMouseEnter', columnSelectionValidator, type, name);\n if (!columnSelectionValidator) {\n return;\n }\n columnSelectionValidator(this, { type, name }, { type: 'chartLink' });\n }\n\n handleColumnMouseLeave(): void {\n const { columnSelectionValidator } = this.props;\n log.debug('handleColumnMouseLeave', columnSelectionValidator);\n if (!columnSelectionValidator) {\n return;\n }\n columnSelectionValidator(this, undefined, { type: 'chartLink' });\n }\n\n handleDisconnect(): void {\n this.setState({\n error: new Error('Figure disconnected'),\n isDisconnected: true,\n });\n }\n\n handleFilterAdd(columns: InputFilter[]): void {\n for (let i = 0; i < columns.length; i += 1) {\n this.openInputFilter(columns[i]);\n }\n }\n\n handleOpenLinker(): void {\n const {\n localDashboardId,\n setActiveTool,\n setDashboardIsolatedLinkerPanelId,\n } = this.props;\n setDashboardIsolatedLinkerPanelId(localDashboardId, undefined);\n setActiveTool(ToolType.LINKER);\n }\n\n handleReconnect(): void {\n this.setState({ isDisconnected: false, error: undefined });\n this.sendColumnChange();\n this.updateColumnFilters();\n }\n\n handleLoadSuccess(model: ChartModel): void {\n log.debug('handleLoadSuccess');\n\n const { model: prevModel } = this.state;\n this.setState(\n {\n model,\n isLoaded: true,\n },\n () => {\n const { inputFilters, source } = this.props;\n const { filterMap, isLinked } = this.state;\n if (model !== prevModel) {\n this.sendColumnChange();\n this.updateColumnFilters();\n this.updateInputFilters(\n inputFilters,\n filterMap.size > 0 || model.isFilterRequired()\n );\n if (source && isLinked) {\n this.startListeningToSource(source);\n this.updateModelFromSource();\n }\n }\n }\n );\n }\n\n handleLoadError(error: unknown): void {\n if (PromiseUtils.isCanceled(error)) {\n return;\n }\n\n log.error('handleLoadError', error);\n this.setState({ error, isLoading: false });\n }\n\n handleSourceColumnChange(): void {\n this.updateModelFromSource();\n }\n\n handleSourceFilterChange(): void {\n this.updateModelFromSource();\n }\n\n handleSourceSortChange(): void {\n this.updateModelFromSource();\n }\n\n updateModelFromSource(): void {\n const { metadata, source } = this.props;\n const { isLinked, model } = this.state;\n if (!isLinked || !model || !source) {\n log.debug2('updateModelFromSource ignoring', isLinked, model, source);\n return;\n }\n const { dh } = model;\n // By now the model has already been loaded, which is the only other cancelable thing in pending\n this.pending.cancel();\n if (isChartPanelTableMetadata(metadata)) {\n const { settings } = metadata;\n this.pending\n .add(\n ChartModelFactory.makeFigureFromSettings(dh, settings, source),\n resolved => resolved.close()\n )\n .then(figure => {\n if (isFigureChartModel(model)) {\n model.setFigure(figure);\n }\n })\n .catch(this.handleLoadError);\n }\n\n this.updatePanelState();\n }\n\n updatePanelState(): void {\n const { sourcePanel } = this.props;\n const { panelState, filterValueMap, settings } = this.state;\n let { tableSettings } = panelState ?? {};\n if (sourcePanel) {\n // Right now just update the panel state from the source\n // If the source isn't available, just keep the state that's already saved\n if (\n hasInputFilter(sourcePanel.props) &&\n hasPanelState(sourcePanel.state)\n ) {\n const { inputFilters } = sourcePanel.props;\n const { panelState: sourcePanelState } = sourcePanel.state;\n if (sourcePanelState != null) {\n tableSettings = IrisGridUtils.extractTableSettings(\n sourcePanelState,\n inputFilters\n );\n }\n }\n }\n\n // eslint-disable-next-line react/no-unused-state\n this.setState({\n panelState: {\n settings,\n tableSettings,\n filterValueMap: Array.from(filterValueMap),\n },\n });\n }\n\n handleError(): void {\n // Don't want to set an error state, because the user can fix a chart error within the chart itself.\n // We're not loading anymore either so stop showing the spinner so the user can actually click those buttons.\n this.setState({ isLoading: false });\n }\n\n handleSettingsChanged(update: Partial<Settings>): void {\n this.setState(({ settings: prevSettings }) => {\n const settings = {\n ...prevSettings,\n ...update,\n };\n log.debug('Updated settings', settings);\n return { settings };\n });\n }\n\n handleHide(): void {\n this.setActive(false);\n }\n\n handleShow(): void {\n this.setActive(true);\n }\n\n handleTabBlur(): void {\n this.setActive(false);\n }\n\n handleTabFocus(): void {\n const isHidden = this.isHidden();\n this.setActive(!isHidden);\n }\n\n handleUpdate({ isLoading }: LoadState): void {\n this.setState({ isLoading });\n }\n\n handleClearAllFilters(): void {\n // nuke link filter and input filter map\n // input filters only clear themselves if they are not yet empty\n this.setState({\n filterValueMap: new Map(),\n filterMap: new Map(),\n });\n this.updatePanelState();\n }\n\n /**\n * Create an input filter panel for the provided column\n * @param column The column to create the input filter for\n */\n openInputFilter(column: InputFilter): void {\n const { glEventHub } = this.props;\n const { name, type } = column;\n glEventHub.emit(InputFilterEvent.OPEN_INPUT, {\n title: `${name} Filter`,\n panelState: {\n name,\n type,\n isValueShown: true,\n },\n createNewStack: true,\n focusElement: 'input',\n });\n }\n\n setActive(isActive: boolean): void {\n this.setState({ isActive }, () => {\n if (isActive) {\n this.loadModelIfNecessary();\n }\n });\n }\n\n sendColumnChange(): void {\n const { model } = this.state;\n if (!model) {\n return;\n }\n const { glEventHub } = this.props;\n const panelId = LayoutUtils.getIdFromPanel(this);\n assertNotNull(panelId);\n emitFilterColumnsChanged(\n glEventHub,\n panelId,\n Array.from(model.getFilterColumnMap().values())\n );\n }\n\n getCoordinateForColumn(columnName: ColumnName): [number, number] | null {\n const className =\n ChartColumnSelectorOverlay.makeButtonClassName(columnName);\n\n if (!this.panelContainer.current) {\n return null;\n }\n\n const element = this.panelContainer.current.querySelector(`.${className}`);\n const rect = element?.getBoundingClientRect() ?? null;\n if (rect == null || rect.width <= 0 || rect.height <= 0) {\n return null;\n }\n const x = rect.left + rect.width / 2;\n const y = rect.bottom;\n return [x, y];\n }\n\n /**\n * Set chart filters based on the filter map\n * @param filterMapParam Filter map\n */\n setFilterMap(filterMapParam: LinkFilterMap): void {\n log.debug('setFilterMap', filterMapParam);\n this.setState(state => {\n const { columnMap, filterMap } = state;\n let updatedFilterMap: null | FilterMap = null;\n const filterValueMap = new Map(state.filterValueMap);\n filterMapParam.forEach(({ columnType, filterList }, columnName) => {\n const column = columnMap.get(columnName);\n if (column == null || column.type !== columnType) {\n return;\n }\n if (filterList.length === 0) {\n log.debug('Ignoring empty filterList for column', columnName);\n return;\n }\n const { value } = filterList[0];\n filterValueMap.set(columnName, value);\n if (filterMap.get(columnName) !== value) {\n if (updatedFilterMap === null) {\n updatedFilterMap = new Map(filterMap);\n }\n updatedFilterMap.set(columnName, value);\n }\n });\n\n // Don't update filterMap unless the filters actually changed.\n // Otherwise the chart gets stuck on a spinner\n // because it never gets an update event for unchanged filters.\n return { filterValueMap, filterMap: updatedFilterMap ?? filterMap };\n });\n }\n\n unsetFilterValue(columnName: ColumnName): void {\n this.setState(state => {\n // We want to unset a value unless there's an input filter for it\n // If there's an input filter, then we want to just set it to that value\n // This way if the user has an input filter and a link, when they delete the link the input filter value takes effect\n const { inputFilters } = this.props;\n const { columnMap } = state;\n let { filterMap, filterValueMap } = state;\n if (!filterValueMap.has(columnName)) {\n return null;\n }\n\n filterValueMap = new Map(state.filterValueMap);\n filterValueMap.delete(columnName);\n\n const inputFilterMap = this.getInputFilterColumnMap(\n columnMap,\n inputFilters\n );\n\n if (inputFilterMap.has(columnName)) {\n const filterValue = filterMap.get(columnName);\n const inputFilterValue = inputFilterMap.get(columnName)?.value;\n if (inputFilterValue != null && filterValue !== inputFilterValue) {\n filterMap = new Map(state.filterMap);\n if (inputFilterValue.length > 0) {\n filterMap.set(columnName, inputFilterValue);\n } else {\n filterMap.delete(columnName);\n }\n }\n } else {\n filterMap = new Map(state.filterMap);\n filterMap.delete(columnName);\n }\n return { filterMap, filterValueMap };\n });\n }\n\n updateChangedInputFilters(\n inputFilters: InputFilter[],\n prevInputFilters: InputFilter[]\n ): void {\n const deletedInputFilters = prevInputFilters.filter(\n prevInputFilter =>\n inputFilters.find(\n inputFilter =>\n inputFilter.name === prevInputFilter.name &&\n inputFilter.type === prevInputFilter.type\n ) === undefined\n );\n if (deletedInputFilters.length > 0) {\n this.deleteInputFilters(deletedInputFilters);\n }\n\n const changedInputFilters = inputFilters.filter(\n inputFilter => !prevInputFilters.includes(inputFilter)\n );\n if (changedInputFilters.length > 0) {\n this.updateInputFilters(changedInputFilters);\n }\n }\n\n updateInputFilters(inputFilters: InputFilter[], forceUpdate = false): void {\n this.setState(state => {\n const { columnMap } = state;\n const filterValueMap = new Map(state.filterValueMap);\n const filterMap = new Map(state.filterMap);\n const update = forceUpdate ? { filterMap, filterValueMap } : {};\n\n for (let i = 0; i < inputFilters.length; i += 1) {\n const { name, type, value } = inputFilters[i];\n const column = columnMap.get(name);\n if (column != null && column.type === type) {\n if (value != null && filterMap.get(name) !== value) {\n if (value === '') {\n filterMap.delete(name);\n } else {\n filterMap.set(name, value);\n }\n update.filterMap = filterMap;\n }\n\n if (filterValueMap.has(name)) {\n // Need to unset whatever the linked value was - if they want that value again, they need to double click the link again\n filterValueMap.delete(name);\n update.filterValueMap = filterValueMap;\n }\n }\n }\n\n log.debug('updateInputFilters', update);\n return update as unknown;\n });\n }\n\n deleteInputFilters(inputFilters: InputFilter[], forceUpdate = false): void {\n this.setState(state => {\n const { columnMap, filterValueMap } = state;\n const filterMap = new Map(state.filterMap);\n let needsUpdate = forceUpdate;\n\n for (let i = 0; i < inputFilters.length; i += 1) {\n const { name, type } = inputFilters[i];\n const column = columnMap.get(name);\n if (column != null && column.type === type) {\n if (filterMap.has(name)) {\n const filterValue = filterMap.get(name);\n if (filterValueMap.has(name)) {\n const linkValue = filterValueMap.get(name);\n if (linkValue !== filterValue && linkValue != null) {\n needsUpdate = true;\n filterMap.set(name, linkValue);\n }\n } else {\n needsUpdate = true;\n filterMap.delete(name);\n }\n }\n }\n }\n\n log.debug('deleteInputFilters', needsUpdate);\n return needsUpdate ? { filterMap } : null;\n });\n }\n\n updateColumnFilters(): void {\n this.setState(({ model }) => {\n if (!model) {\n return null;\n }\n\n return { columnMap: model.getFilterColumnMap() };\n });\n }\n\n updateFilters(): void {\n const { columnMap, filterMap, model } = this.state;\n assertNotNull(model);\n const waitingInputMap = this.getWaitingInputMap(\n model.isFilterRequired(),\n columnMap,\n filterMap\n );\n model.setFilter(filterMap);\n\n if (filterMap.size > 0 && waitingInputMap.size === 0) {\n const defaultTitle = model.getDefaultTitle();\n const filterTitle = TextUtils.join(\n Array.from(filterMap.entries()).map(\n ([name, value]) => `${name}: ${value}`\n )\n );\n if (defaultTitle) {\n model.setTitle(\n `${defaultTitle}<br><span style=\"font-size: smaller\">${filterTitle}</span>`\n );\n } else {\n model.setTitle(filterTitle);\n }\n\n log.debug2('updateFilters filters set', filterMap);\n this.setState({ isLoading: true });\n } else {\n log.debug2('updateFilters waiting on inputs', waitingInputMap);\n model.setTitle(model.getDefaultTitle());\n this.setState({ isLoading: false });\n }\n\n this.updatePanelState();\n }\n\n /**\n * Removes any set filter values that are no longer part of the model\n */\n pruneFilterMaps(): void {\n this.setState(state => {\n const { columnMap } = state;\n const filterMap = new Map(state.filterMap);\n const filterValueMap = new Map(state.filterValueMap);\n const newState: Pick<\n Partial<ChartPanelState>,\n 'filterMap' | 'filterValueMap'\n > = {};\n\n state.filterValueMap.forEach((value, name) => {\n if (!columnMap.has(name)) {\n filterValueMap.delete(name);\n newState.filterValueMap = filterValueMap;\n }\n });\n state.filterMap.forEach((value, name) => {\n if (!columnMap.has(name)) {\n filterMap.delete(name);\n newState.filterMap = filterMap;\n }\n });\n return newState as unknown;\n });\n }\n\n render(): ReactElement {\n const {\n columnSelectionValidator,\n glContainer,\n glEventHub,\n inputFilters,\n isLinkerActive,\n links,\n metadata,\n settings,\n Plotly,\n containerRef,\n } = this.props;\n const {\n columnMap,\n filterMap,\n error,\n model,\n isActive,\n isDisconnected,\n isLoaded,\n isLoading,\n } = this.state;\n const inputFilterMap = this.getInputFilterColumnMap(\n columnMap,\n inputFilters\n );\n const linkedColumnMap = this.getLinkedColumnMap(columnMap, links);\n const waitingInputMap =\n model != null\n ? this.getWaitingInputMap(\n model.isFilterRequired(),\n columnMap,\n filterMap\n )\n : new Map();\n const waitingFilterMap =\n model != null\n ? this.getWaitingFilterMap(\n model.isFilterRequired(),\n columnMap,\n filterMap,\n linkedColumnMap,\n inputFilterMap\n )\n : new Map();\n const errorMessage =\n error != null ? `Unable to open chart. ${error}` : undefined;\n const isWaitingForFilter = waitingInputMap.size > 0;\n const isSelectingColumn = columnMap.size > 0 && isLinkerActive;\n const descriptor = this.getWidgetPanelDescriptor(metadata);\n return (\n <WidgetPanel\n className={classNames('iris-chart-panel', {\n 'input-required': isWaitingForFilter,\n })}\n componentPanel={this}\n glContainer={glContainer}\n glEventHub={glEventHub}\n onHide={this.handleHide}\n onClearAllFilters={this.handleClearAllFilters}\n onShow={this.handleShow}\n onTabBlur={this.handleTabBlur}\n onTabFocus={this.handleTabFocus}\n errorMessage={errorMessage}\n isDisconnected={isDisconnected}\n isLoading={isLoading}\n isLoaded={isLoaded}\n descriptor={descriptor}\n >\n <div\n ref={this.panelContainer}\n className=\"chart-panel-container h-100 w-100\"\n >\n <div className=\"chart-container h-100 w-100\">\n {isLoaded && model && (\n <Chart\n isActive={isActive}\n model={model}\n settings={settings}\n onDisconnect={this.handleDisconnect}\n onReconnect={this.handleReconnect}\n onUpdate={this.handleUpdate}\n onError={this.handleError}\n onSettingsChanged={this.handleSettingsChanged}\n Plotly={Plotly}\n containerRef={containerRef}\n />\n )}\n </div>\n <FadeTransition\n in={isWaitingForFilter && !isSelectingColumn && !isLoading}\n mountOnEnter\n unmountOnExit\n >\n <ChartFilterOverlay\n inputFilterMap={inputFilterMap}\n linkedColumnMap={linkedColumnMap}\n onAdd={this.handleFilterAdd}\n onOpenLinker={this.handleOpenLinker}\n columnMap={columnMap}\n waitingFilterMap={waitingFilterMap}\n waitingInputMap={waitingInputMap}\n />\n </FadeTransition>\n <FadeTransition in={isSelectingColumn} mountOnEnter unmountOnExit>\n <ChartColumnSelectorOverlay\n columns={this.getSelectorColumns(\n columnMap,\n linkedColumnMap,\n columnSelectionValidator\n )}\n onColumnSelected={this.handleColumnSelected}\n onMouseEnter={this.handleColumnMouseEnter}\n onMouseLeave={this.handleColumnMouseLeave}\n />\n </FadeTransition>\n </div>\n </WidgetPanel>\n );\n }\n}\n\nconst mapStateToProps = (state: RootState, ownProps: OwnProps): StateProps => {\n const { localDashboardId, metadata } = ownProps;\n\n let sourcePanelId: string | undefined;\n if (metadata != null && isChartPanelTableMetadata(metadata)) {\n sourcePanelId = metadata.sourcePanelId;\n }\n const panelTableMap = getTableMapForDashboard(state, localDashboardId);\n const openedPanelMap = getOpenedPanelMapForDashboard(state, localDashboardId);\n const activeTool = getActiveTool(state);\n const isolatedLinkerPanelId = getIsolatedLinkerPanelIdForDashboard(\n state,\n localDashboardId\n );\n const isLinkerActive =\n activeTool === ToolType.LINKER && isolatedLinkerPanelId === undefined;\n return {\n columnSelectionValidator: getColumnSelectionValidatorForDashboard(\n state,\n localDashboardId\n ),\n isLinkerActive,\n inputFilters: getInputFiltersForDashboard(state, localDashboardId),\n links: getLinksForDashboard(state, localDashboardId),\n source:\n sourcePanelId != null ? panelTableMap.get(sourcePanelId) : undefined,\n sourcePanel:\n sourcePanelId != null ? openedPanelMap.get(sourcePanelId) : undefined,\n settings: getSettings(state),\n };\n};\n\nconst ConnectedChartPanel = connect(\n mapStateToProps,\n {\n setActiveTool: setActiveToolAction,\n setDashboardIsolatedLinkerPanelId: setDashboardIsolatedLinkerPanelIdAction,\n } satisfies DispatchProps,\n null,\n { forwardRef: true }\n)(ChartPanel);\n\nexport default ConnectedChartPanel;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"ChartPanel.js","names":["React","Component","classNames","memoize","connect","debounce","Chart","ChartModelFactory","isFigureChartModel","getOpenedPanelMapForDashboard","LayoutUtils","IrisGridUtils","FadeTransition","Log","getActiveTool","getSettings","setActiveTool","setActiveToolAction","assertNotNull","Pending","PromiseUtils","TextUtils","WidgetPanel","ToolType","InputFilterEvent","getColumnSelectionValidatorForDashboard","getInputFiltersForDashboard","getIsolatedLinkerPanelIdForDashboard","getLinksForDashboard","getTableMapForDashboard","setDashboardIsolatedLinkerPanelId","setDashboardIsolatedLinkerPanelIdAction","ChartFilterOverlay","ChartColumnSelectorOverlay","isChartPanelFigureMetadata","isChartPanelTableMetadata","emitFilterColumnsChanged","emitLinkPointSelected","jsx","_jsx","jsxs","_jsxs","log","module","UPDATE_MODEL_DEBOUNCE","hasInputFilter","panel","inputFilters","hasPanelState","panelState","ChartPanel","constructor","props","_defineProperty","isFilterRequired","columnMap","filterMap","Map","waitingInputMap","forEach","filter","name","delete","linkedColumnMap","inputFilterMap","waitingFilterMap","value","column","i","length","inputFilter","type","get","set","links","panelId","getIdFromPanel","link","columnName","start","has","end","columnSelectionValidator","Array","from","values","map","isValid","isActive","metadata","table","_metadata$figure","figure","_metadata$name","_objectSpread","handleColumnSelected","bind","handleColumnMouseEnter","handleColumnMouseLeave","handleDisconnect","handleReconnect","handleFilterAdd","handleHide","handleError","handleLoadError","handleLoadSuccess","handleSettingsChanged","handleOpenLinker","handleShow","handleSourceColumnChange","handleSourceFilterChange","handleSourceSortChange","handleTabBlur","handleTabFocus","handleUpdate","updateModelFromSource","handleClearAllFilters","panelContainer","createRef","pending","filterValueMap","settings","state","error","undefined","isDisconnected","isLoading","isLoaded","isLinked","model","componentDidMount","isHidden","setState","initModel","componentDidUpdate","prevProps","prevState","source","makeModel","pruneFilterMaps","updateChangedInputFilters","updateFilters","updatePanelState","updateSettings","startListeningToSource","stopListeningToSource","componentWillUnmount","cancel","add","resolved","close","then","debug","dh","addEventListener","Table","EVENT_CUSTOMCOLUMNSCHANGED","EVENT_FILTERCHANGED","EVENT_SORTCHANGED","removeEventListener","loadModelIfNecessary","glContainer","glEventHub","_ref","Error","columns","openInputFilter","localDashboardId","LINKER","sendColumnChange","updateColumnFilters","prevModel","updateInputFilters","size","isCanceled","debug2","makeFigureFromSettings","setFigure","catch","sourcePanel","tableSettings","sourcePanelState","extractTableSettings","update","_ref2","prevSettings","setActive","_ref3","emit","OPEN_INPUT","title","concat","isValueShown","createNewStack","focusElement","getFilterColumnMap","getCoordinateForColumn","_element$getBoundingC","className","makeButtonClassName","current","element","querySelector","rect","getBoundingClientRect","width","height","x","left","y","bottom","setFilterMap","filterMapParam","_updatedFilterMap","updatedFilterMap","_ref4","columnType","filterList","unsetFilterValue","getInputFilterColumnMap","_inputFilterMap$get","filterValue","inputFilterValue","prevInputFilters","deletedInputFilters","prevInputFilter","find","deleteInputFilters","changedInputFilters","includes","forceUpdate","arguments","needsUpdate","linkValue","_ref5","getWaitingInputMap","setFilter","defaultTitle","getDefaultTitle","filterTitle","join","entries","_ref6","setTitle","newState","render","isLinkerActive","Plotly","containerRef","getLinkedColumnMap","getWaitingFilterMap","errorMessage","isWaitingForFilter","isSelectingColumn","descriptor","getWidgetPanelDescriptor","componentPanel","onHide","onClearAllFilters","onShow","onTabBlur","onTabFocus","children","ref","onDisconnect","onReconnect","onUpdate","onError","onSettingsChanged","in","mountOnEnter","unmountOnExit","onAdd","onOpenLinker","getSelectorColumns","onColumnSelected","onMouseEnter","onMouseLeave","mapStateToProps","ownProps","sourcePanelId","panelTableMap","openedPanelMap","activeTool","isolatedLinkerPanelId","ConnectedChartPanel","forwardRef"],"sources":["../../src/panels/ChartPanel.tsx"],"sourcesContent":["import React, { Component, type ReactElement, type RefObject } from 'react';\nimport classNames from 'classnames';\nimport memoize from 'memoize-one';\nimport { connect } from 'react-redux';\nimport debounce from 'lodash.debounce';\nimport {\n Chart,\n type ChartModel,\n ChartModelFactory,\n type ChartModelSettings,\n type FilterMap,\n isFigureChartModel,\n} from '@deephaven/chart';\nimport type PlotlyType from 'plotly.js';\nimport {\n type DashboardPanelProps,\n getOpenedPanelMapForDashboard,\n LayoutUtils,\n type PanelComponent,\n type PanelMetadata,\n type PanelProps,\n} from '@deephaven/dashboard';\nimport {\n IrisGridUtils,\n type InputFilter,\n type ColumnName,\n type TableSettings,\n} from '@deephaven/iris-grid';\nimport type { dh } from '@deephaven/jsapi-types';\nimport { FadeTransition } from '@deephaven/components';\nimport Log from '@deephaven/log';\nimport {\n getActiveTool,\n getSettings,\n type RootState,\n setActiveTool as setActiveToolAction,\n type WorkspaceSettings,\n} from '@deephaven/redux';\nimport {\n assertNotNull,\n Pending,\n PromiseUtils,\n TextUtils,\n} from '@deephaven/utils';\nimport WidgetPanel from './WidgetPanel';\nimport ToolType from '../linker/ToolType';\nimport { InputFilterEvent } from '../events';\nimport {\n getColumnSelectionValidatorForDashboard,\n getInputFiltersForDashboard,\n getIsolatedLinkerPanelIdForDashboard,\n getLinksForDashboard,\n getTableMapForDashboard,\n setDashboardIsolatedLinkerPanelId as setDashboardIsolatedLinkerPanelIdAction,\n} from '../redux';\nimport ChartFilterOverlay, { type ColumnMap } from './ChartFilterOverlay';\nimport ChartColumnSelectorOverlay, {\n type SelectorColumn,\n} from './ChartColumnSelectorOverlay';\nimport './ChartPanel.scss';\nimport { type Link, type LinkFilterMap } from '../linker/LinkerUtils';\nimport { type PanelState as IrisGridPanelState } from './IrisGridPanel';\nimport {\n isChartPanelFigureMetadata,\n isChartPanelTableMetadata,\n} from './ChartPanelUtils';\nimport { type ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';\nimport { type WidgetPanelDescriptor } from './WidgetPanelTypes';\nimport { emitFilterColumnsChanged } from '../FilterEvents';\nimport { emitLinkPointSelected } from '../linker/LinkerEvent';\n\nconst log = Log.module('ChartPanel');\nconst UPDATE_MODEL_DEBOUNCE = 150;\n\nexport type InputFilterMap = Map<string, InputFilter>;\n\nexport type LinkedColumnMap = Map<string, { name: string; type: string }>;\n\n/** @deprecated Use `PanelMetadata` instead, providing a `name` instead of `figure` */\nexport interface ChartPanelFigureMetadata extends PanelMetadata {\n /**\n * @deprecated use `name` instead\n */\n figure?: string;\n}\n\nexport interface ChartPanelTableMetadata extends PanelMetadata {\n table: string;\n sourcePanelId: string;\n settings: {\n isLinked: boolean;\n title: string;\n xAxis: string;\n series: string[];\n type: keyof dh.plot.SeriesPlotStyle;\n };\n tableSettings: TableSettings;\n}\n\nexport type ChartPanelMetadata =\n | PanelMetadata\n | ChartPanelFigureMetadata\n | ChartPanelTableMetadata;\n\ntype Settings = Record<string, unknown>;\n\nexport interface GLChartPanelState {\n filterValueMap?: [string, unknown][];\n settings: Partial<ChartModelSettings>;\n tableSettings?: TableSettings;\n irisGridState?: {\n advancedFilters: unknown;\n quickFilters: unknown;\n sorts: unknown;\n };\n irisGridPanelState?: {\n partitionColumns: string[];\n partitions: unknown[];\n };\n table?: string;\n figure?: string;\n}\ninterface OwnProps extends DashboardPanelProps {\n metadata: ChartPanelMetadata;\n /** Function to build the ChartModel used by this ChartPanel. Can return a promise. */\n makeModel: () => Promise<ChartModel>;\n localDashboardId: string;\n Plotly?: typeof PlotlyType;\n /**\n * The plot container div.\n * The ref will be undefined on initial render if the chart needs to be loaded.\n */\n containerRef?: React.Ref<HTMLDivElement>;\n\n panelState?: GLChartPanelState;\n}\n\ninterface StateProps {\n inputFilters: InputFilter[];\n links: Link[];\n isLinkerActive: boolean;\n source?: dh.Table;\n sourcePanel?: PanelComponent;\n columnSelectionValidator?: ColumnSelectionValidator;\n settings: Partial<WorkspaceSettings>;\n}\n\ninterface DispatchProps {\n setActiveTool: (tool: string) => void;\n setDashboardIsolatedLinkerPanelId: (\n id: string,\n secondParam: undefined\n ) => void;\n}\n\ninterface ChartPanelState {\n settings: Partial<ChartModelSettings>;\n error?: unknown;\n isActive: boolean;\n isDisconnected: boolean;\n isLoading: boolean;\n isLoaded: boolean;\n isLinked: boolean;\n\n /**\n * Map of all non-empty filters applied to the chart.\n * Initialize the filter map to the previously stored values; input filters will be applied after load.\n */\n filterMap: FilterMap;\n /**\n * Map of filter values set from links, stored in panelState.\n * Combined with inputFilters to get applied filters (filterMap).\n */\n filterValueMap: FilterMap;\n model?: ChartModel;\n columnMap: ColumnMap;\n\n // eslint-disable-next-line react/no-unused-state\n panelState?: GLChartPanelState;\n}\n\ninterface LoadState {\n isLoading: boolean;\n}\n\nfunction hasInputFilter(\n panel: PanelProps\n): panel is PanelProps & { inputFilters: InputFilter[] } {\n return (\n (panel as PanelProps & { inputFilters: InputFilter[] }).inputFilters != null\n );\n}\n\nfunction hasPanelState(\n panel: unknown\n): panel is { panelState: IrisGridPanelState } {\n return (panel as { panelState: IrisGridPanelState }).panelState != null;\n}\n\nexport type ChartPanelProps = OwnProps &\n StateProps &\n DispatchProps &\n React.RefAttributes<ChartPanel>;\n\nexport class ChartPanel extends Component<ChartPanelProps, ChartPanelState> {\n static defaultProps = {\n columnSelectionValidator: null,\n isLinkerActive: false,\n source: null,\n sourcePanel: null,\n panelState: null,\n settings: {},\n containerRef: null,\n };\n\n static displayName = 'ChartPanel';\n\n static COMPONENT = 'ChartPanel';\n\n constructor(props: ChartPanelProps) {\n super(props);\n\n this.handleColumnSelected = this.handleColumnSelected.bind(this);\n this.handleColumnMouseEnter = this.handleColumnMouseEnter.bind(this);\n this.handleColumnMouseLeave = this.handleColumnMouseLeave.bind(this);\n this.handleDisconnect = this.handleDisconnect.bind(this);\n this.handleReconnect = this.handleReconnect.bind(this);\n this.handleFilterAdd = this.handleFilterAdd.bind(this);\n this.handleHide = this.handleHide.bind(this);\n this.handleError = this.handleError.bind(this);\n this.handleLoadError = this.handleLoadError.bind(this);\n this.handleLoadSuccess = this.handleLoadSuccess.bind(this);\n this.handleSettingsChanged = this.handleSettingsChanged.bind(this);\n this.handleOpenLinker = this.handleOpenLinker.bind(this);\n this.handleShow = this.handleShow.bind(this);\n this.handleSourceColumnChange = this.handleSourceColumnChange.bind(this);\n this.handleSourceFilterChange = this.handleSourceFilterChange.bind(this);\n this.handleSourceSortChange = this.handleSourceSortChange.bind(this);\n this.handleTabBlur = this.handleTabBlur.bind(this);\n this.handleTabFocus = this.handleTabFocus.bind(this);\n this.handleUpdate = this.handleUpdate.bind(this);\n this.updateModelFromSource = debounce(\n this.updateModelFromSource.bind(this),\n UPDATE_MODEL_DEBOUNCE\n );\n this.handleClearAllFilters = this.handleClearAllFilters.bind(this);\n\n this.panelContainer = React.createRef();\n this.pending = new Pending();\n\n const { metadata, panelState } = props;\n const { filterValueMap = [], settings = {} } = panelState ?? {};\n\n this.state = {\n settings,\n error: undefined,\n isActive: false,\n isDisconnected: false,\n isLoading: false,\n isLoaded: false,\n isLinked:\n metadata != null &&\n isChartPanelTableMetadata(metadata) &&\n metadata.settings.isLinked,\n\n // Map of all non-empty filters applied to the chart.\n // Initialize the filter map to the previously stored values; input filters will be applied after load.\n filterMap: new Map(filterValueMap),\n // Map of filter values set from links, stored in panelState.\n // Combined with inputFilters to get applied filters (filterMap).\n filterValueMap: new Map(filterValueMap),\n model: undefined,\n columnMap: new Map(),\n\n // eslint-disable-next-line react/no-unused-state\n panelState,\n };\n }\n\n componentDidMount(): void {\n if (!this.isHidden()) {\n this.setState({ isActive: true });\n this.initModel();\n }\n }\n\n componentDidUpdate(\n prevProps: ChartPanelProps,\n prevState: ChartPanelState\n ): void {\n const { inputFilters, source, makeModel } = this.props;\n const { columnMap, model, filterMap, filterValueMap, isLinked, settings } =\n this.state;\n\n if (makeModel !== prevProps.makeModel) {\n this.initModel();\n }\n\n if (model == null) {\n return;\n }\n\n if (columnMap !== prevState.columnMap) {\n this.pruneFilterMaps();\n }\n\n if (inputFilters !== prevProps.inputFilters) {\n this.updateChangedInputFilters(inputFilters, prevProps.inputFilters);\n }\n\n if (filterMap !== prevState.filterMap) {\n this.updateFilters();\n } else if (filterValueMap !== prevState.filterValueMap) {\n this.updatePanelState();\n }\n\n if (settings !== prevState.settings && isFigureChartModel(model)) {\n model.updateSettings(settings);\n this.updatePanelState();\n }\n\n if (isLinked !== prevState.isLinked) {\n if (source) {\n if (isLinked) {\n this.startListeningToSource(source);\n this.updateModelFromSource();\n } else {\n this.stopListeningToSource(source);\n }\n }\n } else if (isLinked && source !== prevProps.source) {\n if (prevProps.source) {\n this.stopListeningToSource(prevProps.source);\n }\n if (source) {\n this.startListeningToSource(source);\n this.updateModelFromSource();\n }\n }\n }\n\n componentWillUnmount(): void {\n this.pending.cancel();\n\n const { model } = this.state;\n const { source } = this.props;\n if (model != null && source) {\n this.stopListeningToSource(source);\n }\n }\n\n panelContainer: RefObject<HTMLDivElement>;\n\n pending: Pending;\n\n initModel(): void {\n this.setState({\n isLoading: true,\n isLoaded: false,\n error: undefined,\n isDisconnected: false,\n });\n\n const { makeModel } = this.props;\n\n this.pending.cancel();\n\n this.pending\n .add(makeModel(), resolved => {\n resolved.close();\n })\n .then(this.handleLoadSuccess, this.handleLoadError);\n }\n\n getWaitingInputMap = memoize(\n (\n isFilterRequired: boolean,\n columnMap: ColumnMap,\n filterMap: FilterMap\n ): Map<string, { name: string; type: string }> => {\n if (!isFilterRequired) {\n return new Map();\n }\n const waitingInputMap = new Map(columnMap);\n filterMap.forEach((filter, name) => {\n waitingInputMap.delete(name);\n });\n return waitingInputMap;\n }\n );\n\n getWaitingFilterMap = memoize(\n (\n isFilterRequired: boolean,\n columnMap: ColumnMap,\n filterMap: FilterMap,\n linkedColumnMap: LinkedColumnMap,\n inputFilterMap: InputFilterMap\n ) => {\n if (!isFilterRequired) {\n return new Map();\n }\n\n const waitingFilterMap = new Map(columnMap);\n filterMap.forEach((filter, name) => {\n waitingFilterMap.delete(name);\n });\n inputFilterMap.forEach((value, name) => {\n waitingFilterMap.delete(name);\n });\n linkedColumnMap.forEach((column, name) => {\n waitingFilterMap.delete(name);\n });\n return waitingFilterMap;\n }\n );\n\n getInputFilterColumnMap = memoize(\n (columnMap: ColumnMap, inputFilters: InputFilter[]) => {\n const inputFilterMap = new Map<string, InputFilter>();\n for (let i = 0; i < inputFilters.length; i += 1) {\n const inputFilter = inputFilters[i];\n const { name, type } = inputFilter;\n const column = columnMap.get(name);\n if (column != null && column.type === type) {\n inputFilterMap.set(name, inputFilter);\n }\n }\n return inputFilterMap;\n }\n );\n\n getLinkedColumnMap = memoize((columnMap: ColumnMap, links: Link[]) => {\n const linkedColumnMap = new Map<string, { name: string; type: string }>();\n const panelId = LayoutUtils.getIdFromPanel(this);\n for (let i = 0; i < links.length; i += 1) {\n const link = links[i];\n let columnName = null;\n if (\n link.start != null &&\n link.start.panelId === panelId &&\n columnMap.has(link.start.columnName)\n ) {\n columnName = link.start.columnName;\n } else if (\n link.end &&\n link.end.panelId === panelId &&\n columnMap.has(link.end.columnName)\n ) {\n columnName = link.end.columnName;\n }\n\n if (columnName != null && columnMap.has(columnName)) {\n const column = columnMap.get(columnName);\n assertNotNull(column);\n linkedColumnMap.set(columnName, column);\n }\n }\n return linkedColumnMap;\n });\n\n getSelectorColumns = memoize(\n (\n columnMap: ColumnMap,\n linkedColumnMap: LinkedColumnMap,\n columnSelectionValidator?: ColumnSelectionValidator\n ) =>\n Array.from(columnMap.values()).map(column => ({\n name: column.name,\n type: column.type,\n isValid: columnSelectionValidator\n ? columnSelectionValidator(this, column, { type: 'chartLink' })\n : false,\n isActive: linkedColumnMap.has(column.name),\n }))\n );\n\n getWidgetPanelDescriptor = memoize(\n (metadata: ChartPanelProps['metadata']): WidgetPanelDescriptor => {\n let name = 'Chart';\n if (isChartPanelTableMetadata(metadata)) {\n name = metadata.table;\n } else if (isChartPanelFigureMetadata(metadata)) {\n name = metadata.figure ?? name;\n } else {\n name = metadata.name ?? name;\n }\n return {\n ...metadata,\n type: 'Chart',\n name,\n };\n }\n );\n\n startListeningToSource(table: dh.Table): void {\n log.debug('startListeningToSource', table);\n const { model } = this.state;\n assertNotNull(model);\n const { dh } = model;\n table.addEventListener(\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n this.handleSourceColumnChange\n );\n table.addEventListener(\n dh.Table.EVENT_FILTERCHANGED,\n this.handleSourceFilterChange\n );\n table.addEventListener(\n dh.Table.EVENT_SORTCHANGED,\n this.handleSourceSortChange\n );\n }\n\n stopListeningToSource(table: dh.Table): void {\n log.debug('stopListeningToSource', table);\n const { model } = this.state;\n assertNotNull(model);\n const { dh } = model;\n table.removeEventListener(\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n this.handleSourceColumnChange\n );\n table.removeEventListener(\n dh.Table.EVENT_FILTERCHANGED,\n this.handleSourceFilterChange\n );\n table.removeEventListener(\n dh.Table.EVENT_SORTCHANGED,\n this.handleSourceSortChange\n );\n }\n\n loadModelIfNecessary(): void {\n const { isActive, isLoaded, isLoading } = this.state;\n if (isActive && !isLoaded && !isLoading) {\n this.initModel();\n }\n }\n\n isHidden(): boolean {\n const { glContainer } = this.props;\n const { isHidden } = glContainer;\n return isHidden;\n }\n\n handleColumnSelected(columnName: string): void {\n const { glEventHub } = this.props;\n const { columnMap } = this.state;\n const panelId = LayoutUtils.getIdFromPanel(this);\n assertNotNull(panelId);\n const column = columnMap.get(columnName);\n if (column == null) {\n return;\n }\n emitLinkPointSelected(glEventHub, panelId, column, {\n type: 'chartLink',\n });\n }\n\n handleColumnMouseEnter({ type, name }: SelectorColumn): void {\n const { columnSelectionValidator } = this.props;\n log.debug('handleColumnMouseEnter', columnSelectionValidator, type, name);\n if (!columnSelectionValidator) {\n return;\n }\n columnSelectionValidator(this, { type, name }, { type: 'chartLink' });\n }\n\n handleColumnMouseLeave(): void {\n const { columnSelectionValidator } = this.props;\n log.debug('handleColumnMouseLeave', columnSelectionValidator);\n if (!columnSelectionValidator) {\n return;\n }\n columnSelectionValidator(this, undefined, { type: 'chartLink' });\n }\n\n handleDisconnect(): void {\n this.setState({\n error: new Error('Figure disconnected'),\n isDisconnected: true,\n });\n }\n\n handleFilterAdd(columns: InputFilter[]): void {\n for (let i = 0; i < columns.length; i += 1) {\n this.openInputFilter(columns[i]);\n }\n }\n\n handleOpenLinker(): void {\n const {\n localDashboardId,\n setActiveTool,\n setDashboardIsolatedLinkerPanelId,\n } = this.props;\n setDashboardIsolatedLinkerPanelId(localDashboardId, undefined);\n setActiveTool(ToolType.LINKER);\n }\n\n handleReconnect(): void {\n this.setState({ isDisconnected: false, error: undefined });\n this.sendColumnChange();\n this.updateColumnFilters();\n }\n\n handleLoadSuccess(model: ChartModel): void {\n log.debug('handleLoadSuccess');\n\n const { model: prevModel } = this.state;\n this.setState(\n {\n model,\n isLoaded: true,\n },\n () => {\n const { inputFilters, source } = this.props;\n const { filterMap, isLinked } = this.state;\n if (model !== prevModel) {\n this.sendColumnChange();\n this.updateColumnFilters();\n this.updateInputFilters(\n inputFilters,\n filterMap.size > 0 || model.isFilterRequired()\n );\n if (source && isLinked) {\n this.startListeningToSource(source);\n this.updateModelFromSource();\n }\n }\n }\n );\n }\n\n handleLoadError(error: unknown): void {\n if (PromiseUtils.isCanceled(error)) {\n return;\n }\n\n log.error('handleLoadError', error);\n this.setState({ error, isLoading: false });\n }\n\n handleSourceColumnChange(): void {\n this.updateModelFromSource();\n }\n\n handleSourceFilterChange(): void {\n this.updateModelFromSource();\n }\n\n handleSourceSortChange(): void {\n this.updateModelFromSource();\n }\n\n updateModelFromSource(): void {\n const { metadata, source } = this.props;\n const { isLinked, model } = this.state;\n if (!isLinked || !model || !source) {\n log.debug2('updateModelFromSource ignoring', isLinked, model, source);\n return;\n }\n const { dh } = model;\n // By now the model has already been loaded, which is the only other cancelable thing in pending\n this.pending.cancel();\n if (isChartPanelTableMetadata(metadata)) {\n const { settings } = metadata;\n this.pending\n .add(\n ChartModelFactory.makeFigureFromSettings(dh, settings, source),\n resolved => resolved.close()\n )\n .then(figure => {\n if (isFigureChartModel(model)) {\n model.setFigure(figure);\n }\n })\n .catch(this.handleLoadError);\n }\n\n this.updatePanelState();\n }\n\n updatePanelState(): void {\n const { sourcePanel } = this.props;\n const { panelState, filterValueMap, settings } = this.state;\n let { tableSettings } = panelState ?? {};\n if (sourcePanel) {\n // Right now just update the panel state from the source\n // If the source isn't available, just keep the state that's already saved\n if (\n hasInputFilter(sourcePanel.props) &&\n hasPanelState(sourcePanel.state)\n ) {\n const { inputFilters } = sourcePanel.props;\n const { panelState: sourcePanelState } = sourcePanel.state;\n if (sourcePanelState != null) {\n tableSettings = IrisGridUtils.extractTableSettings(\n sourcePanelState,\n inputFilters\n );\n }\n }\n }\n\n // eslint-disable-next-line react/no-unused-state\n this.setState({\n panelState: {\n settings,\n tableSettings,\n filterValueMap: Array.from(filterValueMap),\n },\n });\n }\n\n handleError(): void {\n // Don't want to set an error state, because the user can fix a chart error within the chart itself.\n // We're not loading anymore either so stop showing the spinner so the user can actually click those buttons.\n this.setState({ isLoading: false });\n }\n\n handleSettingsChanged(update: Partial<Settings>): void {\n this.setState(({ settings: prevSettings }) => {\n const settings = {\n ...prevSettings,\n ...update,\n };\n log.debug('Updated settings', settings);\n return { settings };\n });\n }\n\n handleHide(): void {\n this.setActive(false);\n }\n\n handleShow(): void {\n this.setActive(true);\n }\n\n handleTabBlur(): void {\n this.setActive(false);\n }\n\n handleTabFocus(): void {\n const isHidden = this.isHidden();\n this.setActive(!isHidden);\n }\n\n handleUpdate({ isLoading }: LoadState): void {\n this.setState({ isLoading });\n }\n\n handleClearAllFilters(): void {\n // nuke link filter and input filter map\n // input filters only clear themselves if they are not yet empty\n this.setState({\n filterValueMap: new Map(),\n filterMap: new Map(),\n });\n this.updatePanelState();\n }\n\n /**\n * Create an input filter panel for the provided column\n * @param column The column to create the input filter for\n */\n openInputFilter(column: InputFilter): void {\n const { glEventHub } = this.props;\n const { name, type } = column;\n glEventHub.emit(InputFilterEvent.OPEN_INPUT, {\n title: `${name} Filter`,\n panelState: {\n name,\n type,\n isValueShown: true,\n },\n createNewStack: true,\n focusElement: 'input',\n });\n }\n\n setActive(isActive: boolean): void {\n this.setState({ isActive }, () => {\n if (isActive) {\n this.loadModelIfNecessary();\n }\n });\n }\n\n sendColumnChange(): void {\n const { model } = this.state;\n if (!model) {\n return;\n }\n const { glEventHub } = this.props;\n const panelId = LayoutUtils.getIdFromPanel(this);\n assertNotNull(panelId);\n emitFilterColumnsChanged(\n glEventHub,\n panelId,\n Array.from(model.getFilterColumnMap().values())\n );\n }\n\n getCoordinateForColumn(columnName: ColumnName): [number, number] | null {\n const className =\n ChartColumnSelectorOverlay.makeButtonClassName(columnName);\n\n if (!this.panelContainer.current) {\n return null;\n }\n\n const element = this.panelContainer.current.querySelector(`.${className}`);\n const rect = element?.getBoundingClientRect() ?? null;\n if (rect == null || rect.width <= 0 || rect.height <= 0) {\n return null;\n }\n const x = rect.left + rect.width / 2;\n const y = rect.bottom;\n return [x, y];\n }\n\n /**\n * Set chart filters based on the filter map\n * @param filterMapParam Filter map\n */\n setFilterMap(filterMapParam: LinkFilterMap): void {\n log.debug('setFilterMap', filterMapParam);\n this.setState(state => {\n const { columnMap, filterMap } = state;\n let updatedFilterMap: null | FilterMap = null;\n const filterValueMap = new Map(state.filterValueMap);\n filterMapParam.forEach(({ columnType, filterList }, columnName) => {\n const column = columnMap.get(columnName);\n if (column == null || column.type !== columnType) {\n return;\n }\n if (filterList.length === 0) {\n log.debug('Ignoring empty filterList for column', columnName);\n return;\n }\n const { value } = filterList[0];\n filterValueMap.set(columnName, value);\n if (filterMap.get(columnName) !== value) {\n if (updatedFilterMap === null) {\n updatedFilterMap = new Map(filterMap);\n }\n updatedFilterMap.set(columnName, value);\n }\n });\n\n // Don't update filterMap unless the filters actually changed.\n // Otherwise the chart gets stuck on a spinner\n // because it never gets an update event for unchanged filters.\n return { filterValueMap, filterMap: updatedFilterMap ?? filterMap };\n });\n }\n\n unsetFilterValue(columnName: ColumnName): void {\n this.setState(state => {\n // We want to unset a value unless there's an input filter for it\n // If there's an input filter, then we want to just set it to that value\n // This way if the user has an input filter and a link, when they delete the link the input filter value takes effect\n const { inputFilters } = this.props;\n const { columnMap } = state;\n let { filterMap, filterValueMap } = state;\n if (!filterValueMap.has(columnName)) {\n return null;\n }\n\n filterValueMap = new Map(state.filterValueMap);\n filterValueMap.delete(columnName);\n\n const inputFilterMap = this.getInputFilterColumnMap(\n columnMap,\n inputFilters\n );\n\n if (inputFilterMap.has(columnName)) {\n const filterValue = filterMap.get(columnName);\n const inputFilterValue = inputFilterMap.get(columnName)?.value;\n if (inputFilterValue != null && filterValue !== inputFilterValue) {\n filterMap = new Map(state.filterMap);\n if (inputFilterValue.length > 0) {\n filterMap.set(columnName, inputFilterValue);\n } else {\n filterMap.delete(columnName);\n }\n }\n } else {\n filterMap = new Map(state.filterMap);\n filterMap.delete(columnName);\n }\n return { filterMap, filterValueMap };\n });\n }\n\n updateChangedInputFilters(\n inputFilters: InputFilter[],\n prevInputFilters: InputFilter[]\n ): void {\n const deletedInputFilters = prevInputFilters.filter(\n prevInputFilter =>\n inputFilters.find(\n inputFilter =>\n inputFilter.name === prevInputFilter.name &&\n inputFilter.type === prevInputFilter.type\n ) === undefined\n );\n if (deletedInputFilters.length > 0) {\n this.deleteInputFilters(deletedInputFilters);\n }\n\n const changedInputFilters = inputFilters.filter(\n inputFilter => !prevInputFilters.includes(inputFilter)\n );\n if (changedInputFilters.length > 0) {\n this.updateInputFilters(changedInputFilters);\n }\n }\n\n updateInputFilters(inputFilters: InputFilter[], forceUpdate = false): void {\n this.setState(state => {\n const { columnMap } = state;\n const filterValueMap = new Map(state.filterValueMap);\n const filterMap = new Map(state.filterMap);\n const update = forceUpdate ? { filterMap, filterValueMap } : {};\n\n for (let i = 0; i < inputFilters.length; i += 1) {\n const { name, type, value } = inputFilters[i];\n const column = columnMap.get(name);\n if (column != null && column.type === type) {\n if (value != null && filterMap.get(name) !== value) {\n if (value === '') {\n filterMap.delete(name);\n } else {\n filterMap.set(name, value);\n }\n update.filterMap = filterMap;\n }\n\n if (filterValueMap.has(name)) {\n // Need to unset whatever the linked value was - if they want that value again, they need to double click the link again\n filterValueMap.delete(name);\n update.filterValueMap = filterValueMap;\n }\n }\n }\n\n log.debug('updateInputFilters', update);\n return update as unknown;\n });\n }\n\n deleteInputFilters(inputFilters: InputFilter[], forceUpdate = false): void {\n this.setState(state => {\n const { columnMap, filterValueMap } = state;\n const filterMap = new Map(state.filterMap);\n let needsUpdate = forceUpdate;\n\n for (let i = 0; i < inputFilters.length; i += 1) {\n const { name, type } = inputFilters[i];\n const column = columnMap.get(name);\n if (column != null && column.type === type) {\n if (filterMap.has(name)) {\n const filterValue = filterMap.get(name);\n if (filterValueMap.has(name)) {\n const linkValue = filterValueMap.get(name);\n if (linkValue !== filterValue && linkValue != null) {\n needsUpdate = true;\n filterMap.set(name, linkValue);\n }\n } else {\n needsUpdate = true;\n filterMap.delete(name);\n }\n }\n }\n }\n\n log.debug('deleteInputFilters', needsUpdate);\n return needsUpdate ? { filterMap } : null;\n });\n }\n\n updateColumnFilters(): void {\n this.setState(({ model }) => {\n if (!model) {\n return null;\n }\n\n return { columnMap: model.getFilterColumnMap() };\n });\n }\n\n updateFilters(): void {\n const { columnMap, filterMap, model } = this.state;\n assertNotNull(model);\n const waitingInputMap = this.getWaitingInputMap(\n model.isFilterRequired(),\n columnMap,\n filterMap\n );\n model.setFilter(filterMap);\n\n if (filterMap.size > 0 && waitingInputMap.size === 0) {\n const defaultTitle = model.getDefaultTitle();\n const filterTitle = TextUtils.join(\n Array.from(filterMap.entries()).map(\n ([name, value]) => `${name}: ${value}`\n )\n );\n if (defaultTitle) {\n model.setTitle(\n `${defaultTitle}<br><span style=\"font-size: smaller\">${filterTitle}</span>`\n );\n } else {\n model.setTitle(filterTitle);\n }\n\n log.debug2('updateFilters filters set', filterMap);\n this.setState({ isLoading: true });\n } else {\n log.debug2('updateFilters waiting on inputs', waitingInputMap);\n model.setTitle(model.getDefaultTitle());\n this.setState({ isLoading: false });\n }\n\n this.updatePanelState();\n }\n\n /**\n * Removes any set filter values that are no longer part of the model\n */\n pruneFilterMaps(): void {\n this.setState(state => {\n const { columnMap } = state;\n const filterMap = new Map(state.filterMap);\n const filterValueMap = new Map(state.filterValueMap);\n const newState: Pick<\n Partial<ChartPanelState>,\n 'filterMap' | 'filterValueMap'\n > = {};\n\n state.filterValueMap.forEach((value, name) => {\n if (!columnMap.has(name)) {\n filterValueMap.delete(name);\n newState.filterValueMap = filterValueMap;\n }\n });\n state.filterMap.forEach((value, name) => {\n if (!columnMap.has(name)) {\n filterMap.delete(name);\n newState.filterMap = filterMap;\n }\n });\n return newState as unknown;\n });\n }\n\n render(): ReactElement {\n const {\n columnSelectionValidator,\n glContainer,\n glEventHub,\n inputFilters,\n isLinkerActive,\n links,\n metadata,\n settings,\n Plotly,\n containerRef,\n } = this.props;\n const {\n columnMap,\n filterMap,\n error,\n model,\n isActive,\n isDisconnected,\n isLoaded,\n isLoading,\n } = this.state;\n const inputFilterMap = this.getInputFilterColumnMap(\n columnMap,\n inputFilters\n );\n const linkedColumnMap = this.getLinkedColumnMap(columnMap, links);\n const waitingInputMap =\n model != null\n ? this.getWaitingInputMap(\n model.isFilterRequired(),\n columnMap,\n filterMap\n )\n : new Map();\n const waitingFilterMap =\n model != null\n ? this.getWaitingFilterMap(\n model.isFilterRequired(),\n columnMap,\n filterMap,\n linkedColumnMap,\n inputFilterMap\n )\n : new Map();\n const errorMessage =\n error != null ? `Unable to open chart. ${error}` : undefined;\n const isWaitingForFilter = waitingInputMap.size > 0;\n const isSelectingColumn = columnMap.size > 0 && isLinkerActive;\n const descriptor = this.getWidgetPanelDescriptor(metadata);\n return (\n <WidgetPanel\n className={classNames('iris-chart-panel', {\n 'input-required': isWaitingForFilter,\n })}\n componentPanel={this}\n glContainer={glContainer}\n glEventHub={glEventHub}\n onHide={this.handleHide}\n onClearAllFilters={this.handleClearAllFilters}\n onShow={this.handleShow}\n onTabBlur={this.handleTabBlur}\n onTabFocus={this.handleTabFocus}\n errorMessage={errorMessage}\n isDisconnected={isDisconnected}\n isLoading={isLoading}\n isLoaded={isLoaded}\n descriptor={descriptor}\n >\n <div\n ref={this.panelContainer}\n className=\"chart-panel-container h-100 w-100\"\n >\n <div className=\"chart-container h-100 w-100\">\n {isLoaded && model && (\n <Chart\n isActive={isActive}\n model={model}\n settings={settings}\n onDisconnect={this.handleDisconnect}\n onReconnect={this.handleReconnect}\n onUpdate={this.handleUpdate}\n onError={this.handleError}\n onSettingsChanged={this.handleSettingsChanged}\n Plotly={Plotly}\n containerRef={containerRef}\n />\n )}\n </div>\n <FadeTransition\n in={isWaitingForFilter && !isSelectingColumn && !isLoading}\n mountOnEnter\n unmountOnExit\n >\n <ChartFilterOverlay\n inputFilterMap={inputFilterMap}\n linkedColumnMap={linkedColumnMap}\n onAdd={this.handleFilterAdd}\n onOpenLinker={this.handleOpenLinker}\n columnMap={columnMap}\n waitingFilterMap={waitingFilterMap}\n waitingInputMap={waitingInputMap}\n />\n </FadeTransition>\n <FadeTransition in={isSelectingColumn} mountOnEnter unmountOnExit>\n <ChartColumnSelectorOverlay\n columns={this.getSelectorColumns(\n columnMap,\n linkedColumnMap,\n columnSelectionValidator\n )}\n onColumnSelected={this.handleColumnSelected}\n onMouseEnter={this.handleColumnMouseEnter}\n onMouseLeave={this.handleColumnMouseLeave}\n />\n </FadeTransition>\n </div>\n </WidgetPanel>\n );\n }\n}\n\nconst mapStateToProps = (state: RootState, ownProps: OwnProps): StateProps => {\n const { localDashboardId, metadata } = ownProps;\n\n let sourcePanelId: string | undefined;\n if (metadata != null && isChartPanelTableMetadata(metadata)) {\n sourcePanelId = metadata.sourcePanelId;\n }\n const panelTableMap = getTableMapForDashboard(state, localDashboardId);\n const openedPanelMap = getOpenedPanelMapForDashboard(state, localDashboardId);\n const activeTool = getActiveTool(state);\n const isolatedLinkerPanelId = getIsolatedLinkerPanelIdForDashboard(\n state,\n localDashboardId\n );\n const isLinkerActive =\n activeTool === ToolType.LINKER && isolatedLinkerPanelId === undefined;\n return {\n columnSelectionValidator: getColumnSelectionValidatorForDashboard(\n state,\n localDashboardId\n ),\n isLinkerActive,\n inputFilters: getInputFiltersForDashboard(state, localDashboardId),\n links: getLinksForDashboard(state, localDashboardId),\n source:\n sourcePanelId != null ? panelTableMap.get(sourcePanelId) : undefined,\n sourcePanel:\n sourcePanelId != null ? openedPanelMap.get(sourcePanelId) : undefined,\n settings: getSettings(state),\n };\n};\n\nconst ConnectedChartPanel = connect(\n mapStateToProps,\n {\n setActiveTool: setActiveToolAction,\n setDashboardIsolatedLinkerPanelId: setDashboardIsolatedLinkerPanelIdAction,\n } satisfies DispatchProps,\n null,\n { forwardRef: true }\n)(ChartPanel);\n\nexport default ConnectedChartPanel;\n"],"mappings":"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"}
|