@deephaven/iris-grid 1.22.1-alpha-pivot-builder.0 → 1.22.2-alpha-pivot-builder.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/AdvancedFilterCreator.js +65 -102
- package/dist/AdvancedFilterCreator.js.map +1 -1
- package/dist/AdvancedFilterCreatorFilterItem.js +22 -37
- package/dist/AdvancedFilterCreatorFilterItem.js.map +1 -1
- package/dist/AdvancedFilterCreatorSelectValue.js +37 -63
- package/dist/AdvancedFilterCreatorSelectValue.js.map +1 -1
- package/dist/AdvancedFilterCreatorSelectValueList.js +29 -59
- package/dist/AdvancedFilterCreatorSelectValueList.js.map +1 -1
- package/dist/ColumnHeaderGroup.js +6 -8
- package/dist/ColumnHeaderGroup.js.map +1 -1
- package/dist/ColumnStatistics.js +22 -28
- package/dist/ColumnStatistics.js.map +1 -1
- package/dist/CrossColumnSearch.js +20 -29
- package/dist/CrossColumnSearch.js.map +1 -1
- package/dist/FilterInputField.js +19 -46
- package/dist/FilterInputField.js.map +1 -1
- package/dist/GotoRow.js +32 -29
- package/dist/GotoRow.js.map +1 -1
- package/dist/IrisGrid.js +490 -822
- package/dist/IrisGrid.js.map +1 -1
- package/dist/IrisGridBottomBar.js +10 -11
- package/dist/IrisGridBottomBar.js.map +1 -1
- package/dist/IrisGridCacheUtils.js +28 -8
- package/dist/IrisGridCacheUtils.js.map +1 -1
- package/dist/IrisGridCellOverflowModal.js +30 -13
- package/dist/IrisGridCellOverflowModal.js.map +1 -1
- package/dist/IrisGridCellRendererUtils.js +6 -12
- package/dist/IrisGridCellRendererUtils.js.map +1 -1
- package/dist/IrisGridCopyHandler.js +28 -47
- package/dist/IrisGridCopyHandler.js.map +1 -1
- package/dist/IrisGridMetricCalculator.js +28 -51
- package/dist/IrisGridMetricCalculator.js.map +1 -1
- package/dist/IrisGridModelUpdater.js +32 -30
- package/dist/IrisGridModelUpdater.js.map +1 -1
- package/dist/IrisGridPartitionSelector.js +28 -62
- package/dist/IrisGridPartitionSelector.js.map +1 -1
- package/dist/IrisGridProxyModel.js +7 -12
- package/dist/IrisGridProxyModel.js.map +1 -1
- package/dist/IrisGridRenderer.js +162 -264
- package/dist/IrisGridRenderer.js.map +1 -1
- package/dist/IrisGridTableModel.js +23 -16
- package/dist/IrisGridTableModel.js.map +1 -1
- package/dist/IrisGridTableModelTemplate.js +49 -73
- package/dist/IrisGridTableModelTemplate.js.map +1 -1
- package/dist/IrisGridTestUtils.js +19 -19
- package/dist/IrisGridTestUtils.js.map +1 -1
- package/dist/IrisGridTextCellRenderer.js +35 -52
- package/dist/IrisGridTextCellRenderer.js.map +1 -1
- package/dist/IrisGridTheme.js +9 -1
- package/dist/IrisGridTheme.js.map +1 -1
- package/dist/IrisGridThemeProvider.js +5 -7
- package/dist/IrisGridThemeProvider.js.map +1 -1
- package/dist/IrisGridTreeTableModel.js +5 -9
- package/dist/IrisGridTreeTableModel.js.map +1 -1
- package/dist/IrisGridUtils.js +246 -300
- package/dist/IrisGridUtils.js.map +1 -1
- package/dist/NoPastePermissionModal.js +3 -5
- package/dist/NoPastePermissionModal.js.map +1 -1
- package/dist/PendingDataBottomBar.js +27 -16
- package/dist/PendingDataBottomBar.js.map +1 -1
- package/dist/ToastBottomBar.js +16 -8
- package/dist/ToastBottomBar.js.map +1 -1
- package/dist/format-context-menus/CustomFormatAction.js +11 -24
- package/dist/format-context-menus/CustomFormatAction.js.map +1 -1
- package/dist/key-handlers/CopyCellKeyHandler.js +3 -4
- package/dist/key-handlers/CopyCellKeyHandler.js.map +1 -1
- package/dist/key-handlers/CopyKeyHandler.js +1 -3
- package/dist/key-handlers/CopyKeyHandler.js.map +1 -1
- package/dist/key-handlers/ReverseKeyHandler.js +1 -3
- package/dist/key-handlers/ReverseKeyHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridCellOverflowMouseHandler.js +35 -59
- package/dist/mousehandlers/IrisGridCellOverflowMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridColumnSelectMouseHandler.js +13 -29
- package/dist/mousehandlers/IrisGridColumnSelectMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridColumnTooltipMouseHandler.js +8 -17
- package/dist/mousehandlers/IrisGridColumnTooltipMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridContextMenuHandler.js +96 -199
- package/dist/mousehandlers/IrisGridContextMenuHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridDataSelectMouseHandler.js +2 -4
- package/dist/mousehandlers/IrisGridDataSelectMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridFilterMouseHandler.js +16 -30
- package/dist/mousehandlers/IrisGridFilterMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridPartitionedTableMouseHandler.js +5 -13
- package/dist/mousehandlers/IrisGridPartitionedTableMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridRowTreeMouseHandler.js +20 -36
- package/dist/mousehandlers/IrisGridRowTreeMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridSortMouseHandler.js +3 -5
- package/dist/mousehandlers/IrisGridSortMouseHandler.js.map +1 -1
- package/dist/mousehandlers/IrisGridTokenMouseHandler.js +9 -18
- package/dist/mousehandlers/IrisGridTokenMouseHandler.js.map +1 -1
- package/dist/mousehandlers/PendingMouseHandler.js +10 -18
- package/dist/mousehandlers/PendingMouseHandler.js.map +1 -1
- package/dist/sidebar/AdvancedSettingsMenu.js +12 -5
- package/dist/sidebar/AdvancedSettingsMenu.js.map +1 -1
- package/dist/sidebar/ChartBuilder.js +45 -102
- package/dist/sidebar/ChartBuilder.js.map +1 -1
- package/dist/sidebar/CustomColumnBuilder.js +35 -77
- package/dist/sidebar/CustomColumnBuilder.js.map +1 -1
- package/dist/sidebar/CustomColumnInput.js +9 -11
- package/dist/sidebar/CustomColumnInput.js.map +1 -1
- package/dist/sidebar/InputEditor.js +17 -24
- package/dist/sidebar/InputEditor.js.map +1 -1
- package/dist/sidebar/PluginTableOptionsErrorBoundary.js +6 -11
- package/dist/sidebar/PluginTableOptionsErrorBoundary.js.map +1 -1
- package/dist/sidebar/RollupRows.js +72 -113
- package/dist/sidebar/RollupRows.js.map +1 -1
- package/dist/sidebar/SelectDistinctBuilder.js +16 -33
- package/dist/sidebar/SelectDistinctBuilder.js.map +1 -1
- package/dist/sidebar/TableCsvExporter.js +50 -74
- package/dist/sidebar/TableCsvExporter.js.map +1 -1
- package/dist/sidebar/TableSaver.js +18 -42
- package/dist/sidebar/TableSaver.js.map +1 -1
- package/dist/sidebar/aggregations/AggregationEdit.js +25 -18
- package/dist/sidebar/aggregations/AggregationEdit.js.map +1 -1
- package/dist/sidebar/aggregations/AggregationUtils.d.ts.map +1 -1
- package/dist/sidebar/aggregations/AggregationUtils.js +3 -4
- package/dist/sidebar/aggregations/AggregationUtils.js.map +1 -1
- package/dist/sidebar/aggregations/Aggregations.js +45 -34
- package/dist/sidebar/aggregations/Aggregations.js.map +1 -1
- package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js +35 -24
- package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js.map +1 -1
- package/dist/sidebar/conditional-formatting/ConditionEditor.js +38 -21
- package/dist/sidebar/conditional-formatting/ConditionEditor.js.map +1 -1
- package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js +27 -11
- package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js.map +1 -1
- package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js +9 -11
- package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js.map +1 -1
- package/dist/sidebar/conditional-formatting/ConditionalFormattingUtils.js +48 -57
- package/dist/sidebar/conditional-formatting/ConditionalFormattingUtils.js.map +1 -1
- package/dist/sidebar/conditional-formatting/RowFormatEditor.js +35 -24
- package/dist/sidebar/conditional-formatting/RowFormatEditor.js.map +1 -1
- package/dist/sidebar/conditional-formatting/StyleEditor.js +26 -11
- package/dist/sidebar/conditional-formatting/StyleEditor.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/SearchItem.js +5 -7
- package/dist/sidebar/visibility-ordering-builder/SearchItem.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/SearchWithModal.js +24 -18
- package/dist/sidebar/visibility-ordering-builder/SearchWithModal.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js +166 -256
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.js +4 -11
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js +28 -14
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js +16 -19
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/PointerSensorWithInteraction.js +1 -3
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/PointerSensorWithInteraction.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js +19 -29
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeDndContext.js +39 -52
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeDndContext.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js +18 -23
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js +19 -15
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.js +16 -30
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.js.map +1 -1
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/utilities.js +30 -39
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/utilities.js.map +1 -1
- package/package.json +16 -16
|
@@ -23,11 +23,9 @@ var GROUPED_LIST_ID = 'grouped-rollup-rows';
|
|
|
23
23
|
var UNGROUPED_LIST_ID = 'ungrouped-rollup-rows';
|
|
24
24
|
class RollupRows extends Component {
|
|
25
25
|
static renderColumn(_ref) {
|
|
26
|
-
var
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
selectedCount
|
|
30
|
-
} = _ref;
|
|
26
|
+
var item = _ref.item,
|
|
27
|
+
isClone = _ref.isClone,
|
|
28
|
+
selectedCount = _ref.selectedCount;
|
|
31
29
|
var text = item === null || item === void 0 ? void 0 : item.name;
|
|
32
30
|
var badgeText = isClone !== undefined && isClone ? "".concat(selectedCount) : undefined;
|
|
33
31
|
var className = isClone !== undefined && isClone ? 'item-list-item-clone' : '';
|
|
@@ -103,14 +101,14 @@ class RollupRows extends Component {
|
|
|
103
101
|
this.renderGroupedItem = this.renderGroupedItem.bind(this);
|
|
104
102
|
this.ungroupedList = /*#__PURE__*/React.createRef();
|
|
105
103
|
this.groupedList = /*#__PURE__*/React.createRef();
|
|
106
|
-
var
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
showConstituents = true,
|
|
112
|
-
|
|
113
|
-
|
|
104
|
+
var config = props.config;
|
|
105
|
+
var _ref2 = config !== null && config !== void 0 ? config : {},
|
|
106
|
+
_ref2$columns = _ref2.columns,
|
|
107
|
+
_columns = _ref2$columns === void 0 ? [] : _ref2$columns,
|
|
108
|
+
_ref2$showConstituent = _ref2.showConstituents,
|
|
109
|
+
showConstituents = _ref2$showConstituent === void 0 ? true : _ref2$showConstituent,
|
|
110
|
+
_ref2$showNonAggregat = _ref2.showNonAggregatedColumns,
|
|
111
|
+
showNonAggregatedColumns = _ref2$showNonAggregat === void 0 ? true : _ref2$showNonAggregat;
|
|
114
112
|
this.state = {
|
|
115
113
|
ungroupedSelectedRanges: [],
|
|
116
114
|
columns: _columns,
|
|
@@ -123,14 +121,11 @@ class RollupRows extends Component {
|
|
|
123
121
|
};
|
|
124
122
|
}
|
|
125
123
|
componentDidUpdate(prevProps, prevState) {
|
|
126
|
-
var
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
showConstituents,
|
|
132
|
-
showNonAggregatedColumns
|
|
133
|
-
} = this.state;
|
|
124
|
+
var config = this.props.config;
|
|
125
|
+
var _this$state = this.state,
|
|
126
|
+
columns = _this$state.columns,
|
|
127
|
+
showConstituents = _this$state.showConstituents,
|
|
128
|
+
showNonAggregatedColumns = _this$state.showNonAggregatedColumns;
|
|
134
129
|
if (config !== prevProps.config) {
|
|
135
130
|
this.updateFromConfig();
|
|
136
131
|
} else if (columns !== prevState.columns || showConstituents !== prevState.showConstituents || showNonAggregatedColumns !== prevState.showNonAggregatedColumns) {
|
|
@@ -155,20 +150,16 @@ class RollupRows extends Component {
|
|
|
155
150
|
this.search(searchFilter);
|
|
156
151
|
}
|
|
157
152
|
handleSortAscending() {
|
|
158
|
-
this.setState(
|
|
159
|
-
var
|
|
160
|
-
sort
|
|
161
|
-
} = _ref2;
|
|
153
|
+
this.setState(_ref3 => {
|
|
154
|
+
var sort = _ref3.sort;
|
|
162
155
|
return {
|
|
163
156
|
sort: sort === RollupRows.SORT.ASCENDING ? null : RollupRows.SORT.ASCENDING
|
|
164
157
|
};
|
|
165
158
|
});
|
|
166
159
|
}
|
|
167
160
|
handleSortDescending() {
|
|
168
|
-
this.setState(
|
|
169
|
-
var
|
|
170
|
-
sort
|
|
171
|
-
} = _ref3;
|
|
161
|
+
this.setState(_ref4 => {
|
|
162
|
+
var sort = _ref4.sort;
|
|
172
163
|
return {
|
|
173
164
|
sort: sort === RollupRows.SORT.DESCENDING ? null : RollupRows.SORT.DESCENDING
|
|
174
165
|
};
|
|
@@ -193,10 +184,8 @@ class RollupRows extends Component {
|
|
|
193
184
|
this.setState({
|
|
194
185
|
dragSource: null
|
|
195
186
|
});
|
|
196
|
-
var
|
|
197
|
-
|
|
198
|
-
source
|
|
199
|
-
} = e;
|
|
187
|
+
var destination = e.destination,
|
|
188
|
+
source = e.source;
|
|
200
189
|
if (destination == null || source == null) {
|
|
201
190
|
return;
|
|
202
191
|
}
|
|
@@ -204,11 +193,9 @@ class RollupRows extends Component {
|
|
|
204
193
|
// We don't allow dragging within the ungrouped list, so if we're dragging into the ungrouped list,
|
|
205
194
|
// it must have came from the grouped list. Remove those grouped columns.
|
|
206
195
|
if (destination.droppableId === UNGROUPED_LIST_ID) {
|
|
207
|
-
this.setState(
|
|
208
|
-
var
|
|
209
|
-
|
|
210
|
-
columns
|
|
211
|
-
} = _ref4;
|
|
196
|
+
this.setState(_ref5 => {
|
|
197
|
+
var groupedSelectedRanges = _ref5.groupedSelectedRanges,
|
|
198
|
+
columns = _ref5.columns;
|
|
212
199
|
var newColumns = [...columns];
|
|
213
200
|
DragUtils.reorder(newColumns, groupedSelectedRanges, [], 0);
|
|
214
201
|
return {
|
|
@@ -229,12 +216,10 @@ class RollupRows extends Component {
|
|
|
229
216
|
// we adjust the index based on all the selected ranges, not just the source.index.
|
|
230
217
|
destinationIndex += 1;
|
|
231
218
|
}
|
|
232
|
-
this.setState(
|
|
233
|
-
var
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
groupedSelectedRanges
|
|
237
|
-
} = _ref5;
|
|
219
|
+
this.setState(_ref6 => {
|
|
220
|
+
var columns = _ref6.columns,
|
|
221
|
+
ungroupedSelectedRanges = _ref6.ungroupedSelectedRanges,
|
|
222
|
+
groupedSelectedRanges = _ref6.groupedSelectedRanges;
|
|
238
223
|
var newColumns = [...columns];
|
|
239
224
|
var sourceItems = isSameList ? newColumns : this.getSortedUngroupedColumns().map(c => c.name);
|
|
240
225
|
var sourceRanges = isSameList ? groupedSelectedRanges : ungroupedSelectedRanges;
|
|
@@ -253,10 +238,8 @@ class RollupRows extends Component {
|
|
|
253
238
|
}
|
|
254
239
|
handleUngroupedSelect(itemIndex) {
|
|
255
240
|
log.debug('handleUngroupedSelect');
|
|
256
|
-
this.setState(
|
|
257
|
-
var
|
|
258
|
-
columns
|
|
259
|
-
} = _ref6;
|
|
241
|
+
this.setState(_ref7 => {
|
|
242
|
+
var columns = _ref7.columns;
|
|
260
243
|
return {
|
|
261
244
|
columns: RollupRows.addGroupings(columns, [this.getSortedUngroupedColumns()[itemIndex].name]),
|
|
262
245
|
ungroupedSelectedRanges: [],
|
|
@@ -266,10 +249,8 @@ class RollupRows extends Component {
|
|
|
266
249
|
}
|
|
267
250
|
handleUngroupedSelectionChange(ungroupedSelectedRanges) {
|
|
268
251
|
log.debug2('handleUngroupedSelectionChange', ungroupedSelectedRanges);
|
|
269
|
-
this.setState(
|
|
270
|
-
var
|
|
271
|
-
ungroupedSelectedRanges: stateUngroupedSelectedRanges
|
|
272
|
-
} = _ref7;
|
|
252
|
+
this.setState(_ref8 => {
|
|
253
|
+
var stateUngroupedSelectedRanges = _ref8.ungroupedSelectedRanges;
|
|
273
254
|
if (ungroupedSelectedRanges === stateUngroupedSelectedRanges) {
|
|
274
255
|
return null;
|
|
275
256
|
}
|
|
@@ -281,10 +262,8 @@ class RollupRows extends Component {
|
|
|
281
262
|
}
|
|
282
263
|
handleGroupedSelectionChange(groupedSelectedRanges) {
|
|
283
264
|
log.debug2('handleGroupedSelectedRanges', groupedSelectedRanges);
|
|
284
|
-
this.setState(
|
|
285
|
-
var
|
|
286
|
-
groupedSelectedRanges: stateGroupedSelectedRanges
|
|
287
|
-
} = _ref8;
|
|
265
|
+
this.setState(_ref9 => {
|
|
266
|
+
var stateGroupedSelectedRanges = _ref9.groupedSelectedRanges;
|
|
288
267
|
if (groupedSelectedRanges === stateGroupedSelectedRanges) {
|
|
289
268
|
return null;
|
|
290
269
|
}
|
|
@@ -295,10 +274,8 @@ class RollupRows extends Component {
|
|
|
295
274
|
});
|
|
296
275
|
}
|
|
297
276
|
handleDeleteClicked(index) {
|
|
298
|
-
this.setState(
|
|
299
|
-
var
|
|
300
|
-
columns
|
|
301
|
-
} = _ref9;
|
|
277
|
+
this.setState(_ref0 => {
|
|
278
|
+
var columns = _ref0.columns;
|
|
302
279
|
var newColumns = columns.slice();
|
|
303
280
|
newColumns.splice(index, 1);
|
|
304
281
|
return {
|
|
@@ -307,34 +284,30 @@ class RollupRows extends Component {
|
|
|
307
284
|
});
|
|
308
285
|
}
|
|
309
286
|
handleShowConstituentsChange() {
|
|
310
|
-
this.setState(
|
|
311
|
-
var
|
|
312
|
-
showConstituents
|
|
313
|
-
} = _ref0;
|
|
287
|
+
this.setState(_ref1 => {
|
|
288
|
+
var showConstituents = _ref1.showConstituents;
|
|
314
289
|
return {
|
|
315
290
|
showConstituents: !showConstituents
|
|
316
291
|
};
|
|
317
292
|
});
|
|
318
293
|
}
|
|
319
294
|
handleShowNonAggregatedColumnsChange() {
|
|
320
|
-
this.setState(
|
|
321
|
-
var
|
|
322
|
-
showNonAggregatedColumns
|
|
323
|
-
} = _ref1;
|
|
295
|
+
this.setState(_ref10 => {
|
|
296
|
+
var showNonAggregatedColumns = _ref10.showNonAggregatedColumns;
|
|
324
297
|
return {
|
|
325
298
|
showNonAggregatedColumns: !showNonAggregatedColumns
|
|
326
299
|
};
|
|
327
300
|
});
|
|
328
301
|
}
|
|
329
302
|
updateFromConfig() {
|
|
330
|
-
var
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
showConstituents = true,
|
|
336
|
-
|
|
337
|
-
|
|
303
|
+
var config = this.props.config;
|
|
304
|
+
var _ref11 = config !== null && config !== void 0 ? config : {},
|
|
305
|
+
_ref11$columns = _ref11.columns,
|
|
306
|
+
columns = _ref11$columns === void 0 ? [] : _ref11$columns,
|
|
307
|
+
_ref11$showConstituen = _ref11.showConstituents,
|
|
308
|
+
showConstituents = _ref11$showConstituen === void 0 ? true : _ref11$showConstituen,
|
|
309
|
+
_ref11$showNonAggrega = _ref11.showNonAggregatedColumns,
|
|
310
|
+
showNonAggregatedColumns = _ref11$showNonAggrega === void 0 ? true : _ref11$showNonAggrega;
|
|
338
311
|
this.setState({
|
|
339
312
|
columns,
|
|
340
313
|
showConstituents,
|
|
@@ -342,14 +315,11 @@ class RollupRows extends Component {
|
|
|
342
315
|
});
|
|
343
316
|
}
|
|
344
317
|
sendChange() {
|
|
345
|
-
var
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
showConstituents,
|
|
351
|
-
showNonAggregatedColumns
|
|
352
|
-
} = this.state;
|
|
318
|
+
var onChange = this.props.onChange;
|
|
319
|
+
var _this$state2 = this.state,
|
|
320
|
+
columns = _this$state2.columns,
|
|
321
|
+
showConstituents = _this$state2.showConstituents,
|
|
322
|
+
showNonAggregatedColumns = _this$state2.showNonAggregatedColumns;
|
|
353
323
|
onChange({
|
|
354
324
|
columns,
|
|
355
325
|
showConstituents,
|
|
@@ -357,31 +327,21 @@ class RollupRows extends Component {
|
|
|
357
327
|
});
|
|
358
328
|
}
|
|
359
329
|
getUngroupedColumns() {
|
|
360
|
-
var
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
var {
|
|
364
|
-
columns
|
|
365
|
-
} = this.state;
|
|
366
|
-
var {
|
|
367
|
-
originalColumns
|
|
368
|
-
} = model;
|
|
330
|
+
var model = this.props.model;
|
|
331
|
+
var columns = this.state.columns;
|
|
332
|
+
var originalColumns = model.originalColumns;
|
|
369
333
|
return this.getCachedUngroupedColumns(originalColumns, columns);
|
|
370
334
|
}
|
|
371
335
|
getSortedUngroupedColumns() {
|
|
372
|
-
var
|
|
373
|
-
sort
|
|
374
|
-
} = this.state;
|
|
336
|
+
var sort = this.state.sort;
|
|
375
337
|
var columns = this.getUngroupedColumns();
|
|
376
338
|
return this.getCachedSortedColumns(columns, sort);
|
|
377
339
|
}
|
|
378
|
-
renderGroupedItem(
|
|
379
|
-
var
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
selectedCount
|
|
384
|
-
} = _ref10;
|
|
340
|
+
renderGroupedItem(_ref12) {
|
|
341
|
+
var item = _ref12.item,
|
|
342
|
+
itemIndex = _ref12.itemIndex,
|
|
343
|
+
isClone = _ref12.isClone,
|
|
344
|
+
selectedCount = _ref12.selectedCount;
|
|
385
345
|
var indent = isClone !== undefined && isClone ? '' : '\u00A0\u00A0'.repeat(itemIndex);
|
|
386
346
|
var text = "".concat(indent).concat(item);
|
|
387
347
|
var badgeText = isClone !== undefined && isClone ? "".concat(selectedCount) : undefined;
|
|
@@ -402,16 +362,15 @@ class RollupRows extends Component {
|
|
|
402
362
|
});
|
|
403
363
|
}
|
|
404
364
|
render() {
|
|
405
|
-
var
|
|
406
|
-
columns,
|
|
407
|
-
dragSource,
|
|
408
|
-
searchFilter,
|
|
409
|
-
groupedSelectedRanges,
|
|
410
|
-
ungroupedSelectedRanges,
|
|
411
|
-
showConstituents,
|
|
412
|
-
showNonAggregatedColumns,
|
|
413
|
-
sort
|
|
414
|
-
} = this.state;
|
|
365
|
+
var _this$state3 = this.state,
|
|
366
|
+
columns = _this$state3.columns,
|
|
367
|
+
dragSource = _this$state3.dragSource,
|
|
368
|
+
searchFilter = _this$state3.searchFilter,
|
|
369
|
+
groupedSelectedRanges = _this$state3.groupedSelectedRanges,
|
|
370
|
+
ungroupedSelectedRanges = _this$state3.ungroupedSelectedRanges,
|
|
371
|
+
showConstituents = _this$state3.showConstituents,
|
|
372
|
+
showNonAggregatedColumns = _this$state3.showNonAggregatedColumns,
|
|
373
|
+
sort = _this$state3.sort;
|
|
415
374
|
var ungroupedColumns = this.getSortedUngroupedColumns();
|
|
416
375
|
var groupListHeight = columns.length * DraggableItemList.DEFAULT_ROW_HEIGHT;
|
|
417
376
|
var ungroupMaxListHeight = ungroupedColumns.length * DraggableItemList.DEFAULT_ROW_HEIGHT + 10;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RollupRows.js","names":["React","Component","classNames","FontAwesomeIcon","DragDropContext","Droppable","Checkbox","DraggableItemList","DragUtils","SearchInput","Tooltip","Button","vsTrash","dhSortAlphaDown","dhSortAlphaUp","TableUtils","memoize","debounce","Log","assertNotNull","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","log","module","DEBOUNCE_SEARCH","GROUPED_LIST_ID","UNGROUPED_LIST_ID","RollupRows","renderColumn","_ref","item","isClone","selectedCount","text","name","badgeText","undefined","concat","className","renderTextItem","addGroupings","currentGroupings","newGroupings","index","arguments","length","insertIndex","groupings","filter","grouping","i","includes","splice","isGroupable","column","isBigDecimalType","type","isBigIntegerType","constructor","props","_defineProperty","searchFilter","columns","getSortedUngroupedColumns","selectedRanges","focusIndex","toLowerCase","push","setState","ungroupedSelectedRanges","ungroupedList","current","scrollToItem","groupedColumns","find","max","sort","sortColumns","SORT","ASCENDING","handleDeleteClicked","bind","handleSearchChange","handleUngroupedSelect","handleUngroupedSelectionChange","handleDragStart","handleDragEnd","handleGroupedSelectionChange","handleShowConstituentsChange","handleShowNonAggregatedColumnsChange","handleSortAscending","handleSortDescending","renderGroupedItem","createRef","groupedList","config","showConstituents","showNonAggregatedColumns","state","groupedSelectedRanges","dragSource","componentDidUpdate","prevProps","prevState","updateFromConfig","sendChange","componentWillUnmount","search","cancel","event","target","value","resetSelection","_ref2","_ref3","DESCENDING","e","debug","document","documentElement","classList","add","source","remove","destination","droppableId","_ref4","newColumns","reorder","isSameList","destinationIndex","_ref5","sourceItems","map","c","sourceRanges","draggedItems","adjustDestinationIndex","newSelectedRanges","itemIndex","_ref6","debug2","_ref7","stateUngroupedSelectedRanges","_ref8","stateGroupedSelectedRanges","_ref9","slice","_ref0","_ref1","onChange","getUngroupedColumns","model","originalColumns","getCachedUngroupedColumns","getCachedSortedColumns","_ref10","indent","repeat","children","kind","onClick","icon","render","ungroupedColumns","groupListHeight","DEFAULT_ROW_HEIGHT","ungroupMaxListHeight","ungroupMinListHeight","Math","min","role","tabIndex","onDragEnd","onDragStart","provided","snapshot","_objectSpread","draggingFromThisWith","isDraggingOver","draggingOverWith","ref","innerRef","droppableProps","draggingItemClassName","draggablePrefix","itemCount","items","offset","onSelectionChange","renderItem","style","isMultiSelect","hasPlaceholder","matchCount","placeholder","active","onSelect","maxHeight","minHeight","isDropDisabled","checked","Object","freeze"],"sources":["../../src/sidebar/RollupRows.tsx"],"sourcesContent":["/* eslint-disable jsx-a11y/click-events-have-key-events */\nimport React, {\n type ChangeEvent,\n Component,\n type ReactElement,\n type RefObject,\n} from 'react';\nimport classNames from 'classnames';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport {\n DragDropContext,\n type DraggableLocation,\n type DragStart,\n Droppable,\n type DropResult,\n} from '@hello-pangea/dnd';\nimport {\n Checkbox,\n DraggableItemList,\n DragUtils,\n SearchInput,\n Tooltip,\n type Range,\n type RenderItemProps,\n Button,\n} from '@deephaven/components';\nimport { vsTrash, dhSortAlphaDown, dhSortAlphaUp } from '@deephaven/icons';\nimport { TableUtils, type SortDirection } from '@deephaven/jsapi-utils';\nimport memoize from 'memoizee';\nimport debounce from 'lodash.debounce';\nimport Log from '@deephaven/log';\nimport { assertNotNull } from '@deephaven/utils';\nimport './RollupRows.scss';\nimport type { dh } from '@deephaven/jsapi-types';\nimport type IrisGridModel from '../IrisGridModel';\nimport { type ColumnName } from '../CommonTypes';\n\nconst log = Log.module('RollupRows');\nconst DEBOUNCE_SEARCH = 150;\nconst GROUPED_LIST_ID = 'grouped-rollup-rows';\nconst UNGROUPED_LIST_ID = 'ungrouped-rollup-rows';\n\nexport interface UIRollupConfig {\n columns: ColumnName[];\n showConstituents: boolean;\n showNonAggregatedColumns: boolean;\n includeDescriptions: true;\n}\n\ninterface RollupRowsProps {\n model: IrisGridModel;\n onChange: (rollupConfig: UIRollupConfig) => void;\n config: UIRollupConfig | null;\n}\n\ninterface RollupRowsState {\n ungroupedSelectedRanges: readonly Range[];\n columns: ColumnName[];\n groupedSelectedRanges: readonly Range[];\n searchFilter: string;\n showConstituents: boolean;\n showNonAggregatedColumns: boolean;\n dragSource: DraggableLocation | null;\n sort: SortDirection;\n}\n\nclass RollupRows extends Component<RollupRowsProps, RollupRowsState> {\n static SORT = Object.freeze({\n ASCENDING: 'ASC',\n DESCENDING: 'DESC',\n });\n\n static defaultProps = {\n config: null,\n onChange: (): void => undefined,\n };\n\n static renderColumn({\n item,\n isClone,\n selectedCount,\n }: RenderItemProps<dh.Column> & {\n isClone?: boolean;\n selectedCount?: number;\n }): ReactElement {\n const text = item?.name;\n const badgeText =\n isClone !== undefined && isClone ? `${selectedCount}` : undefined;\n const className =\n isClone !== undefined && isClone ? 'item-list-item-clone' : '';\n return DraggableItemList.renderTextItem({ text, badgeText, className });\n }\n\n static addGroupings(\n currentGroupings: string[],\n newGroupings: string[],\n index: number = currentGroupings.length\n ): string[] {\n if (newGroupings == null || newGroupings.length === 0) {\n return currentGroupings;\n }\n\n let insertIndex = index;\n const groupings = currentGroupings.filter((grouping, i) => {\n if (newGroupings.includes(grouping)) {\n if (i < insertIndex) {\n insertIndex -= 1;\n }\n return false;\n }\n return true;\n });\n groupings.splice(insertIndex, 0, ...newGroupings);\n return groupings;\n }\n\n static isGroupable(column: dh.Column): boolean {\n return (\n !TableUtils.isBigDecimalType(column.type) &&\n !TableUtils.isBigIntegerType(column.type)\n );\n }\n\n constructor(props: RollupRowsProps) {\n super(props);\n\n this.handleDeleteClicked = this.handleDeleteClicked.bind(this);\n this.handleSearchChange = this.handleSearchChange.bind(this);\n this.handleUngroupedSelect = this.handleUngroupedSelect.bind(this);\n this.handleUngroupedSelectionChange =\n this.handleUngroupedSelectionChange.bind(this);\n this.handleDragStart = this.handleDragStart.bind(this);\n this.handleDragEnd = this.handleDragEnd.bind(this);\n this.handleGroupedSelectionChange =\n this.handleGroupedSelectionChange.bind(this);\n this.handleShowConstituentsChange =\n this.handleShowConstituentsChange.bind(this);\n this.handleShowNonAggregatedColumnsChange =\n this.handleShowNonAggregatedColumnsChange.bind(this);\n this.handleSortAscending = this.handleSortAscending.bind(this);\n this.handleSortDescending = this.handleSortDescending.bind(this);\n this.renderGroupedItem = this.renderGroupedItem.bind(this);\n\n this.ungroupedList = React.createRef();\n this.groupedList = React.createRef();\n\n const { config } = props;\n const {\n columns = [],\n showConstituents = true,\n showNonAggregatedColumns = true,\n } = config ?? {};\n\n this.state = {\n ungroupedSelectedRanges: [],\n columns,\n groupedSelectedRanges: [],\n searchFilter: '',\n showConstituents,\n showNonAggregatedColumns,\n dragSource: null,\n sort: null,\n };\n }\n\n componentDidUpdate(\n prevProps: RollupRowsProps,\n prevState: RollupRowsState\n ): void {\n const { config } = this.props;\n const { columns, showConstituents, showNonAggregatedColumns } = this.state;\n if (config !== prevProps.config) {\n this.updateFromConfig();\n } else if (\n columns !== prevState.columns ||\n showConstituents !== prevState.showConstituents ||\n showNonAggregatedColumns !== prevState.showNonAggregatedColumns\n ) {\n if (\n config == null ||\n columns !== config.columns ||\n showConstituents !== config.showConstituents ||\n showNonAggregatedColumns !== config.showNonAggregatedColumns\n ) {\n this.sendChange();\n }\n }\n }\n\n componentWillUnmount(): void {\n this.search.cancel();\n }\n\n ungroupedList: RefObject<DraggableItemList<dh.Column>>;\n\n groupedList: RefObject<DraggableItemList<string>>;\n\n handleSearchChange(event: ChangeEvent<HTMLInputElement>): void {\n const searchFilter = event.target.value;\n this.setState({ searchFilter });\n if (!searchFilter) {\n this.search.cancel();\n this.resetSelection();\n return;\n }\n this.search(searchFilter);\n }\n\n handleSortAscending(): void {\n this.setState(({ sort }) => ({\n sort:\n sort === RollupRows.SORT.ASCENDING ? null : RollupRows.SORT.ASCENDING,\n }));\n }\n\n handleSortDescending(): void {\n this.setState(({ sort }) => ({\n sort:\n sort === RollupRows.SORT.DESCENDING ? null : RollupRows.SORT.DESCENDING,\n }));\n }\n\n resetSelection(): void {\n this.setState({ ungroupedSelectedRanges: [], groupedSelectedRanges: [] });\n }\n\n search = debounce((searchFilter: string) => {\n const columns = this.getSortedUngroupedColumns();\n const selectedRanges = [] as Range[];\n let focusIndex = null;\n for (let i = 0; i < columns.length; i += 1) {\n const column = columns[i];\n if (column.name.toLowerCase().includes(searchFilter.toLowerCase())) {\n if (focusIndex == null) {\n focusIndex = i;\n }\n selectedRanges.push([i, i]);\n }\n }\n assertNotNull(focusIndex);\n this.setState({ ungroupedSelectedRanges: selectedRanges });\n\n if (selectedRanges.length > 0 && this.ungroupedList.current) {\n this.ungroupedList.current.scrollToItem(focusIndex);\n }\n }, DEBOUNCE_SEARCH);\n\n handleDragStart(e: DragStart): void {\n log.debug('handleDragStart', e);\n\n document.documentElement.classList.add('drag-pointer-events-none');\n\n this.setState({ dragSource: e.source });\n }\n\n handleDragEnd(e: DropResult): void {\n log.debug('handleDragEnd', e);\n\n document.documentElement.classList.remove('drag-pointer-events-none');\n\n this.setState({ dragSource: null });\n\n const { destination, source } = e;\n if (destination == null || source == null) {\n return;\n }\n\n // We don't allow dragging within the ungrouped list, so if we're dragging into the ungrouped list,\n // it must have came from the grouped list. Remove those grouped columns.\n if (destination.droppableId === UNGROUPED_LIST_ID) {\n this.setState(({ groupedSelectedRanges, columns }) => {\n const newColumns = [...columns];\n DragUtils.reorder(newColumns, groupedSelectedRanges, [], 0);\n return {\n columns: newColumns,\n ungroupedSelectedRanges: [],\n groupedSelectedRanges: [],\n };\n });\n return;\n }\n\n // Otherwise, it must be dropping into the grouped list, so we just need to check the source\n const isSameList = source.droppableId === GROUPED_LIST_ID;\n let destinationIndex = destination.index;\n if (isSameList && source.index < destination.index) {\n // @hello-pangea/dnd adjusts the index when dragging within a list already, however that only supports single selection\n // We need to change it back to the index we actually want it to drop at before adjusting for the removed source index, as\n // we adjust the index based on all the selected ranges, not just the source.index.\n destinationIndex += 1;\n }\n this.setState(\n ({ columns, ungroupedSelectedRanges, groupedSelectedRanges }) => {\n const newColumns = [...columns];\n const sourceItems = isSameList\n ? newColumns\n : this.getSortedUngroupedColumns().map(c => c.name);\n const sourceRanges = isSameList\n ? groupedSelectedRanges\n : ungroupedSelectedRanges;\n const draggedItems = DragUtils.reorder(\n sourceItems,\n sourceRanges,\n newColumns,\n destinationIndex\n );\n\n // Select the newly dropped items\n const insertIndex = isSameList\n ? DragUtils.adjustDestinationIndex(\n destinationIndex,\n groupedSelectedRanges\n )\n : destinationIndex;\n const newSelectedRanges = [\n [insertIndex, insertIndex + draggedItems.length - 1] as Range,\n ];\n return {\n columns: newColumns,\n ungroupedSelectedRanges: [] as Range[],\n groupedSelectedRanges: newSelectedRanges,\n };\n }\n );\n this.resetSelection();\n }\n\n handleUngroupedSelect(itemIndex: number): void {\n log.debug('handleUngroupedSelect');\n\n this.setState(({ columns }) => ({\n columns: RollupRows.addGroupings(columns, [\n this.getSortedUngroupedColumns()[itemIndex].name,\n ]),\n ungroupedSelectedRanges: [],\n groupedSelectedRanges: [],\n }));\n }\n\n handleUngroupedSelectionChange(\n ungroupedSelectedRanges: readonly Range[]\n ): void {\n log.debug2('handleUngroupedSelectionChange', ungroupedSelectedRanges);\n this.setState(\n ({ ungroupedSelectedRanges: stateUngroupedSelectedRanges }) => {\n if (ungroupedSelectedRanges === stateUngroupedSelectedRanges) {\n return null;\n }\n\n return { ungroupedSelectedRanges, groupedSelectedRanges: [] };\n }\n );\n }\n\n handleGroupedSelectionChange(groupedSelectedRanges: readonly Range[]): void {\n log.debug2('handleGroupedSelectedRanges', groupedSelectedRanges);\n this.setState(({ groupedSelectedRanges: stateGroupedSelectedRanges }) => {\n if (groupedSelectedRanges === stateGroupedSelectedRanges) {\n return null;\n }\n\n return { groupedSelectedRanges, ungroupedSelectedRanges: [] };\n });\n }\n\n handleDeleteClicked(index: number): void {\n this.setState(({ columns }) => {\n const newColumns = columns.slice();\n newColumns.splice(index, 1);\n return { columns: newColumns };\n });\n }\n\n handleShowConstituentsChange(): void {\n this.setState(({ showConstituents }) => ({\n showConstituents: !showConstituents,\n }));\n }\n\n handleShowNonAggregatedColumnsChange(): void {\n this.setState(({ showNonAggregatedColumns }) => ({\n showNonAggregatedColumns: !showNonAggregatedColumns,\n }));\n }\n\n updateFromConfig(): void {\n const { config } = this.props;\n const {\n columns = [],\n showConstituents = true,\n showNonAggregatedColumns = true,\n } = config ?? {};\n this.setState({ columns, showConstituents, showNonAggregatedColumns });\n }\n\n sendChange(): void {\n const { onChange } = this.props;\n const { columns, showConstituents, showNonAggregatedColumns } = this.state;\n onChange({\n columns,\n showConstituents,\n showNonAggregatedColumns,\n } as UIRollupConfig);\n }\n\n getCachedUngroupedColumns = memoize(\n (\n columns: readonly dh.Column[],\n groupedColumns: readonly ColumnName[]\n ): readonly dh.Column[] =>\n columns.filter(\n column =>\n RollupRows.isGroupable(column) &&\n groupedColumns.find(name => name === column.name) == null\n ),\n { max: 100 }\n );\n\n getCachedSortedColumns = memoize(\n (\n columns: readonly dh.Column[],\n sort?: SortDirection\n ): readonly dh.Column[] =>\n sort == null\n ? [...columns]\n : TableUtils.sortColumns(columns, sort === RollupRows.SORT.ASCENDING),\n { max: 100 }\n );\n\n getUngroupedColumns(): readonly dh.Column[] {\n const { model } = this.props;\n const { columns } = this.state;\n const { originalColumns } = model;\n\n return this.getCachedUngroupedColumns(originalColumns, columns);\n }\n\n getSortedUngroupedColumns(): readonly dh.Column[] {\n const { sort } = this.state;\n const columns = this.getUngroupedColumns();\n return this.getCachedSortedColumns(columns, sort);\n }\n\n renderGroupedItem({\n item,\n itemIndex,\n isClone,\n selectedCount,\n }: RenderItemProps<string> & {\n isClone?: boolean;\n selectedCount?: number;\n }): ReactElement {\n const indent =\n isClone !== undefined && isClone ? '' : '\\u00A0\\u00A0'.repeat(itemIndex);\n const text = `${indent}${item}`;\n const badgeText =\n isClone !== undefined && isClone ? `${selectedCount}` : undefined;\n const className =\n isClone !== undefined && isClone ? 'item-list-item-clone' : '';\n return (\n <>\n {DraggableItemList.renderTextItem({ text, badgeText, className })}\n {(isClone === undefined || !isClone) && (\n <Button\n kind=\"ghost\"\n className=\"btn btn-link btn-link-icon btn-delete-grouping float-right\"\n onClick={() => this.handleDeleteClicked(itemIndex)}\n >\n <FontAwesomeIcon icon={vsTrash} />\n </Button>\n )}\n </>\n );\n }\n\n render(): ReactElement {\n const {\n columns,\n dragSource,\n searchFilter,\n groupedSelectedRanges,\n ungroupedSelectedRanges,\n showConstituents,\n showNonAggregatedColumns,\n sort,\n } = this.state;\n\n const ungroupedColumns = this.getSortedUngroupedColumns();\n const groupListHeight =\n columns.length * DraggableItemList.DEFAULT_ROW_HEIGHT;\n const ungroupMaxListHeight =\n ungroupedColumns.length * DraggableItemList.DEFAULT_ROW_HEIGHT + 10;\n const ungroupMinListHeight = Math.min(\n 3 * DraggableItemList.DEFAULT_ROW_HEIGHT,\n ungroupMaxListHeight\n );\n\n return (\n <div\n role=\"menu\"\n className={classNames('rollup-rows', {\n 'is-dragging': dragSource != null,\n })}\n tabIndex={0}\n >\n <DragDropContext\n onDragEnd={this.handleDragEnd}\n onDragStart={this.handleDragStart}\n >\n <div className=\"rollup-rows-group-by\">\n <div className=\"section-title\">Group By</div>\n {columns.length === 0 && (\n <Droppable droppableId=\"placeholder\">\n {(provided, snapshot) => (\n <div\n className={classNames('placeholder', 'text-muted', {\n 'is-dragging-from-this': snapshot.draggingFromThisWith,\n 'is-dragging-over': snapshot.isDraggingOver,\n 'is-dropping': snapshot.draggingOverWith,\n })}\n ref={provided.innerRef}\n // eslint-disable-next-line react/jsx-props-no-spreading\n {...provided.droppableProps}\n >\n To create a rollup, drag columns from the list below and\n drop them into this area.\n </div>\n )}\n </Droppable>\n )}\n {columns.length > 0 && (\n <DraggableItemList\n draggingItemClassName=\"rollup-rows-dragging-grouped-item\"\n draggablePrefix={GROUPED_LIST_ID}\n droppableId={GROUPED_LIST_ID}\n itemCount={columns.length}\n items={columns}\n offset={0}\n onSelectionChange={this.handleGroupedSelectionChange}\n ref={this.groupedList}\n renderItem={this.renderGroupedItem}\n selectedRanges={groupedSelectedRanges}\n style={\n {\n '--group-list-height': `${groupListHeight}px`,\n '--row-height': `${DraggableItemList.DEFAULT_ROW_HEIGHT}px`,\n } as React.CSSProperties\n }\n isMultiSelect\n hasPlaceholder\n />\n )}\n </div>\n <div className=\"rollup-rows-available-columns\">\n <div className=\"section-title\">Available Grouping Columns</div>\n <div className=\"top-menu\">\n <SearchInput\n className=\"w-100\"\n value={searchFilter}\n matchCount={\n searchFilter ? ungroupedSelectedRanges.length : undefined\n }\n placeholder=\"Find column...\"\n onChange={this.handleSearchChange}\n />\n <Button\n kind=\"ghost\"\n className={classNames('btn-link btn-link-icon', {\n active: sort === RollupRows.SORT.ASCENDING,\n })}\n onClick={this.handleSortAscending}\n >\n <FontAwesomeIcon icon={dhSortAlphaDown} />\n <Tooltip>Sort ascending</Tooltip>\n </Button>\n <Button\n kind=\"ghost\"\n className={classNames('btn-link btn-link-icon', {\n active: sort === RollupRows.SORT.DESCENDING,\n })}\n onClick={this.handleSortDescending}\n >\n <FontAwesomeIcon icon={dhSortAlphaUp} />\n <Tooltip>Sort descending</Tooltip>\n </Button>\n </div>\n <DraggableItemList\n className=\"rollup-available-grouping-columns\"\n draggablePrefix={UNGROUPED_LIST_ID}\n droppableId={UNGROUPED_LIST_ID}\n itemCount={ungroupedColumns.length}\n items={ungroupedColumns}\n renderItem={RollupRows.renderColumn}\n offset={0}\n onSelect={this.handleUngroupedSelect}\n onSelectionChange={this.handleUngroupedSelectionChange}\n ref={this.ungroupedList}\n selectedRanges={ungroupedSelectedRanges}\n style={{\n maxHeight: ungroupMaxListHeight,\n minHeight: ungroupMinListHeight,\n }}\n isDropDisabled={dragSource?.droppableId !== GROUPED_LIST_ID}\n isMultiSelect\n />\n <div className=\"bottom-menu\">\n <div className=\"label\">Show:</div>\n <Checkbox\n checked={showConstituents}\n onChange={this.handleShowConstituentsChange}\n >\n Constituents\n </Checkbox>\n <Checkbox\n checked={showNonAggregatedColumns}\n onChange={this.handleShowNonAggregatedColumnsChange}\n >\n Non-Aggregated Columns\n </Checkbox>\n </div>\n </div>\n </DragDropContext>\n </div>\n );\n }\n}\n\nexport default RollupRows;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"RollupRows.js","names":["React","Component","classNames","FontAwesomeIcon","DragDropContext","Droppable","Checkbox","DraggableItemList","DragUtils","SearchInput","Tooltip","Button","vsTrash","dhSortAlphaDown","dhSortAlphaUp","TableUtils","memoize","debounce","Log","assertNotNull","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","log","module","DEBOUNCE_SEARCH","GROUPED_LIST_ID","UNGROUPED_LIST_ID","RollupRows","renderColumn","_ref","item","isClone","selectedCount","text","name","badgeText","undefined","concat","className","renderTextItem","addGroupings","currentGroupings","newGroupings","index","arguments","length","insertIndex","groupings","filter","grouping","i","includes","splice","isGroupable","column","isBigDecimalType","type","isBigIntegerType","constructor","props","_defineProperty","searchFilter","columns","getSortedUngroupedColumns","selectedRanges","focusIndex","toLowerCase","push","setState","ungroupedSelectedRanges","ungroupedList","current","scrollToItem","groupedColumns","find","max","sort","sortColumns","SORT","ASCENDING","handleDeleteClicked","bind","handleSearchChange","handleUngroupedSelect","handleUngroupedSelectionChange","handleDragStart","handleDragEnd","handleGroupedSelectionChange","handleShowConstituentsChange","handleShowNonAggregatedColumnsChange","handleSortAscending","handleSortDescending","renderGroupedItem","createRef","groupedList","config","_ref2","_ref2$columns","_ref2$showConstituent","showConstituents","_ref2$showNonAggregat","showNonAggregatedColumns","state","groupedSelectedRanges","dragSource","componentDidUpdate","prevProps","prevState","_this$state","updateFromConfig","sendChange","componentWillUnmount","search","cancel","event","target","value","resetSelection","_ref3","_ref4","DESCENDING","e","debug","document","documentElement","classList","add","source","remove","destination","droppableId","_ref5","newColumns","reorder","isSameList","destinationIndex","_ref6","sourceItems","map","c","sourceRanges","draggedItems","adjustDestinationIndex","newSelectedRanges","itemIndex","_ref7","debug2","_ref8","stateUngroupedSelectedRanges","_ref9","stateGroupedSelectedRanges","_ref0","slice","_ref1","_ref10","_ref11","_ref11$columns","_ref11$showConstituen","_ref11$showNonAggrega","onChange","_this$state2","getUngroupedColumns","model","originalColumns","getCachedUngroupedColumns","getCachedSortedColumns","_ref12","indent","repeat","children","kind","onClick","icon","render","_this$state3","ungroupedColumns","groupListHeight","DEFAULT_ROW_HEIGHT","ungroupMaxListHeight","ungroupMinListHeight","Math","min","role","tabIndex","onDragEnd","onDragStart","provided","snapshot","_objectSpread","draggingFromThisWith","isDraggingOver","draggingOverWith","ref","innerRef","droppableProps","draggingItemClassName","draggablePrefix","itemCount","items","offset","onSelectionChange","renderItem","style","isMultiSelect","hasPlaceholder","matchCount","placeholder","active","onSelect","maxHeight","minHeight","isDropDisabled","checked","Object","freeze"],"sources":["../../src/sidebar/RollupRows.tsx"],"sourcesContent":["/* eslint-disable jsx-a11y/click-events-have-key-events */\nimport React, {\n type ChangeEvent,\n Component,\n type ReactElement,\n type RefObject,\n} from 'react';\nimport classNames from 'classnames';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport {\n DragDropContext,\n type DraggableLocation,\n type DragStart,\n Droppable,\n type DropResult,\n} from '@hello-pangea/dnd';\nimport {\n Checkbox,\n DraggableItemList,\n DragUtils,\n SearchInput,\n Tooltip,\n type Range,\n type RenderItemProps,\n Button,\n} from '@deephaven/components';\nimport { vsTrash, dhSortAlphaDown, dhSortAlphaUp } from '@deephaven/icons';\nimport { TableUtils, type SortDirection } from '@deephaven/jsapi-utils';\nimport memoize from 'memoizee';\nimport debounce from 'lodash.debounce';\nimport Log from '@deephaven/log';\nimport { assertNotNull } from '@deephaven/utils';\nimport './RollupRows.scss';\nimport type { dh } from '@deephaven/jsapi-types';\nimport type IrisGridModel from '../IrisGridModel';\nimport { type ColumnName } from '../CommonTypes';\n\nconst log = Log.module('RollupRows');\nconst DEBOUNCE_SEARCH = 150;\nconst GROUPED_LIST_ID = 'grouped-rollup-rows';\nconst UNGROUPED_LIST_ID = 'ungrouped-rollup-rows';\n\nexport interface UIRollupConfig {\n columns: ColumnName[];\n showConstituents: boolean;\n showNonAggregatedColumns: boolean;\n includeDescriptions: true;\n}\n\ninterface RollupRowsProps {\n model: IrisGridModel;\n onChange: (rollupConfig: UIRollupConfig) => void;\n config: UIRollupConfig | null;\n}\n\ninterface RollupRowsState {\n ungroupedSelectedRanges: readonly Range[];\n columns: ColumnName[];\n groupedSelectedRanges: readonly Range[];\n searchFilter: string;\n showConstituents: boolean;\n showNonAggregatedColumns: boolean;\n dragSource: DraggableLocation | null;\n sort: SortDirection;\n}\n\nclass RollupRows extends Component<RollupRowsProps, RollupRowsState> {\n static SORT = Object.freeze({\n ASCENDING: 'ASC',\n DESCENDING: 'DESC',\n });\n\n static defaultProps = {\n config: null,\n onChange: (): void => undefined,\n };\n\n static renderColumn({\n item,\n isClone,\n selectedCount,\n }: RenderItemProps<dh.Column> & {\n isClone?: boolean;\n selectedCount?: number;\n }): ReactElement {\n const text = item?.name;\n const badgeText =\n isClone !== undefined && isClone ? `${selectedCount}` : undefined;\n const className =\n isClone !== undefined && isClone ? 'item-list-item-clone' : '';\n return DraggableItemList.renderTextItem({ text, badgeText, className });\n }\n\n static addGroupings(\n currentGroupings: string[],\n newGroupings: string[],\n index: number = currentGroupings.length\n ): string[] {\n if (newGroupings == null || newGroupings.length === 0) {\n return currentGroupings;\n }\n\n let insertIndex = index;\n const groupings = currentGroupings.filter((grouping, i) => {\n if (newGroupings.includes(grouping)) {\n if (i < insertIndex) {\n insertIndex -= 1;\n }\n return false;\n }\n return true;\n });\n groupings.splice(insertIndex, 0, ...newGroupings);\n return groupings;\n }\n\n static isGroupable(column: dh.Column): boolean {\n return (\n !TableUtils.isBigDecimalType(column.type) &&\n !TableUtils.isBigIntegerType(column.type)\n );\n }\n\n constructor(props: RollupRowsProps) {\n super(props);\n\n this.handleDeleteClicked = this.handleDeleteClicked.bind(this);\n this.handleSearchChange = this.handleSearchChange.bind(this);\n this.handleUngroupedSelect = this.handleUngroupedSelect.bind(this);\n this.handleUngroupedSelectionChange =\n this.handleUngroupedSelectionChange.bind(this);\n this.handleDragStart = this.handleDragStart.bind(this);\n this.handleDragEnd = this.handleDragEnd.bind(this);\n this.handleGroupedSelectionChange =\n this.handleGroupedSelectionChange.bind(this);\n this.handleShowConstituentsChange =\n this.handleShowConstituentsChange.bind(this);\n this.handleShowNonAggregatedColumnsChange =\n this.handleShowNonAggregatedColumnsChange.bind(this);\n this.handleSortAscending = this.handleSortAscending.bind(this);\n this.handleSortDescending = this.handleSortDescending.bind(this);\n this.renderGroupedItem = this.renderGroupedItem.bind(this);\n\n this.ungroupedList = React.createRef();\n this.groupedList = React.createRef();\n\n const { config } = props;\n const {\n columns = [],\n showConstituents = true,\n showNonAggregatedColumns = true,\n } = config ?? {};\n\n this.state = {\n ungroupedSelectedRanges: [],\n columns,\n groupedSelectedRanges: [],\n searchFilter: '',\n showConstituents,\n showNonAggregatedColumns,\n dragSource: null,\n sort: null,\n };\n }\n\n componentDidUpdate(\n prevProps: RollupRowsProps,\n prevState: RollupRowsState\n ): void {\n const { config } = this.props;\n const { columns, showConstituents, showNonAggregatedColumns } = this.state;\n if (config !== prevProps.config) {\n this.updateFromConfig();\n } else if (\n columns !== prevState.columns ||\n showConstituents !== prevState.showConstituents ||\n showNonAggregatedColumns !== prevState.showNonAggregatedColumns\n ) {\n if (\n config == null ||\n columns !== config.columns ||\n showConstituents !== config.showConstituents ||\n showNonAggregatedColumns !== config.showNonAggregatedColumns\n ) {\n this.sendChange();\n }\n }\n }\n\n componentWillUnmount(): void {\n this.search.cancel();\n }\n\n ungroupedList: RefObject<DraggableItemList<dh.Column>>;\n\n groupedList: RefObject<DraggableItemList<string>>;\n\n handleSearchChange(event: ChangeEvent<HTMLInputElement>): void {\n const searchFilter = event.target.value;\n this.setState({ searchFilter });\n if (!searchFilter) {\n this.search.cancel();\n this.resetSelection();\n return;\n }\n this.search(searchFilter);\n }\n\n handleSortAscending(): void {\n this.setState(({ sort }) => ({\n sort:\n sort === RollupRows.SORT.ASCENDING ? null : RollupRows.SORT.ASCENDING,\n }));\n }\n\n handleSortDescending(): void {\n this.setState(({ sort }) => ({\n sort:\n sort === RollupRows.SORT.DESCENDING ? null : RollupRows.SORT.DESCENDING,\n }));\n }\n\n resetSelection(): void {\n this.setState({ ungroupedSelectedRanges: [], groupedSelectedRanges: [] });\n }\n\n search = debounce((searchFilter: string) => {\n const columns = this.getSortedUngroupedColumns();\n const selectedRanges = [] as Range[];\n let focusIndex = null;\n for (let i = 0; i < columns.length; i += 1) {\n const column = columns[i];\n if (column.name.toLowerCase().includes(searchFilter.toLowerCase())) {\n if (focusIndex == null) {\n focusIndex = i;\n }\n selectedRanges.push([i, i]);\n }\n }\n assertNotNull(focusIndex);\n this.setState({ ungroupedSelectedRanges: selectedRanges });\n\n if (selectedRanges.length > 0 && this.ungroupedList.current) {\n this.ungroupedList.current.scrollToItem(focusIndex);\n }\n }, DEBOUNCE_SEARCH);\n\n handleDragStart(e: DragStart): void {\n log.debug('handleDragStart', e);\n\n document.documentElement.classList.add('drag-pointer-events-none');\n\n this.setState({ dragSource: e.source });\n }\n\n handleDragEnd(e: DropResult): void {\n log.debug('handleDragEnd', e);\n\n document.documentElement.classList.remove('drag-pointer-events-none');\n\n this.setState({ dragSource: null });\n\n const { destination, source } = e;\n if (destination == null || source == null) {\n return;\n }\n\n // We don't allow dragging within the ungrouped list, so if we're dragging into the ungrouped list,\n // it must have came from the grouped list. Remove those grouped columns.\n if (destination.droppableId === UNGROUPED_LIST_ID) {\n this.setState(({ groupedSelectedRanges, columns }) => {\n const newColumns = [...columns];\n DragUtils.reorder(newColumns, groupedSelectedRanges, [], 0);\n return {\n columns: newColumns,\n ungroupedSelectedRanges: [],\n groupedSelectedRanges: [],\n };\n });\n return;\n }\n\n // Otherwise, it must be dropping into the grouped list, so we just need to check the source\n const isSameList = source.droppableId === GROUPED_LIST_ID;\n let destinationIndex = destination.index;\n if (isSameList && source.index < destination.index) {\n // @hello-pangea/dnd adjusts the index when dragging within a list already, however that only supports single selection\n // We need to change it back to the index we actually want it to drop at before adjusting for the removed source index, as\n // we adjust the index based on all the selected ranges, not just the source.index.\n destinationIndex += 1;\n }\n this.setState(\n ({ columns, ungroupedSelectedRanges, groupedSelectedRanges }) => {\n const newColumns = [...columns];\n const sourceItems = isSameList\n ? newColumns\n : this.getSortedUngroupedColumns().map(c => c.name);\n const sourceRanges = isSameList\n ? groupedSelectedRanges\n : ungroupedSelectedRanges;\n const draggedItems = DragUtils.reorder(\n sourceItems,\n sourceRanges,\n newColumns,\n destinationIndex\n );\n\n // Select the newly dropped items\n const insertIndex = isSameList\n ? DragUtils.adjustDestinationIndex(\n destinationIndex,\n groupedSelectedRanges\n )\n : destinationIndex;\n const newSelectedRanges = [\n [insertIndex, insertIndex + draggedItems.length - 1] as Range,\n ];\n return {\n columns: newColumns,\n ungroupedSelectedRanges: [] as Range[],\n groupedSelectedRanges: newSelectedRanges,\n };\n }\n );\n this.resetSelection();\n }\n\n handleUngroupedSelect(itemIndex: number): void {\n log.debug('handleUngroupedSelect');\n\n this.setState(({ columns }) => ({\n columns: RollupRows.addGroupings(columns, [\n this.getSortedUngroupedColumns()[itemIndex].name,\n ]),\n ungroupedSelectedRanges: [],\n groupedSelectedRanges: [],\n }));\n }\n\n handleUngroupedSelectionChange(\n ungroupedSelectedRanges: readonly Range[]\n ): void {\n log.debug2('handleUngroupedSelectionChange', ungroupedSelectedRanges);\n this.setState(\n ({ ungroupedSelectedRanges: stateUngroupedSelectedRanges }) => {\n if (ungroupedSelectedRanges === stateUngroupedSelectedRanges) {\n return null;\n }\n\n return { ungroupedSelectedRanges, groupedSelectedRanges: [] };\n }\n );\n }\n\n handleGroupedSelectionChange(groupedSelectedRanges: readonly Range[]): void {\n log.debug2('handleGroupedSelectedRanges', groupedSelectedRanges);\n this.setState(({ groupedSelectedRanges: stateGroupedSelectedRanges }) => {\n if (groupedSelectedRanges === stateGroupedSelectedRanges) {\n return null;\n }\n\n return { groupedSelectedRanges, ungroupedSelectedRanges: [] };\n });\n }\n\n handleDeleteClicked(index: number): void {\n this.setState(({ columns }) => {\n const newColumns = columns.slice();\n newColumns.splice(index, 1);\n return { columns: newColumns };\n });\n }\n\n handleShowConstituentsChange(): void {\n this.setState(({ showConstituents }) => ({\n showConstituents: !showConstituents,\n }));\n }\n\n handleShowNonAggregatedColumnsChange(): void {\n this.setState(({ showNonAggregatedColumns }) => ({\n showNonAggregatedColumns: !showNonAggregatedColumns,\n }));\n }\n\n updateFromConfig(): void {\n const { config } = this.props;\n const {\n columns = [],\n showConstituents = true,\n showNonAggregatedColumns = true,\n } = config ?? {};\n this.setState({ columns, showConstituents, showNonAggregatedColumns });\n }\n\n sendChange(): void {\n const { onChange } = this.props;\n const { columns, showConstituents, showNonAggregatedColumns } = this.state;\n onChange({\n columns,\n showConstituents,\n showNonAggregatedColumns,\n } as UIRollupConfig);\n }\n\n getCachedUngroupedColumns = memoize(\n (\n columns: readonly dh.Column[],\n groupedColumns: readonly ColumnName[]\n ): readonly dh.Column[] =>\n columns.filter(\n column =>\n RollupRows.isGroupable(column) &&\n groupedColumns.find(name => name === column.name) == null\n ),\n { max: 100 }\n );\n\n getCachedSortedColumns = memoize(\n (\n columns: readonly dh.Column[],\n sort?: SortDirection\n ): readonly dh.Column[] =>\n sort == null\n ? [...columns]\n : TableUtils.sortColumns(columns, sort === RollupRows.SORT.ASCENDING),\n { max: 100 }\n );\n\n getUngroupedColumns(): readonly dh.Column[] {\n const { model } = this.props;\n const { columns } = this.state;\n const { originalColumns } = model;\n\n return this.getCachedUngroupedColumns(originalColumns, columns);\n }\n\n getSortedUngroupedColumns(): readonly dh.Column[] {\n const { sort } = this.state;\n const columns = this.getUngroupedColumns();\n return this.getCachedSortedColumns(columns, sort);\n }\n\n renderGroupedItem({\n item,\n itemIndex,\n isClone,\n selectedCount,\n }: RenderItemProps<string> & {\n isClone?: boolean;\n selectedCount?: number;\n }): ReactElement {\n const indent =\n isClone !== undefined && isClone ? '' : '\\u00A0\\u00A0'.repeat(itemIndex);\n const text = `${indent}${item}`;\n const badgeText =\n isClone !== undefined && isClone ? `${selectedCount}` : undefined;\n const className =\n isClone !== undefined && isClone ? 'item-list-item-clone' : '';\n return (\n <>\n {DraggableItemList.renderTextItem({ text, badgeText, className })}\n {(isClone === undefined || !isClone) && (\n <Button\n kind=\"ghost\"\n className=\"btn btn-link btn-link-icon btn-delete-grouping float-right\"\n onClick={() => this.handleDeleteClicked(itemIndex)}\n >\n <FontAwesomeIcon icon={vsTrash} />\n </Button>\n )}\n </>\n );\n }\n\n render(): ReactElement {\n const {\n columns,\n dragSource,\n searchFilter,\n groupedSelectedRanges,\n ungroupedSelectedRanges,\n showConstituents,\n showNonAggregatedColumns,\n sort,\n } = this.state;\n\n const ungroupedColumns = this.getSortedUngroupedColumns();\n const groupListHeight =\n columns.length * DraggableItemList.DEFAULT_ROW_HEIGHT;\n const ungroupMaxListHeight =\n ungroupedColumns.length * DraggableItemList.DEFAULT_ROW_HEIGHT + 10;\n const ungroupMinListHeight = Math.min(\n 3 * DraggableItemList.DEFAULT_ROW_HEIGHT,\n ungroupMaxListHeight\n );\n\n return (\n <div\n role=\"menu\"\n className={classNames('rollup-rows', {\n 'is-dragging': dragSource != null,\n })}\n tabIndex={0}\n >\n <DragDropContext\n onDragEnd={this.handleDragEnd}\n onDragStart={this.handleDragStart}\n >\n <div className=\"rollup-rows-group-by\">\n <div className=\"section-title\">Group By</div>\n {columns.length === 0 && (\n <Droppable droppableId=\"placeholder\">\n {(provided, snapshot) => (\n <div\n className={classNames('placeholder', 'text-muted', {\n 'is-dragging-from-this': snapshot.draggingFromThisWith,\n 'is-dragging-over': snapshot.isDraggingOver,\n 'is-dropping': snapshot.draggingOverWith,\n })}\n ref={provided.innerRef}\n // eslint-disable-next-line react/jsx-props-no-spreading\n {...provided.droppableProps}\n >\n To create a rollup, drag columns from the list below and\n drop them into this area.\n </div>\n )}\n </Droppable>\n )}\n {columns.length > 0 && (\n <DraggableItemList\n draggingItemClassName=\"rollup-rows-dragging-grouped-item\"\n draggablePrefix={GROUPED_LIST_ID}\n droppableId={GROUPED_LIST_ID}\n itemCount={columns.length}\n items={columns}\n offset={0}\n onSelectionChange={this.handleGroupedSelectionChange}\n ref={this.groupedList}\n renderItem={this.renderGroupedItem}\n selectedRanges={groupedSelectedRanges}\n style={\n {\n '--group-list-height': `${groupListHeight}px`,\n '--row-height': `${DraggableItemList.DEFAULT_ROW_HEIGHT}px`,\n } as React.CSSProperties\n }\n isMultiSelect\n hasPlaceholder\n />\n )}\n </div>\n <div className=\"rollup-rows-available-columns\">\n <div className=\"section-title\">Available Grouping Columns</div>\n <div className=\"top-menu\">\n <SearchInput\n className=\"w-100\"\n value={searchFilter}\n matchCount={\n searchFilter ? ungroupedSelectedRanges.length : undefined\n }\n placeholder=\"Find column...\"\n onChange={this.handleSearchChange}\n />\n <Button\n kind=\"ghost\"\n className={classNames('btn-link btn-link-icon', {\n active: sort === RollupRows.SORT.ASCENDING,\n })}\n onClick={this.handleSortAscending}\n >\n <FontAwesomeIcon icon={dhSortAlphaDown} />\n <Tooltip>Sort ascending</Tooltip>\n </Button>\n <Button\n kind=\"ghost\"\n className={classNames('btn-link btn-link-icon', {\n active: sort === RollupRows.SORT.DESCENDING,\n })}\n onClick={this.handleSortDescending}\n >\n <FontAwesomeIcon icon={dhSortAlphaUp} />\n <Tooltip>Sort descending</Tooltip>\n </Button>\n </div>\n <DraggableItemList\n className=\"rollup-available-grouping-columns\"\n draggablePrefix={UNGROUPED_LIST_ID}\n droppableId={UNGROUPED_LIST_ID}\n itemCount={ungroupedColumns.length}\n items={ungroupedColumns}\n renderItem={RollupRows.renderColumn}\n offset={0}\n onSelect={this.handleUngroupedSelect}\n onSelectionChange={this.handleUngroupedSelectionChange}\n ref={this.ungroupedList}\n selectedRanges={ungroupedSelectedRanges}\n style={{\n maxHeight: ungroupMaxListHeight,\n minHeight: ungroupMinListHeight,\n }}\n isDropDisabled={dragSource?.droppableId !== GROUPED_LIST_ID}\n isMultiSelect\n />\n <div className=\"bottom-menu\">\n <div className=\"label\">Show:</div>\n <Checkbox\n checked={showConstituents}\n onChange={this.handleShowConstituentsChange}\n >\n Constituents\n </Checkbox>\n <Checkbox\n checked={showNonAggregatedColumns}\n onChange={this.handleShowNonAggregatedColumnsChange}\n >\n Non-Aggregated Columns\n </Checkbox>\n </div>\n </div>\n </DragDropContext>\n </div>\n );\n }\n}\n\nexport default RollupRows;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -16,22 +16,17 @@ class SelectDistinctBuilder extends Component {
|
|
|
16
16
|
this.handleAddColumnClick = this.handleAddColumnClick.bind(this);
|
|
17
17
|
this.handleDeleteColumn = this.handleDeleteColumn.bind(this);
|
|
18
18
|
this.handleDropdownChanged = this.handleDropdownChanged.bind(this);
|
|
19
|
-
var
|
|
20
|
-
model,
|
|
21
|
-
selectDistinctColumns
|
|
22
|
-
} = this.props;
|
|
19
|
+
var _this$props = this.props,
|
|
20
|
+
model = _this$props.model,
|
|
21
|
+
selectDistinctColumns = _this$props.selectDistinctColumns;
|
|
23
22
|
this.state = {
|
|
24
23
|
inputs: selectDistinctColumns.length > 0 ? [...selectDistinctColumns] : [''],
|
|
25
24
|
columns: model.originalColumns
|
|
26
25
|
};
|
|
27
26
|
}
|
|
28
27
|
componentDidUpdate(prevProps, prevState) {
|
|
29
|
-
var
|
|
30
|
-
|
|
31
|
-
} = this.state;
|
|
32
|
-
var {
|
|
33
|
-
onChange
|
|
34
|
-
} = this.props;
|
|
28
|
+
var inputs = this.state.inputs;
|
|
29
|
+
var onChange = this.props.onChange;
|
|
35
30
|
if (prevState.inputs !== inputs) {
|
|
36
31
|
var filteredInputs = inputs.filter(val => val !== '');
|
|
37
32
|
if (!deepEqual(prevState.inputs.filter(val => val !== ''), filteredInputs)) {
|
|
@@ -41,9 +36,7 @@ class SelectDistinctBuilder extends Component {
|
|
|
41
36
|
}
|
|
42
37
|
handleAddColumnClick() {
|
|
43
38
|
this.setState(_ref => {
|
|
44
|
-
var
|
|
45
|
-
inputs: prevInputs
|
|
46
|
-
} = _ref;
|
|
39
|
+
var prevInputs = _ref.inputs;
|
|
47
40
|
return {
|
|
48
41
|
inputs: [...prevInputs, '']
|
|
49
42
|
};
|
|
@@ -51,9 +44,7 @@ class SelectDistinctBuilder extends Component {
|
|
|
51
44
|
}
|
|
52
45
|
handleDeleteColumn(index) {
|
|
53
46
|
this.setState(_ref2 => {
|
|
54
|
-
var
|
|
55
|
-
inputs
|
|
56
|
-
} = _ref2;
|
|
47
|
+
var inputs = _ref2.inputs;
|
|
57
48
|
return {
|
|
58
49
|
inputs: inputs.length === 1 && index === 0 ? [''] : inputs.filter((input, inputIndex) => index !== inputIndex)
|
|
59
50
|
};
|
|
@@ -62,9 +53,7 @@ class SelectDistinctBuilder extends Component {
|
|
|
62
53
|
handleDropdownChanged(index, value) {
|
|
63
54
|
log.debug('handleDropdownChanged', index, value);
|
|
64
55
|
this.setState(_ref3 => {
|
|
65
|
-
var
|
|
66
|
-
inputs: prevInputs
|
|
67
|
-
} = _ref3;
|
|
56
|
+
var prevInputs = _ref3.inputs;
|
|
68
57
|
var inputs = [...prevInputs];
|
|
69
58
|
inputs[index] = value;
|
|
70
59
|
return {
|
|
@@ -73,20 +62,15 @@ class SelectDistinctBuilder extends Component {
|
|
|
73
62
|
});
|
|
74
63
|
}
|
|
75
64
|
renderInputs() {
|
|
76
|
-
var
|
|
77
|
-
columns,
|
|
78
|
-
inputs
|
|
79
|
-
} = this.state;
|
|
65
|
+
var _this$state = this.state,
|
|
66
|
+
columns = _this$state.columns,
|
|
67
|
+
inputs = _this$state.inputs;
|
|
80
68
|
return inputs.map((value, index) => {
|
|
81
69
|
var options = columns.filter(_ref4 => {
|
|
82
|
-
var
|
|
83
|
-
name
|
|
84
|
-
} = _ref4;
|
|
70
|
+
var name = _ref4.name;
|
|
85
71
|
return name === value || !inputs.includes(name);
|
|
86
72
|
}).map(_ref5 => {
|
|
87
|
-
var
|
|
88
|
-
name
|
|
89
|
-
} = _ref5;
|
|
73
|
+
var name = _ref5.name;
|
|
90
74
|
return /*#__PURE__*/_jsx("option", {
|
|
91
75
|
value: name,
|
|
92
76
|
children: name
|
|
@@ -122,10 +106,9 @@ class SelectDistinctBuilder extends Component {
|
|
|
122
106
|
});
|
|
123
107
|
}
|
|
124
108
|
render() {
|
|
125
|
-
var
|
|
126
|
-
columns,
|
|
127
|
-
inputs
|
|
128
|
-
} = this.state;
|
|
109
|
+
var _this$state2 = this.state,
|
|
110
|
+
columns = _this$state2.columns,
|
|
111
|
+
inputs = _this$state2.inputs;
|
|
129
112
|
var disableAddButton = inputs.length >= columns.length;
|
|
130
113
|
return /*#__PURE__*/_jsxs("div", {
|
|
131
114
|
role: "presentation",
|