@deephaven/dashboard-core-plugins 0.43.0 → 0.44.1-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ChartBuilderPlugin.js +54 -0
- package/dist/ChartBuilderPlugin.js.map +1 -0
- package/dist/ChartPlugin.js +66 -0
- package/dist/ChartPlugin.js.map +1 -0
- package/dist/ConsolePlugin.js +396 -0
- package/dist/ConsolePlugin.js.map +1 -0
- package/dist/FilterPlugin.js +205 -0
- package/dist/FilterPlugin.js.map +1 -0
- package/dist/GridPlugin.js +74 -0
- package/dist/GridPlugin.js.map +1 -0
- package/dist/LinkerPlugin.js +18 -0
- package/dist/LinkerPlugin.js.map +1 -0
- package/dist/MarkdownPlugin.js +87 -0
- package/dist/MarkdownPlugin.js.map +1 -0
- package/dist/PandasPlugin.js +66 -0
- package/dist/PandasPlugin.js.map +1 -0
- package/dist/controls/ControlType.js +10 -0
- package/dist/controls/ControlType.js.map +1 -0
- package/dist/controls/dropdown-filter/DropdownFilter.css +86 -0
- package/dist/controls/dropdown-filter/DropdownFilter.css.map +1 -0
- package/dist/controls/dropdown-filter/DropdownFilter.js +417 -0
- package/dist/controls/dropdown-filter/DropdownFilter.js.map +1 -0
- package/dist/controls/input-filter/InputFilter.css +75 -0
- package/dist/controls/input-filter/InputFilter.css.map +1 -0
- package/dist/controls/input-filter/InputFilter.js +291 -0
- package/dist/controls/input-filter/InputFilter.js.map +1 -0
- package/dist/controls/markdown/MarkdownContainer.js +30 -0
- package/dist/controls/markdown/MarkdownContainer.js.map +1 -0
- package/dist/controls/markdown/MarkdownEditor.js +52 -0
- package/dist/controls/markdown/MarkdownEditor.js.map +1 -0
- package/dist/controls/markdown/MarkdownStartPage.js +109 -0
- package/dist/controls/markdown/MarkdownStartPage.js.map +1 -0
- package/dist/controls/markdown/MarkdownUtils.js +23 -0
- package/dist/controls/markdown/MarkdownUtils.js.map +1 -0
- package/dist/events/ChartEvent.js +9 -0
- package/dist/events/ChartEvent.js.map +1 -0
- package/dist/events/ConsoleEvent.js +11 -0
- package/dist/events/ConsoleEvent.js.map +1 -0
- package/dist/events/InputFilterEvent.js +14 -0
- package/dist/events/InputFilterEvent.js.map +1 -0
- package/dist/events/IrisGridEvent.js +12 -0
- package/dist/events/IrisGridEvent.js.map +1 -0
- package/dist/events/MarkdownEvent.js +4 -0
- package/dist/events/MarkdownEvent.js.map +1 -0
- package/dist/events/NotebookEvent.js +15 -0
- package/dist/events/NotebookEvent.js.map +1 -0
- package/dist/events/PQEvent.js +9 -0
- package/dist/events/PQEvent.js.map +1 -0
- package/dist/events/PandasEvent.js +8 -0
- package/dist/events/PandasEvent.js.map +1 -0
- package/dist/events/TabEvent.js +12 -0
- package/dist/events/TabEvent.js.map +1 -0
- package/dist/events/index.js +9 -0
- package/dist/events/index.js.map +1 -0
- package/dist/index.js +17 -0
- package/dist/index.js.map +1 -0
- package/dist/linker/ColumnSelectionValidator.js +2 -0
- package/dist/linker/ColumnSelectionValidator.js.map +1 -0
- package/dist/linker/Linker.js +736 -0
- package/dist/linker/Linker.js.map +1 -0
- package/dist/linker/LinkerLink.css +142 -0
- package/dist/linker/LinkerLink.css.map +1 -0
- package/dist/linker/LinkerLink.js +314 -0
- package/dist/linker/LinkerLink.js.map +1 -0
- package/dist/linker/LinkerOverlayContent.css +63 -0
- package/dist/linker/LinkerOverlayContent.css.map +1 -0
- package/dist/linker/LinkerOverlayContent.js +343 -0
- package/dist/linker/LinkerOverlayContent.js.map +1 -0
- package/dist/linker/LinkerUtils.js +139 -0
- package/dist/linker/LinkerUtils.js.map +1 -0
- package/dist/linker/ToolType.js +5 -0
- package/dist/linker/ToolType.js.map +1 -0
- package/dist/linker/index.js +2 -0
- package/dist/linker/index.js.map +1 -0
- package/dist/panels/ChartColumnSelectorOverlay.css +11 -0
- package/dist/panels/ChartColumnSelectorOverlay.css.map +1 -0
- package/dist/panels/ChartColumnSelectorOverlay.js +38 -0
- package/dist/panels/ChartColumnSelectorOverlay.js.map +1 -0
- package/dist/panels/ChartFilterOverlay.css +22 -0
- package/dist/panels/ChartFilterOverlay.css.map +1 -0
- package/dist/panels/ChartFilterOverlay.js +90 -0
- package/dist/panels/ChartFilterOverlay.js.map +1 -0
- package/dist/panels/ChartPanel.css +38 -0
- package/dist/panels/ChartPanel.css.map +1 -0
- package/dist/panels/ChartPanel.js +971 -0
- package/dist/panels/ChartPanel.js.map +1 -0
- package/dist/panels/ChartPanelUtils.js +5 -0
- package/dist/panels/ChartPanelUtils.js.map +1 -0
- package/dist/panels/CommandHistoryPanel.css +19 -0
- package/dist/panels/CommandHistoryPanel.css.map +1 -0
- package/dist/panels/CommandHistoryPanel.js +195 -0
- package/dist/panels/CommandHistoryPanel.js.map +1 -0
- package/dist/panels/ConsolePanel.css +19 -0
- package/dist/panels/ConsolePanel.css.map +1 -0
- package/dist/panels/ConsolePanel.js +365 -0
- package/dist/panels/ConsolePanel.js.map +1 -0
- package/dist/panels/DropdownFilterPanel.css +6 -0
- package/dist/panels/DropdownFilterPanel.css.map +1 -0
- package/dist/panels/DropdownFilterPanel.js +685 -0
- package/dist/panels/DropdownFilterPanel.js.map +1 -0
- package/dist/panels/FileExplorerPanel.css +6 -0
- package/dist/panels/FileExplorerPanel.css.map +1 -0
- package/dist/panels/FileExplorerPanel.js +252 -0
- package/dist/panels/FileExplorerPanel.js.map +1 -0
- package/dist/panels/FilterSetManager.css +112 -0
- package/dist/panels/FilterSetManager.css.map +1 -0
- package/dist/panels/FilterSetManager.js +689 -0
- package/dist/panels/FilterSetManager.js.map +1 -0
- package/dist/panels/FilterSetManagerPanel.css +34 -0
- package/dist/panels/FilterSetManagerPanel.css.map +1 -0
- package/dist/panels/FilterSetManagerPanel.js +345 -0
- package/dist/panels/FilterSetManagerPanel.js.map +1 -0
- package/dist/panels/InputFilterPanel.js +232 -0
- package/dist/panels/InputFilterPanel.js.map +1 -0
- package/dist/panels/IrisGridPanel.css +24 -0
- package/dist/panels/IrisGridPanel.css.map +1 -0
- package/dist/panels/IrisGridPanel.js +1018 -0
- package/dist/panels/IrisGridPanel.js.map +1 -0
- package/dist/panels/IrisGridPanelTooltip.js +39 -0
- package/dist/panels/IrisGridPanelTooltip.js.map +1 -0
- package/dist/panels/LogPanel.css +15 -0
- package/dist/panels/LogPanel.css.map +1 -0
- package/dist/panels/LogPanel.js +110 -0
- package/dist/panels/LogPanel.js.map +1 -0
- package/dist/panels/MarkdownNotebook.css +107 -0
- package/dist/panels/MarkdownNotebook.css.map +1 -0
- package/dist/panels/MarkdownNotebook.js +232 -0
- package/dist/panels/MarkdownNotebook.js.map +1 -0
- package/dist/panels/MarkdownPanel.css +90 -0
- package/dist/panels/MarkdownPanel.css.map +1 -0
- package/dist/panels/MarkdownPanel.js +202 -0
- package/dist/panels/MarkdownPanel.js.map +1 -0
- package/dist/panels/MockFileStorage.js +70 -0
- package/dist/panels/MockFileStorage.js.map +1 -0
- package/dist/panels/MockFileStorageTable.js +80 -0
- package/dist/panels/MockFileStorageTable.js.map +1 -0
- package/dist/panels/NotebookPanel.css +44 -0
- package/dist/panels/NotebookPanel.css.map +1 -0
- package/dist/panels/NotebookPanel.js +1224 -0
- package/dist/panels/NotebookPanel.js.map +1 -0
- package/dist/panels/PandasPanel.css +15 -0
- package/dist/panels/PandasPanel.css.map +1 -0
- package/dist/panels/PandasPanel.js +86 -0
- package/dist/panels/PandasPanel.js.map +1 -0
- package/dist/panels/Panel.js +314 -0
- package/dist/panels/Panel.js.map +1 -0
- package/dist/panels/PanelContextMenu.js +126 -0
- package/dist/panels/PanelContextMenu.js.map +1 -0
- package/dist/panels/RenameDialog.js +156 -0
- package/dist/panels/RenameDialog.js.map +1 -0
- package/dist/panels/WidgetPanel.css +17 -0
- package/dist/panels/WidgetPanel.css.map +1 -0
- package/dist/panels/WidgetPanel.js +189 -0
- package/dist/panels/WidgetPanel.js.map +1 -0
- package/dist/panels/WidgetPanelTooltip.css +40 -0
- package/dist/panels/WidgetPanelTooltip.css.map +1 -0
- package/dist/panels/WidgetPanelTooltip.js +49 -0
- package/dist/panels/WidgetPanelTooltip.js.map +1 -0
- package/dist/panels/index.js +22 -0
- package/dist/panels/index.js.map +1 -0
- package/dist/prop-types/CommonPropTypes.js +9 -0
- package/dist/prop-types/CommonPropTypes.js.map +1 -0
- package/dist/prop-types/UIPropTypes.js +42 -0
- package/dist/prop-types/UIPropTypes.js.map +1 -0
- package/dist/prop-types/index.js +3 -0
- package/dist/prop-types/index.js.map +1 -0
- package/dist/redux/actionTypes.js +3 -0
- package/dist/redux/actionTypes.js.map +1 -0
- package/dist/redux/actions.js +88 -0
- package/dist/redux/actions.js.map +1 -0
- package/dist/redux/index.js +10 -0
- package/dist/redux/index.js.map +1 -0
- package/dist/redux/reducers/connection.js +7 -0
- package/dist/redux/reducers/connection.js.map +1 -0
- package/dist/redux/reducers/index.js +5 -0
- package/dist/redux/reducers/index.js.map +1 -0
- package/dist/redux/reducers/sessionWrapper.js +7 -0
- package/dist/redux/reducers/sessionWrapper.js.map +1 -0
- package/dist/redux/selectors.js +92 -0
- package/dist/redux/selectors.js.map +1 -0
- package/package.json +22 -22
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { useCallback, useEffect, useState } from 'react';
|
|
2
|
+
import { useDispatch } from 'react-redux';
|
|
3
|
+
import shortid from 'shortid';
|
|
4
|
+
import { assertIsDashboardPluginProps, LayoutUtils, PanelEvent, updateDashboardData, useListener } from '@deephaven/dashboard';
|
|
5
|
+
import Log from '@deephaven/log';
|
|
6
|
+
import { TextUtils } from '@deephaven/utils';
|
|
7
|
+
import { InputFilterEvent } from "./events/index.js";
|
|
8
|
+
import { DropdownFilterPanel, FilterSetManagerPanel, InputFilterPanel } from "./panels/index.js";
|
|
9
|
+
var log = Log.module('FilterPlugin');
|
|
10
|
+
function flattenArray(accumulator, currentValue) {
|
|
11
|
+
return accumulator.concat(currentValue);
|
|
12
|
+
}
|
|
13
|
+
export function FilterPlugin(props) {
|
|
14
|
+
assertIsDashboardPluginProps(props);
|
|
15
|
+
var {
|
|
16
|
+
id: localDashboardId,
|
|
17
|
+
layout,
|
|
18
|
+
registerComponent
|
|
19
|
+
} = props;
|
|
20
|
+
var dispatch = useDispatch();
|
|
21
|
+
var [panelColumns] = useState(() => new Map());
|
|
22
|
+
var [panelFilters] = useState(() => new Map());
|
|
23
|
+
var [panelTables] = useState(() => new Map());
|
|
24
|
+
var sendUpdate = useCallback(() => {
|
|
25
|
+
var columns = Array.from(panelColumns.values()).reduce(flattenArray, []).sort((a, b) => {
|
|
26
|
+
var aName = TextUtils.toLower(a.name);
|
|
27
|
+
var bName = TextUtils.toLower(b.name);
|
|
28
|
+
if (aName !== bName) {
|
|
29
|
+
return aName > bName ? 1 : -1;
|
|
30
|
+
}
|
|
31
|
+
var aType = TextUtils.toLower(a.type);
|
|
32
|
+
var bType = TextUtils.toLower(b.type);
|
|
33
|
+
if (aType !== bType) {
|
|
34
|
+
return aType > bType ? 1 : -1;
|
|
35
|
+
}
|
|
36
|
+
return 0;
|
|
37
|
+
}).reduce((array, column) => {
|
|
38
|
+
if (array.length === 0 || TextUtils.toLower(array[array.length - 1].name) !== TextUtils.toLower(column.name) || TextUtils.toLower(array[array.length - 1].type) !== TextUtils.toLower(column.type)) {
|
|
39
|
+
array.push(column);
|
|
40
|
+
}
|
|
41
|
+
return array;
|
|
42
|
+
}, []);
|
|
43
|
+
var filters = Array.from(panelFilters.values()).reduce(flattenArray, []).sort((a, b) => a.timestamp - b.timestamp);
|
|
44
|
+
var tableMap = new Map(panelTables);
|
|
45
|
+
log.debug('sendUpdate', {
|
|
46
|
+
columns,
|
|
47
|
+
filters,
|
|
48
|
+
tableMap
|
|
49
|
+
});
|
|
50
|
+
dispatch(updateDashboardData(localDashboardId, {
|
|
51
|
+
columns,
|
|
52
|
+
filters,
|
|
53
|
+
tableMap
|
|
54
|
+
}));
|
|
55
|
+
}, [dispatch, localDashboardId, panelColumns, panelFilters, panelTables]);
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Handler for the COLUMNS_CHANGED event.
|
|
59
|
+
* @param panel The component that's emitting the filter change
|
|
60
|
+
* @param columns The columns in this panel
|
|
61
|
+
*/
|
|
62
|
+
var handleColumnsChanged = useCallback((panel, columns) => {
|
|
63
|
+
log.debug2('handleColumnsChanged', panel, columns);
|
|
64
|
+
panelColumns.set(panel, [].concat(columns));
|
|
65
|
+
sendUpdate();
|
|
66
|
+
}, [panelColumns, sendUpdate]);
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Handler for the FILTERS_CHANGED event.
|
|
70
|
+
* @param {Component} panel The component that's emitting the filter change
|
|
71
|
+
* @param {FilterChangeEvent|Array<FilterChangeEvent>} filters The input filters set by the panel
|
|
72
|
+
*/
|
|
73
|
+
var handleFiltersChanged = useCallback((panel, filters) => {
|
|
74
|
+
log.debug2('handleFiltersChanged', panel, filters);
|
|
75
|
+
panelFilters.set(panel, [].concat(filters));
|
|
76
|
+
sendUpdate();
|
|
77
|
+
}, [panelFilters, sendUpdate]);
|
|
78
|
+
var handleTableChanged = useCallback((panel, table) => {
|
|
79
|
+
log.debug2('handleTableChanged', panel, table);
|
|
80
|
+
panelTables.set(LayoutUtils.getIdFromPanel(panel), table);
|
|
81
|
+
sendUpdate();
|
|
82
|
+
}, [panelTables, sendUpdate]);
|
|
83
|
+
var handlePanelUnmount = useCallback(panel => {
|
|
84
|
+
log.debug2('handlePanelUnmount', panel);
|
|
85
|
+
panelColumns.delete(panel);
|
|
86
|
+
panelFilters.delete(panel);
|
|
87
|
+
panelTables.delete(LayoutUtils.getIdFromPanel(panel));
|
|
88
|
+
sendUpdate();
|
|
89
|
+
}, [panelColumns, panelFilters, panelTables, sendUpdate]);
|
|
90
|
+
var handleOpenDropdown = useCallback(_ref => {
|
|
91
|
+
var {
|
|
92
|
+
title = 'DropdownFilter',
|
|
93
|
+
metadata = {},
|
|
94
|
+
panelState = null,
|
|
95
|
+
id = shortid.generate(),
|
|
96
|
+
focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,
|
|
97
|
+
createNewStack = false,
|
|
98
|
+
dragEvent = null
|
|
99
|
+
} = _ref;
|
|
100
|
+
var config = {
|
|
101
|
+
type: 'react-component',
|
|
102
|
+
component: DropdownFilterPanel.COMPONENT,
|
|
103
|
+
props: {
|
|
104
|
+
id,
|
|
105
|
+
metadata,
|
|
106
|
+
panelState,
|
|
107
|
+
localDashboardId
|
|
108
|
+
},
|
|
109
|
+
title,
|
|
110
|
+
id
|
|
111
|
+
};
|
|
112
|
+
var {
|
|
113
|
+
root
|
|
114
|
+
} = layout;
|
|
115
|
+
LayoutUtils.openComponent({
|
|
116
|
+
root,
|
|
117
|
+
config,
|
|
118
|
+
focusElement,
|
|
119
|
+
createNewStack,
|
|
120
|
+
dragEvent
|
|
121
|
+
});
|
|
122
|
+
}, [layout, localDashboardId]);
|
|
123
|
+
var handleOpenInput = useCallback(_ref2 => {
|
|
124
|
+
var {
|
|
125
|
+
title = 'InputFilter',
|
|
126
|
+
metadata = {},
|
|
127
|
+
panelState = null,
|
|
128
|
+
id = shortid.generate(),
|
|
129
|
+
focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,
|
|
130
|
+
createNewStack = false,
|
|
131
|
+
dragEvent = undefined
|
|
132
|
+
} = _ref2;
|
|
133
|
+
var config = {
|
|
134
|
+
type: 'react-component',
|
|
135
|
+
component: InputFilterPanel.COMPONENT,
|
|
136
|
+
props: {
|
|
137
|
+
id,
|
|
138
|
+
metadata,
|
|
139
|
+
panelState,
|
|
140
|
+
localDashboardId
|
|
141
|
+
},
|
|
142
|
+
title,
|
|
143
|
+
id
|
|
144
|
+
};
|
|
145
|
+
var {
|
|
146
|
+
root
|
|
147
|
+
} = layout;
|
|
148
|
+
LayoutUtils.openComponent({
|
|
149
|
+
root,
|
|
150
|
+
config,
|
|
151
|
+
focusElement,
|
|
152
|
+
createNewStack,
|
|
153
|
+
dragEvent
|
|
154
|
+
});
|
|
155
|
+
}, [layout, localDashboardId]);
|
|
156
|
+
var handleOpenFilterSetManager = useCallback(_ref3 => {
|
|
157
|
+
var {
|
|
158
|
+
title = 'FilterSets',
|
|
159
|
+
metadata = {},
|
|
160
|
+
panelState = null,
|
|
161
|
+
id = shortid.generate(),
|
|
162
|
+
focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,
|
|
163
|
+
createNewStack = false,
|
|
164
|
+
dragEvent = null
|
|
165
|
+
} = _ref3;
|
|
166
|
+
var config = {
|
|
167
|
+
type: 'react-component',
|
|
168
|
+
component: FilterSetManagerPanel.COMPONENT,
|
|
169
|
+
props: {
|
|
170
|
+
id,
|
|
171
|
+
metadata,
|
|
172
|
+
panelState,
|
|
173
|
+
localDashboardId
|
|
174
|
+
},
|
|
175
|
+
title,
|
|
176
|
+
id
|
|
177
|
+
};
|
|
178
|
+
var {
|
|
179
|
+
root
|
|
180
|
+
} = layout;
|
|
181
|
+
LayoutUtils.openComponent({
|
|
182
|
+
root,
|
|
183
|
+
config,
|
|
184
|
+
focusElement,
|
|
185
|
+
createNewStack,
|
|
186
|
+
dragEvent
|
|
187
|
+
});
|
|
188
|
+
}, [layout, localDashboardId]);
|
|
189
|
+
useEffect(function registerComponentsAndReturnCleanup() {
|
|
190
|
+
var cleanups = [registerComponent(DropdownFilterPanel.COMPONENT, DropdownFilterPanel), registerComponent(InputFilterPanel.COMPONENT, InputFilterPanel), registerComponent(FilterSetManagerPanel.COMPONENT, FilterSetManagerPanel)];
|
|
191
|
+
return () => {
|
|
192
|
+
cleanups.forEach(cleanup => cleanup());
|
|
193
|
+
};
|
|
194
|
+
}, [registerComponent]);
|
|
195
|
+
useListener(layout.eventHub, InputFilterEvent.COLUMNS_CHANGED, handleColumnsChanged);
|
|
196
|
+
useListener(layout.eventHub, InputFilterEvent.FILTERS_CHANGED, handleFiltersChanged);
|
|
197
|
+
useListener(layout.eventHub, InputFilterEvent.TABLE_CHANGED, handleTableChanged);
|
|
198
|
+
useListener(layout.eventHub, InputFilterEvent.OPEN_DROPDOWN, handleOpenDropdown);
|
|
199
|
+
useListener(layout.eventHub, InputFilterEvent.OPEN_INPUT, handleOpenInput);
|
|
200
|
+
useListener(layout.eventHub, InputFilterEvent.OPEN_FILTER_SET_MANAGER, handleOpenFilterSetManager);
|
|
201
|
+
useListener(layout.eventHub, PanelEvent.UNMOUNT, handlePanelUnmount);
|
|
202
|
+
return null;
|
|
203
|
+
}
|
|
204
|
+
export default FilterPlugin;
|
|
205
|
+
//# sourceMappingURL=FilterPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterPlugin.js","names":["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","undefined","handleOpenFilterSetManager","registerComponentsAndReturnCleanup","cleanups","forEach","cleanup","eventHub","COLUMNS_CHANGED","FILTERS_CHANGED","TABLE_CHANGED","OPEN_DROPDOWN","OPEN_INPUT","OPEN_FILTER_SET_MANAGER","UNMOUNT"],"sources":["../src/FilterPlugin.tsx"],"sourcesContent":["import { 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 function FilterPlugin(props: FilterPluginProps): JSX.Element | null {\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' as const,\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 = undefined,\n }) => {\n const config = {\n type: 'react-component' as const,\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' as const,\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 null;\n}\n\nexport default FilterPlugin;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { useCallback, useEffect, useMemo } from 'react';
|
|
2
|
+
import { assertIsDashboardPluginProps, LayoutUtils, PanelEvent, useListener } from '@deephaven/dashboard';
|
|
3
|
+
import { IrisGridModelFactory } from '@deephaven/iris-grid';
|
|
4
|
+
import { useApi } from '@deephaven/jsapi-bootstrap';
|
|
5
|
+
import shortid from 'shortid';
|
|
6
|
+
import { IrisGridPanel } from "./panels/index.js";
|
|
7
|
+
export function GridPlugin(props) {
|
|
8
|
+
assertIsDashboardPluginProps(props);
|
|
9
|
+
var {
|
|
10
|
+
getDownloadWorker,
|
|
11
|
+
loadPlugin,
|
|
12
|
+
id,
|
|
13
|
+
layout,
|
|
14
|
+
registerComponent,
|
|
15
|
+
hydrate,
|
|
16
|
+
theme
|
|
17
|
+
} = props;
|
|
18
|
+
var dh = useApi();
|
|
19
|
+
var supportedTypes = useMemo(() => [dh.VariableType.TABLE, dh.VariableType.TREETABLE, dh.VariableType.HIERARCHICALTABLE], [dh]);
|
|
20
|
+
var handlePanelOpen = useCallback(_ref => {
|
|
21
|
+
var {
|
|
22
|
+
dragEvent,
|
|
23
|
+
fetch,
|
|
24
|
+
panelId = shortid.generate(),
|
|
25
|
+
widget
|
|
26
|
+
} = _ref;
|
|
27
|
+
var {
|
|
28
|
+
name,
|
|
29
|
+
type
|
|
30
|
+
} = widget;
|
|
31
|
+
if (!supportedTypes.includes(type)) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
var metadata = {
|
|
35
|
+
name,
|
|
36
|
+
table: name,
|
|
37
|
+
type: widget.type
|
|
38
|
+
};
|
|
39
|
+
var makeModel = () => fetch().then(table => IrisGridModelFactory.makeModel(dh, table));
|
|
40
|
+
var config = {
|
|
41
|
+
type: 'react-component',
|
|
42
|
+
component: IrisGridPanel.COMPONENT,
|
|
43
|
+
props: {
|
|
44
|
+
getDownloadWorker,
|
|
45
|
+
loadPlugin,
|
|
46
|
+
localDashboardId: id,
|
|
47
|
+
id: panelId,
|
|
48
|
+
metadata,
|
|
49
|
+
makeModel,
|
|
50
|
+
theme
|
|
51
|
+
},
|
|
52
|
+
title: name,
|
|
53
|
+
id: panelId
|
|
54
|
+
};
|
|
55
|
+
var {
|
|
56
|
+
root
|
|
57
|
+
} = layout;
|
|
58
|
+
LayoutUtils.openComponent({
|
|
59
|
+
root,
|
|
60
|
+
config,
|
|
61
|
+
dragEvent
|
|
62
|
+
});
|
|
63
|
+
}, [dh, getDownloadWorker, id, layout, loadPlugin, supportedTypes, theme]);
|
|
64
|
+
useEffect(function registerComponentsAndReturnCleanup() {
|
|
65
|
+
var cleanups = [registerComponent(IrisGridPanel.COMPONENT, IrisGridPanel, hydrate)];
|
|
66
|
+
return () => {
|
|
67
|
+
cleanups.forEach(cleanup => cleanup());
|
|
68
|
+
};
|
|
69
|
+
}, [hydrate, registerComponent]);
|
|
70
|
+
useListener(layout.eventHub, PanelEvent.OPEN, handlePanelOpen);
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
export default GridPlugin;
|
|
74
|
+
//# sourceMappingURL=GridPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GridPlugin.js","names":["useCallback","useEffect","useMemo","assertIsDashboardPluginProps","LayoutUtils","PanelEvent","useListener","IrisGridModelFactory","useApi","shortid","IrisGridPanel","GridPlugin","props","getDownloadWorker","loadPlugin","id","layout","registerComponent","hydrate","theme","dh","supportedTypes","VariableType","TABLE","TREETABLE","HIERARCHICALTABLE","handlePanelOpen","dragEvent","fetch","panelId","generate","widget","name","type","includes","metadata","table","makeModel","then","config","component","COMPONENT","localDashboardId","title","root","openComponent","registerComponentsAndReturnCleanup","cleanups","forEach","cleanup","eventHub","OPEN"],"sources":["../src/GridPlugin.tsx"],"sourcesContent":["import React, { DragEvent, useCallback, useEffect, useMemo } from 'react';\nimport {\n assertIsDashboardPluginProps,\n DashboardPluginComponentProps,\n LayoutUtils,\n PanelEvent,\n PanelHydrateFunction,\n useListener,\n} from '@deephaven/dashboard';\nimport { IrisGridModelFactory, IrisGridThemeType } from '@deephaven/iris-grid';\nimport { useApi } from '@deephaven/jsapi-bootstrap';\nimport type { Table, VariableDefinition } from '@deephaven/jsapi-types';\nimport shortid from 'shortid';\nimport { IrisGridPanel, IrisGridPanelProps } from './panels';\n\nexport type GridPluginProps = Partial<DashboardPluginComponentProps> & {\n getDownloadWorker?: () => Promise<ServiceWorker>;\n loadPlugin?: (name: string) => ReturnType<typeof React.forwardRef>;\n hydrate: PanelHydrateFunction<IrisGridPanelProps>;\n theme?: Partial<IrisGridThemeType>;\n};\n\nexport function GridPlugin(props: GridPluginProps): JSX.Element | null {\n assertIsDashboardPluginProps(props);\n const {\n getDownloadWorker,\n loadPlugin,\n id,\n layout,\n registerComponent,\n hydrate,\n theme,\n } = props;\n const dh = useApi();\n const supportedTypes: string[] = useMemo(\n () => [\n dh.VariableType.TABLE,\n dh.VariableType.TREETABLE,\n dh.VariableType.HIERARCHICALTABLE,\n ],\n [dh]\n );\n const handlePanelOpen = useCallback(\n ({\n dragEvent,\n fetch,\n panelId = shortid.generate(),\n widget,\n }: {\n dragEvent?: DragEvent;\n fetch: () => Promise<Table>;\n panelId?: string;\n widget: VariableDefinition;\n }) => {\n const { name, type } = widget;\n if (!supportedTypes.includes(type)) {\n return;\n }\n const metadata = { name, table: name, type: widget.type };\n const makeModel = () =>\n fetch().then((table: Table) =>\n IrisGridModelFactory.makeModel(dh, table)\n );\n const config = {\n type: 'react-component' as const,\n component: IrisGridPanel.COMPONENT,\n props: {\n getDownloadWorker,\n loadPlugin,\n localDashboardId: id,\n id: panelId,\n metadata,\n makeModel,\n theme,\n },\n title: name,\n id: panelId,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({ root, config, dragEvent });\n },\n [dh, getDownloadWorker, id, layout, loadPlugin, supportedTypes, theme]\n );\n\n useEffect(\n function registerComponentsAndReturnCleanup() {\n const cleanups = [\n registerComponent(\n IrisGridPanel.COMPONENT,\n IrisGridPanel,\n hydrate as PanelHydrateFunction\n ),\n ];\n return () => {\n cleanups.forEach(cleanup => cleanup());\n };\n },\n [hydrate, registerComponent]\n );\n\n useListener(layout.eventHub, PanelEvent.OPEN, handlePanelOpen);\n\n return null;\n}\n\nexport default GridPlugin;\n"],"mappings":"AAAA,SAA2BA,WAAW,EAAEC,SAAS,EAAEC,OAAO,QAAQ,OAAO;AACzE,SACEC,4BAA4B,EAE5BC,WAAW,EACXC,UAAU,EAEVC,WAAW,QACN,sBAAsB;AAC7B,SAASC,oBAAoB,QAA2B,sBAAsB;AAC9E,SAASC,MAAM,QAAQ,4BAA4B;AAEnD,OAAOC,OAAO,MAAM,SAAS;AAAC,SACrBC,aAAa;AAStB,OAAO,SAASC,UAAU,CAACC,KAAsB,EAAsB;EACrET,4BAA4B,CAACS,KAAK,CAAC;EACnC,IAAM;IACJC,iBAAiB;IACjBC,UAAU;IACVC,EAAE;IACFC,MAAM;IACNC,iBAAiB;IACjBC,OAAO;IACPC;EACF,CAAC,GAAGP,KAAK;EACT,IAAMQ,EAAE,GAAGZ,MAAM,EAAE;EACnB,IAAMa,cAAwB,GAAGnB,OAAO,CACtC,MAAM,CACJkB,EAAE,CAACE,YAAY,CAACC,KAAK,EACrBH,EAAE,CAACE,YAAY,CAACE,SAAS,EACzBJ,EAAE,CAACE,YAAY,CAACG,iBAAiB,CAClC,EACD,CAACL,EAAE,CAAC,CACL;EACD,IAAMM,eAAe,GAAG1B,WAAW,CACjC,QAUM;IAAA,IAVL;MACC2B,SAAS;MACTC,KAAK;MACLC,OAAO,GAAGpB,OAAO,CAACqB,QAAQ,EAAE;MAC5BC;IAMF,CAAC;IACC,IAAM;MAAEC,IAAI;MAAEC;IAAK,CAAC,GAAGF,MAAM;IAC7B,IAAI,CAACV,cAAc,CAACa,QAAQ,CAACD,IAAI,CAAC,EAAE;MAClC;IACF;IACA,IAAME,QAAQ,GAAG;MAAEH,IAAI;MAAEI,KAAK,EAAEJ,IAAI;MAAEC,IAAI,EAAEF,MAAM,CAACE;IAAK,CAAC;IACzD,IAAMI,SAAS,GAAG,MAChBT,KAAK,EAAE,CAACU,IAAI,CAAEF,KAAY,IACxB7B,oBAAoB,CAAC8B,SAAS,CAACjB,EAAE,EAAEgB,KAAK,CAAC,CAC1C;IACH,IAAMG,MAAM,GAAG;MACbN,IAAI,EAAE,iBAA0B;MAChCO,SAAS,EAAE9B,aAAa,CAAC+B,SAAS;MAClC7B,KAAK,EAAE;QACLC,iBAAiB;QACjBC,UAAU;QACV4B,gBAAgB,EAAE3B,EAAE;QACpBA,EAAE,EAAEc,OAAO;QACXM,QAAQ;QACRE,SAAS;QACTlB;MACF,CAAC;MACDwB,KAAK,EAAEX,IAAI;MACXjB,EAAE,EAAEc;IACN,CAAC;IAED,IAAM;MAAEe;IAAK,CAAC,GAAG5B,MAAM;IACvBZ,WAAW,CAACyC,aAAa,CAAC;MAAED,IAAI;MAAEL,MAAM;MAAEZ;IAAU,CAAC,CAAC;EACxD,CAAC,EACD,CAACP,EAAE,EAAEP,iBAAiB,EAAEE,EAAE,EAAEC,MAAM,EAAEF,UAAU,EAAEO,cAAc,EAAEF,KAAK,CAAC,CACvE;EAEDlB,SAAS,CACP,SAAS6C,kCAAkC,GAAG;IAC5C,IAAMC,QAAQ,GAAG,CACf9B,iBAAiB,CACfP,aAAa,CAAC+B,SAAS,EACvB/B,aAAa,EACbQ,OAAO,CACR,CACF;IACD,OAAO,MAAM;MACX6B,QAAQ,CAACC,OAAO,CAACC,OAAO,IAAIA,OAAO,EAAE,CAAC;IACxC,CAAC;EACH,CAAC,EACD,CAAC/B,OAAO,EAAED,iBAAiB,CAAC,CAC7B;EAEDX,WAAW,CAACU,MAAM,CAACkC,QAAQ,EAAE7C,UAAU,CAAC8C,IAAI,EAAEzB,eAAe,CAAC;EAE9D,OAAO,IAAI;AACb;AAEA,eAAef,UAAU"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { assertIsDashboardPluginProps } from '@deephaven/dashboard';
|
|
3
|
+
import Linker from "./linker/Linker.js";
|
|
4
|
+
export function LinkerPlugin(props) {
|
|
5
|
+
assertIsDashboardPluginProps(props);
|
|
6
|
+
var {
|
|
7
|
+
id,
|
|
8
|
+
layout,
|
|
9
|
+
panelManager
|
|
10
|
+
} = props;
|
|
11
|
+
return /*#__PURE__*/React.createElement(Linker, {
|
|
12
|
+
layout: layout,
|
|
13
|
+
localDashboardId: id,
|
|
14
|
+
panelManager: panelManager
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
export default LinkerPlugin;
|
|
18
|
+
//# sourceMappingURL=LinkerPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LinkerPlugin.js","names":["React","assertIsDashboardPluginProps","Linker","LinkerPlugin","props","id","layout","panelManager"],"sources":["../src/LinkerPlugin.tsx"],"sourcesContent":["import React from 'react';\nimport {\n assertIsDashboardPluginProps,\n DashboardPluginComponentProps,\n} from '@deephaven/dashboard';\nimport Linker from './linker/Linker';\n\nexport type LinkerPluginProps = Partial<DashboardPluginComponentProps>;\n\nexport function LinkerPlugin(props: LinkerPluginProps): JSX.Element {\n assertIsDashboardPluginProps(props);\n const { id, layout, panelManager } = props;\n return (\n <Linker layout={layout} localDashboardId={id} panelManager={panelManager} />\n );\n}\n\nexport default LinkerPlugin;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SACEC,4BAA4B,QAEvB,sBAAsB;AAAC,OACvBC,MAAM;AAIb,OAAO,SAASC,YAAY,CAACC,KAAwB,EAAe;EAClEH,4BAA4B,CAACG,KAAK,CAAC;EACnC,IAAM;IAAEC,EAAE;IAAEC,MAAM;IAAEC;EAAa,CAAC,GAAGH,KAAK;EAC1C,oBACE,oBAAC,MAAM;IAAC,MAAM,EAAEE,MAAO;IAAC,gBAAgB,EAAED,EAAG;IAAC,YAAY,EAAEE;EAAa,EAAG;AAEhF;AAEA,eAAeJ,YAAY"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { useCallback, useEffect } from 'react';
|
|
2
|
+
import shortid from 'shortid';
|
|
3
|
+
import { assertIsDashboardPluginProps, dehydrate, hydrate, LayoutUtils, useListener } from '@deephaven/dashboard';
|
|
4
|
+
import { MarkdownPanel } from "./panels/index.js";
|
|
5
|
+
import MarkdownUtils from "./controls/markdown/MarkdownUtils.js";
|
|
6
|
+
import MarkdownEvent from "./events/MarkdownEvent.js";
|
|
7
|
+
export function MarkdownPlugin(props) {
|
|
8
|
+
assertIsDashboardPluginProps(props);
|
|
9
|
+
var {
|
|
10
|
+
id,
|
|
11
|
+
layout,
|
|
12
|
+
panelManager,
|
|
13
|
+
registerComponent
|
|
14
|
+
} = props;
|
|
15
|
+
var dehydrateMarkdown = useCallback(config => {
|
|
16
|
+
var {
|
|
17
|
+
title,
|
|
18
|
+
componentState,
|
|
19
|
+
props: configProps
|
|
20
|
+
} = config;
|
|
21
|
+
var {
|
|
22
|
+
panelState = null
|
|
23
|
+
} = configProps;
|
|
24
|
+
if (componentState != null) {
|
|
25
|
+
({
|
|
26
|
+
panelState = null
|
|
27
|
+
} = componentState);
|
|
28
|
+
}
|
|
29
|
+
if (title == null || panelState == null || panelState.content == null || panelState.content.length === 0 || panelState.content === MarkdownUtils.DEFAULT_CONTENT) {
|
|
30
|
+
// We don't want to save it if there's no content
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
return dehydrate(config);
|
|
34
|
+
}, []);
|
|
35
|
+
var handleOpen = useCallback(function () {
|
|
36
|
+
var {
|
|
37
|
+
title = '',
|
|
38
|
+
metadata = {},
|
|
39
|
+
id: panelId = shortid.generate(),
|
|
40
|
+
focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,
|
|
41
|
+
createNewStack = false,
|
|
42
|
+
dragEvent = null
|
|
43
|
+
} = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
44
|
+
var openedMarkdowns = panelManager.getOpenedPanelConfigsOfType(MarkdownPanel.COMPONENT);
|
|
45
|
+
var closedMarkdowns = panelManager.getClosedPanelConfigsOfType(MarkdownPanel.COMPONENT);
|
|
46
|
+
var usedTitles = openedMarkdowns.map(markdown => {
|
|
47
|
+
var _markdown$title;
|
|
48
|
+
return (_markdown$title = markdown.title) !== null && _markdown$title !== void 0 ? _markdown$title : '';
|
|
49
|
+
});
|
|
50
|
+
var panelTitle = title != null && title !== '' ? title : MarkdownUtils.getNewMarkdownTitle(usedTitles);
|
|
51
|
+
var content = closedMarkdowns.length > 0 ? null : MarkdownUtils.DEFAULT_CONTENT;
|
|
52
|
+
var config = {
|
|
53
|
+
type: 'react-component',
|
|
54
|
+
component: MarkdownPanel.COMPONENT,
|
|
55
|
+
props: {
|
|
56
|
+
id: panelId,
|
|
57
|
+
metadata,
|
|
58
|
+
panelState: {
|
|
59
|
+
content
|
|
60
|
+
},
|
|
61
|
+
localDashboardId: id
|
|
62
|
+
},
|
|
63
|
+
title: panelTitle,
|
|
64
|
+
id: panelId
|
|
65
|
+
};
|
|
66
|
+
var {
|
|
67
|
+
root
|
|
68
|
+
} = layout;
|
|
69
|
+
LayoutUtils.openComponent({
|
|
70
|
+
root,
|
|
71
|
+
config,
|
|
72
|
+
focusElement,
|
|
73
|
+
createNewStack,
|
|
74
|
+
dragEvent
|
|
75
|
+
});
|
|
76
|
+
}, [id, layout, panelManager]);
|
|
77
|
+
useEffect(function registerComponentsAndReturnCleanup() {
|
|
78
|
+
var cleanups = [registerComponent(MarkdownPanel.COMPONENT, MarkdownPanel, hydrate, dehydrateMarkdown)];
|
|
79
|
+
return () => {
|
|
80
|
+
cleanups.forEach(cleanup => cleanup());
|
|
81
|
+
};
|
|
82
|
+
}, [dehydrateMarkdown, registerComponent]);
|
|
83
|
+
useListener(layout.eventHub, MarkdownEvent.OPEN, handleOpen);
|
|
84
|
+
return null;
|
|
85
|
+
}
|
|
86
|
+
export default MarkdownPlugin;
|
|
87
|
+
//# sourceMappingURL=MarkdownPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarkdownPlugin.js","names":["useCallback","useEffect","shortid","assertIsDashboardPluginProps","dehydrate","hydrate","LayoutUtils","useListener","MarkdownPanel","MarkdownUtils","MarkdownEvent","MarkdownPlugin","props","id","layout","panelManager","registerComponent","dehydrateMarkdown","config","title","componentState","configProps","panelState","content","length","DEFAULT_CONTENT","handleOpen","metadata","panelId","generate","focusElement","DEFAULT_FOCUS_SELECTOR","createNewStack","dragEvent","openedMarkdowns","getOpenedPanelConfigsOfType","COMPONENT","closedMarkdowns","getClosedPanelConfigsOfType","usedTitles","map","markdown","panelTitle","getNewMarkdownTitle","type","component","localDashboardId","root","openComponent","registerComponentsAndReturnCleanup","cleanups","forEach","cleanup","eventHub","OPEN"],"sources":["../src/MarkdownPlugin.tsx"],"sourcesContent":["import { useCallback, useEffect } from 'react';\nimport shortid from 'shortid';\nimport {\n assertIsDashboardPluginProps,\n DashboardPluginComponentProps,\n dehydrate,\n hydrate,\n LayoutUtils,\n useListener,\n} from '@deephaven/dashboard';\nimport { MarkdownPanel } from './panels';\nimport MarkdownUtils from './controls/markdown/MarkdownUtils';\nimport MarkdownEvent from './events/MarkdownEvent';\n\nexport type MarkdownPluginProps = Partial<DashboardPluginComponentProps>;\n\nexport type MarkdownComponentState = {\n panelState?: { content: string } | null;\n};\n\nexport function MarkdownPlugin(props: MarkdownPluginProps): JSX.Element | null {\n assertIsDashboardPluginProps(props);\n const { id, layout, panelManager, registerComponent } = props;\n const dehydrateMarkdown = useCallback(config => {\n const { title, componentState, props: configProps } = config;\n let { panelState = null }: MarkdownComponentState = configProps;\n if (componentState != null) {\n ({ panelState = null } = componentState as MarkdownComponentState);\n }\n if (\n title == null ||\n panelState == null ||\n panelState.content == null ||\n panelState.content.length === 0 ||\n panelState.content === MarkdownUtils.DEFAULT_CONTENT\n ) {\n // We don't want to save it if there's no content\n return null;\n }\n return dehydrate(config);\n }, []);\n\n const handleOpen = useCallback(\n ({\n title = '',\n metadata = {},\n id: panelId = shortid.generate(),\n focusElement = LayoutUtils.DEFAULT_FOCUS_SELECTOR,\n createNewStack = false,\n dragEvent = null,\n } = {}) => {\n const openedMarkdowns = panelManager.getOpenedPanelConfigsOfType(\n MarkdownPanel.COMPONENT\n );\n const closedMarkdowns = panelManager.getClosedPanelConfigsOfType(\n MarkdownPanel.COMPONENT\n );\n const usedTitles = openedMarkdowns.map(markdown => markdown.title ?? '');\n const panelTitle =\n title != null && title !== ''\n ? title\n : MarkdownUtils.getNewMarkdownTitle(usedTitles);\n const content =\n closedMarkdowns.length > 0 ? null : MarkdownUtils.DEFAULT_CONTENT;\n const config = {\n type: 'react-component' as const,\n component: MarkdownPanel.COMPONENT,\n props: {\n id: panelId,\n metadata,\n panelState: { content },\n localDashboardId: id,\n },\n title: panelTitle,\n id: panelId,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({\n root,\n config,\n focusElement,\n createNewStack,\n dragEvent,\n });\n },\n [id, layout, panelManager]\n );\n\n useEffect(\n function registerComponentsAndReturnCleanup() {\n const cleanups = [\n registerComponent(\n MarkdownPanel.COMPONENT,\n MarkdownPanel,\n hydrate,\n dehydrateMarkdown\n ),\n ];\n\n return () => {\n cleanups.forEach(cleanup => cleanup());\n };\n },\n [dehydrateMarkdown, registerComponent]\n );\n\n useListener(layout.eventHub, MarkdownEvent.OPEN, handleOpen);\n\n return null;\n}\n\nexport default MarkdownPlugin;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { useCallback, useEffect } from 'react';
|
|
2
|
+
import { assertIsDashboardPluginProps, LayoutUtils, PanelEvent, useListener } from '@deephaven/dashboard';
|
|
3
|
+
import { IrisGridModelFactory } from '@deephaven/iris-grid';
|
|
4
|
+
import { useApi } from '@deephaven/jsapi-bootstrap';
|
|
5
|
+
import shortid from 'shortid';
|
|
6
|
+
import { PandasPanel } from "./panels/index.js";
|
|
7
|
+
export function PandasPlugin(props) {
|
|
8
|
+
assertIsDashboardPluginProps(props);
|
|
9
|
+
var {
|
|
10
|
+
hydrate,
|
|
11
|
+
id,
|
|
12
|
+
layout,
|
|
13
|
+
registerComponent
|
|
14
|
+
} = props;
|
|
15
|
+
var dh = useApi();
|
|
16
|
+
var handlePanelOpen = useCallback(_ref => {
|
|
17
|
+
var {
|
|
18
|
+
dragEvent,
|
|
19
|
+
fetch,
|
|
20
|
+
panelId = shortid.generate(),
|
|
21
|
+
widget
|
|
22
|
+
} = _ref;
|
|
23
|
+
var {
|
|
24
|
+
name,
|
|
25
|
+
type
|
|
26
|
+
} = widget;
|
|
27
|
+
if (type !== dh.VariableType.PANDAS) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
var metadata = {
|
|
31
|
+
name,
|
|
32
|
+
table: name
|
|
33
|
+
};
|
|
34
|
+
var makeModel = () => fetch().then(table => IrisGridModelFactory.makeModel(dh, table));
|
|
35
|
+
var config = {
|
|
36
|
+
type: 'react-component',
|
|
37
|
+
component: PandasPanel.COMPONENT,
|
|
38
|
+
props: {
|
|
39
|
+
localDashboardId: id,
|
|
40
|
+
id: panelId,
|
|
41
|
+
metadata,
|
|
42
|
+
makeModel
|
|
43
|
+
},
|
|
44
|
+
title: name,
|
|
45
|
+
id: panelId
|
|
46
|
+
};
|
|
47
|
+
var {
|
|
48
|
+
root
|
|
49
|
+
} = layout;
|
|
50
|
+
LayoutUtils.openComponent({
|
|
51
|
+
root,
|
|
52
|
+
config,
|
|
53
|
+
dragEvent
|
|
54
|
+
});
|
|
55
|
+
}, [dh, id, layout]);
|
|
56
|
+
useEffect(function registerComponentsAndReturnCleanup() {
|
|
57
|
+
var cleanups = [registerComponent(PandasPanel.COMPONENT, PandasPanel, hydrate)];
|
|
58
|
+
return () => {
|
|
59
|
+
cleanups.forEach(cleanup => cleanup());
|
|
60
|
+
};
|
|
61
|
+
}, [hydrate, registerComponent]);
|
|
62
|
+
useListener(layout.eventHub, PanelEvent.OPEN, handlePanelOpen);
|
|
63
|
+
return null;
|
|
64
|
+
}
|
|
65
|
+
export default PandasPlugin;
|
|
66
|
+
//# sourceMappingURL=PandasPlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PandasPlugin.js","names":["useCallback","useEffect","assertIsDashboardPluginProps","LayoutUtils","PanelEvent","useListener","IrisGridModelFactory","useApi","shortid","PandasPanel","PandasPlugin","props","hydrate","id","layout","registerComponent","dh","handlePanelOpen","dragEvent","fetch","panelId","generate","widget","name","type","VariableType","PANDAS","metadata","table","makeModel","then","config","component","COMPONENT","localDashboardId","title","root","openComponent","registerComponentsAndReturnCleanup","cleanups","forEach","cleanup","eventHub","OPEN"],"sources":["../src/PandasPlugin.tsx"],"sourcesContent":["import { useCallback, useEffect } from 'react';\nimport {\n assertIsDashboardPluginProps,\n DashboardPluginComponentProps,\n LayoutUtils,\n PanelEvent,\n PanelHydrateFunction,\n useListener,\n} from '@deephaven/dashboard';\nimport { IrisGridModelFactory } from '@deephaven/iris-grid';\nimport { useApi } from '@deephaven/jsapi-bootstrap';\nimport type { Table } from '@deephaven/jsapi-types';\nimport shortid from 'shortid';\nimport { PandasPanel, PandasPanelProps } from './panels';\n\nexport type PandasPluginProps = Partial<DashboardPluginComponentProps> & {\n hydrate: PanelHydrateFunction<PandasPanelProps>;\n};\n\nexport function PandasPlugin(props: PandasPluginProps): JSX.Element | null {\n assertIsDashboardPluginProps(props);\n const { hydrate, id, layout, registerComponent } = props;\n\n const dh = useApi();\n\n const handlePanelOpen = useCallback(\n ({ dragEvent, fetch, panelId = shortid.generate(), widget }) => {\n const { name, type } = widget;\n if (type !== dh.VariableType.PANDAS) {\n return;\n }\n\n const metadata = { name, table: name };\n const makeModel = () =>\n fetch().then((table: Table) =>\n IrisGridModelFactory.makeModel(dh, table)\n );\n const config = {\n type: 'react-component' as const,\n component: PandasPanel.COMPONENT,\n props: {\n localDashboardId: id,\n id: panelId,\n metadata,\n makeModel,\n },\n title: name,\n id: panelId,\n };\n\n const { root } = layout;\n LayoutUtils.openComponent({ root, config, dragEvent });\n },\n [dh, id, layout]\n );\n\n useEffect(\n function registerComponentsAndReturnCleanup() {\n const cleanups = [\n registerComponent(PandasPanel.COMPONENT, PandasPanel, hydrate),\n ];\n\n return () => {\n cleanups.forEach(cleanup => cleanup());\n };\n },\n [hydrate, registerComponent]\n );\n\n useListener(layout.eventHub, PanelEvent.OPEN, handlePanelOpen);\n\n return null;\n}\n\nexport default PandasPlugin;\n"],"mappings":"AAAA,SAASA,WAAW,EAAEC,SAAS,QAAQ,OAAO;AAC9C,SACEC,4BAA4B,EAE5BC,WAAW,EACXC,UAAU,EAEVC,WAAW,QACN,sBAAsB;AAC7B,SAASC,oBAAoB,QAAQ,sBAAsB;AAC3D,SAASC,MAAM,QAAQ,4BAA4B;AAEnD,OAAOC,OAAO,MAAM,SAAS;AAAC,SACrBC,WAAW;AAMpB,OAAO,SAASC,YAAY,CAACC,KAAwB,EAAsB;EACzET,4BAA4B,CAACS,KAAK,CAAC;EACnC,IAAM;IAAEC,OAAO;IAAEC,EAAE;IAAEC,MAAM;IAAEC;EAAkB,CAAC,GAAGJ,KAAK;EAExD,IAAMK,EAAE,GAAGT,MAAM,EAAE;EAEnB,IAAMU,eAAe,GAAGjB,WAAW,CACjC,QAAgE;IAAA,IAA/D;MAAEkB,SAAS;MAAEC,KAAK;MAAEC,OAAO,GAAGZ,OAAO,CAACa,QAAQ,EAAE;MAAEC;IAAO,CAAC;IACzD,IAAM;MAAEC,IAAI;MAAEC;IAAK,CAAC,GAAGF,MAAM;IAC7B,IAAIE,IAAI,KAAKR,EAAE,CAACS,YAAY,CAACC,MAAM,EAAE;MACnC;IACF;IAEA,IAAMC,QAAQ,GAAG;MAAEJ,IAAI;MAAEK,KAAK,EAAEL;IAAK,CAAC;IACtC,IAAMM,SAAS,GAAG,MAChBV,KAAK,EAAE,CAACW,IAAI,CAAEF,KAAY,IACxBtB,oBAAoB,CAACuB,SAAS,CAACb,EAAE,EAAEY,KAAK,CAAC,CAC1C;IACH,IAAMG,MAAM,GAAG;MACbP,IAAI,EAAE,iBAA0B;MAChCQ,SAAS,EAAEvB,WAAW,CAACwB,SAAS;MAChCtB,KAAK,EAAE;QACLuB,gBAAgB,EAAErB,EAAE;QACpBA,EAAE,EAAEO,OAAO;QACXO,QAAQ;QACRE;MACF,CAAC;MACDM,KAAK,EAAEZ,IAAI;MACXV,EAAE,EAAEO;IACN,CAAC;IAED,IAAM;MAAEgB;IAAK,CAAC,GAAGtB,MAAM;IACvBX,WAAW,CAACkC,aAAa,CAAC;MAAED,IAAI;MAAEL,MAAM;MAAEb;IAAU,CAAC,CAAC;EACxD,CAAC,EACD,CAACF,EAAE,EAAEH,EAAE,EAAEC,MAAM,CAAC,CACjB;EAEDb,SAAS,CACP,SAASqC,kCAAkC,GAAG;IAC5C,IAAMC,QAAQ,GAAG,CACfxB,iBAAiB,CAACN,WAAW,CAACwB,SAAS,EAAExB,WAAW,EAAEG,OAAO,CAAC,CAC/D;IAED,OAAO,MAAM;MACX2B,QAAQ,CAACC,OAAO,CAACC,OAAO,IAAIA,OAAO,EAAE,CAAC;IACxC,CAAC;EACH,CAAC,EACD,CAAC7B,OAAO,EAAEG,iBAAiB,CAAC,CAC7B;EAEDV,WAAW,CAACS,MAAM,CAAC4B,QAAQ,EAAEtC,UAAU,CAACuC,IAAI,EAAE1B,eAAe,CAAC;EAE9D,OAAO,IAAI;AACb;AAEA,eAAeP,YAAY"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
2
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
3
|
+
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
4
|
+
class ControlType {}
|
|
5
|
+
_defineProperty(ControlType, "DROPDOWN_FILTER", 'ControlType.DROPDOWN_FILTER');
|
|
6
|
+
_defineProperty(ControlType, "INPUT_FILTER", 'ControlType.INPUT_FILTER');
|
|
7
|
+
_defineProperty(ControlType, "MARKDOWN", 'ControlType.MARKDOWN');
|
|
8
|
+
_defineProperty(ControlType, "FILTER_SET_MANAGER", 'ControlType.FILTER_SET_MANAGER');
|
|
9
|
+
export default ControlType;
|
|
10
|
+
//# sourceMappingURL=ControlType.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ControlType.js","names":["ControlType"],"sources":["../../src/controls/ControlType.ts"],"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"],"mappings":";;;AAAA,MAAMA,WAAW,CAAC;AAQjB,gBARKA,WAAW,qBACU,6BAA6B;AAAA,gBADlDA,WAAW,kBAGO,0BAA0B;AAAA,gBAH5CA,WAAW,cAKG,sBAAsB;AAAA,gBALpCA,WAAW,wBAOa,gCAAgC;AAG9D,eAAeA,WAAW"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/* stylelint-disable scss/at-import-no-partial-leading-underscore */
|
|
2
|
+
.dropdown-filter-panel-component .lm_content {
|
|
3
|
+
overflow: visible;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
.dropdown-filter {
|
|
7
|
+
background: #1a171a;
|
|
8
|
+
}
|
|
9
|
+
.dropdown-filter .error-message {
|
|
10
|
+
color: #f95d84;
|
|
11
|
+
margin-bottom: 1.5rem;
|
|
12
|
+
font-size: 1rem;
|
|
13
|
+
}
|
|
14
|
+
.dropdown-filter .dropdown-filter-settings-card,
|
|
15
|
+
.dropdown-filter .dropdown-filter-value-card {
|
|
16
|
+
position: relative;
|
|
17
|
+
overflow: auto;
|
|
18
|
+
height: 100%;
|
|
19
|
+
background: #2d2a2e;
|
|
20
|
+
}
|
|
21
|
+
.dropdown-filter .dropdown-filter-card-content {
|
|
22
|
+
margin: auto;
|
|
23
|
+
padding: 0.25rem;
|
|
24
|
+
}
|
|
25
|
+
.dropdown-filter .dropdown-filter-settings-card {
|
|
26
|
+
display: flex;
|
|
27
|
+
justify-content: center;
|
|
28
|
+
align-items: center;
|
|
29
|
+
}
|
|
30
|
+
.dropdown-filter .dropdown-filter-settings-grid {
|
|
31
|
+
display: grid;
|
|
32
|
+
grid-template-columns: max-content min-max(min-content, 350px);
|
|
33
|
+
column-gap: 0.5rem;
|
|
34
|
+
row-gap: 0.5rem;
|
|
35
|
+
padding-bottom: 1rem;
|
|
36
|
+
}
|
|
37
|
+
.dropdown-filter .dropdown-filter-settings-grid label {
|
|
38
|
+
padding-top: calc(0.375rem + 2px);
|
|
39
|
+
margin-bottom: 0;
|
|
40
|
+
}
|
|
41
|
+
.dropdown-filter .dropdown-filter-settings-grid .text-muted {
|
|
42
|
+
grid-column-start: 2;
|
|
43
|
+
}
|
|
44
|
+
.dropdown-filter .dropdown-filter-settings-buttons {
|
|
45
|
+
display: flex;
|
|
46
|
+
justify-content: flex-end;
|
|
47
|
+
flex-wrap: wrap;
|
|
48
|
+
}
|
|
49
|
+
.dropdown-filter .dropdown-filter-value-card {
|
|
50
|
+
display: flex;
|
|
51
|
+
justify-content: center;
|
|
52
|
+
align-items: center;
|
|
53
|
+
}
|
|
54
|
+
.dropdown-filter .dropdown-filter-column {
|
|
55
|
+
position: absolute;
|
|
56
|
+
top: 0;
|
|
57
|
+
left: 0;
|
|
58
|
+
padding: 0.5rem;
|
|
59
|
+
color: #929192;
|
|
60
|
+
font-size: small;
|
|
61
|
+
}
|
|
62
|
+
.dropdown-filter .dropdown-filter-menu {
|
|
63
|
+
position: absolute;
|
|
64
|
+
top: 0;
|
|
65
|
+
right: 0;
|
|
66
|
+
}
|
|
67
|
+
.dropdown-filter .dropdown-filter-value-input {
|
|
68
|
+
max-width: 100%;
|
|
69
|
+
padding: 0.25rem;
|
|
70
|
+
}
|
|
71
|
+
.dropdown-filter .dropdown-filter-value-input input {
|
|
72
|
+
font-size: x-large;
|
|
73
|
+
color: #f0f0ee;
|
|
74
|
+
text-align: center;
|
|
75
|
+
background: transparent;
|
|
76
|
+
border: none;
|
|
77
|
+
border-bottom: 1px solid #929192;
|
|
78
|
+
max-width: 100%;
|
|
79
|
+
}
|
|
80
|
+
.dropdown-filter .dropdown-filter-value-input input:focus {
|
|
81
|
+
outline: none;
|
|
82
|
+
border-bottom: 1px solid rgba(72, 120, 234, 0.85);
|
|
83
|
+
box-shadow: 0 0.2rem 0 rgba(72, 120, 234, 0.35);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/*# sourceMappingURL=DropdownFilter.css.map */
|