@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.
Files changed (181) hide show
  1. package/dist/ChartBuilderPlugin.js +54 -0
  2. package/dist/ChartBuilderPlugin.js.map +1 -0
  3. package/dist/ChartPlugin.js +66 -0
  4. package/dist/ChartPlugin.js.map +1 -0
  5. package/dist/ConsolePlugin.js +396 -0
  6. package/dist/ConsolePlugin.js.map +1 -0
  7. package/dist/FilterPlugin.js +205 -0
  8. package/dist/FilterPlugin.js.map +1 -0
  9. package/dist/GridPlugin.js +74 -0
  10. package/dist/GridPlugin.js.map +1 -0
  11. package/dist/LinkerPlugin.js +18 -0
  12. package/dist/LinkerPlugin.js.map +1 -0
  13. package/dist/MarkdownPlugin.js +87 -0
  14. package/dist/MarkdownPlugin.js.map +1 -0
  15. package/dist/PandasPlugin.js +66 -0
  16. package/dist/PandasPlugin.js.map +1 -0
  17. package/dist/controls/ControlType.js +10 -0
  18. package/dist/controls/ControlType.js.map +1 -0
  19. package/dist/controls/dropdown-filter/DropdownFilter.css +86 -0
  20. package/dist/controls/dropdown-filter/DropdownFilter.css.map +1 -0
  21. package/dist/controls/dropdown-filter/DropdownFilter.js +417 -0
  22. package/dist/controls/dropdown-filter/DropdownFilter.js.map +1 -0
  23. package/dist/controls/input-filter/InputFilter.css +75 -0
  24. package/dist/controls/input-filter/InputFilter.css.map +1 -0
  25. package/dist/controls/input-filter/InputFilter.js +291 -0
  26. package/dist/controls/input-filter/InputFilter.js.map +1 -0
  27. package/dist/controls/markdown/MarkdownContainer.js +30 -0
  28. package/dist/controls/markdown/MarkdownContainer.js.map +1 -0
  29. package/dist/controls/markdown/MarkdownEditor.js +52 -0
  30. package/dist/controls/markdown/MarkdownEditor.js.map +1 -0
  31. package/dist/controls/markdown/MarkdownStartPage.js +109 -0
  32. package/dist/controls/markdown/MarkdownStartPage.js.map +1 -0
  33. package/dist/controls/markdown/MarkdownUtils.js +23 -0
  34. package/dist/controls/markdown/MarkdownUtils.js.map +1 -0
  35. package/dist/events/ChartEvent.js +9 -0
  36. package/dist/events/ChartEvent.js.map +1 -0
  37. package/dist/events/ConsoleEvent.js +11 -0
  38. package/dist/events/ConsoleEvent.js.map +1 -0
  39. package/dist/events/InputFilterEvent.js +14 -0
  40. package/dist/events/InputFilterEvent.js.map +1 -0
  41. package/dist/events/IrisGridEvent.js +12 -0
  42. package/dist/events/IrisGridEvent.js.map +1 -0
  43. package/dist/events/MarkdownEvent.js +4 -0
  44. package/dist/events/MarkdownEvent.js.map +1 -0
  45. package/dist/events/NotebookEvent.js +15 -0
  46. package/dist/events/NotebookEvent.js.map +1 -0
  47. package/dist/events/PQEvent.js +9 -0
  48. package/dist/events/PQEvent.js.map +1 -0
  49. package/dist/events/PandasEvent.js +8 -0
  50. package/dist/events/PandasEvent.js.map +1 -0
  51. package/dist/events/TabEvent.js +12 -0
  52. package/dist/events/TabEvent.js.map +1 -0
  53. package/dist/events/index.js +9 -0
  54. package/dist/events/index.js.map +1 -0
  55. package/dist/index.js +17 -0
  56. package/dist/index.js.map +1 -0
  57. package/dist/linker/ColumnSelectionValidator.js +2 -0
  58. package/dist/linker/ColumnSelectionValidator.js.map +1 -0
  59. package/dist/linker/Linker.js +736 -0
  60. package/dist/linker/Linker.js.map +1 -0
  61. package/dist/linker/LinkerLink.css +142 -0
  62. package/dist/linker/LinkerLink.css.map +1 -0
  63. package/dist/linker/LinkerLink.js +314 -0
  64. package/dist/linker/LinkerLink.js.map +1 -0
  65. package/dist/linker/LinkerOverlayContent.css +63 -0
  66. package/dist/linker/LinkerOverlayContent.css.map +1 -0
  67. package/dist/linker/LinkerOverlayContent.js +343 -0
  68. package/dist/linker/LinkerOverlayContent.js.map +1 -0
  69. package/dist/linker/LinkerUtils.js +139 -0
  70. package/dist/linker/LinkerUtils.js.map +1 -0
  71. package/dist/linker/ToolType.js +5 -0
  72. package/dist/linker/ToolType.js.map +1 -0
  73. package/dist/linker/index.js +2 -0
  74. package/dist/linker/index.js.map +1 -0
  75. package/dist/panels/ChartColumnSelectorOverlay.css +11 -0
  76. package/dist/panels/ChartColumnSelectorOverlay.css.map +1 -0
  77. package/dist/panels/ChartColumnSelectorOverlay.js +38 -0
  78. package/dist/panels/ChartColumnSelectorOverlay.js.map +1 -0
  79. package/dist/panels/ChartFilterOverlay.css +22 -0
  80. package/dist/panels/ChartFilterOverlay.css.map +1 -0
  81. package/dist/panels/ChartFilterOverlay.js +90 -0
  82. package/dist/panels/ChartFilterOverlay.js.map +1 -0
  83. package/dist/panels/ChartPanel.css +38 -0
  84. package/dist/panels/ChartPanel.css.map +1 -0
  85. package/dist/panels/ChartPanel.js +971 -0
  86. package/dist/panels/ChartPanel.js.map +1 -0
  87. package/dist/panels/ChartPanelUtils.js +5 -0
  88. package/dist/panels/ChartPanelUtils.js.map +1 -0
  89. package/dist/panels/CommandHistoryPanel.css +19 -0
  90. package/dist/panels/CommandHistoryPanel.css.map +1 -0
  91. package/dist/panels/CommandHistoryPanel.js +195 -0
  92. package/dist/panels/CommandHistoryPanel.js.map +1 -0
  93. package/dist/panels/ConsolePanel.css +19 -0
  94. package/dist/panels/ConsolePanel.css.map +1 -0
  95. package/dist/panels/ConsolePanel.js +365 -0
  96. package/dist/panels/ConsolePanel.js.map +1 -0
  97. package/dist/panels/DropdownFilterPanel.css +6 -0
  98. package/dist/panels/DropdownFilterPanel.css.map +1 -0
  99. package/dist/panels/DropdownFilterPanel.js +685 -0
  100. package/dist/panels/DropdownFilterPanel.js.map +1 -0
  101. package/dist/panels/FileExplorerPanel.css +6 -0
  102. package/dist/panels/FileExplorerPanel.css.map +1 -0
  103. package/dist/panels/FileExplorerPanel.js +252 -0
  104. package/dist/panels/FileExplorerPanel.js.map +1 -0
  105. package/dist/panels/FilterSetManager.css +112 -0
  106. package/dist/panels/FilterSetManager.css.map +1 -0
  107. package/dist/panels/FilterSetManager.js +689 -0
  108. package/dist/panels/FilterSetManager.js.map +1 -0
  109. package/dist/panels/FilterSetManagerPanel.css +34 -0
  110. package/dist/panels/FilterSetManagerPanel.css.map +1 -0
  111. package/dist/panels/FilterSetManagerPanel.js +345 -0
  112. package/dist/panels/FilterSetManagerPanel.js.map +1 -0
  113. package/dist/panels/InputFilterPanel.js +232 -0
  114. package/dist/panels/InputFilterPanel.js.map +1 -0
  115. package/dist/panels/IrisGridPanel.css +24 -0
  116. package/dist/panels/IrisGridPanel.css.map +1 -0
  117. package/dist/panels/IrisGridPanel.js +1018 -0
  118. package/dist/panels/IrisGridPanel.js.map +1 -0
  119. package/dist/panels/IrisGridPanelTooltip.js +39 -0
  120. package/dist/panels/IrisGridPanelTooltip.js.map +1 -0
  121. package/dist/panels/LogPanel.css +15 -0
  122. package/dist/panels/LogPanel.css.map +1 -0
  123. package/dist/panels/LogPanel.js +110 -0
  124. package/dist/panels/LogPanel.js.map +1 -0
  125. package/dist/panels/MarkdownNotebook.css +107 -0
  126. package/dist/panels/MarkdownNotebook.css.map +1 -0
  127. package/dist/panels/MarkdownNotebook.js +232 -0
  128. package/dist/panels/MarkdownNotebook.js.map +1 -0
  129. package/dist/panels/MarkdownPanel.css +90 -0
  130. package/dist/panels/MarkdownPanel.css.map +1 -0
  131. package/dist/panels/MarkdownPanel.js +202 -0
  132. package/dist/panels/MarkdownPanel.js.map +1 -0
  133. package/dist/panels/MockFileStorage.js +70 -0
  134. package/dist/panels/MockFileStorage.js.map +1 -0
  135. package/dist/panels/MockFileStorageTable.js +80 -0
  136. package/dist/panels/MockFileStorageTable.js.map +1 -0
  137. package/dist/panels/NotebookPanel.css +44 -0
  138. package/dist/panels/NotebookPanel.css.map +1 -0
  139. package/dist/panels/NotebookPanel.js +1224 -0
  140. package/dist/panels/NotebookPanel.js.map +1 -0
  141. package/dist/panels/PandasPanel.css +15 -0
  142. package/dist/panels/PandasPanel.css.map +1 -0
  143. package/dist/panels/PandasPanel.js +86 -0
  144. package/dist/panels/PandasPanel.js.map +1 -0
  145. package/dist/panels/Panel.js +314 -0
  146. package/dist/panels/Panel.js.map +1 -0
  147. package/dist/panels/PanelContextMenu.js +126 -0
  148. package/dist/panels/PanelContextMenu.js.map +1 -0
  149. package/dist/panels/RenameDialog.js +156 -0
  150. package/dist/panels/RenameDialog.js.map +1 -0
  151. package/dist/panels/WidgetPanel.css +17 -0
  152. package/dist/panels/WidgetPanel.css.map +1 -0
  153. package/dist/panels/WidgetPanel.js +189 -0
  154. package/dist/panels/WidgetPanel.js.map +1 -0
  155. package/dist/panels/WidgetPanelTooltip.css +40 -0
  156. package/dist/panels/WidgetPanelTooltip.css.map +1 -0
  157. package/dist/panels/WidgetPanelTooltip.js +49 -0
  158. package/dist/panels/WidgetPanelTooltip.js.map +1 -0
  159. package/dist/panels/index.js +22 -0
  160. package/dist/panels/index.js.map +1 -0
  161. package/dist/prop-types/CommonPropTypes.js +9 -0
  162. package/dist/prop-types/CommonPropTypes.js.map +1 -0
  163. package/dist/prop-types/UIPropTypes.js +42 -0
  164. package/dist/prop-types/UIPropTypes.js.map +1 -0
  165. package/dist/prop-types/index.js +3 -0
  166. package/dist/prop-types/index.js.map +1 -0
  167. package/dist/redux/actionTypes.js +3 -0
  168. package/dist/redux/actionTypes.js.map +1 -0
  169. package/dist/redux/actions.js +88 -0
  170. package/dist/redux/actions.js.map +1 -0
  171. package/dist/redux/index.js +10 -0
  172. package/dist/redux/index.js.map +1 -0
  173. package/dist/redux/reducers/connection.js +7 -0
  174. package/dist/redux/reducers/connection.js.map +1 -0
  175. package/dist/redux/reducers/index.js +5 -0
  176. package/dist/redux/reducers/index.js.map +1 -0
  177. package/dist/redux/reducers/sessionWrapper.js +7 -0
  178. package/dist/redux/reducers/sessionWrapper.js.map +1 -0
  179. package/dist/redux/selectors.js +92 -0
  180. package/dist/redux/selectors.js.map +1 -0
  181. 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 */