material-react-table 0.7.0-alpha.12 → 0.7.0-alpha.13

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.
@@ -282,7 +282,7 @@ export declare type MaterialReactTableProps<D extends Record<string, any> = {}>
282
282
  row: MRT_Row<D>;
283
283
  tableInstance: MRT_TableInstance<D>;
284
284
  }) => void;
285
- onGlobalFilterChange?: ({ event, tableInstance, }: {
285
+ onGlobalSearchFilterChange?: ({ event, tableInstance, }: {
286
286
  event: ChangeEvent<HTMLInputElement>;
287
287
  tableInstance: MRT_TableInstance<D>;
288
288
  }) => void;
@@ -46,6 +46,8 @@ export interface MRT_Localization {
46
46
  showHideSearch: string;
47
47
  sortByColumnAsc: string;
48
48
  sortByColumnDesc: string;
49
+ sortedByColumnAsc: string;
50
+ sortedByColumnDesc: string;
49
51
  thenBy: string;
50
52
  toggleDensePadding: string;
51
53
  toggleFullScreen: string;
@@ -53,5 +55,6 @@ export interface MRT_Localization {
53
55
  toggleSelectRow: string;
54
56
  ungroupByColumn: string;
55
57
  unpin: string;
58
+ unsorted: string;
56
59
  }
57
60
  export declare const MRT_DefaultLocalization_EN: MRT_Localization;
@@ -118,13 +118,16 @@ var MRT_DefaultLocalization_EN = {
118
118
  showHideSearch: 'Show/Hide search',
119
119
  sortByColumnAsc: 'Sort by {column} ascending',
120
120
  sortByColumnDesc: 'Sort by {column} descending',
121
+ sortedByColumnAsc: 'Sorted by {column} ascending',
122
+ sortedByColumnDesc: 'Sorted by {column} descending',
121
123
  thenBy: ', then by ',
122
124
  toggleDensePadding: 'Toggle dense padding',
123
125
  toggleFullScreen: 'Toggle full screen',
124
126
  toggleSelectAll: 'Toggle select all',
125
127
  toggleSelectRow: 'Toggle select row',
126
128
  ungroupByColumn: 'Ungroup by {column}',
127
- unpin: 'Unpin'
129
+ unpin: 'Unpin',
130
+ unsorted: 'Unsorted'
128
131
  };
129
132
 
130
133
  var MRT_Default_Icons = {
@@ -1159,7 +1162,7 @@ var MRT_SearchTextField = function MRT_SearchTextField(_ref) {
1159
1162
  idPrefix = _tableInstance$option.idPrefix,
1160
1163
  localization = _tableInstance$option.localization,
1161
1164
  muiSearchTextFieldProps = _tableInstance$option.muiSearchTextFieldProps,
1162
- onGlobalFilterChange = _tableInstance$option.onGlobalFilterChange;
1165
+ onGlobalSearchFilterChange = _tableInstance$option.onGlobalSearchFilterChange;
1163
1166
 
1164
1167
  var _getState = getState(),
1165
1168
  globalFilter = _getState.globalFilter,
@@ -1177,7 +1180,7 @@ var MRT_SearchTextField = function MRT_SearchTextField(_ref) {
1177
1180
  var _event$target$value;
1178
1181
 
1179
1182
  setGlobalFilter((_event$target$value = event.target.value) != null ? _event$target$value : undefined);
1180
- onGlobalFilterChange == null ? void 0 : onGlobalFilterChange({
1183
+ onGlobalSearchFilterChange == null ? void 0 : onGlobalSearchFilterChange({
1181
1184
  event: event,
1182
1185
  tableInstance: tableInstance
1183
1186
  });
@@ -1221,9 +1224,7 @@ var MRT_SearchTextField = function MRT_SearchTextField(_ref) {
1221
1224
  height: '1.75rem',
1222
1225
  width: '1.75rem'
1223
1226
  }
1224
- }, React__default.createElement(SearchIcon, {
1225
- fontSize: "small"
1226
- }))))),
1227
+ }, React__default.createElement(SearchIcon, null))))),
1227
1228
  endAdornment: React__default.createElement(material.InputAdornment, {
1228
1229
  position: "end"
1229
1230
  }, React__default.createElement(material.IconButton, {
@@ -1232,9 +1233,7 @@ var MRT_SearchTextField = function MRT_SearchTextField(_ref) {
1232
1233
  onClick: handleClear,
1233
1234
  size: "small",
1234
1235
  title: localization.clearSearch
1235
- }, React__default.createElement(CloseIcon, {
1236
- fontSize: "small"
1237
- })))
1236
+ }, React__default.createElement(CloseIcon, null)))
1238
1237
  }
1239
1238
  }, textFieldProps, {
1240
1239
  sx: _extends({
@@ -1278,8 +1277,7 @@ var MRT_FullScreenToggleButton = function MRT_FullScreenToggleButton(_ref) {
1278
1277
  title: localization.toggleFullScreen
1279
1278
  }, React__default.createElement(material.IconButton, Object.assign({
1280
1279
  "aria-label": localization.showHideFilters,
1281
- onClick: handleToggleFullScreen,
1282
- size: "small"
1280
+ onClick: handleToggleFullScreen
1283
1281
  }, rest), isFullScreen ? React__default.createElement(FullscreenExitIcon, null) : React__default.createElement(FullscreenIcon, null)));
1284
1282
  };
1285
1283
 
@@ -1305,8 +1303,7 @@ var MRT_ShowHideColumnsButton = function MRT_ShowHideColumnsButton(_ref) {
1305
1303
  title: localization.showHideColumns
1306
1304
  }, React__default.createElement(material.IconButton, Object.assign({
1307
1305
  "aria-label": localization.showHideColumns,
1308
- onClick: handleClick,
1309
- size: "small"
1306
+ onClick: handleClick
1310
1307
  }, rest), React__default.createElement(ViewColumnIcon, null))), React__default.createElement(MRT_ShowHideColumnsMenu, {
1311
1308
  anchorEl: anchorEl,
1312
1309
  setAnchorEl: setAnchorEl,
@@ -1345,8 +1342,7 @@ var MRT_ToggleDensePaddingButton = function MRT_ToggleDensePaddingButton(_ref) {
1345
1342
  title: localization.toggleDensePadding
1346
1343
  }, React__default.createElement(material.IconButton, Object.assign({
1347
1344
  "aria-label": localization.toggleDensePadding,
1348
- onClick: handleToggleDensePadding,
1349
- size: "small"
1345
+ onClick: handleToggleDensePadding
1350
1346
  }, rest), isDensePadding ? React__default.createElement(DensitySmallIcon, null) : React__default.createElement(DensityMediumIcon, null)));
1351
1347
  };
1352
1348
 
@@ -1381,8 +1377,7 @@ var MRT_ToggleFiltersButton = function MRT_ToggleFiltersButton(_ref) {
1381
1377
  title: localization.showHideFilters
1382
1378
  }, React__default.createElement(material.IconButton, Object.assign({
1383
1379
  "aria-label": localization.showHideFilters,
1384
- onClick: handleToggleShowFilters,
1385
- size: "small"
1380
+ onClick: handleToggleShowFilters
1386
1381
  }, rest), showFilters ? React__default.createElement(FilterListOffIcon, null) : React__default.createElement(FilterListIcon, null)));
1387
1382
  };
1388
1383
 
@@ -1427,7 +1422,6 @@ var MRT_ToggleGlobalFilterButton = function MRT_ToggleGlobalFilterButton(_ref) {
1427
1422
  arrow: true,
1428
1423
  title: localization.showHideSearch
1429
1424
  }, React__default.createElement(material.IconButton, Object.assign({
1430
- size: "small",
1431
1425
  onClick: handleToggleSearch
1432
1426
  }, rest), showGlobalFilter ? React__default.createElement(SearchOffIcon, null) : React__default.createElement(SearchIcon, null)));
1433
1427
  };
@@ -1457,9 +1451,7 @@ var MRT_ToolbarInternalButtons = function MRT_ToolbarInternalButtons(_ref) {
1457
1451
  return React__default.createElement(material.Box, {
1458
1452
  sx: {
1459
1453
  display: 'flex',
1460
- gap: '0.5rem',
1461
- alignItems: 'center',
1462
- p: '0 0.5rem'
1454
+ alignItems: 'center'
1463
1455
  }
1464
1456
  }, enableFilters && enableGlobalFilter && React__default.createElement(MRT_ToggleGlobalFilterButton, {
1465
1457
  tableInstance: tableInstance
@@ -1877,9 +1869,7 @@ var MRT_FilterTextField = function MRT_FilterTextField(_ref) {
1877
1869
  height: '1.75rem',
1878
1870
  width: '1.75rem'
1879
1871
  }
1880
- }, React__default.createElement(CloseIcon, {
1881
- fontSize: "small"
1882
- })))))
1872
+ }, React__default.createElement(CloseIcon, null)))))
1883
1873
  }
1884
1874
  }, textFieldProps, {
1885
1875
  sx: _extends({
@@ -2013,7 +2003,7 @@ var MRT_TableHeadCell = function MRT_TableHeadCell(_ref) {
2013
2003
 
2014
2004
  var tableCellProps = _extends({}, header.getHeaderProps(), mTableHeadCellProps, mcTableHeadCellProps);
2015
2005
 
2016
- var sortTooltip = !!column.getIsSorted() ? column.getIsSorted() === 'desc' ? localization.clearSort : localization.sortByColumnDesc.replace('{column}', column.header) : localization.sortByColumnAsc.replace('{column}', column.header);
2006
+ var sortTooltip = !!column.getIsSorted() ? column.getIsSorted() === 'desc' ? localization.sortedByColumnDesc.replace('{column}', column.header) : localization.sortedByColumnAsc.replace('{column}', column.header) : localization.unsorted;
2017
2007
  var filterType = (_getState2 = getState()) == null ? void 0 : (_getState2$currentFil = _getState2.currentFilterTypes) == null ? void 0 : _getState2$currentFil[header.id];
2018
2008
  var filterTooltip = !!column.getColumnFilterValue() ? localization.filteringByColumn.replace('{column}', String(column.header)).replace('{filterType}', filterType instanceof Function ? '' : // @ts-ignore
2019
2009
  localization["filter" + (filterType.charAt(0).toUpperCase() + filterType.slice(1))]).replace('{filterValue}', column.getColumnFilterValue()).replace('" "', '') : localization.showHideFilters;
@@ -2048,16 +2038,18 @@ var MRT_TableHeadCell = function MRT_TableHeadCell(_ref) {
2048
2038
  justifyContent: column.columnDefType === 'group' ? 'center' : 'space-between',
2049
2039
  width: '100%'
2050
2040
  }
2051
- }, React__default.createElement(material.Box, Object.assign({}, column.getToggleSortingProps(), {
2041
+ }, React__default.createElement(material.Box, {
2042
+ onClick: function onClick() {
2043
+ return column.toggleSorting();
2044
+ },
2052
2045
  sx: {
2053
2046
  alignItems: 'center',
2054
2047
  cursor: column.getCanSort() && column.columnDefType !== 'group' ? 'pointer' : undefined,
2055
2048
  display: 'flex',
2056
2049
  flexWrap: 'nowrap',
2057
2050
  whiteSpace: column.header.length < 15 ? 'nowrap' : 'normal'
2058
- },
2059
- title: undefined
2060
- }), headerElement, column.columnDefType !== 'group' && column.getCanSort() && React__default.createElement(material.Tooltip, {
2051
+ }
2052
+ }, headerElement, column.columnDefType !== 'group' && column.getCanSort() && React__default.createElement(material.Tooltip, {
2061
2053
  arrow: true,
2062
2054
  placement: "top",
2063
2055
  title: sortTooltip
@@ -2086,11 +2078,7 @@ var MRT_TableHeadCell = function MRT_TableHeadCell(_ref) {
2086
2078
  opacity: 0.8
2087
2079
  }
2088
2080
  }
2089
- }, showFilters && !column.getColumnFilterValue() ? React__default.createElement(FilterAltOff, {
2090
- fontSize: "small"
2091
- }) : React__default.createElement(FilterAltIcon, {
2092
- fontSize: "small"
2093
- })))), React__default.createElement(material.Box, {
2081
+ }, showFilters && !column.getColumnFilterValue() ? React__default.createElement(FilterAltOff, null) : React__default.createElement(FilterAltIcon, null)))), React__default.createElement(material.Box, {
2094
2082
  sx: {
2095
2083
  alignItems: 'center',
2096
2084
  display: 'flex',
@@ -2864,7 +2852,9 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
2864
2852
  return Object.assign.apply(Object, [{}].concat(getAllLeafColumnDefs(props.columns).map(function (c) {
2865
2853
  var _ref, _c$filter, _props$initialState8, _props$initialState8$, _c$filterSelectOption, _ref2;
2866
2854
 
2867
- return _ref2 = {}, _ref2[c.id] = (_ref = (_c$filter = c.filter) != null ? _c$filter : props == null ? void 0 : (_props$initialState8 = props.initialState) == null ? void 0 : (_props$initialState8$ = _props$initialState8.columnFilters) == null ? void 0 : _props$initialState8$[c.id]) != null ? _ref : !!((_c$filterSelectOption = c.filterSelectOptions) != null && _c$filterSelectOption.length) ? MRT_FILTER_TYPE.EQUALS : MRT_FILTER_TYPE.BEST_MATCH, _ref2;
2855
+ return _ref2 = {}, _ref2[c.id] = (_ref = (_c$filter = c.filter) != null ? _c$filter : props == null ? void 0 : (_props$initialState8 = props.initialState) == null ? void 0 : (_props$initialState8$ = _props$initialState8.columnFilters) == null ? void 0 : _props$initialState8$.find(function (cf) {
2856
+ return cf.id === c.id;
2857
+ })) != null ? _ref : !!((_c$filterSelectOption = c.filterSelectOptions) != null && _c$filterSelectOption.length) ? MRT_FILTER_TYPE.EQUALS : MRT_FILTER_TYPE.BEST_MATCH, _ref2;
2868
2858
  })));
2869
2859
  }),
2870
2860
  currentFilterTypes = _useState7[0],
@@ -2959,19 +2949,22 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
2959
2949
  }) : props.data;
2960
2950
  }, [props.data, props.isLoading]); //@ts-ignore
2961
2951
 
2962
- var tableInstance = _extends({}, reactTable.useTable(table, _extends({}, props, {
2963
- columnFilterRowsFn: reactTable.columnFilterRowsFn,
2952
+ var tableInstance = _extends({}, reactTable.useTableInstance(table, _extends({}, props, {
2964
2953
  columns: columns,
2965
2954
  data: data,
2966
- expandRowsFn: reactTable.expandRowsFn,
2967
2955
  //@ts-ignore
2968
2956
  filterTypes: defaultFilterFNs,
2957
+ getColumnFilteredRowModel: reactTable.getColumnFilteredRowModelSync(),
2958
+ getCoreRowModel: reactTable.getCoreRowModelSync(),
2959
+ getExpandedRowModel: reactTable.getExpandedRowModel(),
2960
+ getGlobalFilteredRowModel: reactTable.getGlobalFilteredRowModelSync(),
2961
+ getGroupedRowModel: reactTable.getGroupedRowModelSync(),
2962
+ getPaginationRowModel: reactTable.getPaginationRowModel(),
2963
+ getSortedRowModel: reactTable.getSortedRowModelSync(),
2969
2964
  getSubRows: (_props$getSubRows = props.getSubRows) != null ? _props$getSubRows : function (originalRow) {
2970
2965
  return originalRow.subRows;
2971
2966
  },
2972
- globalFilterRowsFn: reactTable.globalFilterRowsFn,
2973
2967
  globalFilterType: currentGlobalFilterType,
2974
- groupRowsFn: reactTable.groupRowsFn,
2975
2968
  idPrefix: idPrefix,
2976
2969
  //@ts-ignore
2977
2970
  initialState: props.initialState,
@@ -2980,8 +2973,6 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
2980
2973
  return reactTable.functionalUpdate(updater, old);
2981
2974
  });
2982
2975
  },
2983
- paginateRowsFn: reactTable.paginateRowsFn,
2984
- sortRowsFn: reactTable.sortRowsFn,
2985
2976
  state: _extends({
2986
2977
  currentEditingRow: currentEditingRow,
2987
2978
  currentFilterTypes: currentFilterTypes,
@@ -3009,12 +3000,6 @@ var MRT_TableRoot = function MRT_TableRoot(props) {
3009
3000
  };
3010
3001
 
3011
3002
  var _excluded$5 = ["autoResetExpanded", "enableColumnActions", "enableColumnFilters", "enableDensePaddingToggle", "enableExpandAll", "enableFilters", "enableFullScreenToggle", "enableGlobalFilter", "enableHiding", "enableMultiRowSelection", "enablePagination", "enableSelectAll", "enableSorting", "enableStickyHeader", "icons", "localization", "positionActionsColumn", "positionPagination", "positionToolbarActions", "positionToolbarAlertBanner"];
3012
-
3013
- global.performance = global.performance || {
3014
- now: function now() {
3015
- return new Date().getTime();
3016
- }
3017
- };
3018
3003
  var MaterialReactTable = (function (_ref) {
3019
3004
  var _ref$autoResetExpande = _ref.autoResetExpanded,
3020
3005
  autoResetExpanded = _ref$autoResetExpande === void 0 ? false : _ref$autoResetExpande,