UNPKG

@adaptabletools/adaptable

Version:

Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements

19 lines (18 loc) 1.26 kB
import { mapAdaptablePredicateDefToQlPredicateDef, mapColumnFilterToQlPredicate, qlPredicateToString, } from '../../..//View/Components/ColumnFilter/utils'; import { mapColumnDataTypeToExpressionFunctionType } from '../../../Utilities/adaptableQlUtils'; export const getFilterPreview = (columnFilter, api) => { const column = api.columnApi.getColumnWithColumnId(columnFilter.ColumnId); const columnFilterOptions = api.optionsApi.getFilterOptions().columnFilterOptions; const predicateDefs = api.filterApi.columnFilterApi.getFilterPredicateDefsForColumn(column); const columnType = api.columnApi.getColumnDataTypeForColumnId(columnFilter.ColumnId); const qlDataType = mapColumnDataTypeToExpressionFunctionType(columnType); const qlPredicateDefs = predicateDefs.map((pd) => mapAdaptablePredicateDefToQlPredicateDef(pd, qlDataType)); const qlPredicate = mapColumnFilterToQlPredicate(columnFilter, column, qlPredicateDefs, columnFilterOptions); return `[${qlPredicateToString(qlPredicate, qlPredicateDefs)}]`; }; export const getLayoutFilterViewItems = (layout, api) => { return { name: 'Column Filters', values: (layout.ColumnFilters ?? []).map((columnFilter) => getFilterPreview(columnFilter, api)), }; };