-
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
/
Copy pathgridSingleSelectOperators.ts
45 lines (43 loc) · 1.58 KB
/
gridSingleSelectOperators.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
import { GridFilterInputSingleSelect } from '../components/panel/filterPanel/GridFilterInputSingleSelect';
import { GridFilterOperator } from '../models/gridFilterOperator';
import { GridFilterInputMultipleSingleSelect } from '../components/panel/filterPanel/GridFilterInputMultipleSingleSelect';
import { isObject } from '../utils/utils';
const parseObjectValue = (value: unknown) => {
if (value == null || !isObject<{ value: unknown }>(value)) {
return value;
}
return value.value;
};
export const getGridSingleSelectOperators = (): GridFilterOperator[] => [
{
value: 'is',
getApplyFilterFn: (filterItem) => {
if (filterItem.value == null || filterItem.value === '') {
return null;
}
return ({ value }): boolean => parseObjectValue(value) === parseObjectValue(filterItem.value);
},
InputComponent: GridFilterInputSingleSelect,
},
{
value: 'not',
getApplyFilterFn: (filterItem) => {
if (filterItem.value == null || filterItem.value === '') {
return null;
}
return ({ value }): boolean => parseObjectValue(value) !== parseObjectValue(filterItem.value);
},
InputComponent: GridFilterInputSingleSelect,
},
{
value: 'isAnyOf',
getApplyFilterFn: (filterItem) => {
if (!Array.isArray(filterItem.value) || filterItem.value.length === 0) {
return null;
}
const filterItemValues = filterItem.value.map(parseObjectValue);
return ({ value }): boolean => filterItemValues.includes(parseObjectValue(value));
},
InputComponent: GridFilterInputMultipleSingleSelect,
},
];