@tanstack/table-core 9.0.0-alpha.4 → 9.0.0-alpha.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/dist/cjs/aggregationFns.cjs +4 -8
  2. package/dist/cjs/aggregationFns.cjs.map +1 -1
  3. package/dist/cjs/core/cell.cjs +3 -3
  4. package/dist/cjs/core/cell.cjs.map +1 -1
  5. package/dist/cjs/core/cell.d.cts +1 -1
  6. package/dist/cjs/core/column.cjs +3 -3
  7. package/dist/cjs/core/column.cjs.map +1 -1
  8. package/dist/cjs/core/column.d.cts +1 -1
  9. package/dist/cjs/core/headers.cjs +5 -5
  10. package/dist/cjs/core/headers.cjs.map +1 -1
  11. package/dist/cjs/core/row.cjs +5 -6
  12. package/dist/cjs/core/row.cjs.map +1 -1
  13. package/dist/cjs/core/row.d.cts +1 -1
  14. package/dist/cjs/core/table.cjs +11 -7
  15. package/dist/cjs/core/table.cjs.map +1 -1
  16. package/dist/cjs/core/table.d.cts +9 -1
  17. package/dist/cjs/features/ColumnFaceting.cjs +1 -1
  18. package/dist/cjs/features/ColumnFaceting.cjs.map +1 -1
  19. package/dist/cjs/features/ColumnFiltering.cjs +6 -6
  20. package/dist/cjs/features/ColumnFiltering.cjs.map +1 -1
  21. package/dist/cjs/features/ColumnGrouping.cjs +8 -9
  22. package/dist/cjs/features/ColumnGrouping.cjs.map +1 -1
  23. package/dist/cjs/features/ColumnOrdering.cjs +4 -4
  24. package/dist/cjs/features/ColumnOrdering.cjs.map +1 -1
  25. package/dist/cjs/features/ColumnPinning.cjs +5 -5
  26. package/dist/cjs/features/ColumnPinning.cjs.map +1 -1
  27. package/dist/cjs/features/ColumnSizing.cjs +7 -8
  28. package/dist/cjs/features/ColumnSizing.cjs.map +1 -1
  29. package/dist/cjs/features/ColumnVisibility.cjs +5 -5
  30. package/dist/cjs/features/ColumnVisibility.cjs.map +1 -1
  31. package/dist/cjs/features/GlobalFaceting.cjs +1 -1
  32. package/dist/cjs/features/GlobalFaceting.cjs.map +1 -1
  33. package/dist/cjs/features/GlobalFiltering.cjs +4 -4
  34. package/dist/cjs/features/GlobalFiltering.cjs.map +1 -1
  35. package/dist/cjs/features/RowExpanding.cjs +6 -8
  36. package/dist/cjs/features/RowExpanding.cjs.map +1 -1
  37. package/dist/cjs/features/RowPagination.cjs +4 -5
  38. package/dist/cjs/features/RowPagination.cjs.map +1 -1
  39. package/dist/cjs/features/RowPinning.cjs +5 -6
  40. package/dist/cjs/features/RowPinning.cjs.map +1 -1
  41. package/dist/cjs/features/RowSelection.cjs +6 -8
  42. package/dist/cjs/features/RowSelection.cjs.map +1 -1
  43. package/dist/cjs/features/RowSorting.cjs +6 -7
  44. package/dist/cjs/features/RowSorting.cjs.map +1 -1
  45. package/dist/cjs/index.cjs +5 -4
  46. package/dist/cjs/index.cjs.map +1 -1
  47. package/dist/cjs/types.d.cts +8 -8
  48. package/dist/cjs/utils/filterRowsUtils.cjs +2 -2
  49. package/dist/cjs/utils/filterRowsUtils.cjs.map +1 -1
  50. package/dist/cjs/utils/getCoreRowModel.cjs +1 -1
  51. package/dist/cjs/utils/getCoreRowModel.cjs.map +1 -1
  52. package/dist/cjs/utils/getFacetedMinMaxValues.cjs +1 -2
  53. package/dist/cjs/utils/getFacetedMinMaxValues.cjs.map +1 -1
  54. package/dist/cjs/utils/getFacetedUniqueValues.cjs +1 -2
  55. package/dist/cjs/utils/getFacetedUniqueValues.cjs.map +1 -1
  56. package/dist/cjs/utils/getGroupedRowModel.cjs +1 -1
  57. package/dist/cjs/utils/getGroupedRowModel.cjs.map +1 -1
  58. package/dist/cjs/utils/getSortedRowModel.cjs +3 -6
  59. package/dist/cjs/utils/getSortedRowModel.cjs.map +1 -1
  60. package/dist/cjs/utils.cjs +2 -4
  61. package/dist/cjs/utils.cjs.map +1 -1
  62. package/dist/esm/aggregationFns.js +4 -8
  63. package/dist/esm/aggregationFns.js.map +1 -1
  64. package/dist/esm/core/cell.d.ts +1 -1
  65. package/dist/esm/core/cell.js +3 -3
  66. package/dist/esm/core/cell.js.map +1 -1
  67. package/dist/esm/core/column.d.ts +1 -1
  68. package/dist/esm/core/column.js +3 -3
  69. package/dist/esm/core/column.js.map +1 -1
  70. package/dist/esm/core/headers.js +5 -5
  71. package/dist/esm/core/headers.js.map +1 -1
  72. package/dist/esm/core/row.d.ts +1 -1
  73. package/dist/esm/core/row.js +6 -7
  74. package/dist/esm/core/row.js.map +1 -1
  75. package/dist/esm/core/table.d.ts +9 -1
  76. package/dist/esm/core/table.js +12 -8
  77. package/dist/esm/core/table.js.map +1 -1
  78. package/dist/esm/features/ColumnFaceting.js +1 -1
  79. package/dist/esm/features/ColumnFaceting.js.map +1 -1
  80. package/dist/esm/features/ColumnFiltering.js +6 -6
  81. package/dist/esm/features/ColumnFiltering.js.map +1 -1
  82. package/dist/esm/features/ColumnGrouping.js +8 -9
  83. package/dist/esm/features/ColumnGrouping.js.map +1 -1
  84. package/dist/esm/features/ColumnOrdering.js +4 -4
  85. package/dist/esm/features/ColumnOrdering.js.map +1 -1
  86. package/dist/esm/features/ColumnPinning.js +5 -5
  87. package/dist/esm/features/ColumnPinning.js.map +1 -1
  88. package/dist/esm/features/ColumnSizing.js +7 -8
  89. package/dist/esm/features/ColumnSizing.js.map +1 -1
  90. package/dist/esm/features/ColumnVisibility.js +5 -5
  91. package/dist/esm/features/ColumnVisibility.js.map +1 -1
  92. package/dist/esm/features/GlobalFaceting.js +1 -1
  93. package/dist/esm/features/GlobalFaceting.js.map +1 -1
  94. package/dist/esm/features/GlobalFiltering.js +4 -4
  95. package/dist/esm/features/GlobalFiltering.js.map +1 -1
  96. package/dist/esm/features/RowExpanding.js +6 -8
  97. package/dist/esm/features/RowExpanding.js.map +1 -1
  98. package/dist/esm/features/RowPagination.js +4 -5
  99. package/dist/esm/features/RowPagination.js.map +1 -1
  100. package/dist/esm/features/RowPinning.js +5 -6
  101. package/dist/esm/features/RowPinning.js.map +1 -1
  102. package/dist/esm/features/RowSelection.js +6 -8
  103. package/dist/esm/features/RowSelection.js.map +1 -1
  104. package/dist/esm/features/RowSorting.js +6 -7
  105. package/dist/esm/features/RowSorting.js.map +1 -1
  106. package/dist/esm/index.js +10 -9
  107. package/dist/esm/types.d.ts +8 -8
  108. package/dist/esm/utils/filterRowsUtils.js +3 -3
  109. package/dist/esm/utils/filterRowsUtils.js.map +1 -1
  110. package/dist/esm/utils/getCoreRowModel.js +2 -2
  111. package/dist/esm/utils/getCoreRowModel.js.map +1 -1
  112. package/dist/esm/utils/getFacetedMinMaxValues.js +1 -2
  113. package/dist/esm/utils/getFacetedMinMaxValues.js.map +1 -1
  114. package/dist/esm/utils/getFacetedUniqueValues.js +1 -2
  115. package/dist/esm/utils/getFacetedUniqueValues.js.map +1 -1
  116. package/dist/esm/utils/getGroupedRowModel.js +2 -2
  117. package/dist/esm/utils/getGroupedRowModel.js.map +1 -1
  118. package/dist/esm/utils/getSortedRowModel.js +3 -6
  119. package/dist/esm/utils/getSortedRowModel.js.map +1 -1
  120. package/dist/esm/utils.js +2 -4
  121. package/dist/esm/utils.js.map +1 -1
  122. package/package.json +1 -1
  123. package/src/core/cell.ts +2 -2
  124. package/src/core/column.ts +2 -2
  125. package/src/core/headers.ts +5 -5
  126. package/src/core/row.ts +4 -4
  127. package/src/core/table.ts +43 -7
  128. package/src/features/ColumnFaceting.ts +1 -1
  129. package/src/features/ColumnFiltering.ts +6 -6
  130. package/src/features/ColumnGrouping.ts +7 -7
  131. package/src/features/ColumnOrdering.ts +4 -4
  132. package/src/features/ColumnPinning.ts +5 -5
  133. package/src/features/ColumnSizing.ts +6 -6
  134. package/src/features/ColumnVisibility.ts +5 -5
  135. package/src/features/GlobalFaceting.ts +1 -1
  136. package/src/features/GlobalFiltering.ts +4 -4
  137. package/src/features/RowExpanding.ts +4 -4
  138. package/src/features/RowPagination.ts +3 -3
  139. package/src/features/RowPinning.ts +4 -4
  140. package/src/features/RowSelection.ts +4 -4
  141. package/src/features/RowSorting.ts +5 -5
  142. package/src/types.ts +8 -8
  143. package/src/utils/filterRowsUtils.ts +3 -3
  144. package/src/utils/getCoreRowModel.ts +2 -2
  145. package/src/utils/getGroupedRowModel.ts +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"RowExpanding.js","sources":["../../../src/features/RowExpanding.ts"],"sourcesContent":["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<string, boolean>\nexport type ExpandedState = true | Record<string, boolean>\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<TData extends RowData> {\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<any>) => () => RowModel<any>\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<TData>) => 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<TData>) => 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<ExpandedState>\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<TData extends RowData> {\n _autoResetExpanded: () => void\n _getExpandedRowModel?: () => RowModel<TData>\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<TData>\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<TData>\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<ExpandedState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): ExpandedOptions<TData> => {\n return {\n onExpandedChange: makeStateUpdater('expanded', table),\n paginateExpandedRows: true,\n }\n },\n\n createTable: <TData extends RowData>(table: Table<TData>): 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: <TData extends RowData>(\n row: Row<TData>,\n table: Table<TData>\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"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"RowExpanding.js","sources":["../../../src/features/RowExpanding.ts"],"sourcesContent":["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<string, boolean>\nexport type ExpandedState = true | Record<string, boolean>\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<TData extends RowData> {\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<any>) => () => RowModel<any>\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<TData>) => 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<TData>) => 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<ExpandedState>\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<TData extends RowData> {\n _autoResetExpanded: () => void\n _getExpandedRowModel?: () => RowModel<TData>\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<TData>\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<TData>\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<ExpandedState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): ExpandedOptions<TData> => {\n return {\n onExpandedChange: makeStateUpdater('expanded', table),\n paginateExpandedRows: true,\n }\n },\n\n _createTable: <TData extends RowData>(table: Table<TData>): 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: <TData extends RowData>(\n row: Row<TData>,\n table: Table<TData>\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"],"names":[],"mappings":";AAwKO,MAAM,eAA6B;AAAA,EACxC,kBAAkB,CAAC,UAA8B;AACxC,WAAA;AAAA,MACL,UAAU,CAAC;AAAA,MACX,GAAG;AAAA,IAAA;AAAA,EAEP;AAAA,EAEA,oBAAoB,CAClB,UAC2B;AACpB,WAAA;AAAA,MACL,kBAAkB,iBAAiB,YAAY,KAAK;AAAA,MACpD,sBAAsB;AAAA,IAAA;AAAA,EAE1B;AAAA,EAEA,cAAc,CAAwB,UAA8B;AAClE,QAAI,aAAa;AACjB,QAAI,SAAS;AAEb,UAAM,qBAAqB,MAAM;AAC/B,UAAI,CAAC,YAAY;AACf,cAAM,OAAO,MAAM;AACJ,uBAAA;AAAA,QAAA,CACd;AACD;AAAA,MACF;AAGE,UAAA,MAAM,QAAQ,gBACd,MAAM,QAAQ,qBACd,CAAC,MAAM,QAAQ,iBACf;AACA,YAAI,OAAQ;AACH,iBAAA;AACT,cAAM,OAAO,MAAM;AACjB,gBAAM,cAAc;AACX,mBAAA;AAAA,QAAA,CACV;AAAA,MACH;AAAA,IAAA;AAEF,UAAM,cAAc,CAAA,YAAA;;AAAW,+BAAM,SAAQ,qBAAd,4BAAiC;AAAA;AAChE,UAAM,wBAAwB,CAAY,aAAA;AACxC,UAAI,YAAY,CAAC,MAAM,wBAAwB;AAC7C,cAAM,YAAY,IAAI;AAAA,MAAA,OACjB;AACC,cAAA,YAAY,CAAA,CAAE;AAAA,MACtB;AAAA,IAAA;AAEF,UAAM,gBAAgB,CAAgB,iBAAA;;AAC9B,YAAA,YAAY,eAAe,CAAC,MAAI,WAAM,iBAAN,mBAAoB,aAAY,CAAA,CAAE;AAAA,IAAA;AAE1E,UAAM,uBAAuB,MAAM;AAC1B,aAAA,MACJ,yBACA,EAAA,SAAS,KAAK,CAAO,QAAA,IAAI,cAAc;AAAA,IAAA;AAE5C,UAAM,kCAAkC,MAAM;AAC5C,aAAO,CAAC,MAAe;;AACnB,gBAAU,YAAV;AACF,cAAM,sBAAsB;AAAA,MAAA;AAAA,IAC9B;AAEF,UAAM,wBAAwB,MAAM;AAC5B,YAAA,WAAW,MAAM,SAAA,EAAW;AAClC,aAAO,aAAa,QAAQ,OAAO,OAAO,QAAQ,EAAE,KAAK,OAAO;AAAA,IAAA;AAElE,UAAM,uBAAuB,MAAM;AAC3B,YAAA,WAAW,MAAM,SAAA,EAAW;AAG9B,UAAA,OAAO,aAAa,WAAW;AACjC,eAAO,aAAa;AAAA,MACtB;AAEA,UAAI,CAAC,OAAO,KAAK,QAAQ,EAAE,QAAQ;AAC1B,eAAA;AAAA,MACT;AAGI,UAAA,MAAM,YAAY,EAAE,SAAS,KAAK,SAAO,CAAC,IAAI,cAAc,CAAC,GAAG;AAC3D,eAAA;AAAA,MACT;AAGO,aAAA;AAAA,IAAA;AAET,UAAM,mBAAmB,MAAM;AAC7B,UAAI,WAAW;AAEf,YAAM,SACJ,MAAM,SAAA,EAAW,aAAa,OAC1B,OAAO,KAAK,MAAM,cAAc,QAAQ,IACxC,OAAO,KAAK,MAAM,SAAA,EAAW,QAAQ;AAE3C,aAAO,QAAQ,CAAM,OAAA;AACb,cAAA,UAAU,GAAG,MAAM,GAAG;AAC5B,mBAAW,KAAK,IAAI,UAAU,QAAQ,MAAM;AAAA,MAAA,CAC7C;AAEM,aAAA;AAAA,IAAA;AAEH,UAAA,yBAAyB,MAAM,MAAM,kBAAkB;AAC7D,UAAM,sBAAsB,MAAM;AAChC,UAAI,CAAC,MAAM,wBAAwB,MAAM,QAAQ,qBAAqB;AACpE,cAAM,uBAAuB,MAAM,QAAQ,oBAAoB,KAAK;AAAA,MACtE;AAEA,UAAI,MAAM,QAAQ,mBAAmB,CAAC,MAAM,sBAAsB;AAChE,eAAO,MAAM;MACf;AAEA,aAAO,MAAM;IAAqB;AAAA,EAEtC;AAAA,EAEA,YAAY,CACV,KACA,UACS;AACT,QAAI,iBAAiB,CAAY,aAAA;AAC/B,YAAM,YAAY,CAAO,QAAA;AACjB,cAAA,SAAS,QAAQ,OAAO,OAAO,CAAC,EAAC,2BAAM,IAAI;AAEjD,YAAI,cAAiC,CAAA;AAErC,YAAI,QAAQ,MAAM;AAChB,iBAAO,KAAK,MAAM,YAAA,EAAc,QAAQ,EAAE,QAAQ,CAAS,UAAA;AACzD,wBAAY,KAAK,IAAI;AAAA,UAAA,CACtB;AAAA,QAAA,OACI;AACS,wBAAA;AAAA,QAChB;AAEA,mBAAW,YAAY,CAAC;AAEpB,YAAA,CAAC,UAAU,UAAU;AAChB,iBAAA;AAAA,YACL,GAAG;AAAA,YACH,CAAC,IAAI,EAAE,GAAG;AAAA,UAAA;AAAA,QAEd;AAEI,YAAA,UAAU,CAAC,UAAU;AACjB,gBAAA,EAAE,CAAC,IAAI,EAAE,GAAG,GAAG,GAAG,KAAS,IAAA;AAC1B,iBAAA;AAAA,QACT;AAEO,eAAA;AAAA,MAAA,CACR;AAAA,IAAA;AAEH,QAAI,gBAAgB,MAAM;;AAClB,YAAA,WAAW,MAAM,SAAA,EAAW;AAE3B,aAAA,CAAC,IACN,iBAAM,SAAQ,qBAAd,4BAAiC,UAChC,aAAa,SAAQ,qCAAW,IAAI;AAAA,IAAE;AAG3C,QAAI,eAAe,MAAM;;AACvB,eACE,iBAAM,SAAQ,oBAAd,4BAAgC,WAC9B,MAAM,QAAQ,mBAAmB,SAAS,CAAC,GAAC,SAAI,YAAJ,mBAAa;AAAA,IAAA;AAG/D,QAAI,0BAA0B,MAAM;AAClC,UAAI,kBAAkB;AACtB,UAAI,aAAa;AAEV,aAAA,mBAAmB,WAAW,UAAU;AAC7C,qBAAa,MAAM,OAAO,WAAW,UAAU,IAAI;AACnD,0BAAkB,WAAW;MAC/B;AAEO,aAAA;AAAA,IAAA;AAET,QAAI,2BAA2B,MAAM;AAC7B,YAAA,YAAY,IAAI;AAEtB,aAAO,MAAM;AACX,YAAI,CAAC,UAAW;AAChB,YAAI,eAAe;AAAA,MAAA;AAAA,IACrB;AAAA,EAEJ;AACF;"}
@@ -6,7 +6,7 @@ const getDefaultPaginationState = () => ({
6
6
  pageSize: defaultPageSize
7
7
  });
8
8
  const RowPagination = {
9
- getInitialState: (state) => {
9
+ _getInitialState: (state) => {
10
10
  return {
11
11
  ...state,
12
12
  pagination: {
@@ -15,12 +15,12 @@ const RowPagination = {
15
15
  }
16
16
  };
17
17
  },
18
- getDefaultOptions: (table) => {
18
+ _getDefaultOptions: (table) => {
19
19
  return {
20
20
  onPaginationChange: makeStateUpdater("pagination", table)
21
21
  };
22
22
  },
23
- createTable: (table) => {
23
+ _createTable: (table) => {
24
24
  let registered = false;
25
25
  let queued = false;
26
26
  table._autoResetPageIndex = () => {
@@ -31,8 +31,7 @@ const RowPagination = {
31
31
  return;
32
32
  }
33
33
  if (table.options.autoResetAll ?? table.options.autoResetPageIndex ?? !table.options.manualPagination) {
34
- if (queued)
35
- return;
34
+ if (queued) return;
36
35
  queued = true;
37
36
  table._queue(() => {
38
37
  table.resetPageIndex();
@@ -1 +1 @@
1
- {"version":3,"file":"RowPagination.js","sources":["../../../src/features/RowPagination.ts"],"sourcesContent":["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<PaginationState>\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<any>) => () => RowModel<any>\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<PaginationState>\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<PaginationState>\n}\n\nexport interface PaginationInstance<TData extends RowData> {\n _autoResetPageIndex: () => void\n _getPaginationRowModel?: () => RowModel<TData>\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<TData>\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<TData>\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<number>) => 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<number>) => 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<number>) => 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<PaginationState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): PaginationDefaultOptions => {\n return {\n onPaginationChange: makeStateUpdater('pagination', table),\n }\n },\n\n createTable: <TData extends RowData>(table: Table<TData>): 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<PaginationState> = 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"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"RowPagination.js","sources":["../../../src/features/RowPagination.ts"],"sourcesContent":["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<PaginationState>\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<any>) => () => RowModel<any>\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<PaginationState>\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<PaginationState>\n}\n\nexport interface PaginationInstance<TData extends RowData> {\n _autoResetPageIndex: () => void\n _getPaginationRowModel?: () => RowModel<TData>\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<TData>\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<TData>\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<number>) => 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<number>) => 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<number>) => 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<PaginationState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): PaginationDefaultOptions => {\n return {\n onPaginationChange: makeStateUpdater('pagination', table),\n }\n },\n\n _createTable: <TData extends RowData>(table: Table<TData>): 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<PaginationState> = 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"],"names":[],"mappings":"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"}
@@ -4,18 +4,18 @@ const getDefaultRowPinningState = () => ({
4
4
  bottom: []
5
5
  });
6
6
  const RowPinning = {
7
- getInitialState: (state) => {
7
+ _getInitialState: (state) => {
8
8
  return {
9
9
  rowPinning: getDefaultRowPinningState(),
10
10
  ...state
11
11
  };
12
12
  },
13
- getDefaultOptions: (table) => {
13
+ _getDefaultOptions: (table) => {
14
14
  return {
15
15
  onRowPinningChange: makeStateUpdater("rowPinning", table)
16
16
  };
17
17
  },
18
- createRow: (row, table) => {
18
+ _createRow: (row, table) => {
19
19
  row.pin = (position, includeLeafRows, includeParentRows) => {
20
20
  const leafRowIds = includeLeafRows ? row.getLeafRows().map(({ id }) => id) : [];
21
21
  const parentRowIds = includeParentRows ? row.getParentRows().map(({ id }) => id) : [];
@@ -62,13 +62,12 @@ const RowPinning = {
62
62
  row.getPinnedIndex = () => {
63
63
  var _a;
64
64
  const position = row.getIsPinned();
65
- if (!position)
66
- return -1;
65
+ if (!position) return -1;
67
66
  const visiblePinnedRowIds = (_a = table._getPinnedRows(position)) == null ? void 0 : _a.map(({ id }) => id);
68
67
  return (visiblePinnedRowIds == null ? void 0 : visiblePinnedRowIds.indexOf(row.id)) ?? -1;
69
68
  };
70
69
  },
71
- createTable: (table) => {
70
+ _createTable: (table) => {
72
71
  table.setRowPinning = (updater) => {
73
72
  var _a, _b;
74
73
  return (_b = (_a = table.options).onRowPinningChange) == null ? void 0 : _b.call(_a, updater);
@@ -1 +1 @@
1
- {"version":3,"file":"RowPinning.js","sources":["../../../src/features/RowPinning.ts"],"sourcesContent":["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<TData extends RowData> {\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<TData>) => 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<RowPinningState>\n}\n\nexport interface RowPinningDefaultOptions {\n onRowPinningChange: OnChangeFn<RowPinningState>\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<TData extends RowData> {\n _getPinnedRows: (position: 'top' | 'bottom') => Row<TData>[]\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<TData>[]\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<TData>[]\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<TData>[]\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<RowPinningState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): RowPinningDefaultOptions => {\n return {\n onRowPinningChange: makeStateUpdater('rowPinning', table),\n }\n },\n\n createRow: <TData extends RowData>(\n row: Row<TData>,\n table: Table<TData>\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 = table\n ._getPinnedRows(position)\n ?.map(({ id }) => id)\n\n return visiblePinnedRowIds?.indexOf(row.id) ?? -1\n }\n },\n\n createTable: <TData extends RowData>(table: Table<TData>): 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 = memo(\n position => [\n table.getRowModel().rows,\n table.getState().rowPinning[position!],\n position,\n ],\n (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\n .filter(Boolean)\n .map(d => ({ ...d, position })) as Row<TData>[]\n },\n getMemoOptions(table.options, 'debugRows', '_getPinnedRows')\n )\n\n table.getTopRows = () => table._getPinnedRows('top')\n\n table.getBottomRows = () => table._getPinnedRows('bottom')\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"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"RowPinning.js","sources":["../../../src/features/RowPinning.ts"],"sourcesContent":["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<TData extends RowData> {\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<TData>) => 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<RowPinningState>\n}\n\nexport interface RowPinningDefaultOptions {\n onRowPinningChange: OnChangeFn<RowPinningState>\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<TData extends RowData> {\n _getPinnedRows: (position: 'top' | 'bottom') => Row<TData>[]\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<TData>[]\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<TData>[]\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<TData>[]\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<RowPinningState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): RowPinningDefaultOptions => {\n return {\n onRowPinningChange: makeStateUpdater('rowPinning', table),\n }\n },\n\n _createRow: <TData extends RowData>(\n row: Row<TData>,\n table: Table<TData>\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 = table\n ._getPinnedRows(position)\n ?.map(({ id }) => id)\n\n return visiblePinnedRowIds?.indexOf(row.id) ?? -1\n }\n },\n\n _createTable: <TData extends RowData>(table: Table<TData>): 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 = memo(\n position => [\n table.getRowModel().rows,\n table.getState().rowPinning[position!],\n position,\n ],\n (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\n .filter(Boolean)\n .map(d => ({ ...d, position })) as Row<TData>[]\n },\n getMemoOptions(table.options, 'debugRows', '_getPinnedRows')\n )\n\n table.getTopRows = () => table._getPinnedRows('top')\n\n table.getBottomRows = () => table._getPinnedRows('bottom')\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"],"names":[],"mappings":"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"}
@@ -1,12 +1,12 @@
1
1
  import { makeStateUpdater, memo, getMemoOptions } from "../utils.js";
2
2
  const RowSelection = {
3
- getInitialState: (state) => {
3
+ _getInitialState: (state) => {
4
4
  return {
5
5
  rowSelection: {},
6
6
  ...state
7
7
  };
8
8
  },
9
- getDefaultOptions: (table) => {
9
+ _getDefaultOptions: (table) => {
10
10
  return {
11
11
  onRowSelectionChange: makeStateUpdater("rowSelection", table),
12
12
  enableRowSelection: true,
@@ -17,7 +17,7 @@ const RowSelection = {
17
17
  // isInclusiveSelectEvent: (e: unknown) => !!e.shiftKey,
18
18
  };
19
19
  },
20
- createTable: (table) => {
20
+ _createTable: (table) => {
21
21
  table.setRowSelection = (updater) => {
22
22
  var _a, _b;
23
23
  return (_b = (_a = table.options).onRowSelectionChange) == null ? void 0 : _b.call(_a, updater);
@@ -145,7 +145,7 @@ const RowSelection = {
145
145
  };
146
146
  };
147
147
  },
148
- createRow: (row, table) => {
148
+ _createRow: (row, table) => {
149
149
  row.toggleSelected = (value, opts) => {
150
150
  const isSelected = row.getIsSelected();
151
151
  table.setRowSelection((old) => {
@@ -198,8 +198,7 @@ const RowSelection = {
198
198
  const canSelect = row.getCanSelect();
199
199
  return (e) => {
200
200
  var _a;
201
- if (!canSelect)
202
- return;
201
+ if (!canSelect) return;
203
202
  row.toggleSelected(
204
203
  (_a = e.target) == null ? void 0 : _a.checked
205
204
  );
@@ -260,8 +259,7 @@ function isRowSelected(row, selection) {
260
259
  }
261
260
  function isSubRowSelected(row, selection, table) {
262
261
  var _a;
263
- if (!((_a = row.subRows) == null ? void 0 : _a.length))
264
- return false;
262
+ if (!((_a = row.subRows) == null ? void 0 : _a.length)) return false;
265
263
  let allChildrenSelected = true;
266
264
  let someSelected = false;
267
265
  row.subRows.forEach((subRow) => {
@@ -1 +1 @@
1
- {"version":3,"file":"RowSelection.js","sources":["../../../src/features/RowSelection.ts"],"sourcesContent":["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<string, boolean>\n\nexport interface RowSelectionTableState {\n rowSelection: RowSelectionState\n}\n\nexport interface RowSelectionOptions<TData extends RowData> {\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<TData>) => 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<TData>) => 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<TData>) => 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<RowSelectionState>\n // enableGroupingRowSelection?:\n // | boolean\n // | ((\n // row: Row<TData>\n // ) => boolean)\n // isAdditiveSelectEvent?: (e: unknown) => boolean\n // isInclusiveSelectEvent?: (e: unknown) => boolean\n // selectRowsFn?: (\n // table: Table<TData>,\n // rowModel: RowModel<TData>\n // ) => RowModel<TData>\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<TData extends RowData> {\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<TData>\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<TData>\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<TData>\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<TData>\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<RowSelectionState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): RowSelectionOptions<TData> => {\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: <TData extends RowData>(table: Table<TData>): 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: <TData extends RowData>(\n row: Row<TData>,\n table: Table<TData>\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 = <TData extends RowData>(\n selectedRowIds: Record<string, boolean>,\n id: string,\n value: boolean,\n includeChildren: boolean,\n table: Table<TData>\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<TData extends RowData>(\n table: Table<TData>,\n rowModel: RowModel<TData>\n): RowModel<TData> {\n const rowSelection = table.getState().rowSelection\n\n const newSelectedFlatRows: Row<TData>[] = []\n const newSelectedRowsById: Record<string, Row<TData>> = {}\n\n // Filters top level and nested rows\n const recurseRows = (rows: Row<TData>[], depth = 0): Row<TData>[] => {\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<TData>[]\n }\n\n return {\n rows: recurseRows(rowModel.rows),\n flatRows: newSelectedFlatRows,\n rowsById: newSelectedRowsById,\n }\n}\n\nexport function isRowSelected<TData extends RowData>(\n row: Row<TData>,\n selection: Record<string, boolean>\n): boolean {\n return selection[row.id] ?? false\n}\n\nexport function isSubRowSelected<TData extends RowData>(\n row: Row<TData>,\n selection: Record<string, boolean>,\n table: Table<TData>\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"],"names":["row"],"mappings":";AAsMO,MAAM,eAA6B;AAAA,EACxC,iBAAiB,CAAC,UAAkC;AAC3C,WAAA;AAAA,MACL,cAAc,CAAC;AAAA,MACf,GAAG;AAAA,IAAA;AAAA,EAEP;AAAA,EAEA,mBAAmB,CACjB,UAC+B;AACxB,WAAA;AAAA,MACL,sBAAsB,iBAAiB,gBAAgB,KAAK;AAAA,MAC5D,oBAAoB;AAAA,MACpB,yBAAyB;AAAA,MACzB,uBAAuB;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,EAK3B;AAAA,EAEA,aAAa,CAAwB,UAA8B;AACjE,UAAM,kBAAkB,CAAA,YAAA;;AACtB,+BAAM,SAAQ,yBAAd,4BAAqC;AAAA;AACjC,UAAA,oBAAoB,kBACxB,MAAM;AAAA,MACJ,eAAe,CAAA,IAAK,MAAM,aAAa,gBAAgB,CAAC;AAAA,IAAA;AAE5D,UAAM,wBAAwB,CAAS,UAAA;AACrC,YAAM,gBAAgB,CAAO,QAAA;AAC3B,gBACE,OAAO,UAAU,cAAc,QAAQ,CAAC,MAAM;AAE1C,cAAA,eAAe,EAAE,GAAG;AAEpB,cAAA,qBAAqB,MAAM,sBAAA,EAAwB;AAIzD,YAAI,OAAO;AACT,6BAAmB,QAAQ,CAAO,QAAA;AAC5B,gBAAA,CAAC,IAAI,gBAAgB;AACvB;AAAA,YACF;AACa,yBAAA,IAAI,EAAE,IAAI;AAAA,UAAA,CACxB;AAAA,QAAA,OACI;AACL,6BAAmB,QAAQ,CAAO,QAAA;AACzB,mBAAA,aAAa,IAAI,EAAE;AAAA,UAAA,CAC3B;AAAA,QACH;AAEO,eAAA;AAAA,MAAA,CACR;AAAA,IAAA;AAEH,UAAM,4BAA4B,CAAA,UAChC,MAAM,gBAAgB,CAAO,QAAA;AAC3B,YAAM,gBACJ,OAAO,UAAU,cACb,QACA,CAAC,MAAM;AAEP,YAAA,eAAkC,EAAE,GAAG;AAE7C,YAAM,YAAY,EAAE,KAAK,QAAQ,CAAO,QAAA;AACtC,4BAAoB,cAAc,IAAI,IAAI,eAAe,MAAM,KAAK;AAAA,MAAA,CACrE;AAEM,aAAA;AAAA,IAAA,CACR;AA4DG,UAAA,yBAAyB,MAAM,MAAM,gBAAgB;AAC3D,UAAM,sBAAsB;AAAA,MAC1B,MAAM,CAAC,MAAM,SAAA,EAAW,cAAc,MAAM,iBAAiB;AAAA,MAC7D,CAAC,cAAc,aAAa;AAC1B,YAAI,CAAC,OAAO,KAAK,YAAY,EAAE,QAAQ;AAC9B,iBAAA;AAAA,YACL,MAAM,CAAC;AAAA,YACP,UAAU,CAAC;AAAA,YACX,UAAU,CAAC;AAAA,UAAA;AAAA,QAEf;AAEO,eAAA,aAAa,OAAO,QAAQ;AAAA,MACrC;AAAA,MACA,eAAe,MAAM,SAAS,cAAc,qBAAqB;AAAA,IAAA;AAGnE,UAAM,8BAA8B;AAAA,MAClC,MAAM,CAAC,MAAM,SAAA,EAAW,cAAc,MAAM,qBAAqB;AAAA,MACjE,CAAC,cAAc,aAAa;AAC1B,YAAI,CAAC,OAAO,KAAK,YAAY,EAAE,QAAQ;AAC9B,iBAAA;AAAA,YACL,MAAM,CAAC;AAAA,YACP,UAAU,CAAC;AAAA,YACX,UAAU,CAAC;AAAA,UAAA;AAAA,QAEf;AAEO,eAAA,aAAa,OAAO,QAAQ;AAAA,MACrC;AAAA,MACA,eAAe,MAAM,SAAS,cAAc,6BAA6B;AAAA,IAAA;AAG3E,UAAM,6BAA6B;AAAA,MACjC,MAAM,CAAC,MAAM,SAAA,EAAW,cAAc,MAAM,mBAAmB;AAAA,MAC/D,CAAC,cAAc,aAAa;AAC1B,YAAI,CAAC,OAAO,KAAK,YAAY,EAAE,QAAQ;AAC9B,iBAAA;AAAA,YACL,MAAM,CAAC;AAAA,YACP,UAAU,CAAC;AAAA,YACX,UAAU,CAAC;AAAA,UAAA;AAAA,QAEf;AAEO,eAAA,aAAa,OAAO,QAAQ;AAAA,MACrC;AAAA,MACA,eAAe,MAAM,SAAS,cAAc,4BAA4B;AAAA,IAAA;AAmB1E,UAAM,uBAAuB,MAAM;AAC3B,YAAA,qBAAqB,MAAM,oBAAA,EAAsB;AACvD,YAAM,EAAE,aAAA,IAAiB,MAAM,SAAS;AAExC,UAAI,oBAAoB;AAAA,QACtB,mBAAmB,UAAU,OAAO,KAAK,YAAY,EAAE;AAAA,MAAA;AAGzD,UAAI,mBAAmB;AACrB,YACE,mBAAmB;AAAA,UACjB,SAAO,IAAI,aAAA,KAAkB,CAAC,aAAa,IAAI,EAAE;AAAA,QAAA,GAEnD;AACoB,8BAAA;AAAA,QACtB;AAAA,MACF;AAEO,aAAA;AAAA,IAAA;AAGT,UAAM,2BAA2B,MAAM;AAC/B,YAAA,qBAAqB,MACxB,sBAAsB,EACtB,SAAS,OAAO,CAAA,QAAO,IAAI,aAAA,CAAc;AAC5C,YAAM,EAAE,aAAA,IAAiB,MAAM,SAAS;AAEpC,UAAA,wBAAwB,CAAC,CAAC,mBAAmB;AAG/C,UAAA,yBACA,mBAAmB,KAAK,CAAA,QAAO,CAAC,aAAa,IAAI,EAAE,CAAC,GACpD;AACwB,gCAAA;AAAA,MAC1B;AAEO,aAAA;AAAA,IAAA;AAGT,UAAM,wBAAwB,MAAM;AAClC,YAAM,gBAAgB,OAAO;AAAA,QAC3B,MAAM,WAAW,gBAAgB,CAAC;AAAA,MAClC,EAAA;AACF,aACE,gBAAgB,KAChB,gBAAgB,MAAM,sBAAsB,SAAS;AAAA,IAAA;AAIzD,UAAM,4BAA4B,MAAM;AAChC,YAAA,qBAAqB,MAAM,sBAAA,EAAwB;AACzD,aAAO,MAAM,yBAAyB,IAClC,QACA,mBACG,OAAO,SAAO,IAAI,aAAc,CAAA,EAChC,KAAK,CAAK,MAAA,EAAE,mBAAmB,EAAE,mBAAmB;AAAA,IAAA;AAG7D,UAAM,kCAAkC,MAAM;AAC5C,aAAO,CAAC,MAAe;AACf,cAAA;AAAA,UACF,EAAiB,OAA4B;AAAA,QAAA;AAAA,MACjD;AAAA,IACF;AAGF,UAAM,sCAAsC,MAAM;AAChD,aAAO,CAAC,MAAe;AACf,cAAA;AAAA,UACF,EAAiB,OAA4B;AAAA,QAAA;AAAA,MACjD;AAAA,IACF;AAAA,EAEJ;AAAA,EAEA,WAAW,CACT,KACA,UACS;AACL,QAAA,iBAAiB,CAAC,OAAO,SAAS;AAC9B,YAAA,aAAa,IAAI;AAEvB,YAAM,gBAAgB,CAAO,QAAA;AAC3B,gBAAQ,OAAO,UAAU,cAAc,QAAQ,CAAC;AAEhD,YAAI,IAAI,kBAAkB,eAAe,OAAO;AACvC,iBAAA;AAAA,QACT;AAEM,cAAA,iBAAiB,EAAE,GAAG;AAE5B;AAAA,UACE;AAAA,UACA,IAAI;AAAA,UACJ;AAAA,WACA,6BAAM,mBAAkB;AAAA,UACxB;AAAA,QAAA;AAGK,eAAA;AAAA,MAAA,CACR;AAAA,IAAA;AAEH,QAAI,gBAAgB,MAAM;AACxB,YAAM,EAAE,aAAA,IAAiB,MAAM,SAAS;AACjC,aAAA,cAAc,KAAK,YAAY;AAAA,IAAA;AAGxC,QAAI,oBAAoB,MAAM;AAC5B,YAAM,EAAE,aAAA,IAAiB,MAAM,SAAS;AACxC,aAAO,iBAAiB,KAAK,YAAmB,MAAM;AAAA,IAAA;AAGxD,QAAI,0BAA0B,MAAM;AAClC,YAAM,EAAE,aAAA,IAAiB,MAAM,SAAS;AACxC,aAAO,iBAAiB,KAAK,YAAmB,MAAM;AAAA,IAAA;AAGxD,QAAI,eAAe,MAAM;AACvB,UAAI,OAAO,MAAM,QAAQ,uBAAuB,YAAY;AACnD,eAAA,MAAM,QAAQ,mBAAmB,GAAG;AAAA,MAC7C;AAEO,aAAA,MAAM,QAAQ,sBAAsB;AAAA,IAAA;AAG7C,QAAI,sBAAsB,MAAM;AAC9B,UAAI,OAAO,MAAM,QAAQ,0BAA0B,YAAY;AACtD,eAAA,MAAM,QAAQ,sBAAsB,GAAG;AAAA,MAChD;AAEO,aAAA,MAAM,QAAQ,yBAAyB;AAAA,IAAA;AAGhD,QAAI,oBAAoB,MAAM;AAC5B,UAAI,OAAO,MAAM,QAAQ,4BAA4B,YAAY;AACxD,eAAA,MAAM,QAAQ,wBAAwB,GAAG;AAAA,MAClD;AAEO,aAAA,MAAM,QAAQ,2BAA2B;AAAA,IAAA;AAElD,QAAI,2BAA2B,MAAM;AAC7B,YAAA,YAAY,IAAI;AAEtB,aAAO,CAAC,MAAe;;AACrB,YAAI,CAAC;AAAW;AACZ,YAAA;AAAA,WACA,OAAiB,WAAjB,mBAA8C;AAAA,QAAA;AAAA,MAClD;AAAA,IACF;AAAA,EAEJ;AACF;AAEA,MAAM,sBAAsB,CAC1B,gBACA,IACA,OACA,iBACA,UACG;;AACH,QAAM,MAAM,MAAM,OAAO,IAAI,IAAI;AAQjC,MAAI,OAAO;AACL,QAAA,CAAC,IAAI,qBAAqB;AACrB,aAAA,KAAK,cAAc,EAAE,QAAQ,SAAO,OAAO,eAAe,GAAG,CAAC;AAAA,IACvE;AACI,QAAA,IAAI,gBAAgB;AACtB,qBAAe,EAAE,IAAI;AAAA,IACvB;AAAA,EAAA,OACK;AACL,WAAO,eAAe,EAAE;AAAA,EAC1B;AAGA,MAAI,qBAAmB,SAAI,YAAJ,mBAAa,WAAU,IAAI,uBAAuB;AACvE,QAAI,QAAQ;AAAA,MAAQ,CAAAA,SAClB,oBAAoB,gBAAgBA,KAAI,IAAI,OAAO,iBAAiB,KAAK;AAAA,IAAA;AAAA,EAE7E;AACF;AAEgB,SAAA,aACd,OACA,UACiB;AACX,QAAA,eAAe,MAAM,SAAA,EAAW;AAEtC,QAAM,sBAAoC,CAAA;AAC1C,QAAM,sBAAkD,CAAA;AAGxD,QAAM,cAAc,CAAC,MAAoB,QAAQ,MAAoB;AAC5D,WAAA,KACJ,IAAI,CAAO,QAAA;;AACJ,YAAA,aAAa,cAAc,KAAK,YAAY;AAElD,UAAI,YAAY;AACd,4BAAoB,KAAK,GAAG;AACR,4BAAA,IAAI,EAAE,IAAI;AAAA,MAChC;AAEI,WAAA,SAAI,YAAJ,mBAAa,QAAQ;AACjB,cAAA;AAAA,UACJ,GAAG;AAAA,UACH,SAAS,YAAY,IAAI,SAAS,QAAQ,CAAC;AAAA,QAAA;AAAA,MAE/C;AAEA,UAAI,YAAY;AACP,eAAA;AAAA,MACT;AAAA,IAAA,CACD,EACA,OAAO,OAAO;AAAA,EAAA;AAGZ,SAAA;AAAA,IACL,MAAM,YAAY,SAAS,IAAI;AAAA,IAC/B,UAAU;AAAA,IACV,UAAU;AAAA,EAAA;AAEd;AAEgB,SAAA,cACd,KACA,WACS;AACF,SAAA,UAAU,IAAI,EAAE,KAAK;AAC9B;AAEgB,SAAA,iBACd,KACA,WACA,OAC0B;;AACtB,MAAA,GAAC,SAAI,YAAJ,mBAAa;AAAe,WAAA;AAEjC,MAAI,sBAAsB;AAC1B,MAAI,eAAe;AAEf,MAAA,QAAQ,QAAQ,CAAU,WAAA;AAExB,QAAA,gBAAgB,CAAC,qBAAqB;AACxC;AAAA,IACF;AAEI,QAAA,OAAO,gBAAgB;AACrB,UAAA,cAAc,QAAQ,SAAS,GAAG;AACrB,uBAAA;AAAA,MAAA,OACV;AACiB,8BAAA;AAAA,MACxB;AAAA,IACF;AAGA,QAAI,OAAO,WAAW,OAAO,QAAQ,QAAQ;AAC3C,YAAM,yBAAyB,iBAAiB,QAAQ,SAAgB;AACxE,UAAI,2BAA2B,OAAO;AACrB,uBAAA;AAAA,MAAA,WACN,2BAA2B,QAAQ;AAC7B,uBAAA;AACO,8BAAA;AAAA,MAAA,OACjB;AACiB,8BAAA;AAAA,MACxB;AAAA,IACF;AAAA,EAAA,CACD;AAEM,SAAA,sBAAsB,QAAQ,eAAe,SAAS;AAC/D;"}
1
+ {"version":3,"file":"RowSelection.js","sources":["../../../src/features/RowSelection.ts"],"sourcesContent":["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<string, boolean>\n\nexport interface RowSelectionTableState {\n rowSelection: RowSelectionState\n}\n\nexport interface RowSelectionOptions<TData extends RowData> {\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<TData>) => 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<TData>) => 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<TData>) => 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<RowSelectionState>\n // enableGroupingRowSelection?:\n // | boolean\n // | ((\n // row: Row<TData>\n // ) => boolean)\n // isAdditiveSelectEvent?: (e: unknown) => boolean\n // isInclusiveSelectEvent?: (e: unknown) => boolean\n // selectRowsFn?: (\n // table: Table<TData>,\n // rowModel: RowModel<TData>\n // ) => RowModel<TData>\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<TData extends RowData> {\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<TData>\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<TData>\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<TData>\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<TData>\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<RowSelectionState>) => 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: <TData extends RowData>(\n table: Table<TData>\n ): RowSelectionOptions<TData> => {\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: <TData extends RowData>(table: Table<TData>): 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: <TData extends RowData>(\n row: Row<TData>,\n table: Table<TData>\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 = <TData extends RowData>(\n selectedRowIds: Record<string, boolean>,\n id: string,\n value: boolean,\n includeChildren: boolean,\n table: Table<TData>\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<TData extends RowData>(\n table: Table<TData>,\n rowModel: RowModel<TData>\n): RowModel<TData> {\n const rowSelection = table.getState().rowSelection\n\n const newSelectedFlatRows: Row<TData>[] = []\n const newSelectedRowsById: Record<string, Row<TData>> = {}\n\n // Filters top level and nested rows\n const recurseRows = (rows: Row<TData>[], depth = 0): Row<TData>[] => {\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<TData>[]\n }\n\n return {\n rows: recurseRows(rowModel.rows),\n flatRows: newSelectedFlatRows,\n rowsById: newSelectedRowsById,\n }\n}\n\nexport function isRowSelected<TData extends RowData>(\n row: Row<TData>,\n selection: Record<string, boolean>\n): boolean {\n return selection[row.id] ?? false\n}\n\nexport function isSubRowSelected<TData extends RowData>(\n row: Row<TData>,\n selection: Record<string, boolean>,\n table: Table<TData>\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"],"names":["row"],"mappings":"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"}
@@ -1,19 +1,19 @@
1
1
  import { sortingFns, reSplitAlphaNumeric } from "../sortingFns.js";
2
2
  import { makeStateUpdater, isFunction } from "../utils.js";
3
3
  const RowSorting = {
4
- getInitialState: (state) => {
4
+ _getInitialState: (state) => {
5
5
  return {
6
6
  sorting: [],
7
7
  ...state
8
8
  };
9
9
  },
10
- getDefaultColumnDef: () => {
10
+ _getDefaultColumnDef: () => {
11
11
  return {
12
12
  sortingFn: "auto",
13
13
  sortUndefined: 1
14
14
  };
15
15
  },
16
- getDefaultOptions: (table) => {
16
+ _getDefaultOptions: (table) => {
17
17
  return {
18
18
  onSortingChange: makeStateUpdater("sorting", table),
19
19
  isMultiSortEvent: (e) => {
@@ -21,7 +21,7 @@ const RowSorting = {
21
21
  }
22
22
  };
23
23
  },
24
- createColumn: (column, table) => {
24
+ _createColumn: (column, table) => {
25
25
  column.getAutoSortingFn = () => {
26
26
  const firstRows = table.getFilteredRowModel().flatRows.slice(10);
27
27
  let isString = false;
@@ -163,8 +163,7 @@ const RowSorting = {
163
163
  const canSort = column.getCanSort();
164
164
  return (e) => {
165
165
  var _a, _b, _c, _d;
166
- if (!canSort)
167
- return;
166
+ if (!canSort) return;
168
167
  (_a = e.persist) == null ? void 0 : _a.call(e);
169
168
  (_d = column.toggleSorting) == null ? void 0 : _d.call(
170
169
  column,
@@ -174,7 +173,7 @@ const RowSorting = {
174
173
  };
175
174
  };
176
175
  },
177
- createTable: (table) => {
176
+ _createTable: (table) => {
178
177
  table.setSorting = (updater) => {
179
178
  var _a, _b;
180
179
  return (_b = (_a = table.options).onSortingChange) == null ? void 0 : _b.call(_a, updater);