material-react-table 2.0.0-alpha.2 → 2.0.0-alpha.3

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.
@@ -0,0 +1,94 @@
1
+ import { type MRT_Localization } from '..';
2
+
3
+ export const MRT_Localization_NP: MRT_Localization = {
4
+ actions: 'कार्यहरू',
5
+ and: 'तथा',
6
+ cancel: 'रद्द गर्नुहोस्',
7
+ changeFilterMode: 'फिल्टर प्रणाली परिवर्तन गर्नुहोस्',
8
+ changeSearchMode: 'खोज प्रणाली परिवर्तन गर्नुहोस्',
9
+ clearFilter: 'फिल्टर हटाउनुहोस्',
10
+ clearSearch: 'खोजिएको शब्द मेट्नुहोस्',
11
+ clearSort: 'क्रम हटाउनुहोस्',
12
+ clickToCopy: 'प्रतिलिपि बनाउन क्लिक गर्नुहोस्',
13
+ collapse: 'संकुचित गर्नुहोस्',
14
+ collapseAll: 'सबै संकुचित गर्नुहोस्',
15
+ columnActions: 'यस स्तम्भका कार्यहरू',
16
+ copiedToClipboard: 'क्लिपबोर्डमा प्रतिलिपि गरियो',
17
+ dropToGroupBy: '{column} का आधारमा समूह बनाउनुहोस्',
18
+ edit: 'सम्पादन गर्नुहोस्',
19
+ expand: 'विस्तार गर्नुहोस्',
20
+ expandAll: 'सबै विस्तार गर्नुहोस्',
21
+ filterArrIncludes: 'समावेश भएको',
22
+ filterArrIncludesAll: 'सबै समावेश भएको',
23
+ filterArrIncludesSome: 'केही समावेश भएको',
24
+ filterBetween: 'बीचको',
25
+ filterBetweenInclusive: 'बीचमा समावेश गरिएको',
26
+ filterByColumn: '{column} का आधारमा फिल्टर गर्नुहोस्',
27
+ filterContains: 'समावेश गरिएको',
28
+ filterEmpty: 'खाली भएको',
29
+ filterEndsWith: 'अन्तमा समावेश गरिएको',
30
+ filterEquals: 'समान',
31
+ filterEqualsString: 'समान',
32
+ filterFuzzy: 'अस्पष्ट',
33
+ filterGreaterThan: 'ठुलो भएको',
34
+ filterGreaterThanOrEqualTo: 'ठुलो वा समान',
35
+ filterInNumberRange: 'संख्या दायरामा',
36
+ filterIncludesString: 'समावेश गरिएको',
37
+ filterIncludesStringSensitive: 'समावेश गरिएको (संवेदनशील)',
38
+ filterLessThan: 'सानो भएको',
39
+ filterLessThanOrEqualTo: 'सानो वा समान',
40
+ filterMode: 'फिल्टर प्रणाली: {filterType}',
41
+ filterNotEmpty: 'खाली नभएको',
42
+ filterNotEquals: 'असमान',
43
+ filterStartsWith: 'सुरुमा समावेश गरिएको',
44
+ filterWeakEquals: 'असमान',
45
+ filteringByColumn: '{column} द्वारा फिल्टर गर्दै - {filterType} {filterValue}',
46
+ goToFirstPage: 'पहिलो पृष्ठमा जानुहोस्',
47
+ goToLastPage: 'अन्तिम पृष्ठमा जानुहोस्',
48
+ goToNextPage: 'अर्को पृष्ठमा जानुहोस्',
49
+ goToPreviousPage: 'अघिल्लो पृष्ठमा जानुहोस्',
50
+ grab: 'ग्र्याब गर्नुहोस',
51
+ groupByColumn: '{column} का आधारमा समूह बनाउनुहोस्',
52
+ groupedBy: 'समूह बनाईएको आधार',
53
+ hideAll: 'सबै लुकाउनुहोस्',
54
+ hideColumn: '{column} स्तम्भ लुकाउनुहोस्',
55
+ max: 'अधिकतम',
56
+ min: 'न्यूनतम',
57
+ move: 'सार्नुहोस्',
58
+ noRecordsToDisplay: 'केही रेकर्ड छैन',
59
+ noResultsFound: 'कुनै परिणाम फेला परेन',
60
+ of: ', कुल संख्या: ',
61
+ or: 'वा',
62
+ pin: 'पिन गर्नुहोस्',
63
+ pinToLeft: 'बायाँतर्फ पिन गर्नुहोस्',
64
+ pinToRight: 'दायाँतर्फ पिन गर्नुहोस्',
65
+ resetColumnSize: 'स्तम्भ आकार रिसेट गर्नुहोस्',
66
+ resetOrder: 'क्रम रिसेट गर्नुहोस्',
67
+ rowActions: 'पंक्तिका कार्यहरू',
68
+ rowNumber: 'क्र.सं.',
69
+ rowNumbers: 'क्रमाङ्क',
70
+ rowsPerPage: 'प्रति पृष्ठ',
71
+ save: 'सुरक्षित गर्नुहोस्',
72
+ search: 'खोज्नुहोस्',
73
+ selectedCountOfRowCountRowsSelected:
74
+ '{rowCount} पंक्ति(हरू)बाट {selectedCount} चयनित',
75
+ select: 'चयन गर्नुहोस्',
76
+ showAll: 'सबै देखाउनुहोस्',
77
+ showAllColumns: 'सबै स्तम्भ देखाउनुहोस्',
78
+ showHideColumns: 'स्तम्भ देखाउनुहोस्/लुकाउनुहोस्',
79
+ showHideFilters: 'फिल्टर देखाउनुहोस्/लुकाउनुहोस्',
80
+ showHideSearch: 'खोज-क्षेत्र देखाउनुहोस्/लुकाउनुहोस्',
81
+ sortByColumnAsc: '{column}का आधारमा बढ्दो क्रममा क्रमबद्ध गर्नुहोस्',
82
+ sortByColumnDesc: '{column}का आधारमा घट्दो क्रममा क्रमबद्ध गर्नुहोस्',
83
+ sortedByColumnAsc: '{column}का आधारमा बढ्दो क्रममा क्रमबद्ध गरिएको',
84
+ sortedByColumnDesc: '{column}का आधारमा घट्दो क्रममा क्रमबद्ध गरिएको',
85
+ thenBy: ', त्यसपछि ',
86
+ toggleDensity: 'घनत्व परिवर्तन गर्नुहोस्',
87
+ toggleFullScreen: 'पूर्ण स्क्रिनमा लग्नुहोस्/हटाउनुहोस्',
88
+ toggleSelectAll: 'सबै चयन गर्नुहोस्/हटाउनुहोस्',
89
+ toggleSelectRow: 'पंक्ति चयन गर्नुहोस्/हटाउनुहोस्',
90
+ toggleVisibility: 'दृश्यता परिवर्तन गर्नुहोस्',
91
+ ungroupByColumn: '{column} का आधारमा समूह हटाउनुहोस्',
92
+ unpin: 'अनपिन गर्नुहोस्',
93
+ unpinAll: 'सबै अनपिन गर्नुहोस्'
94
+ };
@@ -36,6 +36,7 @@ export const MRT_ColumnActionMenu = <TData extends Record<string, any>>({
36
36
  const {
37
37
  getState,
38
38
  options: {
39
+ columnFilterDisplayMode,
39
40
  columnFilterModeOptions,
40
41
  enableColumnFilterModes,
41
42
  enableColumnFilters,
@@ -217,37 +218,39 @@ export const MRT_ColumnActionMenu = <TData extends Record<string, any>>({
217
218
  {localization.clearFilter}
218
219
  </Box>
219
220
  </MenuItem>,
220
- <MenuItem
221
- disabled={showColumnFilters && !enableColumnFilterModes}
222
- divider={enableGrouping || enableHiding}
223
- key={4}
224
- onClick={
225
- showColumnFilters
226
- ? handleOpenFilterModeMenu
227
- : handleFilterByColumn
228
- }
229
- sx={commonMenuItemStyles}
230
- >
231
- <Box sx={commonListItemStyles}>
232
- <ListItemIcon>
233
- <FilterListIcon />
234
- </ListItemIcon>
235
- {localization.filterByColumn?.replace(
236
- '{column}',
237
- String(columnDef.header),
221
+ columnFilterDisplayMode === 'subheader' && (
222
+ <MenuItem
223
+ disabled={showColumnFilters && !enableColumnFilterModes}
224
+ divider={enableGrouping || enableHiding}
225
+ key={4}
226
+ onClick={
227
+ showColumnFilters
228
+ ? handleOpenFilterModeMenu
229
+ : handleFilterByColumn
230
+ }
231
+ sx={commonMenuItemStyles}
232
+ >
233
+ <Box sx={commonListItemStyles}>
234
+ <ListItemIcon>
235
+ <FilterListIcon />
236
+ </ListItemIcon>
237
+ {localization.filterByColumn?.replace(
238
+ '{column}',
239
+ String(columnDef.header),
240
+ )}
241
+ </Box>
242
+ {showFilterModeSubMenu && (
243
+ <IconButton
244
+ onClick={handleOpenFilterModeMenu}
245
+ onMouseEnter={handleOpenFilterModeMenu}
246
+ size="small"
247
+ sx={{ p: 0 }}
248
+ >
249
+ <ArrowRightIcon />
250
+ </IconButton>
238
251
  )}
239
- </Box>
240
- {showFilterModeSubMenu && (
241
- <IconButton
242
- onClick={handleOpenFilterModeMenu}
243
- onMouseEnter={handleOpenFilterModeMenu}
244
- size="small"
245
- sx={{ p: 0 }}
246
- >
247
- <ArrowRightIcon />
248
- </IconButton>
249
- )}
250
- </MenuItem>,
252
+ </MenuItem>
253
+ ),
251
254
  showFilterModeSubMenu && (
252
255
  <MRT_FilterOptionMenu
253
256
  anchorEl={filterMenuAnchorEl}
@@ -258,7 +261,7 @@ export const MRT_ColumnActionMenu = <TData extends Record<string, any>>({
258
261
  table={table}
259
262
  />
260
263
  ),
261
- ]
264
+ ].filter(Boolean)
262
265
  : []),
263
266
  ...(enableGrouping && column.getCanGroup()
264
267
  ? [
@@ -199,7 +199,7 @@ export const MRT_FilterOptionMenu = <TData extends Record<string, any>>({
199
199
  column.setFilterValue(currentFilterValue); // perform new filter render
200
200
  }
201
201
  } else if (
202
- columnDef?.filterVariant === 'range' ||
202
+ columnDef?.filterVariant?.includes('range') ||
203
203
  rangeModes.includes(option as MRT_FilterOption)
204
204
  ) {
205
205
  // will now be range filter mode
package/src/types.ts CHANGED
@@ -38,6 +38,7 @@ import {
38
38
  type Virtualizer,
39
39
  type VirtualizerOptions,
40
40
  } from '@tanstack/react-virtual';
41
+ import { type AutocompleteProps } from '@mui/material';
41
42
  import { type AlertProps } from '@mui/material/Alert';
42
43
  import { type ButtonProps } from '@mui/material/Button';
43
44
  import { type CheckboxProps } from '@mui/material/Checkbox';
@@ -59,6 +60,7 @@ import { type TablePaginationProps } from '@mui/material/TablePagination';
59
60
  import { type TableRowProps } from '@mui/material/TableRow';
60
61
  import { type TextFieldProps } from '@mui/material/TextField';
61
62
  import { type ToolbarProps } from '@mui/material/Toolbar';
63
+ import { type DatePickerProps } from '@mui/x-date-pickers';
62
64
  import { type MRT_AggregationFns } from './aggregationFns';
63
65
  import { type MRT_FilterFns } from './filterFns';
64
66
  import { type MRT_Icons } from './icons';
@@ -406,7 +408,10 @@ export type MRT_ColumnDef<TData extends Record<string, any>> = Omit<
406
408
  filterFn?: MRT_FilterFn<TData>;
407
409
  filterSelectOptions?: ({ text: string; value: any } | string)[];
408
410
  filterVariant?:
411
+ | 'autocomplete'
409
412
  | 'checkbox'
413
+ | 'date'
414
+ | 'date-range'
410
415
  | 'multi-select'
411
416
  | 'range'
412
417
  | 'range-slider'
@@ -458,12 +463,25 @@ export type MRT_ColumnDef<TData extends Record<string, any>> = Omit<
458
463
  table: MRT_TableInstance<TData>;
459
464
  }) => TextFieldProps)
460
465
  | TextFieldProps;
466
+ muiFilterAutocompleteProps?:
467
+ | ((props: {
468
+ column: MRT_Column<TData>;
469
+ table: MRT_TableInstance<TData>;
470
+ }) => AutocompleteProps<any, any, any, any>)
471
+ | AutocompleteProps<any, any, any, any>;
461
472
  muiFilterCheckboxProps?:
462
473
  | ((props: {
463
474
  column: MRT_Column<TData>;
464
475
  table: MRT_TableInstance<TData>;
465
476
  }) => CheckboxProps)
466
477
  | CheckboxProps;
478
+ muiFilterDatePickerProps?:
479
+ | ((props: {
480
+ column: MRT_Column<TData>;
481
+ rangeFilterIndex?: number;
482
+ table: MRT_TableInstance<TData>;
483
+ }) => DatePickerProps<any>)
484
+ | DatePickerProps<any>;
467
485
  muiFilterSliderProps?:
468
486
  | ((props: {
469
487
  column: MRT_Column<TData>;
@@ -782,12 +800,25 @@ export type MRT_TableOptions<TData extends Record<string, any>> = Omit<
782
800
  table: MRT_TableInstance<TData>;
783
801
  }) => IconButtonProps)
784
802
  | IconButtonProps;
803
+ muiFilterAutocompleteProps?:
804
+ | ((props: {
805
+ column: MRT_Column<TData>;
806
+ table: MRT_TableInstance<TData>;
807
+ }) => AutocompleteProps<any, any, any, any>)
808
+ | AutocompleteProps<any, any, any, any>;
785
809
  muiFilterCheckboxProps?:
786
810
  | ((props: {
787
811
  column: MRT_Column<TData>;
788
812
  table: MRT_TableInstance<TData>;
789
813
  }) => CheckboxProps)
790
814
  | CheckboxProps;
815
+ muiFilterDatePickerProps?:
816
+ | ((props: {
817
+ column: MRT_Column<TData>;
818
+ rangeFilterIndex?: number;
819
+ table: MRT_TableInstance<TData>;
820
+ }) => DatePickerProps<any>)
821
+ | DatePickerProps<any>;
791
822
  muiFilterSliderProps?:
792
823
  | ((props: {
793
824
  column: MRT_Column<TData>;