@deephaven/dashboard-core-plugins 0.15.5-vite.12 → 0.15.5
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.js.map +1 -1
- package/dist/ConsolePlugin.js.map +1 -1
- package/dist/FilterPlugin.js +1 -1
- package/dist/FilterPlugin.js.map +1 -1
- package/dist/GridPlugin.js.map +1 -1
- package/dist/LinkerPlugin.js.map +1 -1
- package/dist/MarkdownPlugin.js.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/MarkdownEvent.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.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/LinkerLink.js.map +1 -1
- package/dist/linker/LinkerOverlayContent.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 +18 -14
- 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.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/index.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 +21 -17
|
@@ -1,6 +1,53 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import React, { Component, RefObject } from 'react';
|
|
2
|
+
import { Column, Row, TableTemplate } from '@deephaven/jsapi-shim';
|
|
3
|
+
import { DateTimeColumnFormatter, Formatter, FormattingRule } from '@deephaven/jsapi-utils';
|
|
4
|
+
import { Pending } from '@deephaven/utils';
|
|
5
|
+
import { Container, EventEmitter } from '@deephaven/golden-layout';
|
|
6
|
+
import DropdownFilter, { DropdownFilterColumn } from '../controls/dropdown-filter/DropdownFilter';
|
|
7
|
+
import './DropdownFilterPanel.scss';
|
|
8
|
+
import { Link } from '../linker/LinkerUtils';
|
|
9
|
+
import { ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
|
|
10
|
+
interface PanelState {
|
|
11
|
+
name?: string;
|
|
12
|
+
type?: string;
|
|
13
|
+
value?: string;
|
|
14
|
+
isValueShown?: boolean;
|
|
15
|
+
timestamp?: number;
|
|
16
|
+
}
|
|
17
|
+
interface DropdownFilterPanelProps {
|
|
18
|
+
glContainer: Container;
|
|
19
|
+
glEventHub: EventEmitter;
|
|
20
|
+
panelState?: PanelState;
|
|
21
|
+
isLinkerActive: boolean;
|
|
22
|
+
columns: Column[];
|
|
23
|
+
columnSelectionValidator?: ColumnSelectionValidator;
|
|
24
|
+
disableLinking: boolean;
|
|
25
|
+
settings: {
|
|
26
|
+
formatter: FormattingRule[];
|
|
27
|
+
};
|
|
28
|
+
panelTableMap: Map<string | string[], TableTemplate>;
|
|
29
|
+
dashboardLinks: Link[];
|
|
30
|
+
}
|
|
31
|
+
interface DropdownFilterPanelState {
|
|
32
|
+
column?: DropdownFilterColumn;
|
|
33
|
+
formatter: Formatter;
|
|
34
|
+
valuesTable?: TableTemplate;
|
|
35
|
+
valuesColumn?: Column;
|
|
36
|
+
sourceSize: number;
|
|
37
|
+
value: string;
|
|
38
|
+
timestamp?: number;
|
|
39
|
+
values: unknown[];
|
|
40
|
+
isValueShown: boolean;
|
|
41
|
+
wasFlipped: boolean;
|
|
42
|
+
skipUpdate: boolean;
|
|
43
|
+
panelState?: PanelState;
|
|
44
|
+
isDisconnected: boolean;
|
|
45
|
+
isLoading: boolean;
|
|
46
|
+
isLoaded: boolean;
|
|
47
|
+
error: unknown | null;
|
|
48
|
+
}
|
|
49
|
+
declare class DropdownFilterPanel extends Component<DropdownFilterPanelProps, DropdownFilterPanelState> {
|
|
50
|
+
static displayName: string;
|
|
4
51
|
static COMPONENT: string;
|
|
5
52
|
static MAX_TABLE_SIZE: number;
|
|
6
53
|
static DATETIME_FORMATTER: DateTimeColumnFormatter;
|
|
@@ -8,121 +55,78 @@ declare class DropdownFilterPanel extends React.Component<any, any, any> {
|
|
|
8
55
|
name: string;
|
|
9
56
|
type: null;
|
|
10
57
|
}>;
|
|
11
|
-
constructor(props:
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
handleClearAllFilters(): void;
|
|
18
|
-
handleDisconnect(): void;
|
|
19
|
-
handleReconnect(): void;
|
|
20
|
-
handleColumnSelected(): void;
|
|
21
|
-
handleSourceFilterChange(): void;
|
|
22
|
-
handleSourceSortChange(): void;
|
|
23
|
-
handleSourceSizeChange({ detail }: {
|
|
24
|
-
detail: any;
|
|
25
|
-
}): void;
|
|
26
|
-
handleSourceMouseEnter(): void;
|
|
27
|
-
handleSourceMouseLeave(): void;
|
|
28
|
-
handleValuesTableUpdate({ detail }: {
|
|
29
|
-
detail: any;
|
|
30
|
-
}): void;
|
|
31
|
-
dropdownFilterRef: React.RefObject<any>;
|
|
32
|
-
panelContainer: React.RefObject<any>;
|
|
58
|
+
constructor(props: DropdownFilterPanelProps);
|
|
59
|
+
componentDidMount(): void;
|
|
60
|
+
componentDidUpdate(prevProps: DropdownFilterPanelProps, prevState: DropdownFilterPanelState): void;
|
|
61
|
+
componentWillUnmount(): void;
|
|
62
|
+
dropdownFilterRef: RefObject<DropdownFilter>;
|
|
63
|
+
panelContainer: RefObject<HTMLDivElement>;
|
|
33
64
|
pending: Pending;
|
|
34
|
-
cleanup
|
|
35
|
-
columnFormats
|
|
36
|
-
getCachedValues: (
|
|
37
|
-
getCoordinateForColumn():
|
|
38
|
-
getSettingsErrorMessage(): string |
|
|
39
|
-
getPanelErrorMessage(): string |
|
|
40
|
-
getCachedPanelLinks: (this: any, dashboardLinks:
|
|
65
|
+
cleanup?: () => void;
|
|
66
|
+
columnFormats?: FormattingRule[];
|
|
67
|
+
getCachedValues: (rawValues: unknown[], { type, name }: DropdownFilterColumn, formatter: Formatter) => (string | null)[];
|
|
68
|
+
getCoordinateForColumn(): [number, number] | null;
|
|
69
|
+
getSettingsErrorMessage(): string | undefined;
|
|
70
|
+
getPanelErrorMessage(): string | undefined;
|
|
71
|
+
getCachedPanelLinks: (this: any, dashboardLinks: Link[], panel: any) => Link[];
|
|
41
72
|
getCachedSource: (this: any, links: any) => any;
|
|
42
73
|
getCachedSourceTable: (this: any, panelTableMap: any, source: any) => any;
|
|
43
|
-
getCachedSourceColumn: (this: any, table:
|
|
44
|
-
getSource(props?: Readonly<
|
|
74
|
+
getCachedSourceColumn: (this: any, table: TableTemplate, source: any) => Column | null;
|
|
75
|
+
getSource(props?: Readonly<DropdownFilterPanelProps> & Readonly<{
|
|
45
76
|
children?: React.ReactNode;
|
|
46
77
|
}>): any;
|
|
47
|
-
getSourceTable(props?: Readonly<
|
|
78
|
+
getSourceTable(props?: Readonly<DropdownFilterPanelProps> & Readonly<{
|
|
48
79
|
children?: React.ReactNode;
|
|
49
80
|
}>): any;
|
|
50
|
-
getValuesColumn(valuesTable:
|
|
51
|
-
startListeningToSource(sourceTable:
|
|
52
|
-
stopListeningToSource(sourceTable:
|
|
81
|
+
getValuesColumn(valuesTable: TableTemplate): Column | null;
|
|
82
|
+
startListeningToSource(sourceTable: TableTemplate): void;
|
|
83
|
+
stopListeningToSource(sourceTable: TableTemplate): void;
|
|
84
|
+
handleChange({ column, isValueShown, value, }: {
|
|
85
|
+
column: Partial<Column> | null;
|
|
86
|
+
isValueShown?: boolean | undefined;
|
|
87
|
+
value?: string | undefined;
|
|
88
|
+
}): void;
|
|
89
|
+
handleDisconnect(): void;
|
|
90
|
+
handleReconnect(): void;
|
|
91
|
+
handleSourceFilterChange(): void;
|
|
92
|
+
handleSourceSortChange(): void;
|
|
93
|
+
handleSourceSizeChange({ detail }: {
|
|
94
|
+
detail: number;
|
|
95
|
+
}): void;
|
|
96
|
+
handleColumnSelected(): void;
|
|
97
|
+
handleClearAllFilters(): void;
|
|
53
98
|
/**
|
|
54
99
|
* Set the filter value, card side, selected column
|
|
55
|
-
* @param
|
|
56
|
-
* @param
|
|
100
|
+
* @param state Filter state to set
|
|
101
|
+
* @param sendUpdate Emit filters changed event if true
|
|
57
102
|
*/
|
|
58
|
-
setPanelState(state:
|
|
59
|
-
|
|
103
|
+
setPanelState(state: {
|
|
104
|
+
name: string;
|
|
105
|
+
type: string;
|
|
106
|
+
value: string;
|
|
107
|
+
isValueShown: boolean;
|
|
108
|
+
}, sendUpdate?: boolean): void;
|
|
109
|
+
sendUpdate(name: string | null, type: string | undefined, value: string | undefined, timestamp?: number): void;
|
|
60
110
|
updateValuesTable(): void;
|
|
61
111
|
applySourceSorts(): void;
|
|
62
112
|
applySourceFilters(): void;
|
|
63
|
-
updateViewportListener(valuesTable:
|
|
64
|
-
setViewport(valuesTable:
|
|
65
|
-
updateFormatterSettings(settings:
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
contentItem: PropTypes.Requireable<PropTypes.InferProps<{}>>;
|
|
77
|
-
}> | null | undefined)[]>;
|
|
78
|
-
}>>;
|
|
79
|
-
}>>;
|
|
80
|
-
title: PropTypes.Requireable<string>;
|
|
81
|
-
setTitle: PropTypes.Requireable<(...args: any[]) => any>;
|
|
82
|
-
close: PropTypes.Requireable<(...args: any[]) => any>;
|
|
83
|
-
}>>;
|
|
84
|
-
const glEventHub: PropTypes.Validator<PropTypes.InferProps<{
|
|
85
|
-
on: PropTypes.Requireable<(...args: any[]) => any>;
|
|
86
|
-
off: PropTypes.Requireable<(...args: any[]) => any>;
|
|
87
|
-
emit: PropTypes.Requireable<(...args: any[]) => any>;
|
|
88
|
-
}>>;
|
|
89
|
-
const panelState: PropTypes.Requireable<PropTypes.InferProps<{
|
|
90
|
-
name: PropTypes.Requireable<string>;
|
|
91
|
-
type: PropTypes.Requireable<string>;
|
|
92
|
-
value: PropTypes.Requireable<string>;
|
|
93
|
-
isValueShown: PropTypes.Requireable<boolean>;
|
|
94
|
-
}>>;
|
|
95
|
-
const isLinkerActive: PropTypes.Validator<boolean>;
|
|
96
|
-
const columns: PropTypes.Validator<(PropTypes.InferProps<{}> | null | undefined)[]>;
|
|
97
|
-
const columnSelectionValidator: PropTypes.Requireable<(...args: any[]) => any>;
|
|
98
|
-
const disableLinking: PropTypes.Validator<boolean>;
|
|
99
|
-
const settings: PropTypes.Validator<PropTypes.InferProps<{
|
|
100
|
-
columnFormats: PropTypes.Requireable<(PropTypes.InferProps<{}> | null | undefined)[]>;
|
|
101
|
-
}>>;
|
|
102
|
-
const panelTableMap: PropTypes.Validator<Map<unknown, unknown>>;
|
|
103
|
-
const dashboardLinks: PropTypes.Validator<(PropTypes.InferProps<{
|
|
104
|
-
start: PropTypes.Requireable<PropTypes.InferProps<{
|
|
105
|
-
panelId: PropTypes.Validator<string>;
|
|
106
|
-
columnName: PropTypes.Validator<string>;
|
|
107
|
-
}>>;
|
|
108
|
-
end: PropTypes.Requireable<PropTypes.InferProps<{
|
|
109
|
-
panelId: PropTypes.Validator<string>;
|
|
110
|
-
columnName: PropTypes.Validator<string>;
|
|
111
|
-
}>>;
|
|
112
|
-
id: PropTypes.Requireable<string>;
|
|
113
|
-
isReversed: PropTypes.Requireable<boolean>;
|
|
114
|
-
}> | null | undefined)[]>;
|
|
115
|
-
}
|
|
116
|
-
namespace defaultProps {
|
|
117
|
-
const columnSelectionValidator_1: null;
|
|
118
|
-
export { columnSelectionValidator_1 as columnSelectionValidator };
|
|
119
|
-
const panelState_1: null;
|
|
120
|
-
export { panelState_1 as panelState };
|
|
121
|
-
}
|
|
122
|
-
const displayName: string;
|
|
113
|
+
updateViewportListener(valuesTable: TableTemplate): void;
|
|
114
|
+
setViewport(valuesTable: TableTemplate): void;
|
|
115
|
+
updateFormatterSettings(settings: {
|
|
116
|
+
formatter?: FormattingRule[] | undefined;
|
|
117
|
+
}): void;
|
|
118
|
+
handleValuesTableUpdate({ detail }: {
|
|
119
|
+
detail: {
|
|
120
|
+
rows: Row[];
|
|
121
|
+
};
|
|
122
|
+
}): void;
|
|
123
|
+
handleSourceMouseEnter(): void;
|
|
124
|
+
handleSourceMouseLeave(): void;
|
|
125
|
+
render(): JSX.Element;
|
|
123
126
|
}
|
|
124
|
-
import React
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
127
|
+
declare const _default: import("react-redux").ConnectedComponent<typeof DropdownFilterPanel, import("react-redux").Omit<React.ClassAttributes<DropdownFilterPanel> & DropdownFilterPanelProps, "columns" | "columnSelectionValidator" | "isLinkerActive" | "disableLinking" | "settings" | "panelTableMap" | "dashboardLinks"> & {
|
|
128
|
+
localDashboardId: string;
|
|
129
|
+
glContainer: Container;
|
|
130
|
+
}>;
|
|
131
|
+
export default _default;
|
|
128
132
|
//# sourceMappingURL=DropdownFilterPanel.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DropdownFilterPanel.d.ts","sourceRoot":"","sources":["../../src/panels/DropdownFilterPanel.
|
|
1
|
+
{"version":3,"file":"DropdownFilterPanel.d.ts","sourceRoot":"","sources":["../../src/panels/DropdownFilterPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
2
2
|
|
|
3
3
|
import React, { Component } from 'react';
|
|
4
|
-
import PropTypes from 'prop-types';
|
|
5
4
|
import { connect } from 'react-redux';
|
|
6
5
|
import debounce from 'lodash.debounce';
|
|
7
6
|
import deepEqual from 'deep-equal';
|
|
8
7
|
import memoize from 'memoize-one';
|
|
9
|
-
import {
|
|
8
|
+
import { LayoutUtils } from '@deephaven/dashboard';
|
|
10
9
|
import dh from '@deephaven/jsapi-shim';
|
|
11
10
|
import { DateTimeColumnFormatter, Formatter, FormatterUtils, TableUtils } from '@deephaven/jsapi-utils';
|
|
12
11
|
import Log from '@deephaven/log';
|
|
@@ -16,7 +15,6 @@ import DropdownFilter from "../controls/dropdown-filter/DropdownFilter.js";
|
|
|
16
15
|
import { InputFilterEvent } from "../events/index.js";
|
|
17
16
|
import { getColumnsForDashboard, getColumnSelectionValidatorForDashboard, getIsolatedLinkerPanelIdForDashboard, getLinksForDashboard, getTableMapForDashboard } from "../redux/index.js";
|
|
18
17
|
import "./DropdownFilterPanel.css";
|
|
19
|
-
import { UIPropTypes } from "../prop-types/index.js";
|
|
20
18
|
import ToolType from "../linker/ToolType.js";
|
|
21
19
|
import WidgetPanel from "./WidgetPanel.js";
|
|
22
20
|
var log = Log.module('DropdownFilterPanel');
|
|
@@ -27,18 +25,28 @@ class DropdownFilterPanel extends Component {
|
|
|
27
25
|
constructor(props) {
|
|
28
26
|
super(props);
|
|
29
27
|
|
|
28
|
+
_defineProperty(this, "dropdownFilterRef", void 0);
|
|
29
|
+
|
|
30
|
+
_defineProperty(this, "panelContainer", void 0);
|
|
31
|
+
|
|
32
|
+
_defineProperty(this, "pending", void 0);
|
|
33
|
+
|
|
34
|
+
_defineProperty(this, "cleanup", void 0);
|
|
35
|
+
|
|
36
|
+
_defineProperty(this, "columnFormats", void 0);
|
|
37
|
+
|
|
30
38
|
_defineProperty(this, "getCachedValues", memoize((rawValues, _ref, formatter) => {
|
|
31
39
|
var {
|
|
32
40
|
type,
|
|
33
41
|
name
|
|
34
42
|
} = _ref;
|
|
35
43
|
|
|
36
|
-
if (TableUtils.isDateType(type)) {
|
|
44
|
+
if (type && TableUtils.isDateType(type)) {
|
|
37
45
|
return rawValues.map(value => DropdownFilterPanel.DATETIME_FORMATTER.format(value));
|
|
38
46
|
}
|
|
39
47
|
|
|
40
48
|
return rawValues.map(value => // Skip formatting for nulls so they don't get converted to ''
|
|
41
|
-
value != null ? formatter.getFormattedString(value, type, name) : null);
|
|
49
|
+
value != null && type != null ? formatter.getFormattedString(value, type, name) : null);
|
|
42
50
|
}));
|
|
43
51
|
|
|
44
52
|
_defineProperty(this, "getCachedPanelLinks", memoize((dashboardLinks, panel) => {
|
|
@@ -114,28 +122,27 @@ class DropdownFilterPanel extends Component {
|
|
|
114
122
|
this.dropdownFilterRef = /*#__PURE__*/React.createRef();
|
|
115
123
|
this.panelContainer = /*#__PURE__*/React.createRef();
|
|
116
124
|
this.pending = new Pending();
|
|
117
|
-
this.cleanup = null;
|
|
118
125
|
var {
|
|
119
126
|
panelState,
|
|
120
127
|
settings
|
|
121
128
|
} = props;
|
|
122
|
-
this.columnFormats = settings
|
|
129
|
+
this.columnFormats = FormatterUtils.getColumnFormats(settings);
|
|
123
130
|
var {
|
|
124
131
|
value: _value = '',
|
|
125
132
|
isValueShown = false,
|
|
126
133
|
name: _name,
|
|
127
134
|
type: _type,
|
|
128
|
-
timestamp
|
|
135
|
+
timestamp
|
|
129
136
|
} = panelState !== null && panelState !== void 0 ? panelState : {};
|
|
130
137
|
var column = _name != null && _type != null ? {
|
|
131
138
|
name: _name,
|
|
132
139
|
type: _type
|
|
133
|
-
} :
|
|
140
|
+
} : undefined;
|
|
134
141
|
this.state = {
|
|
135
142
|
column,
|
|
136
143
|
formatter: new Formatter(this.columnFormats),
|
|
137
|
-
valuesTable:
|
|
138
|
-
valuesColumn:
|
|
144
|
+
valuesTable: undefined,
|
|
145
|
+
valuesColumn: undefined,
|
|
139
146
|
sourceSize: 0,
|
|
140
147
|
value: _value,
|
|
141
148
|
timestamp,
|
|
@@ -187,11 +194,11 @@ class DropdownFilterPanel extends Component {
|
|
|
187
194
|
var prevSource = this.getSource(prevProps);
|
|
188
195
|
var prevSourceTable = this.getSourceTable(prevProps);
|
|
189
196
|
|
|
190
|
-
if (settings !== prevProps.settings) {
|
|
197
|
+
if (settings !== prevProps.settings && settings !== undefined) {
|
|
191
198
|
this.updateFormatterSettings(settings);
|
|
192
199
|
}
|
|
193
200
|
|
|
194
|
-
if (valuesTable !== prevState.valuesTable && prevState.valuesTable
|
|
201
|
+
if (valuesTable !== prevState.valuesTable && prevState.valuesTable != null) {
|
|
195
202
|
log.debug('Table in state modified, closing the old table.');
|
|
196
203
|
prevState.valuesTable.close();
|
|
197
204
|
} // Checking source change in addition to table change
|
|
@@ -228,7 +235,7 @@ class DropdownFilterPanel extends Component {
|
|
|
228
235
|
this.cleanup();
|
|
229
236
|
}
|
|
230
237
|
|
|
231
|
-
if (valuesTable
|
|
238
|
+
if (valuesTable != null) {
|
|
232
239
|
valuesTable.close();
|
|
233
240
|
}
|
|
234
241
|
}
|
|
@@ -236,7 +243,7 @@ class DropdownFilterPanel extends Component {
|
|
|
236
243
|
getCoordinateForColumn() {
|
|
237
244
|
var _element$getBoundingC;
|
|
238
245
|
|
|
239
|
-
if (
|
|
246
|
+
if (this.panelContainer.current == null) {
|
|
240
247
|
return null;
|
|
241
248
|
}
|
|
242
249
|
|
|
@@ -261,14 +268,14 @@ class DropdownFilterPanel extends Component {
|
|
|
261
268
|
return "Table too large, must have fewer than ".concat(DropdownFilterPanel.MAX_TABLE_SIZE, " options.");
|
|
262
269
|
}
|
|
263
270
|
|
|
264
|
-
return
|
|
271
|
+
return undefined;
|
|
265
272
|
}
|
|
266
273
|
|
|
267
274
|
getPanelErrorMessage() {
|
|
268
275
|
var {
|
|
269
276
|
error
|
|
270
277
|
} = this.state;
|
|
271
|
-
return error ? "".concat(error) :
|
|
278
|
+
return error ? "".concat(error) : undefined;
|
|
272
279
|
}
|
|
273
280
|
|
|
274
281
|
getSource() {
|
|
@@ -319,12 +326,14 @@ class DropdownFilterPanel extends Component {
|
|
|
319
326
|
value
|
|
320
327
|
} = _ref3;
|
|
321
328
|
var {
|
|
322
|
-
name =
|
|
323
|
-
type =
|
|
329
|
+
name = undefined,
|
|
330
|
+
type = undefined
|
|
324
331
|
} = column !== null && column !== void 0 ? column : {};
|
|
325
332
|
var sendUpdate = true;
|
|
326
333
|
var timestamp = Date.now();
|
|
327
334
|
this.setState(_ref4 => {
|
|
335
|
+
var _ref5, _timestamp;
|
|
336
|
+
|
|
328
337
|
var {
|
|
329
338
|
panelState,
|
|
330
339
|
timestamp: prevTimestamp,
|
|
@@ -333,7 +342,7 @@ class DropdownFilterPanel extends Component {
|
|
|
333
342
|
} = _ref4;
|
|
334
343
|
// If the user had a value set, and they flip the card over and flip it back without changing any settings, ignore it
|
|
335
344
|
var isFlip = panelState != null && isValueShown !== panelState.isValueShown && name === panelState.name && type === panelState.type && value === panelState.value;
|
|
336
|
-
sendUpdate = !skipUpdate && isValueShown && (!isFlip || !wasFlipped);
|
|
345
|
+
sendUpdate = (_ref5 = !skipUpdate && isValueShown && (!isFlip || !wasFlipped)) !== null && _ref5 !== void 0 ? _ref5 : false;
|
|
337
346
|
|
|
338
347
|
if (!sendUpdate) {
|
|
339
348
|
timestamp = prevTimestamp;
|
|
@@ -345,7 +354,7 @@ class DropdownFilterPanel extends Component {
|
|
|
345
354
|
name,
|
|
346
355
|
type,
|
|
347
356
|
value,
|
|
348
|
-
timestamp
|
|
357
|
+
timestamp: (_timestamp = timestamp) !== null && _timestamp !== void 0 ? _timestamp : undefined
|
|
349
358
|
},
|
|
350
359
|
timestamp,
|
|
351
360
|
wasFlipped: isFlip,
|
|
@@ -353,7 +362,7 @@ class DropdownFilterPanel extends Component {
|
|
|
353
362
|
};
|
|
354
363
|
}, () => {
|
|
355
364
|
if (sendUpdate) {
|
|
356
|
-
this.sendUpdate(name, type, value, timestamp);
|
|
365
|
+
this.sendUpdate(name !== null && name !== void 0 ? name : null, type, value, timestamp);
|
|
357
366
|
}
|
|
358
367
|
});
|
|
359
368
|
}
|
|
@@ -381,10 +390,10 @@ class DropdownFilterPanel extends Component {
|
|
|
381
390
|
this.applySourceSorts();
|
|
382
391
|
}
|
|
383
392
|
|
|
384
|
-
handleSourceSizeChange(
|
|
393
|
+
handleSourceSizeChange(_ref6) {
|
|
385
394
|
var {
|
|
386
395
|
detail
|
|
387
|
-
} =
|
|
396
|
+
} = _ref6;
|
|
388
397
|
this.setState({
|
|
389
398
|
sourceSize: detail
|
|
390
399
|
});
|
|
@@ -399,17 +408,19 @@ class DropdownFilterPanel extends Component {
|
|
|
399
408
|
}
|
|
400
409
|
|
|
401
410
|
handleClearAllFilters() {
|
|
402
|
-
|
|
411
|
+
var _this$dropdownFilterR, _this$dropdownFilterR2;
|
|
412
|
+
|
|
413
|
+
(_this$dropdownFilterR = this.dropdownFilterRef) === null || _this$dropdownFilterR === void 0 ? void 0 : (_this$dropdownFilterR2 = _this$dropdownFilterR.current) === null || _this$dropdownFilterR2 === void 0 ? void 0 : _this$dropdownFilterR2.clearFilter();
|
|
403
414
|
}
|
|
404
415
|
/**
|
|
405
416
|
* Set the filter value, card side, selected column
|
|
406
|
-
* @param
|
|
407
|
-
* @param
|
|
417
|
+
* @param state Filter state to set
|
|
418
|
+
* @param sendUpdate Emit filters changed event if true
|
|
408
419
|
*/
|
|
409
420
|
|
|
410
421
|
|
|
411
422
|
setPanelState(state) {
|
|
412
|
-
var _this$
|
|
423
|
+
var _this$dropdownFilterR3, _this$dropdownFilterR4;
|
|
413
424
|
|
|
414
425
|
var sendUpdate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
415
426
|
|
|
@@ -424,7 +435,7 @@ class DropdownFilterPanel extends Component {
|
|
|
424
435
|
}); // Changing the inputFilter state via props doesn't quite work because of the delays on manual input changes
|
|
425
436
|
// Setting the ref state directly triggers the onChange handler and updates the panelState
|
|
426
437
|
|
|
427
|
-
(_this$
|
|
438
|
+
(_this$dropdownFilterR3 = this.dropdownFilterRef) === null || _this$dropdownFilterR3 === void 0 ? void 0 : (_this$dropdownFilterR4 = _this$dropdownFilterR3.current) === null || _this$dropdownFilterR4 === void 0 ? void 0 : _this$dropdownFilterR4.setFilterState(state);
|
|
428
439
|
}
|
|
429
440
|
|
|
430
441
|
sendUpdate(name, type, value, timestamp) {
|
|
@@ -457,7 +468,7 @@ class DropdownFilterPanel extends Component {
|
|
|
457
468
|
log.debug('updateValuesTable', source, sourceTable);
|
|
458
469
|
this.setState({
|
|
459
470
|
values: [],
|
|
460
|
-
valuesTable:
|
|
471
|
+
valuesTable: undefined,
|
|
461
472
|
error: null
|
|
462
473
|
});
|
|
463
474
|
|
|
@@ -491,7 +502,7 @@ class DropdownFilterPanel extends Component {
|
|
|
491
502
|
valuesTable
|
|
492
503
|
});
|
|
493
504
|
}).catch(error => {
|
|
494
|
-
if (PromiseUtils.
|
|
505
|
+
if (PromiseUtils.isCanceled(error)) {
|
|
495
506
|
return;
|
|
496
507
|
}
|
|
497
508
|
|
|
@@ -545,7 +556,7 @@ class DropdownFilterPanel extends Component {
|
|
|
545
556
|
}
|
|
546
557
|
|
|
547
558
|
if (valuesTable == null) {
|
|
548
|
-
this.cleanup =
|
|
559
|
+
this.cleanup = undefined;
|
|
549
560
|
return;
|
|
550
561
|
}
|
|
551
562
|
|
|
@@ -555,6 +566,12 @@ class DropdownFilterPanel extends Component {
|
|
|
555
566
|
|
|
556
567
|
setViewport(valuesTable) {
|
|
557
568
|
var valuesColumn = this.getValuesColumn(valuesTable);
|
|
569
|
+
|
|
570
|
+
if (!valuesColumn) {
|
|
571
|
+
log.error('values column is null');
|
|
572
|
+
return;
|
|
573
|
+
}
|
|
574
|
+
|
|
558
575
|
valuesTable.setViewport(0, DropdownFilterPanel.MAX_TABLE_SIZE - 1, [valuesColumn]);
|
|
559
576
|
}
|
|
560
577
|
|
|
@@ -569,16 +586,22 @@ class DropdownFilterPanel extends Component {
|
|
|
569
586
|
}
|
|
570
587
|
}
|
|
571
588
|
|
|
572
|
-
handleValuesTableUpdate(
|
|
589
|
+
handleValuesTableUpdate(_ref7) {
|
|
573
590
|
var {
|
|
574
591
|
detail
|
|
575
|
-
} =
|
|
592
|
+
} = _ref7;
|
|
576
593
|
var {
|
|
577
594
|
rows
|
|
578
595
|
} = detail;
|
|
579
596
|
var {
|
|
580
597
|
valuesTable
|
|
581
598
|
} = this.state;
|
|
599
|
+
|
|
600
|
+
if (!valuesTable) {
|
|
601
|
+
log.error('valuesTable is null');
|
|
602
|
+
return;
|
|
603
|
+
}
|
|
604
|
+
|
|
582
605
|
var valuesColumn = this.getValuesColumn(valuesTable);
|
|
583
606
|
|
|
584
607
|
if (!valuesColumn) {
|
|
@@ -616,7 +639,7 @@ class DropdownFilterPanel extends Component {
|
|
|
616
639
|
return;
|
|
617
640
|
}
|
|
618
641
|
|
|
619
|
-
columnSelectionValidator(this,
|
|
642
|
+
columnSelectionValidator(this, undefined);
|
|
620
643
|
}
|
|
621
644
|
|
|
622
645
|
render() {
|
|
@@ -678,6 +701,8 @@ class DropdownFilterPanel extends Component {
|
|
|
678
701
|
|
|
679
702
|
}
|
|
680
703
|
|
|
704
|
+
_defineProperty(DropdownFilterPanel, "displayName", 'DropdownFilterPanel');
|
|
705
|
+
|
|
681
706
|
_defineProperty(DropdownFilterPanel, "COMPONENT", 'DropdownFilterPanel');
|
|
682
707
|
|
|
683
708
|
_defineProperty(DropdownFilterPanel, "MAX_TABLE_SIZE", 256);
|
|
@@ -693,33 +718,6 @@ _defineProperty(DropdownFilterPanel, "SOURCE_COLUMN", Object.freeze({
|
|
|
693
718
|
type: null
|
|
694
719
|
}));
|
|
695
720
|
|
|
696
|
-
DropdownFilterPanel.propTypes = {
|
|
697
|
-
glContainer: GLPropTypes.Container.isRequired,
|
|
698
|
-
glEventHub: GLPropTypes.EventHub.isRequired,
|
|
699
|
-
panelState: PropTypes.shape({
|
|
700
|
-
name: PropTypes.string,
|
|
701
|
-
type: PropTypes.string,
|
|
702
|
-
value: PropTypes.string,
|
|
703
|
-
isValueShown: PropTypes.bool
|
|
704
|
-
}),
|
|
705
|
-
isLinkerActive: PropTypes.bool.isRequired,
|
|
706
|
-
columns: PropTypes.arrayOf(PropTypes.shape({})).isRequired,
|
|
707
|
-
columnSelectionValidator: PropTypes.func,
|
|
708
|
-
disableLinking: PropTypes.bool.isRequired,
|
|
709
|
-
settings: PropTypes.shape({
|
|
710
|
-
columnFormats: PropTypes.arrayOf(PropTypes.shape({}))
|
|
711
|
-
}).isRequired,
|
|
712
|
-
// eslint-disable-next-line react/no-unused-prop-types
|
|
713
|
-
panelTableMap: PropTypes.instanceOf(Map).isRequired,
|
|
714
|
-
// eslint-disable-next-line react/no-unused-prop-types
|
|
715
|
-
dashboardLinks: UIPropTypes.Links.isRequired
|
|
716
|
-
};
|
|
717
|
-
DropdownFilterPanel.defaultProps = {
|
|
718
|
-
columnSelectionValidator: null,
|
|
719
|
-
panelState: null
|
|
720
|
-
};
|
|
721
|
-
DropdownFilterPanel.displayName = 'DropdownFilterPanel';
|
|
722
|
-
|
|
723
721
|
var mapStateToProps = (state, ownProps) => {
|
|
724
722
|
var {
|
|
725
723
|
localDashboardId
|