{"version":3,"file":"static/js/3016.d4037354fece86879c77.js","mappings":"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","sources":["../node_modules/@mui/icons-material/esm/ExpandMore.js","../node_modules/@mui/system/Grid/traverseBreakpoints.js","../node_modules/@mui/system/Grid/gridGenerator.js","../node_modules/@mui/system/Grid/createGrid.js","../node_modules/@mui/material/Grid2/Grid2.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/isMuiElement/isMuiElement.js","../node_modules/@mui/material/styles/cssUtils.js","../node_modules/@mui/material/Skeleton/skeletonClasses.js","../node_modules/@mui/material/Skeleton/Skeleton.js","../node_modules/@web-for-marketing/react-ui/lib/esm/components/Icons/CheckmarkIcon.js","../node_modules/@web-for-marketing/react-ui/lib/esm/components/Icons/CloseIcon.js","../node_modules/@web-for-marketing/react-ui/lib/esm/components/Icons/ExpandIcon.js","../node_modules/@web-for-marketing/react-ui/lib/esm/components/Icons/NewTabIcon.js","../../../src/index.tsx","../../../src/utils.ts","../../../src/core/headers.ts","../../../src/core/row.ts","../../../src/core/cell.ts","../../../src/features/ColumnFaceting.ts","../../../src/filterFns.ts","../../../src/features/ColumnFiltering.ts","../../../src/aggregationFns.ts","../../../src/features/ColumnGrouping.ts","../../../src/features/ColumnOrdering.ts","../../../src/features/ColumnPinning.ts","../../../src/features/ColumnSizing.ts","../../../src/features/ColumnVisibility.ts","../../../src/features/GlobalFaceting.ts","../../../src/features/RowSelection.ts","../../../src/sortingFns.ts","../../../src/core/table.ts","../../../src/features/GlobalFiltering.ts","../../../src/features/RowSorting.ts","../../../src/features/RowExpanding.ts","../../../src/features/RowPagination.ts","../../../src/features/RowPinning.ts","../../../src/core/column.ts","../../../src/utils/getCoreRowModel.ts","../../../src/utils/getExpandedRowModel.ts"],"sourcesContent":["\"use client\";\n\nimport createSvgIcon from './utils/createSvgIcon';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon( /*#__PURE__*/_jsx(\"path\", {\n d: \"M16.59 8.59 12 13.17 7.41 8.59 6 10l6 6 6-6z\"\n}), 'ExpandMore');","export const filterBreakpointKeys = (breakpointsKeys, responsiveKeys) => breakpointsKeys.filter(key => responsiveKeys.includes(key));\nexport const traverseBreakpoints = (breakpoints, responsive, iterator) => {\n const smallestBreakpoint = breakpoints.keys[0]; // the keys is sorted from smallest to largest by `createBreakpoints`.\n\n if (Array.isArray(responsive)) {\n responsive.forEach((breakpointValue, index) => {\n iterator((responsiveStyles, style) => {\n if (index <= breakpoints.keys.length - 1) {\n if (index === 0) {\n Object.assign(responsiveStyles, style);\n } else {\n responsiveStyles[breakpoints.up(breakpoints.keys[index])] = style;\n }\n }\n }, breakpointValue);\n });\n } else if (responsive && typeof responsive === 'object') {\n // prevent null\n // responsive could be a very big object, pick the smallest responsive values\n\n const keys = Object.keys(responsive).length > breakpoints.keys.length ? breakpoints.keys : filterBreakpointKeys(breakpoints.keys, Object.keys(responsive));\n keys.forEach(key => {\n if (breakpoints.keys.includes(key)) {\n // @ts-ignore already checked that responsive is an object\n const breakpointValue = responsive[key];\n if (breakpointValue !== undefined) {\n iterator((responsiveStyles, style) => {\n if (smallestBreakpoint === key) {\n Object.assign(responsiveStyles, style);\n } else {\n responsiveStyles[breakpoints.up(key)] = style;\n }\n }, breakpointValue);\n }\n }\n });\n } else if (typeof responsive === 'number' || typeof responsive === 'string') {\n iterator((responsiveStyles, style) => {\n Object.assign(responsiveStyles, style);\n }, responsive);\n }\n};","import { traverseBreakpoints } from \"./traverseBreakpoints.js\";\nfunction appendLevel(level) {\n if (!level) {\n return '';\n }\n return `Level${level}`;\n}\nfunction isNestedContainer(ownerState) {\n return ownerState.unstable_level > 0 && ownerState.container;\n}\nfunction createGetSelfSpacing(ownerState) {\n return function getSelfSpacing(axis) {\n return `var(--Grid-${axis}Spacing${appendLevel(ownerState.unstable_level)})`;\n };\n}\nfunction createGetParentSpacing(ownerState) {\n return function getParentSpacing(axis) {\n if (ownerState.unstable_level === 0) {\n return `var(--Grid-${axis}Spacing)`;\n }\n return `var(--Grid-${axis}Spacing${appendLevel(ownerState.unstable_level - 1)})`;\n };\n}\nfunction getParentColumns(ownerState) {\n if (ownerState.unstable_level === 0) {\n return `var(--Grid-columns)`;\n }\n return `var(--Grid-columns${appendLevel(ownerState.unstable_level - 1)})`;\n}\nexport const generateGridSizeStyles = ({\n theme,\n ownerState\n}) => {\n const getParentSpacing = createGetParentSpacing(ownerState);\n const styles = {};\n traverseBreakpoints(theme.breakpoints, ownerState.size, (appendStyle, value) => {\n let style = {};\n if (value === 'grow') {\n style = {\n flexBasis: 0,\n flexGrow: 1,\n maxWidth: '100%'\n };\n }\n if (value === 'auto') {\n style = {\n flexBasis: 'auto',\n flexGrow: 0,\n flexShrink: 0,\n maxWidth: 'none',\n width: 'auto'\n };\n }\n if (typeof value === 'number') {\n style = {\n flexGrow: 0,\n flexBasis: 'auto',\n width: `calc(100% * ${value} / ${getParentColumns(ownerState)} - (${getParentColumns(ownerState)} - ${value}) * (${getParentSpacing('column')} / ${getParentColumns(ownerState)}))`\n };\n }\n appendStyle(styles, style);\n });\n return styles;\n};\nexport const generateGridOffsetStyles = ({\n theme,\n ownerState\n}) => {\n const getParentSpacing = createGetParentSpacing(ownerState);\n const styles = {};\n traverseBreakpoints(theme.breakpoints, ownerState.offset, (appendStyle, value) => {\n let style = {};\n if (value === 'auto') {\n style = {\n marginLeft: 'auto'\n };\n }\n if (typeof value === 'number') {\n style = {\n marginLeft: value === 0 ? '0px' : `calc(100% * ${value} / ${getParentColumns(ownerState)} + ${getParentSpacing('column')} * ${value} / ${getParentColumns(ownerState)})`\n };\n }\n appendStyle(styles, style);\n });\n return styles;\n};\nexport const generateGridColumnsStyles = ({\n theme,\n ownerState\n}) => {\n if (!ownerState.container) {\n return {};\n }\n const styles = isNestedContainer(ownerState) ? {\n [`--Grid-columns${appendLevel(ownerState.unstable_level)}`]: getParentColumns(ownerState)\n } : {\n '--Grid-columns': 12\n };\n traverseBreakpoints(theme.breakpoints, ownerState.columns, (appendStyle, value) => {\n appendStyle(styles, {\n [`--Grid-columns${appendLevel(ownerState.unstable_level)}`]: value\n });\n });\n return styles;\n};\nexport const generateGridRowSpacingStyles = ({\n theme,\n ownerState\n}) => {\n if (!ownerState.container) {\n return {};\n }\n const getParentSpacing = createGetParentSpacing(ownerState);\n const styles = isNestedContainer(ownerState) ? {\n // Set the default spacing as its parent spacing.\n // It will be overridden if spacing props are provided\n [`--Grid-rowSpacing${appendLevel(ownerState.unstable_level)}`]: getParentSpacing('row')\n } : {};\n traverseBreakpoints(theme.breakpoints, ownerState.rowSpacing, (appendStyle, value) => {\n appendStyle(styles, {\n [`--Grid-rowSpacing${appendLevel(ownerState.unstable_level)}`]: typeof value === 'string' ? value : theme.spacing?.(value)\n });\n });\n return styles;\n};\nexport const generateGridColumnSpacingStyles = ({\n theme,\n ownerState\n}) => {\n if (!ownerState.container) {\n return {};\n }\n const getParentSpacing = createGetParentSpacing(ownerState);\n const styles = isNestedContainer(ownerState) ? {\n // Set the default spacing as its parent spacing.\n // It will be overridden if spacing props are provided\n [`--Grid-columnSpacing${appendLevel(ownerState.unstable_level)}`]: getParentSpacing('column')\n } : {};\n traverseBreakpoints(theme.breakpoints, ownerState.columnSpacing, (appendStyle, value) => {\n appendStyle(styles, {\n [`--Grid-columnSpacing${appendLevel(ownerState.unstable_level)}`]: typeof value === 'string' ? value : theme.spacing?.(value)\n });\n });\n return styles;\n};\nexport const generateGridDirectionStyles = ({\n theme,\n ownerState\n}) => {\n if (!ownerState.container) {\n return {};\n }\n const styles = {};\n traverseBreakpoints(theme.breakpoints, ownerState.direction, (appendStyle, value) => {\n appendStyle(styles, {\n flexDirection: value\n });\n });\n return styles;\n};\nexport const generateGridStyles = ({\n ownerState\n}) => {\n const getSelfSpacing = createGetSelfSpacing(ownerState);\n return {\n minWidth: 0,\n boxSizing: 'border-box',\n ...(ownerState.container && {\n display: 'flex',\n flexWrap: 'wrap',\n ...(ownerState.wrap && ownerState.wrap !== 'wrap' && {\n flexWrap: ownerState.wrap\n }),\n gap: `${getSelfSpacing('row')} ${getSelfSpacing('column')}`\n })\n };\n};\nexport const generateSizeClassNames = size => {\n const classNames = [];\n Object.entries(size).forEach(([key, value]) => {\n if (value !== false && value !== undefined) {\n classNames.push(`grid-${key}-${String(value)}`);\n }\n });\n return classNames;\n};\nexport const generateSpacingClassNames = (spacing, smallestBreakpoint = 'xs') => {\n function isValidSpacing(val) {\n if (val === undefined) {\n return false;\n }\n return typeof val === 'string' && !Number.isNaN(Number(val)) || typeof val === 'number' && val > 0;\n }\n if (isValidSpacing(spacing)) {\n return [`spacing-${smallestBreakpoint}-${String(spacing)}`];\n }\n if (typeof spacing === 'object' && !Array.isArray(spacing)) {\n const classNames = [];\n Object.entries(spacing).forEach(([key, value]) => {\n if (isValidSpacing(value)) {\n classNames.push(`spacing-${key}-${String(value)}`);\n }\n });\n return classNames;\n }\n return [];\n};\nexport const generateDirectionClasses = direction => {\n if (direction === undefined) {\n return [];\n }\n if (typeof direction === 'object') {\n return Object.entries(direction).map(([key, value]) => `direction-${key}-${value}`);\n }\n return [`direction-xs-${String(direction)}`];\n};","import * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport isMuiElement from '@mui/utils/isMuiElement';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nimport composeClasses from '@mui/utils/composeClasses';\nimport systemStyled from \"../styled/index.js\";\nimport useThemePropsSystem from \"../useThemeProps/index.js\";\nimport useTheme from \"../useTheme/index.js\";\nimport { extendSxProp } from \"../styleFunctionSx/index.js\";\nimport createTheme from \"../createTheme/index.js\";\nimport { generateGridStyles, generateGridSizeStyles, generateGridColumnsStyles, generateGridColumnSpacingStyles, generateGridRowSpacingStyles, generateGridDirectionStyles, generateGridOffsetStyles, generateSizeClassNames, generateSpacingClassNames, generateDirectionClasses } from \"./gridGenerator.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst defaultTheme = createTheme();\n\n// widening Theme to any so that the consumer can own the theme structure.\nconst defaultCreateStyledComponent = systemStyled('div', {\n name: 'MuiGrid',\n slot: 'Root',\n overridesResolver: (props, styles) => styles.root\n});\nfunction useThemePropsDefault(props) {\n return useThemePropsSystem({\n props,\n name: 'MuiGrid',\n defaultTheme\n });\n}\nexport default function createGrid(options = {}) {\n const {\n // This will allow adding custom styled fn (for example for custom sx style function)\n createStyledComponent = defaultCreateStyledComponent,\n useThemeProps = useThemePropsDefault,\n componentName = 'MuiGrid'\n } = options;\n const useUtilityClasses = (ownerState, theme) => {\n const {\n container,\n direction,\n spacing,\n wrap,\n size\n } = ownerState;\n const slots = {\n root: ['root', container && 'container', wrap !== 'wrap' && `wrap-xs-${String(wrap)}`, ...generateDirectionClasses(direction), ...generateSizeClassNames(size), ...(container ? generateSpacingClassNames(spacing, theme.breakpoints.keys[0]) : [])]\n };\n return composeClasses(slots, slot => generateUtilityClass(componentName, slot), {});\n };\n function parseResponsiveProp(propValue, breakpoints, shouldUseValue = () => true) {\n const parsedProp = {};\n if (propValue === null) {\n return parsedProp;\n }\n if (Array.isArray(propValue)) {\n propValue.forEach((value, index) => {\n if (value !== null && shouldUseValue(value) && breakpoints.keys[index]) {\n parsedProp[breakpoints.keys[index]] = value;\n }\n });\n } else if (typeof propValue === 'object') {\n Object.keys(propValue).forEach(key => {\n const value = propValue[key];\n if (value !== null && value !== undefined && shouldUseValue(value)) {\n parsedProp[key] = value;\n }\n });\n } else {\n parsedProp[breakpoints.keys[0]] = propValue;\n }\n return parsedProp;\n }\n const GridRoot = createStyledComponent(generateGridColumnsStyles, generateGridColumnSpacingStyles, generateGridRowSpacingStyles, generateGridSizeStyles, generateGridDirectionStyles, generateGridStyles, generateGridOffsetStyles);\n const Grid = /*#__PURE__*/React.forwardRef(function Grid(inProps, ref) {\n const theme = useTheme();\n const themeProps = useThemeProps(inProps);\n const props = extendSxProp(themeProps); // `color` type conflicts with html color attribute.\n const {\n className,\n children,\n columns: columnsProp = 12,\n container = false,\n component = 'div',\n direction = 'row',\n wrap = 'wrap',\n size: sizeProp = {},\n offset: offsetProp = {},\n spacing: spacingProp = 0,\n rowSpacing: rowSpacingProp = spacingProp,\n columnSpacing: columnSpacingProp = spacingProp,\n unstable_level: level = 0,\n ...other\n } = props;\n const size = parseResponsiveProp(sizeProp, theme.breakpoints, val => val !== false);\n const offset = parseResponsiveProp(offsetProp, theme.breakpoints);\n const columns = inProps.columns ?? (level ? undefined : columnsProp);\n const spacing = inProps.spacing ?? (level ? undefined : spacingProp);\n const rowSpacing = inProps.rowSpacing ?? inProps.spacing ?? (level ? undefined : rowSpacingProp);\n const columnSpacing = inProps.columnSpacing ?? inProps.spacing ?? (level ? undefined : columnSpacingProp);\n const ownerState = {\n ...props,\n level,\n columns,\n container,\n direction,\n wrap,\n spacing,\n rowSpacing,\n columnSpacing,\n size,\n offset\n };\n const classes = useUtilityClasses(ownerState, theme);\n return /*#__PURE__*/_jsx(GridRoot, {\n ref: ref,\n as: component,\n ownerState: ownerState,\n className: clsx(classes.root, className),\n ...other,\n children: React.Children.map(children, child => {\n if (/*#__PURE__*/React.isValidElement(child) && isMuiElement(child, ['Grid'])) {\n return /*#__PURE__*/React.cloneElement(child, {\n unstable_level: child.props?.unstable_level ?? level + 1\n });\n }\n return child;\n })\n });\n });\n process.env.NODE_ENV !== \"production\" ? Grid.propTypes /* remove-proptypes */ = {\n children: PropTypes.node,\n className: PropTypes.string,\n columns: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.number), PropTypes.number, PropTypes.object]),\n columnSpacing: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.number, PropTypes.string])), PropTypes.number, PropTypes.object, PropTypes.string]),\n component: PropTypes.elementType,\n container: PropTypes.bool,\n direction: PropTypes.oneOfType([PropTypes.oneOf(['column-reverse', 'column', 'row-reverse', 'row']), PropTypes.arrayOf(PropTypes.oneOf(['column-reverse', 'column', 'row-reverse', 'row'])), PropTypes.object]),\n offset: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.number])), PropTypes.object]),\n rowSpacing: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.number, PropTypes.string])), PropTypes.number, PropTypes.object, PropTypes.string]),\n size: PropTypes.oneOfType([PropTypes.string, PropTypes.bool, PropTypes.number, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.bool, PropTypes.number])), PropTypes.object]),\n spacing: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.number, PropTypes.string])), PropTypes.number, PropTypes.object, PropTypes.string]),\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n wrap: PropTypes.oneOf(['nowrap', 'wrap-reverse', 'wrap'])\n } : void 0;\n\n // @ts-ignore internal logic for nested grid\n Grid.muiName = 'Grid';\n return Grid;\n}","'use client';\n\nimport PropTypes from 'prop-types';\nimport { createGrid as createGrid2 } from '@mui/system/Grid';\nimport { styled, useThemeProps } from \"../styles/index.js\";\n/**\n *\n * Demos:\n *\n * - [Grid version 2](https://mui.com/material-ui/react-grid2/)\n *\n * API:\n *\n * - [Grid2 API](https://mui.com/material-ui/api/grid-2/)\n */\nconst Grid2 = createGrid2({\n createStyledComponent: styled('div', {\n name: 'MuiGrid2',\n slot: 'Root',\n overridesResolver: (props, styles) => styles.root\n }),\n componentName: 'MuiGrid2',\n useThemeProps: inProps => useThemeProps({\n props: inProps,\n name: 'MuiGrid2'\n })\n});\nprocess.env.NODE_ENV !== \"production\" ? Grid2.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n /**\n * The number of columns.\n * @default 12\n */\n columns: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.arrayOf(PropTypes.number), PropTypes.number, PropTypes.object]),\n /**\n * Defines the horizontal space between the type `item` components.\n * It overrides the value of the `spacing` prop.\n */\n columnSpacing: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.number, PropTypes.string])), PropTypes.number, PropTypes.object, PropTypes.string]),\n /**\n * If `true`, the component will have the flex *container* behavior.\n * You should be wrapping *items* with a *container*.\n * @default false\n */\n container: PropTypes.bool,\n /**\n * Defines the `flex-direction` style property.\n * It is applied for all screen sizes.\n * @default 'row'\n */\n direction: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['column-reverse', 'column', 'row-reverse', 'row']), PropTypes.arrayOf(PropTypes.oneOf(['column-reverse', 'column', 'row-reverse', 'row'])), PropTypes.object]),\n /**\n * Defines the offset value for the type `item` components.\n */\n offset: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.string, PropTypes.number, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.number])), PropTypes.object]),\n /**\n * Defines the vertical space between the type `item` components.\n * It overrides the value of the `spacing` prop.\n */\n rowSpacing: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.number, PropTypes.string])), PropTypes.number, PropTypes.object, PropTypes.string]),\n /**\n * Defines the size of the the type `item` components.\n */\n size: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.string, PropTypes.bool, PropTypes.number, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.bool, PropTypes.number])), PropTypes.object]),\n /**\n * Defines the space between the type `item` components.\n * It can only be used on a type `container` component.\n * @default 0\n */\n spacing: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.number, PropTypes.string])), PropTypes.number, PropTypes.object, PropTypes.string]),\n /**\n * @ignore\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * @internal\n * The level of the grid starts from `0`\n * and increases when the grid nests inside another grid regardless of container or item.\n *\n * ```js\n * // level 0\n * // level 1\n * // level 2\n * // level 1\n * ```\n *\n * Only consecutive grid is considered nesting.\n * A grid container will start at `0` if there are non-Grid element above it.\n *\n * ```js\n * // level 0\n *
\n * // level 0\n * // level 1\n * ```\n */\n unstable_level: PropTypes.number,\n /**\n * Defines the `flex-wrap` style property.\n * It's applied for all screen sizes.\n * @default 'wrap'\n */\n wrap: PropTypes.oneOf(['nowrap', 'wrap-reverse', 'wrap'])\n} : void 0;\nexport default Grid2;","import * as React from 'react';\nexport default function isMuiElement(element, muiNames) {\n return /*#__PURE__*/React.isValidElement(element) && muiNames.indexOf(\n // For server components `muiName` is avaialble in element.type._payload.value.muiName\n // relevant info - https://github.com/facebook/react/blob/2807d781a08db8e9873687fccc25c0f12b4fb3d4/packages/react/src/ReactLazy.js#L45\n // eslint-disable-next-line no-underscore-dangle\n element.type.muiName ?? element.type?._payload?.value?.muiName) !== -1;\n}","export function isUnitless(value) {\n return String(parseFloat(value)).length === String(value).length;\n}\n\n// Ported from Compass\n// https://github.com/Compass/compass/blob/master/core/stylesheets/compass/typography/_units.scss\n// Emulate the sass function \"unit\"\nexport function getUnit(input) {\n return String(input).match(/[\\d.\\-+]*\\s*(.*)/)[1] || '';\n}\n\n// Emulate the sass function \"unitless\"\nexport function toUnitless(length) {\n return parseFloat(length);\n}\n\n// Convert any CSS or value to any another.\n// From https://github.com/KyleAMathews/convert-css-length\nexport function convertLength(baseFontSize) {\n return (length, toUnit) => {\n const fromUnit = getUnit(length);\n\n // Optimize for cases where `from` and `to` units are accidentally the same.\n if (fromUnit === toUnit) {\n return length;\n }\n\n // Convert input length to pixels.\n let pxLength = toUnitless(length);\n if (fromUnit !== 'px') {\n if (fromUnit === 'em') {\n pxLength = toUnitless(length) * toUnitless(baseFontSize);\n } else if (fromUnit === 'rem') {\n pxLength = toUnitless(length) * toUnitless(baseFontSize);\n }\n }\n\n // Convert length in pixels to the output unit\n let outputLength = pxLength;\n if (toUnit !== 'px') {\n if (toUnit === 'em') {\n outputLength = pxLength / toUnitless(baseFontSize);\n } else if (toUnit === 'rem') {\n outputLength = pxLength / toUnitless(baseFontSize);\n } else {\n return length;\n }\n }\n return parseFloat(outputLength.toFixed(5)) + toUnit;\n };\n}\nexport function alignProperty({\n size,\n grid\n}) {\n const sizeBelow = size - size % grid;\n const sizeAbove = sizeBelow + grid;\n return size - sizeBelow < sizeAbove - size ? sizeBelow : sizeAbove;\n}\n\n// fontGrid finds a minimal grid (in rem) for the fontSize values so that the\n// lineHeight falls under a x pixels grid, 4px in the case of Material Design,\n// without changing the relative line height\nexport function fontGrid({\n lineHeight,\n pixels,\n htmlFontSize\n}) {\n return pixels / (lineHeight * htmlFontSize);\n}\n\n/**\n * generate a responsive version of a given CSS property\n * @example\n * responsiveProperty({\n * cssProperty: 'fontSize',\n * min: 15,\n * max: 20,\n * unit: 'px',\n * breakpoints: [300, 600],\n * })\n *\n * // this returns\n *\n * {\n * fontSize: '15px',\n * '@media (min-width:300px)': {\n * fontSize: '17.5px',\n * },\n * '@media (min-width:600px)': {\n * fontSize: '20px',\n * },\n * }\n * @param {Object} params\n * @param {string} params.cssProperty - The CSS property to be made responsive\n * @param {number} params.min - The smallest value of the CSS property\n * @param {number} params.max - The largest value of the CSS property\n * @param {string} [params.unit] - The unit to be used for the CSS property\n * @param {Array.number} [params.breakpoints] - An array of breakpoints\n * @param {number} [params.alignStep] - Round scaled value to fall under this grid\n * @returns {Object} responsive styles for {params.cssProperty}\n */\nexport function responsiveProperty({\n cssProperty,\n min,\n max,\n unit = 'rem',\n breakpoints = [600, 900, 1200],\n transform = null\n}) {\n const output = {\n [cssProperty]: `${min}${unit}`\n };\n const factor = (max - min) / breakpoints[breakpoints.length - 1];\n breakpoints.forEach(breakpoint => {\n let value = min + factor * breakpoint;\n if (transform !== null) {\n value = transform(value);\n }\n output[`@media (min-width:${breakpoint}px)`] = {\n [cssProperty]: `${Math.round(value * 10000) / 10000}${unit}`\n };\n });\n return output;\n}","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getSkeletonUtilityClass(slot) {\n return generateUtilityClass('MuiSkeleton', slot);\n}\nconst skeletonClasses = generateUtilityClasses('MuiSkeleton', ['root', 'text', 'rectangular', 'rounded', 'circular', 'pulse', 'wave', 'withChildren', 'fitContent', 'heightAuto']);\nexport default skeletonClasses;","'use client';\n\nimport * as React from 'react';\nimport clsx from 'clsx';\nimport PropTypes from 'prop-types';\nimport composeClasses from '@mui/utils/composeClasses';\nimport { alpha, unstable_getUnit as getUnit, unstable_toUnitless as toUnitless } from \"../styles/index.js\";\nimport { keyframes, css, styled } from \"../zero-styled/index.js\";\nimport memoTheme from \"../utils/memoTheme.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport { getSkeletonUtilityClass } from \"./skeletonClasses.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n classes,\n variant,\n animation,\n hasChildren,\n width,\n height\n } = ownerState;\n const slots = {\n root: ['root', variant, animation, hasChildren && 'withChildren', hasChildren && !width && 'fitContent', hasChildren && !height && 'heightAuto']\n };\n return composeClasses(slots, getSkeletonUtilityClass, classes);\n};\nconst pulseKeyframe = keyframes`\n 0% {\n opacity: 1;\n }\n\n 50% {\n opacity: 0.4;\n }\n\n 100% {\n opacity: 1;\n }\n`;\nconst waveKeyframe = keyframes`\n 0% {\n transform: translateX(-100%);\n }\n\n 50% {\n /* +0.5s of delay between each loop */\n transform: translateX(100%);\n }\n\n 100% {\n transform: translateX(100%);\n }\n`;\n\n// This implementation is for supporting both Styled-components v4+ and Pigment CSS.\n// A global animation has to be created here for Styled-components v4+ (https://github.com/styled-components/styled-components/blob/main/packages/styled-components/src/utils/errors.md#12).\n// which can be done by checking typeof indeterminate1Keyframe !== 'string' (at runtime, Pigment CSS transform keyframes`` to a string).\nconst pulseAnimation = typeof pulseKeyframe !== 'string' ? css`\n animation: ${pulseKeyframe} 2s ease-in-out 0.5s infinite;\n ` : null;\nconst waveAnimation = typeof waveKeyframe !== 'string' ? css`\n animation: ${waveKeyframe} 2s linear 0.5s infinite;\n ` : null;\nconst SkeletonRoot = styled('span', {\n name: 'MuiSkeleton',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, styles[ownerState.variant], ownerState.animation !== false && styles[ownerState.animation], ownerState.hasChildren && styles.withChildren, ownerState.hasChildren && !ownerState.width && styles.fitContent, ownerState.hasChildren && !ownerState.height && styles.heightAuto];\n }\n})(memoTheme(({\n theme\n}) => {\n const radiusUnit = getUnit(theme.shape.borderRadius) || 'px';\n const radiusValue = toUnitless(theme.shape.borderRadius);\n return {\n display: 'block',\n // Create a \"on paper\" color with sufficient contrast retaining the color\n backgroundColor: theme.vars ? theme.vars.palette.Skeleton.bg : alpha(theme.palette.text.primary, theme.palette.mode === 'light' ? 0.11 : 0.13),\n height: '1.2em',\n variants: [{\n props: {\n variant: 'text'\n },\n style: {\n marginTop: 0,\n marginBottom: 0,\n height: 'auto',\n transformOrigin: '0 55%',\n transform: 'scale(1, 0.60)',\n borderRadius: `${radiusValue}${radiusUnit}/${Math.round(radiusValue / 0.6 * 10) / 10}${radiusUnit}`,\n '&:empty:before': {\n content: '\"\\\\00a0\"'\n }\n }\n }, {\n props: {\n variant: 'circular'\n },\n style: {\n borderRadius: '50%'\n }\n }, {\n props: {\n variant: 'rounded'\n },\n style: {\n borderRadius: (theme.vars || theme).shape.borderRadius\n }\n }, {\n props: ({\n ownerState\n }) => ownerState.hasChildren,\n style: {\n '& > *': {\n visibility: 'hidden'\n }\n }\n }, {\n props: ({\n ownerState\n }) => ownerState.hasChildren && !ownerState.width,\n style: {\n maxWidth: 'fit-content'\n }\n }, {\n props: ({\n ownerState\n }) => ownerState.hasChildren && !ownerState.height,\n style: {\n height: 'auto'\n }\n }, {\n props: {\n animation: 'pulse'\n },\n style: pulseAnimation || {\n animation: `${pulseKeyframe} 2s ease-in-out 0.5s infinite`\n }\n }, {\n props: {\n animation: 'wave'\n },\n style: {\n position: 'relative',\n overflow: 'hidden',\n /* Fix bug in Safari https://bugs.webkit.org/show_bug.cgi?id=68196 */\n WebkitMaskImage: '-webkit-radial-gradient(white, black)',\n '&::after': {\n background: `linear-gradient(\n 90deg,\n transparent,\n ${(theme.vars || theme).palette.action.hover},\n transparent\n )`,\n content: '\"\"',\n position: 'absolute',\n transform: 'translateX(-100%)' /* Avoid flash during server-side hydration */,\n bottom: 0,\n left: 0,\n right: 0,\n top: 0\n }\n }\n }, {\n props: {\n animation: 'wave'\n },\n style: {\n '&::after': waveAnimation || {\n animation: `${waveKeyframe} 2s linear 0.5s infinite`\n }\n }\n }]\n };\n}));\nconst Skeleton = /*#__PURE__*/React.forwardRef(function Skeleton(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiSkeleton'\n });\n const {\n animation = 'pulse',\n className,\n component = 'span',\n height,\n style,\n variant = 'text',\n width,\n ...other\n } = props;\n const ownerState = {\n ...props,\n animation,\n component,\n variant,\n hasChildren: Boolean(other.children)\n };\n const classes = useUtilityClasses(ownerState);\n return /*#__PURE__*/_jsx(SkeletonRoot, {\n as: component,\n ref: ref,\n className: clsx(classes.root, className),\n ownerState: ownerState,\n ...other,\n style: {\n width,\n height,\n ...style\n }\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Skeleton.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * The animation.\n * If `false` the animation effect is disabled.\n * @default 'pulse'\n */\n animation: PropTypes.oneOf(['pulse', 'wave', false]),\n /**\n * Optional children to infer width and height from.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * Height of the skeleton.\n * Useful when you don't want to adapt the skeleton to a text element but for instance a card.\n */\n height: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n /**\n * @ignore\n */\n style: PropTypes.object,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * The type of content that will be rendered.\n * @default 'text'\n */\n variant: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['circular', 'rectangular', 'rounded', 'text']), PropTypes.string]),\n /**\n * Width of the skeleton.\n * Useful when the skeleton is inside an inline element with no width of its own.\n */\n width: PropTypes.oneOfType([PropTypes.number, PropTypes.string])\n} : void 0;\nexport default Skeleton;","import { jsx as _jsx } from \"@emotion/react/jsx-runtime\";\nexport function CheckmarkIcon(props) {\n return (_jsx(\"svg\", Object.assign({ \"aria-hidden\": true, width: '21', height: '16', viewBox: '0 0 21 16', fill: 'none', xmlns: 'http://www.w3.org/2000/svg', color: '#3C5164' }, props, { children: _jsx(\"path\", { fillRule: 'evenodd', clipRule: 'evenodd', d: 'M19.3631 1.20883C20.07 1.73902 20.2133 2.74189 19.6831 3.44881L10.0832 16.2487C9.8127 16.6094 9.40263 16.8392 8.95383 16.8816C8.50504 16.9241 8.05916 16.7752 7.72586 16.4717L1.3259 10.6431C0.672583 10.0482 0.625295 9.0362 1.22028 8.38288C1.81527 7.72956 2.82722 7.68227 3.48054 8.27726L8.57922 12.9207L17.1231 1.52882C17.6533 0.821903 18.6562 0.678635 19.3631 1.20883Z', fill: 'currentColor' }) })));\n}\n","import { jsx as _jsx } from \"@emotion/react/jsx-runtime\";\nexport function CloseIcon(props) {\n return (_jsx(\"svg\", Object.assign({ \"aria-hidden\": true, width: '20', height: '20', viewBox: '0 0 20 20', fill: 'none', xmlns: 'http://www.w3.org/2000/svg' }, props, { children: _jsx(\"path\", { d: 'M3.78033 2.71967C3.48744 2.42678 3.01256 2.42678 2.71967 2.71967C2.42678 3.01256 2.42678 3.48744 2.71967 3.78033L8.93934 10L2.71967 16.2197C2.42678 16.5126 2.42678 16.9874 2.71967 17.2803C3.01256 17.5732 3.48744 17.5732 3.78033 17.2803L10 11.0607L16.2197 17.2803C16.5126 17.5732 16.9874 17.5732 17.2803 17.2803C17.5732 16.9874 17.5732 16.5126 17.2803 16.2197L11.0607 10L17.2803 3.78033C17.5732 3.48744 17.5732 3.01256 17.2803 2.71967C16.9874 2.42678 16.5126 2.42678 16.2197 2.71967L10 8.93934L3.78033 2.71967Z', fill: '#3C5164' }) })));\n}\n","import { jsx as _jsx } from \"@emotion/react/jsx-runtime\";\nexport function ExpandIcon(props) {\n return (_jsx(\"svg\", Object.assign({ \"aria-hidden\": true, width: '20', height: '20', viewBox: '0 0 20 20', fill: 'none', xmlns: 'http://www.w3.org/2000/svg', color: '#3C5164' }, props, { children: _jsx(\"path\", { d: 'M3.56444 5.50613C3.29168 5.19441 2.81786 5.16282 2.50613 5.43558C2.19441 5.70834 2.16282 6.18216 2.43558 6.49389L9.43553 14.4939C9.57794 14.6566 9.78369 14.75 9.99996 14.75C10.2162 14.75 10.422 14.6567 10.5644 14.4939L17.5644 6.49389C17.8372 6.18216 17.8056 5.70834 17.4939 5.43558C17.1822 5.16282 16.7083 5.1944 16.4356 5.50613L9.99997 12.8611L3.56444 5.50613Z', fill: 'currentColor' }) })));\n}\n","import { jsx as _jsx, jsxs as _jsxs } from \"@emotion/react/jsx-runtime\";\nexport function NewTabIcon(props) {\n return (_jsxs(\"svg\", Object.assign({ \"aria-hidden\": true, width: '20', height: '20', viewBox: '0 0 20 20', fill: 'none', xmlns: 'http://www.w3.org/2000/svg' }, props, { children: [_jsx(\"path\", { d: 'M13.55 1.87498H17.0643L6.5113 12.428C6.2184 12.7209 6.2184 13.1957 6.51129 13.4886C6.80419 13.7815 7.27906 13.7815 7.57195 13.4886L18.125 2.93562V6.44999C18.125 6.8642 18.4608 7.19999 18.875 7.19999C19.2892 7.19999 19.625 6.86397 19.625 6.44975V1.12498C19.625 0.946165 19.5883 0.784042 19.4506 0.625237C19.3964 0.562735 19.3259 0.492949 19.2223 0.443448C19.1193 0.394248 19.0049 0.374985 18.875 0.374985H13.55C13.1358 0.374985 12.8 0.710771 12.8 1.12498C12.8 1.5392 13.1358 1.87498 13.55 1.87498Z', fill: '#3C5164' }), _jsx(\"path\", { d: 'M2.30833 3.925C1.24057 3.925 0.375 4.7906 0.375 5.85835V17.6917C0.375 18.7594 1.24057 19.625 2.30833 19.625H14.1417C15.2094 19.625 16.075 18.7594 16.075 17.6917V10.5917C16.075 10.1775 15.7392 9.8417 15.325 9.8417C14.9108 9.8417 14.575 10.1775 14.575 10.5917V17.6917C14.575 17.931 14.381 18.125 14.1417 18.125H2.30833C2.06901 18.125 1.875 17.931 1.875 17.6917V5.85835C1.875 5.61901 2.06901 5.42501 2.30833 5.42501H9.40831C9.82252 5.42501 10.1583 5.08922 10.1583 4.67501C10.1583 4.26079 9.82252 3.925 9.40831 3.925H2.30833Z', fill: '#3C5164' })] })));\n}\n","import * as React from 'react'\nexport * from '@tanstack/table-core'\n\nimport {\n TableOptions,\n TableOptionsResolved,\n RowData,\n createTable,\n} from '@tanstack/table-core'\n\nexport type Renderable = React.ReactNode | React.ComponentType\n\n//\n\n/**\n * If rendering headers, cells, or footers with custom markup, use flexRender instead of `cell.getValue()` or `cell.renderValue()`.\n */\nexport function flexRender(\n Comp: Renderable,\n props: TProps\n): React.ReactNode | React.JSX.Element {\n return !Comp ? null : isReactComponent(Comp) ? (\n \n ) : (\n Comp\n )\n}\n\nfunction isReactComponent(\n component: unknown\n): component is React.ComponentType {\n return (\n isClassComponent(component) ||\n typeof component === 'function' ||\n isExoticComponent(component)\n )\n}\n\nfunction isClassComponent(component: any) {\n return (\n typeof component === 'function' &&\n (() => {\n const proto = Object.getPrototypeOf(component)\n return proto.prototype && proto.prototype.isReactComponent\n })()\n )\n}\n\nfunction isExoticComponent(component: any) {\n return (\n typeof component === 'object' &&\n typeof component.$$typeof === 'symbol' &&\n ['react.memo', 'react.forward_ref'].includes(component.$$typeof.description)\n )\n}\n\nexport function useReactTable(\n options: TableOptions\n) {\n // Compose in the generic options to the user options\n const resolvedOptions: TableOptionsResolved = {\n state: {}, // Dummy state\n onStateChange: () => {}, // noop\n renderFallbackValue: null,\n ...options,\n }\n\n // Create a new table and store it in state\n const [tableRef] = React.useState(() => ({\n current: createTable(resolvedOptions),\n }))\n\n // By default, manage table state here using the table's initial state\n const [state, setState] = React.useState(() => tableRef.current.initialState)\n\n // Compose the default state above with any user state. This will allow the user\n // to only control a subset of the state if desired.\n tableRef.current.setOptions(prev => ({\n ...prev,\n ...options,\n state: {\n ...state,\n ...options.state,\n },\n // Similarly, we'll maintain both our internal state and any user-provided\n // state.\n onStateChange: updater => {\n setState(updater)\n options.onStateChange?.(updater)\n },\n }))\n\n return tableRef.current\n}\n","import { TableOptionsResolved, TableState, Updater } from './types'\n\nexport type PartialKeys = Omit & Partial>\nexport type RequiredKeys = Omit &\n Required>\nexport type Overwrite = Omit<\n T,\n keyof U\n> &\n U\n\nexport type UnionToIntersection = (\n T extends any ? (x: T) => any : never\n) extends (x: infer R) => any\n ? R\n : never\n\nexport type IsAny = 1 extends 0 & T ? Y : N\nexport type IsKnown = unknown extends T ? N : Y\n\ntype ComputeRange<\n N extends number,\n Result extends Array = [],\n> = Result['length'] extends N\n ? Result\n : ComputeRange\ntype Index40 = ComputeRange<40>[number]\n\n// Is this type a tuple?\ntype IsTuple = T extends readonly any[] & { length: infer Length }\n ? Length extends Index40\n ? T\n : never\n : never\n\n// If this type is a tuple, what indices are allowed?\ntype AllowedIndexes<\n Tuple extends ReadonlyArray,\n Keys extends number = never,\n> = Tuple extends readonly []\n ? Keys\n : Tuple extends readonly [infer _, ...infer Tail]\n ? AllowedIndexes\n : Keys\n\nexport type DeepKeys = TDepth['length'] extends 5\n ? never\n : unknown extends T\n ? string\n : T extends readonly any[] & IsTuple\n ? AllowedIndexes | DeepKeysPrefix, TDepth>\n : T extends any[]\n ? DeepKeys\n : T extends Date\n ? never\n : T extends object\n ? (keyof T & string) | DeepKeysPrefix\n : never\n\ntype DeepKeysPrefix<\n T,\n TPrefix,\n TDepth extends any[],\n> = TPrefix extends keyof T & (number | string)\n ? `${TPrefix}.${DeepKeys & string}`\n : never\n\nexport type DeepValue =\n T extends Record\n ? TProp extends `${infer TBranch}.${infer TDeepProp}`\n ? DeepValue\n : T[TProp & string]\n : never\n\nexport type NoInfer = [T][T extends any ? 0 : never]\n\nexport type Getter = () => NoInfer\n\n///\n\nexport function functionalUpdate(updater: Updater, input: T): T {\n return typeof updater === 'function'\n ? (updater as (input: T) => T)(input)\n : updater\n}\n\nexport function noop() {\n //\n}\n\nexport function makeStateUpdater(\n key: K,\n instance: unknown\n) {\n return (updater: Updater) => {\n ;(instance as any).setState((old: TTableState) => {\n return {\n ...old,\n [key]: functionalUpdate(updater, (old as any)[key]),\n }\n })\n }\n}\n\ntype AnyFunction = (...args: any) => any\n\nexport function isFunction(d: any): d is T {\n return d instanceof Function\n}\n\nexport function isNumberArray(d: any): d is number[] {\n return Array.isArray(d) && d.every(val => typeof val === 'number')\n}\n\nexport function flattenBy(\n arr: TNode[],\n getChildren: (item: TNode) => TNode[]\n) {\n const flat: TNode[] = []\n\n const recurse = (subArr: TNode[]) => {\n subArr.forEach(item => {\n flat.push(item)\n const children = getChildren(item)\n if (children?.length) {\n recurse(children)\n }\n })\n }\n\n recurse(arr)\n\n return flat\n}\n\nexport function memo(\n getDeps: (depArgs?: TDepArgs) => [...TDeps],\n fn: (...args: NoInfer<[...TDeps]>) => TResult,\n opts: {\n key: any\n debug?: () => any\n onChange?: (result: TResult) => void\n }\n): (depArgs?: TDepArgs) => TResult {\n let deps: any[] = []\n let result: TResult | undefined\n\n return depArgs => {\n let depTime: number\n if (opts.key && opts.debug) depTime = Date.now()\n\n const newDeps = getDeps(depArgs)\n\n const depsChanged =\n newDeps.length !== deps.length ||\n newDeps.some((dep: any, index: number) => deps[index] !== dep)\n\n if (!depsChanged) {\n return result!\n }\n\n deps = newDeps\n\n let resultTime: number\n if (opts.key && opts.debug) resultTime = Date.now()\n\n result = fn(...newDeps)\n opts?.onChange?.(result)\n\n if (opts.key && opts.debug) {\n if (opts?.debug()) {\n const depEndTime = Math.round((Date.now() - depTime!) * 100) / 100\n const resultEndTime = Math.round((Date.now() - resultTime!) * 100) / 100\n const resultFpsPercentage = resultEndTime / 16\n\n const pad = (str: number | string, num: number) => {\n str = String(str)\n while (str.length < num) {\n str = ' ' + str\n }\n return str\n }\n\n console.info(\n `%c⏱ ${pad(resultEndTime, 5)} /${pad(depEndTime, 5)} ms`,\n `\n font-size: .6rem;\n font-weight: bold;\n color: hsl(${Math.max(\n 0,\n Math.min(120 - 120 * resultFpsPercentage, 120)\n )}deg 100% 31%);`,\n opts?.key\n )\n }\n }\n\n return result!\n }\n}\n\nexport function getMemoOptions(\n tableOptions: Partial>,\n debugLevel:\n | 'debugAll'\n | 'debugCells'\n | 'debugTable'\n | 'debugColumns'\n | 'debugRows'\n | 'debugHeaders',\n key: string,\n onChange?: (result: any) => void\n) {\n return {\n debug: () => tableOptions?.debugAll ?? tableOptions[debugLevel],\n key: process.env.NODE_ENV === 'development' && key,\n onChange,\n }\n}\n","import {\n RowData,\n Column,\n Header,\n HeaderGroup,\n Table,\n TableFeature,\n} from '../types'\nimport { getMemoOptions, memo } from '../utils'\n\nconst debug = 'debugHeaders'\n\nexport interface CoreHeaderGroup {\n depth: number\n headers: Header[]\n id: string\n}\n\nexport interface HeaderContext {\n /**\n * An instance of a column.\n */\n column: Column\n /**\n * An instance of a header.\n */\n header: Header\n /**\n * The table instance.\n */\n table: Table\n}\n\nexport interface CoreHeader {\n /**\n * The col-span for the header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#colspan)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n colSpan: number\n /**\n * The header's associated column object.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#column)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n column: Column\n /**\n * The depth of the header, zero-indexed based.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#depth)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n depth: number\n /**\n * Returns the rendering context (or props) for column-based components like headers, footers and filters.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#getcontext)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getContext: () => HeaderContext\n /**\n * Returns the leaf headers hierarchically nested under this header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#getleafheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getLeafHeaders: () => Header[]\n /**\n * The header's associated header group object.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#headergroup)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n headerGroup: HeaderGroup\n /**\n * The unique identifier for the header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#id)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n id: string\n /**\n * The index for the header within the header group.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#index)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n index: number\n /**\n * A boolean denoting if the header is a placeholder header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#isplaceholder)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n isPlaceholder: boolean\n /**\n * If the header is a placeholder header, this will be a unique header ID that does not conflict with any other headers across the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#placeholderid)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n placeholderId?: string\n /**\n * The row-span for the header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#rowspan)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n rowSpan: number\n /**\n * The header's hierarchical sub/child headers. Will be empty if the header's associated column is a leaf-column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/header#subheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n subHeaders: Header[]\n}\n\nexport interface HeadersInstance {\n /**\n * Returns all header groups for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getheadergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getHeaderGroups: () => HeaderGroup[]\n /**\n * If pinning, returns the header groups for the left pinned columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getleftheadergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getLeftHeaderGroups: () => HeaderGroup[]\n /**\n * If pinning, returns the header groups for columns that are not pinned.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getcenterheadergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getCenterHeaderGroups: () => HeaderGroup[]\n /**\n * If pinning, returns the header groups for the right pinned columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getrightheadergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getRightHeaderGroups: () => HeaderGroup[]\n\n /**\n * Returns the footer groups for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getfootergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getFooterGroups: () => HeaderGroup[]\n /**\n * If pinning, returns the footer groups for the left pinned columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getleftfootergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getLeftFooterGroups: () => HeaderGroup[]\n /**\n * If pinning, returns the footer groups for columns that are not pinned.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getcenterfootergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getCenterFooterGroups: () => HeaderGroup[]\n /**\n * If pinning, returns the footer groups for the right pinned columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getrightfootergroups)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getRightFooterGroups: () => HeaderGroup[]\n\n /**\n * Returns headers for all columns in the table, including parent headers.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getflatheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getFlatHeaders: () => Header[]\n /**\n * If pinning, returns headers for all left pinned columns in the table, including parent headers.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getleftflatheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getLeftFlatHeaders: () => Header[]\n /**\n * If pinning, returns headers for all columns that are not pinned, including parent headers.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getcenterflatheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getCenterFlatHeaders: () => Header[]\n /**\n * If pinning, returns headers for all right pinned columns in the table, including parent headers.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getrightflatheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getRightFlatHeaders: () => Header[]\n\n /**\n * Returns headers for all leaf columns in the table, (not including parent headers).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getleafheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getLeafHeaders: () => Header[]\n /**\n * If pinning, returns headers for all left pinned leaf columns in the table, (not including parent headers).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getleftleafheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getLeftLeafHeaders: () => Header[]\n /**\n * If pinning, returns headers for all columns that are not pinned, (not including parent headers).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getcenterleafheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getCenterLeafHeaders: () => Header[]\n /**\n * If pinning, returns headers for all right pinned leaf columns in the table, (not including parent headers).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/headers#getrightleafheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/headers)\n */\n getRightLeafHeaders: () => Header[]\n}\n\n//\n\nfunction createHeader(\n table: Table,\n column: Column,\n options: {\n id?: string\n isPlaceholder?: boolean\n placeholderId?: string\n index: number\n depth: number\n }\n): Header {\n const id = options.id ?? column.id\n\n let header: CoreHeader = {\n id,\n column,\n index: options.index,\n isPlaceholder: !!options.isPlaceholder,\n placeholderId: options.placeholderId,\n depth: options.depth,\n subHeaders: [],\n colSpan: 0,\n rowSpan: 0,\n headerGroup: null!,\n getLeafHeaders: (): Header[] => {\n const leafHeaders: Header[] = []\n\n const recurseHeader = (h: CoreHeader) => {\n if (h.subHeaders && h.subHeaders.length) {\n h.subHeaders.map(recurseHeader)\n }\n leafHeaders.push(h as Header)\n }\n\n recurseHeader(header)\n\n return leafHeaders\n },\n getContext: () => ({\n table,\n header: header as Header,\n column,\n }),\n }\n\n table._features.forEach(feature => {\n feature.createHeader?.(header as Header, table)\n })\n\n return header as Header\n}\n\nexport const Headers: TableFeature = {\n createTable: (table: Table): void => {\n // Header Groups\n\n table.getHeaderGroups = memo(\n () => [\n table.getAllColumns(),\n table.getVisibleLeafColumns(),\n table.getState().columnPinning.left,\n table.getState().columnPinning.right,\n ],\n (allColumns, leafColumns, left, right) => {\n const leftColumns =\n left\n ?.map(columnId => leafColumns.find(d => d.id === columnId)!)\n .filter(Boolean) ?? []\n\n const rightColumns =\n right\n ?.map(columnId => leafColumns.find(d => d.id === columnId)!)\n .filter(Boolean) ?? []\n\n const centerColumns = leafColumns.filter(\n column => !left?.includes(column.id) && !right?.includes(column.id)\n )\n\n const headerGroups = buildHeaderGroups(\n allColumns,\n [...leftColumns, ...centerColumns, ...rightColumns],\n table\n )\n\n return headerGroups\n },\n getMemoOptions(table.options, debug, 'getHeaderGroups')\n )\n\n table.getCenterHeaderGroups = memo(\n () => [\n table.getAllColumns(),\n table.getVisibleLeafColumns(),\n table.getState().columnPinning.left,\n table.getState().columnPinning.right,\n ],\n (allColumns, leafColumns, left, right) => {\n leafColumns = leafColumns.filter(\n column => !left?.includes(column.id) && !right?.includes(column.id)\n )\n return buildHeaderGroups(allColumns, leafColumns, table, 'center')\n },\n getMemoOptions(table.options, debug, 'getCenterHeaderGroups')\n )\n\n table.getLeftHeaderGroups = memo(\n () => [\n table.getAllColumns(),\n table.getVisibleLeafColumns(),\n table.getState().columnPinning.left,\n ],\n (allColumns, leafColumns, left) => {\n const orderedLeafColumns =\n left\n ?.map(columnId => leafColumns.find(d => d.id === columnId)!)\n .filter(Boolean) ?? []\n\n return buildHeaderGroups(allColumns, orderedLeafColumns, table, 'left')\n },\n getMemoOptions(table.options, debug, 'getLeftHeaderGroups')\n )\n\n table.getRightHeaderGroups = memo(\n () => [\n table.getAllColumns(),\n table.getVisibleLeafColumns(),\n table.getState().columnPinning.right,\n ],\n (allColumns, leafColumns, right) => {\n const orderedLeafColumns =\n right\n ?.map(columnId => leafColumns.find(d => d.id === columnId)!)\n .filter(Boolean) ?? []\n\n return buildHeaderGroups(allColumns, orderedLeafColumns, table, 'right')\n },\n getMemoOptions(table.options, debug, 'getRightHeaderGroups')\n )\n\n // Footer Groups\n\n table.getFooterGroups = memo(\n () => [table.getHeaderGroups()],\n headerGroups => {\n return [...headerGroups].reverse()\n },\n getMemoOptions(table.options, debug, 'getFooterGroups')\n )\n\n table.getLeftFooterGroups = memo(\n () => [table.getLeftHeaderGroups()],\n headerGroups => {\n return [...headerGroups].reverse()\n },\n getMemoOptions(table.options, debug, 'getLeftFooterGroups')\n )\n\n table.getCenterFooterGroups = memo(\n () => [table.getCenterHeaderGroups()],\n headerGroups => {\n return [...headerGroups].reverse()\n },\n getMemoOptions(table.options, debug, 'getCenterFooterGroups')\n )\n\n table.getRightFooterGroups = memo(\n () => [table.getRightHeaderGroups()],\n headerGroups => {\n return [...headerGroups].reverse()\n },\n getMemoOptions(table.options, debug, 'getRightFooterGroups')\n )\n\n // Flat Headers\n\n table.getFlatHeaders = memo(\n () => [table.getHeaderGroups()],\n headerGroups => {\n return headerGroups\n .map(headerGroup => {\n return headerGroup.headers\n })\n .flat()\n },\n getMemoOptions(table.options, debug, 'getFlatHeaders')\n )\n\n table.getLeftFlatHeaders = memo(\n () => [table.getLeftHeaderGroups()],\n left => {\n return left\n .map(headerGroup => {\n return headerGroup.headers\n })\n .flat()\n },\n getMemoOptions(table.options, debug, 'getLeftFlatHeaders')\n )\n\n table.getCenterFlatHeaders = memo(\n () => [table.getCenterHeaderGroups()],\n left => {\n return left\n .map(headerGroup => {\n return headerGroup.headers\n })\n .flat()\n },\n getMemoOptions(table.options, debug, 'getCenterFlatHeaders')\n )\n\n table.getRightFlatHeaders = memo(\n () => [table.getRightHeaderGroups()],\n left => {\n return left\n .map(headerGroup => {\n return headerGroup.headers\n })\n .flat()\n },\n getMemoOptions(table.options, debug, 'getRightFlatHeaders')\n )\n\n // Leaf Headers\n\n table.getCenterLeafHeaders = memo(\n () => [table.getCenterFlatHeaders()],\n flatHeaders => {\n return flatHeaders.filter(header => !header.subHeaders?.length)\n },\n getMemoOptions(table.options, debug, 'getCenterLeafHeaders')\n )\n\n table.getLeftLeafHeaders = memo(\n () => [table.getLeftFlatHeaders()],\n flatHeaders => {\n return flatHeaders.filter(header => !header.subHeaders?.length)\n },\n getMemoOptions(table.options, debug, 'getLeftLeafHeaders')\n )\n\n table.getRightLeafHeaders = memo(\n () => [table.getRightFlatHeaders()],\n flatHeaders => {\n return flatHeaders.filter(header => !header.subHeaders?.length)\n },\n getMemoOptions(table.options, debug, 'getRightLeafHeaders')\n )\n\n table.getLeafHeaders = memo(\n () => [\n table.getLeftHeaderGroups(),\n table.getCenterHeaderGroups(),\n table.getRightHeaderGroups(),\n ],\n (left, center, right) => {\n return [\n ...(left[0]?.headers ?? []),\n ...(center[0]?.headers ?? []),\n ...(right[0]?.headers ?? []),\n ]\n .map(header => {\n return header.getLeafHeaders()\n })\n .flat()\n },\n getMemoOptions(table.options, debug, 'getLeafHeaders')\n )\n },\n}\n\nexport function buildHeaderGroups(\n allColumns: Column[],\n columnsToGroup: Column[],\n table: Table,\n headerFamily?: 'center' | 'left' | 'right'\n) {\n // Find the max depth of the columns:\n // build the leaf column row\n // build each buffer row going up\n // placeholder for non-existent level\n // real column for existing level\n\n let maxDepth = 0\n\n const findMaxDepth = (columns: Column[], depth = 1) => {\n maxDepth = Math.max(maxDepth, depth)\n\n columns\n .filter(column => column.getIsVisible())\n .forEach(column => {\n if (column.columns?.length) {\n findMaxDepth(column.columns, depth + 1)\n }\n }, 0)\n }\n\n findMaxDepth(allColumns)\n\n let headerGroups: HeaderGroup[] = []\n\n const createHeaderGroup = (\n headersToGroup: Header[],\n depth: number\n ) => {\n // The header group we are creating\n const headerGroup: HeaderGroup = {\n depth,\n id: [headerFamily, `${depth}`].filter(Boolean).join('_'),\n headers: [],\n }\n\n // The parent columns we're going to scan next\n const pendingParentHeaders: Header[] = []\n\n // Scan each column for parents\n headersToGroup.forEach(headerToGroup => {\n // What is the latest (last) parent column?\n\n const latestPendingParentHeader = [...pendingParentHeaders].reverse()[0]\n\n const isLeafHeader = headerToGroup.column.depth === headerGroup.depth\n\n let column: Column\n let isPlaceholder = false\n\n if (isLeafHeader && headerToGroup.column.parent) {\n // The parent header is new\n column = headerToGroup.column.parent\n } else {\n // The parent header is repeated\n column = headerToGroup.column\n isPlaceholder = true\n }\n\n if (\n latestPendingParentHeader &&\n latestPendingParentHeader?.column === column\n ) {\n // This column is repeated. Add it as a sub header to the next batch\n latestPendingParentHeader.subHeaders.push(headerToGroup)\n } else {\n // This is a new header. Let's create it\n const header = createHeader(table, column, {\n id: [headerFamily, depth, column.id, headerToGroup?.id]\n .filter(Boolean)\n .join('_'),\n isPlaceholder,\n placeholderId: isPlaceholder\n ? `${pendingParentHeaders.filter(d => d.column === column).length}`\n : undefined,\n depth,\n index: pendingParentHeaders.length,\n })\n\n // Add the headerToGroup as a subHeader of the new header\n header.subHeaders.push(headerToGroup)\n // Add the new header to the pendingParentHeaders to get grouped\n // in the next batch\n pendingParentHeaders.push(header)\n }\n\n headerGroup.headers.push(headerToGroup)\n headerToGroup.headerGroup = headerGroup\n })\n\n headerGroups.push(headerGroup)\n\n if (depth > 0) {\n createHeaderGroup(pendingParentHeaders, depth - 1)\n }\n }\n\n const bottomHeaders = columnsToGroup.map((column, index) =>\n createHeader(table, column, {\n depth: maxDepth,\n index,\n })\n )\n\n createHeaderGroup(bottomHeaders, maxDepth - 1)\n\n headerGroups.reverse()\n\n // headerGroups = headerGroups.filter(headerGroup => {\n // return !headerGroup.headers.every(header => header.isPlaceholder)\n // })\n\n const recurseHeadersForSpans = (\n headers: Header[]\n ): { colSpan: number; rowSpan: number }[] => {\n const filteredHeaders = headers.filter(header =>\n header.column.getIsVisible()\n )\n\n return filteredHeaders.map(header => {\n let colSpan = 0\n let rowSpan = 0\n let childRowSpans = [0]\n\n if (header.subHeaders && header.subHeaders.length) {\n childRowSpans = []\n\n recurseHeadersForSpans(header.subHeaders).forEach(\n ({ colSpan: childColSpan, rowSpan: childRowSpan }) => {\n colSpan += childColSpan\n childRowSpans.push(childRowSpan)\n }\n )\n } else {\n colSpan = 1\n }\n\n const minChildRowSpan = Math.min(...childRowSpans)\n rowSpan = rowSpan + minChildRowSpan\n\n header.colSpan = colSpan\n header.rowSpan = rowSpan\n\n return { colSpan, rowSpan }\n })\n }\n\n recurseHeadersForSpans(headerGroups[0]?.headers ?? [])\n\n return headerGroups\n}\n","import { RowData, Cell, Row, Table } from '../types'\nimport { flattenBy, getMemoOptions, memo } from '../utils'\nimport { createCell } from './cell'\n\nexport interface CoreRow {\n _getAllCellsByColumnId: () => Record>\n _uniqueValuesCache: Record\n _valuesCache: Record\n /**\n * The depth of the row (if nested or grouped) relative to the root row array.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#depth)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n depth: number\n /**\n * Returns all of the cells for the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#getallcells)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n getAllCells: () => Cell[]\n /**\n * Returns the leaf rows for the row, not including any parent rows.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#getleafrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n getLeafRows: () => Row[]\n /**\n * Returns the parent row for the row, if it exists.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#getparentrow)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n getParentRow: () => Row | undefined\n /**\n * Returns the parent rows for the row, all the way up to a root row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#getparentrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n getParentRows: () => Row[]\n /**\n * Returns a unique array of values from the row for a given columnId.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#getuniquevalues)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n getUniqueValues: (columnId: string) => TValue[]\n /**\n * Returns the value from the row for a given columnId.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#getvalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n getValue: (columnId: string) => TValue\n /**\n * The resolved unique identifier for the row resolved via the `options.getRowId` option. Defaults to the row's index (or relative index if it is a subRow).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#id)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n id: string\n /**\n * The index of the row within its parent array (or the root data array).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#index)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n index: number\n /**\n * The original row object provided to the table. If the row is a grouped row, the original row object will be the first original in the group.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#original)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n original: TData\n /**\n * An array of the original subRows as returned by the `options.getSubRows` option.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#originalsubrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n originalSubRows?: TData[]\n /**\n * If nested, this row's parent row id.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#parentid)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n parentId?: string\n /**\n * Renders the value for the row in a given columnId the same as `getValue`, but will return the `renderFallbackValue` if no value is found.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#rendervalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n renderValue: (columnId: string) => TValue\n /**\n * An array of subRows for the row as returned and created by the `options.getSubRows` option.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/row#subrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/rows)\n */\n subRows: Row[]\n}\n\nexport const createRow = (\n table: Table,\n id: string,\n original: TData,\n rowIndex: number,\n depth: number,\n subRows?: Row[],\n parentId?: string\n): Row => {\n let row: CoreRow = {\n id,\n index: rowIndex,\n original,\n depth,\n parentId,\n _valuesCache: {},\n _uniqueValuesCache: {},\n getValue: columnId => {\n if (row._valuesCache.hasOwnProperty(columnId)) {\n return row._valuesCache[columnId]\n }\n\n const column = table.getColumn(columnId)\n\n if (!column?.accessorFn) {\n return undefined\n }\n\n row._valuesCache[columnId] = column.accessorFn(\n row.original as TData,\n rowIndex\n )\n\n return row._valuesCache[columnId] as any\n },\n getUniqueValues: columnId => {\n if (row._uniqueValuesCache.hasOwnProperty(columnId)) {\n return row._uniqueValuesCache[columnId]\n }\n\n const column = table.getColumn(columnId)\n\n if (!column?.accessorFn) {\n return undefined\n }\n\n if (!column.columnDef.getUniqueValues) {\n row._uniqueValuesCache[columnId] = [row.getValue(columnId)]\n return row._uniqueValuesCache[columnId]\n }\n\n row._uniqueValuesCache[columnId] = column.columnDef.getUniqueValues(\n row.original as TData,\n rowIndex\n )\n\n return row._uniqueValuesCache[columnId] as any\n },\n renderValue: columnId =>\n row.getValue(columnId) ?? table.options.renderFallbackValue,\n subRows: subRows ?? [],\n getLeafRows: () => flattenBy(row.subRows, d => d.subRows),\n getParentRow: () =>\n row.parentId ? table.getRow(row.parentId, true) : undefined,\n getParentRows: () => {\n let parentRows: Row[] = []\n let currentRow = row\n while (true) {\n const parentRow = currentRow.getParentRow()\n if (!parentRow) break\n parentRows.push(parentRow)\n currentRow = parentRow\n }\n return parentRows.reverse()\n },\n getAllCells: memo(\n () => [table.getAllLeafColumns()],\n leafColumns => {\n return leafColumns.map(column => {\n return createCell(table, row as Row, column, column.id)\n })\n },\n getMemoOptions(table.options, 'debugRows', 'getAllCells')\n ),\n\n _getAllCellsByColumnId: memo(\n () => [row.getAllCells()],\n allCells => {\n return allCells.reduce(\n (acc, cell) => {\n acc[cell.column.id] = cell\n return acc\n },\n {} as Record>\n )\n },\n getMemoOptions(table.options, 'debugRows', 'getAllCellsByColumnId')\n ),\n }\n\n for (let i = 0; i < table._features.length; i++) {\n const feature = table._features[i]\n feature?.createRow?.(row as Row, table)\n }\n\n return row as Row\n}\n","import { RowData, Cell, Column, Row, Table } from '../types'\nimport { Getter, getMemoOptions, memo } from '../utils'\n\nexport interface CellContext {\n cell: Cell\n column: Column\n getValue: Getter\n renderValue: Getter\n row: Row\n table: Table\n}\n\nexport interface CoreCell {\n /**\n * The associated Column object for the cell.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/cell#column)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/cells)\n */\n column: Column\n /**\n * Returns the rendering context (or props) for cell-based components like cells and aggregated cells. Use these props with your framework's `flexRender` utility to render these using the template of your choice:\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/cell#getcontext)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/cells)\n */\n getContext: () => CellContext\n /**\n * Returns the value for the cell, accessed via the associated column's accessor key or accessor function.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/cell#getvalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/cells)\n */\n getValue: CellContext['getValue']\n /**\n * The unique ID for the cell across the entire table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/cell#id)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/cells)\n */\n id: string\n /**\n * Renders the value for a cell the same as `getValue`, but will return the `renderFallbackValue` if no value is found.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/cell#rendervalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/cells)\n */\n renderValue: CellContext['renderValue']\n /**\n * The associated Row object for the cell.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/cell#row)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/cells)\n */\n row: Row\n}\n\nexport function createCell(\n table: Table,\n row: Row,\n column: Column,\n columnId: string\n): Cell {\n const getRenderValue = () =>\n cell.getValue() ?? table.options.renderFallbackValue\n\n const cell: CoreCell = {\n id: `${row.id}_${column.id}`,\n row,\n column,\n getValue: () => row.getValue(columnId),\n renderValue: getRenderValue,\n getContext: memo(\n () => [table, column, row, cell],\n (table, column, row, cell) => ({\n table,\n column,\n row,\n cell: cell as Cell,\n getValue: cell.getValue,\n renderValue: cell.renderValue,\n }),\n getMemoOptions(table.options, 'debugCells', 'cell.getContext')\n ),\n }\n\n table._features.forEach(feature => {\n feature.createCell?.(\n cell as Cell,\n column,\n row as Row,\n table\n )\n }, {})\n\n return cell as Cell\n}\n","import { RowModel } from '..'\nimport { Column, RowData, Table, TableFeature } from '../types'\n\nexport interface FacetedColumn {\n _getFacetedMinMaxValues?: () => undefined | [number, number]\n _getFacetedRowModel?: () => RowModel\n _getFacetedUniqueValues?: () => Map\n /**\n * A function that **computes and returns** a min/max tuple derived from `column.getFacetedRowModel`. Useful for displaying faceted result values.\n * > ⚠️ Requires that you pass a valid `getFacetedMinMaxValues` function to `options.getFacetedMinMaxValues`. A default implementation is provided via the exported `getFacetedMinMaxValues` function.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-faceting#getfacetedminmaxvalues)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-faceting)\n */\n getFacetedMinMaxValues: () => undefined | [number, number]\n /**\n * Returns the row model with all other column filters applied, excluding its own filter. Useful for displaying faceted result counts.\n * > ⚠️ Requires that you pass a valid `getFacetedRowModel` function to `options.facetedRowModel`. A default implementation is provided via the exported `getFacetedRowModel` function.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-faceting#getfacetedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-faceting)\n */\n getFacetedRowModel: () => RowModel\n /**\n * A function that **computes and returns** a `Map` of unique values and their occurrences derived from `column.getFacetedRowModel`. Useful for displaying faceted result values.\n * > ⚠️ Requires that you pass a valid `getFacetedUniqueValues` function to `options.getFacetedUniqueValues`. A default implementation is provided via the exported `getFacetedUniqueValues` function.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-faceting#getfaceteduniquevalues)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-faceting)\n */\n getFacetedUniqueValues: () => Map\n}\n\nexport interface FacetedOptions {\n getFacetedMinMaxValues?: (\n table: Table,\n columnId: string\n ) => () => undefined | [number, number]\n getFacetedRowModel?: (\n table: Table,\n columnId: string\n ) => () => RowModel\n getFacetedUniqueValues?: (\n table: Table,\n columnId: string\n ) => () => Map\n}\n\n//\n\nexport const ColumnFaceting: TableFeature = {\n createColumn: (\n column: Column,\n table: Table\n ): void => {\n column._getFacetedRowModel =\n table.options.getFacetedRowModel &&\n table.options.getFacetedRowModel(table, column.id)\n column.getFacetedRowModel = () => {\n if (!column._getFacetedRowModel) {\n return table.getPreFilteredRowModel()\n }\n\n return column._getFacetedRowModel()\n }\n column._getFacetedUniqueValues =\n table.options.getFacetedUniqueValues &&\n table.options.getFacetedUniqueValues(table, column.id)\n column.getFacetedUniqueValues = () => {\n if (!column._getFacetedUniqueValues) {\n return new Map()\n }\n\n return column._getFacetedUniqueValues()\n }\n column._getFacetedMinMaxValues =\n table.options.getFacetedMinMaxValues &&\n table.options.getFacetedMinMaxValues(table, column.id)\n column.getFacetedMinMaxValues = () => {\n if (!column._getFacetedMinMaxValues) {\n return undefined\n }\n\n return column._getFacetedMinMaxValues()\n }\n },\n}\n","import { FilterFn } from './features/ColumnFiltering'\n\nconst includesString: FilterFn = (\n row,\n columnId: string,\n filterValue: string\n) => {\n const search = filterValue?.toString()?.toLowerCase()\n return Boolean(\n row\n .getValue(columnId)\n ?.toString()\n ?.toLowerCase()\n ?.includes(search)\n )\n}\n\nincludesString.autoRemove = (val: any) => testFalsey(val)\n\nconst includesStringSensitive: FilterFn = (\n row,\n columnId: string,\n filterValue: string\n) => {\n return Boolean(\n row.getValue(columnId)?.toString()?.includes(filterValue)\n )\n}\n\nincludesStringSensitive.autoRemove = (val: any) => testFalsey(val)\n\nconst equalsString: FilterFn = (\n row,\n columnId: string,\n filterValue: string\n) => {\n return (\n row.getValue(columnId)?.toString()?.toLowerCase() ===\n filterValue?.toLowerCase()\n )\n}\n\nequalsString.autoRemove = (val: any) => testFalsey(val)\n\nconst arrIncludes: FilterFn = (\n row,\n columnId: string,\n filterValue: unknown\n) => {\n return row.getValue(columnId)?.includes(filterValue)\n}\n\narrIncludes.autoRemove = (val: any) => testFalsey(val)\n\nconst arrIncludesAll: FilterFn = (\n row,\n columnId: string,\n filterValue: unknown[]\n) => {\n return !filterValue.some(\n val => !row.getValue(columnId)?.includes(val)\n )\n}\n\narrIncludesAll.autoRemove = (val: any) => testFalsey(val) || !val?.length\n\nconst arrIncludesSome: FilterFn = (\n row,\n columnId: string,\n filterValue: unknown[]\n) => {\n return filterValue.some(val =>\n row.getValue(columnId)?.includes(val)\n )\n}\n\narrIncludesSome.autoRemove = (val: any) => testFalsey(val) || !val?.length\n\nconst equals: FilterFn = (row, columnId: string, filterValue: unknown) => {\n return row.getValue(columnId) === filterValue\n}\n\nequals.autoRemove = (val: any) => testFalsey(val)\n\nconst weakEquals: FilterFn = (\n row,\n columnId: string,\n filterValue: unknown\n) => {\n return row.getValue(columnId) == filterValue\n}\n\nweakEquals.autoRemove = (val: any) => testFalsey(val)\n\nconst inNumberRange: FilterFn = (\n row,\n columnId: string,\n filterValue: [number, number]\n) => {\n let [min, max] = filterValue\n\n const rowValue = row.getValue(columnId)\n return rowValue >= min && rowValue <= max\n}\n\ninNumberRange.resolveFilterValue = (val: [any, any]) => {\n let [unsafeMin, unsafeMax] = val\n\n let parsedMin =\n typeof unsafeMin !== 'number' ? parseFloat(unsafeMin as string) : unsafeMin\n let parsedMax =\n typeof unsafeMax !== 'number' ? parseFloat(unsafeMax as string) : unsafeMax\n\n let min =\n unsafeMin === null || Number.isNaN(parsedMin) ? -Infinity : parsedMin\n let max = unsafeMax === null || Number.isNaN(parsedMax) ? Infinity : parsedMax\n\n if (min > max) {\n const temp = min\n min = max\n max = temp\n }\n\n return [min, max] as const\n}\n\ninNumberRange.autoRemove = (val: any) =>\n testFalsey(val) || (testFalsey(val[0]) && testFalsey(val[1]))\n\n// Export\n\nexport const filterFns = {\n includesString,\n includesStringSensitive,\n equalsString,\n arrIncludes,\n arrIncludesAll,\n arrIncludesSome,\n equals,\n weakEquals,\n inNumberRange,\n}\n\nexport type BuiltInFilterFn = keyof typeof filterFns\n\n// Utils\n\nfunction testFalsey(val: any) {\n return val === undefined || val === null || val === ''\n}\n","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 {\n filterFn: FilterFn\n id: string\n resolvedValue: unknown\n}\n\nexport interface FilterFn {\n (\n row: Row,\n columnId: string,\n filterValue: any,\n addMeta: (meta: FilterMeta) => void\n ): boolean\n autoRemove?: ColumnFilterAutoRemoveTestFn\n resolveFilterValue?: TransformFilterValueFn\n}\n\nexport type TransformFilterValueFn = (\n value: any,\n column?: Column\n) => unknown\n\nexport type ColumnFilterAutoRemoveTestFn = (\n value: any,\n column?: Column\n) => boolean\n\nexport type CustomFilterFns = Record<\n string,\n FilterFn\n>\n\nexport type FilterFnOption =\n | 'auto'\n | BuiltInFilterFn\n | keyof FilterFns\n | FilterFn\n\nexport interface ColumnFiltersColumnDef {\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\n}\n\nexport interface ColumnFiltersColumn {\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 | 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 | 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) => void\n}\n\nexport interface ColumnFiltersRow {\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\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\n}\n\ninterface ColumnFiltersOptionsBase {\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) => () => RowModel\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\n}\n\ntype ResolvedFilterFns = keyof FilterFns extends never\n ? {\n filterFns?: Record>\n }\n : {\n filterFns: Record>\n }\n\nexport interface ColumnFiltersOptions\n extends ColumnFiltersOptionsBase,\n ResolvedFilterFns {}\n\nexport interface ColumnFiltersInstance {\n _getFilteredRowModel?: () => RowModel\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\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\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) => 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) => void\n}\n\n//\n\nexport const ColumnFiltering: TableFeature = {\n getDefaultColumnDef: <\n TData extends RowData,\n >(): ColumnFiltersColumnDef => {\n return {\n filterFn: 'auto',\n }\n },\n\n getInitialState: (state): ColumnFiltersTableState => {\n return {\n columnFilters: [],\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): ColumnFiltersOptions => {\n return {\n onColumnFiltersChange: makeStateUpdater('columnFilters', table),\n filterFromLeafRows: false,\n maxLeafRowFilterDepth: 100,\n } as ColumnFiltersOptions\n },\n\n createColumn: (\n column: Column,\n table: Table\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, 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: (\n row: Row,\n _table: Table\n ): void => {\n row.columnFilters = {}\n row.columnFiltersMeta = {}\n },\n\n createTable: (table: Table): void => {\n table.setColumnFilters = (updater: Updater) => {\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(\n filterFn?: FilterFn,\n value?: any,\n column?: Column\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","import { AggregationFn } from './features/ColumnGrouping'\nimport { isNumberArray } from './utils'\n\nconst sum: AggregationFn = (columnId, _leafRows, childRows) => {\n // It's faster to just add the aggregations together instead of\n // process leaf nodes individually\n return childRows.reduce((sum, next) => {\n const nextValue = next.getValue(columnId)\n return sum + (typeof nextValue === 'number' ? nextValue : 0)\n }, 0)\n}\n\nconst min: AggregationFn = (columnId, _leafRows, childRows) => {\n let min: number | undefined\n\n childRows.forEach(row => {\n const value = row.getValue(columnId)\n\n if (\n value != null &&\n (min! > value || (min === undefined && value >= value))\n ) {\n min = value\n }\n })\n\n return min\n}\n\nconst max: AggregationFn = (columnId, _leafRows, childRows) => {\n let max: number | undefined\n\n childRows.forEach(row => {\n const value = row.getValue(columnId)\n if (\n value != null &&\n (max! < value || (max === undefined && value >= value))\n ) {\n max = value\n }\n })\n\n return max\n}\n\nconst extent: AggregationFn = (columnId, _leafRows, childRows) => {\n let min: number | undefined\n let max: number | undefined\n\n childRows.forEach(row => {\n const value = row.getValue(columnId)\n if (value != null) {\n if (min === undefined) {\n if (value >= value) min = max = value\n } else {\n if (min > value) min = value\n if (max! < value) max = value\n }\n }\n })\n\n return [min, max]\n}\n\nconst mean: AggregationFn = (columnId, leafRows) => {\n let count = 0\n let sum = 0\n\n leafRows.forEach(row => {\n let value = row.getValue(columnId)\n if (value != null && (value = +value) >= value) {\n ++count, (sum += value)\n }\n })\n\n if (count) return sum / count\n\n return\n}\n\nconst median: AggregationFn = (columnId, leafRows) => {\n if (!leafRows.length) {\n return\n }\n\n const values = leafRows.map(row => row.getValue(columnId))\n if (!isNumberArray(values)) {\n return\n }\n if (values.length === 1) {\n return values[0]\n }\n\n const mid = Math.floor(values.length / 2)\n const nums = values.sort((a, b) => a - b)\n return values.length % 2 !== 0 ? nums[mid] : (nums[mid - 1]! + nums[mid]!) / 2\n}\n\nconst unique: AggregationFn = (columnId, leafRows) => {\n return Array.from(new Set(leafRows.map(d => d.getValue(columnId))).values())\n}\n\nconst uniqueCount: AggregationFn = (columnId, leafRows) => {\n return new Set(leafRows.map(d => d.getValue(columnId))).size\n}\n\nconst count: AggregationFn = (_columnId, leafRows) => {\n return leafRows.length\n}\n\nexport const aggregationFns = {\n sum,\n min,\n max,\n extent,\n mean,\n median,\n unique,\n uniqueCount,\n count,\n}\n\nexport type BuiltInAggregationFn = keyof typeof aggregationFns\n","import { RowModel } from '..'\nimport { BuiltInAggregationFn, aggregationFns } from '../aggregationFns'\nimport {\n AggregationFns,\n Cell,\n Column,\n ColumnDefTemplate,\n OnChangeFn,\n Row,\n RowData,\n Table,\n TableFeature,\n Updater,\n} from '../types'\nimport { isFunction, makeStateUpdater } from '../utils'\n\nexport type GroupingState = string[]\n\nexport interface GroupingTableState {\n grouping: GroupingState\n}\n\nexport type AggregationFn = (\n columnId: string,\n leafRows: Row[],\n childRows: Row[]\n) => any\n\nexport type CustomAggregationFns = Record>\n\nexport type AggregationFnOption =\n | 'auto'\n | keyof AggregationFns\n | BuiltInAggregationFn\n | AggregationFn\n\nexport interface GroupingColumnDef {\n /**\n * The cell to display each row for the column if the cell is an aggregate. If a function is passed, it will be passed a props object with the context of the cell and should return the property type for your adapter (the exact type depends on the adapter being used).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#aggregatedcell)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n aggregatedCell?: ColumnDefTemplate<\n ReturnType['getContext']>\n >\n /**\n * The resolved aggregation function for the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#aggregationfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n aggregationFn?: AggregationFnOption\n /**\n * Enables/disables grouping for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#enablegrouping)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n enableGrouping?: boolean\n /**\n * Specify a value to be used for grouping rows on this column. If this option is not specified, the value derived from `accessorKey` / `accessorFn` will be used instead.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getgroupingvalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getGroupingValue?: (row: TData) => any\n}\n\nexport interface GroupingColumn {\n /**\n * Returns the aggregation function for the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getaggregationfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getAggregationFn: () => AggregationFn | undefined\n /**\n * Returns the automatically inferred aggregation function for the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getautoaggregationfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getAutoAggregationFn: () => AggregationFn | undefined\n /**\n * Returns whether or not the column can be grouped.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getcangroup)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getCanGroup: () => boolean\n /**\n * Returns the index of the column in the grouping state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getgroupedindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getGroupedIndex: () => number\n /**\n * Returns whether or not the column is currently grouped.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getisgrouped)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getIsGrouped: () => boolean\n /**\n * Returns a function that toggles the grouping state of the column. This is useful for passing to the `onClick` prop of a button.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#gettogglegroupinghandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getToggleGroupingHandler: () => () => void\n /**\n * Toggles the grouping state of the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#togglegrouping)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n toggleGrouping: () => void\n}\n\nexport interface GroupingRow {\n _groupingValuesCache: Record\n /**\n * Returns the grouping value for any row and column (including leaf rows).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getgroupingvalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getGroupingValue: (columnId: string) => unknown\n /**\n * Returns whether or not the row is currently grouped.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getisgrouped)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getIsGrouped: () => boolean\n /**\n * If this row is grouped, this is the id of the column that this row is grouped by.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#groupingcolumnid)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n groupingColumnId?: string\n /**\n * If this row is grouped, this is the unique/shared value for the `groupingColumnId` for all of the rows in this group.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#groupingvalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n groupingValue?: unknown\n}\n\nexport interface GroupingCell {\n /**\n * Returns whether or not the cell is currently aggregated.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getisaggregated)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getIsAggregated: () => boolean\n /**\n * Returns whether or not the cell is currently grouped.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getisgrouped)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getIsGrouped: () => boolean\n /**\n * Returns whether or not the cell is currently a placeholder cell.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getisplaceholder)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getIsPlaceholder: () => boolean\n}\n\nexport interface ColumnDefaultOptions {\n enableGrouping: boolean\n onGroupingChange: OnChangeFn\n}\n\ninterface GroupingOptionsBase {\n /**\n * Enables/disables grouping for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#enablegrouping)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n enableGrouping?: boolean\n /**\n * Returns the row model after grouping has taken place, but no further.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getgroupedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getGroupedRowModel?: (table: Table) => () => RowModel\n /**\n * Grouping columns are automatically reordered by default to the start of the columns list. If you would rather remove them or leave them as-is, set the appropriate mode here.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#groupedcolumnmode)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n groupedColumnMode?: false | 'reorder' | 'remove'\n /**\n * Enables manual grouping. If this option is set to `true`, the table will not automatically group rows using `getGroupedRowModel()` and instead will expect you to manually group the rows before passing them to the table. This is useful if you are doing server-side grouping and aggregation.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#manualgrouping)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n manualGrouping?: boolean\n /**\n * If this function is provided, it will be called when the grouping state changes and you will be expected to manage the state yourself. You can pass the managed state back to the table via the `tableOptions.state.grouping` option.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#ongroupingchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n onGroupingChange?: OnChangeFn\n}\n\ntype ResolvedAggregationFns = keyof AggregationFns extends never\n ? {\n aggregationFns?: Record>\n }\n : {\n aggregationFns: Record>\n }\n\nexport interface GroupingOptions\n extends GroupingOptionsBase,\n ResolvedAggregationFns {}\n\nexport type GroupingColumnMode = false | 'reorder' | 'remove'\n\nexport interface GroupingInstance {\n _getGroupedRowModel?: () => RowModel\n /**\n * Returns the row model for the table after grouping has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getgroupedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getGroupedRowModel: () => RowModel\n /**\n * Returns the row model for the table before any grouping has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#getpregroupedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n getPreGroupedRowModel: () => RowModel\n /**\n * Resets the **grouping** state to `initialState.grouping`, 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/grouping#resetgrouping)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n resetGrouping: (defaultState?: boolean) => void\n /**\n * Updates the grouping state of the table via an update function or value.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/grouping#setgrouping)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/grouping)\n */\n setGrouping: (updater: Updater) => void\n}\n\n//\n\nexport const ColumnGrouping: TableFeature = {\n getDefaultColumnDef: (): GroupingColumnDef<\n TData,\n unknown\n > => {\n return {\n aggregatedCell: props => (props.getValue() as any)?.toString?.() ?? null,\n aggregationFn: 'auto',\n }\n },\n\n getInitialState: (state): GroupingTableState => {\n return {\n grouping: [],\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): GroupingOptions => {\n return {\n onGroupingChange: makeStateUpdater('grouping', table),\n groupedColumnMode: 'reorder',\n }\n },\n\n createColumn: (\n column: Column,\n table: Table\n ): void => {\n column.toggleGrouping = () => {\n table.setGrouping(old => {\n // Find any existing grouping for this column\n if (old?.includes(column.id)) {\n return old.filter(d => d !== column.id)\n }\n\n return [...(old ?? []), column.id]\n })\n }\n\n column.getCanGroup = () => {\n return (\n (column.columnDef.enableGrouping ?? true) &&\n (table.options.enableGrouping ?? true) &&\n (!!column.accessorFn || !!column.columnDef.getGroupingValue)\n )\n }\n\n column.getIsGrouped = () => {\n return table.getState().grouping?.includes(column.id)\n }\n\n column.getGroupedIndex = () => table.getState().grouping?.indexOf(column.id)\n\n column.getToggleGroupingHandler = () => {\n const canGroup = column.getCanGroup()\n\n return () => {\n if (!canGroup) return\n column.toggleGrouping()\n }\n }\n column.getAutoAggregationFn = () => {\n const firstRow = table.getCoreRowModel().flatRows[0]\n\n const value = firstRow?.getValue(column.id)\n\n if (typeof value === 'number') {\n return aggregationFns.sum\n }\n\n if (Object.prototype.toString.call(value) === '[object Date]') {\n return aggregationFns.extent\n }\n }\n column.getAggregationFn = () => {\n if (!column) {\n throw new Error()\n }\n\n return isFunction(column.columnDef.aggregationFn)\n ? column.columnDef.aggregationFn\n : column.columnDef.aggregationFn === 'auto'\n ? column.getAutoAggregationFn()\n : table.options.aggregationFns?.[\n column.columnDef.aggregationFn as string\n ] ??\n aggregationFns[\n column.columnDef.aggregationFn as BuiltInAggregationFn\n ]\n }\n },\n\n createTable: (table: Table): void => {\n table.setGrouping = updater => table.options.onGroupingChange?.(updater)\n\n table.resetGrouping = defaultState => {\n table.setGrouping(defaultState ? [] : table.initialState?.grouping ?? [])\n }\n\n table.getPreGroupedRowModel = () => table.getFilteredRowModel()\n table.getGroupedRowModel = () => {\n if (!table._getGroupedRowModel && table.options.getGroupedRowModel) {\n table._getGroupedRowModel = table.options.getGroupedRowModel(table)\n }\n\n if (table.options.manualGrouping || !table._getGroupedRowModel) {\n return table.getPreGroupedRowModel()\n }\n\n return table._getGroupedRowModel()\n }\n },\n\n createRow: (\n row: Row,\n table: Table\n ): void => {\n row.getIsGrouped = () => !!row.groupingColumnId\n row.getGroupingValue = columnId => {\n if (row._groupingValuesCache.hasOwnProperty(columnId)) {\n return row._groupingValuesCache[columnId]\n }\n\n const column = table.getColumn(columnId)\n\n if (!column?.columnDef.getGroupingValue) {\n return row.getValue(columnId)\n }\n\n row._groupingValuesCache[columnId] = column.columnDef.getGroupingValue(\n row.original\n )\n\n return row._groupingValuesCache[columnId]\n }\n row._groupingValuesCache = {}\n },\n\n createCell: (\n cell: Cell,\n column: Column,\n row: Row,\n table: Table\n ): void => {\n const getRenderValue = () =>\n cell.getValue() ?? table.options.renderFallbackValue\n\n cell.getIsGrouped = () =>\n column.getIsGrouped() && column.id === row.groupingColumnId\n cell.getIsPlaceholder = () => !cell.getIsGrouped() && column.getIsGrouped()\n cell.getIsAggregated = () =>\n !cell.getIsGrouped() && !cell.getIsPlaceholder() && !!row.subRows?.length\n },\n}\n\nexport function orderColumns(\n leafColumns: Column[],\n grouping: string[],\n groupedColumnMode?: GroupingColumnMode\n) {\n if (!grouping?.length || !groupedColumnMode) {\n return leafColumns\n }\n\n const nonGroupingColumns = leafColumns.filter(\n col => !grouping.includes(col.id)\n )\n\n if (groupedColumnMode === 'remove') {\n return nonGroupingColumns\n }\n\n const groupingColumns = grouping\n .map(g => leafColumns.find(col => col.id === g)!)\n .filter(Boolean)\n\n return [...groupingColumns, ...nonGroupingColumns]\n}\n","import { getMemoOptions, makeStateUpdater, memo } from '../utils'\n\nimport {\n Column,\n OnChangeFn,\n RowData,\n Table,\n TableFeature,\n Updater,\n} from '../types'\n\nimport { orderColumns } from './ColumnGrouping'\nimport { ColumnPinningPosition, _getVisibleLeafColumns } from '..'\n\nexport interface ColumnOrderTableState {\n columnOrder: ColumnOrderState\n}\n\nexport type ColumnOrderState = string[]\n\nexport interface ColumnOrderOptions {\n /**\n * If provided, this function will be called with an `updaterFn` when `state.columnOrder` 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-ordering#oncolumnorderchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-ordering)\n */\n onColumnOrderChange?: OnChangeFn\n}\n\nexport interface ColumnOrderColumn {\n /**\n * Returns the index of the column in the order of the visible columns. Optionally pass a `position` parameter to get the index of the column in a sub-section of the table\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-ordering#getindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-ordering)\n */\n getIndex: (position?: ColumnPinningPosition | 'center') => number\n /**\n * Returns `true` if the column is the first column in the order of the visible columns. Optionally pass a `position` parameter to check if the column is the first in a sub-section of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-ordering#getisfirstcolumn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-ordering)\n */\n getIsFirstColumn: (position?: ColumnPinningPosition | 'center') => boolean\n /**\n * Returns `true` if the column is the last column in the order of the visible columns. Optionally pass a `position` parameter to check if the column is the last in a sub-section of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-ordering#getislastcolumn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-ordering)\n */\n getIsLastColumn: (position?: ColumnPinningPosition | 'center') => boolean\n}\n\nexport interface ColumnOrderDefaultOptions {\n onColumnOrderChange: OnChangeFn\n}\n\nexport interface ColumnOrderInstance {\n _getOrderColumnsFn: () => (\n columns: Column[]\n ) => Column[]\n /**\n * Resets the **columnOrder** state to `initialState.columnOrder`, 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-ordering#resetcolumnorder)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-ordering)\n */\n resetColumnOrder: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.columnOrder` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-ordering#setcolumnorder)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-ordering)\n */\n setColumnOrder: (updater: Updater) => void\n}\n\n//\n\nexport const ColumnOrdering: TableFeature = {\n getInitialState: (state): ColumnOrderTableState => {\n return {\n columnOrder: [],\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): ColumnOrderDefaultOptions => {\n return {\n onColumnOrderChange: makeStateUpdater('columnOrder', table),\n }\n },\n\n createColumn: (\n column: Column,\n table: Table\n ): void => {\n column.getIndex = memo(\n position => [_getVisibleLeafColumns(table, position)],\n columns => columns.findIndex(d => d.id === column.id),\n getMemoOptions(table.options, 'debugColumns', 'getIndex')\n )\n column.getIsFirstColumn = position => {\n const columns = _getVisibleLeafColumns(table, position)\n return columns[0]?.id === column.id\n }\n column.getIsLastColumn = position => {\n const columns = _getVisibleLeafColumns(table, position)\n return columns[columns.length - 1]?.id === column.id\n }\n },\n\n createTable: (table: Table): void => {\n table.setColumnOrder = updater =>\n table.options.onColumnOrderChange?.(updater)\n table.resetColumnOrder = defaultState => {\n table.setColumnOrder(\n defaultState ? [] : table.initialState.columnOrder ?? []\n )\n }\n table._getOrderColumnsFn = memo(\n () => [\n table.getState().columnOrder,\n table.getState().grouping,\n table.options.groupedColumnMode,\n ],\n (columnOrder, grouping, groupedColumnMode) =>\n (columns: Column[]) => {\n // Sort grouped columns to the start of the column list\n // before the headers are built\n let orderedColumns: Column[] = []\n\n // If there is no order, return the normal columns\n if (!columnOrder?.length) {\n orderedColumns = columns\n } else {\n const columnOrderCopy = [...columnOrder]\n\n // If there is an order, make a copy of the columns\n const columnsCopy = [...columns]\n\n // And make a new ordered array of the columns\n\n // Loop over the columns and place them in order into the new array\n while (columnsCopy.length && columnOrderCopy.length) {\n const targetColumnId = columnOrderCopy.shift()\n const foundIndex = columnsCopy.findIndex(\n d => d.id === targetColumnId\n )\n if (foundIndex > -1) {\n orderedColumns.push(columnsCopy.splice(foundIndex, 1)[0]!)\n }\n }\n\n // If there are any columns left, add them to the end\n orderedColumns = [...orderedColumns, ...columnsCopy]\n }\n\n return orderColumns(orderedColumns, grouping, groupedColumnMode)\n },\n getMemoOptions(table.options, 'debugTable', '_getOrderColumnsFn')\n )\n },\n}\n","import {\n OnChangeFn,\n Updater,\n Table,\n Column,\n Row,\n Cell,\n RowData,\n TableFeature,\n} from '../types'\nimport { getMemoOptions, makeStateUpdater, memo } from '../utils'\n\nexport type ColumnPinningPosition = false | 'left' | 'right'\n\nexport interface ColumnPinningState {\n left?: string[]\n right?: string[]\n}\n\nexport interface ColumnPinningTableState {\n columnPinning: ColumnPinningState\n}\n\nexport interface ColumnPinningOptions {\n /**\n * Enables/disables column pinning for the table. Defaults to `true`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#enablecolumnpinning)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n enableColumnPinning?: boolean\n /**\n * @deprecated Use `enableColumnPinning` or `enableRowPinning` instead.\n * Enables/disables all pinning for the table. Defaults to `true`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#enablepinning)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n enablePinning?: boolean\n /**\n * If provided, this function will be called with an `updaterFn` when `state.columnPinning` changes. This overrides the default internal state management, so you will also need to supply `state.columnPinning` from your own managed state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#oncolumnpinningchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/oncolumnpinningchange)\n */\n onColumnPinningChange?: OnChangeFn\n}\n\nexport interface ColumnPinningDefaultOptions {\n onColumnPinningChange: OnChangeFn\n}\n\nexport interface ColumnPinningColumnDef {\n /**\n * Enables/disables column pinning for this column. Defaults to `true`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#enablepinning-1)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n enablePinning?: boolean\n}\n\nexport interface ColumnPinningColumn {\n /**\n * Returns whether or not the column can be pinned.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getcanpin)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getCanPin: () => boolean\n /**\n * Returns the pinned position of the column. (`'left'`, `'right'` or `false`)\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getispinned)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getIsPinned: () => ColumnPinningPosition\n /**\n * Returns the numeric pinned index of the column within a pinned column group.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getpinnedindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getPinnedIndex: () => number\n /**\n * Pins a column to the `'left'` or `'right'`, or unpins the column to the center if `false` is passed.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#pin)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n pin: (position: ColumnPinningPosition) => void\n}\n\nexport interface ColumnPinningRow {\n /**\n * Returns all center pinned (unpinned) leaf cells in the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getcentervisiblecells)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getCenterVisibleCells: () => Cell[]\n /**\n * Returns all left pinned leaf cells in the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getleftvisiblecells)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getLeftVisibleCells: () => Cell[]\n /**\n * Returns all right pinned leaf cells in the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getrightvisiblecells)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getRightVisibleCells: () => Cell[]\n}\n\nexport interface ColumnPinningInstance {\n /**\n * Returns all center pinned (unpinned) leaf columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getcenterleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getCenterLeafColumns: () => Column[]\n /**\n * Returns whether or not any columns are pinned. Optionally specify to only check for pinned columns in either the `left` or `right` position.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getissomecolumnspinned)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getIsSomeColumnsPinned: (position?: ColumnPinningPosition) => boolean\n /**\n * Returns all left pinned leaf columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getleftleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getLeftLeafColumns: () => Column[]\n /**\n * Returns all right pinned leaf columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#getrightleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n getRightLeafColumns: () => Column[]\n /**\n * Resets the **columnPinning** state to `initialState.columnPinning`, or `true` can be passed to force a default blank state reset to `{ left: [], right: [], }`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#resetcolumnpinning)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n resetColumnPinning: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.columnPinning` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-pinning#setcolumnpinning)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-pinning)\n */\n setColumnPinning: (updater: Updater) => void\n}\n\n//\n\nconst getDefaultColumnPinningState = (): ColumnPinningState => ({\n left: [],\n right: [],\n})\n\nexport const ColumnPinning: TableFeature = {\n getInitialState: (state): ColumnPinningTableState => {\n return {\n columnPinning: getDefaultColumnPinningState(),\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): ColumnPinningDefaultOptions => {\n return {\n onColumnPinningChange: makeStateUpdater('columnPinning', table),\n }\n },\n\n createColumn: (\n column: Column,\n table: Table\n ): void => {\n column.pin = position => {\n const columnIds = column\n .getLeafColumns()\n .map(d => d.id)\n .filter(Boolean) as string[]\n\n table.setColumnPinning(old => {\n if (position === 'right') {\n return {\n left: (old?.left ?? []).filter(d => !columnIds?.includes(d)),\n right: [\n ...(old?.right ?? []).filter(d => !columnIds?.includes(d)),\n ...columnIds,\n ],\n }\n }\n\n if (position === 'left') {\n return {\n left: [\n ...(old?.left ?? []).filter(d => !columnIds?.includes(d)),\n ...columnIds,\n ],\n right: (old?.right ?? []).filter(d => !columnIds?.includes(d)),\n }\n }\n\n return {\n left: (old?.left ?? []).filter(d => !columnIds?.includes(d)),\n right: (old?.right ?? []).filter(d => !columnIds?.includes(d)),\n }\n })\n }\n\n column.getCanPin = () => {\n const leafColumns = column.getLeafColumns()\n\n return leafColumns.some(\n d =>\n (d.columnDef.enablePinning ?? true) &&\n (table.options.enableColumnPinning ??\n table.options.enablePinning ??\n true)\n )\n }\n\n column.getIsPinned = () => {\n const leafColumnIds = column.getLeafColumns().map(d => d.id)\n\n const { left, right } = table.getState().columnPinning\n\n const isLeft = leafColumnIds.some(d => left?.includes(d))\n const isRight = leafColumnIds.some(d => right?.includes(d))\n\n return isLeft ? 'left' : isRight ? 'right' : false\n }\n\n column.getPinnedIndex = () => {\n const position = column.getIsPinned()\n\n return position\n ? table.getState().columnPinning?.[position]?.indexOf(column.id) ?? -1\n : 0\n }\n },\n\n createRow: (\n row: Row,\n table: Table\n ): void => {\n row.getCenterVisibleCells = memo(\n () => [\n row._getAllVisibleCells(),\n table.getState().columnPinning.left,\n table.getState().columnPinning.right,\n ],\n (allCells, left, right) => {\n const leftAndRight: string[] = [...(left ?? []), ...(right ?? [])]\n\n return allCells.filter(d => !leftAndRight.includes(d.column.id))\n },\n getMemoOptions(table.options, 'debugRows', 'getCenterVisibleCells')\n )\n row.getLeftVisibleCells = memo(\n () => [row._getAllVisibleCells(), table.getState().columnPinning.left],\n (allCells, left) => {\n const cells = (left ?? [])\n .map(columnId => allCells.find(cell => cell.column.id === columnId)!)\n .filter(Boolean)\n .map(d => ({ ...d, position: 'left' }) as Cell)\n\n return cells\n },\n getMemoOptions(table.options, 'debugRows', 'getLeftVisibleCells')\n )\n row.getRightVisibleCells = memo(\n () => [row._getAllVisibleCells(), table.getState().columnPinning.right],\n (allCells, right) => {\n const cells = (right ?? [])\n .map(columnId => allCells.find(cell => cell.column.id === columnId)!)\n .filter(Boolean)\n .map(d => ({ ...d, position: 'right' }) as Cell)\n\n return cells\n },\n getMemoOptions(table.options, 'debugRows', 'getRightVisibleCells')\n )\n },\n\n createTable: (table: Table): void => {\n table.setColumnPinning = updater =>\n table.options.onColumnPinningChange?.(updater)\n\n table.resetColumnPinning = defaultState =>\n table.setColumnPinning(\n defaultState\n ? getDefaultColumnPinningState()\n : table.initialState?.columnPinning ?? getDefaultColumnPinningState()\n )\n\n table.getIsSomeColumnsPinned = position => {\n const pinningState = table.getState().columnPinning\n\n if (!position) {\n return Boolean(pinningState.left?.length || pinningState.right?.length)\n }\n return Boolean(pinningState[position]?.length)\n }\n\n table.getLeftLeafColumns = memo(\n () => [table.getAllLeafColumns(), table.getState().columnPinning.left],\n (allColumns, left) => {\n return (left ?? [])\n .map(columnId => allColumns.find(column => column.id === columnId)!)\n .filter(Boolean)\n },\n getMemoOptions(table.options, 'debugColumns', 'getLeftLeafColumns')\n )\n\n table.getRightLeafColumns = memo(\n () => [table.getAllLeafColumns(), table.getState().columnPinning.right],\n (allColumns, right) => {\n return (right ?? [])\n .map(columnId => allColumns.find(column => column.id === columnId)!)\n .filter(Boolean)\n },\n getMemoOptions(table.options, 'debugColumns', 'getRightLeafColumns')\n )\n\n table.getCenterLeafColumns = memo(\n () => [\n table.getAllLeafColumns(),\n table.getState().columnPinning.left,\n table.getState().columnPinning.right,\n ],\n (allColumns, left, right) => {\n const leftAndRight: string[] = [...(left ?? []), ...(right ?? [])]\n\n return allColumns.filter(d => !leftAndRight.includes(d.id))\n },\n getMemoOptions(table.options, 'debugColumns', 'getCenterLeafColumns')\n )\n },\n}\n","import { _getVisibleLeafColumns } from '..'\nimport {\n RowData,\n Column,\n Header,\n OnChangeFn,\n Table,\n Updater,\n TableFeature,\n} from '../types'\nimport { getMemoOptions, makeStateUpdater, memo } from '../utils'\nimport { ColumnPinningPosition } from './ColumnPinning'\n\n//\n\nexport interface ColumnSizingTableState {\n columnSizing: ColumnSizingState\n columnSizingInfo: ColumnSizingInfoState\n}\n\nexport type ColumnSizingState = Record\n\nexport interface ColumnSizingInfoState {\n columnSizingStart: [string, number][]\n deltaOffset: null | number\n deltaPercentage: null | number\n isResizingColumn: false | string\n startOffset: null | number\n startSize: null | number\n}\n\nexport type ColumnResizeMode = 'onChange' | 'onEnd'\n\nexport type ColumnResizeDirection = 'ltr' | 'rtl'\n\nexport interface ColumnSizingOptions {\n /**\n * Determines when the columnSizing state is updated. `onChange` updates the state when the user is dragging the resize handle. `onEnd` updates the state when the user releases the resize handle.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#columnresizemode)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n columnResizeMode?: ColumnResizeMode\n /**\n * Enables or disables column resizing for the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#enablecolumnresizing)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n enableColumnResizing?: boolean\n /**\n * Enables or disables right-to-left support for resizing the column. defaults to 'ltr'.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#columnResizeDirection)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n columnResizeDirection?: ColumnResizeDirection\n /**\n * If provided, this function will be called with an `updaterFn` when `state.columnSizing` changes. This overrides the default internal state management, so you will also need to supply `state.columnSizing` from your own managed state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#oncolumnsizingchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n onColumnSizingChange?: OnChangeFn\n /**\n * If provided, this function will be called with an `updaterFn` when `state.columnSizingInfo` changes. This overrides the default internal state management, so you will also need to supply `state.columnSizingInfo` from your own managed state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#oncolumnsizinginfochange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n onColumnSizingInfoChange?: OnChangeFn\n}\n\nexport type ColumnSizingDefaultOptions = Pick<\n ColumnSizingOptions,\n | 'columnResizeMode'\n | 'onColumnSizingChange'\n | 'onColumnSizingInfoChange'\n | 'columnResizeDirection'\n>\n\nexport interface ColumnSizingInstance {\n /**\n * If pinning, returns the total size of the center portion of the table by calculating the sum of the sizes of all unpinned/center leaf-columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getcentertotalsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getCenterTotalSize: () => number\n /**\n * Returns the total size of the left portion of the table by calculating the sum of the sizes of all left leaf-columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getlefttotalsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getLeftTotalSize: () => number\n /**\n * Returns the total size of the right portion of the table by calculating the sum of the sizes of all right leaf-columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getrighttotalsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getRightTotalSize: () => number\n /**\n * Returns the total size of the table by calculating the sum of the sizes of all leaf-columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#gettotalsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getTotalSize: () => number\n /**\n * Resets column sizing to its initial state. If `defaultState` is `true`, the default state for the table will be used instead of the initialValue provided to the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#resetcolumnsizing)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n resetColumnSizing: (defaultState?: boolean) => void\n /**\n * Resets column sizing info to its initial state. If `defaultState` is `true`, the default state for the table will be used instead of the initialValue provided to the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#resetheadersizeinfo)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n resetHeaderSizeInfo: (defaultState?: boolean) => void\n /**\n * Sets the column sizing state using an updater function or a value. This will trigger the underlying `onColumnSizingChange` function if one is passed to the table options, otherwise the state will be managed automatically by the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#setcolumnsizing)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n setColumnSizing: (updater: Updater) => void\n /**\n * Sets the column sizing info state using an updater function or a value. This will trigger the underlying `onColumnSizingInfoChange` function if one is passed to the table options, otherwise the state will be managed automatically by the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#setcolumnsizinginfo)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n setColumnSizingInfo: (updater: Updater) => void\n}\n\nexport interface ColumnSizingColumnDef {\n /**\n * Enables or disables column resizing for the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#enableresizing)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n enableResizing?: boolean\n /**\n * The maximum allowed size for the column\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#maxsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n maxSize?: number\n /**\n * The minimum allowed size for the column\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#minsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n minSize?: number\n /**\n * The desired size for the column\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#size)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n size?: number\n}\n\nexport interface ColumnSizingColumn {\n /**\n * Returns `true` if the column can be resized.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getcanresize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getCanResize: () => boolean\n /**\n * Returns `true` if the column is currently being resized.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getisresizing)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getIsResizing: () => boolean\n /**\n * Returns the current size of the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getSize: () => number\n /**\n * Returns the offset measurement along the row-axis (usually the x-axis for standard tables) for the header. This is effectively a sum of the offset measurements of all preceding (left) headers in relation to the current column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getstart)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getStart: (position?: ColumnPinningPosition | 'center') => number\n /**\n * Returns the offset measurement along the row-axis (usually the x-axis for standard tables) for the header. This is effectively a sum of the offset measurements of all succeeding (right) headers in relation to the current column.\n */\n getAfter: (position?: ColumnPinningPosition | 'center') => number\n /**\n * Resets the column to its initial size.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#resetsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n resetSize: () => void\n}\n\nexport interface ColumnSizingHeader {\n /**\n * Returns an event handler function that can be used to resize the header. It can be used as an:\n * - `onMouseDown` handler\n * - `onTouchStart` handler\n *\n * The dragging and release events are automatically handled for you.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getresizehandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getResizeHandler: (context?: Document) => (event: unknown) => void\n /**\n * Returns the current size of the header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getsize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getSize: () => number\n /**\n * Returns the offset measurement along the row-axis (usually the x-axis for standard tables) for the header. This is effectively a sum of the offset measurements of all preceding headers.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-sizing#getstart)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-sizing)\n */\n getStart: (position?: ColumnPinningPosition) => number\n}\n\n//\n\nexport const defaultColumnSizing = {\n size: 150,\n minSize: 20,\n maxSize: Number.MAX_SAFE_INTEGER,\n}\n\nconst getDefaultColumnSizingInfoState = (): ColumnSizingInfoState => ({\n startOffset: null,\n startSize: null,\n deltaOffset: null,\n deltaPercentage: null,\n isResizingColumn: false,\n columnSizingStart: [],\n})\n\nexport const ColumnSizing: TableFeature = {\n getDefaultColumnDef: (): ColumnSizingColumnDef => {\n return defaultColumnSizing\n },\n getInitialState: (state): ColumnSizingTableState => {\n return {\n columnSizing: {},\n columnSizingInfo: getDefaultColumnSizingInfoState(),\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): ColumnSizingDefaultOptions => {\n return {\n columnResizeMode: 'onEnd',\n columnResizeDirection: 'ltr',\n onColumnSizingChange: makeStateUpdater('columnSizing', table),\n onColumnSizingInfoChange: makeStateUpdater('columnSizingInfo', table),\n }\n },\n\n createColumn: (\n column: Column,\n table: Table\n ): void => {\n column.getSize = () => {\n const columnSize = table.getState().columnSizing[column.id]\n\n return Math.min(\n Math.max(\n column.columnDef.minSize ?? defaultColumnSizing.minSize,\n columnSize ?? column.columnDef.size ?? defaultColumnSizing.size\n ),\n column.columnDef.maxSize ?? defaultColumnSizing.maxSize\n )\n }\n\n column.getStart = memo(\n position => [\n position,\n _getVisibleLeafColumns(table, position),\n table.getState().columnSizing,\n ],\n (position, columns) =>\n columns\n .slice(0, column.getIndex(position))\n .reduce((sum, column) => sum + column.getSize(), 0),\n getMemoOptions(table.options, 'debugColumns', 'getStart')\n )\n\n column.getAfter = memo(\n position => [\n position,\n _getVisibleLeafColumns(table, position),\n table.getState().columnSizing,\n ],\n (position, columns) =>\n columns\n .slice(column.getIndex(position) + 1)\n .reduce((sum, column) => sum + column.getSize(), 0),\n getMemoOptions(table.options, 'debugColumns', 'getAfter')\n )\n\n column.resetSize = () => {\n table.setColumnSizing(({ [column.id]: _, ...rest }) => {\n return rest\n })\n }\n column.getCanResize = () => {\n return (\n (column.columnDef.enableResizing ?? true) &&\n (table.options.enableColumnResizing ?? true)\n )\n }\n column.getIsResizing = () => {\n return table.getState().columnSizingInfo.isResizingColumn === column.id\n }\n },\n\n createHeader: (\n header: Header,\n table: Table\n ): void => {\n header.getSize = () => {\n let sum = 0\n\n const recurse = (header: Header) => {\n if (header.subHeaders.length) {\n header.subHeaders.forEach(recurse)\n } else {\n sum += header.column.getSize() ?? 0\n }\n }\n\n recurse(header)\n\n return sum\n }\n header.getStart = () => {\n if (header.index > 0) {\n const prevSiblingHeader = header.headerGroup.headers[header.index - 1]!\n return prevSiblingHeader.getStart() + prevSiblingHeader.getSize()\n }\n\n return 0\n }\n header.getResizeHandler = _contextDocument => {\n const column = table.getColumn(header.column.id)\n const canResize = column?.getCanResize()\n\n return (e: unknown) => {\n if (!column || !canResize) {\n return\n }\n\n ;(e as any).persist?.()\n\n if (isTouchStartEvent(e)) {\n // lets not respond to multiple touches (e.g. 2 or 3 fingers)\n if (e.touches && e.touches.length > 1) {\n return\n }\n }\n\n const startSize = header.getSize()\n\n const columnSizingStart: [string, number][] = header\n ? header.getLeafHeaders().map(d => [d.column.id, d.column.getSize()])\n : [[column.id, column.getSize()]]\n\n const clientX = isTouchStartEvent(e)\n ? Math.round(e.touches[0]!.clientX)\n : (e as MouseEvent).clientX\n\n const newColumnSizing: ColumnSizingState = {}\n\n const updateOffset = (\n eventType: 'move' | 'end',\n clientXPos?: number\n ) => {\n if (typeof clientXPos !== 'number') {\n return\n }\n\n table.setColumnSizingInfo(old => {\n const deltaDirection =\n table.options.columnResizeDirection === 'rtl' ? -1 : 1\n const deltaOffset =\n (clientXPos - (old?.startOffset ?? 0)) * deltaDirection\n const deltaPercentage = Math.max(\n deltaOffset / (old?.startSize ?? 0),\n -0.999999\n )\n\n old.columnSizingStart.forEach(([columnId, headerSize]) => {\n newColumnSizing[columnId] =\n Math.round(\n Math.max(headerSize + headerSize * deltaPercentage, 0) * 100\n ) / 100\n })\n\n return {\n ...old,\n deltaOffset,\n deltaPercentage,\n }\n })\n\n if (\n table.options.columnResizeMode === 'onChange' ||\n eventType === 'end'\n ) {\n table.setColumnSizing(old => ({\n ...old,\n ...newColumnSizing,\n }))\n }\n }\n\n const onMove = (clientXPos?: number) => updateOffset('move', clientXPos)\n\n const onEnd = (clientXPos?: number) => {\n updateOffset('end', clientXPos)\n\n table.setColumnSizingInfo(old => ({\n ...old,\n isResizingColumn: false,\n startOffset: null,\n startSize: null,\n deltaOffset: null,\n deltaPercentage: null,\n columnSizingStart: [],\n }))\n }\n\n const contextDocument =\n _contextDocument || typeof document !== 'undefined' ? document : null\n\n const mouseEvents = {\n moveHandler: (e: MouseEvent) => onMove(e.clientX),\n upHandler: (e: MouseEvent) => {\n contextDocument?.removeEventListener(\n 'mousemove',\n mouseEvents.moveHandler\n )\n contextDocument?.removeEventListener(\n 'mouseup',\n mouseEvents.upHandler\n )\n onEnd(e.clientX)\n },\n }\n\n const touchEvents = {\n moveHandler: (e: TouchEvent) => {\n if (e.cancelable) {\n e.preventDefault()\n e.stopPropagation()\n }\n onMove(e.touches[0]!.clientX)\n return false\n },\n upHandler: (e: TouchEvent) => {\n contextDocument?.removeEventListener(\n 'touchmove',\n touchEvents.moveHandler\n )\n contextDocument?.removeEventListener(\n 'touchend',\n touchEvents.upHandler\n )\n if (e.cancelable) {\n e.preventDefault()\n e.stopPropagation()\n }\n onEnd(e.touches[0]?.clientX)\n },\n }\n\n const passiveIfSupported = passiveEventSupported()\n ? { passive: false }\n : false\n\n if (isTouchStartEvent(e)) {\n contextDocument?.addEventListener(\n 'touchmove',\n touchEvents.moveHandler,\n passiveIfSupported\n )\n contextDocument?.addEventListener(\n 'touchend',\n touchEvents.upHandler,\n passiveIfSupported\n )\n } else {\n contextDocument?.addEventListener(\n 'mousemove',\n mouseEvents.moveHandler,\n passiveIfSupported\n )\n contextDocument?.addEventListener(\n 'mouseup',\n mouseEvents.upHandler,\n passiveIfSupported\n )\n }\n\n table.setColumnSizingInfo(old => ({\n ...old,\n startOffset: clientX,\n startSize,\n deltaOffset: 0,\n deltaPercentage: 0,\n columnSizingStart,\n isResizingColumn: column.id,\n }))\n }\n }\n },\n\n createTable: (table: Table): void => {\n table.setColumnSizing = updater =>\n table.options.onColumnSizingChange?.(updater)\n table.setColumnSizingInfo = updater =>\n table.options.onColumnSizingInfoChange?.(updater)\n table.resetColumnSizing = defaultState => {\n table.setColumnSizing(\n defaultState ? {} : table.initialState.columnSizing ?? {}\n )\n }\n table.resetHeaderSizeInfo = defaultState => {\n table.setColumnSizingInfo(\n defaultState\n ? getDefaultColumnSizingInfoState()\n : table.initialState.columnSizingInfo ??\n getDefaultColumnSizingInfoState()\n )\n }\n table.getTotalSize = () =>\n table.getHeaderGroups()[0]?.headers.reduce((sum, header) => {\n return sum + header.getSize()\n }, 0) ?? 0\n table.getLeftTotalSize = () =>\n table.getLeftHeaderGroups()[0]?.headers.reduce((sum, header) => {\n return sum + header.getSize()\n }, 0) ?? 0\n table.getCenterTotalSize = () =>\n table.getCenterHeaderGroups()[0]?.headers.reduce((sum, header) => {\n return sum + header.getSize()\n }, 0) ?? 0\n table.getRightTotalSize = () =>\n table.getRightHeaderGroups()[0]?.headers.reduce((sum, header) => {\n return sum + header.getSize()\n }, 0) ?? 0\n },\n}\n\nlet passiveSupported: boolean | null = null\nexport function passiveEventSupported() {\n if (typeof passiveSupported === 'boolean') return passiveSupported\n\n let supported = false\n try {\n const options = {\n get passive() {\n supported = true\n return false\n },\n }\n\n const noop = () => {}\n\n window.addEventListener('test', noop, options)\n window.removeEventListener('test', noop)\n } catch (err) {\n supported = false\n }\n passiveSupported = supported\n return passiveSupported\n}\n\nfunction isTouchStartEvent(e: unknown): e is TouchEvent {\n return (e as TouchEvent).type === 'touchstart'\n}\n","import { ColumnPinningPosition } from '..'\nimport {\n Cell,\n Column,\n OnChangeFn,\n Table,\n Updater,\n Row,\n RowData,\n TableFeature,\n} from '../types'\nimport { getMemoOptions, makeStateUpdater, memo } from '../utils'\n\nexport type VisibilityState = Record\n\nexport interface VisibilityTableState {\n columnVisibility: VisibilityState\n}\n\nexport interface VisibilityOptions {\n /**\n * Whether to enable column hiding. Defaults to `true`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#enablehiding)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n enableHiding?: boolean\n /**\n * If provided, this function will be called with an `updaterFn` when `state.columnVisibility` 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-visibility#oncolumnvisibilitychange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n onColumnVisibilityChange?: OnChangeFn\n}\n\nexport type VisibilityDefaultOptions = Pick<\n VisibilityOptions,\n 'onColumnVisibilityChange'\n>\n\nexport interface VisibilityInstance {\n /**\n * If column pinning, returns a flat array of leaf-node columns that are visible in the unpinned/center portion of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getcentervisibleleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getCenterVisibleLeafColumns: () => Column[]\n /**\n * Returns whether all columns are visible\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getisallcolumnsvisible)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getIsAllColumnsVisible: () => boolean\n /**\n * Returns whether any columns are visible\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getissomecolumnsvisible)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getIsSomeColumnsVisible: () => boolean\n /**\n * If column pinning, returns a flat array of leaf-node columns that are visible in the left portion of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getleftvisibleleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getLeftVisibleLeafColumns: () => Column[]\n /**\n * If column pinning, returns a flat array of leaf-node columns that are visible in the right portion of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getrightvisibleleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getRightVisibleLeafColumns: () => Column[]\n /**\n * Returns a handler for toggling the visibility of all columns, meant to be bound to a `input[type=checkbox]` element.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#gettoggleallcolumnsvisibilityhandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getToggleAllColumnsVisibilityHandler: () => (event: unknown) => void\n /**\n * Returns a flat array of columns that are visible, including parent columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getvisibleflatcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getVisibleFlatColumns: () => Column[]\n /**\n * Returns a flat array of leaf-node columns that are visible.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getvisibleleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getVisibleLeafColumns: () => Column[]\n /**\n * Resets the column visibility state to the initial state. If `defaultState` is provided, the state will be reset to `{}`\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#resetcolumnvisibility)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n resetColumnVisibility: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.columnVisibility` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#setcolumnvisibility)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n setColumnVisibility: (updater: Updater) => void\n /**\n * Toggles the visibility of all columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#toggleallcolumnsvisible)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n toggleAllColumnsVisible: (value?: boolean) => void\n}\n\nexport interface VisibilityColumnDef {\n enableHiding?: boolean\n}\n\nexport interface VisibilityRow {\n _getAllVisibleCells: () => Cell[]\n /**\n * Returns an array of cells that account for column visibility for the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getvisiblecells)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getVisibleCells: () => Cell[]\n}\n\nexport interface VisibilityColumn {\n /**\n * Returns whether the column can be hidden\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getcanhide)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getCanHide: () => boolean\n /**\n * Returns whether the column is visible\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#getisvisible)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getIsVisible: () => boolean\n /**\n * Returns a function that can be used to toggle the column visibility. This function can be used to bind to an event handler to a checkbox.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#gettogglevisibilityhandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n getToggleVisibilityHandler: () => (event: unknown) => void\n /**\n * Toggles the visibility of the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/column-visibility#togglevisibility)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-visibility)\n */\n toggleVisibility: (value?: boolean) => void\n}\n\n//\n\nexport const ColumnVisibility: TableFeature = {\n getInitialState: (state): VisibilityTableState => {\n return {\n columnVisibility: {},\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): VisibilityDefaultOptions => {\n return {\n onColumnVisibilityChange: makeStateUpdater('columnVisibility', table),\n }\n },\n\n createColumn: (\n column: Column,\n table: Table\n ): void => {\n column.toggleVisibility = value => {\n if (column.getCanHide()) {\n table.setColumnVisibility(old => ({\n ...old,\n [column.id]: value ?? !column.getIsVisible(),\n }))\n }\n }\n column.getIsVisible = () => {\n const childColumns = column.columns\n return (\n (childColumns.length\n ? childColumns.some(c => c.getIsVisible())\n : table.getState().columnVisibility?.[column.id]) ?? true\n )\n }\n\n column.getCanHide = () => {\n return (\n (column.columnDef.enableHiding ?? true) &&\n (table.options.enableHiding ?? true)\n )\n }\n column.getToggleVisibilityHandler = () => {\n return (e: unknown) => {\n column.toggleVisibility?.(\n ((e as MouseEvent).target as HTMLInputElement).checked\n )\n }\n }\n },\n\n createRow: (\n row: Row,\n table: Table\n ): void => {\n row._getAllVisibleCells = memo(\n () => [row.getAllCells(), table.getState().columnVisibility],\n cells => {\n return cells.filter(cell => cell.column.getIsVisible())\n },\n getMemoOptions(table.options, 'debugRows', '_getAllVisibleCells')\n )\n row.getVisibleCells = memo(\n () => [\n row.getLeftVisibleCells(),\n row.getCenterVisibleCells(),\n row.getRightVisibleCells(),\n ],\n (left, center, right) => [...left, ...center, ...right],\n getMemoOptions(table.options, 'debugRows', 'getVisibleCells')\n )\n },\n\n createTable: (table: Table): void => {\n const makeVisibleColumnsMethod = (\n key: string,\n getColumns: () => Column[]\n ): (() => Column[]) => {\n return memo(\n () => [\n getColumns(),\n getColumns()\n .filter(d => d.getIsVisible())\n .map(d => d.id)\n .join('_'),\n ],\n columns => {\n return columns.filter(d => d.getIsVisible?.())\n },\n getMemoOptions(table.options, 'debugColumns', key)\n )\n }\n\n table.getVisibleFlatColumns = makeVisibleColumnsMethod(\n 'getVisibleFlatColumns',\n () => table.getAllFlatColumns()\n )\n table.getVisibleLeafColumns = makeVisibleColumnsMethod(\n 'getVisibleLeafColumns',\n () => table.getAllLeafColumns()\n )\n table.getLeftVisibleLeafColumns = makeVisibleColumnsMethod(\n 'getLeftVisibleLeafColumns',\n () => table.getLeftLeafColumns()\n )\n table.getRightVisibleLeafColumns = makeVisibleColumnsMethod(\n 'getRightVisibleLeafColumns',\n () => table.getRightLeafColumns()\n )\n table.getCenterVisibleLeafColumns = makeVisibleColumnsMethod(\n 'getCenterVisibleLeafColumns',\n () => table.getCenterLeafColumns()\n )\n\n table.setColumnVisibility = updater =>\n table.options.onColumnVisibilityChange?.(updater)\n\n table.resetColumnVisibility = defaultState => {\n table.setColumnVisibility(\n defaultState ? {} : table.initialState.columnVisibility ?? {}\n )\n }\n\n table.toggleAllColumnsVisible = value => {\n value = value ?? !table.getIsAllColumnsVisible()\n\n table.setColumnVisibility(\n table.getAllLeafColumns().reduce(\n (obj, column) => ({\n ...obj,\n [column.id]: !value ? !column.getCanHide?.() : value,\n }),\n {}\n )\n )\n }\n\n table.getIsAllColumnsVisible = () =>\n !table.getAllLeafColumns().some(column => !column.getIsVisible?.())\n\n table.getIsSomeColumnsVisible = () =>\n table.getAllLeafColumns().some(column => column.getIsVisible?.())\n\n table.getToggleAllColumnsVisibilityHandler = () => {\n return (e: unknown) => {\n table.toggleAllColumnsVisible(\n ((e as MouseEvent).target as HTMLInputElement)?.checked\n )\n }\n }\n },\n}\n\nexport function _getVisibleLeafColumns(\n table: Table,\n position?: ColumnPinningPosition | 'center'\n) {\n return !position\n ? table.getVisibleLeafColumns()\n : position === 'center'\n ? table.getCenterVisibleLeafColumns()\n : position === 'left'\n ? table.getLeftVisibleLeafColumns()\n : table.getRightVisibleLeafColumns()\n}\n","import { RowModel } from '..'\nimport { Table, RowData, TableFeature } from '../types'\n\nexport interface GlobalFacetingInstance {\n _getGlobalFacetedMinMaxValues?: () => undefined | [number, number]\n _getGlobalFacetedRowModel?: () => RowModel\n _getGlobalFacetedUniqueValues?: () => Map\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\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\n}\n\n//\n\nexport const GlobalFaceting: TableFeature = {\n createTable: (table: Table): 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","import {\n OnChangeFn,\n Table,\n Row,\n RowModel,\n Updater,\n RowData,\n TableFeature,\n} from '../types'\nimport { getMemoOptions, makeStateUpdater, memo } from '../utils'\n\nexport type RowSelectionState = Record\n\nexport interface RowSelectionTableState {\n rowSelection: RowSelectionState\n}\n\nexport interface RowSelectionOptions {\n /**\n * - Enables/disables multiple row selection for all rows in the table OR\n * - A function that given a row, returns whether to enable/disable multiple row selection for that row's children/grandchildren\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#enablemultirowselection)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n enableMultiRowSelection?: boolean | ((row: Row) => boolean)\n /**\n * - Enables/disables row selection for all rows in the table OR\n * - A function that given a row, returns whether to enable/disable row selection for that row\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#enablerowselection)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n enableRowSelection?: boolean | ((row: Row) => boolean)\n /**\n * Enables/disables automatic sub-row selection when a parent row is selected, or a function that enables/disables automatic sub-row selection for each row.\n * (Use in combination with expanding or grouping features)\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#enablesubrowselection)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n enableSubRowSelection?: boolean | ((row: Row) => boolean)\n /**\n * If provided, this function will be called with an `updaterFn` when `state.rowSelection` 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/row-selection#onrowselectionchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n onRowSelectionChange?: OnChangeFn\n // enableGroupingRowSelection?:\n // | boolean\n // | ((\n // row: Row\n // ) => boolean)\n // isAdditiveSelectEvent?: (e: unknown) => boolean\n // isInclusiveSelectEvent?: (e: unknown) => boolean\n // selectRowsFn?: (\n // table: Table,\n // rowModel: RowModel\n // ) => RowModel\n}\n\nexport interface RowSelectionRow {\n /**\n * Returns whether or not the row can multi-select.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getcanmultiselect)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getCanMultiSelect: () => boolean\n /**\n * Returns whether or not the row can be selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getcanselect)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getCanSelect: () => boolean\n /**\n * Returns whether or not the row can select sub rows automatically when the parent row is selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getcanselectsubrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getCanSelectSubRows: () => boolean\n /**\n * Returns whether or not all of the row's sub rows are selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getisallsubrowsselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getIsAllSubRowsSelected: () => boolean\n /**\n * Returns whether or not the row is selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getisselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getIsSelected: () => boolean\n /**\n * Returns whether or not some of the row's sub rows are selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getissomeselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getIsSomeSelected: () => boolean\n /**\n * Returns a handler that can be used to toggle the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#gettoggleselectedhandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getToggleSelectedHandler: () => (event: unknown) => void\n /**\n * Selects/deselects the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#toggleselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n toggleSelected: (value?: boolean, opts?: { selectChildren?: boolean }) => void\n}\n\nexport interface RowSelectionInstance {\n /**\n * Returns the row model of all rows that are selected after filtering has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getfilteredselectedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getFilteredSelectedRowModel: () => RowModel\n /**\n * Returns the row model of all rows that are selected after grouping has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getgroupedselectedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getGroupedSelectedRowModel: () => RowModel\n /**\n * Returns whether or not all rows on the current page are selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getisallpagerowsselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getIsAllPageRowsSelected: () => boolean\n /**\n * Returns whether or not all rows in the table are selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getisallrowsselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getIsAllRowsSelected: () => boolean\n /**\n * Returns whether or not any rows on the current page are selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getissomepagerowsselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getIsSomePageRowsSelected: () => boolean\n /**\n * Returns whether or not any rows in the table are selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getissomerowsselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getIsSomeRowsSelected: () => boolean\n /**\n * Returns the core row model of all rows before row selection has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getpreselectedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getPreSelectedRowModel: () => RowModel\n /**\n * Returns the row model of all rows that are selected.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#getselectedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getSelectedRowModel: () => RowModel\n /**\n * Returns a handler that can be used to toggle all rows on the current page.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#gettoggleallpagerowsselectedhandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getToggleAllPageRowsSelectedHandler: () => (event: unknown) => void\n /**\n * Returns a handler that can be used to toggle all rows in the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#gettoggleallrowsselectedhandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n getToggleAllRowsSelectedHandler: () => (event: unknown) => void\n /**\n * Resets the **rowSelection** state to the `initialState.rowSelection`, 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/row-selection#resetrowselection)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n resetRowSelection: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.rowSelection` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#setrowselection)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n setRowSelection: (updater: Updater) => void\n /**\n * Selects/deselects all rows on the current page.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#toggleallpagerowsselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n toggleAllPageRowsSelected: (value?: boolean) => void\n /**\n * Selects/deselects all rows in the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-selection#toggleallrowsselected)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-selection)\n */\n toggleAllRowsSelected: (value?: boolean) => void\n}\n\n//\n\nexport const RowSelection: TableFeature = {\n getInitialState: (state): RowSelectionTableState => {\n return {\n rowSelection: {},\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): RowSelectionOptions => {\n return {\n onRowSelectionChange: makeStateUpdater('rowSelection', table),\n enableRowSelection: true,\n enableMultiRowSelection: true,\n enableSubRowSelection: true,\n // enableGroupingRowSelection: false,\n // isAdditiveSelectEvent: (e: unknown) => !!e.metaKey,\n // isInclusiveSelectEvent: (e: unknown) => !!e.shiftKey,\n }\n },\n\n createTable: (table: Table): void => {\n table.setRowSelection = updater =>\n table.options.onRowSelectionChange?.(updater)\n table.resetRowSelection = defaultState =>\n table.setRowSelection(\n defaultState ? {} : table.initialState.rowSelection ?? {}\n )\n table.toggleAllRowsSelected = value => {\n table.setRowSelection(old => {\n value =\n typeof value !== 'undefined' ? value : !table.getIsAllRowsSelected()\n\n const rowSelection = { ...old }\n\n const preGroupedFlatRows = table.getPreGroupedRowModel().flatRows\n\n // We don't use `mutateRowIsSelected` here for performance reasons.\n // All of the rows are flat already, so it wouldn't be worth it\n if (value) {\n preGroupedFlatRows.forEach(row => {\n if (!row.getCanSelect()) {\n return\n }\n rowSelection[row.id] = true\n })\n } else {\n preGroupedFlatRows.forEach(row => {\n delete rowSelection[row.id]\n })\n }\n\n return rowSelection\n })\n }\n table.toggleAllPageRowsSelected = value =>\n table.setRowSelection(old => {\n const resolvedValue =\n typeof value !== 'undefined'\n ? value\n : !table.getIsAllPageRowsSelected()\n\n const rowSelection: RowSelectionState = { ...old }\n\n table.getRowModel().rows.forEach(row => {\n mutateRowIsSelected(rowSelection, row.id, resolvedValue, true, table)\n })\n\n return rowSelection\n })\n\n // addRowSelectionRange: rowId => {\n // const {\n // rows,\n // rowsById,\n // options: { selectGroupingRows, selectSubRows },\n // } = table\n\n // const findSelectedRow = (rows: Row[]) => {\n // let found\n // rows.find(d => {\n // if (d.getIsSelected()) {\n // found = d\n // return true\n // }\n // const subFound = findSelectedRow(d.subRows || [])\n // if (subFound) {\n // found = subFound\n // return true\n // }\n // return false\n // })\n // return found\n // }\n\n // const firstRow = findSelectedRow(rows) || rows[0]\n // const lastRow = rowsById[rowId]\n\n // let include = false\n // const selectedRowIds = {}\n\n // const addRow = (row: Row) => {\n // mutateRowIsSelected(selectedRowIds, row.id, true, {\n // rowsById,\n // selectGroupingRows: selectGroupingRows!,\n // selectSubRows: selectSubRows!,\n // })\n // }\n\n // table.rows.forEach(row => {\n // const isFirstRow = row.id === firstRow.id\n // const isLastRow = row.id === lastRow.id\n\n // if (isFirstRow || isLastRow) {\n // if (!include) {\n // include = true\n // } else if (include) {\n // addRow(row)\n // include = false\n // }\n // }\n\n // if (include) {\n // addRow(row)\n // }\n // })\n\n // table.setRowSelection(selectedRowIds)\n // },\n table.getPreSelectedRowModel = () => table.getCoreRowModel()\n table.getSelectedRowModel = memo(\n () => [table.getState().rowSelection, table.getCoreRowModel()],\n (rowSelection, rowModel) => {\n if (!Object.keys(rowSelection).length) {\n return {\n rows: [],\n flatRows: [],\n rowsById: {},\n }\n }\n\n return selectRowsFn(table, rowModel)\n },\n getMemoOptions(table.options, 'debugTable', 'getSelectedRowModel')\n )\n\n table.getFilteredSelectedRowModel = memo(\n () => [table.getState().rowSelection, table.getFilteredRowModel()],\n (rowSelection, rowModel) => {\n if (!Object.keys(rowSelection).length) {\n return {\n rows: [],\n flatRows: [],\n rowsById: {},\n }\n }\n\n return selectRowsFn(table, rowModel)\n },\n getMemoOptions(table.options, 'debugTable', 'getFilteredSelectedRowModel')\n )\n\n table.getGroupedSelectedRowModel = memo(\n () => [table.getState().rowSelection, table.getSortedRowModel()],\n (rowSelection, rowModel) => {\n if (!Object.keys(rowSelection).length) {\n return {\n rows: [],\n flatRows: [],\n rowsById: {},\n }\n }\n\n return selectRowsFn(table, rowModel)\n },\n getMemoOptions(table.options, 'debugTable', 'getGroupedSelectedRowModel')\n )\n\n ///\n\n // getGroupingRowCanSelect: rowId => {\n // const row = table.getRow(rowId)\n\n // if (!row) {\n // throw new Error()\n // }\n\n // if (typeof table.options.enableGroupingRowSelection === 'function') {\n // return table.options.enableGroupingRowSelection(row)\n // }\n\n // return table.options.enableGroupingRowSelection ?? false\n // },\n\n table.getIsAllRowsSelected = () => {\n const preGroupedFlatRows = table.getFilteredRowModel().flatRows\n const { rowSelection } = table.getState()\n\n let isAllRowsSelected = Boolean(\n preGroupedFlatRows.length && Object.keys(rowSelection).length\n )\n\n if (isAllRowsSelected) {\n if (\n preGroupedFlatRows.some(\n row => row.getCanSelect() && !rowSelection[row.id]\n )\n ) {\n isAllRowsSelected = false\n }\n }\n\n return isAllRowsSelected\n }\n\n table.getIsAllPageRowsSelected = () => {\n const paginationFlatRows = table\n .getPaginationRowModel()\n .flatRows.filter(row => row.getCanSelect())\n const { rowSelection } = table.getState()\n\n let isAllPageRowsSelected = !!paginationFlatRows.length\n\n if (\n isAllPageRowsSelected &&\n paginationFlatRows.some(row => !rowSelection[row.id])\n ) {\n isAllPageRowsSelected = false\n }\n\n return isAllPageRowsSelected\n }\n\n table.getIsSomeRowsSelected = () => {\n const totalSelected = Object.keys(\n table.getState().rowSelection ?? {}\n ).length\n return (\n totalSelected > 0 &&\n totalSelected < table.getFilteredRowModel().flatRows.length\n )\n }\n\n table.getIsSomePageRowsSelected = () => {\n const paginationFlatRows = table.getPaginationRowModel().flatRows\n return table.getIsAllPageRowsSelected()\n ? false\n : paginationFlatRows\n .filter(row => row.getCanSelect())\n .some(d => d.getIsSelected() || d.getIsSomeSelected())\n }\n\n table.getToggleAllRowsSelectedHandler = () => {\n return (e: unknown) => {\n table.toggleAllRowsSelected(\n ((e as MouseEvent).target as HTMLInputElement).checked\n )\n }\n }\n\n table.getToggleAllPageRowsSelectedHandler = () => {\n return (e: unknown) => {\n table.toggleAllPageRowsSelected(\n ((e as MouseEvent).target as HTMLInputElement).checked\n )\n }\n }\n },\n\n createRow: (\n row: Row,\n table: Table\n ): void => {\n row.toggleSelected = (value, opts) => {\n const isSelected = row.getIsSelected()\n\n table.setRowSelection(old => {\n value = typeof value !== 'undefined' ? value : !isSelected\n\n if (row.getCanSelect() && isSelected === value) {\n return old\n }\n\n const selectedRowIds = { ...old }\n\n mutateRowIsSelected(\n selectedRowIds,\n row.id,\n value,\n opts?.selectChildren ?? true,\n table\n )\n\n return selectedRowIds\n })\n }\n row.getIsSelected = () => {\n const { rowSelection } = table.getState()\n return isRowSelected(row, rowSelection)\n }\n\n row.getIsSomeSelected = () => {\n const { rowSelection } = table.getState()\n return isSubRowSelected(row, rowSelection, table) === 'some'\n }\n\n row.getIsAllSubRowsSelected = () => {\n const { rowSelection } = table.getState()\n return isSubRowSelected(row, rowSelection, table) === 'all'\n }\n\n row.getCanSelect = () => {\n if (typeof table.options.enableRowSelection === 'function') {\n return table.options.enableRowSelection(row)\n }\n\n return table.options.enableRowSelection ?? true\n }\n\n row.getCanSelectSubRows = () => {\n if (typeof table.options.enableSubRowSelection === 'function') {\n return table.options.enableSubRowSelection(row)\n }\n\n return table.options.enableSubRowSelection ?? true\n }\n\n row.getCanMultiSelect = () => {\n if (typeof table.options.enableMultiRowSelection === 'function') {\n return table.options.enableMultiRowSelection(row)\n }\n\n return table.options.enableMultiRowSelection ?? true\n }\n row.getToggleSelectedHandler = () => {\n const canSelect = row.getCanSelect()\n\n return (e: unknown) => {\n if (!canSelect) return\n row.toggleSelected(\n ((e as MouseEvent).target as HTMLInputElement)?.checked\n )\n }\n }\n },\n}\n\nconst mutateRowIsSelected = (\n selectedRowIds: Record,\n id: string,\n value: boolean,\n includeChildren: boolean,\n table: Table\n) => {\n const row = table.getRow(id, true)\n\n // const isGrouped = row.getIsGrouped()\n\n // if ( // TODO: enforce grouping row selection rules\n // !isGrouped ||\n // (isGrouped && table.options.enableGroupingRowSelection)\n // ) {\n if (value) {\n if (!row.getCanMultiSelect()) {\n Object.keys(selectedRowIds).forEach(key => delete selectedRowIds[key])\n }\n if (row.getCanSelect()) {\n selectedRowIds[id] = true\n }\n } else {\n delete selectedRowIds[id]\n }\n // }\n\n if (includeChildren && row.subRows?.length && row.getCanSelectSubRows()) {\n row.subRows.forEach(row =>\n mutateRowIsSelected(selectedRowIds, row.id, value, includeChildren, table)\n )\n }\n}\n\nexport function selectRowsFn(\n table: Table,\n rowModel: RowModel\n): RowModel {\n const rowSelection = table.getState().rowSelection\n\n const newSelectedFlatRows: Row[] = []\n const newSelectedRowsById: Record> = {}\n\n // Filters top level and nested rows\n const recurseRows = (rows: Row[], depth = 0): Row[] => {\n return rows\n .map(row => {\n const isSelected = isRowSelected(row, rowSelection)\n\n if (isSelected) {\n newSelectedFlatRows.push(row)\n newSelectedRowsById[row.id] = row\n }\n\n if (row.subRows?.length) {\n row = {\n ...row,\n subRows: recurseRows(row.subRows, depth + 1),\n }\n }\n\n if (isSelected) {\n return row\n }\n })\n .filter(Boolean) as Row[]\n }\n\n return {\n rows: recurseRows(rowModel.rows),\n flatRows: newSelectedFlatRows,\n rowsById: newSelectedRowsById,\n }\n}\n\nexport function isRowSelected(\n row: Row,\n selection: Record\n): boolean {\n return selection[row.id] ?? false\n}\n\nexport function isSubRowSelected(\n row: Row,\n selection: Record,\n table: Table\n): boolean | 'some' | 'all' {\n if (!row.subRows?.length) return false\n\n let allChildrenSelected = true\n let someSelected = false\n\n row.subRows.forEach(subRow => {\n // Bail out early if we know both of these\n if (someSelected && !allChildrenSelected) {\n return\n }\n\n if (subRow.getCanSelect()) {\n if (isRowSelected(subRow, selection)) {\n someSelected = true\n } else {\n allChildrenSelected = false\n }\n }\n\n // Check row selection of nested subrows\n if (subRow.subRows && subRow.subRows.length) {\n const subRowChildrenSelected = isSubRowSelected(subRow, selection, table)\n if (subRowChildrenSelected === 'all') {\n someSelected = true\n } else if (subRowChildrenSelected === 'some') {\n someSelected = true\n allChildrenSelected = false\n } else {\n allChildrenSelected = false\n }\n }\n })\n\n return allChildrenSelected ? 'all' : someSelected ? 'some' : false\n}\n","import { SortingFn } from './features/RowSorting'\n\nexport const reSplitAlphaNumeric = /([0-9]+)/gm\n\nconst alphanumeric: SortingFn = (rowA, rowB, columnId) => {\n return compareAlphanumeric(\n toString(rowA.getValue(columnId)).toLowerCase(),\n toString(rowB.getValue(columnId)).toLowerCase()\n )\n}\n\nconst alphanumericCaseSensitive: SortingFn = (rowA, rowB, columnId) => {\n return compareAlphanumeric(\n toString(rowA.getValue(columnId)),\n toString(rowB.getValue(columnId))\n )\n}\n\n// The text filter is more basic (less numeric support)\n// but is much faster\nconst text: SortingFn = (rowA, rowB, columnId) => {\n return compareBasic(\n toString(rowA.getValue(columnId)).toLowerCase(),\n toString(rowB.getValue(columnId)).toLowerCase()\n )\n}\n\n// The text filter is more basic (less numeric support)\n// but is much faster\nconst textCaseSensitive: SortingFn = (rowA, rowB, columnId) => {\n return compareBasic(\n toString(rowA.getValue(columnId)),\n toString(rowB.getValue(columnId))\n )\n}\n\nconst datetime: SortingFn = (rowA, rowB, columnId) => {\n const a = rowA.getValue(columnId)\n const b = rowB.getValue(columnId)\n\n // Can handle nullish values\n // Use > and < because == (and ===) doesn't work with\n // Date objects (would require calling getTime()).\n return a > b ? 1 : a < b ? -1 : 0\n}\n\nconst basic: SortingFn = (rowA, rowB, columnId) => {\n return compareBasic(rowA.getValue(columnId), rowB.getValue(columnId))\n}\n\n// Utils\n\nfunction compareBasic(a: any, b: any) {\n return a === b ? 0 : a > b ? 1 : -1\n}\n\nfunction toString(a: any) {\n if (typeof a === 'number') {\n if (isNaN(a) || a === Infinity || a === -Infinity) {\n return ''\n }\n return String(a)\n }\n if (typeof a === 'string') {\n return a\n }\n return ''\n}\n\n// Mixed sorting is slow, but very inclusive of many edge cases.\n// It handles numbers, mixed alphanumeric combinations, and even\n// null, undefined, and Infinity\nfunction compareAlphanumeric(aStr: string, bStr: string) {\n // Split on number groups, but keep the delimiter\n // Then remove falsey split values\n const a = aStr.split(reSplitAlphaNumeric).filter(Boolean)\n const b = bStr.split(reSplitAlphaNumeric).filter(Boolean)\n\n // While\n while (a.length && b.length) {\n const aa = a.shift()!\n const bb = b.shift()!\n\n const an = parseInt(aa, 10)\n const bn = parseInt(bb, 10)\n\n const combo = [an, bn].sort()\n\n // Both are string\n if (isNaN(combo[0]!)) {\n if (aa > bb) {\n return 1\n }\n if (bb > aa) {\n return -1\n }\n continue\n }\n\n // One is a string, one is a number\n if (isNaN(combo[1]!)) {\n return isNaN(an) ? -1 : 1\n }\n\n // Both are numbers\n if (an > bn) {\n return 1\n }\n if (bn > an) {\n return -1\n }\n }\n\n return a.length - b.length\n}\n\n// Exports\n\nexport const sortingFns = {\n alphanumeric,\n alphanumericCaseSensitive,\n text,\n textCaseSensitive,\n datetime,\n basic,\n}\n\nexport type BuiltInSortingFn = keyof typeof sortingFns\n","import { functionalUpdate, getMemoOptions, memo, RequiredKeys } from '../utils'\n\nimport {\n Updater,\n TableOptionsResolved,\n TableState,\n Table,\n InitialTableState,\n Row,\n Column,\n RowModel,\n ColumnDef,\n TableOptions,\n RowData,\n TableMeta,\n ColumnDefResolved,\n GroupColumnDef,\n TableFeature,\n} from '../types'\n\n//\nimport { createColumn } from './column'\nimport { Headers } from './headers'\n//\n\nimport { ColumnFaceting } from '../features/ColumnFaceting'\nimport { ColumnFiltering } from '../features/ColumnFiltering'\nimport { ColumnGrouping } from '../features/ColumnGrouping'\nimport { ColumnOrdering } from '../features/ColumnOrdering'\nimport { ColumnPinning } from '../features/ColumnPinning'\nimport { ColumnSizing } from '../features/ColumnSizing'\nimport { ColumnVisibility } from '../features/ColumnVisibility'\nimport { GlobalFaceting } from '../features/GlobalFaceting'\nimport { GlobalFiltering } from '../features/GlobalFiltering'\nimport { RowExpanding } from '../features/RowExpanding'\nimport { RowPagination } from '../features/RowPagination'\nimport { RowPinning } from '../features/RowPinning'\nimport { RowSelection } from '../features/RowSelection'\nimport { RowSorting } from '../features/RowSorting'\n\nconst builtInFeatures = [\n Headers,\n ColumnVisibility,\n ColumnOrdering,\n ColumnPinning,\n ColumnFaceting,\n ColumnFiltering,\n GlobalFaceting, //depends on ColumnFaceting\n GlobalFiltering, //depends on ColumnFiltering\n RowSorting,\n ColumnGrouping, //depends on RowSorting\n RowExpanding,\n RowPagination,\n RowPinning,\n RowSelection,\n ColumnSizing,\n] as const\n\n//\n\nexport interface CoreTableState {}\n\nexport interface CoreOptions {\n /**\n * An array of extra features that you can add to the table instance.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#_features)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n _features?: TableFeature[]\n /**\n * Set this option to override any of the `autoReset...` feature options.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#autoresetall)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n autoResetAll?: boolean\n /**\n * The array of column defs to use for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#columns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n columns: ColumnDef[]\n /**\n * The data for the table to display. This array should match the type you provided to `table.setRowType<...>`. Columns can access this data via string/index or a functional accessor. When the `data` option changes reference, the table will reprocess the data.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#data)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n data: TData[]\n /**\n * Set this option to `true` to output all debugging information to the console.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#debugall)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n debugAll?: boolean\n /**\n * Set this option to `true` to output cell debugging information to the console.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#debugcells]\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n debugCells?: boolean\n /**\n * Set this option to `true` to output column debugging information to the console.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#debugcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n debugColumns?: boolean\n /**\n * Set this option to `true` to output header debugging information to the console.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#debugheaders)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n debugHeaders?: boolean\n /**\n * Set this option to `true` to output row debugging information to the console.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#debugrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n debugRows?: boolean\n /**\n * Set this option to `true` to output table debugging information to the console.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#debugtable)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n debugTable?: boolean\n /**\n * Default column options to use for all column defs supplied to the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#defaultcolumn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n defaultColumn?: Partial>\n /**\n * This required option is a factory for a function that computes and returns the core row model for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getcorerowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getCoreRowModel: (table: Table) => () => RowModel\n /**\n * This optional function is used to derive a unique ID for any given row. If not provided the rows index is used (nested rows join together with `.` using their grandparents' index eg. `index.index.index`). If you need to identify individual rows that are originating from any server-side operations, it's suggested you use this function to return an ID that makes sense regardless of network IO/ambiguity eg. a userId, taskId, database ID field, etc.\n * @example getRowId: row => row.userId\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getrowid)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getRowId?: (originalRow: TData, index: number, parent?: Row) => string\n /**\n * This optional function is used to access the sub rows for any given row. If you are using nested rows, you will need to use this function to return the sub rows object (or undefined) from the row.\n * @example getSubRows: row => row.subRows\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getsubrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getSubRows?: (originalRow: TData, index: number) => undefined | TData[]\n /**\n * Use this option to optionally pass initial state to the table. This state will be used when resetting various table states either automatically by the table (eg. `options.autoResetPageIndex`) or via functions like `table.resetRowSelection()`. Most reset function allow you optionally pass a flag to reset to a blank/default state instead of the initial state.\n *\n * Table state will not be reset when this object changes, which also means that the initial state object does not need to be stable.\n *\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#initialstate)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n initialState?: InitialTableState\n /**\n * This option is used to optionally implement the merging of table options.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#mergeoptions)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n mergeOptions?: (\n defaultOptions: TableOptions,\n options: Partial>\n ) => TableOptions\n /**\n * You can pass any object to `options.meta` and access it anywhere the `table` is available via `table.options.meta`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#meta)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n meta?: TableMeta\n /**\n * The `onStateChange` option can be used to optionally listen to state changes within the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#onstatechange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n onStateChange: (updater: Updater) => void\n /**\n * Value used when the desired value is not found in the data.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#renderfallbackvalue)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n renderFallbackValue: any\n /**\n * The `state` option can be used to optionally _control_ part or all of the table state. The state you pass here will merge with and overwrite the internal automatically-managed state to produce the final state for the table. You can also listen to state changes via the `onStateChange` option.\n * > Note: Any state passed in here will override both the internal state and any other `initialState` you provide.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#state)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n state: Partial\n}\n\nexport interface CoreInstance {\n _features: readonly TableFeature[]\n _getAllFlatColumnsById: () => Record>\n _getColumnDefs: () => ColumnDef[]\n _getCoreRowModel?: () => RowModel\n _getDefaultColumnDef: () => Partial>\n _getRowId: (_: TData, index: number, parent?: Row) => string\n _queue: (cb: () => void) => void\n /**\n * Returns all columns in the table in their normalized and nested hierarchy.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getallcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getAllColumns: () => Column[]\n /**\n * Returns all columns in the table flattened to a single level.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getallflatcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getAllFlatColumns: () => Column[]\n /**\n * Returns all leaf-node columns in the table flattened to a single level. This does not include parent columns.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getallleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getAllLeafColumns: () => Column[]\n /**\n * Returns a single column by its ID.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getcolumn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getColumn: (columnId: string) => Column | undefined\n /**\n * Returns the core row model before any processing has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getcorerowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getCoreRowModel: () => RowModel\n /**\n * Returns the row with the given ID.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getrow)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getRow: (id: string, searchAll?: boolean) => Row\n /**\n * Returns the final model after all processing from other used features has been applied. This is the row model that is most commonly used for rendering.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getRowModel: () => RowModel\n /**\n * Call this function to get the table's current state. It's recommended to use this function and its state, especially when managing the table state manually. It is the exact same state used internally by the table for every feature and function it provides.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#getstate)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n getState: () => TableState\n /**\n * This is the resolved initial state of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#initialstate)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n initialState: TableState\n /**\n * A read-only reference to the table's current options.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#options)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n options: RequiredKeys, 'state'>\n /**\n * Call this function to reset the table state to the initial state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#reset)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n reset: () => void\n /**\n * This function can be used to update the table options.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#setoptions)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n setOptions: (newOptions: Updater>) => void\n /**\n * Call this function to update the table state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/table#setstate)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/tables)\n */\n setState: (updater: Updater) => void\n}\n\nexport function createTable(\n options: TableOptionsResolved\n): Table {\n if (\n process.env.NODE_ENV !== 'production' &&\n (options.debugAll || options.debugTable)\n ) {\n console.info('Creating Table Instance...')\n }\n\n const _features = [...builtInFeatures, ...(options._features ?? [])]\n\n let table = { _features } as unknown as Table\n\n const defaultOptions = table._features.reduce((obj, feature) => {\n return Object.assign(obj, feature.getDefaultOptions?.(table))\n }, {}) as TableOptionsResolved\n\n const mergeOptions = (options: TableOptionsResolved) => {\n if (table.options.mergeOptions) {\n return table.options.mergeOptions(defaultOptions, options)\n }\n\n return {\n ...defaultOptions,\n ...options,\n }\n }\n\n const coreInitialState: CoreTableState = {}\n\n let initialState = {\n ...coreInitialState,\n ...(options.initialState ?? {}),\n } as TableState\n\n table._features.forEach(feature => {\n initialState = (feature.getInitialState?.(initialState) ??\n initialState) as TableState\n })\n\n const queued: (() => void)[] = []\n let queuedTimeout = false\n\n const coreInstance: CoreInstance = {\n _features,\n options: {\n ...defaultOptions,\n ...options,\n },\n initialState,\n _queue: cb => {\n queued.push(cb)\n\n if (!queuedTimeout) {\n queuedTimeout = true\n\n // Schedule a microtask to run the queued callbacks after\n // the current call stack (render, etc) has finished.\n Promise.resolve()\n .then(() => {\n while (queued.length) {\n queued.shift()!()\n }\n queuedTimeout = false\n })\n .catch(error =>\n setTimeout(() => {\n throw error\n })\n )\n }\n },\n reset: () => {\n table.setState(table.initialState)\n },\n setOptions: updater => {\n const newOptions = functionalUpdate(updater, table.options)\n table.options = mergeOptions(newOptions) as RequiredKeys<\n TableOptionsResolved,\n 'state'\n >\n },\n\n getState: () => {\n return table.options.state as TableState\n },\n\n setState: (updater: Updater) => {\n table.options.onStateChange?.(updater)\n },\n\n _getRowId: (row: TData, index: number, parent?: Row) =>\n table.options.getRowId?.(row, index, parent) ??\n `${parent ? [parent.id, index].join('.') : index}`,\n\n getCoreRowModel: () => {\n if (!table._getCoreRowModel) {\n table._getCoreRowModel = table.options.getCoreRowModel(table)\n }\n\n return table._getCoreRowModel!()\n },\n\n // The final calls start at the bottom of the model,\n // expanded rows, which then work their way up\n\n getRowModel: () => {\n return table.getPaginationRowModel()\n },\n //in next version, we should just pass in the row model as the optional 2nd arg\n getRow: (id: string, searchAll?: boolean) => {\n let row = (\n searchAll ? table.getPrePaginationRowModel() : table.getRowModel()\n ).rowsById[id]\n\n if (!row) {\n row = table.getCoreRowModel().rowsById[id]\n if (!row) {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(`getRow could not find row with ID: ${id}`)\n }\n throw new Error()\n }\n }\n\n return row\n },\n _getDefaultColumnDef: memo(\n () => [table.options.defaultColumn],\n defaultColumn => {\n defaultColumn = (defaultColumn ?? {}) as Partial<\n ColumnDef\n >\n\n return {\n header: props => {\n const resolvedColumnDef = props.header.column\n .columnDef as ColumnDefResolved\n\n if (resolvedColumnDef.accessorKey) {\n return resolvedColumnDef.accessorKey\n }\n\n if (resolvedColumnDef.accessorFn) {\n return resolvedColumnDef.id\n }\n\n return null\n },\n // footer: props => props.header.column.id,\n cell: props => props.renderValue()?.toString?.() ?? null,\n ...table._features.reduce((obj, feature) => {\n return Object.assign(obj, feature.getDefaultColumnDef?.())\n }, {}),\n ...defaultColumn,\n } as Partial>\n },\n getMemoOptions(options, 'debugColumns', '_getDefaultColumnDef')\n ),\n\n _getColumnDefs: () => table.options.columns,\n\n getAllColumns: memo(\n () => [table._getColumnDefs()],\n columnDefs => {\n const recurseColumns = (\n columnDefs: ColumnDef[],\n parent?: Column,\n depth = 0\n ): Column[] => {\n return columnDefs.map(columnDef => {\n const column = createColumn(table, columnDef, depth, parent)\n\n const groupingColumnDef = columnDef as GroupColumnDef<\n TData,\n unknown\n >\n\n column.columns = groupingColumnDef.columns\n ? recurseColumns(groupingColumnDef.columns, column, depth + 1)\n : []\n\n return column\n })\n }\n\n return recurseColumns(columnDefs)\n },\n getMemoOptions(options, 'debugColumns', 'getAllColumns')\n ),\n\n getAllFlatColumns: memo(\n () => [table.getAllColumns()],\n allColumns => {\n return allColumns.flatMap(column => {\n return column.getFlatColumns()\n })\n },\n getMemoOptions(options, 'debugColumns', 'getAllFlatColumns')\n ),\n\n _getAllFlatColumnsById: memo(\n () => [table.getAllFlatColumns()],\n flatColumns => {\n return flatColumns.reduce(\n (acc, column) => {\n acc[column.id] = column\n return acc\n },\n {} as Record>\n )\n },\n getMemoOptions(options, 'debugColumns', 'getAllFlatColumnsById')\n ),\n\n getAllLeafColumns: memo(\n () => [table.getAllColumns(), table._getOrderColumnsFn()],\n (allColumns, orderColumns) => {\n let leafColumns = allColumns.flatMap(column => column.getLeafColumns())\n return orderColumns(leafColumns)\n },\n getMemoOptions(options, 'debugColumns', 'getAllLeafColumns')\n ),\n\n getColumn: columnId => {\n const column = table._getAllFlatColumnsById()[columnId]\n\n if (process.env.NODE_ENV !== 'production' && !column) {\n console.error(`[Table] Column with id '${columnId}' does not exist.`)\n }\n\n return column\n },\n }\n\n Object.assign(table, coreInstance)\n\n for (let index = 0; index < table._features.length; index++) {\n const feature = table._features[index]\n feature?.createTable?.(table)\n }\n\n return table\n}\n","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 {\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) => 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\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\n}\n\nexport interface GlobalFilterInstance {\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 | 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 | 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) => 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: (\n table: Table\n ): GlobalFilterOptions => {\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\n },\n\n createColumn: (\n column: Column,\n table: Table\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: (table: Table): 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","import { RowModel } from '..'\nimport {\n BuiltInSortingFn,\n reSplitAlphaNumeric,\n sortingFns,\n} from '../sortingFns'\n\nimport {\n Column,\n OnChangeFn,\n Table,\n Row,\n Updater,\n RowData,\n SortingFns,\n TableFeature,\n} from '../types'\n\nimport { isFunction, makeStateUpdater } from '../utils'\n\nexport type SortDirection = 'asc' | 'desc'\n\nexport interface ColumnSort {\n desc: boolean\n id: string\n}\n\nexport type SortingState = ColumnSort[]\n\nexport interface SortingTableState {\n sorting: SortingState\n}\n\nexport interface SortingFn {\n (rowA: Row, rowB: Row, columnId: string): number\n}\n\nexport type CustomSortingFns = Record<\n string,\n SortingFn\n>\n\nexport type SortingFnOption =\n | 'auto'\n | keyof SortingFns\n | BuiltInSortingFn\n | SortingFn\n\nexport interface SortingColumnDef {\n /**\n * Enables/Disables multi-sorting for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablemultisort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableMultiSort?: boolean\n /**\n * Enables/Disables sorting for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablesorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableSorting?: boolean\n /**\n * Inverts the order of the sorting for this column. This is useful for values that have an inverted best/worst scale where lower numbers are better, eg. a ranking (1st, 2nd, 3rd) or golf-like scoring\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#invertsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n invertSorting?: boolean\n /**\n * Set to `true` for sorting toggles on this column to start in the descending direction.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortdescfirst)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortDescFirst?: boolean\n /**\n * The sorting function to use with this column.\n * - A `string` referencing a built-in sorting function\n * - A custom sorting function\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortingfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortingFn?: SortingFnOption\n /**\n * The priority of undefined values when sorting this column.\n * - `false`\n * - Undefined values will be considered tied and need to be sorted by the next column filter or original index (whichever applies)\n * - `-1`\n * - Undefined values will be sorted with higher priority (ascending) (if ascending, undefined will appear on the beginning of the list)\n * - `1`\n * - Undefined values will be sorted with lower priority (descending) (if ascending, undefined will appear on the end of the list)\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortundefined)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortUndefined?: false | -1 | 1 | 'first' | 'last'\n}\n\nexport interface SortingColumn {\n /**\n * Removes this column from the table's sorting state\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#clearsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n clearSorting: () => void\n /**\n * Returns a sort direction automatically inferred based on the columns values.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getautosortdir)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getAutoSortDir: () => SortDirection\n /**\n * Returns a sorting function automatically inferred based on the columns values.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getautosortingfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getAutoSortingFn: () => SortingFn\n /**\n * Returns whether this column can be multi-sorted.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getcanmultisort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getCanMultiSort: () => boolean\n /**\n * Returns whether this column can be sorted.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getcansort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getCanSort: () => boolean\n /**\n * Returns the first direction that should be used when sorting this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getfirstsortdir)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getFirstSortDir: () => SortDirection\n /**\n * Returns the current sort direction of this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getissorted)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getIsSorted: () => false | SortDirection\n /**\n * Returns the next sorting order.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getnextsortingorder)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getNextSortingOrder: () => SortDirection | false\n /**\n * Returns the index position of this column's sorting within the sorting state\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortIndex: () => number\n /**\n * Returns the resolved sorting function to be used for this column\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortingfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortingFn: () => SortingFn\n /**\n * Returns a function that can be used to toggle this column's sorting state. This is useful for attaching a click handler to the column header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#gettogglesortinghandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getToggleSortingHandler: () => undefined | ((event: unknown) => void)\n /**\n * Toggles this columns sorting state. If `desc` is provided, it will force the sort direction to that value. If `isMulti` is provided, it will additivity multi-sort the column (or toggle it if it is already sorted).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#togglesorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n toggleSorting: (desc?: boolean, isMulti?: boolean) => void\n}\n\ninterface SortingOptionsBase {\n /**\n * Enables/disables the ability to remove multi-sorts\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablemultiremove)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableMultiRemove?: boolean\n /**\n * Enables/Disables multi-sorting for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablemultisort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableMultiSort?: boolean\n /**\n * Enables/Disables sorting for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablesorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableSorting?: boolean\n /**\n * Enables/Disables the ability to remove sorting for the table.\n * - If `true` then changing sort order will circle like: 'none' -> 'desc' -> 'asc' -> 'none' -> ...\n * - If `false` then changing sort order will circle like: 'none' -> 'desc' -> 'asc' -> 'desc' -> 'asc' -> ...\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablesortingremoval)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableSortingRemoval?: boolean\n /**\n * This function is used to retrieve the sorted row model. If using server-side sorting, this function is not required. To use client-side sorting, pass the exported `getSortedRowModel()` from your adapter to your table or implement your own.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortedRowModel?: (table: Table) => () => RowModel\n /**\n * Pass a custom function that will be used to determine if a multi-sort event should be triggered. It is passed the event from the sort toggle handler and should return `true` if the event should trigger a multi-sort.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#ismultisortevent)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n isMultiSortEvent?: (e: unknown) => boolean\n /**\n * Enables manual sorting for the table. If this is `true`, you will be expected to sort your data before it is passed to the table. This is useful if you are doing server-side sorting.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#manualsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n manualSorting?: boolean\n /**\n * Set a maximum number of columns that can be multi-sorted.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#maxmultisortcolcount)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n maxMultiSortColCount?: number\n /**\n * If provided, this function will be called with an `updaterFn` when `state.sorting` 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/sorting#onsortingchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n onSortingChange?: OnChangeFn\n /**\n * If `true`, all sorts will default to descending as their first toggle state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortdescfirst)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortDescFirst?: boolean\n}\n\ntype ResolvedSortingFns = keyof SortingFns extends never\n ? {\n sortingFns?: Record>\n }\n : {\n sortingFns: Record>\n }\n\nexport interface SortingOptions\n extends SortingOptionsBase,\n ResolvedSortingFns {}\n\nexport interface SortingInstance {\n _getSortedRowModel?: () => RowModel\n /**\n * Returns the row model for the table before any sorting has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getpresortedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getPreSortedRowModel: () => RowModel\n /**\n * Returns the row model for the table after sorting has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortedRowModel: () => RowModel\n /**\n * Resets the **sorting** state to `initialState.sorting`, 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/sorting#resetsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n resetSorting: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.sorting` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#setsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n setSorting: (updater: Updater) => void\n}\n\n//\n\nexport const RowSorting: TableFeature = {\n getInitialState: (state): SortingTableState => {\n return {\n sorting: [],\n ...state,\n }\n },\n\n getDefaultColumnDef: (): SortingColumnDef => {\n return {\n sortingFn: 'auto',\n sortUndefined: 1,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): SortingOptions => {\n return {\n onSortingChange: makeStateUpdater('sorting', table),\n isMultiSortEvent: (e: unknown) => {\n return (e as MouseEvent).shiftKey\n },\n }\n },\n\n createColumn: (\n column: Column,\n table: Table\n ): void => {\n column.getAutoSortingFn = () => {\n const firstRows = table.getFilteredRowModel().flatRows.slice(10)\n\n let isString = false\n\n for (const row of firstRows) {\n const value = row?.getValue(column.id)\n\n if (Object.prototype.toString.call(value) === '[object Date]') {\n return sortingFns.datetime\n }\n\n if (typeof value === 'string') {\n isString = true\n\n if (value.split(reSplitAlphaNumeric).length > 1) {\n return sortingFns.alphanumeric\n }\n }\n }\n\n if (isString) {\n return sortingFns.text\n }\n\n return sortingFns.basic\n }\n column.getAutoSortDir = () => {\n const firstRow = table.getFilteredRowModel().flatRows[0]\n\n const value = firstRow?.getValue(column.id)\n\n if (typeof value === 'string') {\n return 'asc'\n }\n\n return 'desc'\n }\n column.getSortingFn = () => {\n if (!column) {\n throw new Error()\n }\n\n return isFunction(column.columnDef.sortingFn)\n ? column.columnDef.sortingFn\n : column.columnDef.sortingFn === 'auto'\n ? column.getAutoSortingFn()\n : table.options.sortingFns?.[column.columnDef.sortingFn as string] ??\n sortingFns[column.columnDef.sortingFn as BuiltInSortingFn]\n }\n column.toggleSorting = (desc, multi) => {\n // if (column.columns.length) {\n // column.columns.forEach((c, i) => {\n // if (c.id) {\n // table.toggleColumnSorting(c.id, undefined, multi || !!i)\n // }\n // })\n // return\n // }\n\n // this needs to be outside of table.setSorting to be in sync with rerender\n const nextSortingOrder = column.getNextSortingOrder()\n const hasManualValue = typeof desc !== 'undefined' && desc !== null\n\n table.setSorting(old => {\n // Find any existing sorting for this column\n const existingSorting = old?.find(d => d.id === column.id)\n const existingIndex = old?.findIndex(d => d.id === column.id)\n\n let newSorting: SortingState = []\n\n // What should we do with this sort action?\n let sortAction: 'add' | 'remove' | 'toggle' | 'replace'\n let nextDesc = hasManualValue ? desc : nextSortingOrder === 'desc'\n\n // Multi-mode\n if (old?.length && column.getCanMultiSort() && multi) {\n if (existingSorting) {\n sortAction = 'toggle'\n } else {\n sortAction = 'add'\n }\n } else {\n // Normal mode\n if (old?.length && existingIndex !== old.length - 1) {\n sortAction = 'replace'\n } else if (existingSorting) {\n sortAction = 'toggle'\n } else {\n sortAction = 'replace'\n }\n }\n\n // Handle toggle states that will remove the sorting\n if (sortAction === 'toggle') {\n // If we are \"actually\" toggling (not a manual set value), should we remove the sorting?\n if (!hasManualValue) {\n // Is our intention to remove?\n if (!nextSortingOrder) {\n sortAction = 'remove'\n }\n }\n }\n\n if (sortAction === 'add') {\n newSorting = [\n ...old,\n {\n id: column.id,\n desc: nextDesc,\n },\n ]\n // Take latest n columns\n newSorting.splice(\n 0,\n newSorting.length -\n (table.options.maxMultiSortColCount ?? Number.MAX_SAFE_INTEGER)\n )\n } else if (sortAction === 'toggle') {\n // This flips (or sets) the\n newSorting = old.map(d => {\n if (d.id === column.id) {\n return {\n ...d,\n desc: nextDesc,\n }\n }\n return d\n })\n } else if (sortAction === 'remove') {\n newSorting = old.filter(d => d.id !== column.id)\n } else {\n newSorting = [\n {\n id: column.id,\n desc: nextDesc,\n },\n ]\n }\n\n return newSorting\n })\n }\n\n column.getFirstSortDir = () => {\n const sortDescFirst =\n column.columnDef.sortDescFirst ??\n table.options.sortDescFirst ??\n column.getAutoSortDir() === 'desc'\n return sortDescFirst ? 'desc' : 'asc'\n }\n\n column.getNextSortingOrder = (multi?: boolean) => {\n const firstSortDirection = column.getFirstSortDir()\n const isSorted = column.getIsSorted()\n\n if (!isSorted) {\n return firstSortDirection\n }\n\n if (\n isSorted !== firstSortDirection &&\n (table.options.enableSortingRemoval ?? true) && // If enableSortRemove, enable in general\n (multi ? table.options.enableMultiRemove ?? true : true) // If multi, don't allow if enableMultiRemove))\n ) {\n return false\n }\n return isSorted === 'desc' ? 'asc' : 'desc'\n }\n\n column.getCanSort = () => {\n return (\n (column.columnDef.enableSorting ?? true) &&\n (table.options.enableSorting ?? true) &&\n !!column.accessorFn\n )\n }\n\n column.getCanMultiSort = () => {\n return (\n column.columnDef.enableMultiSort ??\n table.options.enableMultiSort ??\n !!column.accessorFn\n )\n }\n\n column.getIsSorted = () => {\n const columnSort = table.getState().sorting?.find(d => d.id === column.id)\n\n return !columnSort ? false : columnSort.desc ? 'desc' : 'asc'\n }\n\n column.getSortIndex = () =>\n table.getState().sorting?.findIndex(d => d.id === column.id) ?? -1\n\n column.clearSorting = () => {\n //clear sorting for just 1 column\n table.setSorting(old =>\n old?.length ? old.filter(d => d.id !== column.id) : []\n )\n }\n\n column.getToggleSortingHandler = () => {\n const canSort = column.getCanSort()\n\n return (e: unknown) => {\n if (!canSort) return\n ;(e as any).persist?.()\n column.toggleSorting?.(\n undefined,\n column.getCanMultiSort() ? table.options.isMultiSortEvent?.(e) : false\n )\n }\n }\n },\n\n createTable: (table: Table): void => {\n table.setSorting = updater => table.options.onSortingChange?.(updater)\n table.resetSorting = defaultState => {\n table.setSorting(defaultState ? [] : table.initialState?.sorting ?? [])\n }\n table.getPreSortedRowModel = () => table.getGroupedRowModel()\n table.getSortedRowModel = () => {\n if (!table._getSortedRowModel && table.options.getSortedRowModel) {\n table._getSortedRowModel = table.options.getSortedRowModel(table)\n }\n\n if (table.options.manualSorting || !table._getSortedRowModel) {\n return table.getPreSortedRowModel()\n }\n\n return table._getSortedRowModel()\n }\n },\n}\n","import { RowModel } from '..'\nimport {\n OnChangeFn,\n Table,\n Row,\n Updater,\n RowData,\n TableFeature,\n} from '../types'\nimport { makeStateUpdater } from '../utils'\n\nexport type ExpandedStateList = Record\nexport type ExpandedState = true | Record\nexport interface ExpandedTableState {\n expanded: ExpandedState\n}\n\nexport interface ExpandedRow {\n /**\n * Returns whether the row can be expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getcanexpand)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getCanExpand: () => boolean\n /**\n * Returns whether all parent rows of the row are expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getisallparentsexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getIsAllParentsExpanded: () => boolean\n /**\n * Returns whether the row is expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getisexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getIsExpanded: () => boolean\n /**\n * Returns a function that can be used to toggle the expanded state of the row. This function can be used to bind to an event handler to a button.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#gettoggleexpandedhandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getToggleExpandedHandler: () => () => void\n /**\n * Toggles the expanded state (or sets it if `expanded` is provided) for the row.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#toggleexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n toggleExpanded: (expanded?: boolean) => void\n}\n\nexport interface ExpandedOptions {\n /**\n * Enable this setting to automatically reset the expanded state of the table when expanding state changes.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#autoresetexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n autoResetExpanded?: boolean\n /**\n * Enable/disable expanding for all rows.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#enableexpanding)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n enableExpanding?: boolean\n /**\n * This function is responsible for returning the expanded row model. If this function is not provided, the table will not expand rows. You can use the default exported `getExpandedRowModel` function to get the expanded row model or implement your own.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getexpandedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getExpandedRowModel?: (table: Table) => () => RowModel\n /**\n * If provided, allows you to override the default behavior of determining whether a row is currently expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getisrowexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getIsRowExpanded?: (row: Row) => boolean\n /**\n * If provided, allows you to override the default behavior of determining whether a row can be expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getrowcanexpand)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getRowCanExpand?: (row: Row) => boolean\n /**\n * Enables manual row expansion. If this is set to `true`, `getExpandedRowModel` will not be used to expand rows and you would be expected to perform the expansion in your own data model. This is useful if you are doing server-side expansion.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#manualexpanding)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n manualExpanding?: boolean\n /**\n * This function is called when the `expanded` table state changes. If a function is provided, you will be responsible for managing this state on your own. To pass the managed state back to the table, use the `tableOptions.state.expanded` option.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#onexpandedchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n onExpandedChange?: OnChangeFn\n /**\n * If `true` expanded rows will be paginated along with the rest of the table (which means expanded rows may span multiple pages). If `false` expanded rows will not be considered for pagination (which means expanded rows will always render on their parents page. This also means more rows will be rendered than the set page size)\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#paginateexpandedrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n paginateExpandedRows?: boolean\n}\n\nexport interface ExpandedInstance {\n _autoResetExpanded: () => void\n _getExpandedRowModel?: () => RowModel\n /**\n * Returns whether there are any rows that can be expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getcansomerowsexpand)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getCanSomeRowsExpand: () => boolean\n /**\n * Returns the maximum depth of the expanded rows.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getexpandeddepth)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getExpandedDepth: () => number\n /**\n * Returns the row model after expansion has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getexpandedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getExpandedRowModel: () => RowModel\n /**\n * Returns whether all rows are currently expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getisallrowsexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getIsAllRowsExpanded: () => boolean\n /**\n * Returns whether there are any rows that are currently expanded.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getissomerowsexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getIsSomeRowsExpanded: () => boolean\n /**\n * Returns the row model before expansion has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#getpreexpandedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getPreExpandedRowModel: () => RowModel\n /**\n * Returns a handler that can be used to toggle the expanded state of all rows. This handler is meant to be used with an `input[type=checkbox]` element.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#gettoggleallrowsexpandedhandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n getToggleAllRowsExpandedHandler: () => (event: unknown) => void\n /**\n * Resets the expanded state of the table to the initial state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#resetexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n resetExpanded: (defaultState?: boolean) => void\n /**\n * Updates the expanded state of the table via an update function or value.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#setexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n setExpanded: (updater: Updater) => void\n /**\n * Toggles the expanded state for all rows.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/expanding#toggleallrowsexpanded)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/expanding)\n */\n toggleAllRowsExpanded: (expanded?: boolean) => void\n}\n\n//\n\nexport const RowExpanding: TableFeature = {\n getInitialState: (state): ExpandedTableState => {\n return {\n expanded: {},\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): ExpandedOptions => {\n return {\n onExpandedChange: makeStateUpdater('expanded', table),\n paginateExpandedRows: true,\n }\n },\n\n createTable: (table: Table): void => {\n let registered = false\n let queued = false\n\n table._autoResetExpanded = () => {\n if (!registered) {\n table._queue(() => {\n registered = true\n })\n return\n }\n\n if (\n table.options.autoResetAll ??\n table.options.autoResetExpanded ??\n !table.options.manualExpanding\n ) {\n if (queued) return\n queued = true\n table._queue(() => {\n table.resetExpanded()\n queued = false\n })\n }\n }\n table.setExpanded = updater => table.options.onExpandedChange?.(updater)\n table.toggleAllRowsExpanded = expanded => {\n if (expanded ?? !table.getIsAllRowsExpanded()) {\n table.setExpanded(true)\n } else {\n table.setExpanded({})\n }\n }\n table.resetExpanded = defaultState => {\n table.setExpanded(defaultState ? {} : table.initialState?.expanded ?? {})\n }\n table.getCanSomeRowsExpand = () => {\n return table\n .getPrePaginationRowModel()\n .flatRows.some(row => row.getCanExpand())\n }\n table.getToggleAllRowsExpandedHandler = () => {\n return (e: unknown) => {\n ;(e as any).persist?.()\n table.toggleAllRowsExpanded()\n }\n }\n table.getIsSomeRowsExpanded = () => {\n const expanded = table.getState().expanded\n return expanded === true || Object.values(expanded).some(Boolean)\n }\n table.getIsAllRowsExpanded = () => {\n const expanded = table.getState().expanded\n\n // If expanded is true, save some cycles and return true\n if (typeof expanded === 'boolean') {\n return expanded === true\n }\n\n if (!Object.keys(expanded).length) {\n return false\n }\n\n // If any row is not expanded, return false\n if (table.getRowModel().flatRows.some(row => !row.getIsExpanded())) {\n return false\n }\n\n // They must all be expanded :shrug:\n return true\n }\n table.getExpandedDepth = () => {\n let maxDepth = 0\n\n const rowIds =\n table.getState().expanded === true\n ? Object.keys(table.getRowModel().rowsById)\n : Object.keys(table.getState().expanded)\n\n rowIds.forEach(id => {\n const splitId = id.split('.')\n maxDepth = Math.max(maxDepth, splitId.length)\n })\n\n return maxDepth\n }\n table.getPreExpandedRowModel = () => table.getSortedRowModel()\n table.getExpandedRowModel = () => {\n if (!table._getExpandedRowModel && table.options.getExpandedRowModel) {\n table._getExpandedRowModel = table.options.getExpandedRowModel(table)\n }\n\n if (table.options.manualExpanding || !table._getExpandedRowModel) {\n return table.getPreExpandedRowModel()\n }\n\n return table._getExpandedRowModel()\n }\n },\n\n createRow: (\n row: Row,\n table: Table\n ): void => {\n row.toggleExpanded = expanded => {\n table.setExpanded(old => {\n const exists = old === true ? true : !!old?.[row.id]\n\n let oldExpanded: ExpandedStateList = {}\n\n if (old === true) {\n Object.keys(table.getRowModel().rowsById).forEach(rowId => {\n oldExpanded[rowId] = true\n })\n } else {\n oldExpanded = old\n }\n\n expanded = expanded ?? !exists\n\n if (!exists && expanded) {\n return {\n ...oldExpanded,\n [row.id]: true,\n }\n }\n\n if (exists && !expanded) {\n const { [row.id]: _, ...rest } = oldExpanded\n return rest\n }\n\n return old\n })\n }\n row.getIsExpanded = () => {\n const expanded = table.getState().expanded\n\n return !!(\n table.options.getIsRowExpanded?.(row) ??\n (expanded === true || expanded?.[row.id])\n )\n }\n row.getCanExpand = () => {\n return (\n table.options.getRowCanExpand?.(row) ??\n ((table.options.enableExpanding ?? true) && !!row.subRows?.length)\n )\n }\n row.getIsAllParentsExpanded = () => {\n let isFullyExpanded = true\n let currentRow = row\n\n while (isFullyExpanded && currentRow.parentId) {\n currentRow = table.getRow(currentRow.parentId, true)\n isFullyExpanded = currentRow.getIsExpanded()\n }\n\n return isFullyExpanded\n }\n row.getToggleExpandedHandler = () => {\n const canExpand = row.getCanExpand()\n\n return () => {\n if (!canExpand) return\n row.toggleExpanded()\n }\n }\n },\n}\n","import {\n OnChangeFn,\n Table,\n RowModel,\n Updater,\n RowData,\n TableFeature,\n} from '../types'\nimport {\n functionalUpdate,\n getMemoOptions,\n makeStateUpdater,\n memo,\n} from '../utils'\n\nexport interface PaginationState {\n pageIndex: number\n pageSize: number\n}\n\nexport interface PaginationTableState {\n pagination: PaginationState\n}\n\nexport interface PaginationInitialTableState {\n pagination?: Partial\n}\n\nexport interface PaginationOptions {\n /**\n * If set to `true`, pagination will be reset to the first page when page-altering state changes eg. `data` is updated, filters change, grouping changes, etc.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#autoresetpageindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n autoResetPageIndex?: boolean\n /**\n * Returns the row model after pagination has taken place, but no further.\n *\n * Pagination columns are automatically reordered by default to the start of the columns list. If you would rather remove them or leave them as-is, set the appropriate mode here.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getpaginationrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getPaginationRowModel?: (table: Table) => () => RowModel\n /**\n * Enables manual pagination. If this option is set to `true`, the table will not automatically paginate rows using `getPaginationRowModel()` and instead will expect you to manually paginate the rows before passing them to the table. This is useful if you are doing server-side pagination and aggregation.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#manualpagination)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n manualPagination?: boolean\n /**\n * If this function is provided, it will be called when the pagination state changes and you will be expected to manage the state yourself. You can pass the managed state back to the table via the `tableOptions.state.pagination` option.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#onpaginationchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n onPaginationChange?: OnChangeFn\n /**\n * When manually controlling pagination, you can supply a total `pageCount` value to the table if you know it (Or supply a `rowCount` and `pageCount` will be calculated). If you do not know how many pages there are, you can set this to `-1`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#pagecount)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n pageCount?: number\n /**\n * When manually controlling pagination, you can supply a total `rowCount` value to the table if you know it. The `pageCount` can be calculated from this value and the `pageSize`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#rowcount)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n rowCount?: number\n}\n\nexport interface PaginationDefaultOptions {\n onPaginationChange: OnChangeFn\n}\n\nexport interface PaginationInstance {\n _autoResetPageIndex: () => void\n _getPaginationRowModel?: () => RowModel\n /**\n * Returns whether the table can go to the next page.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getcannextpage)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getCanNextPage: () => boolean\n /**\n * Returns whether the table can go to the previous page.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getcanpreviouspage)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getCanPreviousPage: () => boolean\n /**\n * Returns the page count. If manually paginating or controlling the pagination state, this will come directly from the `options.pageCount` table option, otherwise it will be calculated from the table data using the total row count and current page size.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getpagecount)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getPageCount: () => number\n /**\n * Returns the row count. If manually paginating or controlling the pagination state, this will come directly from the `options.rowCount` table option, otherwise it will be calculated from the table data.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getrowcount)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getRowCount: () => number\n /**\n * Returns an array of page options (zero-index-based) for the current page size.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getpageoptions)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getPageOptions: () => number[]\n /**\n * Returns the row model for the table after pagination has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getpaginationrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getPaginationRowModel: () => RowModel\n /**\n * Returns the row model for the table before any pagination has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#getprepaginationrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n getPrePaginationRowModel: () => RowModel\n /**\n * Increments the page index by one, if possible.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#nextpage)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n nextPage: () => void\n /**\n * Decrements the page index by one, if possible.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#previouspage)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n previousPage: () => void\n /**\n * Sets the page index to `0`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#firstpage)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n firstPage: () => void\n /**\n * Sets the page index to the last page.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#lastpage)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n lastPage: () => void\n /**\n * Resets the page index to its initial state. If `defaultState` is `true`, the page index will be reset to `0` regardless of initial state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#resetpageindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n resetPageIndex: (defaultState?: boolean) => void\n /**\n * Resets the page size to its initial state. If `defaultState` is `true`, the page size will be reset to `10` regardless of initial state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#resetpagesize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n resetPageSize: (defaultState?: boolean) => void\n /**\n * Resets the **pagination** state to `initialState.pagination`, 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/pagination#resetpagination)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n resetPagination: (defaultState?: boolean) => void\n /**\n * @deprecated The page count no longer exists in the pagination state. Just pass as a table option instead.\n */\n setPageCount: (updater: Updater) => void\n /**\n * Updates the page index using the provided function or value in the `state.pagination.pageIndex` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#setpageindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n setPageIndex: (updater: Updater) => void\n /**\n * Updates the page size using the provided function or value in the `state.pagination.pageSize` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#setpagesize)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n setPageSize: (updater: Updater) => void\n /**\n * Sets or updates the `state.pagination` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/pagination#setpagination)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/pagination)\n */\n setPagination: (updater: Updater) => void\n}\n\n//\n\nconst defaultPageIndex = 0\nconst defaultPageSize = 10\n\nconst getDefaultPaginationState = (): PaginationState => ({\n pageIndex: defaultPageIndex,\n pageSize: defaultPageSize,\n})\n\nexport const RowPagination: TableFeature = {\n getInitialState: (state): PaginationTableState => {\n return {\n ...state,\n pagination: {\n ...getDefaultPaginationState(),\n ...state?.pagination,\n },\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): PaginationDefaultOptions => {\n return {\n onPaginationChange: makeStateUpdater('pagination', table),\n }\n },\n\n createTable: (table: Table): void => {\n let registered = false\n let queued = false\n\n table._autoResetPageIndex = () => {\n if (!registered) {\n table._queue(() => {\n registered = true\n })\n return\n }\n\n if (\n table.options.autoResetAll ??\n table.options.autoResetPageIndex ??\n !table.options.manualPagination\n ) {\n if (queued) return\n queued = true\n table._queue(() => {\n table.resetPageIndex()\n queued = false\n })\n }\n }\n table.setPagination = updater => {\n const safeUpdater: Updater = old => {\n let newState = functionalUpdate(updater, old)\n\n return newState\n }\n\n return table.options.onPaginationChange?.(safeUpdater)\n }\n table.resetPagination = defaultState => {\n table.setPagination(\n defaultState\n ? getDefaultPaginationState()\n : table.initialState.pagination ?? getDefaultPaginationState()\n )\n }\n table.setPageIndex = updater => {\n table.setPagination(old => {\n let pageIndex = functionalUpdate(updater, old.pageIndex)\n\n const maxPageIndex =\n typeof table.options.pageCount === 'undefined' ||\n table.options.pageCount === -1\n ? Number.MAX_SAFE_INTEGER\n : table.options.pageCount - 1\n\n pageIndex = Math.max(0, Math.min(pageIndex, maxPageIndex))\n\n return {\n ...old,\n pageIndex,\n }\n })\n }\n table.resetPageIndex = defaultState => {\n table.setPageIndex(\n defaultState\n ? defaultPageIndex\n : table.initialState?.pagination?.pageIndex ?? defaultPageIndex\n )\n }\n table.resetPageSize = defaultState => {\n table.setPageSize(\n defaultState\n ? defaultPageSize\n : table.initialState?.pagination?.pageSize ?? defaultPageSize\n )\n }\n table.setPageSize = updater => {\n table.setPagination(old => {\n const pageSize = Math.max(1, functionalUpdate(updater, old.pageSize))\n const topRowIndex = old.pageSize * old.pageIndex!\n const pageIndex = Math.floor(topRowIndex / pageSize)\n\n return {\n ...old,\n pageIndex,\n pageSize,\n }\n })\n }\n //deprecated\n table.setPageCount = updater =>\n table.setPagination(old => {\n let newPageCount = functionalUpdate(\n updater,\n table.options.pageCount ?? -1\n )\n\n if (typeof newPageCount === 'number') {\n newPageCount = Math.max(-1, newPageCount)\n }\n\n return {\n ...old,\n pageCount: newPageCount,\n }\n })\n\n table.getPageOptions = memo(\n () => [table.getPageCount()],\n pageCount => {\n let pageOptions: number[] = []\n if (pageCount && pageCount > 0) {\n pageOptions = [...new Array(pageCount)].fill(null).map((_, i) => i)\n }\n return pageOptions\n },\n getMemoOptions(table.options, 'debugTable', 'getPageOptions')\n )\n\n table.getCanPreviousPage = () => table.getState().pagination.pageIndex > 0\n\n table.getCanNextPage = () => {\n const { pageIndex } = table.getState().pagination\n\n const pageCount = table.getPageCount()\n\n if (pageCount === -1) {\n return true\n }\n\n if (pageCount === 0) {\n return false\n }\n\n return pageIndex < pageCount - 1\n }\n\n table.previousPage = () => {\n return table.setPageIndex(old => old - 1)\n }\n\n table.nextPage = () => {\n return table.setPageIndex(old => {\n return old + 1\n })\n }\n\n table.firstPage = () => {\n return table.setPageIndex(0)\n }\n\n table.lastPage = () => {\n return table.setPageIndex(table.getPageCount() - 1)\n }\n\n table.getPrePaginationRowModel = () => table.getExpandedRowModel()\n table.getPaginationRowModel = () => {\n if (\n !table._getPaginationRowModel &&\n table.options.getPaginationRowModel\n ) {\n table._getPaginationRowModel =\n table.options.getPaginationRowModel(table)\n }\n\n if (table.options.manualPagination || !table._getPaginationRowModel) {\n return table.getPrePaginationRowModel()\n }\n\n return table._getPaginationRowModel()\n }\n\n table.getPageCount = () => {\n return (\n table.options.pageCount ??\n Math.ceil(table.getRowCount() / table.getState().pagination.pageSize)\n )\n }\n\n table.getRowCount = () => {\n return (\n table.options.rowCount ?? table.getPrePaginationRowModel().rows.length\n )\n }\n },\n}\n","import {\n OnChangeFn,\n Updater,\n Table,\n Row,\n RowData,\n TableFeature,\n} from '../types'\nimport { getMemoOptions, makeStateUpdater, memo } from '../utils'\n\nexport type RowPinningPosition = false | 'top' | 'bottom'\n\nexport interface RowPinningState {\n bottom?: string[]\n top?: string[]\n}\n\nexport interface RowPinningTableState {\n rowPinning: RowPinningState\n}\n\nexport interface RowPinningOptions {\n /**\n * Enables/disables row pinning for the table. Defaults to `true`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#enablerowpinning)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n enableRowPinning?: boolean | ((row: Row) => boolean)\n /**\n * When `false`, pinned rows will not be visible if they are filtered or paginated out of the table. When `true`, pinned rows will always be visible regardless of filtering or pagination. Defaults to `true`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#keeppinnedrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n keepPinnedRows?: boolean\n /**\n * If provided, this function will be called with an `updaterFn` when `state.rowPinning` changes. This overrides the default internal state management, so you will also need to supply `state.rowPinning` from your own managed state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#onrowpinningchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/onrowpinningchange)\n */\n onRowPinningChange?: OnChangeFn\n}\n\nexport interface RowPinningDefaultOptions {\n onRowPinningChange: OnChangeFn\n}\n\nexport interface RowPinningRow {\n /**\n * Returns whether or not the row can be pinned.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#getcanpin-1)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n getCanPin: () => boolean\n /**\n * Returns the pinned position of the row. (`'top'`, `'bottom'` or `false`)\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#getispinned-1)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n getIsPinned: () => RowPinningPosition\n /**\n * Returns the numeric pinned index of the row within a pinned row group.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#getpinnedindex-1)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n getPinnedIndex: () => number\n /**\n * Pins a row to the `'top'` or `'bottom'`, or unpins the row to the center if `false` is passed.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#pin-1)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n pin: (\n position: RowPinningPosition,\n includeLeafRows?: boolean,\n includeParentRows?: boolean\n ) => void\n}\n\nexport interface RowPinningInstance {\n _getPinnedRows: (\n visiblePinnedRows: Array>,\n pinnedRowIds: Array | undefined,\n position: 'top' | 'bottom'\n ) => Row[]\n /**\n * Returns all bottom pinned rows.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#getbottomrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n getBottomRows: () => Row[]\n /**\n * Returns all rows that are not pinned to the top or bottom.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#getcenterrows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n getCenterRows: () => Row[]\n /**\n * Returns whether or not any rows are pinned. Optionally specify to only check for pinned rows in either the `top` or `bottom` position.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#getissomerowspinned)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n getIsSomeRowsPinned: (position?: RowPinningPosition) => boolean\n /**\n * Returns all top pinned rows.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#gettoprows)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n getTopRows: () => Row[]\n /**\n * Resets the **rowPinning** state to `initialState.rowPinning`, or `true` can be passed to force a default blank state reset to `{ top: [], bottom: [], }`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#resetrowpinning)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n resetRowPinning: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.rowPinning` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/row-pinning#setrowpinning)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/row-pinning)\n */\n setRowPinning: (updater: Updater) => void\n}\n\n//\n\nconst getDefaultRowPinningState = (): RowPinningState => ({\n top: [],\n bottom: [],\n})\n\nexport const RowPinning: TableFeature = {\n getInitialState: (state): RowPinningTableState => {\n return {\n rowPinning: getDefaultRowPinningState(),\n ...state,\n }\n },\n\n getDefaultOptions: (\n table: Table\n ): RowPinningDefaultOptions => {\n return {\n onRowPinningChange: makeStateUpdater('rowPinning', table),\n }\n },\n\n createRow: (\n row: Row,\n table: Table\n ): void => {\n row.pin = (position, includeLeafRows, includeParentRows) => {\n const leafRowIds = includeLeafRows\n ? row.getLeafRows().map(({ id }) => id)\n : []\n const parentRowIds = includeParentRows\n ? row.getParentRows().map(({ id }) => id)\n : []\n const rowIds = new Set([...parentRowIds, row.id, ...leafRowIds])\n\n table.setRowPinning(old => {\n if (position === 'bottom') {\n return {\n top: (old?.top ?? []).filter(d => !rowIds?.has(d)),\n bottom: [\n ...(old?.bottom ?? []).filter(d => !rowIds?.has(d)),\n ...Array.from(rowIds),\n ],\n }\n }\n\n if (position === 'top') {\n return {\n top: [\n ...(old?.top ?? []).filter(d => !rowIds?.has(d)),\n ...Array.from(rowIds),\n ],\n bottom: (old?.bottom ?? []).filter(d => !rowIds?.has(d)),\n }\n }\n\n return {\n top: (old?.top ?? []).filter(d => !rowIds?.has(d)),\n bottom: (old?.bottom ?? []).filter(d => !rowIds?.has(d)),\n }\n })\n }\n row.getCanPin = () => {\n const { enableRowPinning, enablePinning } = table.options\n if (typeof enableRowPinning === 'function') {\n return enableRowPinning(row)\n }\n return enableRowPinning ?? enablePinning ?? true\n }\n row.getIsPinned = () => {\n const rowIds = [row.id]\n\n const { top, bottom } = table.getState().rowPinning\n\n const isTop = rowIds.some(d => top?.includes(d))\n const isBottom = rowIds.some(d => bottom?.includes(d))\n\n return isTop ? 'top' : isBottom ? 'bottom' : false\n }\n row.getPinnedIndex = () => {\n const position = row.getIsPinned()\n if (!position) return -1\n\n const visiblePinnedRowIds = (\n position === 'top' ? table.getTopRows() : table.getBottomRows()\n )?.map(({ id }) => id)\n\n return visiblePinnedRowIds?.indexOf(row.id) ?? -1\n }\n },\n\n createTable: (table: Table): void => {\n table.setRowPinning = updater => table.options.onRowPinningChange?.(updater)\n\n table.resetRowPinning = defaultState =>\n table.setRowPinning(\n defaultState\n ? getDefaultRowPinningState()\n : table.initialState?.rowPinning ?? getDefaultRowPinningState()\n )\n\n table.getIsSomeRowsPinned = position => {\n const pinningState = table.getState().rowPinning\n\n if (!position) {\n return Boolean(pinningState.top?.length || pinningState.bottom?.length)\n }\n return Boolean(pinningState[position]?.length)\n }\n\n table._getPinnedRows = (visibleRows, pinnedRowIds, position) => {\n const rows =\n table.options.keepPinnedRows ?? true\n ? //get all rows that are pinned even if they would not be otherwise visible\n //account for expanded parent rows, but not pagination or filtering\n (pinnedRowIds ?? []).map(rowId => {\n const row = table.getRow(rowId, true)\n return row.getIsAllParentsExpanded() ? row : null\n })\n : //else get only visible rows that are pinned\n (pinnedRowIds ?? []).map(\n rowId => visibleRows.find(row => row.id === rowId)!\n )\n\n return rows.filter(Boolean).map(d => ({ ...d, position })) as Row[]\n }\n\n table.getTopRows = memo(\n () => [table.getRowModel().rows, table.getState().rowPinning.top],\n (allRows, topPinnedRowIds) =>\n table._getPinnedRows(allRows, topPinnedRowIds, 'top'),\n getMemoOptions(table.options, 'debugRows', 'getTopRows')\n )\n\n table.getBottomRows = memo(\n () => [table.getRowModel().rows, table.getState().rowPinning.bottom],\n (allRows, bottomPinnedRowIds) =>\n table._getPinnedRows(allRows, bottomPinnedRowIds, 'bottom'),\n getMemoOptions(table.options, 'debugRows', 'getBottomRows')\n )\n\n table.getCenterRows = memo(\n () => [\n table.getRowModel().rows,\n table.getState().rowPinning.top,\n table.getState().rowPinning.bottom,\n ],\n (allRows, top, bottom) => {\n const topAndBottom = new Set([...(top ?? []), ...(bottom ?? [])])\n return allRows.filter(d => !topAndBottom.has(d.id))\n },\n getMemoOptions(table.options, 'debugRows', 'getCenterRows')\n )\n },\n}\n","import {\n Column,\n Table,\n AccessorFn,\n ColumnDef,\n RowData,\n ColumnDefResolved,\n} from '../types'\nimport { getMemoOptions, memo } from '../utils'\n\nexport interface CoreColumn {\n /**\n * The resolved accessor function to use when extracting the value for the column from each row. Will only be defined if the column def has a valid accessor key or function defined.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#accessorfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n accessorFn?: AccessorFn\n /**\n * The original column def used to create the column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#columndef)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n columnDef: ColumnDef\n /**\n * The child column (if the column is a group column). Will be an empty array if the column is not a group column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#columns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n columns: Column[]\n /**\n * The depth of the column (if grouped) relative to the root column def array.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#depth)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n depth: number\n /**\n * Returns the flattened array of this column and all child/grand-child columns for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#getflatcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n getFlatColumns: () => Column[]\n /**\n * Returns an array of all leaf-node columns for this column. If a column has no children, it is considered the only leaf-node column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#getleafcolumns)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n getLeafColumns: () => Column[]\n /**\n * The resolved unique identifier for the column resolved in this priority:\n - A manual `id` property from the column def\n - The accessor key from the column def\n - The header string from the column def\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#id)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n id: string\n /**\n * The parent column for this column. Will be undefined if this is a root column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/core/column#parent)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/column-defs)\n */\n parent?: Column\n}\n\nexport function createColumn(\n table: Table,\n columnDef: ColumnDef,\n depth: number,\n parent?: Column\n): Column {\n const defaultColumn = table._getDefaultColumnDef()\n\n const resolvedColumnDef = {\n ...defaultColumn,\n ...columnDef,\n } as ColumnDefResolved\n\n const accessorKey = resolvedColumnDef.accessorKey\n\n let id =\n resolvedColumnDef.id ??\n (accessorKey\n ? typeof String.prototype.replaceAll === 'function'\n ? accessorKey.replaceAll('.', '_')\n : accessorKey.replace(/\\./g, '_')\n : undefined) ??\n (typeof resolvedColumnDef.header === 'string'\n ? resolvedColumnDef.header\n : undefined)\n\n let accessorFn: AccessorFn | undefined\n\n if (resolvedColumnDef.accessorFn) {\n accessorFn = resolvedColumnDef.accessorFn\n } else if (accessorKey) {\n // Support deep accessor keys\n if (accessorKey.includes('.')) {\n accessorFn = (originalRow: TData) => {\n let result = originalRow as Record\n\n for (const key of accessorKey.split('.')) {\n result = result?.[key]\n if (process.env.NODE_ENV !== 'production' && result === undefined) {\n console.warn(\n `\"${key}\" in deeply nested key \"${accessorKey}\" returned undefined.`\n )\n }\n }\n\n return result\n }\n } else {\n accessorFn = (originalRow: TData) =>\n (originalRow as any)[resolvedColumnDef.accessorKey]\n }\n }\n\n if (!id) {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(\n resolvedColumnDef.accessorFn\n ? `Columns require an id when using an accessorFn`\n : `Columns require an id when using a non-string header`\n )\n }\n throw new Error()\n }\n\n let column: CoreColumn = {\n id: `${String(id)}`,\n accessorFn,\n parent: parent as any,\n depth,\n columnDef: resolvedColumnDef as ColumnDef,\n columns: [],\n getFlatColumns: memo(\n () => [true],\n () => {\n return [\n column as Column,\n ...column.columns?.flatMap(d => d.getFlatColumns()),\n ]\n },\n getMemoOptions(table.options, 'debugColumns', 'column.getFlatColumns')\n ),\n getLeafColumns: memo(\n () => [table._getOrderColumnsFn()],\n orderColumns => {\n if (column.columns?.length) {\n let leafColumns = column.columns.flatMap(column =>\n column.getLeafColumns()\n )\n\n return orderColumns(leafColumns)\n }\n\n return [column as Column]\n },\n getMemoOptions(table.options, 'debugColumns', 'column.getLeafColumns')\n ),\n }\n\n for (const feature of table._features) {\n feature.createColumn?.(column as Column, table)\n }\n\n // Yes, we have to convert table to unknown, because we know more than the compiler here.\n return column as Column\n}\n","import { createRow } from '../core/row'\nimport { Table, Row, RowModel, RowData } from '../types'\nimport { getMemoOptions, memo } from '../utils'\n\nexport function getCoreRowModel(): (\n table: Table\n) => () => RowModel {\n return table =>\n memo(\n () => [table.options.data],\n (\n data\n ): {\n rows: Row[]\n flatRows: Row[]\n rowsById: Record>\n } => {\n const rowModel: RowModel = {\n rows: [],\n flatRows: [],\n rowsById: {},\n }\n\n const accessRows = (\n originalRows: TData[],\n depth = 0,\n parentRow?: Row\n ): Row[] => {\n const rows = [] as Row[]\n\n for (let i = 0; i < originalRows.length; i++) {\n // This could be an expensive check at scale, so we should move it somewhere else, but where?\n // if (!id) {\n // if (process.env.NODE_ENV !== 'production') {\n // throw new Error(`getRowId expected an ID, but got ${id}`)\n // }\n // }\n\n // Make the row\n const row = createRow(\n table,\n table._getRowId(originalRows[i]!, i, parentRow),\n originalRows[i]!,\n i,\n depth,\n undefined,\n parentRow?.id\n )\n\n // Keep track of every row in a flat array\n rowModel.flatRows.push(row)\n // Also keep track of every row by its ID\n rowModel.rowsById[row.id] = row\n // Push table row into parent\n rows.push(row)\n\n // Get the original subrows\n if (table.options.getSubRows) {\n row.originalSubRows = table.options.getSubRows(\n originalRows[i]!,\n i\n )\n\n // Then recursively access them\n if (row.originalSubRows?.length) {\n row.subRows = accessRows(row.originalSubRows, depth + 1, row)\n }\n }\n }\n\n return rows\n }\n\n rowModel.rows = accessRows(data)\n\n return rowModel\n },\n getMemoOptions(table.options, 'debugTable', 'getRowModel', () =>\n table._autoResetPageIndex()\n )\n )\n}\n","import { Table, Row, RowModel, RowData } from '../types'\nimport { getMemoOptions, memo } from '../utils'\n\nexport function getExpandedRowModel(): (\n table: Table\n) => () => RowModel {\n return table =>\n memo(\n () => [\n table.getState().expanded,\n table.getPreExpandedRowModel(),\n table.options.paginateExpandedRows,\n ],\n (expanded, rowModel, paginateExpandedRows) => {\n if (\n !rowModel.rows.length ||\n (expanded !== true && !Object.keys(expanded ?? {}).length)\n ) {\n return rowModel\n }\n\n if (!paginateExpandedRows) {\n // Only expand rows at this point if they are being paginated\n return rowModel\n }\n\n return expandRows(rowModel)\n },\n getMemoOptions(table.options, 'debugTable', 'getExpandedRowModel')\n )\n}\n\nexport function expandRows(rowModel: RowModel) {\n const expandedRows: Row[] = []\n\n const handleRow = (row: Row) => {\n expandedRows.push(row)\n\n if (row.subRows?.length && row.getIsExpanded()) {\n row.subRows.forEach(handleRow)\n }\n }\n\n rowModel.rows.forEach(handleRow)\n\n return {\n rows: expandedRows,\n flatRows: rowModel.flatRows,\n rowsById: rowModel.rowsById,\n }\n}\n"],"names":["createSvgIcon","_jsx","d","traverseBreakpoints","breakpoints","responsive","iterator","smallestBreakpoint","keys","Array","isArray","forEach","breakpointValue","index","responsiveStyles","style","length","Object","assign","up","breakpointsKeys","responsiveKeys","filter","key","includes","undefined","filterBreakpointKeys","appendLevel","level","isNestedContainer","ownerState","unstable_level","container","createGetParentSpacing","axis","getParentColumns","generateGridSizeStyles","theme","getParentSpacing","styles","size","appendStyle","value","flexBasis","flexGrow","maxWidth","flexShrink","width","generateGridOffsetStyles","offset","marginLeft","generateGridColumnsStyles","columns","generateGridRowSpacingStyles","rowSpacing","spacing","generateGridColumnSpacingStyles","columnSpacing","generateGridDirectionStyles","direction","flexDirection","generateGridStyles","getSelfSpacing","createGetSelfSpacing","minWidth","boxSizing","display","flexWrap","wrap","gap","generateSizeClassNames","classNames","entries","push","String","generateSpacingClassNames","isValidSpacing","val","Number","isNaN","generateDirectionClasses","map","defaultTheme","createTheme","defaultCreateStyledComponent","systemStyled","name","slot","overridesResolver","props","root","useThemePropsDefault","useThemePropsSystem","Grid2","options","createStyledComponent","useThemeProps","componentName","parseResponsiveProp","propValue","shouldUseValue","parsedProp","GridRoot","Grid","React","inProps","ref","useTheme","themeProps","extendSxProp","className","children","columnsProp","component","sizeProp","offsetProp","spacingProp","rowSpacingProp","columnSpacingProp","other","classes","useUtilityClasses","slots","composeClasses","generateUtilityClass","as","clsx","child","element","muiNames","indexOf","type","muiName","_payload","createGrid2","styled","getUnit","input","match","toUnitless","parseFloat","getSkeletonUtilityClass","generateUtilityClasses","pulseKeyframe","keyframes","waveKeyframe","pulseAnimation","css","waveAnimation","SkeletonRoot","variant","animation","hasChildren","withChildren","fitContent","height","heightAuto","memoTheme","radiusUnit","shape","borderRadius","radiusValue","backgroundColor","vars","palette","Skeleton","bg","alpha","text","primary","mode","variants","marginTop","marginBottom","transformOrigin","transform","Math","round","content","visibility","position","overflow","WebkitMaskImage","background","action","hover","bottom","left","right","top","useDefaultProps","Boolean","CheckmarkIcon","viewBox","fill","xmlns","color","fillRule","clipRule","CloseIcon","ExpandIcon","NewTabIcon","_jsxs","flexRender","Comp","proto","getPrototypeOf","prototype","isReactComponent","isClassComponent","$$typeof","description","isExoticComponent","useReactTable","resolvedOptions","state","onStateChange","renderFallbackValue","tableRef","current","createTable","setState","initialState","setOptions","prev","updater","functionalUpdate","makeStateUpdater","instance","old","isFunction","Function","flattenBy","arr","getChildren","flat","recurse","subArr","item","memo","getDeps","fn","opts","result","deps","depArgs","depTime","debug","Date","now","newDeps","some","dep","resultTime","onChange","depEndTime","resultEndTime","resultFpsPercentage","pad","str","num","console","info","max","min","getMemoOptions","tableOptions","debugLevel","_tableOptions$debugAl","debugAll","process","createHeader","table","column","_options$id","header","id","isPlaceholder","placeholderId","depth","subHeaders","colSpan","rowSpan","headerGroup","getLeafHeaders","leafHeaders","recurseHeader","h","getContext","_features","feature","Headers","getHeaderGroups","getAllColumns","getVisibleLeafColumns","getState","columnPinning","allColumns","leafColumns","_left$map$filter","_right$map$filter","leftColumns","columnId","find","rightColumns","buildHeaderGroups","getCenterHeaderGroups","getLeftHeaderGroups","_left$map$filter2","getRightHeaderGroups","_right$map$filter2","getFooterGroups","headerGroups","reverse","getLeftFooterGroups","getCenterFooterGroups","getRightFooterGroups","getFlatHeaders","headers","getLeftFlatHeaders","getCenterFlatHeaders","getRightFlatHeaders","getCenterLeafHeaders","flatHeaders","_header$subHeaders","getLeftLeafHeaders","_header$subHeaders2","getRightLeafHeaders","_header$subHeaders3","center","_left$0$headers","_left$","_center$0$headers","_center$","_right$0$headers","_right$","columnsToGroup","headerFamily","_headerGroups$0$heade","_headerGroups$","maxDepth","findMaxDepth","getIsVisible","_column$columns","createHeaderGroup","headersToGroup","join","pendingParentHeaders","headerToGroup","latestPendingParentHeader","parent","bottomHeaders","recurseHeadersForSpans","childRowSpans","_ref","childColSpan","childRowSpan","createRow","original","rowIndex","subRows","parentId","row","_valuesCache","_uniqueValuesCache","getValue","hasOwnProperty","getColumn","accessorFn","getUniqueValues","columnDef","renderValue","_row$getValue","getLeafRows","getParentRow","getRow","getParentRows","parentRows","currentRow","parentRow","getAllCells","getAllLeafColumns","cell","getRenderValue","_cell$getValue","createCell","_getAllCellsByColumnId","allCells","reduce","acc","i","ColumnFaceting","createColumn","_getFacetedRowModel","getFacetedRowModel","getPreFilteredRowModel","_getFacetedUniqueValues","getFacetedUniqueValues","Map","_getFacetedMinMaxValues","getFacetedMinMaxValues","includesString","filterValue","_filterValue$toString","search","toString","toLowerCase","autoRemove","testFalsey","includesStringSensitive","_row$getValue2","equalsString","_row$getValue3","arrIncludes","_row$getValue4","arrIncludesAll","_row$getValue5","arrIncludesSome","_row$getValue6","equals","weakEquals","inNumberRange","rowValue","resolveFilterValue","unsafeMin","unsafeMax","parsedMin","parsedMax","Infinity","temp","filterFns","ColumnFiltering","getDefaultColumnDef","filterFn","getInitialState","columnFilters","getDefaultOptions","onColumnFiltersChange","filterFromLeafRows","maxLeafRowFilterDepth","getAutoFilterFn","firstRow","getCoreRowModel","flatRows","getFilterFn","_table$options$filter","_table$options$filter2","getCanFilter","_column$columnDef$ena","_table$options$enable","_table$options$enable2","enableColumnFilter","enableColumnFilters","enableFilters","getIsFiltered","getFilterIndex","getFilterValue","_table$getState$colum","_table$getState$colum2","_table$getState$colum3","findIndex","setFilterValue","setColumnFilters","previousFilter","newFilter","_old$filter","shouldAutoRemoveFilter","newFilterObj","_old$map","_table","columnFiltersMeta","_functionalUpdate","resetColumnFilters","defaultState","_table$initialState$c","_table$initialState","getFilteredRowModel","_getFilteredRowModel","manualFiltering","aggregationFns","sum","_leafRows","childRows","next","nextValue","extent","mean","leafRows","count","median","values","every","mid","floor","nums","sort","a","b","unique","from","Set","uniqueCount","_columnId","ColumnGrouping","aggregatedCell","_toString","_props$getValue","aggregationFn","grouping","onGroupingChange","groupedColumnMode","toggleGrouping","setGrouping","getCanGroup","enableGrouping","getGroupingValue","getIsGrouped","_table$getState$group","getGroupedIndex","_table$getState$group2","getToggleGroupingHandler","canGroup","getAutoAggregationFn","call","getAggregationFn","_table$options$aggreg","_table$options$aggreg2","Error","resetGrouping","_table$initialState$g","getPreGroupedRowModel","getGroupedRowModel","_getGroupedRowModel","manualGrouping","groupingColumnId","_groupingValuesCache","getIsPlaceholder","getIsAggregated","_row$subRows","ColumnOrdering","columnOrder","onColumnOrderChange","getIndex","_getVisibleLeafColumns","getIsFirstColumn","_columns$","getIsLastColumn","_columns","setColumnOrder","resetColumnOrder","_getOrderColumnsFn","orderedColumns","columnOrderCopy","columnsCopy","targetColumnId","shift","foundIndex","splice","nonGroupingColumns","col","g","orderColumns","ColumnPinning","onColumnPinningChange","pin","columnIds","getLeafColumns","setColumnPinning","_old$left3","_old$right3","_old$left","_old$right","_old$left2","_old$right2","getCanPin","_d$columnDef$enablePi","enablePinning","enableColumnPinning","getIsPinned","leafColumnIds","isLeft","isRight","getPinnedIndex","getCenterVisibleCells","_getAllVisibleCells","leftAndRight","getLeftVisibleCells","getRightVisibleCells","resetColumnPinning","getIsSomeColumnsPinned","_pinningState$positio","pinningState","_pinningState$left","_pinningState$right","getLeftLeafColumns","getRightLeafColumns","getCenterLeafColumns","defaultColumnSizing","minSize","maxSize","MAX_SAFE_INTEGER","ColumnSizing","columnSizing","columnSizingInfo","startOffset","startSize","deltaOffset","deltaPercentage","isResizingColumn","columnSizingStart","columnResizeMode","columnResizeDirection","onColumnSizingChange","onColumnSizingInfoChange","getSize","_column$columnDef$min","_column$columnDef$max","columnSize","getStart","slice","getAfter","resetSize","setColumnSizing","_ref2","_","rest","getCanResize","enableResizing","enableColumnResizing","getIsResizing","_header$column$getSiz","prevSiblingHeader","getResizeHandler","_contextDocument","canResize","e","persist","isTouchStartEvent","touches","clientX","newColumnSizing","updateOffset","eventType","clientXPos","setColumnSizingInfo","_old$startOffset","_old$startSize","deltaDirection","_ref3","headerSize","onMove","onEnd","contextDocument","document","mouseEvents","moveHandler","upHandler","removeEventListener","touchEvents","cancelable","preventDefault","stopPropagation","_e$touches$","passiveIfSupported","passiveSupported","supported","passive","noop","window","addEventListener","err","passiveEventSupported","resetColumnSizing","resetHeaderSizeInfo","_table$initialState$c2","getTotalSize","_table$getHeaderGroup","_table$getHeaderGroup2","getLeftTotalSize","_table$getLeftHeaderG","_table$getLeftHeaderG2","getCenterTotalSize","_table$getCenterHeade","_table$getCenterHeade2","getRightTotalSize","_table$getRightHeader","_table$getRightHeader2","getCenterVisibleLeafColumns","getLeftVisibleLeafColumns","getRightVisibleLeafColumns","RowSelection","rowSelection","onRowSelectionChange","enableRowSelection","enableMultiRowSelection","enableSubRowSelection","setRowSelection","resetRowSelection","_table$initialState$r","toggleAllRowsSelected","getIsAllRowsSelected","preGroupedFlatRows","getCanSelect","toggleAllPageRowsSelected","resolvedValue","getIsAllPageRowsSelected","getRowModel","rows","mutateRowIsSelected","getPreSelectedRowModel","getSelectedRowModel","rowModel","selectRowsFn","rowsById","getFilteredSelectedRowModel","getGroupedSelectedRowModel","getSortedRowModel","isAllRowsSelected","paginationFlatRows","getPaginationRowModel","isAllPageRowsSelected","getIsSomeRowsSelected","_table$getState$rowSe","totalSelected","getIsSomePageRowsSelected","getIsSelected","getIsSomeSelected","getToggleAllRowsSelectedHandler","target","checked","getToggleAllPageRowsSelectedHandler","toggleSelected","isSelected","_opts$selectChildren","selectedRowIds","selectChildren","isRowSelected","isSubRowSelected","getIsAllSubRowsSelected","getCanSelectSubRows","getCanMultiSelect","_table$options$enable3","getToggleSelectedHandler","canSelect","_target","includeChildren","newSelectedFlatRows","newSelectedRowsById","recurseRows","_row$subRows2","selection","_selection$row$id","_row$subRows3","allChildrenSelected","someSelected","subRow","subRowChildrenSelected","reSplitAlphaNumeric","compareBasic","compareAlphanumeric","aStr","bStr","split","aa","bb","an","parseInt","bn","combo","sortingFns","alphanumeric","rowA","rowB","alphanumericCaseSensitive","textCaseSensitive","datetime","basic","builtInFeatures","columnVisibility","onColumnVisibilityChange","toggleVisibility","getCanHide","setColumnVisibility","childColumns","c","enableHiding","getToggleVisibilityHandler","cells","getVisibleCells","makeVisibleColumnsMethod","getColumns","getVisibleFlatColumns","getAllFlatColumns","resetColumnVisibility","toggleAllColumnsVisible","_value","getIsAllColumnsVisible","obj","getIsSomeColumnsVisible","getToggleAllColumnsVisibilityHandler","_getGlobalFacetedRowModel","getGlobalFacetedRowModel","_getGlobalFacetedUniqueValues","getGlobalFacetedUniqueValues","_getGlobalFacetedMinMaxValues","getGlobalFacetedMinMaxValues","globalFilter","onGlobalFilterChange","globalFilterFn","getColumnCanGlobalFilter","_table$getCoreRowMode","getCanGlobalFilter","_table$options$getCol","enableGlobalFilter","getGlobalAutoFilterFn","getGlobalFilterFn","setGlobalFilter","resetGlobalFilter","sorting","sortingFn","sortUndefined","onSortingChange","isMultiSortEvent","shiftKey","getAutoSortingFn","firstRows","isString","getAutoSortDir","getSortingFn","_table$options$sortin","_table$options$sortin2","toggleSorting","desc","multi","nextSortingOrder","getNextSortingOrder","hasManualValue","setSorting","existingSorting","existingIndex","sortAction","newSorting","nextDesc","_table$options$maxMul","getCanMultiSort","maxMultiSortColCount","getFirstSortDir","_column$columnDef$sor","sortDescFirst","firstSortDirection","isSorted","getIsSorted","enableSortingRemoval","enableMultiRemove","getCanSort","enableSorting","_column$columnDef$ena2","enableMultiSort","_table$getState$sorti","columnSort","getSortIndex","_table$getState$sorti2","_table$getState$sorti3","clearSorting","getToggleSortingHandler","canSort","resetSorting","_table$initialState$s","getPreSortedRowModel","_getSortedRowModel","manualSorting","expanded","onExpandedChange","paginateExpandedRows","registered","queued","_autoResetExpanded","_table$options$autoRe","autoResetAll","autoResetExpanded","manualExpanding","_queue","resetExpanded","setExpanded","toggleAllRowsExpanded","getIsAllRowsExpanded","_table$initialState$e","getCanSomeRowsExpand","getPrePaginationRowModel","getCanExpand","getToggleAllRowsExpandedHandler","getIsSomeRowsExpanded","getIsExpanded","getExpandedDepth","splitId","getPreExpandedRowModel","getExpandedRowModel","_getExpandedRowModel","toggleExpanded","_expanded","exists","oldExpanded","rowId","_table$options$getIsR","getIsRowExpanded","_table$options$getRow","getRowCanExpand","enableExpanding","getIsAllParentsExpanded","isFullyExpanded","getToggleExpandedHandler","canExpand","pagination","pageIndex","pageSize","onPaginationChange","_autoResetPageIndex","autoResetPageIndex","manualPagination","resetPageIndex","setPagination","resetPagination","_table$initialState$p","setPageIndex","maxPageIndex","pageCount","_table$initialState$p2","resetPageSize","_table$initialState$p3","_table$initialState2","setPageSize","topRowIndex","setPageCount","_table$options$pageCo","newPageCount","getPageOptions","getPageCount","pageOptions","getCanPreviousPage","getCanNextPage","previousPage","nextPage","firstPage","lastPage","_getPaginationRowModel","_table$options$pageCo2","ceil","getRowCount","_table$options$rowCou","rowCount","rowPinning","onRowPinningChange","includeLeafRows","includeParentRows","leafRowIds","parentRowIds","rowIds","setRowPinning","_old$top3","_old$bottom3","_old$top","_old$bottom","_old$top2","_old$bottom2","has","enableRowPinning","isTop","isBottom","_ref4","_visiblePinnedRowIds$","visiblePinnedRowIds","getTopRows","getBottomRows","_ref5","resetRowPinning","getIsSomeRowsPinned","_pinningState$top","_pinningState$bottom","_getPinnedRows","visibleRows","pinnedRowIds","_table$options$keepPi","keepPinnedRows","allRows","topPinnedRowIds","bottomPinnedRowIds","getCenterRows","topAndBottom","_options$_features","_options$initialState","defaultOptions","_feature$getInitialSt","queuedTimeout","coreInstance","cb","Promise","resolve","then","catch","error","setTimeout","reset","newOptions","mergeOptions","_getRowId","getRowId","_getCoreRowModel","searchAll","_getDefaultColumnDef","defaultColumn","_defaultColumn","resolvedColumnDef","accessorKey","_props$renderValue$to","_props$renderValue","_getColumnDefs","columnDefs","recurseColumns","_resolvedColumnDef$id","replaceAll","replace","originalRow","_result","getFlatColumns","flatMap","_column$columns2","groupingColumnDef","_getAllFlatColumnsById","flatColumns","data","accessRows","originalRows","_row$originalSubRows","getSubRows","originalSubRows","expandRows","expandedRows","handleRow"],"sourceRoot":""}