td-stylekit 30.17.3 → 32.0.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/CHANGELOG.md +24 -0
- package/dist/es/ActionBar/ActionBar.js +10 -12
- package/dist/es/ActionBar/components/IconButton.d.ts +11 -1
- package/dist/es/ActionBar/components/IconButton.js +28 -8
- package/dist/es/BarChart/BarChart.d.ts +3 -16
- package/dist/es/BarChart/BarChart.js +12 -17
- package/dist/es/Box/Box.js +3 -5
- package/dist/es/Button/Button.d.ts +1 -16
- package/dist/es/Button/Button.js +55 -23
- package/dist/es/Canvas/elements.js +2 -4
- package/dist/es/Checkbox/Checkbox.d.ts +0 -4
- package/dist/es/Checkbox/Checkbox.js +33 -37
- package/dist/es/ColorPicker/ColorPicker.js +2 -4
- package/dist/es/ComparisonChart/ComparisonChart.d.ts +2 -13
- package/dist/es/ComparisonChart/ComparisonChart.js +10 -12
- package/dist/es/DataGrid/DataGrid.d.ts +3 -14
- package/dist/es/DataGrid/DataGrid.js +83 -61
- package/dist/es/DataGrid/components/ColumnHeader.d.ts +2 -6
- package/dist/es/DataGrid/components/ColumnHeader.js +8 -10
- package/dist/es/DataGrid/components/FocusableRow.js +1 -1
- package/dist/es/DataGrid/components/InputCell.js +0 -3
- package/dist/es/DataGrid/components/ScrollableTable.d.ts +0 -15
- package/dist/es/DataGrid/components/ScrollableTable.js +32 -32
- package/dist/es/DataGrid/elements.d.ts +4 -7
- package/dist/es/DataGrid/elements.js +1 -2
- package/dist/es/DataGrid/renderers.js +1 -2
- package/dist/es/DateControl/DateControl.d.ts +1 -6
- package/dist/es/DateControl/DateControl.js +2 -4
- package/dist/es/DateControl/elements.d.ts +1 -238
- package/dist/es/DateControl/elements.js +1 -2
- package/dist/es/DatePicker/DatePicker.d.ts +0 -6
- package/dist/es/DatePicker/DatePicker.js +28 -19
- package/dist/es/Drawer/elements.js +2 -4
- package/dist/es/DropdownButton/DropdownButton.d.ts +3 -10
- package/dist/es/DropdownButton/DropdownButton.js +18 -16
- package/dist/es/DropdownButton/DropdownButtonElements.d.ts +1 -1
- package/dist/es/FileInput/FileInput.d.ts +1 -6
- package/dist/es/FileInput/FileInput.js +7 -10
- package/dist/es/FormControl/FormControl.d.ts +1 -2
- package/dist/es/FormControl/FormControl.js +31 -29
- package/dist/es/FormControl/components/CheckboxGroup.js +1 -2
- package/dist/es/FormControl/components/RadioGroup.js +1 -2
- package/dist/es/FormControl/elements.js +4 -8
- package/dist/es/FormModal/FormModal.d.ts +1 -6
- package/dist/es/FormModal/FormModal.js +3 -6
- package/dist/es/GrowthRateChart/GrowthRateChart.d.ts +4 -64
- package/dist/es/GrowthRateChart/GrowthRateChart.js +32 -17
- package/dist/es/Icon/Icon.js +1 -2
- package/dist/es/IconBar/IconBar.js +1 -2
- package/dist/es/IconBar/LogoItem.js +1 -2
- package/dist/es/LeftTruncatedText/LeftTruncatedText.js +2 -4
- package/dist/es/Loader/LoaderDiamond.js +2 -4
- package/dist/es/Loader/LoaderDots.js +1 -2
- package/dist/es/Logo/Logo.d.ts +0 -7
- package/dist/es/Logo/Logo.js +6 -8
- package/dist/es/Logo/LogoDark.d.ts +1 -8
- package/dist/es/Logo/LogoDark.js +5 -7
- package/dist/es/Logo/LogoLight.d.ts +1 -8
- package/dist/es/Logo/LogoLight.js +5 -7
- package/dist/es/Menu/Menu.d.ts +0 -4
- package/dist/es/Menu/Menu.js +6 -9
- package/dist/es/Menu/MenuElements.d.ts +2 -6
- package/dist/es/Menu/MenuElements.js +10 -9
- package/dist/es/MiddleTruncatedText/MiddleTruncatedText.js +1 -2
- package/dist/es/Modal/Modal.d.ts +2 -9
- package/dist/es/Modal/Modal.js +13 -13
- package/dist/es/Modal/components/MenuBody.d.ts +1 -3
- package/dist/es/Modal/components/MenuBody.js +2 -4
- package/dist/es/Modal/components/ModalMessage.d.ts +1 -6
- package/dist/es/Modal/components/ModalMessage.js +14 -16
- package/dist/es/Modal/components/ModalOverlay.d.ts +1 -0
- package/dist/es/Modal/components/elements.d.ts +19 -19
- package/dist/es/Modal/components/elements.js +20 -22
- package/dist/es/MultiSelect/MultiSelect.d.ts +3 -27
- package/dist/es/MultiSelect/MultiSelect.js +46 -46
- package/dist/es/MultiSelect/elements.d.ts +6 -5
- package/dist/es/MultiSelect/elements.js +64 -59
- package/dist/es/Radio/Radio.d.ts +1 -6
- package/dist/es/Radio/Radio.js +14 -15
- package/dist/es/RightTruncatedText/RightTruncatedText.js +1 -2
- package/dist/es/SecondaryNavigation/SecondaryNavigation.d.ts +1 -7
- package/dist/es/SecondaryNavigation/SecondaryNavigation.js +3 -6
- package/dist/es/Section/Section.d.ts +1 -5
- package/dist/es/Section/Section.js +4 -6
- package/dist/es/Section/elements.js +1 -2
- package/dist/es/Select/Select.d.ts +1 -13
- package/dist/es/Select/Select.js +9 -22
- package/dist/es/Shuttle/Shuttle.d.ts +3 -15
- package/dist/es/Shuttle/Shuttle.js +22 -22
- package/dist/es/Shuttle/elements.js +4 -8
- package/dist/es/Tabs/elements.js +3 -6
- package/dist/es/Tagger/Tagger.d.ts +2 -10
- package/dist/es/Tagger/Tagger.js +39 -41
- package/dist/es/Tagger/TaggerElements.js +2 -4
- package/dist/es/Tagger/components/PopupSelector.d.ts +13 -19
- package/dist/es/Tagger/components/PopupSelector.js +49 -51
- package/dist/es/Tagger/types.d.ts +5 -5
- package/dist/es/Tagger/variantProps.js +1 -2
- package/dist/es/TimeControl/TimeControl.js +25 -18
- package/dist/es/TimeControl/elements.d.ts +1 -238
- package/dist/es/TimeControl/elements.js +1 -2
- package/dist/es/TimePicker/TimePicker.js +6 -10
- package/dist/es/TimePicker/components/Spinner.js +16 -12
- package/dist/es/Toast/Toast.d.ts +4 -11
- package/dist/es/Toast/Toast.js +12 -13
- package/dist/es/Toast/elements.js +1 -2
- package/dist/es/Toggle/Toggle.d.ts +0 -5
- package/dist/es/Toggle/Toggle.js +10 -11
- package/dist/es/TooltipPopover/TooltipPopover.d.ts +1 -8
- package/dist/es/TooltipPopover/TooltipPopover.js +6 -9
- package/dist/es/Tree/Tree.js +2 -4
- package/dist/es/Tree/elements.js +1 -2
- package/dist/es/VisuallyHidden/VisuallyHidden.js +1 -2
- package/dist/es/VolumeChart/VolumeChart.d.ts +1 -10
- package/dist/es/VolumeChart/VolumeChart.js +6 -8
- package/dist/es/react/index.d.ts +2 -0
- package/dist/es/react/index.js +18 -0
- package/dist/es/react/jsx-dev-runtime.d.ts +2 -0
- package/dist/es/react/jsx-dev-runtime.js +18 -0
- package/dist/es/react/jsx-runtime.d.ts +2 -0
- package/dist/es/react/jsx-runtime.js +18 -0
- package/dist/es/utils/resetcss.d.ts +1 -1
- package/dist/es/utils/resetcss.js +1 -2
- package/dist/es/utils/tailwindcss.d.ts +1 -1
- package/dist/es/utils/tailwindcss.js +1 -2
- package/package.json +27 -9
|
@@ -14,13 +14,12 @@ var _components = require("./components");
|
|
|
14
14
|
var _utils = require("../utils");
|
|
15
15
|
var _lodash = _interopRequireDefault(require("lodash.curry"));
|
|
16
16
|
var _lodash2 = _interopRequireDefault(require("lodash.includes"));
|
|
17
|
-
var _lodash3 = _interopRequireDefault(require("lodash.
|
|
18
|
-
var _lodash4 = _interopRequireDefault(require("lodash.
|
|
19
|
-
var _lodash5 = _interopRequireDefault(require("lodash.
|
|
20
|
-
var _lodash6 = _interopRequireDefault(require("lodash.uniq"));
|
|
17
|
+
var _lodash3 = _interopRequireDefault(require("lodash.range"));
|
|
18
|
+
var _lodash4 = _interopRequireDefault(require("lodash.throttle"));
|
|
19
|
+
var _lodash5 = _interopRequireDefault(require("lodash.uniq"));
|
|
21
20
|
var dataGridUtils = _interopRequireWildcard(require("./utils"));
|
|
22
21
|
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
23
|
-
var _excluded = ["children", "hasMoreRows", "height", "loadMoreRows", "
|
|
22
|
+
var _excluded = ["children", "hasMoreRows", "height", "loadMoreRows", "rowCount", "sortBy", "sortDirection", "width", "data-instrumentation"];
|
|
24
23
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
25
24
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
26
25
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
@@ -86,17 +85,20 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
86
85
|
return;
|
|
87
86
|
}
|
|
88
87
|
_this.setState(function (state) {
|
|
88
|
+
var _this$props$selectedR;
|
|
89
89
|
var lastSelectedRow = state.lastSelectedRow;
|
|
90
|
-
var selectedRows = _this.props.selectedRows;
|
|
90
|
+
var selectedRows = (_this$props$selectedR = _this.props.selectedRows) !== null && _this$props$selectedR !== void 0 ? _this$props$selectedR : [];
|
|
91
91
|
var selected = [].concat(_toConsumableArray(selectedRows), [index]);
|
|
92
92
|
if (_this.props.selectable === DataGrid.SINGLE_SELECT) {
|
|
93
93
|
selected = [index];
|
|
94
94
|
} else if (contiguous && typeof lastSelectedRow === 'number') {
|
|
95
95
|
var start = Math.min(lastSelectedRow, index);
|
|
96
96
|
var end = Math.max(lastSelectedRow, index);
|
|
97
|
-
selected = (0,
|
|
97
|
+
selected = (0, _lodash5["default"])([].concat(_toConsumableArray(selectedRows), _toConsumableArray((0, _lodash3["default"])(start, end + 1))));
|
|
98
|
+
}
|
|
99
|
+
if (_this.props.onSelect) {
|
|
100
|
+
_this.props.onSelect(selected);
|
|
98
101
|
}
|
|
99
|
-
_this.props.onSelect(selected);
|
|
100
102
|
return {
|
|
101
103
|
lastSelectedRow: index
|
|
102
104
|
};
|
|
@@ -118,15 +120,16 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
118
120
|
return;
|
|
119
121
|
}
|
|
120
122
|
_this.setState(function (state) {
|
|
123
|
+
var _this$props$selectedR2;
|
|
121
124
|
var lastSelectedRow = state.lastSelectedRow;
|
|
122
|
-
var selectedRows = _this.props.selectedRows;
|
|
125
|
+
var selectedRows = (_this$props$selectedR2 = _this.props.selectedRows) !== null && _this$props$selectedR2 !== void 0 ? _this$props$selectedR2 : [];
|
|
123
126
|
var selected = selectedRows.filter(function (idx) {
|
|
124
127
|
return idx !== index;
|
|
125
128
|
});
|
|
126
129
|
if (contiguous && typeof lastSelectedRow === 'number') {
|
|
127
130
|
var start = Math.min(lastSelectedRow, index);
|
|
128
131
|
var end = Math.max(lastSelectedRow, index);
|
|
129
|
-
var toDeselect = (0,
|
|
132
|
+
var toDeselect = (0, _lodash3["default"])(start, end + 1);
|
|
130
133
|
selected = selectedRows.filter(function (idx) {
|
|
131
134
|
return !(0, _lodash2["default"])(toDeselect, idx);
|
|
132
135
|
});
|
|
@@ -134,7 +137,9 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
134
137
|
if (_this.props.selectable === DataGrid.SINGLE_SELECT && !selected.length) {
|
|
135
138
|
return null;
|
|
136
139
|
}
|
|
137
|
-
_this.props.onSelect
|
|
140
|
+
if (_this.props.onSelect) {
|
|
141
|
+
_this.props.onSelect(selected);
|
|
142
|
+
}
|
|
138
143
|
return {
|
|
139
144
|
lastSelectedRow: index
|
|
140
145
|
};
|
|
@@ -147,12 +152,14 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
147
152
|
});
|
|
148
153
|
});
|
|
149
154
|
_defineProperty(_this, "toggleSelect", function (_ref3) {
|
|
155
|
+
var _this$props$selectedR3;
|
|
150
156
|
var index = _ref3.index,
|
|
151
157
|
contiguous = _ref3.contiguous;
|
|
152
158
|
if (index === null) {
|
|
153
159
|
return;
|
|
154
160
|
}
|
|
155
|
-
|
|
161
|
+
var selectedRows = (_this$props$selectedR3 = _this.props.selectedRows) !== null && _this$props$selectedR3 !== void 0 ? _this$props$selectedR3 : [];
|
|
162
|
+
if (!selectedRows.includes(index)) {
|
|
156
163
|
_this.select({
|
|
157
164
|
index: index,
|
|
158
165
|
contiguous: contiguous
|
|
@@ -165,32 +172,41 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
165
172
|
}
|
|
166
173
|
});
|
|
167
174
|
_defineProperty(_this, "setSelectedRows", function (rows) {
|
|
168
|
-
_this.props.onSelect
|
|
175
|
+
if (_this.props.onSelect) {
|
|
176
|
+
_this.props.onSelect(rows);
|
|
177
|
+
}
|
|
169
178
|
});
|
|
170
179
|
_defineProperty(_this, "handleFilter", function (_ref4) {
|
|
171
180
|
var sortBy = _ref4.sortBy,
|
|
172
181
|
sortDirection = _ref4.sortDirection,
|
|
173
182
|
filters = _ref4.filters;
|
|
174
183
|
var _this$props = _this.props,
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
184
|
+
_this$props$sortBy = _this$props.sortBy,
|
|
185
|
+
oldSortBy = _this$props$sortBy === void 0 ? '' : _this$props$sortBy,
|
|
186
|
+
_this$props$sortDirec = _this$props.sortDirection,
|
|
187
|
+
oldSortDirection = _this$props$sortDirec === void 0 ? _reactVirtualized.SortDirection.ASC : _this$props$sortDirec,
|
|
188
|
+
_this$props$filters = _this$props.filters,
|
|
189
|
+
oldFilters = _this$props$filters === void 0 ? {} : _this$props$filters;
|
|
178
190
|
var newData = {
|
|
179
191
|
sortBy: sortBy || oldSortBy,
|
|
180
192
|
sortDirection: sortDirection || oldSortDirection,
|
|
181
193
|
filters: _objectSpread(_objectSpread({}, oldFilters), filters)
|
|
182
194
|
};
|
|
183
|
-
_this.props.onFilter
|
|
195
|
+
if (_this.props.onFilter) {
|
|
196
|
+
_this.props.onFilter(newData);
|
|
197
|
+
}
|
|
184
198
|
});
|
|
185
199
|
_defineProperty(_this, "handleKeyDown", function (event) {
|
|
200
|
+
var _this$props$selectedR4;
|
|
186
201
|
if (_this.state.disableKeyboardShortcuts) {
|
|
187
202
|
return;
|
|
188
203
|
}
|
|
204
|
+
var selectedRows = (_this$props$selectedR4 = _this.props.selectedRows) !== null && _this$props$selectedR4 !== void 0 ? _this$props$selectedR4 : [];
|
|
189
205
|
switch (event.key) {
|
|
190
206
|
case 'a':
|
|
191
207
|
if ((event.metaKey || event.ctrlKey) && _this.props.selectable === DataGrid.MULTI_SELECT) {
|
|
192
208
|
event.preventDefault();
|
|
193
|
-
if (_this.props.rowCount ===
|
|
209
|
+
if (_this.props.rowCount === selectedRows.length) {
|
|
194
210
|
_this.deselectAll();
|
|
195
211
|
} else {
|
|
196
212
|
_this.selectAll();
|
|
@@ -243,10 +259,12 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
243
259
|
}
|
|
244
260
|
});
|
|
245
261
|
// throttling this so a double click behaves like a single click
|
|
246
|
-
_defineProperty(_this, "handleRowClick", (0,
|
|
262
|
+
_defineProperty(_this, "handleRowClick", (0, _lodash4["default"])(function (_ref5) {
|
|
263
|
+
var _this$props$allowRowE;
|
|
247
264
|
var event = _ref5.event,
|
|
248
265
|
index = _ref5.index;
|
|
249
|
-
|
|
266
|
+
var allowRowEventPassthrough = (_this$props$allowRowE = _this.props.allowRowEventPassthrough) !== null && _this$props$allowRowE !== void 0 ? _this$props$allowRowE : false;
|
|
267
|
+
if (!allowRowEventPassthrough) {
|
|
250
268
|
event.stopPropagation();
|
|
251
269
|
}
|
|
252
270
|
_this.toggleSelect({
|
|
@@ -297,14 +315,21 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
297
315
|
var validChildren = children.flat().filter(function (child) {
|
|
298
316
|
return typeof child === 'function';
|
|
299
317
|
});
|
|
318
|
+
var _this$props2 = _this.props,
|
|
319
|
+
_this$props2$filters = _this$props2.filters,
|
|
320
|
+
filters = _this$props2$filters === void 0 ? {} : _this$props2$filters,
|
|
321
|
+
_this$props2$localeSt = _this$props2.localeStrings,
|
|
322
|
+
localeStrings = _this$props2$localeSt === void 0 ? {} : _this$props2$localeSt,
|
|
323
|
+
_this$props2$locale = _this$props2.locale,
|
|
324
|
+
locale = _this$props2$locale === void 0 ? 'en' : _this$props2$locale;
|
|
300
325
|
return validChildren.map(function (child, index) {
|
|
301
326
|
return child({
|
|
302
|
-
locale:
|
|
303
|
-
localeStrings:
|
|
327
|
+
locale: locale,
|
|
328
|
+
localeStrings: localeStrings,
|
|
304
329
|
columnIndex: index,
|
|
305
330
|
columnCount: validChildren.length,
|
|
306
331
|
getFilterValue: function getFilterValue(dataKey) {
|
|
307
|
-
return
|
|
332
|
+
return filters[dataKey];
|
|
308
333
|
},
|
|
309
334
|
onHeaderPopoverOpen: function onHeaderPopoverOpen(open) {
|
|
310
335
|
return _this.setState({
|
|
@@ -343,9 +368,9 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
343
368
|
});
|
|
344
369
|
_defineProperty(_this, "isRowLoaded", function (_ref9) {
|
|
345
370
|
var index = _ref9.index;
|
|
346
|
-
var _this$
|
|
347
|
-
hasMoreRows = _this$
|
|
348
|
-
rowCount = _this$
|
|
371
|
+
var _this$props3 = _this.props,
|
|
372
|
+
hasMoreRows = _this$props3.hasMoreRows,
|
|
373
|
+
rowCount = _this$props3.rowCount;
|
|
349
374
|
return !hasMoreRows || index < rowCount;
|
|
350
375
|
});
|
|
351
376
|
_defineProperty(_this, "isContextMenuVisible", function (index) {
|
|
@@ -357,16 +382,18 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
357
382
|
});
|
|
358
383
|
});
|
|
359
384
|
_defineProperty(_this, "contextMenuRenderer", function (index) {
|
|
385
|
+
var _this$props$selectedR5;
|
|
386
|
+
var selectedRows = (_this$props$selectedR5 = _this.props.selectedRows) !== null && _this$props$selectedR5 !== void 0 ? _this$props$selectedR5 : [];
|
|
360
387
|
if (_this.props.contextMenuRenderer && _this.isContextMenuVisible(index) && document.body !== null) {
|
|
361
388
|
var contextMenuCloseWrapper = (0, _jsxRuntime.jsx)(_utils.CloseWrapper, {
|
|
362
389
|
"data-gs-c": gsC(_this.props.contextMenuRenderer(_objectSpread(_objectSpread({}, _this.state.activeContextMenu), {}, {
|
|
363
|
-
selectedRows:
|
|
390
|
+
selectedRows: selectedRows,
|
|
364
391
|
onClose: _this.closeContextMenu
|
|
365
392
|
}))),
|
|
366
393
|
"data-gs": gs("src", "datagrid", "datagrid.tsx", "data-grid", "close-wrapper"),
|
|
367
394
|
onClose: _this.closeContextMenu,
|
|
368
395
|
children: _this.props.contextMenuRenderer(_objectSpread(_objectSpread({}, _this.state.activeContextMenu), {}, {
|
|
369
|
-
selectedRows:
|
|
396
|
+
selectedRows: selectedRows,
|
|
370
397
|
onClose: _this.closeContextMenu
|
|
371
398
|
}))
|
|
372
399
|
});
|
|
@@ -388,6 +415,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
388
415
|
});
|
|
389
416
|
});
|
|
390
417
|
_defineProperty(_this, "rowRenderer", function (_ref11) {
|
|
418
|
+
var _this$props$selectedR6, _this$props$dataInst;
|
|
391
419
|
var key = _ref11.key,
|
|
392
420
|
style = _ref11.style,
|
|
393
421
|
index = _ref11.index,
|
|
@@ -396,12 +424,14 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
396
424
|
className = _ref11.className,
|
|
397
425
|
onRowMouseOver = _ref11.onRowMouseOver,
|
|
398
426
|
onRowMouseOut = _ref11.onRowMouseOut;
|
|
427
|
+
var selectedRows = (_this$props$selectedR6 = _this.props.selectedRows) !== null && _this$props$selectedR6 !== void 0 ? _this$props$selectedR6 : [];
|
|
428
|
+
var dataInstrumentation = (_this$props$dataInst = _this.props['data-instrumentation']) !== null && _this$props$dataInst !== void 0 ? _this$props$dataInst : 'datagrid';
|
|
399
429
|
return (0, _jsxRuntime.jsxs)(_components.FocusableRow, {
|
|
400
430
|
"data-gs": gs("src", "datagrid", "datagrid.tsx", "data-grid", "focusable-row"),
|
|
401
431
|
className: className,
|
|
402
432
|
"aria-rowindex": index + 1,
|
|
403
433
|
zebra: index % 2 === 1,
|
|
404
|
-
selected:
|
|
434
|
+
selected: selectedRows.includes(index),
|
|
405
435
|
selecting: _this.state.selecting,
|
|
406
436
|
focused: index === _this.state.focusedRow,
|
|
407
437
|
style: style,
|
|
@@ -424,7 +454,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
424
454
|
focusedRow: index
|
|
425
455
|
});
|
|
426
456
|
},
|
|
427
|
-
"data-instrumentation": "".concat(
|
|
457
|
+
"data-instrumentation": "".concat(dataInstrumentation, "-row").concat(index + 1),
|
|
428
458
|
onClick: _this.props.selectable && !_this.state.activeContextMenu ? function (event) {
|
|
429
459
|
return _this.handleRowClick({
|
|
430
460
|
event: event,
|
|
@@ -440,7 +470,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
440
470
|
rowData: rowData
|
|
441
471
|
}
|
|
442
472
|
});
|
|
443
|
-
if (!
|
|
473
|
+
if (!selectedRows.includes(index) && _this.props.selectable) {
|
|
444
474
|
_this.handleRowClick({
|
|
445
475
|
event: event,
|
|
446
476
|
index: index
|
|
@@ -465,18 +495,23 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
465
495
|
key: "render",
|
|
466
496
|
value: function render() {
|
|
467
497
|
var _this2 = this;
|
|
468
|
-
var _this$
|
|
469
|
-
children = _this$
|
|
470
|
-
hasMoreRows = _this$
|
|
471
|
-
height = _this$
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
498
|
+
var _this$props4 = this.props,
|
|
499
|
+
children = _this$props4.children,
|
|
500
|
+
hasMoreRows = _this$props4.hasMoreRows,
|
|
501
|
+
height = _this$props4.height,
|
|
502
|
+
_this$props4$loadMore = _this$props4.loadMoreRows,
|
|
503
|
+
loadMoreRows = _this$props4$loadMore === void 0 ? function () {
|
|
504
|
+
return Promise.resolve(false);
|
|
505
|
+
} : _this$props4$loadMore,
|
|
506
|
+
rowCount = _this$props4.rowCount,
|
|
507
|
+
_this$props4$sortBy = _this$props4.sortBy,
|
|
508
|
+
sortBy = _this$props4$sortBy === void 0 ? '' : _this$props4$sortBy,
|
|
509
|
+
_this$props4$sortDire = _this$props4.sortDirection,
|
|
510
|
+
sortDirection = _this$props4$sortDire === void 0 ? _reactVirtualized.SortDirection.ASC : _this$props4$sortDire,
|
|
511
|
+
width = _this$props4.width,
|
|
512
|
+
_this$props4$dataIns = _this$props4['data-instrumentation'],
|
|
513
|
+
dataInstrumentation = _this$props4$dataIns === void 0 ? 'datagrid' : _this$props4$dataIns,
|
|
514
|
+
props = _objectWithoutProperties(_this$props4, _excluded);
|
|
480
515
|
|
|
481
516
|
// This fixes an issue where the header of the DataGrid doesn't render on page load in Safari
|
|
482
517
|
var safariStyle = {
|
|
@@ -528,7 +563,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
528
563
|
return accumulator + flexGrow;
|
|
529
564
|
}, 0);
|
|
530
565
|
spannedColumns.push( /*#__PURE__*/(0, _react2.cloneElement)(column, {
|
|
531
|
-
'data-instrumentation': "".concat(
|
|
566
|
+
'data-instrumentation': "".concat(dataInstrumentation, "-row").concat(rowIndex, "-col").concat(index),
|
|
532
567
|
style: _objectSpread(_objectSpread({}, Elements.cellResetStyle), {}, {
|
|
533
568
|
flex: "0 1 ".concat(_width, "px"),
|
|
534
569
|
flexGrow: flexGrow
|
|
@@ -537,7 +572,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
537
572
|
index += span; // skip columns that have been spanned over
|
|
538
573
|
} else {
|
|
539
574
|
spannedColumns.push( /*#__PURE__*/(0, _react2.cloneElement)(column, {
|
|
540
|
-
'data-instrumentation': "".concat(
|
|
575
|
+
'data-instrumentation': "".concat(dataInstrumentation, "-row").concat(rowIndex, "-col").concat(index)
|
|
541
576
|
}));
|
|
542
577
|
index++;
|
|
543
578
|
}
|
|
@@ -550,10 +585,10 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
550
585
|
css: /*#__PURE__*/(0, _react.css)({
|
|
551
586
|
width: width,
|
|
552
587
|
height: height
|
|
553
|
-
}, process.env.NODE_ENV === "production" ? "" : ";label:render;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/DataGrid.tsx"],"names":[],"mappings":"AA4qBQ","file":"../../../src/DataGrid/DataGrid.tsx","sourcesContent":["import {\n  ReactNode,\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  createRef,\n  cloneElement,\n  Component\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  InfiniteLoader,\n  Table,\n  SortDirection,\n  TableRowProps\n} from 'react-virtualized'\nimport type {\n  SortDirectionType,\n  TableProps,\n  IndexRange,\n  Index,\n  RowMouseEventHandlerParams\n} from 'react-virtualized'\nimport * as Elements from './elements'\nimport * as Renderers from './renderers'\nimport {\n  BasicColumn,\n  FocusableRow,\n  InputCell,\n  CollapsibleCell,\n  ScrollableTable\n} from './components'\nimport { CloseWrapper } from '../utils'\nimport curry from 'lodash.curry'\nimport includes from 'lodash.includes'\nimport noop from 'lodash.noop'\nimport range from 'lodash.range'\nimport throttle from 'lodash.throttle'\nimport uniq from 'lodash.uniq'\nimport * as dataGridUtils from './utils'\nimport type {\n  BasicColumnMappedProps,\n  BasicColumnProps\n} from './components/BasicColumn'\nimport type { LocaleStrings } from './constants'\n\nexport type onFilterArguments = {\n  filters: { [dataKey: string]: any }\n  sortBy?: string\n  sortDirection?: SortDirectionType\n}\n\ntype activeContextMenuState = {\n  top: number\n  left: number\n  index: number\n  rowData: any\n}\n\ntype contextMenuRendererArguments = {\n  top?: number\n  left?: number\n  index?: number\n  rowData?: any\n  selectedRows: Array<number>\n  onClose: () => void\n}\n\nexport type SelectableType = 'single' | 'multi'\n\nexport type ColumnFunction = (args: BasicColumnMappedProps) => ReactNode\n\nexport type DataGridProps = {\n  /** Functions that create react virtualized Columns. Default column is exposed as DataGrid.Column. */\n  // Can take a single column or an array of columns\n  children: ColumnFunction | (ColumnFunction | ColumnFunction[])[]\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Called during the onContextMenu event of each row. */\n  contextMenuRenderer?: (\n    contextMenuRendererArguments: contextMenuRendererArguments\n  ) => ReactNode\n  /** Called when a column is filtered or sorted. */\n  onFilter: (onFilterArguments: onFilterArguments) => void\n  /** Called when a column is resized by the user. Passing this in enables\n   * resize handles on the right edge of the header cells. */\n  onResize?: (newSizes: number[]) => void\n  /** Called when the row selection changes. Receives array of indices. */\n  onSelect: (indexes: number[]) => void\n  /** Called when the row is double clicked. Receives index. */\n  onRowDoubleClick?: (info: RowMouseEventHandlerParams) => void\n  /** Infinite loading: Indicates more rows need to be loaded. */\n  hasMoreRows?: boolean\n  /** Infinite loading: Called when more rows need to be loaded. */\n  loadMoreRows?: (props: IndexRange) => Promise<any>\n  /** Count of rows that have already been loaded. */\n  rowCount: number\n  /** Required by react-virtualized table. */\n  rowGetter: (props: { index: number }) => any\n  /** Whether rows can be selected (and how many). */\n  selectable?: SelectableType | false\n  /** Array of indices that should be selected. Only used if `selectable` is set. */\n  selectedRows: Array<number>\n  /** The column you want to sort */\n  sortBy?: string\n  /** The direction sorting should be done */\n  sortDirection?: SortDirectionType\n  /** A map of columns to filter data */\n  filters?: { [dataKey: string]: any }\n  /** Set the width of scrollable content */\n  scrollWidth?: number\n  width: number\n  height: number\n  /** Locale string: ja, de, es, ko, en, etc. */\n  locale?: string\n  /** Locale strings to override en for language in locale */\n  localeStrings?: LocaleStrings\n  /** allow events to propagate to a cell on row select */\n  allowRowEventPassthrough?: boolean\n} & Partial<TableProps>\n\ntype DataGridState = {\n  activeContextMenu: activeContextMenuState | null\n  disableKeyboardShortcuts: boolean\n  focusedRow: number | null\n  selecting: boolean\n  lastSelectedRow: number | null\n}\n\ntype HandleFilterArguments = {\n  sortBy?: string\n  sortDirection?: SortDirectionType\n  filters?: any\n}\n\n/**\n * Component for displaying data in a grid with support for things like\n * filtering, sorting, and context menus.\n *\n * Depends on react-virtualized/styles.css.\n *\n * For react-virtualized Table docs see: https://github.com/bvaughn/react-virtualized/blob/master/docs/Table.md\n *\n */\nclass DataGrid extends Component<DataGridProps, DataGridState> {\n  // expose sub-components\n  static Column = curry(BasicColumn)\n  static SortDirection = SortDirection\n  static Elements = Elements\n  static InputCell = InputCell\n  static CollapsibleCell = CollapsibleCell\n  static Renderers = Renderers\n\n  static SINGLE_SELECT: SelectableType = 'single'\n  static MULTI_SELECT: SelectableType = 'multi'\n  static MIN_COL_WIDTH = 50\n\n  static utils = dataGridUtils\n\n  static defaultProps = {\n    loadMoreRows: noop,\n    onSelect: noop,\n    onFilter: noop,\n    'data-instrumentation': 'datagrid',\n    sortBy: '',\n    sortDirection: SortDirection.ASC,\n    filters: {},\n    selectedRows: [],\n    allowRowEventPassthrough: false\n  }\n\n  static displayName = 'DataGrid'\n\n  state: DataGridState = {\n    activeContextMenu: null,\n    disableKeyboardShortcuts: false,\n    focusedRow: null,\n    lastSelectedRow: null,\n    selecting: false\n  }\n\n  infiniteTable = createRef<InfiniteLoader>()\n\n  totalWidth = 0\n  columnWidthPercents: number[] = []\n\n  columnTransformer: (\n    columns: ReactElement<any>[],\n    rowData: any,\n    rowIndex: number\n  ) => ReactNode[] | null | undefined\n\n  select = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = [...selectedRows, index]\n      if (this.props.selectable === DataGrid.SINGLE_SELECT) {\n        selected = [index]\n      } else if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        selected = uniq([...selectedRows, ...range(start, end + 1)])\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  selectAll = () => {\n    const { rowCount } = this.props\n    this.setSelectedRows(Array.from({ length: rowCount }).map((_, idx) => idx))\n  }\n\n  deselect = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const { selectedRows } = this.props\n      let selected = selectedRows.filter(idx => idx !== index)\n      if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        const toDeselect = range(start, end + 1)\n        selected = selectedRows.filter(idx => !includes(toDeselect, idx))\n      }\n      if (\n        this.props.selectable === DataGrid.SINGLE_SELECT &&\n        !selected.length\n      ) {\n        return null\n      }\n      this.props.onSelect(selected)\n      return { lastSelectedRow: index }\n    })\n  }\n\n  deselectAll = () => {\n    this.setSelectedRows([])\n    this.setState({\n      lastSelectedRow: null\n    })\n  }\n\n  toggleSelect = ({\n    index,\n    contiguous\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    if (!this.props.selectedRows.includes(index)) {\n      this.select({ index, contiguous })\n    } else {\n      this.deselect({ index, contiguous })\n    }\n  }\n\n  setSelectedRows = (rows: Array<number>) => {\n    this.props.onSelect(rows)\n  }\n\n  handleFilter = ({\n    sortBy,\n    sortDirection,\n    filters\n  }: HandleFilterArguments) => {\n    const {\n      sortBy: oldSortBy,\n      sortDirection: oldSortDirection,\n      filters: oldFilters\n    } = this.props\n    const newData = {\n      sortBy: sortBy || oldSortBy,\n      sortDirection: sortDirection || oldSortDirection,\n      filters: {\n        ...oldFilters,\n        ...filters\n      }\n    }\n    this.props.onFilter(newData)\n  }\n\n  handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'a':\n        if (\n          (event.metaKey || event.ctrlKey) &&\n          this.props.selectable === DataGrid.MULTI_SELECT\n        ) {\n          event.preventDefault()\n          if (this.props.rowCount === this.props.selectedRows.length) {\n            this.deselectAll()\n          } else {\n            this.selectAll()\n          }\n        }\n        break\n      case 'ArrowUp':\n        this.setState(state => ({\n          focusedRow: Math.max((state.focusedRow || 0) - 1, 0)\n        }))\n        event.preventDefault()\n        break\n      case 'ArrowDown':\n        this.setState(state => ({\n          focusedRow:\n            state.focusedRow != null\n              ? Math.min(state.focusedRow + 1, this.props.rowCount - 1)\n              : 0\n        }))\n        event.preventDefault()\n        break\n      case 'Enter':\n      case ' ':\n        if (this.props.selectable) {\n          this.toggleSelect({\n            index: this.state.focusedRow || 0,\n            contiguous: event.shiftKey\n          })\n        }\n        event.preventDefault()\n        break\n      case 'Shift':\n        this.setState({\n          selecting: true\n        })\n        break\n    }\n  }\n\n  handleKeyUp = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'Shift':\n        this.setState({\n          selecting: false\n        })\n        break\n    }\n  }\n\n  // throttling this so a double click behaves like a single click\n  handleRowClick = throttle(\n    ({ event, index }: { event: MouseEvent<any>; index: number }) => {\n      if (!this.props.allowRowEventPassthrough) {\n        event.stopPropagation()\n      }\n\n      this.toggleSelect({ index, contiguous: event.shiftKey })\n    },\n    250,\n    { leading: true, trailing: false }\n  )\n\n  handleResize = ({ x, index }: { x: number; index: number }) => {\n    if (this.columnWidthPercents.length > 0 && this.totalWidth) {\n      const prevWidths = this.columnWidthPercents\n      const newWidths = [...prevWidths]\n      const parentWidth = this.props.scrollWidth ?? this.props.width\n      // limit next index from going beyond bounds\n      const nextIndex = Math.min(index + 1, prevWidths.length - 1)\n      const percentChange = x / this.totalWidth\n\n      if (this.props.scrollWidth) {\n        // if table is scrollable, we can grow the column without\n        // shrinking the others\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n          DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n      } else {\n        // if the table is not scrollable, ensure all columns fit by\n        // adjusting the current column and the one after it\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH ||\n          (prevWidths[nextIndex] - percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n        newWidths[nextIndex] = prevWidths[nextIndex] - safePercentChange\n      }\n\n      if (this.props.onResize) {\n        this.props.onResize(\n          // multiply by width prop to get correct percentage\n          newWidths.map(width => Math.round(width * parentWidth))\n        )\n      }\n    }\n  }\n\n  mapChildren = () => {\n    const IsArray = (\n      children\n    ): children is (ColumnFunction | ColumnFunction[])[] =>\n      Array.isArray(children)\n\n    const children: (ColumnFunction | ColumnFunction[])[] = IsArray(\n      this.props.children\n    )\n      ? this.props.children\n      : [this.props.children]\n\n    const validChildren = children\n      .flat()\n      .filter(child => typeof child === 'function')\n\n    return validChildren.map((child, index) =>\n      child({\n        locale: this.props.locale || 'en',\n        localeStrings: this.props.localeStrings || {},\n        columnIndex: index,\n        columnCount: validChildren.length,\n        getFilterValue: dataKey =>\n          this.props.filters && this.props.filters[dataKey],\n        onHeaderPopoverOpen: open =>\n          this.setState({ disableKeyboardShortcuts: open }),\n        onSort: sortArgs => {\n          this.setSelectedRows([])\n          this.handleFilter({ ...sortArgs })\n        },\n        onFilter: ({ dataKey, value, operator }) => {\n          this.setSelectedRows([])\n          this.handleFilter({\n            filters: {\n              [dataKey]: operator\n                ? {\n                    value,\n                    operator\n                  }\n                : value\n            }\n          })\n        },\n        onResize:\n          // the presence of `onResize` will show drag handles so don't set it\n          // if no prop is passed in or for the last column if the table isn't\n          // scrollable\n          this.props.onResize &&\n          ((!this.props.scrollWidth && index !== validChildren.length - 1) ||\n            this.props.scrollWidth)\n            ? ({ x }) => {\n                this.handleResize({ x, index })\n              }\n            : undefined\n      })\n    )\n  }\n\n  isRowLoaded = ({ index }: Index) => {\n    const { hasMoreRows, rowCount } = this.props\n    return !hasMoreRows || index < rowCount\n  }\n\n  isContextMenuVisible = (index: number) =>\n    this.state.activeContextMenu && this.state.activeContextMenu.index === index\n\n  closeContextMenu = () => {\n    this.setState({\n      activeContextMenu: null\n    })\n  }\n\n  contextMenuRenderer = (index: number) => {\n    if (\n      this.props.contextMenuRenderer &&\n      this.isContextMenuVisible(index) &&\n      document.body !== null\n    ) {\n      const contextMenuCloseWrapper = (\n        <CloseWrapper onClose={this.closeContextMenu}>\n          {this.props.contextMenuRenderer({\n            ...this.state.activeContextMenu,\n            selectedRows: this.props.selectedRows,\n            onClose: this.closeContextMenu\n          })}\n        </CloseWrapper>\n      )\n      return ReactDOM.createPortal(contextMenuCloseWrapper, document.body)\n    }\n    return null\n  }\n\n  headerRowRenderer = ({\n    columns,\n    style\n  }: {\n    columns: ReactNode[]\n    style: {}\n  }) => (\n    <Elements.Row role=\"row\" header zebra style={style}>\n      {columns}\n    </Elements.Row>\n  )\n\n  rowRenderer = ({\n    key,\n    style,\n    index,\n    rowData,\n    columns,\n    className,\n    onRowMouseOver,\n    onRowMouseOut\n  }: TableRowProps) => (\n    <FocusableRow\n      className={className}\n      aria-rowindex={index + 1}\n      zebra={index % 2 === 1}\n      selected={this.props.selectedRows.includes(index)}\n      selecting={this.state.selecting}\n      focused={index === this.state.focusedRow}\n      key={key}\n      style={style}\n      onMouseLeave={event => {\n        onRowMouseOut && onRowMouseOut({ rowData, index, event })\n      }}\n      onMouseEnter={event => {\n        onRowMouseOver && onRowMouseOver({ rowData, index, event })\n      }}\n      onFocus={() => this.setState({ focusedRow: index })}\n      data-instrumentation={`${this.props['data-instrumentation']}-row${\n        index + 1\n      }`}\n      onClick={\n        this.props.selectable && !this.state.activeContextMenu\n          ? event => this.handleRowClick({ event, index })\n          : undefined\n      }\n      onContextMenu={\n        this.props.contextMenuRenderer\n          ? event => {\n              this.setState({\n                activeContextMenu: {\n                  left: event.clientX,\n                  top: event.clientY,\n                  index,\n                  rowData\n                }\n              })\n              if (\n                !this.props.selectedRows.includes(index) &&\n                this.props.selectable\n              ) {\n                this.handleRowClick({ event, index })\n              }\n              event.preventDefault()\n            }\n          : undefined\n      }\n      onDoubleClick={event =>\n        this.props.onRowDoubleClick &&\n        this.props.onRowDoubleClick({ index, event, rowData })\n      }\n    >\n      {this.columnTransformer\n        ? this.columnTransformer(columns, rowData, index)\n        : columns}\n      {this.contextMenuRenderer(index)}\n    </FocusableRow>\n  )\n\n  render() {\n    const {\n      children,\n      hasMoreRows,\n      height,\n      loadMoreRows,\n      onFilter,\n      rowCount,\n      sortBy = '',\n      sortDirection,\n      width,\n      ...props\n    } = this.props\n\n    // This fixes an issue where the header of the DataGrid doesn't render on page load in Safari\n    const safariStyle = {\n      transform: `translateZ(0)`\n    }\n\n    const mappedChildren = this.mapChildren().filter(child => child !== null)\n    // TODO: Better type signature when accessing children props?\n    const spanData = mappedChildren.map((child: ReactElement) => ({\n      colspan: child.props.colspan ? child.props.colspan : () => 1,\n      width: child.props.width,\n      flexGrow: child.props.flexGrow\n    }))\n    // Get the actual width of all the columns. This is independent from the\n    // width prop.\n    this.totalWidth = mappedChildren.reduce<number>(\n      (total: number, child: ReactElement<BasicColumnProps>) =>\n        total + child.props.width,\n      0\n    )\n    // Convert the widths to percents so we can map them back to the real table\n    // width later.\n    this.columnWidthPercents = mappedChildren.map(\n      ({ props }: ReactElement) => props.width / this.totalWidth\n    )\n\n    this.columnTransformer = (\n      columns: ReactElement<any>[],\n      rowData,\n      rowIndex\n    ) => {\n      const spans = spanData.map(item => item.colspan(rowData))\n      const spannedColumns: ReactElement[] = []\n      let index = 0\n      while (index < columns.length) {\n        const span = spans[index]\n        const column = columns[index]\n        if (span > 1) {\n          const followingColumns = spanData.slice(index, span)\n          // find new width by adding current column width plus columns that are spanned over\n\n          const width = followingColumns.reduce(\n            (accumulator, { width }: { width: number }) => accumulator + width,\n            0\n          )\n\n          const flexGrow = followingColumns.reduce(\n            (accumulator, { flexGrow }: { flexGrow: number }) =>\n              accumulator + flexGrow,\n            0\n          )\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`,\n              style: {\n                ...Elements.cellResetStyle,\n                flex: `0 1 ${width}px`,\n                flexGrow\n              }\n            })\n          )\n          index += span // skip columns that have been spanned over\n        } else {\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${this.props['data-instrumentation']}-row${rowIndex}-col${index}`\n            })\n          )\n          index++\n        }\n      }\n      return spannedColumns\n    }\n\n    const TableComponent =\n      this.props.scrollWidth !== undefined ? ScrollableTable : Table\n\n    return (\n      <Elements.TableContainer\n        css={{ width, height }}\n        onKeyDown={this.handleKeyDown}\n        onKeyUp={this.handleKeyUp}\n        data-instrumentation={`${this.props['data-instrumentation']}-grid`}\n      >\n        <InfiniteLoader\n          isRowLoaded={this.isRowLoaded}\n          loadMoreRows={loadMoreRows || (() => Promise.resolve(false))}\n          rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n          threshold={5}\n          ref={this.infiniteTable}\n        >\n          {({ onRowsRendered, registerChild }) => (\n            <TableComponent\n              style={safariStyle}\n              gridStyle={{ outline: 'none' }}\n              headerHeight={36}\n              rowHeight={30}\n              sortBy={sortBy}\n              sortDirection={sortDirection}\n              ref={registerChild}\n              noRowsRendered={() => <div>No results</div>}\n              onRowsRendered={onRowsRendered}\n              onScroll={\n                this.state.activeContextMenu\n                  ? () => this.closeContextMenu()\n                  : undefined\n              }\n              rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n              headerRowRenderer={this.headerRowRenderer}\n              rowRenderer={this.rowRenderer}\n              // account for border width of container\n              width={width - 2}\n              height={height - 2}\n              {...props}\n            >\n              {mappedChildren}\n            </TableComponent>\n          )}\n        </InfiniteLoader>\n      </Elements.TableContainer>\n    )\n  }\n}\n\nexport default DataGrid\n"]} */"),
|
|
588
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:render;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/DataGrid.tsx"],"names":[],"mappings":"AA4qBQ","file":"../../../src/DataGrid/DataGrid.tsx","sourcesContent":["import {\n  ReactNode,\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  createRef,\n  cloneElement,\n  Component\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  InfiniteLoader,\n  Table,\n  SortDirection,\n  TableRowProps\n} from 'react-virtualized'\nimport type {\n  SortDirectionType,\n  TableProps,\n  IndexRange,\n  Index,\n  RowMouseEventHandlerParams\n} from 'react-virtualized'\nimport * as Elements from './elements'\nimport * as Renderers from './renderers'\nimport {\n  BasicColumn,\n  FocusableRow,\n  InputCell,\n  CollapsibleCell,\n  ScrollableTable\n} from './components'\nimport { CloseWrapper } from '../utils'\nimport curry from 'lodash.curry'\nimport includes from 'lodash.includes'\nimport range from 'lodash.range'\nimport throttle from 'lodash.throttle'\nimport uniq from 'lodash.uniq'\nimport * as dataGridUtils from './utils'\nimport type {\n  BasicColumnMappedProps,\n  BasicColumnProps\n} from './components/BasicColumn'\nimport type { LocaleStrings } from './constants'\n\nexport type onFilterArguments = {\n  filters: { [dataKey: string]: any }\n  sortBy?: string\n  sortDirection?: SortDirectionType\n}\n\ntype activeContextMenuState = {\n  top: number\n  left: number\n  index: number\n  rowData: any\n}\n\ntype contextMenuRendererArguments = {\n  top?: number\n  left?: number\n  index?: number\n  rowData?: any\n  selectedRows: Array<number>\n  onClose: () => void\n}\n\nexport type SelectableType = 'single' | 'multi'\n\nexport type ColumnFunction = (args: BasicColumnMappedProps) => ReactNode\n\nexport type DataGridProps = {\n  /** Functions that create react virtualized Columns. Default column is exposed as DataGrid.Column. */\n  // Can take a single column or an array of columns\n  children: ColumnFunction | (ColumnFunction | ColumnFunction[])[]\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Called during the onContextMenu event of each row. */\n  contextMenuRenderer?: (\n    contextMenuRendererArguments: contextMenuRendererArguments\n  ) => ReactNode\n  /** Called when a column is filtered or sorted. */\n  onFilter?: (onFilterArguments: onFilterArguments) => void\n  /** Called when a column is resized by the user. Passing this in enables\n   * resize handles on the right edge of the header cells. */\n  onResize?: (newSizes: number[]) => void\n  /** Called when the row selection changes. Receives array of indices. */\n  onSelect?: (indexes: number[]) => void\n  /** Called when the row is double clicked. Receives index. */\n  onRowDoubleClick?: (info: RowMouseEventHandlerParams) => void\n  /** Infinite loading: Indicates more rows need to be loaded. */\n  hasMoreRows?: boolean\n  /** Infinite loading: Called when more rows need to be loaded. */\n  loadMoreRows?: (props: IndexRange) => Promise<any>\n  /** Count of rows that have already been loaded. */\n  rowCount: number\n  /** Required by react-virtualized table. */\n  rowGetter: (props: { index: number }) => any\n  /** Whether rows can be selected (and how many). */\n  selectable?: SelectableType | false\n  /** Array of indices that should be selected. Only used if `selectable` is set. */\n  selectedRows?: Array<number>\n  /** The column you want to sort */\n  sortBy?: string\n  /** The direction sorting should be done */\n  sortDirection?: SortDirectionType\n  /** A map of columns to filter data */\n  filters?: { [dataKey: string]: any }\n  /** Set the width of scrollable content */\n  scrollWidth?: number\n  width: number\n  height: number\n  /** Locale string: ja, de, es, ko, en, etc. */\n  locale?: string\n  /** Locale strings to override en for language in locale */\n  localeStrings?: LocaleStrings\n  /** allow events to propagate to a cell on row select */\n  allowRowEventPassthrough?: boolean\n} & Partial<TableProps>\n\ntype DataGridState = {\n  activeContextMenu: activeContextMenuState | null\n  disableKeyboardShortcuts: boolean\n  focusedRow: number | null\n  selecting: boolean\n  lastSelectedRow: number | null\n}\n\ntype HandleFilterArguments = {\n  sortBy?: string\n  sortDirection?: SortDirectionType\n  filters?: any\n}\n\n/**\n * Component for displaying data in a grid with support for things like\n * filtering, sorting, and context menus.\n *\n * Depends on react-virtualized/styles.css.\n *\n * For react-virtualized Table docs see: https://github.com/bvaughn/react-virtualized/blob/master/docs/Table.md\n *\n */\nclass DataGrid extends Component<DataGridProps, DataGridState> {\n  // expose sub-components\n  static Column = curry(BasicColumn)\n  static SortDirection = SortDirection\n  static Elements = Elements\n  static InputCell = InputCell\n  static CollapsibleCell = CollapsibleCell\n  static Renderers = Renderers\n\n  static SINGLE_SELECT: SelectableType = 'single'\n  static MULTI_SELECT: SelectableType = 'multi'\n  static MIN_COL_WIDTH = 50\n\n  static utils = dataGridUtils\n\n  static displayName = 'DataGrid'\n\n  state: DataGridState = {\n    activeContextMenu: null,\n    disableKeyboardShortcuts: false,\n    focusedRow: null,\n    lastSelectedRow: null,\n    selecting: false\n  }\n\n  infiniteTable = createRef<InfiniteLoader>()\n\n  totalWidth = 0\n  columnWidthPercents: number[] = []\n\n  columnTransformer: (\n    columns: ReactElement<any>[],\n    rowData: any,\n    rowIndex: number\n  ) => ReactNode[] | null | undefined\n\n  select = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const selectedRows = this.props.selectedRows ?? []\n      let selected = [...selectedRows, index]\n      if (this.props.selectable === DataGrid.SINGLE_SELECT) {\n        selected = [index]\n      } else if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        selected = uniq([...selectedRows, ...range(start, end + 1)])\n      }\n      if (this.props.onSelect) {\n        this.props.onSelect(selected)\n      }\n      return { lastSelectedRow: index }\n    })\n  }\n\n  selectAll = () => {\n    const { rowCount } = this.props\n    this.setSelectedRows(Array.from({ length: rowCount }).map((_, idx) => idx))\n  }\n\n  deselect = ({\n    index,\n    contiguous = false\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    this.setState(state => {\n      const { lastSelectedRow } = state\n      const selectedRows = this.props.selectedRows ?? []\n      let selected = selectedRows.filter(idx => idx !== index)\n      if (contiguous && typeof lastSelectedRow === 'number') {\n        const start = Math.min(lastSelectedRow, index)\n        const end = Math.max(lastSelectedRow, index)\n        const toDeselect = range(start, end + 1)\n        selected = selectedRows.filter(idx => !includes(toDeselect, idx))\n      }\n      if (\n        this.props.selectable === DataGrid.SINGLE_SELECT &&\n        !selected.length\n      ) {\n        return null\n      }\n      if (this.props.onSelect) {\n        this.props.onSelect(selected)\n      }\n      return { lastSelectedRow: index }\n    })\n  }\n\n  deselectAll = () => {\n    this.setSelectedRows([])\n    this.setState({\n      lastSelectedRow: null\n    })\n  }\n\n  toggleSelect = ({\n    index,\n    contiguous\n  }: {\n    index: number\n    contiguous: boolean\n  }) => {\n    if (index === null) {\n      return\n    }\n    const selectedRows = this.props.selectedRows ?? []\n    if (!selectedRows.includes(index)) {\n      this.select({ index, contiguous })\n    } else {\n      this.deselect({ index, contiguous })\n    }\n  }\n\n  setSelectedRows = (rows: Array<number>) => {\n    if (this.props.onSelect) {\n      this.props.onSelect(rows)\n    }\n  }\n\n  handleFilter = ({\n    sortBy,\n    sortDirection,\n    filters\n  }: HandleFilterArguments) => {\n    const {\n      sortBy: oldSortBy = '',\n      sortDirection: oldSortDirection = SortDirection.ASC,\n      filters: oldFilters = {}\n    } = this.props\n    const newData = {\n      sortBy: sortBy || oldSortBy,\n      sortDirection: sortDirection || oldSortDirection,\n      filters: {\n        ...oldFilters,\n        ...filters\n      }\n    }\n    if (this.props.onFilter) {\n      this.props.onFilter(newData)\n    }\n  }\n\n  handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    const selectedRows = this.props.selectedRows ?? []\n    switch (event.key) {\n      case 'a':\n        if (\n          (event.metaKey || event.ctrlKey) &&\n          this.props.selectable === DataGrid.MULTI_SELECT\n        ) {\n          event.preventDefault()\n          if (this.props.rowCount === selectedRows.length) {\n            this.deselectAll()\n          } else {\n            this.selectAll()\n          }\n        }\n        break\n      case 'ArrowUp':\n        this.setState(state => ({\n          focusedRow: Math.max((state.focusedRow || 0) - 1, 0)\n        }))\n        event.preventDefault()\n        break\n      case 'ArrowDown':\n        this.setState(state => ({\n          focusedRow:\n            state.focusedRow != null\n              ? Math.min(state.focusedRow + 1, this.props.rowCount - 1)\n              : 0\n        }))\n        event.preventDefault()\n        break\n      case 'Enter':\n      case ' ':\n        if (this.props.selectable) {\n          this.toggleSelect({\n            index: this.state.focusedRow || 0,\n            contiguous: event.shiftKey\n          })\n        }\n        event.preventDefault()\n        break\n      case 'Shift':\n        this.setState({\n          selecting: true\n        })\n        break\n    }\n  }\n\n  handleKeyUp = (event: KeyboardEvent<HTMLDivElement>) => {\n    if (this.state.disableKeyboardShortcuts) {\n      return\n    }\n    switch (event.key) {\n      case 'Shift':\n        this.setState({\n          selecting: false\n        })\n        break\n    }\n  }\n\n  // throttling this so a double click behaves like a single click\n  handleRowClick = throttle(\n    ({ event, index }: { event: MouseEvent<any>; index: number }) => {\n      const allowRowEventPassthrough =\n        this.props.allowRowEventPassthrough ?? false\n      if (!allowRowEventPassthrough) {\n        event.stopPropagation()\n      }\n\n      this.toggleSelect({ index, contiguous: event.shiftKey })\n    },\n    250,\n    { leading: true, trailing: false }\n  )\n\n  handleResize = ({ x, index }: { x: number; index: number }) => {\n    if (this.columnWidthPercents.length > 0 && this.totalWidth) {\n      const prevWidths = this.columnWidthPercents\n      const newWidths = [...prevWidths]\n      const parentWidth = this.props.scrollWidth ?? this.props.width\n      // limit next index from going beyond bounds\n      const nextIndex = Math.min(index + 1, prevWidths.length - 1)\n      const percentChange = x / this.totalWidth\n\n      if (this.props.scrollWidth) {\n        // if table is scrollable, we can grow the column without\n        // shrinking the others\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n          DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n      } else {\n        // if the table is not scrollable, ensure all columns fit by\n        // adjusting the current column and the one after it\n        const safePercentChange =\n          (prevWidths[index] + percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH ||\n          (prevWidths[nextIndex] - percentChange) * parentWidth <\n            DataGrid.MIN_COL_WIDTH\n            ? 0\n            : percentChange\n        newWidths[index] = prevWidths[index] + safePercentChange\n        newWidths[nextIndex] = prevWidths[nextIndex] - safePercentChange\n      }\n\n      if (this.props.onResize) {\n        this.props.onResize(\n          // multiply by width prop to get correct percentage\n          newWidths.map(width => Math.round(width * parentWidth))\n        )\n      }\n    }\n  }\n\n  mapChildren = () => {\n    const IsArray = (\n      children\n    ): children is (ColumnFunction | ColumnFunction[])[] =>\n      Array.isArray(children)\n\n    const children: (ColumnFunction | ColumnFunction[])[] = IsArray(\n      this.props.children\n    )\n      ? this.props.children\n      : [this.props.children]\n\n    const validChildren = children\n      .flat()\n      .filter(child => typeof child === 'function')\n\n    const { filters = {}, localeStrings = {}, locale = 'en' } = this.props\n\n    return validChildren.map((child, index) =>\n      child({\n        locale,\n        localeStrings,\n        columnIndex: index,\n        columnCount: validChildren.length,\n        getFilterValue: dataKey => filters[dataKey],\n        onHeaderPopoverOpen: open =>\n          this.setState({ disableKeyboardShortcuts: open }),\n        onSort: sortArgs => {\n          this.setSelectedRows([])\n          this.handleFilter({ ...sortArgs })\n        },\n        onFilter: ({ dataKey, value, operator }) => {\n          this.setSelectedRows([])\n          this.handleFilter({\n            filters: {\n              [dataKey]: operator\n                ? {\n                    value,\n                    operator\n                  }\n                : value\n            }\n          })\n        },\n        onResize:\n          // the presence of `onResize` will show drag handles so don't set it\n          // if no prop is passed in or for the last column if the table isn't\n          // scrollable\n          this.props.onResize &&\n          ((!this.props.scrollWidth && index !== validChildren.length - 1) ||\n            this.props.scrollWidth)\n            ? ({ x }) => {\n                this.handleResize({ x, index })\n              }\n            : undefined\n      })\n    )\n  }\n\n  isRowLoaded = ({ index }: Index) => {\n    const { hasMoreRows, rowCount } = this.props\n    return !hasMoreRows || index < rowCount\n  }\n\n  isContextMenuVisible = (index: number) =>\n    this.state.activeContextMenu && this.state.activeContextMenu.index === index\n\n  closeContextMenu = () => {\n    this.setState({\n      activeContextMenu: null\n    })\n  }\n\n  contextMenuRenderer = (index: number) => {\n    const selectedRows = this.props.selectedRows ?? []\n    if (\n      this.props.contextMenuRenderer &&\n      this.isContextMenuVisible(index) &&\n      document.body !== null\n    ) {\n      const contextMenuCloseWrapper = (\n        <CloseWrapper onClose={this.closeContextMenu}>\n          {this.props.contextMenuRenderer({\n            ...this.state.activeContextMenu,\n            selectedRows,\n            onClose: this.closeContextMenu\n          })}\n        </CloseWrapper>\n      )\n      return ReactDOM.createPortal(contextMenuCloseWrapper, document.body)\n    }\n    return null\n  }\n\n  headerRowRenderer = ({\n    columns,\n    style\n  }: {\n    columns: ReactNode[]\n    style: {}\n  }) => (\n    <Elements.Row role=\"row\" header zebra style={style}>\n      {columns}\n    </Elements.Row>\n  )\n\n  rowRenderer = ({\n    key,\n    style,\n    index,\n    rowData,\n    columns,\n    className,\n    onRowMouseOver,\n    onRowMouseOut\n  }: TableRowProps) => {\n    const selectedRows = this.props.selectedRows ?? []\n    const dataInstrumentation = this.props['data-instrumentation'] ?? 'datagrid'\n    return (\n      <FocusableRow\n        className={className}\n        aria-rowindex={index + 1}\n        zebra={index % 2 === 1}\n        selected={selectedRows.includes(index)}\n        selecting={this.state.selecting}\n        focused={index === this.state.focusedRow}\n        key={key}\n        style={style}\n        onMouseLeave={event => {\n          onRowMouseOut && onRowMouseOut({ rowData, index, event })\n        }}\n        onMouseEnter={event => {\n          onRowMouseOver && onRowMouseOver({ rowData, index, event })\n        }}\n        onFocus={() => this.setState({ focusedRow: index })}\n        data-instrumentation={`${dataInstrumentation}-row${index + 1}`}\n        onClick={\n          this.props.selectable && !this.state.activeContextMenu\n            ? event => this.handleRowClick({ event, index })\n            : undefined\n        }\n        onContextMenu={\n          this.props.contextMenuRenderer\n            ? event => {\n                this.setState({\n                  activeContextMenu: {\n                    left: event.clientX,\n                    top: event.clientY,\n                    index,\n                    rowData\n                  }\n                })\n                if (!selectedRows.includes(index) && this.props.selectable) {\n                  this.handleRowClick({ event, index })\n                }\n                event.preventDefault()\n              }\n            : undefined\n        }\n        onDoubleClick={event =>\n          this.props.onRowDoubleClick &&\n          this.props.onRowDoubleClick({ index, event, rowData })\n        }\n      >\n        {this.columnTransformer\n          ? this.columnTransformer(columns, rowData, index)\n          : columns}\n        {this.contextMenuRenderer(index)}\n      </FocusableRow>\n    )\n  }\n\n  render() {\n    const {\n      children,\n      hasMoreRows,\n      height,\n      loadMoreRows = () => Promise.resolve(false),\n      rowCount,\n      sortBy = '',\n      sortDirection = SortDirection.ASC,\n      width,\n      'data-instrumentation': dataInstrumentation = 'datagrid',\n      ...props\n    } = this.props\n\n    // This fixes an issue where the header of the DataGrid doesn't render on page load in Safari\n    const safariStyle = {\n      transform: `translateZ(0)`\n    }\n\n    const mappedChildren = this.mapChildren().filter(child => child !== null)\n    // TODO: Better type signature when accessing children props?\n    const spanData = mappedChildren.map((child: ReactElement) => ({\n      colspan: child.props.colspan ? child.props.colspan : () => 1,\n      width: child.props.width,\n      flexGrow: child.props.flexGrow\n    }))\n    // Get the actual width of all the columns. This is independent from the\n    // width prop.\n    this.totalWidth = mappedChildren.reduce<number>(\n      (total: number, child: ReactElement<BasicColumnProps>) =>\n        total + child.props.width,\n      0\n    )\n    // Convert the widths to percents so we can map them back to the real table\n    // width later.\n    this.columnWidthPercents = mappedChildren.map(\n      ({ props }: ReactElement) => props.width / this.totalWidth\n    )\n\n    this.columnTransformer = (\n      columns: ReactElement<any>[],\n      rowData,\n      rowIndex\n    ) => {\n      const spans = spanData.map(item => item.colspan(rowData))\n      const spannedColumns: ReactElement[] = []\n      let index = 0\n      while (index < columns.length) {\n        const span = spans[index]\n        const column = columns[index]\n        if (span > 1) {\n          const followingColumns = spanData.slice(index, span)\n          // find new width by adding current column width plus columns that are spanned over\n\n          const width = followingColumns.reduce(\n            (accumulator, { width }: { width: number }) => accumulator + width,\n            0\n          )\n\n          const flexGrow = followingColumns.reduce(\n            (accumulator, { flexGrow }: { flexGrow: number }) =>\n              accumulator + flexGrow,\n            0\n          )\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${dataInstrumentation}-row${rowIndex}-col${index}`,\n              style: {\n                ...Elements.cellResetStyle,\n                flex: `0 1 ${width}px`,\n                flexGrow\n              }\n            })\n          )\n          index += span // skip columns that have been spanned over\n        } else {\n          spannedColumns.push(\n            cloneElement(column, {\n              'data-instrumentation': `${dataInstrumentation}-row${rowIndex}-col${index}`\n            })\n          )\n          index++\n        }\n      }\n      return spannedColumns\n    }\n\n    const TableComponent =\n      this.props.scrollWidth !== undefined ? ScrollableTable : Table\n\n    return (\n      <Elements.TableContainer\n        css={{ width, height }}\n        onKeyDown={this.handleKeyDown}\n        onKeyUp={this.handleKeyUp}\n        data-instrumentation={`${dataInstrumentation}-grid`}\n      >\n        <InfiniteLoader\n          isRowLoaded={this.isRowLoaded}\n          loadMoreRows={loadMoreRows}\n          rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n          threshold={5}\n          ref={this.infiniteTable}\n        >\n          {({ onRowsRendered, registerChild }) => (\n            <TableComponent\n              style={safariStyle}\n              gridStyle={{ outline: 'none' }}\n              headerHeight={36}\n              rowHeight={30}\n              sortBy={sortBy}\n              sortDirection={sortDirection}\n              ref={registerChild}\n              noRowsRendered={() => <div>No results</div>}\n              onRowsRendered={onRowsRendered}\n              onScroll={\n                this.state.activeContextMenu\n                  ? () => this.closeContextMenu()\n                  : undefined\n              }\n              rowCount={hasMoreRows ? rowCount + 1 : rowCount}\n              headerRowRenderer={this.headerRowRenderer}\n              rowRenderer={this.rowRenderer}\n              // account for border width of container\n              width={width - 2}\n              height={height - 2}\n              {...props}\n            >\n              {mappedChildren}\n            </TableComponent>\n          )}\n        </InfiniteLoader>\n      </Elements.TableContainer>\n    )\n  }\n}\n\nexport default DataGrid\n"]} */"),
|
|
554
589
|
onKeyDown: this.handleKeyDown,
|
|
555
590
|
onKeyUp: this.handleKeyUp,
|
|
556
|
-
"data-instrumentation": "".concat(
|
|
591
|
+
"data-instrumentation": "".concat(dataInstrumentation, "-grid"),
|
|
557
592
|
children: (0, _jsxRuntime.jsx)(_reactVirtualized.InfiniteLoader, {
|
|
558
593
|
"data-gs-c": gsC(function children(_ref15) {
|
|
559
594
|
var onRowsRendered = _ref15.onRowsRendered,
|
|
@@ -594,9 +629,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
|
|
|
594
629
|
}),
|
|
595
630
|
"data-gs": gs("src", "datagrid", "datagrid.tsx", "elements-tablecontainer", "infinite-loader"),
|
|
596
631
|
isRowLoaded: this.isRowLoaded,
|
|
597
|
-
loadMoreRows: loadMoreRows
|
|
598
|
-
return Promise.resolve(false);
|
|
599
|
-
},
|
|
632
|
+
loadMoreRows: loadMoreRows,
|
|
600
633
|
rowCount: hasMoreRows ? rowCount + 1 : rowCount,
|
|
601
634
|
threshold: 5,
|
|
602
635
|
ref: this.infiniteTable,
|
|
@@ -651,16 +684,5 @@ _defineProperty(DataGrid, "SINGLE_SELECT", 'single');
|
|
|
651
684
|
_defineProperty(DataGrid, "MULTI_SELECT", 'multi');
|
|
652
685
|
_defineProperty(DataGrid, "MIN_COL_WIDTH", 50);
|
|
653
686
|
_defineProperty(DataGrid, "utils", dataGridUtils);
|
|
654
|
-
_defineProperty(DataGrid, "defaultProps", {
|
|
655
|
-
loadMoreRows: _lodash3["default"],
|
|
656
|
-
onSelect: _lodash3["default"],
|
|
657
|
-
onFilter: _lodash3["default"],
|
|
658
|
-
'data-instrumentation': 'datagrid',
|
|
659
|
-
sortBy: '',
|
|
660
|
-
sortDirection: _reactVirtualized.SortDirection.ASC,
|
|
661
|
-
filters: {},
|
|
662
|
-
selectedRows: [],
|
|
663
|
-
allowRowEventPassthrough: false
|
|
664
|
-
});
|
|
665
687
|
_defineProperty(DataGrid, "displayName", 'DataGrid');
|
|
666
688
|
var _default = exports["default"] = DataGrid;
|
|
@@ -23,8 +23,8 @@ type ColumnHeaderProps = {
|
|
|
23
23
|
filterValue: any;
|
|
24
24
|
filterRenderer?: ((arg0: filterRendererArguments) => ReactNode) | false | null;
|
|
25
25
|
sortRenderer?: ((arg0: sortRendererArguments) => ReactNode) | false | null;
|
|
26
|
-
sortAscIcon
|
|
27
|
-
sortDescIcon
|
|
26
|
+
sortAscIcon?: ReactNode;
|
|
27
|
+
sortDescIcon?: ReactNode;
|
|
28
28
|
sortBy?: string;
|
|
29
29
|
/** Locale */
|
|
30
30
|
locale?: string;
|
|
@@ -40,10 +40,6 @@ type ColumnHeaderState = {
|
|
|
40
40
|
* Component that renders a column header. Responsible for sorting and filtering.
|
|
41
41
|
*/
|
|
42
42
|
declare class ColumnHeader extends Component<ColumnHeaderProps, ColumnHeaderState> {
|
|
43
|
-
static defaultProps: {
|
|
44
|
-
sortAscIcon: import("@emotion/react/jsx-runtime").JSX.Element;
|
|
45
|
-
sortDescIcon: import("@emotion/react/jsx-runtime").JSX.Element;
|
|
46
|
-
};
|
|
47
43
|
state: {
|
|
48
44
|
opened: boolean;
|
|
49
45
|
isFiltering: boolean;
|
|
@@ -99,8 +99,14 @@ var ColumnHeader = /*#__PURE__*/function (_Component) {
|
|
|
99
99
|
_this$props$showSortI = _this$props.showSortIndicator,
|
|
100
100
|
showSortIndicator = _this$props$showSortI === void 0 ? false : _this$props$showSortI,
|
|
101
101
|
sortDirection = _this$props.sortDirection,
|
|
102
|
-
|
|
103
|
-
|
|
102
|
+
_this$props$sortAscIc = _this$props.sortAscIcon,
|
|
103
|
+
sortAscIcon = _this$props$sortAscIc === void 0 ? (0, _jsxRuntime.jsx)(_Icon["default"].Medium.ToolSortAsc, {
|
|
104
|
+
"data-gs": gs("src", "datagrid", "components", "icon-medium-tool-sort-asc")
|
|
105
|
+
}) : _this$props$sortAscIc,
|
|
106
|
+
_this$props$sortDescI = _this$props.sortDescIcon,
|
|
107
|
+
sortDescIcon = _this$props$sortDescI === void 0 ? (0, _jsxRuntime.jsx)(_Icon["default"].Medium.ToolSortDesc, {
|
|
108
|
+
"data-gs": gs("src", "datagrid", "components", "icon-medium-tool-sort-desc")
|
|
109
|
+
}) : _this$props$sortDescI,
|
|
104
110
|
onSort = _this$props.onSort,
|
|
105
111
|
onFilter = _this$props.onFilter,
|
|
106
112
|
onResize = _this$props.onResize,
|
|
@@ -198,12 +204,4 @@ var ColumnHeader = /*#__PURE__*/function (_Component) {
|
|
|
198
204
|
}
|
|
199
205
|
}]);
|
|
200
206
|
}(_react.Component);
|
|
201
|
-
_defineProperty(ColumnHeader, "defaultProps", {
|
|
202
|
-
sortAscIcon: (0, _jsxRuntime.jsx)(_Icon["default"].Medium.ToolSortAsc, {
|
|
203
|
-
"data-gs": gs("src", "datagrid", "components", "icon-medium-tool-sort-asc")
|
|
204
|
-
}),
|
|
205
|
-
sortDescIcon: (0, _jsxRuntime.jsx)(_Icon["default"].Medium.ToolSortDesc, {
|
|
206
|
-
"data-gs": gs("src", "datagrid", "components", "icon-medium-tool-sort-desc")
|
|
207
|
-
})
|
|
208
|
-
});
|
|
209
207
|
var _default = exports["default"] = ColumnHeader;
|
|
@@ -65,7 +65,7 @@ var FocusableRow = /*#__PURE__*/function (_Component) {
|
|
|
65
65
|
value: function render() {
|
|
66
66
|
return (0, _jsxRuntime.jsx)(_elements.Row, _objectSpread(_objectSpread({
|
|
67
67
|
"data-gs": gs("src", "datagrid", "components", "row"),
|
|
68
|
-
|
|
68
|
+
"data-testid": "data-grid-focusable-row",
|
|
69
69
|
tabIndex: this.props.onClick && (this.props.focused ? 0 : -1)
|
|
70
70
|
}, this.props), {}, {
|
|
71
71
|
ref: this.element
|
|
@@ -29,21 +29,6 @@ declare class ScrollableTable extends React.PureComponent<TableProps, Scrollable
|
|
|
29
29
|
constructor(props: TableProps);
|
|
30
30
|
componentDidMount(): void;
|
|
31
31
|
componentDidUpdate(): void;
|
|
32
|
-
static defaultProps: {
|
|
33
|
-
disableHeader: boolean;
|
|
34
|
-
estimatedRowSize: number;
|
|
35
|
-
headerHeight: number;
|
|
36
|
-
headerStyle: {};
|
|
37
|
-
noRowsRenderer: () => null;
|
|
38
|
-
onRowsRendered: () => null;
|
|
39
|
-
onScroll: () => null;
|
|
40
|
-
overscanIndicesGetter: import("react-virtualized/dist/es/Grid").OverscanIndicesGetter;
|
|
41
|
-
overscanRowCount: number;
|
|
42
|
-
rowStyle: {};
|
|
43
|
-
scrollToAlignment: string;
|
|
44
|
-
scrollToIndex: number;
|
|
45
|
-
style: {};
|
|
46
|
-
};
|
|
47
32
|
render(): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
48
33
|
createColumn: ({ column, columnIndex, isScrolling, parent, rowData, rowIndex }: {
|
|
49
34
|
column: React.ReactElement<ColumnProps>;
|