material-react-table 0.12.2 → 0.13.2

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.
@@ -1,5 +1,5 @@
1
1
  import React, { useMemo, forwardRef, useState, useCallback, Fragment, useLayoutEffect, useEffect } from 'react';
2
- import { ArrowRight, Cancel, CheckBox, ClearAll, Close, DensityMedium, DensitySmall, KeyboardDoubleArrowDown, DragHandle, DynamicFeed, Edit, ExpandLess, ExpandMore, FilterAlt, FilterAltOff, FilterList, FilterListOff, FullscreenExit, Fullscreen, MoreHoriz, MoreVert, PushPin, RestartAlt, Save, Search, SearchOff, Sort, ViewColumn, VisibilityOff } from '@mui/icons-material';
2
+ import { ArrowRight, Cancel, CheckBox, ClearAll, Close, DensityLarge, DensityMedium, DensitySmall, DragHandle, DynamicFeed, Edit, ExpandLess, ExpandMore, FilterAlt, FilterAltOff, FilterList, FilterListOff, FullscreenExit, Fullscreen, KeyboardDoubleArrowDown, MoreHoriz, MoreVert, PushPin, RestartAlt, Save, Search, SearchOff, Sort, ViewColumn, VisibilityOff } from '@mui/icons-material';
3
3
  import { createTable, getCoreRowModel, getExpandedRowModel, getFacetedRowModel, getFilteredRowModel, getGroupedRowModel, getPaginationRowModel, getSortedRowModel, useTableInstance } from '@tanstack/react-table';
4
4
  import { Tooltip, IconButton, Menu, MenuItem, Box, FormControlLabel, Switch, Button, Divider, ListItemIcon, Checkbox, debounce, Collapse, TextField, InputAdornment, TablePagination, Chip, Alert, LinearProgress, useMediaQuery, Toolbar, lighten, alpha, TableSortLabel, TableCell, TableRow, TableHead, darken, Skeleton, TableBody, TableFooter, Table, TableContainer, Paper, Dialog, Grow } from '@mui/material';
5
5
  import { rankItem, rankings } from '@tanstack/match-sorter-utils';
@@ -101,7 +101,7 @@ var MRT_DefaultLocalization_EN = {
101
101
  sortedByColumnDesc: 'Sorted by {column} descending',
102
102
  thenBy: ', then by ',
103
103
  to: 'to',
104
- toggleDensePadding: 'Toggle dense padding',
104
+ toggleDensity: 'Toggle density',
105
105
  toggleFullScreen: 'Toggle full screen',
106
106
  toggleSelectAll: 'Toggle select all',
107
107
  toggleSelectRow: 'Toggle select row',
@@ -117,9 +117,9 @@ var MRT_Default_Icons = {
117
117
  CheckBoxIcon: CheckBox,
118
118
  ClearAllIcon: ClearAll,
119
119
  CloseIcon: Close,
120
+ DensityLargeIcon: DensityLarge,
120
121
  DensityMediumIcon: DensityMedium,
121
122
  DensitySmallIcon: DensitySmall,
122
- KeyboardDoubleArrowDownIcon: KeyboardDoubleArrowDown,
123
123
  DragHandleIcon: DragHandle,
124
124
  DynamicFeedIcon: DynamicFeed,
125
125
  EditIcon: Edit,
@@ -131,6 +131,7 @@ var MRT_Default_Icons = {
131
131
  FilterListOffIcon: FilterListOff,
132
132
  FullscreenExitIcon: FullscreenExit,
133
133
  FullscreenIcon: Fullscreen,
134
+ KeyboardDoubleArrowDownIcon: KeyboardDoubleArrowDown,
134
135
  MoreHorizIcon: MoreHoriz,
135
136
  MoreVertIcon: MoreVert,
136
137
  PushPinIcon: PushPin,
@@ -152,28 +153,33 @@ var MRT_ExpandAllButton = function MRT_ExpandAllButton(_ref) {
152
153
  _instance$options = instance.options,
153
154
  KeyboardDoubleArrowDownIcon = _instance$options.icons.KeyboardDoubleArrowDownIcon,
154
155
  localization = _instance$options.localization,
156
+ muiExpandAllButtonProps = _instance$options.muiExpandAllButtonProps,
155
157
  renderDetailPanel = _instance$options.renderDetailPanel,
156
158
  toggleAllRowsExpanded = instance.toggleAllRowsExpanded;
157
159
 
158
160
  var _getState = getState(),
159
- isDensePadding = _getState.isDensePadding;
161
+ density = _getState.density;
160
162
 
163
+ var iconButtonProps = muiExpandAllButtonProps instanceof Function ? muiExpandAllButtonProps({
164
+ instance: instance
165
+ }) : muiExpandAllButtonProps;
161
166
  return React.createElement(Tooltip, {
162
167
  arrow: true,
163
168
  enterDelay: 1000,
164
169
  enterNextDelay: 1000,
165
170
  title: localization.expandAll
166
- }, React.createElement(IconButton, {
171
+ }, React.createElement(IconButton, Object.assign({
167
172
  "aria-label": localization.expandAll,
168
173
  disabled: !getCanSomeRowsExpand() && !renderDetailPanel,
169
174
  onClick: function onClick() {
170
175
  return toggleAllRowsExpanded(!getIsAllRowsExpanded());
171
- },
172
- sx: {
173
- height: isDensePadding ? '1.75rem' : '2.25rem',
174
- width: isDensePadding ? '1.75rem' : '2.25rem'
175
176
  }
176
- }, React.createElement(KeyboardDoubleArrowDownIcon, {
177
+ }, iconButtonProps, {
178
+ sx: _extends({
179
+ height: density === 'compact' ? '1.75rem' : '2.25rem',
180
+ width: density === 'compact' ? '1.75rem' : '2.25rem'
181
+ }, iconButtonProps == null ? void 0 : iconButtonProps.sx)
182
+ }), React.createElement(KeyboardDoubleArrowDownIcon, {
177
183
  style: {
178
184
  transform: "rotate(" + (getIsAllRowsExpanded() ? -180 : getIsSomeRowsExpanded() ? -90 : 0) + "deg)",
179
185
  transition: 'transform 0.2s'
@@ -188,11 +194,17 @@ var MRT_ExpandButton = function MRT_ExpandButton(_ref) {
188
194
  _instance$options = instance.options,
189
195
  ExpandMoreIcon = _instance$options.icons.ExpandMoreIcon,
190
196
  localization = _instance$options.localization,
197
+ muiExpandButtonProps = _instance$options.muiExpandButtonProps,
191
198
  onExpandChanged = _instance$options.onExpandChanged,
192
199
  renderDetailPanel = _instance$options.renderDetailPanel;
193
200
 
194
201
  var _getState = getState(),
195
- isDensePadding = _getState.isDensePadding;
202
+ density = _getState.density;
203
+
204
+ var iconButtonProps = muiExpandButtonProps instanceof Function ? muiExpandButtonProps({
205
+ instance: instance,
206
+ row: row
207
+ }) : muiExpandButtonProps;
196
208
 
197
209
  var handleToggleExpand = function handleToggleExpand(event) {
198
210
  row.toggleExpanded();
@@ -208,15 +220,16 @@ var MRT_ExpandButton = function MRT_ExpandButton(_ref) {
208
220
  enterDelay: 1000,
209
221
  enterNextDelay: 1000,
210
222
  title: localization.expand
211
- }, React.createElement(IconButton, {
223
+ }, React.createElement(IconButton, Object.assign({
212
224
  "aria-label": localization.expand,
213
225
  disabled: !row.getCanExpand() && !renderDetailPanel,
214
- onClick: handleToggleExpand,
215
- sx: {
216
- height: isDensePadding ? '1.75rem' : '2.25rem',
217
- width: isDensePadding ? '1.75rem' : '2.25rem'
218
- }
219
- }, React.createElement(ExpandMoreIcon, {
226
+ onClick: handleToggleExpand
227
+ }, iconButtonProps, {
228
+ sx: _extends({
229
+ height: density === 'compact' ? '1.75rem' : '2.25rem',
230
+ width: density === 'compact' ? '1.75rem' : '2.25rem'
231
+ }, iconButtonProps == null ? void 0 : iconButtonProps.sx)
232
+ }), React.createElement(ExpandMoreIcon, {
220
233
  style: {
221
234
  transform: "rotate(" + (!row.getCanExpand() && !renderDetailPanel ? -90 : row.getIsExpanded() ? -180 : 0) + "deg)",
222
235
  transition: 'transform 0.2s'
@@ -352,7 +365,7 @@ var MRT_FilterOptionMenu = function MRT_FilterOptionMenu(_ref) {
352
365
  setCurrentGlobalFilterFn = instance.setCurrentGlobalFilterFn;
353
366
 
354
367
  var _getState = getState(),
355
- isDensePadding = _getState.isDensePadding,
368
+ density = _getState.density,
356
369
  currentFilterFns = _getState.currentFilterFns,
357
370
  currentGlobalFilterFn = _getState.currentGlobalFilterFn;
358
371
 
@@ -459,7 +472,7 @@ var MRT_FilterOptionMenu = function MRT_FilterOptionMenu(_ref) {
459
472
  },
460
473
  open: !!anchorEl,
461
474
  MenuListProps: {
462
- dense: isDensePadding
475
+ dense: density === 'compact'
463
476
  }
464
477
  }, filterOptions.map(function (_ref4, index) {
465
478
  var option = _ref4.option,
@@ -755,7 +768,7 @@ var MRT_ShowHideColumnsMenu = function MRT_ShowHideColumnsMenu(_ref) {
755
768
  enableColumnOrdering = _instance$options.enableColumnOrdering;
756
769
 
757
770
  var _getState = getState(),
758
- isDensePadding = _getState.isDensePadding,
771
+ density = _getState.density,
759
772
  columnOrder = _getState.columnOrder,
760
773
  columnPinning = _getState.columnPinning;
761
774
 
@@ -789,7 +802,7 @@ var MRT_ShowHideColumnsMenu = function MRT_ShowHideColumnsMenu(_ref) {
789
802
  return setAnchorEl(null);
790
803
  },
791
804
  MenuListProps: {
792
- dense: isDensePadding
805
+ dense: density === 'compact'
793
806
  }
794
807
  }, React.createElement(Box, {
795
808
  sx: {
@@ -873,7 +886,7 @@ var MRT_ColumnActionMenu = function MRT_ColumnActionMenu(_ref) {
873
886
  var _getState = getState(),
874
887
  columnSizing = _getState.columnSizing,
875
888
  columnVisibility = _getState.columnVisibility,
876
- isDensePadding = _getState.isDensePadding;
889
+ density = _getState.density;
877
890
 
878
891
  var _useState = useState(null),
879
892
  filterMenuAnchorEl = _useState[0],
@@ -959,7 +972,7 @@ var MRT_ColumnActionMenu = function MRT_ColumnActionMenu(_ref) {
959
972
  return setAnchorEl(null);
960
973
  },
961
974
  MenuListProps: {
962
- dense: isDensePadding
975
+ dense: density === 'compact'
963
976
  }
964
977
  }, enableSorting && column.getCanSort() && [React.createElement(MenuItem, {
965
978
  disabled: !column.getIsSorted(),
@@ -1111,7 +1124,7 @@ var MRT_RowActionMenu = function MRT_RowActionMenu(_ref) {
1111
1124
  renderRowActionMenuItems = _instance$options.renderRowActionMenuItems;
1112
1125
 
1113
1126
  var _getState = getState(),
1114
- isDensePadding = _getState.isDensePadding;
1127
+ density = _getState.density;
1115
1128
 
1116
1129
  return React.createElement(Menu, {
1117
1130
  anchorEl: anchorEl,
@@ -1120,7 +1133,7 @@ var MRT_RowActionMenu = function MRT_RowActionMenu(_ref) {
1120
1133
  return setAnchorEl(null);
1121
1134
  },
1122
1135
  MenuListProps: {
1123
- dense: isDensePadding
1136
+ dense: density === 'compact'
1124
1137
  }
1125
1138
  }, enableEditing && React.createElement(MenuItem, {
1126
1139
  onClick: handleEdit,
@@ -1266,17 +1279,19 @@ var MRT_SelectCheckbox = function MRT_SelectCheckbox(_ref) {
1266
1279
  selectAll = _ref.selectAll,
1267
1280
  instance = _ref.instance;
1268
1281
  var getRowModel = instance.getRowModel,
1282
+ getPaginationRowModel = instance.getPaginationRowModel,
1269
1283
  getSelectedRowModel = instance.getSelectedRowModel,
1270
1284
  getState = instance.getState,
1271
1285
  _instance$options = instance.options,
1272
1286
  localization = _instance$options.localization,
1273
1287
  muiSelectCheckboxProps = _instance$options.muiSelectCheckboxProps,
1288
+ muiSelectAllCheckboxProps = _instance$options.muiSelectAllCheckboxProps,
1274
1289
  onRowSelectionChanged = _instance$options.onRowSelectionChanged,
1275
1290
  onRowSelectAllChanged = _instance$options.onRowSelectAllChanged,
1276
1291
  selectAllMode = _instance$options.selectAllMode;
1277
1292
 
1278
1293
  var _getState = getState(),
1279
- isDensePadding = _getState.isDensePadding;
1294
+ density = _getState.density;
1280
1295
 
1281
1296
  var handleSelectChange = function handleSelectChange(event) {
1282
1297
  if (selectAll) {
@@ -1288,7 +1303,7 @@ var MRT_SelectCheckbox = function MRT_SelectCheckbox(_ref) {
1288
1303
 
1289
1304
  onRowSelectAllChanged == null ? void 0 : onRowSelectAllChanged({
1290
1305
  event: event,
1291
- selectedRows: event.target.checked ? getRowModel().flatRows : [],
1306
+ selectedRows: event.target.checked ? selectAllMode === 'all' ? getRowModel().flatRows : getPaginationRowModel().flatRows : [],
1292
1307
  instance: instance
1293
1308
  });
1294
1309
  } else if (row) {
@@ -1304,8 +1319,9 @@ var MRT_SelectCheckbox = function MRT_SelectCheckbox(_ref) {
1304
1319
  }
1305
1320
  };
1306
1321
 
1307
- var checkboxProps = muiSelectCheckboxProps instanceof Function ? muiSelectCheckboxProps({
1308
- isSelectAll: !!selectAll,
1322
+ var checkboxProps = selectAll ? muiSelectAllCheckboxProps instanceof Function ? muiSelectAllCheckboxProps({
1323
+ instance: instance
1324
+ }) : muiSelectAllCheckboxProps : muiSelectCheckboxProps instanceof Function ? muiSelectCheckboxProps({
1309
1325
  row: row,
1310
1326
  instance: instance
1311
1327
  }) : muiSelectCheckboxProps;
@@ -1321,11 +1337,11 @@ var MRT_SelectCheckbox = function MRT_SelectCheckbox(_ref) {
1321
1337
  'aria-label': selectAll ? localization.toggleSelectAll : localization.toggleSelectRow
1322
1338
  },
1323
1339
  onChange: handleSelectChange,
1324
- size: isDensePadding ? 'small' : 'medium'
1340
+ size: density === 'compact' ? 'small' : 'medium'
1325
1341
  }, checkboxProps, {
1326
1342
  sx: _extends({
1327
- height: isDensePadding ? '1.75rem' : '2.25rem',
1328
- width: isDensePadding ? '1.75rem' : '2.25rem'
1343
+ height: density === 'compact' ? '1.75rem' : '2.25rem',
1344
+ width: density === 'compact' ? '1.75rem' : '2.25rem'
1329
1345
  }, checkboxProps == null ? void 0 : checkboxProps.sx)
1330
1346
  })));
1331
1347
  };
@@ -1403,31 +1419,33 @@ var MRT_ToggleDensePaddingButton = function MRT_ToggleDensePaddingButton(_ref) {
1403
1419
  var getState = instance.getState,
1404
1420
  _instance$options = instance.options,
1405
1421
  _instance$options$ico = _instance$options.icons,
1422
+ DensityLargeIcon = _instance$options$ico.DensityLargeIcon,
1406
1423
  DensityMediumIcon = _instance$options$ico.DensityMediumIcon,
1407
1424
  DensitySmallIcon = _instance$options$ico.DensitySmallIcon,
1408
1425
  localization = _instance$options.localization,
1409
- onIsDensePaddingChanged = _instance$options.onIsDensePaddingChanged,
1410
- setIsDensePadding = instance.setIsDensePadding;
1426
+ onDensityChanged = _instance$options.onDensityChanged,
1427
+ setDensity = instance.setDensity;
1411
1428
 
1412
1429
  var _getState = getState(),
1413
- isDensePadding = _getState.isDensePadding;
1430
+ density = _getState.density;
1414
1431
 
1415
1432
  var handleToggleDensePadding = function handleToggleDensePadding(event) {
1416
- onIsDensePaddingChanged == null ? void 0 : onIsDensePaddingChanged({
1433
+ var nextDensity = density === 'comfortable' ? 'compact' : density === 'compact' ? 'spacious' : 'comfortable';
1434
+ onDensityChanged == null ? void 0 : onDensityChanged({
1417
1435
  event: event,
1418
- isDensePadding: !isDensePadding,
1436
+ density: nextDensity,
1419
1437
  instance: instance
1420
1438
  });
1421
- setIsDensePadding(!isDensePadding);
1439
+ setDensity(nextDensity);
1422
1440
  };
1423
1441
 
1424
1442
  return React.createElement(Tooltip, {
1425
1443
  arrow: true,
1426
- title: localization.toggleDensePadding
1444
+ title: localization.toggleDensity
1427
1445
  }, React.createElement(IconButton, Object.assign({
1428
- "aria-label": localization.toggleDensePadding,
1446
+ "aria-label": localization.toggleDensity,
1429
1447
  onClick: handleToggleDensePadding
1430
- }, rest), isDensePadding ? React.createElement(DensitySmallIcon, null) : React.createElement(DensityMediumIcon, null)));
1448
+ }, rest), density === 'compact' ? React.createElement(DensitySmallIcon, null) : density === 'comfortable' ? React.createElement(DensityMediumIcon, null) : React.createElement(DensityLargeIcon, null)));
1431
1449
  };
1432
1450
 
1433
1451
  var _excluded$3 = ["instance"];
@@ -1618,7 +1636,7 @@ var MRT_ToolbarInternalButtons = function MRT_ToolbarInternalButtons(_ref) {
1618
1636
  var instance = _ref.instance;
1619
1637
  var _instance$options = instance.options,
1620
1638
  enableColumnFilters = _instance$options.enableColumnFilters,
1621
- enableDensePaddingToggle = _instance$options.enableDensePaddingToggle,
1639
+ enableDensityToggle = _instance$options.enableDensityToggle,
1622
1640
  enableFilters = _instance$options.enableFilters,
1623
1641
  enableFullScreenToggle = _instance$options.enableFullScreenToggle,
1624
1642
  enableGlobalFilter = _instance$options.enableGlobalFilter,
@@ -1646,7 +1664,7 @@ var MRT_ToolbarInternalButtons = function MRT_ToolbarInternalButtons(_ref) {
1646
1664
  instance: instance
1647
1665
  }), enableHiding && React.createElement(MRT_ShowHideColumnsButton, {
1648
1666
  instance: instance
1649
- }), enableDensePaddingToggle && React.createElement(MRT_ToggleDensePaddingButton, {
1667
+ }), enableDensityToggle && React.createElement(MRT_ToggleDensePaddingButton, {
1650
1668
  instance: instance
1651
1669
  }), enableFullScreenToggle && React.createElement(MRT_FullScreenToggleButton, {
1652
1670
  instance: instance
@@ -1992,12 +2010,14 @@ var MRT_FilterTextField = function MRT_FilterTextField(_ref) {
1992
2010
  onColumnFilterValueChangedDebounced == null ? void 0 : onColumnFilterValueChangedDebounced({
1993
2011
  column: column,
1994
2012
  event: event,
1995
- filterValue: event.target.value
2013
+ filterValue: event.target.value,
2014
+ instance: instance
1996
2015
  });
1997
2016
  columnDef.onColumnFilterValueChangedDebounced == null ? void 0 : columnDef.onColumnFilterValueChangedDebounced({
1998
2017
  column: column,
1999
2018
  event: event,
2000
- filterValue: event.target.value
2019
+ filterValue: event.target.value,
2020
+ instance: instance
2001
2021
  });
2002
2022
  }, 200), []);
2003
2023
 
@@ -2007,12 +2027,14 @@ var MRT_FilterTextField = function MRT_FilterTextField(_ref) {
2007
2027
  onColumnFilterValueChanged == null ? void 0 : onColumnFilterValueChanged({
2008
2028
  column: column,
2009
2029
  event: event,
2010
- filterValue: event.target.value
2030
+ filterValue: event.target.value,
2031
+ instance: instance
2011
2032
  });
2012
2033
  columnDef.onColumnFilterValueChanged == null ? void 0 : columnDef.onColumnFilterValueChanged({
2013
2034
  column: column,
2014
2035
  event: event,
2015
- filterValue: event.target.value
2036
+ filterValue: event.target.value,
2037
+ instance: instance
2016
2038
  });
2017
2039
  };
2018
2040
 
@@ -2402,7 +2424,7 @@ var MRT_TableHeadCell = function MRT_TableHeadCell(_ref) {
2402
2424
  muiTableHeadCellProps = _instance$options.muiTableHeadCellProps;
2403
2425
 
2404
2426
  var _getState = getState(),
2405
- isDensePadding = _getState.isDensePadding;
2427
+ density = _getState.density;
2406
2428
 
2407
2429
  var column = header.column;
2408
2430
  var columnDef = column.columnDef,
@@ -2451,10 +2473,10 @@ var MRT_TableHeadCell = function MRT_TableHeadCell(_ref) {
2451
2473
  height: '100%',
2452
2474
  left: column.getIsPinned() === 'left' ? column.getStart('left') + "px" : undefined,
2453
2475
  overflow: 'visible',
2454
- p: isDensePadding ? columnDefType === 'display' ? '0 0.5rem' : '0.5rem' : columnDefType === 'display' ? '0.5rem 0.75rem' : '1rem',
2476
+ p: density === 'compact' ? columnDefType === 'display' ? '0 0.5rem' : '0.5rem' : density === 'comfortable' ? columnDefType === 'display' ? '0.5rem 0.75rem' : '1rem' : columnDefType === 'display' ? '1rem 1.25rem' : '1.5rem',
2455
2477
  pb: columnDefType === 'display' ? 0 : undefined,
2456
2478
  position: column.getIsPinned() && columnDefType !== 'group' ? 'sticky' : undefined,
2457
- pt: columnDefType !== 'data' ? 0 : isDensePadding ? '0.25' : '.75rem',
2479
+ pt: columnDefType !== 'data' ? 0 : density === 'compact' ? '0.25' : density === 'comfortable' ? '.75rem' : '1.25rem',
2458
2480
  right: column.getIsPinned() === 'right' ? getTotalRight() + "px" : undefined,
2459
2481
  transition: "all " + (enableColumnResizing ? 0 : '0.2s') + " ease-in-out",
2460
2482
  verticalAlign: 'text-top',
@@ -2781,7 +2803,7 @@ var MRT_TableBodyCell = function MRT_TableBodyCell(_ref) {
2781
2803
  columnOrder = _getState.columnOrder,
2782
2804
  currentEditingCell = _getState.currentEditingCell,
2783
2805
  currentEditingRow = _getState.currentEditingRow,
2784
- isDensePadding = _getState.isDensePadding,
2806
+ density = _getState.density,
2785
2807
  isLoading = _getState.isLoading,
2786
2808
  showSkeletons = _getState.showSkeletons;
2787
2809
 
@@ -2861,13 +2883,13 @@ var MRT_TableBodyCell = function MRT_TableBodyCell(_ref) {
2861
2883
  cursor: isEditable && editingMode === 'cell' ? 'pointer' : 'text',
2862
2884
  left: column.getIsPinned() === 'left' ? column.getStart('left') + "px" : undefined,
2863
2885
  overflow: 'hidden',
2864
- p: isDensePadding ? columnDefType === 'display' ? '0 0.5rem' : '0.5rem' : columnDefType === 'display' ? '0.5rem 0.75rem' : '1rem',
2865
- pl: column.id === 'mrt-expand' ? row.depth + (isDensePadding ? 0.5 : 0.75) + "rem" : undefined,
2886
+ p: density === 'compact' ? columnDefType === 'display' ? '0 0.5rem' : '0.5rem' : density === 'comfortable' ? columnDefType === 'display' ? '0.5rem 0.75rem' : '1rem' : columnDefType === 'display' ? '1rem 1.25rem' : '1.5rem',
2887
+ pl: column.id === 'mrt-expand' ? row.depth + (density === 'compact' ? 0.5 : density === 'comfortable' ? 0.75 : 1.25) + "rem" : undefined,
2866
2888
  position: column.getIsPinned() ? 'sticky' : 'relative',
2867
2889
  right: column.getIsPinned() === 'right' ? getTotalRight() + "px" : undefined,
2868
2890
  textOverflow: columnDefType !== 'display' ? 'ellipsis' : undefined,
2869
2891
  transition: 'all 0.2s ease-in-out',
2870
- whiteSpace: isDensePadding ? 'nowrap' : 'normal',
2892
+ whiteSpace: density === 'compact' ? 'nowrap' : 'normal',
2871
2893
  zIndex: column.getIsPinned() ? 1 : undefined,
2872
2894
  '&:hover': {
2873
2895
  backgroundColor: enableHover && enableEditing && editingMode !== 'row' ? theme.palette.mode === 'dark' ? lighten(theme.palette.background["default"], 0.13) + " !important" : darken(theme.palette.background["default"], 0.07) + " !important" : undefined
@@ -3005,14 +3027,14 @@ var MRT_TableBody = function MRT_TableBody(_ref) {
3005
3027
  virtualizerProps = _instance$options.virtualizerProps;
3006
3028
 
3007
3029
  var _getState = getState(),
3008
- isDensePadding = _getState.isDensePadding;
3030
+ density = _getState.density;
3009
3031
 
3010
3032
  var tableBodyProps = muiTableBodyProps instanceof Function ? muiTableBodyProps({
3011
3033
  instance: instance
3012
3034
  }) : muiTableBodyProps;
3013
3035
  var rows = enablePagination ? getPaginationRowModel().rows : getPrePaginationRowModel().rows;
3014
3036
  var rowVirtualizer = enableRowVirtualization ? useVirtual(_extends({
3015
- overscan: isDensePadding ? 15 : 5,
3037
+ overscan: density === 'compact' ? 15 : 5,
3016
3038
  size: rows.length,
3017
3039
  parentRef: tableContainerRef
3018
3040
  }, virtualizerProps)) : {};
@@ -3049,7 +3071,7 @@ var MRT_TableFooterCell = function MRT_TableFooterCell(_ref) {
3049
3071
  enableColumnResizing = _instance$options.enableColumnResizing;
3050
3072
 
3051
3073
  var _getState = getState(),
3052
- isDensePadding = _getState.isDensePadding;
3074
+ density = _getState.density;
3053
3075
 
3054
3076
  var column = footer.column;
3055
3077
  var columnDef = column.columnDef,
@@ -3077,7 +3099,7 @@ var MRT_TableFooterCell = function MRT_TableFooterCell(_ref) {
3077
3099
  fontWeight: 'bold',
3078
3100
  maxWidth: column.getSize() + "px",
3079
3101
  minWidth: column.getSize() + "px",
3080
- p: isDensePadding ? '0.5rem' : '1rem',
3102
+ p: density === 'compact' ? '0.5rem' : density === 'comfortable' ? '1rem' : '1.5rem',
3081
3103
  transition: "all " + (enableColumnResizing ? '10ms' : '0.2s') + " ease-in-out",
3082
3104
  width: column.getSize(),
3083
3105
  verticalAlign: 'text-top'
@@ -3254,7 +3276,7 @@ var MRT_TablePaper = function MRT_TablePaper(_ref) {
3254
3276
  };
3255
3277
 
3256
3278
  var MRT_TableRoot = function MRT_TableRoot(props) {
3257
- var _initialState$current, _initialState$current2, _initialState$isDense, _initialState$isFullS, _initialState$showFil, _initialState$showGlo, _props$globalFilterFn, _props$state3, _props$state4, _props$onCurrentEditi, _props$onCurrentEditi2, _props$onCurrentFilte, _props$onCurrentGloba, _props$onIsDensePaddi, _props$onIsFullScreen, _props$onShowFiltersC, _props$onShowGlobalFi;
3279
+ var _initialState$current, _initialState$current2, _initialState$density, _initialState$isFullS, _initialState$showFil, _initialState$showGlo, _props$globalFilterFn, _props$state3, _props$state4, _props$onCurrentEditi, _props$onCurrentEditi2, _props$onCurrentFilte, _props$onCurrentGloba, _props$onDensityChang, _props$onIsFullScreen, _props$onShowFiltersC, _props$onShowGlobalFi;
3258
3280
 
3259
3281
  var _useState = useState(props.tableId),
3260
3282
  tableId = _useState[0],
@@ -3308,9 +3330,9 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
3308
3330
  currentEditingRow = _useState3[0],
3309
3331
  setCurrentEditingRow = _useState3[1];
3310
3332
 
3311
- var _useState4 = useState((_initialState$isDense = initialState == null ? void 0 : initialState.isDensePadding) != null ? _initialState$isDense : false),
3312
- isDensePadding = _useState4[0],
3313
- setIsDensePadding = _useState4[1];
3333
+ var _useState4 = useState((_initialState$density = initialState == null ? void 0 : initialState.density) != null ? _initialState$density : 'comfortable'),
3334
+ density = _useState4[0],
3335
+ setDensity = _useState4[1];
3314
3336
 
3315
3337
  var _useState5 = useState((_initialState$isFullS = initialState == null ? void 0 : initialState.isFullScreen) != null ? _initialState$isFullS : false),
3316
3338
  isFullScreen = _useState5[0],
@@ -3469,7 +3491,7 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
3469
3491
  currentEditingRow: currentEditingRow,
3470
3492
  currentFilterFns: currentFilterFns,
3471
3493
  currentGlobalFilterFn: currentGlobalFilterFn,
3472
- isDensePadding: isDensePadding,
3494
+ density: density,
3473
3495
  isFullScreen: isFullScreen,
3474
3496
  showFilters: showFilters,
3475
3497
  showGlobalFilter: showGlobalFilter
@@ -3479,7 +3501,7 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
3479
3501
  setCurrentEditingRow: (_props$onCurrentEditi2 = props.onCurrentEditingRowChange) != null ? _props$onCurrentEditi2 : setCurrentEditingRow,
3480
3502
  setCurrentFilterFns: (_props$onCurrentFilte = props.onCurrentFilterFnsChange) != null ? _props$onCurrentFilte : setCurrentFilterFns,
3481
3503
  setCurrentGlobalFilterFn: (_props$onCurrentGloba = props.onCurrentGlobalFilterFnChange) != null ? _props$onCurrentGloba : setCurrentGlobalFilterFn,
3482
- setIsDensePadding: (_props$onIsDensePaddi = props.onIsDensePaddingChange) != null ? _props$onIsDensePaddi : setIsDensePadding,
3504
+ setDensity: (_props$onDensityChang = props.onDensityChange) != null ? _props$onDensityChang : setDensity,
3483
3505
  setIsFullScreen: (_props$onIsFullScreen = props.onIsFullScreenChange) != null ? _props$onIsFullScreen : setIsFullScreen,
3484
3506
  setShowFilters: (_props$onShowFiltersC = props.onShowFiltersChange) != null ? _props$onShowFiltersC : setShowFilters,
3485
3507
  setShowGlobalFilter: (_props$onShowGlobalFi = props.onShowGlobalFilterChange) != null ? _props$onShowGlobalFi : setShowGlobalFilter
@@ -3525,7 +3547,7 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
3525
3547
  }));
3526
3548
  };
3527
3549
 
3528
- var _excluded$5 = ["autoResetExpanded", "columnResizeMode", "defaultColumn", "editingMode", "enableColumnActions", "enableColumnFilters", "enableColumnOrdering", "enableColumnResizing", "enableDensePaddingToggle", "enableExpandAll", "enableFilters", "enableFullScreenToggle", "enableGlobalFilter", "enableGrouping", "enableHiding", "enableMultiRowSelection", "enablePagination", "enablePinning", "enableSelectAll", "enableSorting", "enableStickyHeader", "enableTableFooter", "enableTableHead", "enableToolbarBottom", "enableToolbarInternalActions", "enableToolbarTop", "icons", "localization", "persistentStateMode", "positionActionsColumn", "positionPagination", "positionGlobalFilter", "positionToolbarActions", "positionToolbarAlertBanner", "rowNumberMode", "selectAllMode"];
3550
+ var _excluded$5 = ["autoResetExpanded", "columnResizeMode", "defaultColumn", "editingMode", "enableColumnActions", "enableColumnFilters", "enableColumnOrdering", "enableColumnResizing", "enableDensityToggle", "enableExpandAll", "enableFilters", "enableFullScreenToggle", "enableGlobalFilter", "enableGrouping", "enableHiding", "enableMultiRowSelection", "enablePagination", "enablePinning", "enableSelectAll", "enableSorting", "enableStickyHeader", "enableTableFooter", "enableTableHead", "enableToolbarBottom", "enableToolbarInternalActions", "enableToolbarTop", "icons", "localization", "persistentStateMode", "positionActionsColumn", "positionPagination", "positionGlobalFilter", "positionToolbarActions", "positionToolbarAlertBanner", "rowNumberMode", "selectAllMode"];
3529
3551
  var MaterialReactTable = (function (_ref) {
3530
3552
  var _ref$autoResetExpande = _ref.autoResetExpanded,
3531
3553
  autoResetExpanded = _ref$autoResetExpande === void 0 ? false : _ref$autoResetExpande,
@@ -3547,8 +3569,8 @@ var MaterialReactTable = (function (_ref) {
3547
3569
  enableColumnOrdering = _ref$enableColumnOrde === void 0 ? false : _ref$enableColumnOrde,
3548
3570
  _ref$enableColumnResi = _ref.enableColumnResizing,
3549
3571
  enableColumnResizing = _ref$enableColumnResi === void 0 ? false : _ref$enableColumnResi,
3550
- _ref$enableDensePaddi = _ref.enableDensePaddingToggle,
3551
- enableDensePaddingToggle = _ref$enableDensePaddi === void 0 ? true : _ref$enableDensePaddi,
3572
+ _ref$enableDensityTog = _ref.enableDensityToggle,
3573
+ enableDensityToggle = _ref$enableDensityTog === void 0 ? true : _ref$enableDensityTog,
3552
3574
  _ref$enableExpandAll = _ref.enableExpandAll,
3553
3575
  enableExpandAll = _ref$enableExpandAll === void 0 ? true : _ref$enableExpandAll,
3554
3576
  _ref$enableFilters = _ref.enableFilters,
@@ -3612,7 +3634,7 @@ var MaterialReactTable = (function (_ref) {
3612
3634
  enableColumnFilters: enableColumnFilters,
3613
3635
  enableColumnOrdering: enableColumnOrdering,
3614
3636
  enableColumnResizing: enableColumnResizing,
3615
- enableDensePaddingToggle: enableDensePaddingToggle,
3637
+ enableDensityToggle: enableDensityToggle,
3616
3638
  enableExpandAll: enableExpandAll,
3617
3639
  enableFilters: enableFilters,
3618
3640
  enableFullScreenToggle: enableFullScreenToggle,