@deephaven/dashboard-core-plugins 0.15.5-vite.12 → 0.15.6-vite.19
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/ChartPlugin.d.ts +2 -1
- package/dist/ChartPlugin.d.ts.map +1 -1
- package/dist/ChartPlugin.js.map +1 -1
- package/dist/FilterPlugin.js +1 -1
- package/dist/FilterPlugin.js.map +1 -1
- package/dist/GridPlugin.d.ts +2 -1
- package/dist/GridPlugin.d.ts.map +1 -1
- package/dist/GridPlugin.js.map +1 -1
- package/dist/PandasPlugin.d.ts +2 -1
- package/dist/PandasPlugin.d.ts.map +1 -1
- package/dist/PandasPlugin.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/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/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/linker/index.d.ts +2 -0
- package/dist/linker/index.d.ts.map +1 -0
- package/dist/linker/index.js +2 -0
- package/dist/linker/index.js.map +1 -0
- 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 +29 -21
- package/dist/panels/ChartFilterOverlay.d.ts.map +1 -1
- package/dist/panels/ChartFilterOverlay.js.map +1 -1
- package/dist/panels/ChartPanel.d.ts +187 -152
- package/dist/panels/ChartPanel.d.ts.map +1 -1
- package/dist/panels/ChartPanel.js +87 -84
- 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 +135 -115
- package/dist/panels/NotebookPanel.d.ts.map +1 -1
- package/dist/panels/NotebookPanel.js +93 -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/panels/index.d.ts +3 -0
- package/dist/panels/index.d.ts.map +1 -1
- package/dist/panels/index.js +3 -0
- package/dist/panels/index.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 +27 -27
- package/dist/redux/selectors.js.map +1 -1
- package/package.json +20 -17
|
@@ -1,28 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
isActive: PropTypes.Validator<boolean>;
|
|
15
|
-
}> | null | undefined)[]>;
|
|
16
|
-
const onColumnSelected: PropTypes.Validator<(...args: any[]) => any>;
|
|
17
|
-
const onMouseEnter: PropTypes.Requireable<(...args: any[]) => any>;
|
|
18
|
-
const onMouseLeave: PropTypes.Requireable<(...args: any[]) => any>;
|
|
19
|
-
}
|
|
20
|
-
namespace defaultProps {
|
|
21
|
-
export function onMouseEnter_1(): void;
|
|
22
|
-
export { onMouseEnter_1 as onMouseEnter };
|
|
23
|
-
export function onMouseLeave_1(): void;
|
|
24
|
-
export { onMouseLeave_1 as onMouseLeave };
|
|
25
|
-
}
|
|
1
|
+
import { MouseEventHandler, ReactElement } from 'react';
|
|
2
|
+
import './ChartColumnSelectorOverlay.scss';
|
|
3
|
+
export interface SelectorColumn {
|
|
4
|
+
name: string;
|
|
5
|
+
type: string;
|
|
6
|
+
isValid: boolean;
|
|
7
|
+
isActive: boolean;
|
|
8
|
+
}
|
|
9
|
+
interface ChartColumnSelectorOverlayProps {
|
|
10
|
+
columns: SelectorColumn[];
|
|
11
|
+
onColumnSelected: (name: string) => void;
|
|
12
|
+
onMouseEnter?: (column: SelectorColumn) => void;
|
|
13
|
+
onMouseLeave?: MouseEventHandler<HTMLButtonElement>;
|
|
26
14
|
}
|
|
27
|
-
|
|
15
|
+
declare const ChartColumnSelectorOverlay: {
|
|
16
|
+
({ columns, onColumnSelected, onMouseEnter, onMouseLeave, }: ChartColumnSelectorOverlayProps): ReactElement;
|
|
17
|
+
makeButtonClassName(columnName: string): string;
|
|
18
|
+
defaultProps: {
|
|
19
|
+
onMouseEnter: () => void;
|
|
20
|
+
onMouseLeave: () => void;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
export default ChartColumnSelectorOverlay;
|
|
28
24
|
//# sourceMappingURL=ChartColumnSelectorOverlay.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartColumnSelectorOverlay.d.ts","sourceRoot":"","sources":["../../src/panels/ChartColumnSelectorOverlay.
|
|
1
|
+
{"version":3,"file":"ChartColumnSelectorOverlay.d.ts","sourceRoot":"","sources":["../../src/panels/ChartColumnSelectorOverlay.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,iBAAiB,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAG/D,OAAO,mCAAmC,CAAC;AAE3C,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,UAAU,+BAA+B;IACvC,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,gBAAgB,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,KAAK,IAAI,CAAC;IAChD,YAAY,CAAC,EAAE,iBAAiB,CAAC,iBAAiB,CAAC,CAAC;CACrD;AAED,QAAA,MAAM,0BAA0B;iEAK7B,+BAA+B,GAAG,YAAY;oCAiCa,MAAM;;4BAIhD,IAAI;4BACJ,IAAI;;CAPvB,CAAC;AAUF,eAAe,0BAA0B,CAAC"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import PropTypes from 'prop-types';
|
|
3
2
|
import classNames from 'classnames';
|
|
4
3
|
import { SocketedButton } from '@deephaven/components';
|
|
5
4
|
import "./ChartColumnSelectorOverlay.css";
|
|
@@ -23,7 +22,9 @@ var ChartColumnSelectorOverlay = _ref => {
|
|
|
23
22
|
key: column.name,
|
|
24
23
|
className: classNames('btn-chart-column-selector', ChartColumnSelectorOverlay.makeButtonClassName(column.name)),
|
|
25
24
|
onClick: () => onColumnSelected(column.name),
|
|
26
|
-
onMouseEnter: () =>
|
|
25
|
+
onMouseEnter: () => {
|
|
26
|
+
if (_onMouseEnter) _onMouseEnter(column);
|
|
27
|
+
},
|
|
27
28
|
onMouseLeave: onMouseLeave,
|
|
28
29
|
disabled: !column.isValid,
|
|
29
30
|
isLinked: column.isActive
|
|
@@ -32,19 +33,9 @@ var ChartColumnSelectorOverlay = _ref => {
|
|
|
32
33
|
|
|
33
34
|
ChartColumnSelectorOverlay.makeButtonClassName = columnName => "btn-chart-column-selector-".concat(columnName);
|
|
34
35
|
|
|
35
|
-
ChartColumnSelectorOverlay.propTypes = {
|
|
36
|
-
columns: PropTypes.arrayOf(PropTypes.shape({
|
|
37
|
-
name: PropTypes.string.isRequired,
|
|
38
|
-
isValid: PropTypes.bool.isRequired,
|
|
39
|
-
isActive: PropTypes.bool.isRequired
|
|
40
|
-
})).isRequired,
|
|
41
|
-
onColumnSelected: PropTypes.func.isRequired,
|
|
42
|
-
onMouseEnter: PropTypes.func,
|
|
43
|
-
onMouseLeave: PropTypes.func
|
|
44
|
-
};
|
|
45
36
|
ChartColumnSelectorOverlay.defaultProps = {
|
|
46
|
-
onMouseEnter: () =>
|
|
47
|
-
onMouseLeave: () =>
|
|
37
|
+
onMouseEnter: () => undefined,
|
|
38
|
+
onMouseLeave: () => undefined
|
|
48
39
|
};
|
|
49
40
|
export default ChartColumnSelectorOverlay;
|
|
50
41
|
//# sourceMappingURL=ChartColumnSelectorOverlay.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartColumnSelectorOverlay.js","names":["React","
|
|
1
|
+
{"version":3,"file":"ChartColumnSelectorOverlay.js","names":["React","classNames","SocketedButton","ChartColumnSelectorOverlay","columns","onColumnSelected","onMouseEnter","onMouseLeave","map","column","name","makeButtonClassName","isValid","isActive","columnName","defaultProps","undefined"],"sources":["../../src/panels/ChartColumnSelectorOverlay.tsx"],"sourcesContent":["import React, { MouseEventHandler, 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\nconst ChartColumnSelectorOverlay = ({\n columns,\n onColumnSelected,\n onMouseEnter,\n onMouseLeave,\n}: ChartColumnSelectorOverlayProps): ReactElement => (\n <div className=\"chart-panel-overlay chart-column-selector-overlay\">\n <div className={classNames('chart-panel-overlay-content')}>\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-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 </>\n </div>\n </div>\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,KAAP,MAAuD,OAAvD;AACA,OAAOC,UAAP,MAAuB,YAAvB;AACA,SAASC,cAAT,QAA+B,uBAA/B;;;AAiBA,IAAMC,0BAA0B,GAAG;EAAA,IAAC;IAClCC,OADkC;IAElCC,gBAFkC;IAGlCC,YAAY,EAAZA,aAHkC;IAIlCC;EAJkC,CAAD;EAAA,oBAMjC;IAAK,SAAS,EAAC;EAAf,gBACE;IAAK,SAAS,EAAEN,UAAU,CAAC,6BAAD;EAA1B,gBACE,uDACE;IAAK,SAAS,EAAC;EAAf,2HADF,eAKE;IAAK,SAAS,EAAC;EAAf,GACGG,OAAO,CAACI,GAAR,CAAYC,MAAM,iBACjB,oBAAC,cAAD;IACE,GAAG,EAAEA,MAAM,CAACC,IADd;IAEE,SAAS,EAAET,UAAU,CACnB,2BADmB,EAEnBE,0BAA0B,CAACQ,mBAA3B,CAA+CF,MAAM,CAACC,IAAtD,CAFmB,CAFvB;IAME,OAAO,EAAE,MAAML,gBAAgB,CAACI,MAAM,CAACC,IAAR,CANjC;IAOE,YAAY,EAAE,MAAM;MAClB,IAAIJ,aAAJ,EAAkBA,aAAY,CAACG,MAAD,CAAZ;IACnB,CATH;IAUE,YAAY,EAAEF,YAVhB;IAWE,QAAQ,EAAE,CAACE,MAAM,CAACG,OAXpB;IAYE,QAAQ,EAAEH,MAAM,CAACI;EAZnB,GAcGJ,MAAM,CAACC,IAdV,CADD,CADH,CALF,CADF,CADF,CANiC;AAAA,CAAnC;;AAsCAP,0BAA0B,CAACQ,mBAA3B,GAAkDG,UAAD,wCAClBA,UADkB,CAAjD;;AAGAX,0BAA0B,CAACY,YAA3B,GAA0C;EACxCT,YAAY,EAAE,MAAYU,SADc;EAExCT,YAAY,EAAE,MAAYS;AAFc,CAA1C;AAKA,eAAeb,0BAAf"}
|
|
@@ -1,23 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
const onOpenLinker: PropTypes.Validator<(...args: any[]) => any>;
|
|
18
|
-
const waitingFilterMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
19
|
-
const waitingInputMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
20
|
-
}
|
|
1
|
+
import { ReactElement } from 'react';
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import { ColumnName, InputFilter } from '@deephaven/iris-grid';
|
|
4
|
+
import './ChartFilterOverlay.scss';
|
|
5
|
+
export declare type ColumnMap = Map<ColumnName, {
|
|
6
|
+
name: string;
|
|
7
|
+
type: string;
|
|
8
|
+
}>;
|
|
9
|
+
interface ChartFilterOverlayProps {
|
|
10
|
+
columnMap: ColumnMap;
|
|
11
|
+
inputFilterMap: Map<ColumnName, InputFilter>;
|
|
12
|
+
linkedColumnMap: Map<string, unknown>;
|
|
13
|
+
onAdd: (columns: InputFilter[]) => void;
|
|
14
|
+
onOpenLinker: () => void;
|
|
15
|
+
waitingFilterMap: Map<string, InputFilter>;
|
|
16
|
+
waitingInputMap: Map<ColumnName, unknown>;
|
|
21
17
|
}
|
|
22
|
-
|
|
18
|
+
declare const ChartFilterOverlay: {
|
|
19
|
+
({ columnMap, inputFilterMap, linkedColumnMap, onAdd, onOpenLinker, waitingFilterMap, waitingInputMap, }: ChartFilterOverlayProps): ReactElement;
|
|
20
|
+
propTypes: {
|
|
21
|
+
columnMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
22
|
+
inputFilterMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
23
|
+
linkedColumnMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
24
|
+
onAdd: PropTypes.Validator<(...args: any[]) => any>;
|
|
25
|
+
onOpenLinker: PropTypes.Validator<(...args: any[]) => any>;
|
|
26
|
+
waitingFilterMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
27
|
+
waitingInputMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
export default ChartFilterOverlay;
|
|
23
31
|
//# sourceMappingURL=ChartFilterOverlay.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartFilterOverlay.d.ts","sourceRoot":"","sources":["../../src/panels/ChartFilterOverlay.
|
|
1
|
+
{"version":3,"file":"ChartFilterOverlay.d.ts","sourceRoot":"","sources":["../../src/panels/ChartFilterOverlay.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAc,YAAY,EAAwB,MAAM,OAAO,CAAC;AAC9E,OAAO,SAAS,MAAM,YAAY,CAAC;AAMnC,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,2BAA2B,CAAC;AAEnC,oBAAY,SAAS,GAAG,GAAG,CAAC,UAAU,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAExE,UAAU,uBAAuB;IAC/B,SAAS,EAAE,SAAS,CAAC;IACrB,cAAc,EAAE,GAAG,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;IAC7C,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,KAAK,EAAE,CAAC,OAAO,EAAE,WAAW,EAAE,KAAK,IAAI,CAAC;IACxC,YAAY,EAAE,MAAM,IAAI,CAAC;IACzB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC3C,eAAe,EAAE,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;CAC3C;AAED,QAAA,MAAM,kBAAkB;8GAQrB,uBAAuB,GAAG,YAAY;;;;;;;;;;CA+FxC,CAAC;AAYF,eAAe,kBAAkB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartFilterOverlay.js","names":["React","useCallback","useMemo","PropTypes","classNames","FontAwesomeIcon","ButtonOld","vsPass","vsWarning","TextUtils","ChartFilterOverlay","columnMap","inputFilterMap","linkedColumnMap","onAdd","onOpenLinker","waitingFilterMap","waitingInputMap","inputMessage","waitingColumns","Array","from","keys","needsInputFilterValue","find","columnName","get","needsLinkValue","columnsText","join","map","item","columns","values","handleAddClick","event","stopPropagation","preventDefault","handleOpenLinker","isWaitingFilters","size","isWaitingInput","column","isColumnWaiting","has","name","icon","propTypes","instanceOf","Map","isRequired","func"],"sources":["../../src/panels/ChartFilterOverlay.
|
|
1
|
+
{"version":3,"file":"ChartFilterOverlay.js","names":["React","useCallback","useMemo","PropTypes","classNames","FontAwesomeIcon","ButtonOld","vsPass","vsWarning","TextUtils","ChartFilterOverlay","columnMap","inputFilterMap","linkedColumnMap","onAdd","onOpenLinker","waitingFilterMap","waitingInputMap","inputMessage","waitingColumns","Array","from","keys","needsInputFilterValue","find","columnName","get","needsLinkValue","columnsText","join","map","item","columns","values","handleAddClick","event","stopPropagation","preventDefault","handleOpenLinker","isWaitingFilters","size","isWaitingInput","column","isColumnWaiting","has","name","icon","propTypes","instanceOf","Map","isRequired","func"],"sources":["../../src/panels/ChartFilterOverlay.tsx"],"sourcesContent":["import React, { MouseEvent, ReactElement, useCallback, useMemo } from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { ButtonOld } from '@deephaven/components';\nimport { vsPass, vsWarning } from '@deephaven/icons';\nimport { TextUtils } from '@deephaven/utils';\nimport { ColumnName, 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\nconst 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 (needsInputFilterValue && needsLinkValue) {\n return `Use a filter control or linked table to set a value for ${columnsText}`;\n }\n if (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 <ButtonOld onClick={handleAddClick} className=\"btn-primary\">\n Add Input Filters\n </ButtonOld>\n <ButtonOld onClick={handleOpenLinker} className=\"btn-primary\">\n Open Linker Tool\n </ButtonOld>\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,67 +1,194 @@
|
|
|
1
|
-
|
|
1
|
+
import { Component, ReactElement, RefObject } from 'react';
|
|
2
|
+
import { Chart, ChartModel, ChartModelSettings } from '@deephaven/chart';
|
|
3
|
+
import { PanelComponent } from '@deephaven/dashboard';
|
|
4
|
+
import { InputFilter, ColumnName } from '@deephaven/iris-grid';
|
|
5
|
+
import { SeriesPlotStyle, TableTemplate } from '@deephaven/jsapi-shim';
|
|
6
|
+
import { WorkspaceSettings } from '@deephaven/redux';
|
|
7
|
+
import { Pending } from '@deephaven/utils';
|
|
8
|
+
import GoldenLayout from '@deephaven/golden-layout';
|
|
9
|
+
import { ModelIndex } from '@deephaven/grid';
|
|
10
|
+
import { AdvancedFilterOptions, SortDirection } from '@deephaven/jsapi-utils';
|
|
11
|
+
import { ColumnMap } from './ChartFilterOverlay';
|
|
12
|
+
import { SelectorColumn } from './ChartColumnSelectorOverlay';
|
|
13
|
+
import './ChartPanel.scss';
|
|
14
|
+
import { Link } from '../linker/LinkerUtils';
|
|
15
|
+
import { ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
|
|
16
|
+
export declare type InputFilterMap = Map<string, InputFilter>;
|
|
17
|
+
export declare type FilterMap = Map<string, string>;
|
|
18
|
+
export declare type LinkedColumnMap = Map<string, {
|
|
19
|
+
name: string;
|
|
20
|
+
type: string;
|
|
21
|
+
}>;
|
|
22
|
+
export declare function isChartPanelTableMetadata(metadata: ChartPanelMetadata): metadata is ChartPanelTableMetadata;
|
|
23
|
+
export declare type ChartPanelFigureMetadata = {
|
|
24
|
+
figure: string;
|
|
25
|
+
};
|
|
26
|
+
export declare type ChartPanelTableMetadata = {
|
|
27
|
+
table: string;
|
|
28
|
+
sourcePanelId: string;
|
|
29
|
+
settings: {
|
|
30
|
+
isLinked: boolean;
|
|
31
|
+
title: string;
|
|
32
|
+
xAxis: string;
|
|
33
|
+
series: string[];
|
|
34
|
+
type: keyof SeriesPlotStyle;
|
|
35
|
+
};
|
|
36
|
+
tableSettings: ChartPanelTableSettings;
|
|
37
|
+
};
|
|
38
|
+
export declare type ChartPanelMetadata = ChartPanelFigureMetadata | ChartPanelTableMetadata;
|
|
39
|
+
declare type Settings = Record<string, unknown>;
|
|
40
|
+
export interface ChartPanelTableSettings {
|
|
41
|
+
quickFilters?: [
|
|
42
|
+
ModelIndex,
|
|
43
|
+
{
|
|
44
|
+
text: string;
|
|
45
|
+
}
|
|
46
|
+
][];
|
|
47
|
+
advancedFilters?: [
|
|
48
|
+
ModelIndex,
|
|
49
|
+
{
|
|
50
|
+
options: AdvancedFilterOptions;
|
|
51
|
+
}
|
|
52
|
+
][];
|
|
53
|
+
inputFilters?: InputFilter[];
|
|
54
|
+
sorts?: {
|
|
55
|
+
column: ModelIndex;
|
|
56
|
+
isAbs: boolean;
|
|
57
|
+
direction: SortDirection;
|
|
58
|
+
}[];
|
|
59
|
+
partition?: unknown;
|
|
60
|
+
partitionColumn?: string;
|
|
61
|
+
}
|
|
62
|
+
export interface GLChartPanelState {
|
|
63
|
+
filterValueMap: [string, string][];
|
|
64
|
+
settings: Partial<ChartModelSettings>;
|
|
65
|
+
tableSettings: ChartPanelTableSettings;
|
|
66
|
+
irisGridState?: {
|
|
67
|
+
advancedFilters: unknown;
|
|
68
|
+
quickFilters: unknown;
|
|
69
|
+
sorts: unknown;
|
|
70
|
+
};
|
|
71
|
+
irisGridPanelState?: {
|
|
72
|
+
partitionColumn: string;
|
|
73
|
+
partition: unknown;
|
|
74
|
+
};
|
|
75
|
+
table?: string;
|
|
76
|
+
figure?: string;
|
|
77
|
+
}
|
|
78
|
+
export interface ChartPanelProps {
|
|
79
|
+
glContainer: GoldenLayout.Container;
|
|
80
|
+
glEventHub: GoldenLayout.EventEmitter;
|
|
81
|
+
metadata: ChartPanelMetadata;
|
|
82
|
+
/** Function to build the ChartModel used by this ChartPanel. Can return a promise. */
|
|
83
|
+
makeModel: () => Promise<ChartModel>;
|
|
84
|
+
inputFilters: InputFilter[];
|
|
85
|
+
links: Link[];
|
|
86
|
+
localDashboardId: string;
|
|
87
|
+
isLinkerActive: boolean;
|
|
88
|
+
source?: TableTemplate;
|
|
89
|
+
sourcePanel?: PanelComponent;
|
|
90
|
+
columnSelectionValidator?: ColumnSelectionValidator;
|
|
91
|
+
setActiveTool: (tool: string) => void;
|
|
92
|
+
setDashboardIsolatedLinkerPanelId: (id: string, secondParam: undefined) => void;
|
|
93
|
+
panelState: GLChartPanelState;
|
|
94
|
+
settings: Partial<WorkspaceSettings>;
|
|
95
|
+
}
|
|
96
|
+
interface ChartPanelState {
|
|
97
|
+
settings: Partial<ChartModelSettings>;
|
|
98
|
+
error?: unknown;
|
|
99
|
+
isActive: boolean;
|
|
100
|
+
isDisconnected: boolean;
|
|
101
|
+
isLoading: boolean;
|
|
102
|
+
isLoaded: boolean;
|
|
103
|
+
isLinked: boolean;
|
|
104
|
+
filterMap: Map<string, string>;
|
|
105
|
+
filterValueMap: Map<string, string>;
|
|
106
|
+
model?: ChartModel;
|
|
107
|
+
columnMap: ColumnMap;
|
|
108
|
+
panelState: GLChartPanelState;
|
|
109
|
+
}
|
|
110
|
+
export declare class ChartPanel extends Component<ChartPanelProps, ChartPanelState> {
|
|
111
|
+
static defaultProps: {
|
|
112
|
+
columnSelectionValidator: null;
|
|
113
|
+
isLinkerActive: boolean;
|
|
114
|
+
source: null;
|
|
115
|
+
sourcePanel: null;
|
|
116
|
+
panelState: null;
|
|
117
|
+
settings: {};
|
|
118
|
+
};
|
|
119
|
+
static displayName: string;
|
|
2
120
|
static COMPONENT: string;
|
|
3
|
-
constructor(props:
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
121
|
+
constructor(props: ChartPanelProps);
|
|
122
|
+
componentDidMount(): void;
|
|
123
|
+
componentDidUpdate(prevProps: ChartPanelProps, prevState: ChartPanelState): void;
|
|
124
|
+
componentWillUnmount(): void;
|
|
125
|
+
panelContainer: RefObject<HTMLDivElement>;
|
|
126
|
+
chart: RefObject<Chart>;
|
|
127
|
+
pending: Pending;
|
|
128
|
+
initModel(): void;
|
|
129
|
+
getWaitingInputMap: (isFilterRequired: boolean, columnMap: ColumnMap, filterMap: FilterMap) => Map<string, {
|
|
130
|
+
name: string;
|
|
131
|
+
type: string;
|
|
132
|
+
}>;
|
|
133
|
+
getWaitingFilterMap: (isFilterRequired: boolean, columnMap: ColumnMap, filterMap: FilterMap, linkedColumnMap: LinkedColumnMap, inputFilterMap: InputFilterMap) => Map<any, any>;
|
|
134
|
+
getInputFilterColumnMap: (columnMap: ColumnMap, inputFilters: InputFilter[]) => Map<string, InputFilter>;
|
|
135
|
+
getLinkedColumnMap: (columnMap: ColumnMap, links: Link[]) => Map<string, {
|
|
136
|
+
name: string;
|
|
137
|
+
type: string;
|
|
138
|
+
}>;
|
|
139
|
+
getSelectorColumns: (columnMap: ColumnMap, linkedColumnMap: LinkedColumnMap, columnSelectionValidator?: ColumnSelectionValidator | undefined) => {
|
|
140
|
+
name: string;
|
|
141
|
+
type: string;
|
|
142
|
+
isValid: boolean;
|
|
143
|
+
isActive: boolean;
|
|
144
|
+
}[];
|
|
145
|
+
startListeningToSource(table: TableTemplate): void;
|
|
146
|
+
stopListeningToSource(table: TableTemplate): void;
|
|
147
|
+
loadModelIfNecessary(): void;
|
|
148
|
+
isHidden(): boolean;
|
|
149
|
+
handleColumnSelected(columnName: string): void;
|
|
150
|
+
handleColumnMouseEnter({ type, name }: SelectorColumn): void;
|
|
9
151
|
handleColumnMouseLeave(): void;
|
|
10
152
|
handleDisconnect(): void;
|
|
11
|
-
|
|
12
|
-
handleFilterAdd(columns: any): void;
|
|
13
|
-
handleHide(): void;
|
|
14
|
-
handleError(): void;
|
|
15
|
-
handleLoadError(error: any): void;
|
|
16
|
-
handleLoadSuccess(model: any): void;
|
|
17
|
-
handleResize(): void;
|
|
18
|
-
handleSettingsChanged(update: any): void;
|
|
153
|
+
handleFilterAdd(columns: InputFilter[]): void;
|
|
19
154
|
handleOpenLinker(): void;
|
|
20
|
-
|
|
155
|
+
handleReconnect(): void;
|
|
156
|
+
handleLoadSuccess(model: ChartModel): void;
|
|
157
|
+
handleLoadError(error: unknown): void;
|
|
21
158
|
handleSourceColumnChange(): void;
|
|
22
159
|
handleSourceFilterChange(): void;
|
|
23
160
|
handleSourceSortChange(): void;
|
|
161
|
+
updateModelFromSource(): void;
|
|
162
|
+
updatePanelState(): void;
|
|
163
|
+
handleError(): void;
|
|
164
|
+
handleResize(): void;
|
|
165
|
+
handleSettingsChanged(update: Partial<Settings>): void;
|
|
166
|
+
handleHide(): void;
|
|
167
|
+
handleShow(): void;
|
|
24
168
|
handleTabBlur(): void;
|
|
25
169
|
handleTabFocus(): void;
|
|
26
170
|
handleUpdate(): void;
|
|
27
|
-
updateModelFromSource(): void;
|
|
28
171
|
handleClearAllFilters(): void;
|
|
29
|
-
panelContainer: React.RefObject<any>;
|
|
30
|
-
chart: React.RefObject<any>;
|
|
31
|
-
pending: Pending;
|
|
32
|
-
initModel(): void;
|
|
33
|
-
getWaitingInputMap: (this: any, isFilterRequired: any, columnMap: any, filterMap: any) => Map<any, any>;
|
|
34
|
-
getWaitingFilterMap: (this: any, isFilterRequired: any, columnMap: any, filterMap: any, linkedColumnMap: any, inputFilterMap: any) => Map<any, any>;
|
|
35
|
-
getInputFilterColumnMap: (this: any, columnMap: any, inputFilters: any) => Map<any, any>;
|
|
36
|
-
getLinkedColumnMap: (this: any, columnMap: any, links: any) => Map<any, any>;
|
|
37
|
-
getSelectorColumns: (this: any, columnMap: any, linkedColumnMap: any, columnSelectionValidator: any) => {
|
|
38
|
-
name: any;
|
|
39
|
-
type: any;
|
|
40
|
-
isValid: any;
|
|
41
|
-
isActive: any;
|
|
42
|
-
}[];
|
|
43
|
-
startListeningToSource(table: any): void;
|
|
44
|
-
stopListeningToSource(table: any): void;
|
|
45
|
-
loadModelIfNecessary(): void;
|
|
46
|
-
isHidden(): any;
|
|
47
|
-
updatePanelState(): void;
|
|
48
172
|
/**
|
|
49
173
|
* Create an input filter panel for the provided column
|
|
50
|
-
* @param
|
|
174
|
+
* @param column The column to create the input filter for
|
|
51
175
|
*/
|
|
52
|
-
openInputFilter(column:
|
|
53
|
-
setActive(isActive:
|
|
176
|
+
openInputFilter(column: InputFilter): void;
|
|
177
|
+
setActive(isActive: boolean): void;
|
|
54
178
|
sendColumnChange(): void;
|
|
55
|
-
getCoordinateForColumn(columnName:
|
|
179
|
+
getCoordinateForColumn(columnName: ColumnName): [number, number] | null;
|
|
56
180
|
/**
|
|
57
181
|
* Set chart filters based on the filter map
|
|
58
|
-
* @param
|
|
182
|
+
* @param filterMapParam Filter map
|
|
59
183
|
*/
|
|
60
|
-
setFilterMap(filterMapParam: Map<string,
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
184
|
+
setFilterMap(filterMapParam: Map<string, {
|
|
185
|
+
columnType: string;
|
|
186
|
+
value: string;
|
|
187
|
+
}>): void;
|
|
188
|
+
unsetFilterValue(columnName: ColumnName): void;
|
|
189
|
+
updateChangedInputFilters(inputFilters: InputFilter[], prevInputFilters: InputFilter[]): void;
|
|
190
|
+
updateInputFilters(inputFilters: InputFilter[], forceUpdate?: boolean): void;
|
|
191
|
+
deleteInputFilters(inputFilters: InputFilter[], forceUpdate?: boolean): void;
|
|
65
192
|
updateColumnFilters(): void;
|
|
66
193
|
updateFilters(): void;
|
|
67
194
|
/**
|
|
@@ -69,112 +196,20 @@ export class ChartPanel extends React.Component<any, any, any> {
|
|
|
69
196
|
*/
|
|
70
197
|
pruneFilterMaps(): void;
|
|
71
198
|
updateChart(): void;
|
|
199
|
+
render(): ReactElement;
|
|
72
200
|
}
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
title: PropTypes.Requireable<string>;
|
|
87
|
-
setTitle: PropTypes.Requireable<(...args: any[]) => any>;
|
|
88
|
-
close: PropTypes.Requireable<(...args: any[]) => any>;
|
|
89
|
-
}>>;
|
|
90
|
-
const glEventHub: PropTypes.Validator<PropTypes.InferProps<{
|
|
91
|
-
on: PropTypes.Requireable<(...args: any[]) => any>;
|
|
92
|
-
off: PropTypes.Requireable<(...args: any[]) => any>;
|
|
93
|
-
emit: PropTypes.Requireable<(...args: any[]) => any>;
|
|
94
|
-
}>>;
|
|
95
|
-
const metadata: PropTypes.Validator<PropTypes.InferProps<{
|
|
96
|
-
figure: PropTypes.Requireable<string>;
|
|
97
|
-
table: PropTypes.Requireable<string>;
|
|
98
|
-
query: PropTypes.Requireable<string>;
|
|
99
|
-
querySerial: PropTypes.Requireable<string>;
|
|
100
|
-
sourcePanelId: PropTypes.Requireable<string>;
|
|
101
|
-
settings: PropTypes.Requireable<PropTypes.InferProps<{
|
|
102
|
-
isLinked: PropTypes.Requireable<boolean>;
|
|
103
|
-
}>>;
|
|
104
|
-
}>>;
|
|
105
|
-
const makeModel: PropTypes.Validator<(...args: any[]) => any>;
|
|
106
|
-
const inputFilters: PropTypes.Validator<(PropTypes.InferProps<{
|
|
107
|
-
name: PropTypes.Validator<string>;
|
|
108
|
-
type: PropTypes.Validator<string>;
|
|
109
|
-
value: any;
|
|
110
|
-
}> | null | undefined)[]>;
|
|
111
|
-
const links: PropTypes.Validator<(PropTypes.InferProps<{
|
|
112
|
-
start: PropTypes.Requireable<PropTypes.InferProps<{
|
|
113
|
-
panelId: PropTypes.Validator<string>;
|
|
114
|
-
columnName: PropTypes.Validator<string>;
|
|
115
|
-
}>>;
|
|
116
|
-
end: PropTypes.Requireable<PropTypes.InferProps<{
|
|
117
|
-
panelId: PropTypes.Validator<string>;
|
|
118
|
-
columnName: PropTypes.Validator<string>;
|
|
119
|
-
}>>;
|
|
120
|
-
id: PropTypes.Requireable<string>;
|
|
121
|
-
isReversed: PropTypes.Requireable<boolean>;
|
|
122
|
-
}> | null | undefined)[]>;
|
|
123
|
-
const localDashboardId: PropTypes.Validator<string>;
|
|
124
|
-
const isLinkerActive: PropTypes.Requireable<boolean>;
|
|
125
|
-
const source: PropTypes.Requireable<PropTypes.InferProps<{
|
|
126
|
-
columns: PropTypes.Validator<(PropTypes.InferProps<{
|
|
127
|
-
name: PropTypes.Validator<string>;
|
|
128
|
-
type: PropTypes.Validator<string>;
|
|
129
|
-
description: PropTypes.Requireable<string>;
|
|
130
|
-
constituentType: PropTypes.Requireable<string>;
|
|
131
|
-
}> | null | undefined)[]>;
|
|
132
|
-
customColumns: PropTypes.Validator<(string | null | undefined)[]>;
|
|
133
|
-
filter: PropTypes.Requireable<(PropTypes.InferProps<{
|
|
134
|
-
not: PropTypes.Validator<(...args: any[]) => any>;
|
|
135
|
-
and: PropTypes.Validator<(...args: any[]) => any>;
|
|
136
|
-
or: PropTypes.Validator<(...args: any[]) => any>;
|
|
137
|
-
}> | null | undefined)[]>;
|
|
138
|
-
addEventListener: PropTypes.Validator<(...args: any[]) => any>;
|
|
139
|
-
removeEventListener: PropTypes.Validator<(...args: any[]) => any>;
|
|
140
|
-
size: PropTypes.Validator<number>;
|
|
141
|
-
sort: PropTypes.Requireable<any[]>;
|
|
142
|
-
copy: PropTypes.Validator<(...args: any[]) => any>;
|
|
143
|
-
applyFilter: PropTypes.Validator<(...args: any[]) => any>;
|
|
144
|
-
applySort: PropTypes.Validator<(...args: any[]) => any>;
|
|
145
|
-
applyCustomColumns: PropTypes.Validator<(...args: any[]) => any>;
|
|
146
|
-
description: PropTypes.Requireable<string>;
|
|
147
|
-
}>>;
|
|
148
|
-
const sourcePanel: PropTypes.Requireable<PropTypes.InferProps<{
|
|
149
|
-
state: PropTypes.Requireable<PropTypes.InferProps<{
|
|
150
|
-
panelState: PropTypes.Requireable<PropTypes.InferProps<{}>>;
|
|
151
|
-
}>>;
|
|
152
|
-
}>>;
|
|
153
|
-
const columnSelectionValidator: PropTypes.Requireable<(...args: any[]) => any>;
|
|
154
|
-
const setActiveTool: PropTypes.Validator<(...args: any[]) => any>;
|
|
155
|
-
const setDashboardIsolatedLinkerPanelId: PropTypes.Validator<(...args: any[]) => any>;
|
|
156
|
-
const panelState: PropTypes.Requireable<PropTypes.InferProps<{}>>;
|
|
157
|
-
const settings: PropTypes.Requireable<PropTypes.InferProps<{}>>;
|
|
158
|
-
}
|
|
159
|
-
namespace defaultProps {
|
|
160
|
-
const columnSelectionValidator_1: null;
|
|
161
|
-
export { columnSelectionValidator_1 as columnSelectionValidator };
|
|
162
|
-
const isLinkerActive_1: boolean;
|
|
163
|
-
export { isLinkerActive_1 as isLinkerActive };
|
|
164
|
-
const source_1: null;
|
|
165
|
-
export { source_1 as source };
|
|
166
|
-
const sourcePanel_1: null;
|
|
167
|
-
export { sourcePanel_1 as sourcePanel };
|
|
168
|
-
const panelState_1: null;
|
|
169
|
-
export { panelState_1 as panelState };
|
|
170
|
-
const settings_1: {};
|
|
171
|
-
export { settings_1 as settings };
|
|
172
|
-
}
|
|
173
|
-
const displayName: string;
|
|
174
|
-
}
|
|
175
|
-
declare var _default: import("react-redux").ConnectedComponent<typeof ChartPanel, any>;
|
|
201
|
+
declare const _default: import("react-redux").ConnectedComponent<typeof ChartPanel, import("react-redux").Omit<Pick<ChartPanelProps, "glContainer" | "metadata" | "glEventHub" | "localDashboardId" | "inputFilters" | "links" | "makeModel" | "setActiveTool" | "setDashboardIsolatedLinkerPanelId"> & Partial<Pick<ChartPanelProps, "source" | "panelState" | "columnSelectionValidator" | "isLinkerActive" | "settings" | "sourcePanel">> & Partial<Pick<{
|
|
202
|
+
columnSelectionValidator: null;
|
|
203
|
+
isLinkerActive: boolean;
|
|
204
|
+
source: null;
|
|
205
|
+
sourcePanel: null;
|
|
206
|
+
panelState: null;
|
|
207
|
+
settings: {};
|
|
208
|
+
}, never>>, "source" | "columnSelectionValidator" | "isLinkerActive" | "settings" | "inputFilters" | "links" | "setActiveTool" | "setDashboardIsolatedLinkerPanelId" | "sourcePanel"> & {
|
|
209
|
+
localDashboardId: string;
|
|
210
|
+
metadata: {
|
|
211
|
+
sourcePanelId: string;
|
|
212
|
+
};
|
|
213
|
+
}>;
|
|
176
214
|
export default _default;
|
|
177
|
-
import React from "react";
|
|
178
|
-
import { Pending } from "@deephaven/utils";
|
|
179
|
-
import PropTypes from "prop-types";
|
|
180
215
|
//# sourceMappingURL=ChartPanel.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartPanel.d.ts","sourceRoot":"","sources":["../../src/panels/ChartPanel.
|
|
1
|
+
{"version":3,"file":"ChartPanel.d.ts","sourceRoot":"","sources":["../../src/panels/ChartPanel.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAMlE,OAAO,EACL,KAAK,EACL,UAAU,EACV,kBAAkB,EAGnB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAGL,cAAc,EAEf,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAiB,WAAW,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAW,EAET,eAAe,EACf,aAAa,EACd,MAAM,uBAAuB,CAAC;AAG/B,OAAO,EAKL,iBAAiB,EAClB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAEL,OAAO,EAGR,MAAM,kBAAkB,CAAC;AAC1B,OAAO,YAAY,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAY9E,OAA2B,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACrE,OAAmC,EACjC,cAAc,EACf,MAAM,8BAA8B,CAAC;AACtC,OAAO,mBAAmB,CAAC;AAC3B,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAE7C,OAAO,EAAE,wBAAwB,EAAE,MAAM,oCAAoC,CAAC;AAK9E,oBAAY,cAAc,GAAG,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;AAEtD,oBAAY,SAAS,GAAG,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAE5C,oBAAY,eAAe,GAAG,GAAG,CAAC,MAAM,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAE1E,wBAAgB,yBAAyB,CACvC,QAAQ,EAAE,kBAAkB,GAC3B,QAAQ,IAAI,uBAAuB,CAErC;AACD,oBAAY,wBAAwB,GAAG;IACrC,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,oBAAY,uBAAuB,GAAG;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE;QACR,QAAQ,EAAE,OAAO,CAAC;QAClB,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,EAAE,MAAM,EAAE,CAAC;QACjB,IAAI,EAAE,MAAM,eAAe,CAAC;KAC7B,CAAC;IACF,aAAa,EAAE,uBAAuB,CAAC;CACxC,CAAC;AAEF,oBAAY,kBAAkB,GAC1B,wBAAwB,GACxB,uBAAuB,CAAC;AAE5B,aAAK,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAExC,MAAM,WAAW,uBAAuB;IACtC,YAAY,CAAC,EAAE;QACb,UAAU;QACV;YACE,IAAI,EAAE,MAAM,CAAC;SACd;KACF,EAAE,CAAC;IACJ,eAAe,CAAC,EAAE;QAChB,UAAU;QACV;YACE,OAAO,EAAE,qBAAqB,CAAC;SAChC;KACF,EAAE,CAAC;IACJ,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC;IAC7B,KAAK,CAAC,EAAE;QACN,MAAM,EAAE,UAAU,CAAC;QACnB,KAAK,EAAE,OAAO,CAAC;QACf,SAAS,EAAE,aAAa,CAAC;KAC1B,EAAE,CAAC;IACJ,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AACD,MAAM,WAAW,iBAAiB;IAChC,cAAc,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;IACnC,QAAQ,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;IACtC,aAAa,EAAE,uBAAuB,CAAC;IACvC,aAAa,CAAC,EAAE;QACd,eAAe,EAAE,OAAO,CAAC;QACzB,YAAY,EAAE,OAAO,CAAC;QACtB,KAAK,EAAE,OAAO,CAAC;KAChB,CAAC;IACF,kBAAkB,CAAC,EAAE;QACnB,eAAe,EAAE,MAAM,CAAC;QACxB,SAAS,EAAE,OAAO,CAAC;KACpB,CAAC;IACF,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AACD,MAAM,WAAW,eAAe;IAC9B,WAAW,EAAE,YAAY,CAAC,SAAS,CAAC;IACpC,UAAU,EAAE,YAAY,CAAC,YAAY,CAAC;IAEtC,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,sFAAsF;IACtF,SAAS,EAAE,MAAM,OAAO,CAAC,UAAU,CAAC,CAAC;IACrC,YAAY,EAAE,WAAW,EAAE,CAAC;IAC5B,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,OAAO,CAAC;IACxB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,wBAAwB,CAAC,EAAE,wBAAwB,CAAC;IACpD,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,iCAAiC,EAAE,CACjC,EAAE,EAAE,MAAM,EACV,WAAW,EAAE,SAAS,KACnB,IAAI,CAAC;IAEV,UAAU,EAAE,iBAAiB,CAAC;IAC9B,QAAQ,EAAE,OAAO,CAAC,iBAAiB,CAAC,CAAC;CACtC;AAED,UAAU,eAAe;IACvB,QAAQ,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;IACtC,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;IAClB,cAAc,EAAE,OAAO,CAAC;IACxB,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,OAAO,CAAC;IAIlB,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAG/B,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,SAAS,EAAE,SAAS,CAAC;IAGrB,UAAU,EAAE,iBAAiB,CAAC;CAC/B;AAgBD,qBAAa,UAAW,SAAQ,SAAS,CAAC,eAAe,EAAE,eAAe,CAAC;IACzE,MAAM,CAAC,YAAY;;;;;;;MAOjB;IAEF,MAAM,CAAC,WAAW,SAAgB;IAElC,MAAM,CAAC,SAAS,SAAgB;gBAEpB,KAAK,EAAE,eAAe;IA+DlC,iBAAiB,IAAI,IAAI;IAOzB,kBAAkB,CAChB,SAAS,EAAE,eAAe,EAC1B,SAAS,EAAE,eAAe,GACzB,IAAI;IAsDP,oBAAoB,IAAI,IAAI;IAS5B,cAAc,EAAE,SAAS,CAAC,cAAc,CAAC,CAAC;IAE1C,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;IAExB,OAAO,EAAE,OAAO,CAAC;IAEjB,SAAS,IAAI,IAAI;IAWjB,kBAAkB,qBAEI,OAAO,iDAGxB,IAAI,MAAM,EAAE;QAAE,MAAM,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAU9C;IAEF,mBAAmB,qBAEG,OAAO,iIAsB3B;IAEF,uBAAuB,uCACgB,WAAW,EAAE,8BAYlD;IAEF,kBAAkB,gCAAyC,IAAI,EAAE;cACf,MAAM;cAAQ,MAAM;OA0BnE;IAEH,kBAAkB;;;;;QAchB;IAEF,sBAAsB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAiBlD,qBAAqB,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAiBjD,oBAAoB,IAAI,IAAI;IAO5B,QAAQ,IAAI,OAAO;IAMnB,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAU9C,sBAAsB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,cAAc,GAAG,IAAI;IAS5D,sBAAsB,IAAI,IAAI;IAS9B,gBAAgB,IAAI,IAAI;IAOxB,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,GAAG,IAAI;IAM7C,gBAAgB,IAAI,IAAI;IAUxB,eAAe,IAAI,IAAI;IAMvB,iBAAiB,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IA4B1C,eAAe,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IASrC,wBAAwB,IAAI,IAAI;IAIhC,wBAAwB,IAAI,IAAI;IAIhC,sBAAsB,IAAI,IAAI;IAI9B,qBAAqB,IAAI,IAAI;IAgC7B,gBAAgB,IAAI,IAAI;IAgCxB,WAAW,IAAI,IAAI;IAMnB,YAAY,IAAI,IAAI;IAIpB,qBAAqB,CAAC,MAAM,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,IAAI;IAWtD,UAAU,IAAI,IAAI;IAIlB,UAAU,IAAI,IAAI;IAIlB,aAAa,IAAI,IAAI;IAIrB,cAAc,IAAI,IAAI;IAKtB,YAAY,IAAI,IAAI;IAIpB,qBAAqB,IAAI,IAAI;IAU7B;;;OAGG;IACH,eAAe,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;IAe1C,SAAS,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IASlC,gBAAgB,IAAI,IAAI;IAaxB,sBAAsB,CAAC,UAAU,EAAE,UAAU,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI;IAmBvE;;;OAGG;IACH,YAAY,CACV,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,GACjE,IAAI;IA4BP,gBAAgB,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IAuC9C,yBAAyB,CACvB,YAAY,EAAE,WAAW,EAAE,EAC3B,gBAAgB,EAAE,WAAW,EAAE,GAC9B,IAAI;IAqBP,kBAAkB,CAAC,YAAY,EAAE,WAAW,EAAE,EAAE,WAAW,UAAQ,GAAG,IAAI;IAiC1E,kBAAkB,CAAC,YAAY,EAAE,WAAW,EAAE,EAAE,WAAW,UAAQ,GAAG,IAAI;IA+B1E,mBAAmB,IAAI,IAAI;IAU3B,aAAa,IAAI,IAAI;IAoCrB;;OAEG;IACH,eAAe,IAAI,IAAI;IA0BvB,WAAW,IAAI,IAAI;IAMnB,MAAM,IAAI,YAAY;CAoIvB;;;;;;;;;;;;;;AAqCD,wBAQc"}
|