UNPKG

@mui/x-data-grid

Version:

The community edition of the data grid component (MUI X).

106 lines 3.63 kB
import { GridFilterInputValue } from '../components/panel/filterPanel/GridFilterInputValue'; import { escapeRegExp } from '../utils/utils'; import { GridFilterInputMultipleValue } from '../components/panel/filterPanel/GridFilterInputMultipleValue'; import { convertLegacyOperators, tagInternalFilter } from './utils'; import { removeDiacritics } from '../hooks/features/filter/gridFilterUtils'; export const getGridStringQuickFilterFn = tagInternalFilter(value => { if (!value) { return null; } const filterRegex = new RegExp(escapeRegExp(value), 'i'); return (_, row, column, apiRef) => { let columnValue = apiRef.current.getRowFormattedValue(row, column); if (apiRef.current.ignoreDiacritics) { columnValue = removeDiacritics(columnValue); } return columnValue != null ? filterRegex.test(columnValue.toString()) : false; }; }); export const getGridStringOperators = (disableTrim = false) => convertLegacyOperators([{ value: 'contains', getApplyFilterFnV7: filterItem => { if (!filterItem.value) { return null; } const filterItemValue = disableTrim ? filterItem.value : filterItem.value.trim(); const filterRegex = new RegExp(escapeRegExp(filterItemValue), 'i'); return value => { return value != null ? filterRegex.test(String(value)) : false; }; }, InputComponent: GridFilterInputValue }, { value: 'equals', getApplyFilterFnV7: filterItem => { if (!filterItem.value) { return null; } const filterItemValue = disableTrim ? filterItem.value : filterItem.value.trim(); const collator = new Intl.Collator(undefined, { sensitivity: 'base', usage: 'search' }); return value => { return value != null ? collator.compare(filterItemValue, value.toString()) === 0 : false; }; }, InputComponent: GridFilterInputValue }, { value: 'startsWith', getApplyFilterFnV7: filterItem => { if (!filterItem.value) { return null; } const filterItemValue = disableTrim ? filterItem.value : filterItem.value.trim(); const filterRegex = new RegExp(`^${escapeRegExp(filterItemValue)}.*$`, 'i'); return value => { return value != null ? filterRegex.test(value.toString()) : false; }; }, InputComponent: GridFilterInputValue }, { value: 'endsWith', getApplyFilterFnV7: filterItem => { if (!filterItem.value) { return null; } const filterItemValue = disableTrim ? filterItem.value : filterItem.value.trim(); const filterRegex = new RegExp(`.*${escapeRegExp(filterItemValue)}$`, 'i'); return value => { return value != null ? filterRegex.test(value.toString()) : false; }; }, InputComponent: GridFilterInputValue }, { value: 'isEmpty', getApplyFilterFnV7: () => { return value => { return value === '' || value == null; }; }, requiresFilterValue: false }, { value: 'isNotEmpty', getApplyFilterFnV7: () => { return value => { return value !== '' && value != null; }; }, requiresFilterValue: false }, { value: 'isAnyOf', getApplyFilterFnV7: filterItem => { if (!Array.isArray(filterItem.value) || filterItem.value.length === 0) { return null; } const filterItemValue = disableTrim ? filterItem.value : filterItem.value.map(val => val.trim()); const collator = new Intl.Collator(undefined, { sensitivity: 'base', usage: 'search' }); return value => value != null ? filterItemValue.some(filterValue => { return collator.compare(filterValue, value.toString() || '') === 0; }) : false; }, InputComponent: GridFilterInputMultipleValue }]);