@tanstack/table-core 8.14.0 → 8.15.2

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.
Files changed (36) hide show
  1. package/build/lib/columnHelper.d.ts +4 -4
  2. package/build/lib/columnHelper.js.map +1 -1
  3. package/build/lib/core/row.d.ts +1 -1
  4. package/build/lib/core/table.js +5 -2
  5. package/build/lib/core/table.js.map +1 -1
  6. package/build/lib/features/ColumnFaceting.d.ts +6 -6
  7. package/build/lib/features/ColumnFaceting.js.map +1 -1
  8. package/build/lib/features/ColumnFiltering.d.ts +48 -48
  9. package/build/lib/features/ColumnFiltering.js.map +1 -1
  10. package/build/lib/features/GlobalFaceting.d.ts +26 -0
  11. package/build/lib/features/GlobalFaceting.js +42 -0
  12. package/build/lib/features/GlobalFaceting.js.map +1 -0
  13. package/build/lib/features/GlobalFiltering.d.ts +21 -42
  14. package/build/lib/features/GlobalFiltering.js +1 -23
  15. package/build/lib/features/GlobalFiltering.js.map +1 -1
  16. package/build/lib/index.d.ts +1 -0
  17. package/build/lib/index.esm.js +34 -26
  18. package/build/lib/index.esm.js.map +1 -1
  19. package/build/lib/index.js +2 -0
  20. package/build/lib/index.js.map +1 -1
  21. package/build/lib/index.mjs +34 -26
  22. package/build/lib/index.mjs.map +1 -1
  23. package/build/lib/types.d.ts +3 -2
  24. package/build/umd/index.development.js +34 -25
  25. package/build/umd/index.development.js.map +1 -1
  26. package/build/umd/index.production.js +1 -1
  27. package/build/umd/index.production.js.map +1 -1
  28. package/package.json +1 -1
  29. package/src/columnHelper.ts +9 -6
  30. package/src/core/table.ts +3 -1
  31. package/src/features/ColumnFaceting.ts +6 -6
  32. package/src/features/ColumnFiltering.ts +48 -48
  33. package/src/features/GlobalFaceting.ts +66 -0
  34. package/src/features/GlobalFiltering.ts +22 -78
  35. package/src/index.ts +1 -0
  36. package/src/types.ts +6 -2
@@ -1 +1 @@
1
- {"version":3,"file":"ColumnFiltering.js","sources":["../../../src/features/ColumnFiltering.ts"],"sourcesContent":["import { RowModel } from '..'\nimport { BuiltInFilterFn, filterFns } from '../filterFns'\nimport {\n Column,\n FilterFns,\n FilterMeta,\n OnChangeFn,\n Row,\n RowData,\n Table,\n TableFeature,\n Updater,\n} from '../types'\nimport { functionalUpdate, isFunction, makeStateUpdater } from '../utils'\n\nexport interface ColumnFiltersTableState {\n columnFilters: ColumnFiltersState\n}\n\nexport type ColumnFiltersState = ColumnFilter[]\n\nexport interface ColumnFilter {\n id: string\n value: unknown\n}\n\nexport interface ResolvedColumnFilter<TData extends RowData> {\n filterFn: FilterFn<TData>\n id: string\n resolvedValue: unknown\n}\n\nexport interface FilterFn<TData extends RowData> {\n (\n row: Row<TData>,\n columnId: string,\n filterValue: any,\n addMeta: (meta: FilterMeta) => void\n ): boolean\n autoRemove?: ColumnFilterAutoRemoveTestFn<TData>\n resolveFilterValue?: TransformFilterValueFn<TData>\n}\n\nexport type TransformFilterValueFn<TData extends RowData> = (\n value: any,\n column?: Column<TData, unknown>\n) => unknown\n\nexport type ColumnFilterAutoRemoveTestFn<TData extends RowData> = (\n value: any,\n column?: Column<TData, unknown>\n) => boolean\n\nexport type CustomFilterFns<TData extends RowData> = Record<\n string,\n FilterFn<TData>\n>\n\nexport type FilterFnOption<TData extends RowData> =\n | 'auto'\n | BuiltInFilterFn\n | keyof FilterFns\n | FilterFn<TData>\n\nexport interface ColumnFiltersColumnDef<TData extends RowData> {\n /**\n * Enables/disables the **column** filter for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#enablecolumnfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n enableColumnFilter?: boolean\n /**\n * The filter function to use with this column. Can be the name of a built-in filter function or a custom filter function.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#filterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n filterFn?: FilterFnOption<TData>\n}\n\nexport interface ColumnFiltersColumn<TData extends RowData> {\n /**\n * Returns an automatically calculated filter function for the column based off of the columns first known value.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getautofilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getAutoFilterFn: () => FilterFn<TData> | undefined\n /**\n * Returns whether or not the column can be **column** filtered.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getcanfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getCanFilter: () => boolean\n /**\n * Returns the filter function (either user-defined or automatic, depending on configuration) for the columnId specified.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getfilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getFilterFn: () => FilterFn<TData> | undefined\n /**\n * Returns the index (including `-1`) of the column filter in the table's `state.columnFilters` array.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getfilterindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getFilterIndex: () => number\n /**\n * Returns the current filter value for the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getfiltervalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getFilterValue: () => unknown\n /**\n * Returns whether or not the column is currently filtered.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getisfiltered)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getIsFiltered: () => boolean\n /**\n * A function that sets the current filter value for the column. You can pass it a value or an updater function for immutability-safe operations on existing values.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#setfiltervalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n setFilterValue: (updater: Updater<any>) => void\n}\n\nexport interface ColumnFiltersRow<TData extends RowData> {\n /**\n * The column filters map for the row. This object tracks whether a row is passing/failing specific filters by their column ID.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#columnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n columnFilters: Record<string, boolean>\n /**\n * The column filters meta map for the row. This object tracks any filter meta for a row as optionally provided during the filtering process.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#columnfiltersmeta)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n columnFiltersMeta: Record<string, FilterMeta>\n}\n\ninterface ColumnFiltersOptionsBase<TData extends RowData> {\n /**\n * Enables/disables **column** filtering for all columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#enablecolumnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n enableColumnFilters?: boolean\n /**\n * Enables/disables all filtering for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#enablefilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n enableFilters?: boolean\n /**\n * By default, filtering is done from parent rows down (so if a parent row is filtered out, all of its children will be filtered out as well). Setting this option to `true` will cause filtering to be done from leaf rows up (which means parent rows will be included so long as one of their child or grand-child rows is also included).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#filterfromleafrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n filterFromLeafRows?: boolean\n /**\n * If provided, this function is called **once** per table and should return a **new function** which will calculate and return the row model for the table when it's filtered.\n * - For server-side filtering, this function is unnecessary and can be ignored since the server should already return the filtered row model.\n * - For client-side filtering, this function is required. A default implementation is provided via any table adapter's `{ getFilteredRowModel }` export.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getfilteredrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getFilteredRowModel?: (table: Table<any>) => () => RowModel<any>\n /**\n * Disables the `getFilteredRowModel` from being used to filter data. This may be useful if your table needs to dynamically support both client-side and server-side filtering.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#manualfiltering)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n manualFiltering?: boolean\n /**\n * By default, filtering is done for all rows (max depth of 100), no matter if they are root level parent rows or the child leaf rows of a parent row. Setting this option to `0` will cause filtering to only be applied to the root level parent rows, with all sub-rows remaining unfiltered. Similarly, setting this option to `1` will cause filtering to only be applied to child leaf rows 1 level deep, and so on.\n\n * This is useful for situations where you want a row's entire child hierarchy to be visible regardless of the applied filter.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#maxleafrowfilterdepth)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n maxLeafRowFilterDepth?: number\n /**\n * If provided, this function will be called with an `updaterFn` when `state.columnFilters` changes. This overrides the default internal state management, so you will need to persist the state change either fully or partially outside of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#oncolumnfilterschange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n onColumnFiltersChange?: OnChangeFn<ColumnFiltersState>\n}\n\ntype ResolvedFilterFns = keyof FilterFns extends never\n ? {\n filterFns?: Record<string, FilterFn<any>>\n }\n : {\n filterFns: Record<keyof FilterFns, FilterFn<any>>\n }\n\nexport interface ColumnFiltersOptions<TData extends RowData>\n extends ColumnFiltersOptionsBase<TData>,\n ResolvedFilterFns {}\n\nexport interface ColumnFiltersInstance<TData extends RowData> {\n _getFilteredRowModel?: () => RowModel<TData>\n /**\n * Returns the row model for the table after **column** filtering has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getfilteredrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getFilteredRowModel: () => RowModel<TData>\n /**\n * Returns the row model for the table before any **column** filtering has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getprefilteredrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getPreFilteredRowModel: () => RowModel<TData>\n /**\n * Resets the **columnFilters** state to `initialState.columnFilters`, or `true` can be passed to force a default blank state reset to `[]`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#resetcolumnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n resetColumnFilters: (defaultState?: boolean) => void\n /**\n * Resets the **globalFilter** state to `initialState.globalFilter`, or `true` can be passed to force a default blank state reset to `undefined`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#resetglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n resetGlobalFilter: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.columnFilters` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#setcolumnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n setColumnFilters: (updater: Updater<ColumnFiltersState>) => void\n /**\n * Sets or updates the `state.globalFilter` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#setglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n setGlobalFilter: (updater: Updater<any>) => void\n}\n\n//\n\nexport const ColumnFiltering: TableFeature = {\n getDefaultColumnDef: <\n TData extends RowData,\n >(): ColumnFiltersColumnDef<TData> => {\n return {\n filterFn: 'auto',\n }\n },\n\n getInitialState: (state): ColumnFiltersTableState => {\n return {\n columnFilters: [],\n ...state,\n }\n },\n\n getDefaultOptions: <TData extends RowData>(\n table: Table<TData>\n ): ColumnFiltersOptions<TData> => {\n return {\n onColumnFiltersChange: makeStateUpdater('columnFilters', table),\n filterFromLeafRows: false,\n maxLeafRowFilterDepth: 100,\n } as ColumnFiltersOptions<TData>\n },\n\n createColumn: <TData extends RowData>(\n column: Column<TData, unknown>,\n table: Table<TData>\n ): void => {\n column.getAutoFilterFn = () => {\n const firstRow = table.getCoreRowModel().flatRows[0]\n\n const value = firstRow?.getValue(column.id)\n\n if (typeof value === 'string') {\n return filterFns.includesString\n }\n\n if (typeof value === 'number') {\n return filterFns.inNumberRange\n }\n\n if (typeof value === 'boolean') {\n return filterFns.equals\n }\n\n if (value !== null && typeof value === 'object') {\n return filterFns.equals\n }\n\n if (Array.isArray(value)) {\n return filterFns.arrIncludes\n }\n\n return filterFns.weakEquals\n }\n column.getFilterFn = () => {\n return isFunction(column.columnDef.filterFn)\n ? column.columnDef.filterFn\n : column.columnDef.filterFn === 'auto'\n ? column.getAutoFilterFn()\n : // @ts-ignore\n table.options.filterFns?.[column.columnDef.filterFn as string] ??\n filterFns[column.columnDef.filterFn as BuiltInFilterFn]\n }\n column.getCanFilter = () => {\n return (\n (column.columnDef.enableColumnFilter ?? true) &&\n (table.options.enableColumnFilters ?? true) &&\n (table.options.enableFilters ?? true) &&\n !!column.accessorFn\n )\n }\n\n column.getIsFiltered = () => column.getFilterIndex() > -1\n\n column.getFilterValue = () =>\n table.getState().columnFilters?.find(d => d.id === column.id)?.value\n\n column.getFilterIndex = () =>\n table.getState().columnFilters?.findIndex(d => d.id === column.id) ?? -1\n\n column.setFilterValue = value => {\n table.setColumnFilters(old => {\n const filterFn = column.getFilterFn()\n const previousFilter = old?.find(d => d.id === column.id)\n\n const newFilter = functionalUpdate(\n value,\n previousFilter ? previousFilter.value : undefined\n )\n\n //\n if (\n shouldAutoRemoveFilter(filterFn as FilterFn<TData>, newFilter, column)\n ) {\n return old?.filter(d => d.id !== column.id) ?? []\n }\n\n const newFilterObj = { id: column.id, value: newFilter }\n\n if (previousFilter) {\n return (\n old?.map(d => {\n if (d.id === column.id) {\n return newFilterObj\n }\n return d\n }) ?? []\n )\n }\n\n if (old?.length) {\n return [...old, newFilterObj]\n }\n\n return [newFilterObj]\n })\n }\n },\n\n createRow: <TData extends RowData>(\n row: Row<TData>,\n _table: Table<TData>\n ): void => {\n row.columnFilters = {}\n row.columnFiltersMeta = {}\n },\n\n createTable: <TData extends RowData>(table: Table<TData>): void => {\n table.setColumnFilters = (updater: Updater<ColumnFiltersState>) => {\n const leafColumns = table.getAllLeafColumns()\n\n const updateFn = (old: ColumnFiltersState) => {\n return functionalUpdate(updater, old)?.filter(filter => {\n const column = leafColumns.find(d => d.id === filter.id)\n\n if (column) {\n const filterFn = column.getFilterFn()\n\n if (shouldAutoRemoveFilter(filterFn, filter.value, column)) {\n return false\n }\n }\n\n return true\n })\n }\n\n table.options.onColumnFiltersChange?.(updateFn)\n }\n\n table.resetColumnFilters = defaultState => {\n table.setColumnFilters(\n defaultState ? [] : table.initialState?.columnFilters ?? []\n )\n }\n\n table.getPreFilteredRowModel = () => table.getCoreRowModel()\n table.getFilteredRowModel = () => {\n if (!table._getFilteredRowModel && table.options.getFilteredRowModel) {\n table._getFilteredRowModel = table.options.getFilteredRowModel(table)\n }\n\n if (table.options.manualFiltering || !table._getFilteredRowModel) {\n return table.getPreFilteredRowModel()\n }\n\n return table._getFilteredRowModel()\n }\n },\n}\n\nexport function shouldAutoRemoveFilter<TData extends RowData>(\n filterFn?: FilterFn<TData>,\n value?: any,\n column?: Column<TData, unknown>\n) {\n return (\n (filterFn && filterFn.autoRemove\n ? filterFn.autoRemove(value, column)\n : false) ||\n typeof value === 'undefined' ||\n (typeof value === 'string' && !value)\n )\n}\n"],"names":["ColumnFiltering","getDefaultColumnDef","filterFn","getInitialState","state","columnFilters","getDefaultOptions","table","onColumnFiltersChange","makeStateUpdater","filterFromLeafRows","maxLeafRowFilterDepth","createColumn","column","getAutoFilterFn","firstRow","getCoreRowModel","flatRows","value","getValue","id","filterFns","includesString","inNumberRange","equals","Array","isArray","arrIncludes","weakEquals","getFilterFn","_table$options$filter","_table$options$filter2","isFunction","columnDef","options","getCanFilter","_column$columnDef$ena","_table$options$enable","_table$options$enable2","enableColumnFilter","enableColumnFilters","enableFilters","accessorFn","getIsFiltered","getFilterIndex","getFilterValue","_table$getState$colum","getState","find","d","_table$getState$colum2","_table$getState$colum3","findIndex","setFilterValue","setColumnFilters","old","previousFilter","newFilter","functionalUpdate","undefined","shouldAutoRemoveFilter","_old$filter","filter","newFilterObj","_old$map","map","length","createRow","row","_table","columnFiltersMeta","createTable","updater","leafColumns","getAllLeafColumns","updateFn","_functionalUpdate","resetColumnFilters","defaultState","_table$initialState$c","_table$initialState","initialState","getPreFilteredRowModel","getFilteredRowModel","_getFilteredRowModel","manualFiltering","autoRemove"],"mappings":"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"}
1
+ {"version":3,"file":"ColumnFiltering.js","sources":["../../../src/features/ColumnFiltering.ts"],"sourcesContent":["import { RowModel } from '..'\nimport { BuiltInFilterFn, filterFns } from '../filterFns'\nimport {\n Column,\n FilterFns,\n FilterMeta,\n OnChangeFn,\n Row,\n RowData,\n Table,\n TableFeature,\n Updater,\n} from '../types'\nimport { functionalUpdate, isFunction, makeStateUpdater } from '../utils'\n\nexport interface ColumnFiltersTableState {\n columnFilters: ColumnFiltersState\n}\n\nexport type ColumnFiltersState = ColumnFilter[]\n\nexport interface ColumnFilter {\n id: string\n value: unknown\n}\n\nexport interface ResolvedColumnFilter<TData extends RowData> {\n filterFn: FilterFn<TData>\n id: string\n resolvedValue: unknown\n}\n\nexport interface FilterFn<TData extends RowData> {\n (\n row: Row<TData>,\n columnId: string,\n filterValue: any,\n addMeta: (meta: FilterMeta) => void\n ): boolean\n autoRemove?: ColumnFilterAutoRemoveTestFn<TData>\n resolveFilterValue?: TransformFilterValueFn<TData>\n}\n\nexport type TransformFilterValueFn<TData extends RowData> = (\n value: any,\n column?: Column<TData, unknown>\n) => unknown\n\nexport type ColumnFilterAutoRemoveTestFn<TData extends RowData> = (\n value: any,\n column?: Column<TData, unknown>\n) => boolean\n\nexport type CustomFilterFns<TData extends RowData> = Record<\n string,\n FilterFn<TData>\n>\n\nexport type FilterFnOption<TData extends RowData> =\n | 'auto'\n | BuiltInFilterFn\n | keyof FilterFns\n | FilterFn<TData>\n\nexport interface ColumnFiltersColumnDef<TData extends RowData> {\n /**\n * Enables/disables the **column** filter for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#enablecolumnfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n enableColumnFilter?: boolean\n /**\n * The filter function to use with this column. Can be the name of a built-in filter function or a custom filter function.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#filterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n filterFn?: FilterFnOption<TData>\n}\n\nexport interface ColumnFiltersColumn<TData extends RowData> {\n /**\n * Returns an automatically calculated filter function for the column based off of the columns first known value.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getautofilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getAutoFilterFn: () => FilterFn<TData> | undefined\n /**\n * Returns whether or not the column can be **column** filtered.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getcanfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getCanFilter: () => boolean\n /**\n * Returns the filter function (either user-defined or automatic, depending on configuration) for the columnId specified.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getfilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getFilterFn: () => FilterFn<TData> | undefined\n /**\n * Returns the index (including `-1`) of the column filter in the table's `state.columnFilters` array.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getfilterindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getFilterIndex: () => number\n /**\n * Returns the current filter value for the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getfiltervalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getFilterValue: () => unknown\n /**\n * Returns whether or not the column is currently filtered.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getisfiltered)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getIsFiltered: () => boolean\n /**\n * A function that sets the current filter value for the column. You can pass it a value or an updater function for immutability-safe operations on existing values.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#setfiltervalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n setFilterValue: (updater: Updater<any>) => void\n}\n\nexport interface ColumnFiltersRow<TData extends RowData> {\n /**\n * The column filters map for the row. This object tracks whether a row is passing/failing specific filters by their column ID.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#columnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n columnFilters: Record<string, boolean>\n /**\n * The column filters meta map for the row. This object tracks any filter meta for a row as optionally provided during the filtering process.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#columnfiltersmeta)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n columnFiltersMeta: Record<string, FilterMeta>\n}\n\ninterface ColumnFiltersOptionsBase<TData extends RowData> {\n /**\n * Enables/disables **column** filtering for all columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#enablecolumnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n enableColumnFilters?: boolean\n /**\n * Enables/disables all filtering for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#enablefilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n enableFilters?: boolean\n /**\n * By default, filtering is done from parent rows down (so if a parent row is filtered out, all of its children will be filtered out as well). Setting this option to `true` will cause filtering to be done from leaf rows up (which means parent rows will be included so long as one of their child or grand-child rows is also included).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#filterfromleafrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n filterFromLeafRows?: boolean\n /**\n * If provided, this function is called **once** per table and should return a **new function** which will calculate and return the row model for the table when it's filtered.\n * - For server-side filtering, this function is unnecessary and can be ignored since the server should already return the filtered row model.\n * - For client-side filtering, this function is required. A default implementation is provided via any table adapter's `{ getFilteredRowModel }` export.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getfilteredrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getFilteredRowModel?: (table: Table<any>) => () => RowModel<any>\n /**\n * Disables the `getFilteredRowModel` from being used to filter data. This may be useful if your table needs to dynamically support both client-side and server-side filtering.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#manualfiltering)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n manualFiltering?: boolean\n /**\n * By default, filtering is done for all rows (max depth of 100), no matter if they are root level parent rows or the child leaf rows of a parent row. Setting this option to `0` will cause filtering to only be applied to the root level parent rows, with all sub-rows remaining unfiltered. Similarly, setting this option to `1` will cause filtering to only be applied to child leaf rows 1 level deep, and so on.\n\n * This is useful for situations where you want a row's entire child hierarchy to be visible regardless of the applied filter.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#maxleafrowfilterdepth)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n maxLeafRowFilterDepth?: number\n /**\n * If provided, this function will be called with an `updaterFn` when `state.columnFilters` changes. This overrides the default internal state management, so you will need to persist the state change either fully or partially outside of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#oncolumnfilterschange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n onColumnFiltersChange?: OnChangeFn<ColumnFiltersState>\n}\n\ntype ResolvedFilterFns = keyof FilterFns extends never\n ? {\n filterFns?: Record<string, FilterFn<any>>\n }\n : {\n filterFns: Record<keyof FilterFns, FilterFn<any>>\n }\n\nexport interface ColumnFiltersOptions<TData extends RowData>\n extends ColumnFiltersOptionsBase<TData>,\n ResolvedFilterFns {}\n\nexport interface ColumnFiltersInstance<TData extends RowData> {\n _getFilteredRowModel?: () => RowModel<TData>\n /**\n * Returns the row model for the table after **column** filtering has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getfilteredrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getFilteredRowModel: () => RowModel<TData>\n /**\n * Returns the row model for the table before any **column** filtering has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#getprefilteredrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n getPreFilteredRowModel: () => RowModel<TData>\n /**\n * Resets the **columnFilters** state to `initialState.columnFilters`, or `true` can be passed to force a default blank state reset to `[]`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#resetcolumnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n resetColumnFilters: (defaultState?: boolean) => void\n /**\n * Resets the **globalFilter** state to `initialState.globalFilter`, or `true` can be passed to force a default blank state reset to `undefined`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#resetglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n resetGlobalFilter: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.columnFilters` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#setcolumnfilters)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n setColumnFilters: (updater: Updater<ColumnFiltersState>) => void\n /**\n * Sets or updates the `state.globalFilter` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-filtering#setglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-filtering)\n */\n setGlobalFilter: (updater: Updater<any>) => void\n}\n\n//\n\nexport const ColumnFiltering: TableFeature = {\n getDefaultColumnDef: <\n TData extends RowData,\n >(): ColumnFiltersColumnDef<TData> => {\n return {\n filterFn: 'auto',\n }\n },\n\n getInitialState: (state): ColumnFiltersTableState => {\n return {\n columnFilters: [],\n ...state,\n }\n },\n\n getDefaultOptions: <TData extends RowData>(\n table: Table<TData>\n ): ColumnFiltersOptions<TData> => {\n return {\n onColumnFiltersChange: makeStateUpdater('columnFilters', table),\n filterFromLeafRows: false,\n maxLeafRowFilterDepth: 100,\n } as ColumnFiltersOptions<TData>\n },\n\n createColumn: <TData extends RowData>(\n column: Column<TData, unknown>,\n table: Table<TData>\n ): void => {\n column.getAutoFilterFn = () => {\n const firstRow = table.getCoreRowModel().flatRows[0]\n\n const value = firstRow?.getValue(column.id)\n\n if (typeof value === 'string') {\n return filterFns.includesString\n }\n\n if (typeof value === 'number') {\n return filterFns.inNumberRange\n }\n\n if (typeof value === 'boolean') {\n return filterFns.equals\n }\n\n if (value !== null && typeof value === 'object') {\n return filterFns.equals\n }\n\n if (Array.isArray(value)) {\n return filterFns.arrIncludes\n }\n\n return filterFns.weakEquals\n }\n column.getFilterFn = () => {\n return isFunction(column.columnDef.filterFn)\n ? column.columnDef.filterFn\n : column.columnDef.filterFn === 'auto'\n ? column.getAutoFilterFn()\n : // @ts-ignore\n table.options.filterFns?.[column.columnDef.filterFn as string] ??\n filterFns[column.columnDef.filterFn as BuiltInFilterFn]\n }\n column.getCanFilter = () => {\n return (\n (column.columnDef.enableColumnFilter ?? true) &&\n (table.options.enableColumnFilters ?? true) &&\n (table.options.enableFilters ?? true) &&\n !!column.accessorFn\n )\n }\n\n column.getIsFiltered = () => column.getFilterIndex() > -1\n\n column.getFilterValue = () =>\n table.getState().columnFilters?.find(d => d.id === column.id)?.value\n\n column.getFilterIndex = () =>\n table.getState().columnFilters?.findIndex(d => d.id === column.id) ?? -1\n\n column.setFilterValue = value => {\n table.setColumnFilters(old => {\n const filterFn = column.getFilterFn()\n const previousFilter = old?.find(d => d.id === column.id)\n\n const newFilter = functionalUpdate(\n value,\n previousFilter ? previousFilter.value : undefined\n )\n\n //\n if (\n shouldAutoRemoveFilter(filterFn as FilterFn<TData>, newFilter, column)\n ) {\n return old?.filter(d => d.id !== column.id) ?? []\n }\n\n const newFilterObj = { id: column.id, value: newFilter }\n\n if (previousFilter) {\n return (\n old?.map(d => {\n if (d.id === column.id) {\n return newFilterObj\n }\n return d\n }) ?? []\n )\n }\n\n if (old?.length) {\n return [...old, newFilterObj]\n }\n\n return [newFilterObj]\n })\n }\n },\n\n createRow: <TData extends RowData>(\n row: Row<TData>,\n _table: Table<TData>\n ): void => {\n row.columnFilters = {}\n row.columnFiltersMeta = {}\n },\n\n createTable: <TData extends RowData>(table: Table<TData>): void => {\n table.setColumnFilters = (updater: Updater<ColumnFiltersState>) => {\n const leafColumns = table.getAllLeafColumns()\n\n const updateFn = (old: ColumnFiltersState) => {\n return functionalUpdate(updater, old)?.filter(filter => {\n const column = leafColumns.find(d => d.id === filter.id)\n\n if (column) {\n const filterFn = column.getFilterFn()\n\n if (shouldAutoRemoveFilter(filterFn, filter.value, column)) {\n return false\n }\n }\n\n return true\n })\n }\n\n table.options.onColumnFiltersChange?.(updateFn)\n }\n\n table.resetColumnFilters = defaultState => {\n table.setColumnFilters(\n defaultState ? [] : table.initialState?.columnFilters ?? []\n )\n }\n\n table.getPreFilteredRowModel = () => table.getCoreRowModel()\n table.getFilteredRowModel = () => {\n if (!table._getFilteredRowModel && table.options.getFilteredRowModel) {\n table._getFilteredRowModel = table.options.getFilteredRowModel(table)\n }\n\n if (table.options.manualFiltering || !table._getFilteredRowModel) {\n return table.getPreFilteredRowModel()\n }\n\n return table._getFilteredRowModel()\n }\n },\n}\n\nexport function shouldAutoRemoveFilter<TData extends RowData>(\n filterFn?: FilterFn<TData>,\n value?: any,\n column?: Column<TData, unknown>\n) {\n return (\n (filterFn && filterFn.autoRemove\n ? filterFn.autoRemove(value, column)\n : false) ||\n typeof value === 'undefined' ||\n (typeof value === 'string' && !value)\n )\n}\n"],"names":["ColumnFiltering","getDefaultColumnDef","filterFn","getInitialState","state","columnFilters","getDefaultOptions","table","onColumnFiltersChange","makeStateUpdater","filterFromLeafRows","maxLeafRowFilterDepth","createColumn","column","getAutoFilterFn","firstRow","getCoreRowModel","flatRows","value","getValue","id","filterFns","includesString","inNumberRange","equals","Array","isArray","arrIncludes","weakEquals","getFilterFn","_table$options$filter","_table$options$filter2","isFunction","columnDef","options","getCanFilter","_column$columnDef$ena","_table$options$enable","_table$options$enable2","enableColumnFilter","enableColumnFilters","enableFilters","accessorFn","getIsFiltered","getFilterIndex","getFilterValue","_table$getState$colum","getState","find","d","_table$getState$colum2","_table$getState$colum3","findIndex","setFilterValue","setColumnFilters","old","previousFilter","newFilter","functionalUpdate","undefined","shouldAutoRemoveFilter","_old$filter","filter","newFilterObj","_old$map","map","length","createRow","row","_table","columnFiltersMeta","createTable","updater","leafColumns","getAllLeafColumns","updateFn","_functionalUpdate","resetColumnFilters","defaultState","_table$initialState$c","_table$initialState","initialState","getPreFilteredRowModel","getFilteredRowModel","_getFilteredRowModel","manualFiltering","autoRemove"],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import { RowModel } from '..';
2
+ import { RowData, TableFeature } from '../types';
3
+ export interface GlobalFacetingInstance<TData extends RowData> {
4
+ _getGlobalFacetedMinMaxValues?: () => undefined | [number, number];
5
+ _getGlobalFacetedRowModel?: () => RowModel<TData>;
6
+ _getGlobalFacetedUniqueValues?: () => Map<any, number>;
7
+ /**
8
+ * Currently, this function returns the built-in `includesString` filter function. In future releases, it may return more dynamic filter functions based on the nature of the data provided.
9
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-faceting#getglobalautofilterfn)
10
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-faceting)
11
+ */
12
+ getGlobalFacetedMinMaxValues: () => undefined | [number, number];
13
+ /**
14
+ * Returns the row model for the table after **global** filtering has been applied.
15
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-faceting#getglobalfacetedrowmodel)
16
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-faceting)
17
+ */
18
+ getGlobalFacetedRowModel: () => RowModel<TData>;
19
+ /**
20
+ * Returns the faceted unique values for the global filter.
21
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-faceting#getglobalfaceteduniquevalues)
22
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-faceting)
23
+ */
24
+ getGlobalFacetedUniqueValues: () => Map<any, number>;
25
+ }
26
+ export declare const GlobalFaceting: TableFeature;
@@ -0,0 +1,42 @@
1
+ /**
2
+ * table-core
3
+ *
4
+ * Copyright (c) TanStack
5
+ *
6
+ * This source code is licensed under the MIT license found in the
7
+ * LICENSE.md file in the root directory of this source tree.
8
+ *
9
+ * @license MIT
10
+ */
11
+ 'use strict';
12
+
13
+ //
14
+
15
+ const GlobalFaceting = {
16
+ createTable: table => {
17
+ table._getGlobalFacetedRowModel = table.options.getFacetedRowModel && table.options.getFacetedRowModel(table, '__global__');
18
+ table.getGlobalFacetedRowModel = () => {
19
+ if (table.options.manualFiltering || !table._getGlobalFacetedRowModel) {
20
+ return table.getPreFilteredRowModel();
21
+ }
22
+ return table._getGlobalFacetedRowModel();
23
+ };
24
+ table._getGlobalFacetedUniqueValues = table.options.getFacetedUniqueValues && table.options.getFacetedUniqueValues(table, '__global__');
25
+ table.getGlobalFacetedUniqueValues = () => {
26
+ if (!table._getGlobalFacetedUniqueValues) {
27
+ return new Map();
28
+ }
29
+ return table._getGlobalFacetedUniqueValues();
30
+ };
31
+ table._getGlobalFacetedMinMaxValues = table.options.getFacetedMinMaxValues && table.options.getFacetedMinMaxValues(table, '__global__');
32
+ table.getGlobalFacetedMinMaxValues = () => {
33
+ if (!table._getGlobalFacetedMinMaxValues) {
34
+ return;
35
+ }
36
+ return table._getGlobalFacetedMinMaxValues();
37
+ };
38
+ }
39
+ };
40
+
41
+ exports.GlobalFaceting = GlobalFaceting;
42
+ //# sourceMappingURL=GlobalFaceting.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GlobalFaceting.js","sources":["../../../src/features/GlobalFaceting.ts"],"sourcesContent":["import { RowModel } from '..'\nimport { Table, RowData, TableFeature } from '../types'\n\nexport interface GlobalFacetingInstance<TData extends RowData> {\n _getGlobalFacetedMinMaxValues?: () => undefined | [number, number]\n _getGlobalFacetedRowModel?: () => RowModel<TData>\n _getGlobalFacetedUniqueValues?: () => Map<any, number>\n /**\n * Currently, this function returns the built-in `includesString` filter function. In future releases, it may return more dynamic filter functions based on the nature of the data provided.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-faceting#getglobalautofilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-faceting)\n */\n getGlobalFacetedMinMaxValues: () => undefined | [number, number]\n /**\n * Returns the row model for the table after **global** filtering has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-faceting#getglobalfacetedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-faceting)\n */\n getGlobalFacetedRowModel: () => RowModel<TData>\n /**\n * Returns the faceted unique values for the global filter.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-faceting#getglobalfaceteduniquevalues)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-faceting)\n */\n getGlobalFacetedUniqueValues: () => Map<any, number>\n}\n\n//\n\nexport const GlobalFaceting: TableFeature = {\n createTable: <TData extends RowData>(table: Table<TData>): void => {\n table._getGlobalFacetedRowModel =\n table.options.getFacetedRowModel &&\n table.options.getFacetedRowModel(table, '__global__')\n\n table.getGlobalFacetedRowModel = () => {\n if (table.options.manualFiltering || !table._getGlobalFacetedRowModel) {\n return table.getPreFilteredRowModel()\n }\n\n return table._getGlobalFacetedRowModel()\n }\n\n table._getGlobalFacetedUniqueValues =\n table.options.getFacetedUniqueValues &&\n table.options.getFacetedUniqueValues(table, '__global__')\n table.getGlobalFacetedUniqueValues = () => {\n if (!table._getGlobalFacetedUniqueValues) {\n return new Map()\n }\n\n return table._getGlobalFacetedUniqueValues()\n }\n\n table._getGlobalFacetedMinMaxValues =\n table.options.getFacetedMinMaxValues &&\n table.options.getFacetedMinMaxValues(table, '__global__')\n table.getGlobalFacetedMinMaxValues = () => {\n if (!table._getGlobalFacetedMinMaxValues) {\n return\n }\n\n return table._getGlobalFacetedMinMaxValues()\n }\n },\n}\n"],"names":["GlobalFaceting","createTable","table","_getGlobalFacetedRowModel","options","getFacetedRowModel","getGlobalFacetedRowModel","manualFiltering","getPreFilteredRowModel","_getGlobalFacetedUniqueValues","getFacetedUniqueValues","getGlobalFacetedUniqueValues","Map","_getGlobalFacetedMinMaxValues","getFacetedMinMaxValues","getGlobalFacetedMinMaxValues"],"mappings":";;;;;;;;;;;;AA2BA;;AAEO,MAAMA,cAA4B,GAAG;EAC1CC,WAAW,EAA0BC,KAAmB,IAAW;AACjEA,IAAAA,KAAK,CAACC,yBAAyB,GAC7BD,KAAK,CAACE,OAAO,CAACC,kBAAkB,IAChCH,KAAK,CAACE,OAAO,CAACC,kBAAkB,CAACH,KAAK,EAAE,YAAY,CAAC,CAAA;IAEvDA,KAAK,CAACI,wBAAwB,GAAG,MAAM;MACrC,IAAIJ,KAAK,CAACE,OAAO,CAACG,eAAe,IAAI,CAACL,KAAK,CAACC,yBAAyB,EAAE;AACrE,QAAA,OAAOD,KAAK,CAACM,sBAAsB,EAAE,CAAA;AACvC,OAAA;AAEA,MAAA,OAAON,KAAK,CAACC,yBAAyB,EAAE,CAAA;KACzC,CAAA;AAEDD,IAAAA,KAAK,CAACO,6BAA6B,GACjCP,KAAK,CAACE,OAAO,CAACM,sBAAsB,IACpCR,KAAK,CAACE,OAAO,CAACM,sBAAsB,CAACR,KAAK,EAAE,YAAY,CAAC,CAAA;IAC3DA,KAAK,CAACS,4BAA4B,GAAG,MAAM;AACzC,MAAA,IAAI,CAACT,KAAK,CAACO,6BAA6B,EAAE;QACxC,OAAO,IAAIG,GAAG,EAAE,CAAA;AAClB,OAAA;AAEA,MAAA,OAAOV,KAAK,CAACO,6BAA6B,EAAE,CAAA;KAC7C,CAAA;AAEDP,IAAAA,KAAK,CAACW,6BAA6B,GACjCX,KAAK,CAACE,OAAO,CAACU,sBAAsB,IACpCZ,KAAK,CAACE,OAAO,CAACU,sBAAsB,CAACZ,KAAK,EAAE,YAAY,CAAC,CAAA;IAC3DA,KAAK,CAACa,4BAA4B,GAAG,MAAM;AACzC,MAAA,IAAI,CAACb,KAAK,CAACW,6BAA6B,EAAE;AACxC,QAAA,OAAA;AACF,OAAA;AAEA,MAAA,OAAOX,KAAK,CAACW,6BAA6B,EAAE,CAAA;KAC7C,CAAA;AACH,GAAA;AACF;;;;"}
@@ -1,4 +1,4 @@
1
- import { FilterFn, FilterFnOption, RowModel } from '..';
1
+ import { FilterFn, FilterFnOption } from '..';
2
2
  import { Column, OnChangeFn, Updater, RowData, TableFeature } from '../types';
3
3
  export interface GlobalFilterTableState {
4
4
  globalFilter: any;
@@ -6,32 +6,32 @@ export interface GlobalFilterTableState {
6
6
  export interface GlobalFilterColumnDef {
7
7
  /**
8
8
  * Enables/disables the **global** filter for this column.
9
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#enableglobalfilter)
10
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
9
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#enableglobalfilter)
10
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
11
11
  */
12
12
  enableGlobalFilter?: boolean;
13
13
  }
14
14
  export interface GlobalFilterColumn {
15
15
  /**
16
16
  * Returns whether or not the column can be **globally** filtered. Set to `false` to disable a column from being scanned during global filtering.
17
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getcanglobalfilter)
18
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
17
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getcanglobalfilter)
18
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
19
19
  */
20
20
  getCanGlobalFilter: () => boolean;
21
21
  }
22
22
  export interface GlobalFilterOptions<TData extends RowData> {
23
23
  /**
24
24
  * Enables/disables **global** filtering for all columns.
25
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#enableglobalfilter)
26
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
25
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#enableglobalfilter)
26
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
27
27
  */
28
28
  enableGlobalFilter?: boolean;
29
29
  /**
30
30
  * If provided, this function will be called with the column and should return `true` or `false` to indicate whether this column should be used for global filtering.
31
31
  *
32
32
  * This is useful if the column can contain data that is not `string` or `number` (i.e. `undefined`).
33
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getcolumncanglobalfilter)
34
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
33
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getcolumncanglobalfilter)
34
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
35
35
  */
36
36
  getColumnCanGlobalFilter?: (column: Column<TData, unknown>) => boolean;
37
37
  /**
@@ -39,61 +39,40 @@ export interface GlobalFilterOptions<TData extends RowData> {
39
39
  * - A `string` referencing a built-in filter function
40
40
  * - A `string` that references a custom filter functions provided via the `tableOptions.filterFns` option
41
41
  * - A custom filter function
42
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#globalfilterfn)
43
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
42
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#globalfilterfn)
43
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
44
44
  */
45
45
  globalFilterFn?: FilterFnOption<TData>;
46
46
  /**
47
47
  * If provided, this function will be called with an `updaterFn` when `state.globalFilter` changes. This overrides the default internal state management, so you will need to persist the state change either fully or partially outside of the table.
48
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#onglobalfilterchange)
49
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
48
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#onglobalfilterchange)
49
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
50
50
  */
51
51
  onGlobalFilterChange?: OnChangeFn<any>;
52
52
  }
53
53
  export interface GlobalFilterInstance<TData extends RowData> {
54
- _getGlobalFacetedMinMaxValues?: () => undefined | [number, number];
55
- _getGlobalFacetedRowModel?: () => RowModel<TData>;
56
- _getGlobalFacetedUniqueValues?: () => Map<any, number>;
57
54
  /**
58
55
  * Currently, this function returns the built-in `includesString` filter function. In future releases, it may return more dynamic filter functions based on the nature of the data provided.
59
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalautofilterfn)
60
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
56
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getglobalautofilterfn)
57
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
61
58
  */
62
59
  getGlobalAutoFilterFn: () => FilterFn<TData> | undefined;
63
- /**
64
- * Returns the faceted min and max values for the global filter.
65
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfacetedminmaxvalues)
66
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
67
- */
68
- getGlobalFacetedMinMaxValues: () => undefined | [number, number];
69
- /**
70
- * Returns the row model for the table after **global** filtering has been applied.
71
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfacetedrowmodel)
72
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
73
- */
74
- getGlobalFacetedRowModel: () => RowModel<TData>;
75
- /**
76
- * Returns the faceted unique values for the global filter.
77
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfaceteduniquevalues)
78
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
79
- */
80
- getGlobalFacetedUniqueValues: () => Map<any, number>;
81
60
  /**
82
61
  * Returns the filter function (either user-defined or automatic, depending on configuration) for the global filter.
83
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfilterfn)
84
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
62
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getglobalfilterfn)
63
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
85
64
  */
86
65
  getGlobalFilterFn: () => FilterFn<TData> | undefined;
87
66
  /**
88
67
  * Resets the **globalFilter** state to `initialState.globalFilter`, or `true` can be passed to force a default blank state reset to `undefined`.
89
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#resetglobalfilter)
90
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
68
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#resetglobalfilter)
69
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
91
70
  */
92
71
  resetGlobalFilter: (defaultState?: boolean) => void;
93
72
  /**
94
73
  * Sets or updates the `state.globalFilter` state.
95
- * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#setglobalfilter)
96
- * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)
74
+ * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#setglobalfilter)
75
+ * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)
97
76
  */
98
77
  setGlobalFilter: (updater: Updater<any>) => void;
99
78
  }
@@ -48,8 +48,7 @@ const GlobalFiltering = {
48
48
  const {
49
49
  globalFilterFn: globalFilterFn
50
50
  } = table.options;
51
- return utils.isFunction(globalFilterFn) ? globalFilterFn : globalFilterFn === 'auto' ? table.getGlobalAutoFilterFn() : // @ts-ignore
52
- (_table$options$filter = (_table$options$filter2 = table.options.filterFns) == null ? void 0 : _table$options$filter2[globalFilterFn]) != null ? _table$options$filter : filterFns.filterFns[globalFilterFn];
51
+ return utils.isFunction(globalFilterFn) ? globalFilterFn : globalFilterFn === 'auto' ? table.getGlobalAutoFilterFn() : (_table$options$filter = (_table$options$filter2 = table.options.filterFns) == null ? void 0 : _table$options$filter2[globalFilterFn]) != null ? _table$options$filter : filterFns.filterFns[globalFilterFn];
53
52
  };
54
53
  table.setGlobalFilter = updater => {
55
54
  table.options.onGlobalFilterChange == null || table.options.onGlobalFilterChange(updater);
@@ -57,27 +56,6 @@ const GlobalFiltering = {
57
56
  table.resetGlobalFilter = defaultState => {
58
57
  table.setGlobalFilter(defaultState ? undefined : table.initialState.globalFilter);
59
58
  };
60
- table._getGlobalFacetedRowModel = table.options.getFacetedRowModel && table.options.getFacetedRowModel(table, '__global__');
61
- table.getGlobalFacetedRowModel = () => {
62
- if (table.options.manualFiltering || !table._getGlobalFacetedRowModel) {
63
- return table.getPreFilteredRowModel();
64
- }
65
- return table._getGlobalFacetedRowModel();
66
- };
67
- table._getGlobalFacetedUniqueValues = table.options.getFacetedUniqueValues && table.options.getFacetedUniqueValues(table, '__global__');
68
- table.getGlobalFacetedUniqueValues = () => {
69
- if (!table._getGlobalFacetedUniqueValues) {
70
- return new Map();
71
- }
72
- return table._getGlobalFacetedUniqueValues();
73
- };
74
- table._getGlobalFacetedMinMaxValues = table.options.getFacetedMinMaxValues && table.options.getFacetedMinMaxValues(table, '__global__');
75
- table.getGlobalFacetedMinMaxValues = () => {
76
- if (!table._getGlobalFacetedMinMaxValues) {
77
- return;
78
- }
79
- return table._getGlobalFacetedMinMaxValues();
80
- };
81
59
  }
82
60
  };
83
61
 
@@ -1 +1 @@
1
- {"version":3,"file":"GlobalFiltering.js","sources":["../../../src/features/GlobalFiltering.ts"],"sourcesContent":["import { FilterFn, FilterFnOption, RowModel } from '..'\nimport { BuiltInFilterFn, filterFns } from '../filterFns'\nimport {\n Column,\n OnChangeFn,\n Table,\n Updater,\n RowData,\n TableFeature,\n} from '../types'\nimport { isFunction, makeStateUpdater } from '../utils'\n\nexport interface GlobalFilterTableState {\n globalFilter: any\n}\n\nexport interface GlobalFilterColumnDef {\n /**\n * Enables/disables the **global** filter for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#enableglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n enableGlobalFilter?: boolean\n}\n\nexport interface GlobalFilterColumn {\n /**\n * Returns whether or not the column can be **globally** filtered. Set to `false` to disable a column from being scanned during global filtering.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getcanglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getCanGlobalFilter: () => boolean\n}\n\nexport interface GlobalFilterOptions<TData extends RowData> {\n /**\n * Enables/disables **global** filtering for all columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#enableglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n enableGlobalFilter?: boolean\n /**\n * If provided, this function will be called with the column and should return `true` or `false` to indicate whether this column should be used for global filtering.\n *\n * This is useful if the column can contain data that is not `string` or `number` (i.e. `undefined`).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getcolumncanglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getColumnCanGlobalFilter?: (column: Column<TData, unknown>) => boolean\n /**\n * The filter function to use for global filtering.\n * - A `string` referencing a built-in filter function\n * - A `string` that references a custom filter functions provided via the `tableOptions.filterFns` option\n * - A custom filter function\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#globalfilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n globalFilterFn?: FilterFnOption<TData>\n /**\n * If provided, this function will be called with an `updaterFn` when `state.globalFilter` changes. This overrides the default internal state management, so you will need to persist the state change either fully or partially outside of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#onglobalfilterchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n onGlobalFilterChange?: OnChangeFn<any>\n}\n\nexport interface GlobalFilterInstance<TData extends RowData> {\n _getGlobalFacetedMinMaxValues?: () => undefined | [number, number]\n _getGlobalFacetedRowModel?: () => RowModel<TData>\n _getGlobalFacetedUniqueValues?: () => Map<any, number>\n /**\n * Currently, this function returns the built-in `includesString` filter function. In future releases, it may return more dynamic filter functions based on the nature of the data provided.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalautofilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getGlobalAutoFilterFn: () => FilterFn<TData> | undefined\n /**\n * Returns the faceted min and max values for the global filter.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfacetedminmaxvalues)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getGlobalFacetedMinMaxValues: () => undefined | [number, number]\n /**\n * Returns the row model for the table after **global** filtering has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfacetedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getGlobalFacetedRowModel: () => RowModel<TData>\n /**\n * Returns the faceted unique values for the global filter.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfaceteduniquevalues)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getGlobalFacetedUniqueValues: () => Map<any, number>\n /**\n * Returns the filter function (either user-defined or automatic, depending on configuration) for the global filter.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#getglobalfilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n getGlobalFilterFn: () => FilterFn<TData> | undefined\n /**\n * Resets the **globalFilter** state to `initialState.globalFilter`, or `true` can be passed to force a default blank state reset to `undefined`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#resetglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n resetGlobalFilter: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.globalFilter` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/filters#setglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/filters)\n */\n setGlobalFilter: (updater: Updater<any>) => void\n}\n\n//\n\nexport const GlobalFiltering: TableFeature = {\n getInitialState: (state): GlobalFilterTableState => {\n return {\n globalFilter: undefined,\n ...state,\n }\n },\n\n getDefaultOptions: <TData extends RowData>(\n table: Table<TData>\n ): GlobalFilterOptions<TData> => {\n return {\n onGlobalFilterChange: makeStateUpdater('globalFilter', table),\n globalFilterFn: 'auto',\n getColumnCanGlobalFilter: column => {\n const value = table\n .getCoreRowModel()\n .flatRows[0]?._getAllCellsByColumnId()\n [column.id]?.getValue()\n\n return typeof value === 'string' || typeof value === 'number'\n },\n } as GlobalFilterOptions<TData>\n },\n\n createColumn: <TData extends RowData>(\n column: Column<TData, unknown>,\n table: Table<TData>\n ): void => {\n column.getCanGlobalFilter = () => {\n return (\n (column.columnDef.enableGlobalFilter ?? true) &&\n (table.options.enableGlobalFilter ?? true) &&\n (table.options.enableFilters ?? true) &&\n (table.options.getColumnCanGlobalFilter?.(column) ?? true) &&\n !!column.accessorFn\n )\n }\n },\n\n createTable: <TData extends RowData>(table: Table<TData>): void => {\n table.getGlobalAutoFilterFn = () => {\n return filterFns.includesString\n }\n\n table.getGlobalFilterFn = () => {\n const { globalFilterFn: globalFilterFn } = table.options\n\n return isFunction(globalFilterFn)\n ? globalFilterFn\n : globalFilterFn === 'auto'\n ? table.getGlobalAutoFilterFn()\n : // @ts-ignore\n table.options.filterFns?.[globalFilterFn as string] ??\n filterFns[globalFilterFn as BuiltInFilterFn]\n }\n\n table.setGlobalFilter = updater => {\n table.options.onGlobalFilterChange?.(updater)\n }\n\n table.resetGlobalFilter = defaultState => {\n table.setGlobalFilter(\n defaultState ? undefined : table.initialState.globalFilter\n )\n }\n\n table._getGlobalFacetedRowModel =\n table.options.getFacetedRowModel &&\n table.options.getFacetedRowModel(table, '__global__')\n\n table.getGlobalFacetedRowModel = () => {\n if (table.options.manualFiltering || !table._getGlobalFacetedRowModel) {\n return table.getPreFilteredRowModel()\n }\n\n return table._getGlobalFacetedRowModel()\n }\n\n table._getGlobalFacetedUniqueValues =\n table.options.getFacetedUniqueValues &&\n table.options.getFacetedUniqueValues(table, '__global__')\n table.getGlobalFacetedUniqueValues = () => {\n if (!table._getGlobalFacetedUniqueValues) {\n return new Map()\n }\n\n return table._getGlobalFacetedUniqueValues()\n }\n\n table._getGlobalFacetedMinMaxValues =\n table.options.getFacetedMinMaxValues &&\n table.options.getFacetedMinMaxValues(table, '__global__')\n table.getGlobalFacetedMinMaxValues = () => {\n if (!table._getGlobalFacetedMinMaxValues) {\n return\n }\n\n return table._getGlobalFacetedMinMaxValues()\n }\n },\n}\n"],"names":["GlobalFiltering","getInitialState","state","globalFilter","undefined","getDefaultOptions","table","onGlobalFilterChange","makeStateUpdater","globalFilterFn","getColumnCanGlobalFilter","column","_table$getCoreRowMode","value","getCoreRowModel","flatRows","_getAllCellsByColumnId","id","getValue","createColumn","getCanGlobalFilter","_column$columnDef$ena","_table$options$enable","_table$options$enable2","_table$options$getCol","columnDef","enableGlobalFilter","options","enableFilters","accessorFn","createTable","getGlobalAutoFilterFn","filterFns","includesString","getGlobalFilterFn","_table$options$filter","_table$options$filter2","isFunction","setGlobalFilter","updater","resetGlobalFilter","defaultState","initialState","_getGlobalFacetedRowModel","getFacetedRowModel","getGlobalFacetedRowModel","manualFiltering","getPreFilteredRowModel","_getGlobalFacetedUniqueValues","getFacetedUniqueValues","getGlobalFacetedUniqueValues","Map","_getGlobalFacetedMinMaxValues","getFacetedMinMaxValues","getGlobalFacetedMinMaxValues"],"mappings":"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"}
1
+ {"version":3,"file":"GlobalFiltering.js","sources":["../../../src/features/GlobalFiltering.ts"],"sourcesContent":["import { FilterFn, FilterFnOption } from '..'\nimport { BuiltInFilterFn, filterFns } from '../filterFns'\nimport {\n Column,\n OnChangeFn,\n Table,\n Updater,\n RowData,\n TableFeature,\n} from '../types'\nimport { isFunction, makeStateUpdater } from '../utils'\n\nexport interface GlobalFilterTableState {\n globalFilter: any\n}\n\nexport interface GlobalFilterColumnDef {\n /**\n * Enables/disables the **global** filter for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#enableglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n enableGlobalFilter?: boolean\n}\n\nexport interface GlobalFilterColumn {\n /**\n * Returns whether or not the column can be **globally** filtered. Set to `false` to disable a column from being scanned during global filtering.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getcanglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n getCanGlobalFilter: () => boolean\n}\n\nexport interface GlobalFilterOptions<TData extends RowData> {\n /**\n * Enables/disables **global** filtering for all columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#enableglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n enableGlobalFilter?: boolean\n /**\n * If provided, this function will be called with the column and should return `true` or `false` to indicate whether this column should be used for global filtering.\n *\n * This is useful if the column can contain data that is not `string` or `number` (i.e. `undefined`).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getcolumncanglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n getColumnCanGlobalFilter?: (column: Column<TData, unknown>) => boolean\n /**\n * The filter function to use for global filtering.\n * - A `string` referencing a built-in filter function\n * - A `string` that references a custom filter functions provided via the `tableOptions.filterFns` option\n * - A custom filter function\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#globalfilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n globalFilterFn?: FilterFnOption<TData>\n /**\n * If provided, this function will be called with an `updaterFn` when `state.globalFilter` changes. This overrides the default internal state management, so you will need to persist the state change either fully or partially outside of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#onglobalfilterchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n onGlobalFilterChange?: OnChangeFn<any>\n}\n\nexport interface GlobalFilterInstance<TData extends RowData> {\n /**\n * Currently, this function returns the built-in `includesString` filter function. In future releases, it may return more dynamic filter functions based on the nature of the data provided.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getglobalautofilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n getGlobalAutoFilterFn: () => FilterFn<TData> | undefined\n /**\n * Returns the filter function (either user-defined or automatic, depending on configuration) for the global filter.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#getglobalfilterfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n getGlobalFilterFn: () => FilterFn<TData> | undefined\n /**\n * Resets the **globalFilter** state to `initialState.globalFilter`, or `true` can be passed to force a default blank state reset to `undefined`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#resetglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n resetGlobalFilter: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.globalFilter` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/global-filtering#setglobalfilter)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/global-filtering)\n */\n setGlobalFilter: (updater: Updater<any>) => void\n}\n\n//\n\nexport const GlobalFiltering: TableFeature = {\n getInitialState: (state): GlobalFilterTableState => {\n return {\n globalFilter: undefined,\n ...state,\n }\n },\n\n getDefaultOptions: <TData extends RowData>(\n table: Table<TData>\n ): GlobalFilterOptions<TData> => {\n return {\n onGlobalFilterChange: makeStateUpdater('globalFilter', table),\n globalFilterFn: 'auto',\n getColumnCanGlobalFilter: column => {\n const value = table\n .getCoreRowModel()\n .flatRows[0]?._getAllCellsByColumnId()\n [column.id]?.getValue()\n\n return typeof value === 'string' || typeof value === 'number'\n },\n } as GlobalFilterOptions<TData>\n },\n\n createColumn: <TData extends RowData>(\n column: Column<TData, unknown>,\n table: Table<TData>\n ): void => {\n column.getCanGlobalFilter = () => {\n return (\n (column.columnDef.enableGlobalFilter ?? true) &&\n (table.options.enableGlobalFilter ?? true) &&\n (table.options.enableFilters ?? true) &&\n (table.options.getColumnCanGlobalFilter?.(column) ?? true) &&\n !!column.accessorFn\n )\n }\n },\n\n createTable: <TData extends RowData>(table: Table<TData>): void => {\n table.getGlobalAutoFilterFn = () => {\n return filterFns.includesString\n }\n\n table.getGlobalFilterFn = () => {\n const { globalFilterFn: globalFilterFn } = table.options\n\n return isFunction(globalFilterFn)\n ? globalFilterFn\n : globalFilterFn === 'auto'\n ? table.getGlobalAutoFilterFn()\n : table.options.filterFns?.[globalFilterFn as string] ??\n filterFns[globalFilterFn as BuiltInFilterFn]\n }\n\n table.setGlobalFilter = updater => {\n table.options.onGlobalFilterChange?.(updater)\n }\n\n table.resetGlobalFilter = defaultState => {\n table.setGlobalFilter(\n defaultState ? undefined : table.initialState.globalFilter\n )\n }\n },\n}\n"],"names":["GlobalFiltering","getInitialState","state","globalFilter","undefined","getDefaultOptions","table","onGlobalFilterChange","makeStateUpdater","globalFilterFn","getColumnCanGlobalFilter","column","_table$getCoreRowMode","value","getCoreRowModel","flatRows","_getAllCellsByColumnId","id","getValue","createColumn","getCanGlobalFilter","_column$columnDef$ena","_table$options$enable","_table$options$enable2","_table$options$getCol","columnDef","enableGlobalFilter","options","enableFilters","accessorFn","createTable","getGlobalAutoFilterFn","filterFns","includesString","getGlobalFilterFn","_table$options$filter","_table$options$filter2","isFunction","setGlobalFilter","updater","resetGlobalFilter","defaultState","initialState"],"mappings":"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"}
@@ -12,6 +12,7 @@ export * from './features/ColumnOrdering';
12
12
  export * from './features/ColumnPinning';
13
13
  export * from './features/ColumnSizing';
14
14
  export * from './features/ColumnVisibility';
15
+ export * from './features/GlobalFaceting';
15
16
  export * from './features/GlobalFiltering';
16
17
  export * from './features/RowExpanding';
17
18
  export * from './features/RowPagination';
@@ -1544,6 +1544,34 @@ function _getVisibleLeafColumns(table, position) {
1544
1544
 
1545
1545
  //
1546
1546
 
1547
+ const GlobalFaceting = {
1548
+ createTable: table => {
1549
+ table._getGlobalFacetedRowModel = table.options.getFacetedRowModel && table.options.getFacetedRowModel(table, '__global__');
1550
+ table.getGlobalFacetedRowModel = () => {
1551
+ if (table.options.manualFiltering || !table._getGlobalFacetedRowModel) {
1552
+ return table.getPreFilteredRowModel();
1553
+ }
1554
+ return table._getGlobalFacetedRowModel();
1555
+ };
1556
+ table._getGlobalFacetedUniqueValues = table.options.getFacetedUniqueValues && table.options.getFacetedUniqueValues(table, '__global__');
1557
+ table.getGlobalFacetedUniqueValues = () => {
1558
+ if (!table._getGlobalFacetedUniqueValues) {
1559
+ return new Map();
1560
+ }
1561
+ return table._getGlobalFacetedUniqueValues();
1562
+ };
1563
+ table._getGlobalFacetedMinMaxValues = table.options.getFacetedMinMaxValues && table.options.getFacetedMinMaxValues(table, '__global__');
1564
+ table.getGlobalFacetedMinMaxValues = () => {
1565
+ if (!table._getGlobalFacetedMinMaxValues) {
1566
+ return;
1567
+ }
1568
+ return table._getGlobalFacetedMinMaxValues();
1569
+ };
1570
+ }
1571
+ };
1572
+
1573
+ //
1574
+
1547
1575
  const GlobalFiltering = {
1548
1576
  getInitialState: state => {
1549
1577
  return {
@@ -1577,8 +1605,7 @@ const GlobalFiltering = {
1577
1605
  const {
1578
1606
  globalFilterFn: globalFilterFn
1579
1607
  } = table.options;
1580
- return isFunction(globalFilterFn) ? globalFilterFn : globalFilterFn === 'auto' ? table.getGlobalAutoFilterFn() : // @ts-ignore
1581
- (_table$options$filter = (_table$options$filter2 = table.options.filterFns) == null ? void 0 : _table$options$filter2[globalFilterFn]) != null ? _table$options$filter : filterFns[globalFilterFn];
1608
+ return isFunction(globalFilterFn) ? globalFilterFn : globalFilterFn === 'auto' ? table.getGlobalAutoFilterFn() : (_table$options$filter = (_table$options$filter2 = table.options.filterFns) == null ? void 0 : _table$options$filter2[globalFilterFn]) != null ? _table$options$filter : filterFns[globalFilterFn];
1582
1609
  };
1583
1610
  table.setGlobalFilter = updater => {
1584
1611
  table.options.onGlobalFilterChange == null || table.options.onGlobalFilterChange(updater);
@@ -1586,27 +1613,6 @@ const GlobalFiltering = {
1586
1613
  table.resetGlobalFilter = defaultState => {
1587
1614
  table.setGlobalFilter(defaultState ? undefined : table.initialState.globalFilter);
1588
1615
  };
1589
- table._getGlobalFacetedRowModel = table.options.getFacetedRowModel && table.options.getFacetedRowModel(table, '__global__');
1590
- table.getGlobalFacetedRowModel = () => {
1591
- if (table.options.manualFiltering || !table._getGlobalFacetedRowModel) {
1592
- return table.getPreFilteredRowModel();
1593
- }
1594
- return table._getGlobalFacetedRowModel();
1595
- };
1596
- table._getGlobalFacetedUniqueValues = table.options.getFacetedUniqueValues && table.options.getFacetedUniqueValues(table, '__global__');
1597
- table.getGlobalFacetedUniqueValues = () => {
1598
- if (!table._getGlobalFacetedUniqueValues) {
1599
- return new Map();
1600
- }
1601
- return table._getGlobalFacetedUniqueValues();
1602
- };
1603
- table._getGlobalFacetedMinMaxValues = table.options.getFacetedMinMaxValues && table.options.getFacetedMinMaxValues(table, '__global__');
1604
- table.getGlobalFacetedMinMaxValues = () => {
1605
- if (!table._getGlobalFacetedMinMaxValues) {
1606
- return;
1607
- }
1608
- return table._getGlobalFacetedMinMaxValues();
1609
- };
1610
1616
  }
1611
1617
  };
1612
1618
 
@@ -2735,8 +2741,10 @@ const RowSorting = {
2735
2741
  }
2736
2742
  };
2737
2743
 
2738
- const builtInFeatures = [Headers, ColumnVisibility, ColumnOrdering, ColumnPinning, ColumnFaceting, ColumnFiltering, GlobalFiltering,
2739
- //depends on ColumnFiltering and ColumnFaceting
2744
+ const builtInFeatures = [Headers, ColumnVisibility, ColumnOrdering, ColumnPinning, ColumnFaceting, ColumnFiltering, GlobalFaceting,
2745
+ //depends on ColumnFaceting
2746
+ GlobalFiltering,
2747
+ //depends on ColumnFiltering
2740
2748
  RowSorting, ColumnGrouping,
2741
2749
  //depends on RowSorting
2742
2750
  RowExpanding, RowPagination, RowPinning, RowSelection, ColumnSizing];
@@ -3507,5 +3515,5 @@ function getSortedRowModel() {
3507
3515
  }, getMemoOptions(table.options, 'debugTable', 'getSortedRowModel', () => table._autoResetPageIndex()));
3508
3516
  }
3509
3517
 
3510
- export { ColumnFaceting, ColumnFiltering, ColumnGrouping, ColumnOrdering, ColumnPinning, ColumnSizing, ColumnVisibility, GlobalFiltering, Headers, RowExpanding, RowPagination, RowPinning, RowSelection, RowSorting, _getVisibleLeafColumns, aggregationFns, buildHeaderGroups, createCell, createColumn, createColumnHelper, createRow, createTable, defaultColumnSizing, expandRows, filterFns, flattenBy, functionalUpdate, getCoreRowModel, getExpandedRowModel, getFacetedMinMaxValues, getFacetedRowModel, getFacetedUniqueValues, getFilteredRowModel, getGroupedRowModel, getMemoOptions, getPaginationRowModel, getSortedRowModel, isFunction, isNumberArray, isRowSelected, isSubRowSelected, makeStateUpdater, memo, noop, orderColumns, passiveEventSupported, reSplitAlphaNumeric, selectRowsFn, shouldAutoRemoveFilter, sortingFns };
3518
+ export { ColumnFaceting, ColumnFiltering, ColumnGrouping, ColumnOrdering, ColumnPinning, ColumnSizing, ColumnVisibility, GlobalFaceting, GlobalFiltering, Headers, RowExpanding, RowPagination, RowPinning, RowSelection, RowSorting, _getVisibleLeafColumns, aggregationFns, buildHeaderGroups, createCell, createColumn, createColumnHelper, createRow, createTable, defaultColumnSizing, expandRows, filterFns, flattenBy, functionalUpdate, getCoreRowModel, getExpandedRowModel, getFacetedMinMaxValues, getFacetedRowModel, getFacetedUniqueValues, getFilteredRowModel, getGroupedRowModel, getMemoOptions, getPaginationRowModel, getSortedRowModel, isFunction, isNumberArray, isRowSelected, isSubRowSelected, makeStateUpdater, memo, noop, orderColumns, passiveEventSupported, reSplitAlphaNumeric, selectRowsFn, shouldAutoRemoveFilter, sortingFns };
3511
3519
  //# sourceMappingURL=index.esm.js.map