@deephaven/dashboard-core-plugins 0.15.5-beta.3 → 0.15.5-beta.4
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.d.ts.map +1 -1
- package/dist/ChartBuilderPlugin.js +2 -1
- package/dist/ChartBuilderPlugin.js.map +1 -1
- package/dist/FilterPlugin.js +1 -1
- package/dist/FilterPlugin.js.map +1 -1
- package/dist/controls/ControlType.d.ts +1 -1
- package/dist/controls/ControlType.d.ts.map +1 -1
- package/dist/controls/ControlType.js.map +1 -1
- package/dist/controls/dropdown-filter/DropdownFilter.d.ts +73 -81
- package/dist/controls/dropdown-filter/DropdownFilter.d.ts.map +1 -1
- package/dist/controls/dropdown-filter/DropdownFilter.js +41 -58
- package/dist/controls/dropdown-filter/DropdownFilter.js.map +1 -1
- package/dist/controls/input-filter/InputFilter.d.ts +46 -46
- package/dist/controls/input-filter/InputFilter.d.ts.map +1 -1
- package/dist/controls/input-filter/InputFilter.js +32 -39
- package/dist/controls/input-filter/InputFilter.js.map +1 -1
- package/dist/controls/markdown/MarkdownContainer.d.ts +11 -16
- package/dist/controls/markdown/MarkdownContainer.d.ts.map +1 -1
- package/dist/controls/markdown/MarkdownContainer.js +5 -8
- package/dist/controls/markdown/MarkdownContainer.js.map +1 -1
- package/dist/controls/markdown/MarkdownEditor.d.ts +17 -19
- package/dist/controls/markdown/MarkdownEditor.d.ts.map +1 -1
- package/dist/controls/markdown/MarkdownEditor.js +5 -8
- package/dist/controls/markdown/MarkdownEditor.js.map +1 -1
- package/dist/controls/markdown/MarkdownStartPage.d.ts +24 -28
- package/dist/controls/markdown/MarkdownStartPage.d.ts.map +1 -1
- package/dist/controls/markdown/MarkdownStartPage.js +19 -23
- package/dist/controls/markdown/MarkdownStartPage.js.map +1 -1
- package/dist/controls/markdown/MarkdownUtils.d.ts +4 -4
- package/dist/controls/markdown/MarkdownUtils.d.ts.map +1 -1
- package/dist/controls/markdown/MarkdownUtils.js +2 -2
- package/dist/controls/markdown/MarkdownUtils.js.map +1 -1
- package/dist/events/ChartEvent.d.ts +1 -1
- package/dist/events/ChartEvent.d.ts.map +1 -1
- package/dist/events/ChartEvent.js.map +1 -1
- package/dist/events/ConsoleEvent.d.ts +1 -1
- package/dist/events/ConsoleEvent.d.ts.map +1 -1
- package/dist/events/ConsoleEvent.js.map +1 -1
- package/dist/events/InputFilterEvent.d.ts +1 -1
- package/dist/events/InputFilterEvent.d.ts.map +1 -1
- package/dist/events/InputFilterEvent.js.map +1 -1
- package/dist/events/IrisGridEvent.d.ts +1 -1
- package/dist/events/IrisGridEvent.d.ts.map +1 -1
- package/dist/events/IrisGridEvent.js.map +1 -1
- package/dist/events/NotebookEvent.d.ts +1 -1
- package/dist/events/NotebookEvent.d.ts.map +1 -1
- package/dist/events/NotebookEvent.js.map +1 -1
- package/dist/events/PQEvent.d.ts +1 -1
- package/dist/events/PQEvent.d.ts.map +1 -1
- package/dist/events/PQEvent.js.map +1 -1
- package/dist/events/PandasEvent.d.ts +1 -1
- package/dist/events/PandasEvent.d.ts.map +1 -1
- package/dist/events/PandasEvent.js.map +1 -1
- package/dist/events/TabEvent.d.ts +1 -1
- package/dist/events/TabEvent.d.ts.map +1 -1
- package/dist/events/TabEvent.js.map +1 -1
- package/dist/events/index.d.ts +8 -8
- package/dist/events/index.d.ts.map +1 -1
- package/dist/events/index.js.map +1 -1
- package/dist/linker/ColumnSelectionValidator.d.ts +4 -0
- package/dist/linker/ColumnSelectionValidator.d.ts.map +1 -0
- package/dist/linker/ColumnSelectionValidator.js +2 -0
- package/dist/linker/ColumnSelectionValidator.js.map +1 -0
- package/dist/linker/Linker.d.ts +11 -11
- package/dist/linker/Linker.js +1 -1
- package/dist/linker/Linker.js.map +1 -1
- package/dist/linker/LinkerUtils.d.ts +3 -3
- package/dist/linker/LinkerUtils.d.ts.map +1 -1
- package/dist/linker/LinkerUtils.js.map +1 -1
- package/dist/linker/ToolType.d.ts +1 -1
- package/dist/linker/ToolType.d.ts.map +1 -1
- package/dist/linker/ToolType.js.map +1 -1
- package/dist/panels/ChartColumnSelectorOverlay.d.ts +22 -26
- package/dist/panels/ChartColumnSelectorOverlay.d.ts.map +1 -1
- package/dist/panels/ChartColumnSelectorOverlay.js +5 -14
- package/dist/panels/ChartColumnSelectorOverlay.js.map +1 -1
- package/dist/panels/ChartFilterOverlay.d.ts +27 -21
- package/dist/panels/ChartFilterOverlay.d.ts.map +1 -1
- package/dist/panels/ChartFilterOverlay.js.map +1 -1
- package/dist/panels/ChartPanel.d.ts +149 -152
- package/dist/panels/ChartPanel.d.ts.map +1 -1
- package/dist/panels/ChartPanel.js +65 -73
- package/dist/panels/ChartPanel.js.map +1 -1
- package/dist/panels/CommandHistoryPanel.d.ts +41 -56
- package/dist/panels/CommandHistoryPanel.d.ts.map +1 -1
- package/dist/panels/CommandHistoryPanel.js +13 -35
- package/dist/panels/CommandHistoryPanel.js.map +1 -1
- package/dist/panels/ConsolePanel.d.ts +63 -73
- package/dist/panels/ConsolePanel.d.ts.map +1 -1
- package/dist/panels/ConsolePanel.js +67 -83
- package/dist/panels/ConsolePanel.js.map +1 -1
- package/dist/panels/DropdownFilterPanel.d.ts +110 -106
- package/dist/panels/DropdownFilterPanel.d.ts.map +1 -1
- package/dist/panels/DropdownFilterPanel.js +60 -62
- package/dist/panels/DropdownFilterPanel.js.map +1 -1
- package/dist/panels/FileExplorerPanel.d.ts +5 -7
- package/dist/panels/FileExplorerPanel.d.ts.map +1 -1
- package/dist/panels/FileExplorerPanel.js.map +1 -1
- package/dist/panels/FilterSetManager.d.ts +3 -1
- package/dist/panels/FilterSetManager.d.ts.map +1 -1
- package/dist/panels/FilterSetManager.js.map +1 -1
- package/dist/panels/FilterSetManagerPanel.d.ts +83 -62
- package/dist/panels/FilterSetManagerPanel.d.ts.map +1 -1
- package/dist/panels/FilterSetManagerPanel.js +58 -36
- package/dist/panels/FilterSetManagerPanel.js.map +1 -1
- package/dist/panels/InputFilterPanel.d.ts +50 -51
- package/dist/panels/InputFilterPanel.d.ts.map +1 -1
- package/dist/panels/InputFilterPanel.js +35 -34
- package/dist/panels/InputFilterPanel.js.map +1 -1
- package/dist/panels/IrisGridPanel.d.ts +191 -178
- package/dist/panels/IrisGridPanel.d.ts.map +1 -1
- package/dist/panels/IrisGridPanel.js +150 -179
- package/dist/panels/IrisGridPanel.js.map +1 -1
- package/dist/panels/LogPanel.d.ts +29 -45
- package/dist/panels/LogPanel.d.ts.map +1 -1
- package/dist/panels/LogPanel.js +9 -11
- package/dist/panels/LogPanel.js.map +1 -1
- package/dist/panels/MarkdownNotebook.d.ts +34 -34
- package/dist/panels/MarkdownNotebook.d.ts.map +1 -1
- package/dist/panels/MarkdownNotebook.js +21 -18
- package/dist/panels/MarkdownNotebook.js.map +1 -1
- package/dist/panels/MarkdownPanel.d.ts +41 -47
- package/dist/panels/MarkdownPanel.d.ts.map +1 -1
- package/dist/panels/MarkdownPanel.js +17 -19
- package/dist/panels/MarkdownPanel.js.map +1 -1
- package/dist/panels/NotebookPanel.d.ts +137 -115
- package/dist/panels/NotebookPanel.d.ts.map +1 -1
- package/dist/panels/NotebookPanel.js +95 -68
- package/dist/panels/NotebookPanel.js.map +1 -1
- package/dist/panels/PandasPanel.d.ts +20 -17
- package/dist/panels/PandasPanel.d.ts.map +1 -1
- package/dist/panels/PandasPanel.js +17 -13
- package/dist/panels/PandasPanel.js.map +1 -1
- package/dist/panels/Panel.d.ts +87 -123
- package/dist/panels/Panel.d.ts.map +1 -1
- package/dist/panels/Panel.js +29 -54
- package/dist/panels/Panel.js.map +1 -1
- package/dist/panels/PanelContextMenu.d.ts +16 -31
- package/dist/panels/PanelContextMenu.d.ts.map +1 -1
- package/dist/panels/PanelContextMenu.js +12 -15
- package/dist/panels/PanelContextMenu.js.map +1 -1
- package/dist/panels/RenameDialog.d.ts +26 -28
- package/dist/panels/RenameDialog.d.ts.map +1 -1
- package/dist/panels/RenameDialog.js +15 -19
- package/dist/panels/RenameDialog.js.map +1 -1
- package/dist/panels/WidgetPanel.d.ts +72 -106
- package/dist/panels/WidgetPanel.d.ts.map +1 -1
- package/dist/panels/WidgetPanel.js +17 -47
- package/dist/panels/WidgetPanel.js.map +1 -1
- package/dist/panels/WidgetPanelTooltip.d.ts +29 -22
- package/dist/panels/WidgetPanelTooltip.d.ts.map +1 -1
- package/dist/panels/WidgetPanelTooltip.js +1 -1
- package/dist/panels/WidgetPanelTooltip.js.map +1 -1
- package/dist/prop-types/CommonPropTypes.d.ts +4 -4
- package/dist/prop-types/CommonPropTypes.d.ts.map +1 -1
- package/dist/prop-types/CommonPropTypes.js +1 -1
- package/dist/prop-types/CommonPropTypes.js.map +1 -1
- package/dist/prop-types/UIPropTypes.d.ts +2 -7
- package/dist/prop-types/UIPropTypes.d.ts.map +1 -1
- package/dist/prop-types/UIPropTypes.js +0 -7
- package/dist/prop-types/UIPropTypes.js.map +1 -1
- package/dist/prop-types/index.d.ts +2 -2
- package/dist/prop-types/index.d.ts.map +1 -1
- package/dist/prop-types/index.js.map +1 -1
- package/dist/redux/actionTypes.d.ts +1 -1
- package/dist/redux/actionTypes.d.ts.map +1 -1
- package/dist/redux/actionTypes.js.map +1 -1
- package/dist/redux/actions.d.ts +63 -8
- package/dist/redux/actions.d.ts.map +1 -1
- package/dist/redux/actions.js +17 -17
- package/dist/redux/actions.js.map +1 -1
- package/dist/redux/reducers/index.d.ts +3 -4
- package/dist/redux/reducers/index.d.ts.map +1 -1
- package/dist/redux/reducers/index.js.map +1 -1
- package/dist/redux/reducers/sessionWrapper.d.ts +1 -1
- package/dist/redux/reducers/sessionWrapper.d.ts.map +1 -1
- package/dist/redux/reducers/sessionWrapper.js.map +1 -1
- package/dist/redux/selectors.d.ts +63 -9
- package/dist/redux/selectors.d.ts.map +1 -1
- package/dist/redux/selectors.js +24 -24
- package/dist/redux/selectors.js.map +1 -1
- package/package.json +20 -17
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartBuilderPlugin.d.ts","sourceRoot":"","sources":["../src/ChartBuilderPlugin.tsx"],"names":[],"mappings":";AAEA,OAAO,EAEL,6BAA6B,EAG9B,MAAM,sBAAsB,CAAC;AAM9B,oBAAY,uBAAuB,GAAG,OAAO,CAAC,6BAA6B,CAAC,CAAC;AAE7E;;;GAGG;AACH,eAAO,MAAM,kBAAkB,UACtB,uBAAuB,KAC7B,
|
|
1
|
+
{"version":3,"file":"ChartBuilderPlugin.d.ts","sourceRoot":"","sources":["../src/ChartBuilderPlugin.tsx"],"names":[],"mappings":";AAEA,OAAO,EAEL,6BAA6B,EAG9B,MAAM,sBAAsB,CAAC;AAM9B,oBAAY,uBAAuB,GAAG,OAAO,CAAC,6BAA6B,CAAC,CAAC;AAE7E;;;GAGG;AACH,eAAO,MAAM,kBAAkB,UACtB,uBAAuB,KAC7B,WAoDF,CAAC;AAEF,eAAe,kBAAkB,CAAC"}
|
|
@@ -25,7 +25,8 @@ export var ChartBuilderPlugin = props => {
|
|
|
25
25
|
settings
|
|
26
26
|
} = metadata;
|
|
27
27
|
|
|
28
|
-
var makeModel = () =>
|
|
28
|
+
var makeModel = () => // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
29
|
+
ChartModelFactory.makeModelFromSettings(settings, table);
|
|
29
30
|
|
|
30
31
|
var title = ChartUtils.titleFromSettings(settings);
|
|
31
32
|
var config = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/ChartBuilderPlugin.tsx"],"names":["React","useCallback","ChartModelFactory","ChartUtils","assertIsDashboardPluginProps","LayoutUtils","useListener","shortid","IrisGridEvent","ChartPanel","ChartBuilderPlugin","props","id","layout","handleCreateChart","metadata","panelId","generate","table","settings","makeModel","makeModelFromSettings","title","titleFromSettings","config","type","component","COMPONENT","localDashboardId","root","openComponent","eventHub","CREATE_CHART"],"mappings":"AAAA,OAAOA,KAAP,IAAgBC,WAAhB,QAAmC,OAAnC;AACA,SAASC,iBAAT,EAA4BC,UAA5B,QAA8C,kBAA9C;AACA,SACEC,4BADF,EAGEC,WAHF,EAIEC,WAJF,QAKO,sBALP;AAOA,OAAOC,OAAP,MAAoB,SAApB;SACSC,a;SACAC,U;;AAIT;AACA;AACA;AACA;AACA,OAAO,IAAMC,kBAAkB,GAC7BC,KADgC,IAEhB;AAChBP,EAAAA,4BAA4B,CAACO,KAAD,CAA5B;AACA,MAAM;AAAEC,IAAAA,EAAF;AAAMC,IAAAA;AAAN,MAAiBF,KAAvB;AACA,MAAMG,iBAAiB,GAAGb,WAAW,CACnC,QAmBM;AAAA,QAnBL;AACCc,MAAAA,QADD;AAECC,MAAAA,OAAO,GAAGT,OAAO,CAACU,QAAR,EAFX;AAGCC,MAAAA;AAHD,KAmBK;AACJ,QAAM;AAAEC,MAAAA;AAAF,QAAeJ,QAArB;;AACA,QAAMK,SAAS,GAAG,
|
|
1
|
+
{"version":3,"sources":["../src/ChartBuilderPlugin.tsx"],"names":["React","useCallback","ChartModelFactory","ChartUtils","assertIsDashboardPluginProps","LayoutUtils","useListener","shortid","IrisGridEvent","ChartPanel","ChartBuilderPlugin","props","id","layout","handleCreateChart","metadata","panelId","generate","table","settings","makeModel","makeModelFromSettings","title","titleFromSettings","config","type","component","COMPONENT","localDashboardId","root","openComponent","eventHub","CREATE_CHART"],"mappings":"AAAA,OAAOA,KAAP,IAAgBC,WAAhB,QAAmC,OAAnC;AACA,SAASC,iBAAT,EAA4BC,UAA5B,QAA8C,kBAA9C;AACA,SACEC,4BADF,EAGEC,WAHF,EAIEC,WAJF,QAKO,sBALP;AAOA,OAAOC,OAAP,MAAoB,SAApB;SACSC,a;SACAC,U;;AAIT;AACA;AACA;AACA;AACA,OAAO,IAAMC,kBAAkB,GAC7BC,KADgC,IAEhB;AAChBP,EAAAA,4BAA4B,CAACO,KAAD,CAA5B;AACA,MAAM;AAAEC,IAAAA,EAAF;AAAMC,IAAAA;AAAN,MAAiBF,KAAvB;AACA,MAAMG,iBAAiB,GAAGb,WAAW,CACnC,QAmBM;AAAA,QAnBL;AACCc,MAAAA,QADD;AAECC,MAAAA,OAAO,GAAGT,OAAO,CAACU,QAAR,EAFX;AAGCC,MAAAA;AAHD,KAmBK;AACJ,QAAM;AAAEC,MAAAA;AAAF,QAAeJ,QAArB;;AACA,QAAMK,SAAS,GAAG,MAChB;AACAlB,IAAAA,iBAAiB,CAACmB,qBAAlB,CAAwCF,QAAxC,EAAyDD,KAAzD,CAFF;;AAGA,QAAMI,KAAK,GAAGnB,UAAU,CAACoB,iBAAX,CAA6BJ,QAA7B,CAAd;AAEA,QAAMK,MAAM,GAAG;AACbC,MAAAA,IAAI,EAAE,iBADO;AAEbC,MAAAA,SAAS,EAAEjB,UAAU,CAACkB,SAFT;AAGbhB,MAAAA,KAAK,EAAE;AACLiB,QAAAA,gBAAgB,EAAEhB,EADb;AAELA,QAAAA,EAAE,EAAEI,OAFC;AAGLD,QAAAA,QAHK;AAILK,QAAAA;AAJK,OAHM;AASbE,MAAAA,KATa;AAUbV,MAAAA,EAAE,EAAEI;AAVS,KAAf;AAaA,QAAM;AAAEa,MAAAA;AAAF,QAAWhB,MAAjB;AACAR,IAAAA,WAAW,CAACyB,aAAZ,CAA0B;AAAED,MAAAA,IAAF;AAAQL,MAAAA;AAAR,KAA1B;AACD,GA1CkC,EA2CnC,CAACZ,EAAD,EAAKC,MAAL,CA3CmC,CAArC;AA8CAP,EAAAA,WAAW,CAACO,MAAM,CAACkB,QAAR,EAAkBvB,aAAa,CAACwB,YAAhC,EAA8ClB,iBAA9C,CAAX;AAEA,sBAAO,yCAAP;AACD,CAtDM;AAwDP,eAAeJ,kBAAf","sourcesContent":["import React, { useCallback } from 'react';\nimport { ChartModelFactory, ChartUtils } from '@deephaven/chart';\nimport {\n assertIsDashboardPluginProps,\n DashboardPluginComponentProps,\n LayoutUtils,\n useListener,\n} from '@deephaven/dashboard';\nimport { Table } from '@deephaven/jsapi-shim';\nimport shortid from 'shortid';\nimport { IrisGridEvent } from './events';\nimport { ChartPanel } from './panels';\n\nexport type ChartBuilderPluginProps = Partial<DashboardPluginComponentProps>;\n\n/**\n * Listens for IrisGridEvent.CREATE_CHART and creates a chart from the settings provided\n * Requires the GridPlugin and ChartPlugin plugins to be loaded as well\n */\nexport const ChartBuilderPlugin = (\n props: ChartBuilderPluginProps\n): JSX.Element => {\n assertIsDashboardPluginProps(props);\n const { id, layout } = props;\n const handleCreateChart = useCallback(\n ({\n metadata,\n panelId = shortid.generate(),\n table,\n }: {\n metadata: {\n settings: {\n type: string;\n series: string[];\n xAxis: string;\n isLinked: boolean;\n hiddenSeries?: string[];\n };\n sourcePanelId: string;\n table: string;\n tableSettings: Record<string, unknown>;\n };\n panelId?: string;\n table: Table;\n }) => {\n const { settings } = metadata;\n const makeModel = () =>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ChartModelFactory.makeModelFromSettings(settings as any, table);\n const title = ChartUtils.titleFromSettings(settings);\n\n const config = {\n type: 'react-component',\n component: ChartPanel.COMPONENT,\n props: {\n localDashboardId: id,\n id: panelId,\n metadata,\n makeModel,\n },\n title,\n id: panelId,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({ root, config });\n },\n [id, layout]\n );\n\n useListener(layout.eventHub, IrisGridEvent.CREATE_CHART, handleCreateChart);\n\n return <></>;\n};\n\nexport default ChartBuilderPlugin;\n"],"file":"ChartBuilderPlugin.js"}
|
package/dist/FilterPlugin.js
CHANGED
|
@@ -63,7 +63,7 @@ export var FilterPlugin = props => {
|
|
|
63
63
|
/**
|
|
64
64
|
* Handler for the COLUMNS_CHANGED event.
|
|
65
65
|
* @param panel The component that's emitting the filter change
|
|
66
|
-
* @param
|
|
66
|
+
* @param columns The columns in this panel
|
|
67
67
|
*/
|
|
68
68
|
|
|
69
69
|
var handleColumnsChanged = useCallback((panel, columns) => {
|
package/dist/FilterPlugin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/FilterPlugin.tsx"],"names":["React","useCallback","useEffect","useState","useDispatch","shortid","assertIsDashboardPluginProps","LayoutUtils","PanelEvent","updateDashboardData","useListener","Log","TextUtils","InputFilterEvent","DropdownFilterPanel","FilterSetManagerPanel","InputFilterPanel","log","module","flattenArray","accumulator","currentValue","concat","FilterPlugin","props","id","localDashboardId","layout","registerComponent","dispatch","panelColumns","Map","panelFilters","panelTables","sendUpdate","columns","Array","from","values","reduce","sort","a","b","aName","toLower","name","bName","aType","type","bType","array","column","length","push","filters","timestamp","tableMap","debug","handleColumnsChanged","panel","debug2","set","handleFiltersChanged","handleTableChanged","table","getIdFromPanel","handlePanelUnmount","delete","handleOpenDropdown","title","metadata","panelState","generate","focusElement","DEFAULT_FOCUS_SELECTOR","createNewStack","dragEvent","config","component","COMPONENT","root","openComponent","handleOpenInput","handleOpenFilterSetManager","registerComponentsAndReturnCleanup","cleanups","forEach","cleanup","eventHub","COLUMNS_CHANGED","FILTERS_CHANGED","TABLE_CHANGED","OPEN_DROPDOWN","OPEN_INPUT","OPEN_FILTER_SET_MANAGER","UNMOUNT"],"mappings":"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","sourcesContent":["import React, { Component, useCallback, useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport shortid from 'shortid';\nimport {\n assertIsDashboardPluginProps,\n DashboardPluginComponentProps,\n LayoutUtils,\n PanelEvent,\n updateDashboardData,\n useListener,\n} from '@deephaven/dashboard';\nimport Log from '@deephaven/log';\nimport { TextUtils } from '@deephaven/utils';\nimport { InputFilterEvent } from './events';\nimport {\n DropdownFilterPanel,\n FilterSetManagerPanel,\n InputFilterPanel,\n} from './panels';\n\nconst log = Log.module('FilterPlugin');\n\ntype Column = {\n name: string;\n type: string;\n};\n\nexport type FilterChangeEvent = Column & {\n value: string;\n timestamp: number;\n excludePanelIds?: string[];\n};\n\nexport type FilterPluginProps = Partial<DashboardPluginComponentProps>;\n\nfunction flattenArray<T>(accumulator: T[], currentValue: T | T[]): T[] {\n return accumulator.concat(currentValue);\n}\n\nexport const FilterPlugin = (props: FilterPluginProps): JSX.Element => {\n assertIsDashboardPluginProps(props);\n const { id: localDashboardId, layout, registerComponent } = props;\n const dispatch = useDispatch();\n const [panelColumns] = useState(() => new Map<Component, Column[]>());\n const [panelFilters] = useState(\n () => new Map<Component, FilterChangeEvent[]>()\n );\n const [panelTables] = useState(() => new Map());\n\n const sendUpdate = useCallback(() => {\n const columns = Array.from(panelColumns.values())\n .reduce(flattenArray, [] as Column[])\n .sort((a, b) => {\n const aName = TextUtils.toLower(a.name);\n const bName = TextUtils.toLower(b.name);\n if (aName !== bName) {\n return aName > bName ? 1 : -1;\n }\n\n const aType = TextUtils.toLower(a.type);\n const bType = TextUtils.toLower(b.type);\n if (aType !== bType) {\n return aType > bType ? 1 : -1;\n }\n\n return 0;\n })\n .reduce((array, column) => {\n if (\n array.length === 0 ||\n TextUtils.toLower(array[array.length - 1].name) !==\n TextUtils.toLower(column.name) ||\n TextUtils.toLower(array[array.length - 1].type) !==\n TextUtils.toLower(column.type)\n ) {\n array.push(column);\n }\n\n return array;\n }, [] as Column[]);\n\n const filters = Array.from(panelFilters.values())\n .reduce(flattenArray, [] as FilterChangeEvent[])\n .sort((a, b) => a.timestamp - b.timestamp);\n const tableMap = new Map(panelTables);\n\n log.debug('sendUpdate', { columns, filters, tableMap });\n dispatch(\n updateDashboardData(localDashboardId, { columns, filters, tableMap })\n );\n }, [dispatch, localDashboardId, panelColumns, panelFilters, panelTables]);\n\n /**\n * Handler for the COLUMNS_CHANGED event.\n * @param panel The component that's emitting the filter change\n * @param {Column|Array<Column>} columns The columns in this panel\n */\n const handleColumnsChanged = useCallback(\n (panel: Component, columns) => {\n log.debug2('handleColumnsChanged', panel, columns);\n panelColumns.set(panel, [].concat(columns) as Column[]);\n sendUpdate();\n },\n [panelColumns, sendUpdate]\n );\n\n /**\n * Handler for the FILTERS_CHANGED event.\n * @param {Component} panel The component that's emitting the filter change\n * @param {FilterChangeEvent|Array<FilterChangeEvent>} filters The input filters set by the panel\n */\n const handleFiltersChanged = useCallback(\n (panel, filters) => {\n log.debug2('handleFiltersChanged', panel, filters);\n panelFilters.set(panel, [].concat(filters) as FilterChangeEvent[]);\n sendUpdate();\n },\n [panelFilters, sendUpdate]\n );\n\n const handleTableChanged = useCallback(\n (panel, table) => {\n log.debug2('handleTableChanged', panel, table);\n panelTables.set(LayoutUtils.getIdFromPanel(panel), table);\n sendUpdate();\n },\n [panelTables, sendUpdate]\n );\n\n const handlePanelUnmount = useCallback(\n panel => {\n log.debug2('handlePanelUnmount', panel);\n panelColumns.delete(panel);\n panelFilters.delete(panel);\n panelTables.delete(LayoutUtils.getIdFromPanel(panel));\n sendUpdate();\n },\n [panelColumns, panelFilters, panelTables, sendUpdate]\n );\n\n const handleOpenDropdown = useCallback(\n ({\n title = 'DropdownFilter',\n metadata = {},\n panelState = null,\n id = shortid.generate(),\n focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,\n createNewStack = false,\n dragEvent = null,\n }) => {\n const config = {\n type: 'react-component',\n component: DropdownFilterPanel.COMPONENT,\n props: { id, metadata, panelState, localDashboardId },\n title,\n id,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({\n root,\n config,\n focusElement,\n createNewStack,\n dragEvent,\n });\n },\n [layout, localDashboardId]\n );\n\n const handleOpenInput = useCallback(\n ({\n title = 'InputFilter',\n metadata = {},\n panelState = null,\n id = shortid.generate(),\n focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,\n createNewStack = false,\n dragEvent = null,\n }) => {\n const config = {\n type: 'react-component',\n component: InputFilterPanel.COMPONENT,\n props: { id, metadata, panelState, localDashboardId },\n title,\n id,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({\n root,\n config,\n focusElement,\n createNewStack,\n dragEvent,\n });\n },\n [layout, localDashboardId]\n );\n\n const handleOpenFilterSetManager = useCallback(\n ({\n title = 'FilterSets',\n metadata = {},\n panelState = null,\n id = shortid.generate(),\n focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,\n createNewStack = false,\n dragEvent = null,\n }) => {\n const config = {\n type: 'react-component',\n component: FilterSetManagerPanel.COMPONENT,\n props: { id, metadata, panelState, localDashboardId },\n title,\n id,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({\n root,\n config,\n focusElement,\n createNewStack,\n dragEvent,\n });\n },\n [layout, localDashboardId]\n );\n\n useEffect(\n function registerComponentsAndReturnCleanup() {\n const cleanups = [\n registerComponent(DropdownFilterPanel.COMPONENT, DropdownFilterPanel),\n registerComponent(InputFilterPanel.COMPONENT, InputFilterPanel),\n registerComponent(\n FilterSetManagerPanel.COMPONENT,\n FilterSetManagerPanel\n ),\n ];\n\n return () => {\n cleanups.forEach(cleanup => cleanup());\n };\n },\n [registerComponent]\n );\n\n useListener(\n layout.eventHub,\n InputFilterEvent.COLUMNS_CHANGED,\n handleColumnsChanged\n );\n useListener(\n layout.eventHub,\n InputFilterEvent.FILTERS_CHANGED,\n handleFiltersChanged\n );\n useListener(\n layout.eventHub,\n InputFilterEvent.TABLE_CHANGED,\n handleTableChanged\n );\n useListener(\n layout.eventHub,\n InputFilterEvent.OPEN_DROPDOWN,\n handleOpenDropdown\n );\n useListener(layout.eventHub, InputFilterEvent.OPEN_INPUT, handleOpenInput);\n useListener(\n layout.eventHub,\n InputFilterEvent.OPEN_FILTER_SET_MANAGER,\n handleOpenFilterSetManager\n );\n useListener(layout.eventHub, PanelEvent.UNMOUNT, handlePanelUnmount);\n\n return <></>;\n};\n\nexport default FilterPlugin;\n"],"file":"FilterPlugin.js"}
|
|
1
|
+
{"version":3,"sources":["../src/FilterPlugin.tsx"],"names":["React","useCallback","useEffect","useState","useDispatch","shortid","assertIsDashboardPluginProps","LayoutUtils","PanelEvent","updateDashboardData","useListener","Log","TextUtils","InputFilterEvent","DropdownFilterPanel","FilterSetManagerPanel","InputFilterPanel","log","module","flattenArray","accumulator","currentValue","concat","FilterPlugin","props","id","localDashboardId","layout","registerComponent","dispatch","panelColumns","Map","panelFilters","panelTables","sendUpdate","columns","Array","from","values","reduce","sort","a","b","aName","toLower","name","bName","aType","type","bType","array","column","length","push","filters","timestamp","tableMap","debug","handleColumnsChanged","panel","debug2","set","handleFiltersChanged","handleTableChanged","table","getIdFromPanel","handlePanelUnmount","delete","handleOpenDropdown","title","metadata","panelState","generate","focusElement","DEFAULT_FOCUS_SELECTOR","createNewStack","dragEvent","config","component","COMPONENT","root","openComponent","handleOpenInput","handleOpenFilterSetManager","registerComponentsAndReturnCleanup","cleanups","forEach","cleanup","eventHub","COLUMNS_CHANGED","FILTERS_CHANGED","TABLE_CHANGED","OPEN_DROPDOWN","OPEN_INPUT","OPEN_FILTER_SET_MANAGER","UNMOUNT"],"mappings":"AAAA,OAAOA,KAAP,IAA2BC,WAA3B,EAAwCC,SAAxC,EAAmDC,QAAnD,QAAmE,OAAnE;AACA,SAASC,WAAT,QAA4B,aAA5B;AACA,OAAOC,OAAP,MAAoB,SAApB;AACA,SACEC,4BADF,EAGEC,WAHF,EAIEC,UAJF,EAKEC,mBALF,EAMEC,WANF,QAOO,sBAPP;AAQA,OAAOC,GAAP,MAAgB,gBAAhB;AACA,SAASC,SAAT,QAA0B,kBAA1B;SACSC,gB;SAEPC,mB,EACAC,qB,EACAC,gB;AAGF,IAAMC,GAAG,GAAGN,GAAG,CAACO,MAAJ,CAAW,cAAX,CAAZ;;AAeA,SAASC,YAAT,CAAyBC,WAAzB,EAA2CC,YAA3C,EAAuE;AACrE,SAAOD,WAAW,CAACE,MAAZ,CAAmBD,YAAnB,CAAP;AACD;;AAED,OAAO,IAAME,YAAY,GAAIC,KAAD,IAA2C;AACrElB,EAAAA,4BAA4B,CAACkB,KAAD,CAA5B;AACA,MAAM;AAAEC,IAAAA,EAAE,EAAEC,gBAAN;AAAwBC,IAAAA,MAAxB;AAAgCC,IAAAA;AAAhC,MAAsDJ,KAA5D;AACA,MAAMK,QAAQ,GAAGzB,WAAW,EAA5B;AACA,MAAM,CAAC0B,YAAD,IAAiB3B,QAAQ,CAAC,MAAM,IAAI4B,GAAJ,EAAP,CAA/B;AACA,MAAM,CAACC,YAAD,IAAiB7B,QAAQ,CAC7B,MAAM,IAAI4B,GAAJ,EADuB,CAA/B;AAGA,MAAM,CAACE,WAAD,IAAgB9B,QAAQ,CAAC,MAAM,IAAI4B,GAAJ,EAAP,CAA9B;AAEA,MAAMG,UAAU,GAAGjC,WAAW,CAAC,MAAM;AACnC,QAAMkC,OAAO,GAAGC,KAAK,CAACC,IAAN,CAAWP,YAAY,CAACQ,MAAb,EAAX,EACbC,MADa,CACNpB,YADM,EACQ,EADR,EAEbqB,IAFa,CAER,CAACC,CAAD,EAAIC,CAAJ,KAAU;AACd,UAAMC,KAAK,GAAG/B,SAAS,CAACgC,OAAV,CAAkBH,CAAC,CAACI,IAApB,CAAd;AACA,UAAMC,KAAK,GAAGlC,SAAS,CAACgC,OAAV,CAAkBF,CAAC,CAACG,IAApB,CAAd;;AACA,UAAIF,KAAK,KAAKG,KAAd,EAAqB;AACnB,eAAOH,KAAK,GAAGG,KAAR,GAAgB,CAAhB,GAAoB,CAAC,CAA5B;AACD;;AAED,UAAMC,KAAK,GAAGnC,SAAS,CAACgC,OAAV,CAAkBH,CAAC,CAACO,IAApB,CAAd;AACA,UAAMC,KAAK,GAAGrC,SAAS,CAACgC,OAAV,CAAkBF,CAAC,CAACM,IAApB,CAAd;;AACA,UAAID,KAAK,KAAKE,KAAd,EAAqB;AACnB,eAAOF,KAAK,GAAGE,KAAR,GAAgB,CAAhB,GAAoB,CAAC,CAA5B;AACD;;AAED,aAAO,CAAP;AACD,KAhBa,EAiBbV,MAjBa,CAiBN,CAACW,KAAD,EAAQC,MAAR,KAAmB;AACzB,UACED,KAAK,CAACE,MAAN,KAAiB,CAAjB,IACAxC,SAAS,CAACgC,OAAV,CAAkBM,KAAK,CAACA,KAAK,CAACE,MAAN,GAAe,CAAhB,CAAL,CAAwBP,IAA1C,MACEjC,SAAS,CAACgC,OAAV,CAAkBO,MAAM,CAACN,IAAzB,CAFF,IAGAjC,SAAS,CAACgC,OAAV,CAAkBM,KAAK,CAACA,KAAK,CAACE,MAAN,GAAe,CAAhB,CAAL,CAAwBJ,IAA1C,MACEpC,SAAS,CAACgC,OAAV,CAAkBO,MAAM,CAACH,IAAzB,CALJ,EAME;AACAE,QAAAA,KAAK,CAACG,IAAN,CAAWF,MAAX;AACD;;AAED,aAAOD,KAAP;AACD,KA7Ba,EA6BX,EA7BW,CAAhB;AA+BA,QAAMI,OAAO,GAAGlB,KAAK,CAACC,IAAN,CAAWL,YAAY,CAACM,MAAb,EAAX,EACbC,MADa,CACNpB,YADM,EACQ,EADR,EAEbqB,IAFa,CAER,CAACC,CAAD,EAAIC,CAAJ,KAAUD,CAAC,CAACc,SAAF,GAAcb,CAAC,CAACa,SAFlB,CAAhB;AAGA,QAAMC,QAAQ,GAAG,IAAIzB,GAAJ,CAAQE,WAAR,CAAjB;AAEAhB,IAAAA,GAAG,CAACwC,KAAJ,CAAU,YAAV,EAAwB;AAAEtB,MAAAA,OAAF;AAAWmB,MAAAA,OAAX;AAAoBE,MAAAA;AAApB,KAAxB;AACA3B,IAAAA,QAAQ,CACNpB,mBAAmB,CAACiB,gBAAD,EAAmB;AAAES,MAAAA,OAAF;AAAWmB,MAAAA,OAAX;AAAoBE,MAAAA;AAApB,KAAnB,CADb,CAAR;AAGD,GAzC6B,EAyC3B,CAAC3B,QAAD,EAAWH,gBAAX,EAA6BI,YAA7B,EAA2CE,YAA3C,EAAyDC,WAAzD,CAzC2B,CAA9B;AA2CA;AACF;AACA;AACA;AACA;;AACE,MAAMyB,oBAAoB,GAAGzD,WAAW,CACtC,CAAC0D,KAAD,EAAmBxB,OAAnB,KAAkD;AAChDlB,IAAAA,GAAG,CAAC2C,MAAJ,CAAW,sBAAX,EAAmCD,KAAnC,EAA0CxB,OAA1C;AACAL,IAAAA,YAAY,CAAC+B,GAAb,CAAiBF,KAAjB,EAAyB,EAAD,CAAiBrC,MAAjB,CAAwBa,OAAxB,CAAxB;AACAD,IAAAA,UAAU;AACX,GALqC,EAMtC,CAACJ,YAAD,EAAeI,UAAf,CANsC,CAAxC;AASA;AACF;AACA;AACA;AACA;;AACE,MAAM4B,oBAAoB,GAAG7D,WAAW,CACtC,CAAC0D,KAAD,EAAQL,OAAR,KAAoB;AAClBrC,IAAAA,GAAG,CAAC2C,MAAJ,CAAW,sBAAX,EAAmCD,KAAnC,EAA0CL,OAA1C;AACAtB,IAAAA,YAAY,CAAC6B,GAAb,CAAiBF,KAAjB,EAAwB,GAAGrC,MAAH,CAAUgC,OAAV,CAAxB;AACApB,IAAAA,UAAU;AACX,GALqC,EAMtC,CAACF,YAAD,EAAeE,UAAf,CANsC,CAAxC;AASA,MAAM6B,kBAAkB,GAAG9D,WAAW,CACpC,CAAC0D,KAAD,EAAQK,KAAR,KAAkB;AAChB/C,IAAAA,GAAG,CAAC2C,MAAJ,CAAW,oBAAX,EAAiCD,KAAjC,EAAwCK,KAAxC;AACA/B,IAAAA,WAAW,CAAC4B,GAAZ,CAAgBtD,WAAW,CAAC0D,cAAZ,CAA2BN,KAA3B,CAAhB,EAAmDK,KAAnD;AACA9B,IAAAA,UAAU;AACX,GALmC,EAMpC,CAACD,WAAD,EAAcC,UAAd,CANoC,CAAtC;AASA,MAAMgC,kBAAkB,GAAGjE,WAAW,CACpC0D,KAAK,IAAI;AACP1C,IAAAA,GAAG,CAAC2C,MAAJ,CAAW,oBAAX,EAAiCD,KAAjC;AACA7B,IAAAA,YAAY,CAACqC,MAAb,CAAoBR,KAApB;AACA3B,IAAAA,YAAY,CAACmC,MAAb,CAAoBR,KAApB;AACA1B,IAAAA,WAAW,CAACkC,MAAZ,CAAmB5D,WAAW,CAAC0D,cAAZ,CAA2BN,KAA3B,CAAnB;AACAzB,IAAAA,UAAU;AACX,GAPmC,EAQpC,CAACJ,YAAD,EAAeE,YAAf,EAA6BC,WAA7B,EAA0CC,UAA1C,CARoC,CAAtC;AAWA,MAAMkC,kBAAkB,GAAGnE,WAAW,CACpC,QAQM;AAAA,QARL;AACCoE,MAAAA,KAAK,GAAG,gBADT;AAECC,MAAAA,QAAQ,GAAG,EAFZ;AAGCC,MAAAA,UAAU,GAAG,IAHd;AAIC9C,MAAAA,EAAE,GAAGpB,OAAO,CAACmE,QAAR,EAJN;AAKCC,MAAAA,YAAY,GAAGlE,WAAW,CAACmE,sBAL5B;AAMCC,MAAAA,cAAc,GAAG,KANlB;AAOCC,MAAAA,SAAS,GAAG;AAPb,KAQK;AACJ,QAAMC,MAAM,GAAG;AACb7B,MAAAA,IAAI,EAAE,iBADO;AAEb8B,MAAAA,SAAS,EAAEhE,mBAAmB,CAACiE,SAFlB;AAGbvD,MAAAA,KAAK,EAAE;AAAEC,QAAAA,EAAF;AAAM6C,QAAAA,QAAN;AAAgBC,QAAAA,UAAhB;AAA4B7C,QAAAA;AAA5B,OAHM;AAIb2C,MAAAA,KAJa;AAKb5C,MAAAA;AALa,KAAf;AAQA,QAAM;AAAEuD,MAAAA;AAAF,QAAWrD,MAAjB;AACApB,IAAAA,WAAW,CAAC0E,aAAZ,CAA0B;AACxBD,MAAAA,IADwB;AAExBH,MAAAA,MAFwB;AAGxBJ,MAAAA,YAHwB;AAIxBE,MAAAA,cAJwB;AAKxBC,MAAAA;AALwB,KAA1B;AAOD,GA1BmC,EA2BpC,CAACjD,MAAD,EAASD,gBAAT,CA3BoC,CAAtC;AA8BA,MAAMwD,eAAe,GAAGjF,WAAW,CACjC,SAQM;AAAA,QARL;AACCoE,MAAAA,KAAK,GAAG,aADT;AAECC,MAAAA,QAAQ,GAAG,EAFZ;AAGCC,MAAAA,UAAU,GAAG,IAHd;AAIC9C,MAAAA,EAAE,GAAGpB,OAAO,CAACmE,QAAR,EAJN;AAKCC,MAAAA,YAAY,GAAGlE,WAAW,CAACmE,sBAL5B;AAMCC,MAAAA,cAAc,GAAG,KANlB;AAOCC,MAAAA,SAAS,GAAG;AAPb,KAQK;AACJ,QAAMC,MAAM,GAAG;AACb7B,MAAAA,IAAI,EAAE,iBADO;AAEb8B,MAAAA,SAAS,EAAE9D,gBAAgB,CAAC+D,SAFf;AAGbvD,MAAAA,KAAK,EAAE;AAAEC,QAAAA,EAAF;AAAM6C,QAAAA,QAAN;AAAgBC,QAAAA,UAAhB;AAA4B7C,QAAAA;AAA5B,OAHM;AAIb2C,MAAAA,KAJa;AAKb5C,MAAAA;AALa,KAAf;AAQA,QAAM;AAAEuD,MAAAA;AAAF,QAAWrD,MAAjB;AACApB,IAAAA,WAAW,CAAC0E,aAAZ,CAA0B;AACxBD,MAAAA,IADwB;AAExBH,MAAAA,MAFwB;AAGxBJ,MAAAA,YAHwB;AAIxBE,MAAAA,cAJwB;AAKxBC,MAAAA;AALwB,KAA1B;AAOD,GA1BgC,EA2BjC,CAACjD,MAAD,EAASD,gBAAT,CA3BiC,CAAnC;AA8BA,MAAMyD,0BAA0B,GAAGlF,WAAW,CAC5C,SAQM;AAAA,QARL;AACCoE,MAAAA,KAAK,GAAG,YADT;AAECC,MAAAA,QAAQ,GAAG,EAFZ;AAGCC,MAAAA,UAAU,GAAG,IAHd;AAIC9C,MAAAA,EAAE,GAAGpB,OAAO,CAACmE,QAAR,EAJN;AAKCC,MAAAA,YAAY,GAAGlE,WAAW,CAACmE,sBAL5B;AAMCC,MAAAA,cAAc,GAAG,KANlB;AAOCC,MAAAA,SAAS,GAAG;AAPb,KAQK;AACJ,QAAMC,MAAM,GAAG;AACb7B,MAAAA,IAAI,EAAE,iBADO;AAEb8B,MAAAA,SAAS,EAAE/D,qBAAqB,CAACgE,SAFpB;AAGbvD,MAAAA,KAAK,EAAE;AAAEC,QAAAA,EAAF;AAAM6C,QAAAA,QAAN;AAAgBC,QAAAA,UAAhB;AAA4B7C,QAAAA;AAA5B,OAHM;AAIb2C,MAAAA,KAJa;AAKb5C,MAAAA;AALa,KAAf;AAQA,QAAM;AAAEuD,MAAAA;AAAF,QAAWrD,MAAjB;AACApB,IAAAA,WAAW,CAAC0E,aAAZ,CAA0B;AACxBD,MAAAA,IADwB;AAExBH,MAAAA,MAFwB;AAGxBJ,MAAAA,YAHwB;AAIxBE,MAAAA,cAJwB;AAKxBC,MAAAA;AALwB,KAA1B;AAOD,GA1B2C,EA2B5C,CAACjD,MAAD,EAASD,gBAAT,CA3B4C,CAA9C;AA8BAxB,EAAAA,SAAS,CACP,SAASkF,kCAAT,GAA8C;AAC5C,QAAMC,QAAQ,GAAG,CACfzD,iBAAiB,CAACd,mBAAmB,CAACiE,SAArB,EAAgCjE,mBAAhC,CADF,EAEfc,iBAAiB,CAACZ,gBAAgB,CAAC+D,SAAlB,EAA6B/D,gBAA7B,CAFF,EAGfY,iBAAiB,CACfb,qBAAqB,CAACgE,SADP,EAEfhE,qBAFe,CAHF,CAAjB;AASA,WAAO,MAAM;AACXsE,MAAAA,QAAQ,CAACC,OAAT,CAAiBC,OAAO,IAAIA,OAAO,EAAnC;AACD,KAFD;AAGD,GAdM,EAeP,CAAC3D,iBAAD,CAfO,CAAT;AAkBAlB,EAAAA,WAAW,CACTiB,MAAM,CAAC6D,QADE,EAET3E,gBAAgB,CAAC4E,eAFR,EAGT/B,oBAHS,CAAX;AAKAhD,EAAAA,WAAW,CACTiB,MAAM,CAAC6D,QADE,EAET3E,gBAAgB,CAAC6E,eAFR,EAGT5B,oBAHS,CAAX;AAKApD,EAAAA,WAAW,CACTiB,MAAM,CAAC6D,QADE,EAET3E,gBAAgB,CAAC8E,aAFR,EAGT5B,kBAHS,CAAX;AAKArD,EAAAA,WAAW,CACTiB,MAAM,CAAC6D,QADE,EAET3E,gBAAgB,CAAC+E,aAFR,EAGTxB,kBAHS,CAAX;AAKA1D,EAAAA,WAAW,CAACiB,MAAM,CAAC6D,QAAR,EAAkB3E,gBAAgB,CAACgF,UAAnC,EAA+CX,eAA/C,CAAX;AACAxE,EAAAA,WAAW,CACTiB,MAAM,CAAC6D,QADE,EAET3E,gBAAgB,CAACiF,uBAFR,EAGTX,0BAHS,CAAX;AAKAzE,EAAAA,WAAW,CAACiB,MAAM,CAAC6D,QAAR,EAAkBhF,UAAU,CAACuF,OAA7B,EAAsC7B,kBAAtC,CAAX;AAEA,sBAAO,yCAAP;AACD,CA9OM;AAgPP,eAAe3C,YAAf","sourcesContent":["import React, { Component, useCallback, useEffect, useState } from 'react';\nimport { useDispatch } from 'react-redux';\nimport shortid from 'shortid';\nimport {\n assertIsDashboardPluginProps,\n DashboardPluginComponentProps,\n LayoutUtils,\n PanelEvent,\n updateDashboardData,\n useListener,\n} from '@deephaven/dashboard';\nimport Log from '@deephaven/log';\nimport { TextUtils } from '@deephaven/utils';\nimport { InputFilterEvent } from './events';\nimport {\n DropdownFilterPanel,\n FilterSetManagerPanel,\n InputFilterPanel,\n} from './panels';\n\nconst log = Log.module('FilterPlugin');\n\ntype Column = {\n name: string;\n type: string;\n};\n\nexport type FilterChangeEvent = Column & {\n value: string;\n timestamp: number;\n excludePanelIds?: string[];\n};\n\nexport type FilterPluginProps = Partial<DashboardPluginComponentProps>;\n\nfunction flattenArray<T>(accumulator: T[], currentValue: T | T[]): T[] {\n return accumulator.concat(currentValue);\n}\n\nexport const FilterPlugin = (props: FilterPluginProps): JSX.Element => {\n assertIsDashboardPluginProps(props);\n const { id: localDashboardId, layout, registerComponent } = props;\n const dispatch = useDispatch();\n const [panelColumns] = useState(() => new Map<Component, Column[]>());\n const [panelFilters] = useState(\n () => new Map<Component, FilterChangeEvent[]>()\n );\n const [panelTables] = useState(() => new Map());\n\n const sendUpdate = useCallback(() => {\n const columns = Array.from(panelColumns.values())\n .reduce(flattenArray, [] as Column[])\n .sort((a, b) => {\n const aName = TextUtils.toLower(a.name);\n const bName = TextUtils.toLower(b.name);\n if (aName !== bName) {\n return aName > bName ? 1 : -1;\n }\n\n const aType = TextUtils.toLower(a.type);\n const bType = TextUtils.toLower(b.type);\n if (aType !== bType) {\n return aType > bType ? 1 : -1;\n }\n\n return 0;\n })\n .reduce((array, column) => {\n if (\n array.length === 0 ||\n TextUtils.toLower(array[array.length - 1].name) !==\n TextUtils.toLower(column.name) ||\n TextUtils.toLower(array[array.length - 1].type) !==\n TextUtils.toLower(column.type)\n ) {\n array.push(column);\n }\n\n return array;\n }, [] as Column[]);\n\n const filters = Array.from(panelFilters.values())\n .reduce(flattenArray, [] as FilterChangeEvent[])\n .sort((a, b) => a.timestamp - b.timestamp);\n const tableMap = new Map(panelTables);\n\n log.debug('sendUpdate', { columns, filters, tableMap });\n dispatch(\n updateDashboardData(localDashboardId, { columns, filters, tableMap })\n );\n }, [dispatch, localDashboardId, panelColumns, panelFilters, panelTables]);\n\n /**\n * Handler for the COLUMNS_CHANGED event.\n * @param panel The component that's emitting the filter change\n * @param columns The columns in this panel\n */\n const handleColumnsChanged = useCallback(\n (panel: Component, columns: Column | Column[]) => {\n log.debug2('handleColumnsChanged', panel, columns);\n panelColumns.set(panel, ([] as Column[]).concat(columns));\n sendUpdate();\n },\n [panelColumns, sendUpdate]\n );\n\n /**\n * Handler for the FILTERS_CHANGED event.\n * @param {Component} panel The component that's emitting the filter change\n * @param {FilterChangeEvent|Array<FilterChangeEvent>} filters The input filters set by the panel\n */\n const handleFiltersChanged = useCallback(\n (panel, filters) => {\n log.debug2('handleFiltersChanged', panel, filters);\n panelFilters.set(panel, [].concat(filters) as FilterChangeEvent[]);\n sendUpdate();\n },\n [panelFilters, sendUpdate]\n );\n\n const handleTableChanged = useCallback(\n (panel, table) => {\n log.debug2('handleTableChanged', panel, table);\n panelTables.set(LayoutUtils.getIdFromPanel(panel), table);\n sendUpdate();\n },\n [panelTables, sendUpdate]\n );\n\n const handlePanelUnmount = useCallback(\n panel => {\n log.debug2('handlePanelUnmount', panel);\n panelColumns.delete(panel);\n panelFilters.delete(panel);\n panelTables.delete(LayoutUtils.getIdFromPanel(panel));\n sendUpdate();\n },\n [panelColumns, panelFilters, panelTables, sendUpdate]\n );\n\n const handleOpenDropdown = useCallback(\n ({\n title = 'DropdownFilter',\n metadata = {},\n panelState = null,\n id = shortid.generate(),\n focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,\n createNewStack = false,\n dragEvent = null,\n }) => {\n const config = {\n type: 'react-component',\n component: DropdownFilterPanel.COMPONENT,\n props: { id, metadata, panelState, localDashboardId },\n title,\n id,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({\n root,\n config,\n focusElement,\n createNewStack,\n dragEvent,\n });\n },\n [layout, localDashboardId]\n );\n\n const handleOpenInput = useCallback(\n ({\n title = 'InputFilter',\n metadata = {},\n panelState = null,\n id = shortid.generate(),\n focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,\n createNewStack = false,\n dragEvent = null,\n }) => {\n const config = {\n type: 'react-component',\n component: InputFilterPanel.COMPONENT,\n props: { id, metadata, panelState, localDashboardId },\n title,\n id,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({\n root,\n config,\n focusElement,\n createNewStack,\n dragEvent,\n });\n },\n [layout, localDashboardId]\n );\n\n const handleOpenFilterSetManager = useCallback(\n ({\n title = 'FilterSets',\n metadata = {},\n panelState = null,\n id = shortid.generate(),\n focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,\n createNewStack = false,\n dragEvent = null,\n }) => {\n const config = {\n type: 'react-component',\n component: FilterSetManagerPanel.COMPONENT,\n props: { id, metadata, panelState, localDashboardId },\n title,\n id,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({\n root,\n config,\n focusElement,\n createNewStack,\n dragEvent,\n });\n },\n [layout, localDashboardId]\n );\n\n useEffect(\n function registerComponentsAndReturnCleanup() {\n const cleanups = [\n registerComponent(DropdownFilterPanel.COMPONENT, DropdownFilterPanel),\n registerComponent(InputFilterPanel.COMPONENT, InputFilterPanel),\n registerComponent(\n FilterSetManagerPanel.COMPONENT,\n FilterSetManagerPanel\n ),\n ];\n\n return () => {\n cleanups.forEach(cleanup => cleanup());\n };\n },\n [registerComponent]\n );\n\n useListener(\n layout.eventHub,\n InputFilterEvent.COLUMNS_CHANGED,\n handleColumnsChanged\n );\n useListener(\n layout.eventHub,\n InputFilterEvent.FILTERS_CHANGED,\n handleFiltersChanged\n );\n useListener(\n layout.eventHub,\n InputFilterEvent.TABLE_CHANGED,\n handleTableChanged\n );\n useListener(\n layout.eventHub,\n InputFilterEvent.OPEN_DROPDOWN,\n handleOpenDropdown\n );\n useListener(layout.eventHub, InputFilterEvent.OPEN_INPUT, handleOpenInput);\n useListener(\n layout.eventHub,\n InputFilterEvent.OPEN_FILTER_SET_MANAGER,\n handleOpenFilterSetManager\n );\n useListener(layout.eventHub, PanelEvent.UNMOUNT, handlePanelUnmount);\n\n return <></>;\n};\n\nexport default FilterPlugin;\n"],"file":"FilterPlugin.js"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
export default ControlType;
|
|
2
1
|
declare class ControlType {
|
|
3
2
|
static DROPDOWN_FILTER: string;
|
|
4
3
|
static INPUT_FILTER: string;
|
|
5
4
|
static MARKDOWN: string;
|
|
6
5
|
static FILTER_SET_MANAGER: string;
|
|
7
6
|
}
|
|
7
|
+
export default ControlType;
|
|
8
8
|
//# sourceMappingURL=ControlType.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ControlType.d.ts","sourceRoot":"","sources":["../../src/controls/ControlType.
|
|
1
|
+
{"version":3,"file":"ControlType.d.ts","sourceRoot":"","sources":["../../src/controls/ControlType.ts"],"names":[],"mappings":"AAAA,cAAM,WAAW;IACf,MAAM,CAAC,eAAe,SAAiC;IAEvD,MAAM,CAAC,YAAY,SAA8B;IAEjD,MAAM,CAAC,QAAQ,SAA0B;IAEzC,MAAM,CAAC,kBAAkB,SAAoC;CAC9D;AAED,eAAe,WAAW,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/controls/ControlType.
|
|
1
|
+
{"version":3,"sources":["../../src/controls/ControlType.ts"],"names":["ControlType"],"mappings":";;AAAA,MAAMA,WAAN,CAAkB;;gBAAZA,W,qBACqB,6B;;gBADrBA,W,kBAGkB,0B;;gBAHlBA,W,cAKc,sB;;gBALdA,W,wBAOwB,gC;;AAG9B,eAAeA,WAAf","sourcesContent":["class ControlType {\n static DROPDOWN_FILTER = 'ControlType.DROPDOWN_FILTER';\n\n static INPUT_FILTER = 'ControlType.INPUT_FILTER';\n\n static MARKDOWN = 'ControlType.MARKDOWN';\n\n static FILTER_SET_MANAGER = 'ControlType.FILTER_SET_MANAGER';\n}\n\nexport default ControlType;\n"],"file":"ControlType.js"}
|
|
@@ -1,23 +1,73 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { ChangeEvent, Component, KeyboardEvent, MouseEvent, ReactElement, RefObject } from 'react';
|
|
2
|
+
import { Column } from '@deephaven/jsapi-shim';
|
|
3
|
+
import memoizee from 'memoizee';
|
|
4
|
+
import './DropdownFilter.scss';
|
|
5
|
+
import { LinkPoint } from '../../linker/LinkerUtils';
|
|
6
|
+
export interface DropdownFilterColumn {
|
|
7
|
+
name: string;
|
|
8
|
+
type?: string;
|
|
9
|
+
}
|
|
10
|
+
interface DropdownFilterProps {
|
|
11
|
+
column: DropdownFilterColumn;
|
|
12
|
+
columns: DropdownFilterColumn[];
|
|
13
|
+
onSourceMouseEnter: () => void;
|
|
14
|
+
onSourceMouseLeave: () => void;
|
|
15
|
+
disableLinking: boolean;
|
|
16
|
+
isLinkerActive: boolean;
|
|
17
|
+
isLoaded: boolean;
|
|
18
|
+
isValueShown: boolean;
|
|
19
|
+
settingsError: string;
|
|
20
|
+
source: LinkPoint;
|
|
21
|
+
value: string;
|
|
22
|
+
values: (string | null)[];
|
|
23
|
+
onChange: (change: {
|
|
24
|
+
column: Partial<Column> | null;
|
|
25
|
+
isValueShown?: boolean;
|
|
26
|
+
value?: string;
|
|
27
|
+
}) => void;
|
|
28
|
+
onColumnSelected: () => void;
|
|
29
|
+
}
|
|
30
|
+
interface DropdownFilterState {
|
|
31
|
+
column: DropdownFilterColumn | null;
|
|
32
|
+
selectedColumn: DropdownFilterColumn | null;
|
|
33
|
+
disableCancel: boolean;
|
|
34
|
+
isValueShown: boolean;
|
|
35
|
+
value: string | null;
|
|
36
|
+
}
|
|
37
|
+
declare class DropdownFilter extends Component<DropdownFilterProps, DropdownFilterState> {
|
|
38
|
+
static defaultProps: {
|
|
39
|
+
column: null;
|
|
40
|
+
disableLinking: boolean;
|
|
41
|
+
isLinkerActive: boolean;
|
|
42
|
+
isLoaded: boolean;
|
|
43
|
+
isValueShown: boolean;
|
|
44
|
+
settingsError: null;
|
|
45
|
+
source: null;
|
|
46
|
+
value: string;
|
|
47
|
+
values: never[];
|
|
48
|
+
onColumnSelected: () => void;
|
|
49
|
+
onSourceMouseEnter: () => void;
|
|
50
|
+
onSourceMouseLeave: () => void;
|
|
51
|
+
};
|
|
3
52
|
static PLACEHOLDER: string;
|
|
4
53
|
static SOURCE_BUTTON_CLASS_NAME: string;
|
|
5
54
|
static SOURCE_BUTTON_PLACEHOLDER: string;
|
|
6
|
-
constructor(props:
|
|
7
|
-
|
|
55
|
+
constructor(props: DropdownFilterProps);
|
|
56
|
+
componentDidUpdate(prevProps: DropdownFilterProps, prevState: DropdownFilterState): void;
|
|
57
|
+
componentWillUnmount(): void;
|
|
58
|
+
dropdownRef: RefObject<HTMLSelectElement>;
|
|
59
|
+
getCompatibleColumns: (source: LinkPoint, columns: DropdownFilterColumn[]) => DropdownFilterColumn[];
|
|
60
|
+
getColumnOptions: (columns: DropdownFilterColumn[], selectedColumn: DropdownFilterColumn | null) => [JSX.Element[], number];
|
|
61
|
+
getSelectedOptionIndex: (values: (string | null)[], value: string | null) => number;
|
|
62
|
+
getValueOptions: (values: (string | null)[]) => JSX.Element[];
|
|
63
|
+
getItemLabel: ((columns: any, index: any) => any) & memoizee.Memoized<(columns: any, index: any) => any>;
|
|
64
|
+
handleColumnChange(event: ChangeEvent<HTMLSelectElement>): void;
|
|
65
|
+
handleDropdownKeyPress(event: KeyboardEvent<HTMLSelectElement>): void;
|
|
66
|
+
handleValueChange(event: ChangeEvent<HTMLSelectElement>): void;
|
|
8
67
|
handleSettingsCancel(): void;
|
|
9
|
-
handleSettingsClick(event: any): void;
|
|
10
68
|
handleSettingsSave(): void;
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
handleValueChange(event: any): void;
|
|
14
|
-
sendUpdate(): void;
|
|
15
|
-
dropdownRef: React.RefObject<any>;
|
|
16
|
-
getCompatibleColumns: (this: any, source: any, columns: any) => any;
|
|
17
|
-
getColumnOptions: (this: any, columns: any, selectedColumn: any) => (number | JSX.Element[])[];
|
|
18
|
-
getSelectedOptionIndex: (this: any, values: any, value: any) => any;
|
|
19
|
-
getValueOptions: (this: any, values: any) => any[];
|
|
20
|
-
getItemLabel: ((columns: any, index: any) => any) & memoizee.Memoized<(columns: any, index: any) => any>;
|
|
69
|
+
handleSettingsClick(event: MouseEvent<HTMLButtonElement>): void;
|
|
70
|
+
handleBackgroundClick(event: MouseEvent<HTMLDivElement>): void;
|
|
21
71
|
handleMouseEnter(): void;
|
|
22
72
|
handleMouseLeave(): void;
|
|
23
73
|
sourceUpdated(): void;
|
|
@@ -25,72 +75,14 @@ declare class DropdownFilter extends React.Component<any, any, any> {
|
|
|
25
75
|
focusInput(): void;
|
|
26
76
|
resetValue(): void;
|
|
27
77
|
clearFilter(): void;
|
|
28
|
-
setFilterState({ name, type, value, isValueShown }: {
|
|
29
|
-
name:
|
|
30
|
-
type:
|
|
31
|
-
value:
|
|
32
|
-
isValueShown:
|
|
78
|
+
setFilterState({ name, type, value, isValueShown, }: {
|
|
79
|
+
name: string;
|
|
80
|
+
type: string;
|
|
81
|
+
value: string;
|
|
82
|
+
isValueShown: boolean;
|
|
33
83
|
}): void;
|
|
84
|
+
sendUpdate: import("lodash").DebouncedFunc<() => void>;
|
|
85
|
+
render(): ReactElement;
|
|
34
86
|
}
|
|
35
|
-
|
|
36
|
-
namespace propTypes {
|
|
37
|
-
const column: PropTypes.Requireable<PropTypes.InferProps<{
|
|
38
|
-
name: PropTypes.Validator<string>;
|
|
39
|
-
type: PropTypes.Validator<string>;
|
|
40
|
-
description: PropTypes.Requireable<string>;
|
|
41
|
-
constituentType: PropTypes.Requireable<string>;
|
|
42
|
-
}>>;
|
|
43
|
-
const columns: PropTypes.Validator<(PropTypes.InferProps<{
|
|
44
|
-
name: PropTypes.Validator<string>;
|
|
45
|
-
type: PropTypes.Validator<string>;
|
|
46
|
-
description: PropTypes.Requireable<string>;
|
|
47
|
-
constituentType: PropTypes.Requireable<string>;
|
|
48
|
-
}> | null | undefined)[]>;
|
|
49
|
-
const onSourceMouseEnter: PropTypes.Requireable<(...args: any[]) => any>;
|
|
50
|
-
const onSourceMouseLeave: PropTypes.Requireable<(...args: any[]) => any>;
|
|
51
|
-
const disableLinking: PropTypes.Requireable<boolean>;
|
|
52
|
-
const isLinkerActive: PropTypes.Requireable<boolean>;
|
|
53
|
-
const isLoaded: PropTypes.Requireable<boolean>;
|
|
54
|
-
const isValueShown: PropTypes.Requireable<boolean>;
|
|
55
|
-
const settingsError: PropTypes.Requireable<string>;
|
|
56
|
-
const source: PropTypes.Requireable<PropTypes.InferProps<{
|
|
57
|
-
panelId: PropTypes.Validator<string>;
|
|
58
|
-
columnName: PropTypes.Validator<string>;
|
|
59
|
-
columnType: PropTypes.Validator<string>;
|
|
60
|
-
}>>;
|
|
61
|
-
const value: PropTypes.Requireable<string>;
|
|
62
|
-
const values: PropTypes.Requireable<(string | null | undefined)[]>;
|
|
63
|
-
const onChange: PropTypes.Validator<(...args: any[]) => any>;
|
|
64
|
-
const onColumnSelected: PropTypes.Requireable<(...args: any[]) => any>;
|
|
65
|
-
}
|
|
66
|
-
namespace defaultProps {
|
|
67
|
-
const column_1: null;
|
|
68
|
-
export { column_1 as column };
|
|
69
|
-
const disableLinking_1: boolean;
|
|
70
|
-
export { disableLinking_1 as disableLinking };
|
|
71
|
-
const isLinkerActive_1: boolean;
|
|
72
|
-
export { isLinkerActive_1 as isLinkerActive };
|
|
73
|
-
const isLoaded_1: boolean;
|
|
74
|
-
export { isLoaded_1 as isLoaded };
|
|
75
|
-
const isValueShown_1: boolean;
|
|
76
|
-
export { isValueShown_1 as isValueShown };
|
|
77
|
-
const settingsError_1: null;
|
|
78
|
-
export { settingsError_1 as settingsError };
|
|
79
|
-
const source_1: null;
|
|
80
|
-
export { source_1 as source };
|
|
81
|
-
const value_1: string;
|
|
82
|
-
export { value_1 as value };
|
|
83
|
-
const values_1: never[];
|
|
84
|
-
export { values_1 as values };
|
|
85
|
-
export function onColumnSelected_1(): void;
|
|
86
|
-
export { onColumnSelected_1 as onColumnSelected };
|
|
87
|
-
export function onSourceMouseEnter_1(): void;
|
|
88
|
-
export { onSourceMouseEnter_1 as onSourceMouseEnter };
|
|
89
|
-
export function onSourceMouseLeave_1(): void;
|
|
90
|
-
export { onSourceMouseLeave_1 as onSourceMouseLeave };
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
import React from "react";
|
|
94
|
-
import memoizee from "memoizee";
|
|
95
|
-
import PropTypes from "prop-types";
|
|
87
|
+
export default DropdownFilter;
|
|
96
88
|
//# sourceMappingURL=DropdownFilter.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DropdownFilter.d.ts","sourceRoot":"","sources":["../../../src/controls/dropdown-filter/DropdownFilter.
|
|
1
|
+
{"version":3,"file":"DropdownFilter.d.ts","sourceRoot":"","sources":["../../../src/controls/dropdown-filter/DropdownFilter.tsx"],"names":[],"mappings":"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"}
|
|
@@ -5,17 +5,14 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
|
5
5
|
/* eslint-disable jsx-a11y/no-static-element-interactions */
|
|
6
6
|
// background click is just a convenience method, not an actual a11y issue
|
|
7
7
|
import React, { Component } from 'react';
|
|
8
|
-
import PropTypes from 'prop-types';
|
|
9
8
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
10
9
|
import { Button, CardFlip, SocketedButton } from '@deephaven/components';
|
|
11
10
|
import { vsGear } from '@deephaven/icons';
|
|
12
|
-
import { PropTypes as APIPropTypes } from '@deephaven/jsapi-shim';
|
|
13
11
|
import { TableUtils } from '@deephaven/jsapi-utils';
|
|
14
12
|
import memoizee from 'memoizee';
|
|
15
13
|
import memoize from 'memoize-one';
|
|
16
14
|
import debounce from 'lodash.debounce';
|
|
17
15
|
import Log from '@deephaven/log';
|
|
18
|
-
import { UIPropTypes } from "../../prop-types/index.js";
|
|
19
16
|
import "./DropdownFilter.css";
|
|
20
17
|
var log = Log.module('DropdownFilter');
|
|
21
18
|
var UPDATE_DEBOUNCE = 150;
|
|
@@ -24,11 +21,13 @@ class DropdownFilter extends Component {
|
|
|
24
21
|
constructor(props) {
|
|
25
22
|
super(props);
|
|
26
23
|
|
|
24
|
+
_defineProperty(this, "dropdownRef", void 0);
|
|
25
|
+
|
|
27
26
|
_defineProperty(this, "getCompatibleColumns", memoize((source, columns) => source ? columns.filter(_ref => {
|
|
28
27
|
var {
|
|
29
28
|
type
|
|
30
29
|
} = _ref;
|
|
31
|
-
return TableUtils.isCompatibleType(type, source.columnType);
|
|
30
|
+
return type !== undefined && TableUtils.isCompatibleType(type, source.columnType);
|
|
32
31
|
}) : []));
|
|
33
32
|
|
|
34
33
|
_defineProperty(this, "getColumnOptions", memoize((columns, selectedColumn) => {
|
|
@@ -76,6 +75,22 @@ class DropdownFilter extends Component {
|
|
|
76
75
|
return name;
|
|
77
76
|
}));
|
|
78
77
|
|
|
78
|
+
_defineProperty(this, "sendUpdate", debounce(() => {
|
|
79
|
+
var {
|
|
80
|
+
onChange
|
|
81
|
+
} = this.props;
|
|
82
|
+
var {
|
|
83
|
+
column,
|
|
84
|
+
value,
|
|
85
|
+
isValueShown
|
|
86
|
+
} = this.state;
|
|
87
|
+
onChange({
|
|
88
|
+
column,
|
|
89
|
+
isValueShown,
|
|
90
|
+
value: value !== null && value !== void 0 ? value : undefined
|
|
91
|
+
});
|
|
92
|
+
}, UPDATE_DEBOUNCE));
|
|
93
|
+
|
|
79
94
|
this.handleColumnChange = this.handleColumnChange.bind(this);
|
|
80
95
|
this.handleSettingsCancel = this.handleSettingsCancel.bind(this);
|
|
81
96
|
this.handleSettingsClick = this.handleSettingsClick.bind(this);
|
|
@@ -83,18 +98,17 @@ class DropdownFilter extends Component {
|
|
|
83
98
|
this.handleBackgroundClick = this.handleBackgroundClick.bind(this);
|
|
84
99
|
this.handleDropdownKeyPress = this.handleDropdownKeyPress.bind(this);
|
|
85
100
|
this.handleValueChange = this.handleValueChange.bind(this);
|
|
86
|
-
this.sendUpdate = debounce(this.sendUpdate.bind(this), UPDATE_DEBOUNCE);
|
|
87
101
|
this.dropdownRef = /*#__PURE__*/React.createRef();
|
|
88
102
|
var {
|
|
89
|
-
column,
|
|
90
|
-
isValueShown,
|
|
103
|
+
column: _column,
|
|
104
|
+
isValueShown: _isValueShown,
|
|
91
105
|
value: _value
|
|
92
106
|
} = props;
|
|
93
107
|
this.state = {
|
|
94
|
-
column,
|
|
95
|
-
selectedColumn:
|
|
96
|
-
disableCancel: !
|
|
97
|
-
isValueShown,
|
|
108
|
+
column: _column,
|
|
109
|
+
selectedColumn: _column,
|
|
110
|
+
disableCancel: !_isValueShown,
|
|
111
|
+
isValueShown: _isValueShown,
|
|
98
112
|
value: _value
|
|
99
113
|
};
|
|
100
114
|
}
|
|
@@ -143,7 +157,7 @@ class DropdownFilter extends Component {
|
|
|
143
157
|
} = event.target;
|
|
144
158
|
log.debug2('handleColumnChange', value);
|
|
145
159
|
|
|
146
|
-
if (value < 0) {
|
|
160
|
+
if (value != null && parseInt(value, 10) < 0) {
|
|
147
161
|
this.setState({
|
|
148
162
|
selectedColumn: null
|
|
149
163
|
});
|
|
@@ -156,7 +170,7 @@ class DropdownFilter extends Component {
|
|
|
156
170
|
} = this.props;
|
|
157
171
|
var columns = this.getCompatibleColumns(source, allColumns);
|
|
158
172
|
this.setState({
|
|
159
|
-
selectedColumn: columns[value]
|
|
173
|
+
selectedColumn: columns[parseInt(value, 10)]
|
|
160
174
|
});
|
|
161
175
|
}
|
|
162
176
|
|
|
@@ -306,22 +320,6 @@ class DropdownFilter extends Component {
|
|
|
306
320
|
});
|
|
307
321
|
}
|
|
308
322
|
|
|
309
|
-
sendUpdate() {
|
|
310
|
-
var {
|
|
311
|
-
onChange
|
|
312
|
-
} = this.props;
|
|
313
|
-
var {
|
|
314
|
-
column,
|
|
315
|
-
value,
|
|
316
|
-
isValueShown
|
|
317
|
-
} = this.state;
|
|
318
|
-
onChange({
|
|
319
|
-
column,
|
|
320
|
-
isValueShown,
|
|
321
|
-
value
|
|
322
|
-
});
|
|
323
|
-
}
|
|
324
|
-
|
|
325
323
|
render() {
|
|
326
324
|
var _source$columnName;
|
|
327
325
|
|
|
@@ -388,14 +386,14 @@ class DropdownFilter extends Component {
|
|
|
388
386
|
type: "button",
|
|
389
387
|
onClick: this.handleSettingsCancel,
|
|
390
388
|
disabled: disableCancel || isValueShown || isLinkerActive,
|
|
391
|
-
tooltip: isLinkerActive ? 'Cancel disabled while linker open' :
|
|
389
|
+
tooltip: isLinkerActive ? 'Cancel disabled while linker open' : undefined
|
|
392
390
|
}, "Cancel"), /*#__PURE__*/React.createElement(Button, {
|
|
393
391
|
kind: "primary",
|
|
394
392
|
type: "button",
|
|
395
393
|
className: "ml-2",
|
|
396
394
|
onClick: this.handleSettingsSave,
|
|
397
395
|
disabled: disableSave || isValueShown || isLinkerActive,
|
|
398
|
-
tooltip: isLinkerActive ? 'Save disabled while linker open' :
|
|
396
|
+
tooltip: isLinkerActive ? 'Save disabled while linker open' : undefined
|
|
399
397
|
}, "Save")))), /*#__PURE__*/React.createElement("div", {
|
|
400
398
|
className: "dropdown-filter-value-card",
|
|
401
399
|
onClick: this.handleBackgroundClick
|
|
@@ -429,29 +427,7 @@ class DropdownFilter extends Component {
|
|
|
429
427
|
|
|
430
428
|
}
|
|
431
429
|
|
|
432
|
-
_defineProperty(DropdownFilter, "
|
|
433
|
-
|
|
434
|
-
_defineProperty(DropdownFilter, "SOURCE_BUTTON_CLASS_NAME", 'btn-dropdown-filter-selector');
|
|
435
|
-
|
|
436
|
-
_defineProperty(DropdownFilter, "SOURCE_BUTTON_PLACEHOLDER", 'Select a column');
|
|
437
|
-
|
|
438
|
-
DropdownFilter.propTypes = {
|
|
439
|
-
column: APIPropTypes.Column,
|
|
440
|
-
columns: PropTypes.arrayOf(APIPropTypes.Column).isRequired,
|
|
441
|
-
onSourceMouseEnter: PropTypes.func,
|
|
442
|
-
onSourceMouseLeave: PropTypes.func,
|
|
443
|
-
disableLinking: PropTypes.bool,
|
|
444
|
-
isLinkerActive: PropTypes.bool,
|
|
445
|
-
isLoaded: PropTypes.bool,
|
|
446
|
-
isValueShown: PropTypes.bool,
|
|
447
|
-
settingsError: PropTypes.string,
|
|
448
|
-
source: UIPropTypes.LinkPoint,
|
|
449
|
-
value: PropTypes.string,
|
|
450
|
-
values: PropTypes.arrayOf(PropTypes.string),
|
|
451
|
-
onChange: PropTypes.func.isRequired,
|
|
452
|
-
onColumnSelected: PropTypes.func
|
|
453
|
-
};
|
|
454
|
-
DropdownFilter.defaultProps = {
|
|
430
|
+
_defineProperty(DropdownFilter, "defaultProps", {
|
|
455
431
|
column: null,
|
|
456
432
|
disableLinking: false,
|
|
457
433
|
isLinkerActive: false,
|
|
@@ -461,9 +437,16 @@ DropdownFilter.defaultProps = {
|
|
|
461
437
|
source: null,
|
|
462
438
|
value: '',
|
|
463
439
|
values: [],
|
|
464
|
-
onColumnSelected: () =>
|
|
465
|
-
onSourceMouseEnter: () =>
|
|
466
|
-
onSourceMouseLeave: () =>
|
|
467
|
-
};
|
|
440
|
+
onColumnSelected: () => undefined,
|
|
441
|
+
onSourceMouseEnter: () => undefined,
|
|
442
|
+
onSourceMouseLeave: () => undefined
|
|
443
|
+
});
|
|
444
|
+
|
|
445
|
+
_defineProperty(DropdownFilter, "PLACEHOLDER", 'Select a value...');
|
|
446
|
+
|
|
447
|
+
_defineProperty(DropdownFilter, "SOURCE_BUTTON_CLASS_NAME", 'btn-dropdown-filter-selector');
|
|
448
|
+
|
|
449
|
+
_defineProperty(DropdownFilter, "SOURCE_BUTTON_PLACEHOLDER", 'Select a column');
|
|
450
|
+
|
|
468
451
|
export default DropdownFilter;
|
|
469
452
|
//# sourceMappingURL=DropdownFilter.js.map
|