@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
JavaScript
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)),
};
};