material-react-table 0.9.5 → 0.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (109) hide show
  1. package/README.md +2 -0
  2. package/dist/MaterialReactTable.d.ts +144 -128
  3. package/dist/body/MRT_TableBody.d.ts +1 -1
  4. package/dist/body/MRT_TableBodyCell.d.ts +1 -1
  5. package/dist/body/MRT_TableBodyRow.d.ts +1 -1
  6. package/dist/body/MRT_TableDetailPanel.d.ts +1 -1
  7. package/dist/buttons/MRT_ColumnPinningButtons.d.ts +1 -1
  8. package/dist/buttons/MRT_CopyButton.d.ts +1 -1
  9. package/dist/buttons/MRT_EditActionButtons.d.ts +1 -1
  10. package/dist/buttons/MRT_ExpandAllButton.d.ts +1 -1
  11. package/dist/buttons/MRT_ExpandButton.d.ts +1 -1
  12. package/dist/buttons/MRT_FullScreenToggleButton.d.ts +1 -1
  13. package/dist/buttons/MRT_GrabHandleButton.d.ts +1 -1
  14. package/dist/buttons/MRT_ShowHideColumnsButton.d.ts +1 -1
  15. package/dist/buttons/MRT_ToggleColumnActionMenuButton.d.ts +1 -1
  16. package/dist/buttons/MRT_ToggleDensePaddingButton.d.ts +1 -1
  17. package/dist/buttons/MRT_ToggleFiltersButton.d.ts +1 -1
  18. package/dist/buttons/MRT_ToggleGlobalFilterButton.d.ts +1 -1
  19. package/dist/buttons/MRT_ToggleRowActionMenuButton.d.ts +1 -1
  20. package/dist/footer/MRT_TableFooter.d.ts +1 -1
  21. package/dist/footer/MRT_TableFooterCell.d.ts +1 -1
  22. package/dist/footer/MRT_TableFooterRow.d.ts +1 -1
  23. package/dist/head/MRT_DraggableTableHeadCell.d.ts +1 -1
  24. package/dist/head/MRT_TableHead.d.ts +1 -1
  25. package/dist/head/MRT_TableHeadCell.d.ts +1 -1
  26. package/dist/head/MRT_TableHeadCellFilterContainer.d.ts +1 -1
  27. package/dist/head/MRT_TableHeadCellFilterLabel.d.ts +1 -1
  28. package/dist/head/MRT_TableHeadCellResizeHandle.d.ts +1 -1
  29. package/dist/head/MRT_TableHeadCellSortLabel.d.ts +1 -1
  30. package/dist/head/MRT_TableHeadRow.d.ts +1 -1
  31. package/dist/inputs/MRT_EditCellTextField.d.ts +1 -1
  32. package/dist/inputs/MRT_FilterRangeFields.d.ts +1 -1
  33. package/dist/inputs/MRT_FilterTextField.d.ts +1 -1
  34. package/dist/inputs/MRT_SearchTextField.d.ts +1 -1
  35. package/dist/inputs/MRT_SelectCheckbox.d.ts +1 -1
  36. package/dist/material-react-table.cjs.development.js +569 -573
  37. package/dist/material-react-table.cjs.development.js.map +1 -1
  38. package/dist/material-react-table.cjs.production.min.js +1 -1
  39. package/dist/material-react-table.cjs.production.min.js.map +1 -1
  40. package/dist/material-react-table.esm.js +569 -573
  41. package/dist/material-react-table.esm.js.map +1 -1
  42. package/dist/menus/MRT_ColumnActionMenu.d.ts +1 -1
  43. package/dist/menus/MRT_FilterOptionMenu.d.ts +1 -1
  44. package/dist/menus/MRT_RowActionMenu.d.ts +1 -1
  45. package/dist/menus/MRT_ShowHideColumnsMenu.d.ts +1 -1
  46. package/dist/menus/MRT_ShowHideColumnsMenuItems.d.ts +1 -1
  47. package/dist/table/MRT_Table.d.ts +1 -1
  48. package/dist/table/MRT_TableContainer.d.ts +1 -1
  49. package/dist/table/MRT_TablePaper.d.ts +2 -2
  50. package/dist/toolbar/MRT_LinearProgressBar.d.ts +1 -1
  51. package/dist/toolbar/MRT_TablePagination.d.ts +1 -1
  52. package/dist/toolbar/MRT_ToolbarAlertBanner.d.ts +1 -1
  53. package/dist/toolbar/MRT_ToolbarBottom.d.ts +1 -1
  54. package/dist/toolbar/MRT_ToolbarInternalButtons.d.ts +1 -1
  55. package/dist/toolbar/MRT_ToolbarTop.d.ts +1 -1
  56. package/dist/utils.d.ts +2 -2
  57. package/package.json +1 -1
  58. package/src/MaterialReactTable.tsx +159 -157
  59. package/src/body/MRT_TableBody.tsx +12 -9
  60. package/src/body/MRT_TableBodyCell.tsx +15 -21
  61. package/src/body/MRT_TableBodyRow.tsx +7 -7
  62. package/src/body/MRT_TableDetailPanel.tsx +14 -11
  63. package/src/buttons/MRT_ColumnPinningButtons.tsx +3 -6
  64. package/src/buttons/MRT_CopyButton.tsx +5 -9
  65. package/src/buttons/MRT_EditActionButtons.tsx +4 -4
  66. package/src/buttons/MRT_ExpandAllButton.tsx +3 -3
  67. package/src/buttons/MRT_ExpandButton.tsx +4 -4
  68. package/src/buttons/MRT_FullScreenToggleButton.tsx +4 -4
  69. package/src/buttons/MRT_GrabHandleButton.tsx +3 -3
  70. package/src/buttons/MRT_ShowHideColumnsButton.tsx +4 -7
  71. package/src/buttons/MRT_ToggleColumnActionMenuButton.tsx +6 -6
  72. package/src/buttons/MRT_ToggleDensePaddingButton.tsx +4 -4
  73. package/src/buttons/MRT_ToggleFiltersButton.tsx +4 -7
  74. package/src/buttons/MRT_ToggleGlobalFilterButton.tsx +5 -5
  75. package/src/buttons/MRT_ToggleRowActionMenuButton.tsx +6 -9
  76. package/src/footer/MRT_TableFooter.tsx +5 -5
  77. package/src/footer/MRT_TableFooterCell.tsx +6 -6
  78. package/src/footer/MRT_TableFooterRow.tsx +5 -8
  79. package/src/head/MRT_DraggableTableHeadCell.tsx +4 -7
  80. package/src/head/MRT_TableHead.tsx +5 -5
  81. package/src/head/MRT_TableHeadCell.tsx +15 -25
  82. package/src/head/MRT_TableHeadCellFilterContainer.tsx +6 -7
  83. package/src/head/MRT_TableHeadCellFilterLabel.tsx +3 -3
  84. package/src/head/MRT_TableHeadCellResizeHandle.tsx +3 -3
  85. package/src/head/MRT_TableHeadCellSortLabel.tsx +3 -6
  86. package/src/head/MRT_TableHeadRow.tsx +6 -6
  87. package/src/inputs/MRT_EditCellTextField.tsx +10 -10
  88. package/src/inputs/MRT_FilterRangeFields.tsx +5 -13
  89. package/src/inputs/MRT_FilterTextField.tsx +10 -14
  90. package/src/inputs/MRT_SearchTextField.tsx +6 -6
  91. package/src/inputs/MRT_SelectCheckbox.tsx +10 -16
  92. package/src/menus/MRT_ColumnActionMenu.tsx +5 -5
  93. package/src/menus/MRT_FilterOptionMenu.tsx +33 -33
  94. package/src/menus/MRT_RowActionMenu.tsx +4 -4
  95. package/src/menus/MRT_ShowHideColumnsMenu.tsx +6 -6
  96. package/src/menus/MRT_ShowHideColumnsMenuItems.tsx +7 -10
  97. package/src/table/MRT_Table.tsx +14 -9
  98. package/src/table/MRT_TableContainer.tsx +16 -12
  99. package/src/table/MRT_TablePaper.tsx +8 -14
  100. package/src/table/MRT_TableRoot.tsx +25 -30
  101. package/src/toolbar/MRT_LinearProgressBar.tsx +4 -7
  102. package/src/toolbar/MRT_TablePagination.tsx +4 -4
  103. package/src/toolbar/MRT_ToolbarAlertBanner.tsx +6 -8
  104. package/src/toolbar/MRT_ToolbarBottom.tsx +8 -8
  105. package/src/toolbar/MRT_ToolbarInternalButtons.tsx +10 -12
  106. package/src/toolbar/MRT_ToolbarTop.tsx +11 -10
  107. package/src/utils.ts +2 -2
  108. package/dist/enums.d.ts +0 -13
  109. package/src/enums.ts +0 -13
@@ -5,26 +5,28 @@ import { MRT_TableBodyRow } from './MRT_TableBodyRow';
5
5
  import type { MRT_Row, MRT_TableInstance } from '..';
6
6
 
7
7
  interface Props {
8
- tableInstance: MRT_TableInstance;
8
+ instance: MRT_TableInstance;
9
9
  tableContainerRef: RefObject<HTMLDivElement>;
10
10
  }
11
11
 
12
- export const MRT_TableBody: FC<Props> = ({
13
- tableInstance,
14
- tableContainerRef,
15
- }) => {
12
+ export const MRT_TableBody: FC<Props> = ({ instance, tableContainerRef }) => {
16
13
  const {
17
14
  getPaginationRowModel,
18
15
  getPrePaginationRowModel,
19
16
  getState,
20
- options: { enablePagination, enableRowVirtualization, muiTableBodyProps },
21
- } = tableInstance;
17
+ options: {
18
+ enablePagination,
19
+ enableRowVirtualization,
20
+ muiTableBodyProps,
21
+ virtualizerProps,
22
+ },
23
+ } = instance;
22
24
 
23
25
  const { isDensePadding } = getState();
24
26
 
25
27
  const tableBodyProps =
26
28
  muiTableBodyProps instanceof Function
27
- ? muiTableBodyProps({ tableInstance })
29
+ ? muiTableBodyProps({ instance })
28
30
  : muiTableBodyProps;
29
31
 
30
32
  const rows = enablePagination
@@ -36,6 +38,7 @@ export const MRT_TableBody: FC<Props> = ({
36
38
  overscan: isDensePadding ? 15 : 5,
37
39
  size: rows.length,
38
40
  parentRef: tableContainerRef,
41
+ ...virtualizerProps,
39
42
  })
40
43
  : ({} as any);
41
44
 
@@ -66,7 +69,7 @@ export const MRT_TableBody: FC<Props> = ({
66
69
  rowIndex={
67
70
  enableRowVirtualization ? rowOrVirtualRow.index : rowIndex
68
71
  }
69
- tableInstance={tableInstance}
72
+ instance={instance}
70
73
  />
71
74
  );
72
75
  },
@@ -10,14 +10,14 @@ interface Props {
10
10
  cell: MRT_Cell;
11
11
  enableHover?: boolean;
12
12
  rowIndex: number;
13
- tableInstance: MRT_TableInstance;
13
+ instance: MRT_TableInstance;
14
14
  }
15
15
 
16
16
  export const MRT_TableBodyCell: FC<Props> = ({
17
17
  cell,
18
18
  enableHover,
19
19
  rowIndex,
20
- tableInstance,
20
+ instance,
21
21
  }) => {
22
22
  const {
23
23
  getState,
@@ -35,7 +35,7 @@ export const MRT_TableBodyCell: FC<Props> = ({
35
35
  },
36
36
  setColumnOrder,
37
37
  setCurrentEditingCell,
38
- } = tableInstance;
38
+ } = instance;
39
39
 
40
40
  const {
41
41
  columnOrder,
@@ -58,12 +58,12 @@ export const MRT_TableBodyCell: FC<Props> = ({
58
58
 
59
59
  const mTableCellBodyProps =
60
60
  muiTableBodyCellProps instanceof Function
61
- ? muiTableBodyCellProps({ cell, tableInstance })
61
+ ? muiTableBodyCellProps({ cell, instance })
62
62
  : muiTableBodyCellProps;
63
63
 
64
64
  const mcTableCellBodyProps =
65
65
  columnDef.muiTableBodyCellProps instanceof Function
66
- ? columnDef.muiTableBodyCellProps({ cell, tableInstance })
66
+ ? columnDef.muiTableBodyCellProps({ cell, instance })
67
67
  : columnDef.muiTableBodyCellProps;
68
68
 
69
69
  const tableCellProps = {
@@ -112,7 +112,7 @@ export const MRT_TableBodyCell: FC<Props> = ({
112
112
  const getIsLastLeftPinnedColumn = () => {
113
113
  return (
114
114
  column.getIsPinned() === 'left' &&
115
- tableInstance.getLeftLeafHeaders().length - 1 === column.getPinnedIndex()
115
+ instance.getLeftLeafHeaders().length - 1 === column.getPinnedIndex()
116
116
  );
117
117
  };
118
118
 
@@ -122,9 +122,7 @@ export const MRT_TableBodyCell: FC<Props> = ({
122
122
 
123
123
  const getTotalRight = () => {
124
124
  return (
125
- (tableInstance.getRightLeafHeaders().length -
126
- 1 -
127
- column.getPinnedIndex()) *
125
+ (instance.getRightLeafHeaders().length - 1 - column.getPinnedIndex()) *
128
126
  150
129
127
  );
130
128
  };
@@ -132,7 +130,7 @@ export const MRT_TableBodyCell: FC<Props> = ({
132
130
  return (
133
131
  <TableCell
134
132
  onClick={(event: MouseEvent<HTMLTableCellElement>) =>
135
- onMrtCellClick?.({ event, cell, tableInstance })
133
+ onMrtCellClick?.({ event, cell, instance })
136
134
  }
137
135
  onDoubleClick={handleDoubleClick}
138
136
  {...tableCellProps}
@@ -184,12 +182,10 @@ export const MRT_TableBodyCell: FC<Props> = ({
184
182
  : undefined,
185
183
  },
186
184
  ...(tableCellProps?.sx as any),
187
- })}
188
- style={{
189
185
  maxWidth: `min(${column.getSize()}px, fit-content)`,
190
186
  minWidth: `max(${column.getSize()}px, ${columnDef.minSize ?? 30}px)`,
191
187
  width: column.getSize(),
192
- }}
188
+ })}
193
189
  >
194
190
  <>
195
191
  {isLoading || showSkeletons ? (
@@ -204,28 +200,26 @@ export const MRT_TableBodyCell: FC<Props> = ({
204
200
  column.id === 'mrt-row-numbers' ? (
205
201
  rowIndex + 1
206
202
  ) : columnDefType === 'display' ? (
207
- columnDef.Cell?.({ cell, tableInstance })
203
+ columnDef.Cell?.({ cell, instance })
208
204
  ) : cell.getIsPlaceholder() ||
209
205
  (row.getIsGrouped() &&
210
206
  column.id !==
211
207
  row.groupingColumnId) ? null : cell.getIsAggregated() ? (
208
+ columnDef.AggregatedCell?.({ cell, instance }) ??
212
209
  cell.renderAggregatedCell()
213
210
  ) : isEditing ? (
214
- <MRT_EditCellTextField cell={cell} tableInstance={tableInstance} />
211
+ <MRT_EditCellTextField cell={cell} instance={instance} />
215
212
  ) : (enableClickToCopy || columnDef.enableClickToCopy) &&
216
213
  columnDef.enableClickToCopy !== false ? (
217
214
  <>
218
- <MRT_CopyButton cell={cell} tableInstance={tableInstance}>
219
- <>
220
- {columnDef?.Cell?.({ cell, tableInstance }) ??
221
- cell.renderCell()}
222
- </>
215
+ <MRT_CopyButton cell={cell} instance={instance}>
216
+ <>{columnDef?.Cell?.({ cell, instance }) ?? cell.renderCell()}</>
223
217
  </MRT_CopyButton>
224
218
  {row.getIsGrouped() && <> ({row.subRows?.length})</>}
225
219
  </>
226
220
  ) : (
227
221
  <>
228
- {columnDef?.Cell?.({ cell, tableInstance }) ?? cell.renderCell()}
222
+ {columnDef?.Cell?.({ cell, instance }) ?? cell.renderCell()}
229
223
  {row.getIsGrouped() && <> ({row.subRows?.length ?? ''})</>}
230
224
  </>
231
225
  )}
@@ -7,18 +7,18 @@ import type { MRT_Row, MRT_TableInstance } from '..';
7
7
  interface Props {
8
8
  row: MRT_Row;
9
9
  rowIndex: number;
10
- tableInstance: MRT_TableInstance;
10
+ instance: MRT_TableInstance;
11
11
  }
12
12
 
13
- export const MRT_TableBodyRow: FC<Props> = ({ row, rowIndex, tableInstance }) => {
13
+ export const MRT_TableBodyRow: FC<Props> = ({ row, rowIndex, instance }) => {
14
14
  const {
15
15
  getIsSomeColumnsPinned,
16
16
  options: { muiTableBodyRowProps, onMrtRowClick, renderDetailPanel },
17
- } = tableInstance;
17
+ } = instance;
18
18
 
19
19
  const tableRowProps =
20
20
  muiTableBodyRowProps instanceof Function
21
- ? muiTableBodyRowProps({ row, tableInstance })
21
+ ? muiTableBodyRowProps({ row, instance })
22
22
  : muiTableBodyRowProps;
23
23
 
24
24
  return (
@@ -26,7 +26,7 @@ export const MRT_TableBodyRow: FC<Props> = ({ row, rowIndex, tableInstance }) =>
26
26
  <TableRow
27
27
  hover
28
28
  onClick={(event: MouseEvent<HTMLTableRowElement>) =>
29
- onMrtRowClick?.({ event, row, tableInstance })
29
+ onMrtRowClick?.({ event, row, instance })
30
30
  }
31
31
  selected={row.getIsSelected()}
32
32
  {...tableRowProps}
@@ -50,12 +50,12 @@ export const MRT_TableBodyRow: FC<Props> = ({ row, rowIndex, tableInstance }) =>
50
50
  key={cell.id}
51
51
  enableHover={tableRowProps?.hover !== false}
52
52
  rowIndex={rowIndex}
53
- tableInstance={tableInstance}
53
+ instance={instance}
54
54
  />
55
55
  ))}
56
56
  </TableRow>
57
57
  {renderDetailPanel && !row.getIsGrouped() && (
58
- <MRT_TableDetailPanel row={row} tableInstance={tableInstance} />
58
+ <MRT_TableDetailPanel row={row} instance={instance} />
59
59
  )}
60
60
  </>
61
61
  );
@@ -4,36 +4,36 @@ import type { MRT_Row, MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props {
6
6
  row: MRT_Row;
7
- tableInstance: MRT_TableInstance;
7
+ instance: MRT_TableInstance;
8
8
  }
9
9
 
10
- export const MRT_TableDetailPanel: FC<Props> = ({ row, tableInstance }) => {
10
+ export const MRT_TableDetailPanel: FC<Props> = ({ row, instance }) => {
11
11
  const {
12
- getVisibleFlatColumns,
12
+ getVisibleLeafColumns,
13
13
  options: {
14
14
  muiTableBodyRowProps,
15
15
  muiTableDetailPanelProps,
16
16
  onMrtDetailPanelClick,
17
17
  renderDetailPanel,
18
18
  },
19
- } = tableInstance;
19
+ } = instance;
20
20
 
21
21
  const tableRowProps =
22
22
  muiTableBodyRowProps instanceof Function
23
- ? muiTableBodyRowProps({ row, tableInstance })
23
+ ? muiTableBodyRowProps({ row, instance })
24
24
  : muiTableBodyRowProps;
25
25
 
26
26
  const tableCellProps =
27
27
  muiTableDetailPanelProps instanceof Function
28
- ? muiTableDetailPanelProps({ row, tableInstance })
28
+ ? muiTableDetailPanelProps({ row, instance })
29
29
  : muiTableDetailPanelProps;
30
30
 
31
31
  return (
32
32
  <TableRow {...tableRowProps}>
33
33
  <TableCell
34
- colSpan={getVisibleFlatColumns().length + 10}
34
+ colSpan={getVisibleLeafColumns().length}
35
35
  onClick={(event: MouseEvent<HTMLTableCellElement>) =>
36
- onMrtDetailPanelClick?.({ event, row, tableInstance })
36
+ onMrtDetailPanelClick?.({ event, row, instance })
37
37
  }
38
38
  {...tableCellProps}
39
39
  sx={{
@@ -41,12 +41,15 @@ export const MRT_TableDetailPanel: FC<Props> = ({ row, tableInstance }) => {
41
41
  pb: row.getIsExpanded() ? '1rem' : 0,
42
42
  pt: row.getIsExpanded() ? '1rem' : 0,
43
43
  transition: 'all 0.2s ease-in-out',
44
+ width: `${instance.getTotalSize()}px`,
44
45
  ...tableCellProps?.sx,
45
46
  }}
46
47
  >
47
- <Collapse in={row.getIsExpanded()}>
48
- {renderDetailPanel?.({ row, tableInstance })}
49
- </Collapse>
48
+ {renderDetailPanel && (
49
+ <Collapse in={row.getIsExpanded()}>
50
+ {renderDetailPanel({ row, instance })}
51
+ </Collapse>
52
+ )}
50
53
  </TableCell>
51
54
  </TableRow>
52
55
  );
@@ -4,19 +4,16 @@ import type { MRT_Column, MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props {
6
6
  column: MRT_Column;
7
- tableInstance: MRT_TableInstance;
7
+ instance: MRT_TableInstance;
8
8
  }
9
9
 
10
- export const MRT_ColumnPinningButtons: FC<Props> = ({
11
- column,
12
- tableInstance,
13
- }) => {
10
+ export const MRT_ColumnPinningButtons: FC<Props> = ({ column, instance }) => {
14
11
  const {
15
12
  options: {
16
13
  icons: { PushPinIcon },
17
14
  localization,
18
15
  },
19
- } = tableInstance;
16
+ } = instance;
20
17
 
21
18
  const handlePinColumn = (pinDirection: 'left' | 'right' | false) => {
22
19
  column.pin(pinDirection);
@@ -5,17 +5,13 @@ import { MRT_Cell, MRT_TableInstance } from '..';
5
5
  interface Props {
6
6
  cell: MRT_Cell;
7
7
  children: ReactNode;
8
- tableInstance: MRT_TableInstance;
8
+ instance: MRT_TableInstance;
9
9
  }
10
10
 
11
- export const MRT_CopyButton: FC<Props> = ({
12
- cell,
13
- children,
14
- tableInstance,
15
- }) => {
11
+ export const MRT_CopyButton: FC<Props> = ({ cell, children, instance }) => {
16
12
  const {
17
13
  options: { localization, muiTableBodyCellCopyButtonProps },
18
- } = tableInstance;
14
+ } = instance;
19
15
 
20
16
  const { column } = cell;
21
17
 
@@ -31,14 +27,14 @@ export const MRT_CopyButton: FC<Props> = ({
31
27
 
32
28
  const mTableBodyCellCopyButtonProps =
33
29
  muiTableBodyCellCopyButtonProps instanceof Function
34
- ? muiTableBodyCellCopyButtonProps({ cell, tableInstance })
30
+ ? muiTableBodyCellCopyButtonProps({ cell, instance })
35
31
  : muiTableBodyCellCopyButtonProps;
36
32
 
37
33
  const mcTableBodyCellCopyButtonProps =
38
34
  columnDef.muiTableBodyCellCopyButtonProps instanceof Function
39
35
  ? columnDef.muiTableBodyCellCopyButtonProps({
40
36
  cell,
41
- tableInstance,
37
+ instance,
42
38
  })
43
39
  : columnDef.muiTableBodyCellCopyButtonProps;
44
40
 
@@ -4,10 +4,10 @@ import type { MRT_Row, MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props {
6
6
  row: MRT_Row;
7
- tableInstance: MRT_TableInstance;
7
+ instance: MRT_TableInstance;
8
8
  }
9
9
 
10
- export const MRT_EditActionButtons: FC<Props> = ({ row, tableInstance }) => {
10
+ export const MRT_EditActionButtons: FC<Props> = ({ row, instance }) => {
11
11
  const {
12
12
  getState,
13
13
  options: {
@@ -16,7 +16,7 @@ export const MRT_EditActionButtons: FC<Props> = ({ row, tableInstance }) => {
16
16
  onMrtEditRowSubmit,
17
17
  },
18
18
  setCurrentEditingRow,
19
- } = tableInstance;
19
+ } = instance;
20
20
 
21
21
  const { currentEditingRow } = getState();
22
22
 
@@ -26,7 +26,7 @@ export const MRT_EditActionButtons: FC<Props> = ({ row, tableInstance }) => {
26
26
  };
27
27
 
28
28
  const handleSave = () => {
29
- onMrtEditRowSubmit?.({ row: currentEditingRow ?? row, tableInstance });
29
+ onMrtEditRowSubmit?.({ row: currentEditingRow ?? row, instance });
30
30
  setCurrentEditingRow(null);
31
31
  };
32
32
 
@@ -3,10 +3,10 @@ import { IconButton, Tooltip } from '@mui/material';
3
3
  import { MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props {
6
- tableInstance: MRT_TableInstance;
6
+ instance: MRT_TableInstance;
7
7
  }
8
8
 
9
- export const MRT_ExpandAllButton: FC<Props> = ({ tableInstance }) => {
9
+ export const MRT_ExpandAllButton: FC<Props> = ({ instance }) => {
10
10
  const {
11
11
  getIsAllRowsExpanded,
12
12
  getIsSomeRowsExpanded,
@@ -18,7 +18,7 @@ export const MRT_ExpandAllButton: FC<Props> = ({ tableInstance }) => {
18
18
  renderDetailPanel,
19
19
  },
20
20
  toggleAllRowsExpanded,
21
- } = tableInstance;
21
+ } = instance;
22
22
 
23
23
  const { isDensePadding } = getState();
24
24
 
@@ -4,10 +4,10 @@ import type { MRT_Row, MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props {
6
6
  row: MRT_Row;
7
- tableInstance: MRT_TableInstance;
7
+ instance: MRT_TableInstance;
8
8
  }
9
9
 
10
- export const MRT_ExpandButton: FC<Props> = ({ row, tableInstance }) => {
10
+ export const MRT_ExpandButton: FC<Props> = ({ row, instance }) => {
11
11
  const {
12
12
  getState,
13
13
  options: {
@@ -16,13 +16,13 @@ export const MRT_ExpandButton: FC<Props> = ({ row, tableInstance }) => {
16
16
  onMrtRowExpandChange,
17
17
  renderDetailPanel,
18
18
  },
19
- } = tableInstance;
19
+ } = instance;
20
20
 
21
21
  const { isDensePadding } = getState();
22
22
 
23
23
  const handleToggleExpand = (event: MouseEvent<HTMLButtonElement>) => {
24
24
  row.toggleExpanded();
25
- onMrtRowExpandChange?.({ event, row, tableInstance });
25
+ onMrtRowExpandChange?.({ event, row, instance });
26
26
  };
27
27
 
28
28
  return (
@@ -3,11 +3,11 @@ import { IconButton, IconButtonProps, Tooltip } from '@mui/material';
3
3
  import { MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props extends IconButtonProps {
6
- tableInstance: MRT_TableInstance;
6
+ instance: MRT_TableInstance;
7
7
  }
8
8
 
9
9
  export const MRT_FullScreenToggleButton: FC<Props> = ({
10
- tableInstance,
10
+ instance,
11
11
  ...rest
12
12
  }) => {
13
13
  const {
@@ -18,7 +18,7 @@ export const MRT_FullScreenToggleButton: FC<Props> = ({
18
18
  onMrtToggleFullScreen,
19
19
  },
20
20
  setIsFullScreen,
21
- } = tableInstance;
21
+ } = instance;
22
22
 
23
23
  const { isFullScreen } = getState();
24
24
 
@@ -26,7 +26,7 @@ export const MRT_FullScreenToggleButton: FC<Props> = ({
26
26
  onMrtToggleFullScreen?.({
27
27
  event,
28
28
  isFullScreen: !isFullScreen,
29
- tableInstance,
29
+ instance,
30
30
  });
31
31
  setIsFullScreen(!isFullScreen);
32
32
  };
@@ -4,17 +4,17 @@ import { MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props {
6
6
  ref: Ref<HTMLButtonElement>;
7
- tableInstance: MRT_TableInstance;
7
+ instance: MRT_TableInstance;
8
8
  }
9
9
 
10
10
  export const MRT_GrabHandleButton: FC<Props> = forwardRef(
11
- ({ tableInstance }, ref) => {
11
+ ({ instance }, ref) => {
12
12
  const {
13
13
  options: {
14
14
  icons: { DragHandleIcon },
15
15
  localization,
16
16
  },
17
- } = tableInstance;
17
+ } = instance;
18
18
 
19
19
  return (
20
20
  <Tooltip
@@ -4,19 +4,16 @@ import { MRT_ShowHideColumnsMenu } from '../menus/MRT_ShowHideColumnsMenu';
4
4
  import { MRT_TableInstance } from '..';
5
5
 
6
6
  interface Props extends IconButtonProps {
7
- tableInstance: MRT_TableInstance;
7
+ instance: MRT_TableInstance;
8
8
  }
9
9
 
10
- export const MRT_ShowHideColumnsButton: FC<Props> = ({
11
- tableInstance,
12
- ...rest
13
- }) => {
10
+ export const MRT_ShowHideColumnsButton: FC<Props> = ({ instance, ...rest }) => {
14
11
  const {
15
12
  options: {
16
13
  icons: { ViewColumnIcon },
17
14
  localization,
18
15
  },
19
- } = tableInstance;
16
+ } = instance;
20
17
 
21
18
  const [anchorEl, setAnchorEl] = useState<null | HTMLElement>(null);
22
19
 
@@ -38,7 +35,7 @@ export const MRT_ShowHideColumnsButton: FC<Props> = ({
38
35
  <MRT_ShowHideColumnsMenu
39
36
  anchorEl={anchorEl}
40
37
  setAnchorEl={setAnchorEl}
41
- tableInstance={tableInstance}
38
+ instance={instance}
42
39
  />
43
40
  </>
44
41
  );
@@ -5,12 +5,12 @@ import type { MRT_Header, MRT_TableInstance } from '..';
5
5
 
6
6
  interface Props {
7
7
  header: MRT_Header;
8
- tableInstance: MRT_TableInstance;
8
+ instance: MRT_TableInstance;
9
9
  }
10
10
 
11
11
  export const MRT_ToggleColumnActionMenuButton: FC<Props> = ({
12
12
  header,
13
- tableInstance,
13
+ instance,
14
14
  }) => {
15
15
  const {
16
16
  options: {
@@ -18,7 +18,7 @@ export const MRT_ToggleColumnActionMenuButton: FC<Props> = ({
18
18
  localization,
19
19
  muiTableHeadCellColumnActionsButtonProps,
20
20
  },
21
- } = tableInstance;
21
+ } = instance;
22
22
 
23
23
  const { column } = header;
24
24
 
@@ -34,14 +34,14 @@ export const MRT_ToggleColumnActionMenuButton: FC<Props> = ({
34
34
 
35
35
  const mTableHeadCellColumnActionsButtonProps =
36
36
  muiTableHeadCellColumnActionsButtonProps instanceof Function
37
- ? muiTableHeadCellColumnActionsButtonProps({ column, tableInstance })
37
+ ? muiTableHeadCellColumnActionsButtonProps({ column, instance })
38
38
  : muiTableHeadCellColumnActionsButtonProps;
39
39
 
40
40
  const mcTableHeadCellColumnActionsButtonProps =
41
41
  columnDef.muiTableHeadCellColumnActionsButtonProps instanceof Function
42
42
  ? columnDef.muiTableHeadCellColumnActionsButtonProps({
43
43
  column,
44
- tableInstance,
44
+ instance,
45
45
  })
46
46
  : columnDef.muiTableHeadCellColumnActionsButtonProps;
47
47
 
@@ -84,7 +84,7 @@ export const MRT_ToggleColumnActionMenuButton: FC<Props> = ({
84
84
  anchorEl={anchorEl}
85
85
  header={header}
86
86
  setAnchorEl={setAnchorEl}
87
- tableInstance={tableInstance}
87
+ instance={instance}
88
88
  />
89
89
  </>
90
90
  );
@@ -3,11 +3,11 @@ import { IconButton, IconButtonProps, Tooltip } from '@mui/material';
3
3
  import { MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props extends IconButtonProps {
6
- tableInstance: MRT_TableInstance;
6
+ instance: MRT_TableInstance;
7
7
  }
8
8
 
9
9
  export const MRT_ToggleDensePaddingButton: FC<Props> = ({
10
- tableInstance,
10
+ instance,
11
11
  ...rest
12
12
  }) => {
13
13
  const {
@@ -18,7 +18,7 @@ export const MRT_ToggleDensePaddingButton: FC<Props> = ({
18
18
  onMrtToggleDensePadding,
19
19
  },
20
20
  setIsDensePadding,
21
- } = tableInstance;
21
+ } = instance;
22
22
 
23
23
  const { isDensePadding } = getState();
24
24
 
@@ -26,7 +26,7 @@ export const MRT_ToggleDensePaddingButton: FC<Props> = ({
26
26
  onMrtToggleDensePadding?.({
27
27
  event,
28
28
  isDensePadding: !isDensePadding,
29
- tableInstance,
29
+ instance,
30
30
  });
31
31
  setIsDensePadding(!isDensePadding);
32
32
  };
@@ -3,13 +3,10 @@ import { IconButton, IconButtonProps, Tooltip } from '@mui/material';
3
3
  import { MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props extends IconButtonProps {
6
- tableInstance: MRT_TableInstance;
6
+ instance: MRT_TableInstance;
7
7
  }
8
8
 
9
- export const MRT_ToggleFiltersButton: FC<Props> = ({
10
- tableInstance,
11
- ...rest
12
- }) => {
9
+ export const MRT_ToggleFiltersButton: FC<Props> = ({ instance, ...rest }) => {
13
10
  const {
14
11
  getState,
15
12
  options: {
@@ -18,7 +15,7 @@ export const MRT_ToggleFiltersButton: FC<Props> = ({
18
15
  onMrtToggleShowFilters,
19
16
  },
20
17
  setShowFilters,
21
- } = tableInstance;
18
+ } = instance;
22
19
 
23
20
  const { showFilters } = getState();
24
21
 
@@ -26,7 +23,7 @@ export const MRT_ToggleFiltersButton: FC<Props> = ({
26
23
  onMrtToggleShowFilters?.({
27
24
  event,
28
25
  showFilters: !showFilters,
29
- tableInstance,
26
+ instance,
30
27
  });
31
28
  setShowFilters(!showFilters);
32
29
  };
@@ -3,11 +3,11 @@ import { IconButton, IconButtonProps, Tooltip } from '@mui/material';
3
3
  import { MRT_TableInstance } from '..';
4
4
 
5
5
  interface Props extends IconButtonProps {
6
- tableInstance: MRT_TableInstance;
6
+ instance: MRT_TableInstance;
7
7
  }
8
8
 
9
9
  export const MRT_ToggleGlobalFilterButton: FC<Props> = ({
10
- tableInstance,
10
+ instance,
11
11
  ...rest
12
12
  }) => {
13
13
  const {
@@ -20,20 +20,20 @@ export const MRT_ToggleGlobalFilterButton: FC<Props> = ({
20
20
  onMrtToggleShowGlobalFilter,
21
21
  },
22
22
  setShowGlobalFilter,
23
- } = tableInstance;
23
+ } = instance;
24
24
 
25
25
  const { showGlobalFilter } = getState();
26
26
 
27
27
  const textFieldProps =
28
28
  muiSearchTextFieldProps instanceof Function
29
- ? muiSearchTextFieldProps({ tableInstance })
29
+ ? muiSearchTextFieldProps({ instance })
30
30
  : muiSearchTextFieldProps;
31
31
 
32
32
  const handleToggleSearch = (event: MouseEvent<HTMLButtonElement>) => {
33
33
  onMrtToggleShowGlobalFilter?.({
34
34
  event,
35
35
  showGlobalFilter: !showGlobalFilter,
36
- tableInstance,
36
+ instance,
37
37
  });
38
38
  setShowGlobalFilter(!showGlobalFilter);
39
39
  setTimeout(