@raystack/apsara 0.32.0 → 0.33.1

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 (229) hide show
  1. package/dist/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.cjs +92 -0
  2. package/dist/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.cjs.map +1 -1
  3. package/dist/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.js +89 -1
  4. package/dist/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.js.map +1 -1
  5. package/dist/node_modules/.pnpm/@tanstack_react-table@8.9.2_react-dom@18.3.1_react@18.2.0__react@18.2.0/node_modules/@tanstack/react-table/build/lib/index.cjs +1 -0
  6. package/dist/node_modules/.pnpm/@tanstack_react-table@8.9.2_react-dom@18.3.1_react@18.2.0__react@18.2.0/node_modules/@tanstack/react-table/build/lib/index.cjs.map +1 -1
  7. package/dist/node_modules/.pnpm/@tanstack_react-table@8.9.2_react-dom@18.3.1_react@18.2.0__react@18.2.0/node_modules/@tanstack/react-table/build/lib/index.js +1 -1
  8. package/dist/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.cjs +20 -0
  9. package/dist/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.cjs.map +1 -1
  10. package/dist/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.js +20 -1
  11. package/dist/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.js.map +1 -1
  12. package/dist/sidebar/sidebar.cjs +6 -6
  13. package/dist/sidebar/sidebar.cjs.map +1 -1
  14. package/dist/sidebar/sidebar.d.ts +4 -4
  15. package/dist/sidebar/sidebar.js +6 -6
  16. package/dist/sidebar/sidebar.js.map +1 -1
  17. package/dist/style.css +1 -1
  18. package/dist/v1/_virtual/isSameOrAfter.cjs +6 -0
  19. package/dist/v1/_virtual/isSameOrAfter.cjs.map +1 -0
  20. package/dist/v1/_virtual/isSameOrAfter.js +4 -0
  21. package/dist/v1/_virtual/isSameOrAfter.js.map +1 -0
  22. package/dist/v1/_virtual/isSameOrBefore.cjs +6 -0
  23. package/dist/v1/_virtual/isSameOrBefore.cjs.map +1 -0
  24. package/dist/v1/_virtual/isSameOrBefore.js +4 -0
  25. package/dist/v1/_virtual/isSameOrBefore.js.map +1 -0
  26. package/dist/v1/components/calendar/calendar.cjs +1 -1
  27. package/dist/v1/components/calendar/calendar.cjs.map +1 -1
  28. package/dist/v1/components/calendar/calendar.js +1 -1
  29. package/dist/v1/components/calendar/calendar.js.map +1 -1
  30. package/dist/v1/components/calendar/date-picker.cjs +26 -17
  31. package/dist/v1/components/calendar/date-picker.cjs.map +1 -1
  32. package/dist/v1/components/calendar/date-picker.d.ts.map +1 -1
  33. package/dist/v1/components/calendar/date-picker.js +26 -17
  34. package/dist/v1/components/calendar/date-picker.js.map +1 -1
  35. package/dist/v1/components/chip/chip.cjs +3 -3
  36. package/dist/v1/components/chip/chip.cjs.map +1 -1
  37. package/dist/v1/components/chip/chip.d.ts +2 -1
  38. package/dist/v1/components/chip/chip.d.ts.map +1 -1
  39. package/dist/v1/components/chip/chip.js +3 -3
  40. package/dist/v1/components/chip/chip.js.map +1 -1
  41. package/dist/v1/components/data-table/components/content.cjs +81 -0
  42. package/dist/v1/components/data-table/components/content.cjs.map +1 -0
  43. package/dist/v1/components/data-table/components/content.d.ts +3 -0
  44. package/dist/v1/components/data-table/components/content.d.ts.map +1 -0
  45. package/dist/v1/components/data-table/components/content.js +79 -0
  46. package/dist/v1/components/data-table/components/content.js.map +1 -0
  47. package/dist/v1/components/data-table/components/display-properties.cjs +14 -0
  48. package/dist/v1/components/data-table/components/display-properties.cjs.map +1 -0
  49. package/dist/v1/components/data-table/components/display-properties.d.ts +5 -0
  50. package/dist/v1/components/data-table/components/display-properties.d.ts.map +1 -0
  51. package/dist/v1/components/data-table/components/display-properties.js +12 -0
  52. package/dist/v1/components/data-table/components/display-properties.js.map +1 -0
  53. package/dist/v1/components/data-table/components/display-settings.cjs +51 -0
  54. package/dist/v1/components/data-table/components/display-settings.cjs.map +1 -0
  55. package/dist/v1/components/data-table/components/display-settings.d.ts +2 -0
  56. package/dist/v1/components/data-table/components/display-settings.d.ts.map +1 -0
  57. package/dist/v1/components/data-table/components/display-settings.js +49 -0
  58. package/dist/v1/components/data-table/components/display-settings.js.map +1 -0
  59. package/dist/v1/components/data-table/components/filters.cjs +44 -0
  60. package/dist/v1/components/data-table/components/filters.cjs.map +1 -0
  61. package/dist/v1/components/data-table/components/filters.d.ts +2 -0
  62. package/dist/v1/components/data-table/components/filters.d.ts.map +1 -0
  63. package/dist/v1/components/data-table/components/filters.js +42 -0
  64. package/dist/v1/components/data-table/components/filters.js.map +1 -0
  65. package/dist/v1/components/data-table/components/grouping.cjs +31 -0
  66. package/dist/v1/components/data-table/components/grouping.cjs.map +1 -0
  67. package/dist/v1/components/data-table/components/grouping.d.ts +9 -0
  68. package/dist/v1/components/data-table/components/grouping.d.ts.map +1 -0
  69. package/dist/v1/components/data-table/components/grouping.js +29 -0
  70. package/dist/v1/components/data-table/components/grouping.js.map +1 -0
  71. package/dist/v1/components/data-table/components/ordering.cjs +24 -0
  72. package/dist/v1/components/data-table/components/ordering.cjs.map +1 -0
  73. package/dist/v1/components/data-table/components/ordering.d.ts +8 -0
  74. package/dist/v1/components/data-table/components/ordering.d.ts.map +1 -0
  75. package/dist/v1/components/data-table/components/ordering.js +22 -0
  76. package/dist/v1/components/data-table/components/ordering.js.map +1 -0
  77. package/dist/v1/components/data-table/components/search.cjs +30 -0
  78. package/dist/v1/components/data-table/components/search.cjs.map +1 -0
  79. package/dist/v1/components/data-table/components/search.d.ts +3 -0
  80. package/dist/v1/components/data-table/components/search.d.ts.map +1 -0
  81. package/dist/v1/components/data-table/components/search.js +28 -0
  82. package/dist/v1/components/data-table/components/search.js.map +1 -0
  83. package/dist/v1/components/data-table/components/toolbar.cjs +15 -0
  84. package/dist/v1/components/data-table/components/toolbar.cjs.map +1 -0
  85. package/dist/v1/components/data-table/components/toolbar.d.ts +4 -0
  86. package/dist/v1/components/data-table/components/toolbar.d.ts.map +1 -0
  87. package/dist/v1/components/data-table/components/toolbar.js +13 -0
  88. package/dist/v1/components/data-table/components/toolbar.js.map +1 -0
  89. package/dist/v1/components/data-table/context.cjs +8 -0
  90. package/dist/v1/components/data-table/context.cjs.map +1 -0
  91. package/dist/v1/components/data-table/context.d.ts +3 -0
  92. package/dist/v1/components/data-table/context.d.ts.map +1 -0
  93. package/dist/v1/components/data-table/context.js +6 -0
  94. package/dist/v1/components/data-table/context.js.map +1 -0
  95. package/dist/v1/components/data-table/data-table.cjs +87 -0
  96. package/dist/v1/components/data-table/data-table.cjs.map +1 -0
  97. package/dist/v1/components/data-table/data-table.d.ts +12 -0
  98. package/dist/v1/components/data-table/data-table.d.ts.map +1 -0
  99. package/dist/v1/components/data-table/data-table.js +85 -0
  100. package/dist/v1/components/data-table/data-table.js.map +1 -0
  101. package/dist/v1/components/data-table/data-table.module.css.cjs +8 -0
  102. package/dist/v1/components/data-table/data-table.module.css.cjs.map +1 -0
  103. package/dist/v1/components/data-table/data-table.module.css.js +4 -0
  104. package/dist/v1/components/data-table/data-table.module.css.js.map +1 -0
  105. package/dist/v1/components/data-table/data-table.types.cjs +9 -0
  106. package/dist/v1/components/data-table/data-table.types.cjs.map +1 -0
  107. package/dist/v1/components/data-table/data-table.types.d.ts +102 -0
  108. package/dist/v1/components/data-table/data-table.types.d.ts.map +1 -0
  109. package/dist/v1/components/data-table/data-table.types.js +7 -0
  110. package/dist/v1/components/data-table/data-table.types.js.map +1 -0
  111. package/dist/v1/components/data-table/hooks/useDataTable.cjs +15 -0
  112. package/dist/v1/components/data-table/hooks/useDataTable.cjs.map +1 -0
  113. package/dist/v1/components/data-table/hooks/useDataTable.d.ts +2 -0
  114. package/dist/v1/components/data-table/hooks/useDataTable.d.ts.map +1 -0
  115. package/dist/v1/components/data-table/hooks/useDataTable.js +13 -0
  116. package/dist/v1/components/data-table/hooks/useDataTable.js.map +1 -0
  117. package/dist/v1/components/data-table/hooks/useFilters.cjs +78 -0
  118. package/dist/v1/components/data-table/hooks/useFilters.cjs.map +1 -0
  119. package/dist/v1/components/data-table/hooks/useFilters.d.ts +9 -0
  120. package/dist/v1/components/data-table/hooks/useFilters.d.ts.map +1 -0
  121. package/dist/v1/components/data-table/hooks/useFilters.js +76 -0
  122. package/dist/v1/components/data-table/hooks/useFilters.js.map +1 -0
  123. package/dist/v1/components/data-table/index.d.ts +4 -0
  124. package/dist/v1/components/data-table/index.d.ts.map +1 -0
  125. package/dist/v1/components/data-table/utils/filter-operations.cjs +83 -0
  126. package/dist/v1/components/data-table/utils/filter-operations.cjs.map +1 -0
  127. package/dist/v1/components/data-table/utils/filter-operations.d.ts +11 -0
  128. package/dist/v1/components/data-table/utils/filter-operations.d.ts.map +1 -0
  129. package/dist/v1/components/data-table/utils/filter-operations.js +80 -0
  130. package/dist/v1/components/data-table/utils/filter-operations.js.map +1 -0
  131. package/dist/v1/components/data-table/utils/index.cjs +156 -0
  132. package/dist/v1/components/data-table/utils/index.cjs.map +1 -0
  133. package/dist/v1/components/data-table/utils/index.d.ts +14 -0
  134. package/dist/v1/components/data-table/utils/index.d.ts.map +1 -0
  135. package/dist/v1/components/data-table/utils/index.js +147 -0
  136. package/dist/v1/components/data-table/utils/index.js.map +1 -0
  137. package/dist/v1/components/dialog/dialog.cjs +4 -3
  138. package/dist/v1/components/dialog/dialog.cjs.map +1 -1
  139. package/dist/v1/components/dialog/dialog.d.ts +9 -2
  140. package/dist/v1/components/dialog/dialog.d.ts.map +1 -1
  141. package/dist/v1/components/dialog/dialog.js +5 -4
  142. package/dist/v1/components/dialog/dialog.js.map +1 -1
  143. package/dist/v1/components/dialog/dialog.module.css.cjs +1 -1
  144. package/dist/v1/components/dialog/dialog.module.css.js +1 -1
  145. package/dist/v1/components/filter-chip/filter-chip.cjs +28 -19
  146. package/dist/v1/components/filter-chip/filter-chip.cjs.map +1 -1
  147. package/dist/v1/components/filter-chip/filter-chip.d.ts +3 -7
  148. package/dist/v1/components/filter-chip/filter-chip.d.ts.map +1 -1
  149. package/dist/v1/components/filter-chip/filter-chip.js +28 -19
  150. package/dist/v1/components/filter-chip/filter-chip.js.map +1 -1
  151. package/dist/v1/components/icons/assets/filter.svg.cjs +41 -0
  152. package/dist/v1/components/icons/assets/filter.svg.cjs.map +1 -0
  153. package/dist/v1/components/icons/assets/filter.svg.js +20 -0
  154. package/dist/v1/components/icons/assets/filter.svg.js.map +1 -0
  155. package/dist/v1/components/icons/icons.d.ts +3 -0
  156. package/dist/v1/components/icons/icons.d.ts.map +1 -0
  157. package/dist/v1/components/icons/index.d.ts +2 -0
  158. package/dist/v1/components/icons/index.d.ts.map +1 -0
  159. package/dist/v1/components/input-field/input-field.cjs +1 -1
  160. package/dist/v1/components/input-field/input-field.cjs.map +1 -1
  161. package/dist/v1/components/input-field/input-field.js +1 -1
  162. package/dist/v1/components/input-field/input-field.js.map +1 -1
  163. package/dist/v1/components/sidebar/index.d.ts +2 -0
  164. package/dist/v1/components/sidebar/index.d.ts.map +1 -0
  165. package/dist/v1/components/sidebar/sidebar.cjs +46 -0
  166. package/dist/v1/components/sidebar/sidebar.cjs.map +1 -0
  167. package/dist/v1/components/sidebar/sidebar.d.ts +61 -0
  168. package/dist/v1/components/sidebar/sidebar.d.ts.map +1 -0
  169. package/dist/v1/components/sidebar/sidebar.js +44 -0
  170. package/dist/v1/components/sidebar/sidebar.js.map +1 -0
  171. package/dist/v1/components/sidebar/sidebar.module.css.cjs +8 -0
  172. package/dist/v1/components/sidebar/sidebar.module.css.cjs.map +1 -0
  173. package/dist/v1/components/sidebar/sidebar.module.css.js +4 -0
  174. package/dist/v1/components/sidebar/sidebar.module.css.js.map +1 -0
  175. package/dist/v1/components/table/table.cjs.map +1 -1
  176. package/dist/v1/components/table/table.d.ts +2 -2
  177. package/dist/v1/components/table/table.js.map +1 -1
  178. package/dist/v1/components/tooltip/tooltip.cjs +2 -2
  179. package/dist/v1/components/tooltip/tooltip.cjs.map +1 -1
  180. package/dist/v1/components/tooltip/tooltip.d.ts +1 -1
  181. package/dist/v1/components/tooltip/tooltip.d.ts.map +1 -1
  182. package/dist/v1/components/tooltip/tooltip.js +2 -2
  183. package/dist/v1/components/tooltip/tooltip.js.map +1 -1
  184. package/dist/v1/index.cjs +6 -2
  185. package/dist/v1/index.cjs.map +1 -1
  186. package/dist/v1/index.d.ts +2 -1
  187. package/dist/v1/index.d.ts.map +1 -1
  188. package/dist/v1/index.js +4 -1
  189. package/dist/v1/index.js.map +1 -1
  190. package/dist/v1/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.cjs +92 -0
  191. package/dist/v1/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.cjs.map +1 -1
  192. package/dist/v1/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.js +89 -1
  193. package/dist/v1/node_modules/.pnpm/@radix-ui_react-icons@1.3.0_react@18.2.0/node_modules/@radix-ui/react-icons/dist/react-icons.esm.js.map +1 -1
  194. package/dist/v1/node_modules/.pnpm/@tanstack_react-table@8.9.2_react-dom@18.3.1_react@18.2.0__react@18.2.0/node_modules/@tanstack/react-table/build/lib/index.cjs +131 -0
  195. package/dist/v1/node_modules/.pnpm/@tanstack_react-table@8.9.2_react-dom@18.3.1_react@18.2.0__react@18.2.0/node_modules/@tanstack/react-table/build/lib/index.cjs.map +1 -0
  196. package/dist/v1/node_modules/.pnpm/@tanstack_react-table@8.9.2_react-dom@18.3.1_react@18.2.0__react@18.2.0/node_modules/@tanstack/react-table/build/lib/index.js +72 -0
  197. package/dist/v1/node_modules/.pnpm/@tanstack_react-table@8.9.2_react-dom@18.3.1_react@18.2.0__react@18.2.0/node_modules/@tanstack/react-table/build/lib/index.js.map +1 -0
  198. package/dist/v1/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.cjs +3338 -0
  199. package/dist/v1/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.cjs.map +1 -0
  200. package/dist/v1/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.js +3299 -0
  201. package/dist/v1/node_modules/.pnpm/@tanstack_table-core@8.9.2/node_modules/@tanstack/table-core/build/lib/index.js.map +1 -0
  202. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrAfter.cjs +16 -0
  203. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrAfter.cjs.map +1 -0
  204. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrAfter.js +12 -0
  205. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrAfter.js.map +1 -0
  206. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrBefore.cjs +16 -0
  207. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrBefore.cjs.map +1 -0
  208. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrBefore.js +12 -0
  209. package/dist/v1/node_modules/.pnpm/dayjs@1.11.11/node_modules/dayjs/plugin/isSameOrBefore.js.map +1 -0
  210. package/dist/v1/style.css +1 -1
  211. package/dist/v1/types/filters.cjs +39 -0
  212. package/dist/v1/types/filters.cjs.map +1 -0
  213. package/dist/v1/types/filters.d.ts +42 -0
  214. package/dist/v1/types/filters.d.ts.map +1 -0
  215. package/dist/v1/types/filters.js +36 -0
  216. package/dist/v1/types/filters.js.map +1 -0
  217. package/package.json +2 -1
  218. package/dist/v1/components/sidepanel/index.d.ts +0 -2
  219. package/dist/v1/components/sidepanel/index.d.ts.map +0 -1
  220. package/dist/v1/components/sidepanel/sidepanel.cjs +0 -44
  221. package/dist/v1/components/sidepanel/sidepanel.cjs.map +0 -1
  222. package/dist/v1/components/sidepanel/sidepanel.d.ts +0 -51
  223. package/dist/v1/components/sidepanel/sidepanel.d.ts.map +0 -1
  224. package/dist/v1/components/sidepanel/sidepanel.js +0 -42
  225. package/dist/v1/components/sidepanel/sidepanel.js.map +0 -1
  226. package/dist/v1/components/sidepanel/sidepanel.module.css.cjs +0 -8
  227. package/dist/v1/components/sidepanel/sidepanel.module.css.cjs.map +0 -1
  228. package/dist/v1/components/sidepanel/sidepanel.module.css.js +0 -4
  229. package/dist/v1/components/sidepanel/sidepanel.module.css.js.map +0 -1
@@ -0,0 +1,3338 @@
1
+ 'use strict';
2
+
3
+ /**
4
+ * table-core
5
+ *
6
+ * Copyright (c) TanStack
7
+ *
8
+ * This source code is licensed under the MIT license found in the
9
+ * LICENSE.md file in the root directory of this source tree.
10
+ *
11
+ * @license MIT
12
+ */
13
+ // Is this type a tuple?
14
+
15
+ // If this type is a tuple, what indices are allowed?
16
+
17
+ ///
18
+
19
+ function functionalUpdate(updater, input) {
20
+ return typeof updater === 'function' ? updater(input) : updater;
21
+ }
22
+ function makeStateUpdater(key, instance) {
23
+ return updater => {
24
+ instance.setState(old => {
25
+ return {
26
+ ...old,
27
+ [key]: functionalUpdate(updater, old[key])
28
+ };
29
+ });
30
+ };
31
+ }
32
+ function isFunction(d) {
33
+ return d instanceof Function;
34
+ }
35
+ function isNumberArray(d) {
36
+ return Array.isArray(d) && d.every(val => typeof val === 'number');
37
+ }
38
+ function flattenBy(arr, getChildren) {
39
+ const flat = [];
40
+ const recurse = subArr => {
41
+ subArr.forEach(item => {
42
+ flat.push(item);
43
+ const children = getChildren(item);
44
+ if (children != null && children.length) {
45
+ recurse(children);
46
+ }
47
+ });
48
+ };
49
+ recurse(arr);
50
+ return flat;
51
+ }
52
+ function memo(getDeps, fn, opts) {
53
+ let deps = [];
54
+ let result;
55
+ return () => {
56
+ let depTime;
57
+ if (opts.key && opts.debug) depTime = Date.now();
58
+ const newDeps = getDeps();
59
+ const depsChanged = newDeps.length !== deps.length || newDeps.some((dep, index) => deps[index] !== dep);
60
+ if (!depsChanged) {
61
+ return result;
62
+ }
63
+ deps = newDeps;
64
+ let resultTime;
65
+ if (opts.key && opts.debug) resultTime = Date.now();
66
+ result = fn(...newDeps);
67
+ opts == null ? void 0 : opts.onChange == null ? void 0 : opts.onChange(result);
68
+ if (opts.key && opts.debug) {
69
+ if (opts != null && opts.debug()) {
70
+ const depEndTime = Math.round((Date.now() - depTime) * 100) / 100;
71
+ const resultEndTime = Math.round((Date.now() - resultTime) * 100) / 100;
72
+ const resultFpsPercentage = resultEndTime / 16;
73
+ const pad = (str, num) => {
74
+ str = String(str);
75
+ while (str.length < num) {
76
+ str = ' ' + str;
77
+ }
78
+ return str;
79
+ };
80
+ console.info(`%c⏱ ${pad(resultEndTime, 5)} /${pad(depEndTime, 5)} ms`, `
81
+ font-size: .6rem;
82
+ font-weight: bold;
83
+ color: hsl(${Math.max(0, Math.min(120 - 120 * resultFpsPercentage, 120))}deg 100% 31%);`, opts == null ? void 0 : opts.key);
84
+ }
85
+ }
86
+ return result;
87
+ };
88
+ }
89
+
90
+ function createColumn(table, columnDef, depth, parent) {
91
+ var _ref, _resolvedColumnDef$id;
92
+ const defaultColumn = table._getDefaultColumnDef();
93
+ const resolvedColumnDef = {
94
+ ...defaultColumn,
95
+ ...columnDef
96
+ };
97
+ const accessorKey = resolvedColumnDef.accessorKey;
98
+ let id = (_ref = (_resolvedColumnDef$id = resolvedColumnDef.id) != null ? _resolvedColumnDef$id : accessorKey ? accessorKey.replace('.', '_') : undefined) != null ? _ref : typeof resolvedColumnDef.header === 'string' ? resolvedColumnDef.header : undefined;
99
+ let accessorFn;
100
+ if (resolvedColumnDef.accessorFn) {
101
+ accessorFn = resolvedColumnDef.accessorFn;
102
+ } else if (accessorKey) {
103
+ // Support deep accessor keys
104
+ if (accessorKey.includes('.')) {
105
+ accessorFn = originalRow => {
106
+ let result = originalRow;
107
+ for (const key of accessorKey.split('.')) {
108
+ var _result;
109
+ result = (_result = result) == null ? void 0 : _result[key];
110
+ if (process.env.NODE_ENV !== 'production' && result === undefined) {
111
+ console.warn(`"${key}" in deeply nested key "${accessorKey}" returned undefined.`);
112
+ }
113
+ }
114
+ return result;
115
+ };
116
+ } else {
117
+ accessorFn = originalRow => originalRow[resolvedColumnDef.accessorKey];
118
+ }
119
+ }
120
+ if (!id) {
121
+ if (process.env.NODE_ENV !== 'production') {
122
+ throw new Error(resolvedColumnDef.accessorFn ? `Columns require an id when using an accessorFn` : `Columns require an id when using a non-string header`);
123
+ }
124
+ throw new Error();
125
+ }
126
+ let column = {
127
+ id: `${String(id)}`,
128
+ accessorFn,
129
+ parent: parent,
130
+ depth,
131
+ columnDef: resolvedColumnDef,
132
+ columns: [],
133
+ getFlatColumns: memo(() => [true], () => {
134
+ var _column$columns;
135
+ return [column, ...((_column$columns = column.columns) == null ? void 0 : _column$columns.flatMap(d => d.getFlatColumns()))];
136
+ }, {
137
+ key: process.env.NODE_ENV === 'production' && 'column.getFlatColumns',
138
+ debug: () => {
139
+ var _table$options$debugA;
140
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugColumns;
141
+ }
142
+ }),
143
+ getLeafColumns: memo(() => [table._getOrderColumnsFn()], orderColumns => {
144
+ var _column$columns2;
145
+ if ((_column$columns2 = column.columns) != null && _column$columns2.length) {
146
+ let leafColumns = column.columns.flatMap(column => column.getLeafColumns());
147
+ return orderColumns(leafColumns);
148
+ }
149
+ return [column];
150
+ }, {
151
+ key: process.env.NODE_ENV === 'production' && 'column.getLeafColumns',
152
+ debug: () => {
153
+ var _table$options$debugA2;
154
+ return (_table$options$debugA2 = table.options.debugAll) != null ? _table$options$debugA2 : table.options.debugColumns;
155
+ }
156
+ })
157
+ };
158
+ column = table._features.reduce((obj, feature) => {
159
+ return Object.assign(obj, feature.createColumn == null ? void 0 : feature.createColumn(column, table));
160
+ }, column);
161
+
162
+ // Yes, we have to convert table to uknown, because we know more than the compiler here.
163
+ return column;
164
+ }
165
+
166
+ //
167
+
168
+ function createHeader(table, column, options) {
169
+ var _options$id;
170
+ const id = (_options$id = options.id) != null ? _options$id : column.id;
171
+ let header = {
172
+ id,
173
+ column,
174
+ index: options.index,
175
+ isPlaceholder: !!options.isPlaceholder,
176
+ placeholderId: options.placeholderId,
177
+ depth: options.depth,
178
+ subHeaders: [],
179
+ colSpan: 0,
180
+ rowSpan: 0,
181
+ headerGroup: null,
182
+ getLeafHeaders: () => {
183
+ const leafHeaders = [];
184
+ const recurseHeader = h => {
185
+ if (h.subHeaders && h.subHeaders.length) {
186
+ h.subHeaders.map(recurseHeader);
187
+ }
188
+ leafHeaders.push(h);
189
+ };
190
+ recurseHeader(header);
191
+ return leafHeaders;
192
+ },
193
+ getContext: () => ({
194
+ table,
195
+ header: header,
196
+ column
197
+ })
198
+ };
199
+ table._features.forEach(feature => {
200
+ Object.assign(header, feature.createHeader == null ? void 0 : feature.createHeader(header, table));
201
+ });
202
+ return header;
203
+ }
204
+ const Headers = {
205
+ createTable: table => {
206
+ return {
207
+ // Header Groups
208
+
209
+ getHeaderGroups: memo(() => [table.getAllColumns(), table.getVisibleLeafColumns(), table.getState().columnPinning.left, table.getState().columnPinning.right], (allColumns, leafColumns, left, right) => {
210
+ var _left$map$filter, _right$map$filter;
211
+ const leftColumns = (_left$map$filter = left == null ? void 0 : left.map(columnId => leafColumns.find(d => d.id === columnId)).filter(Boolean)) != null ? _left$map$filter : [];
212
+ const rightColumns = (_right$map$filter = right == null ? void 0 : right.map(columnId => leafColumns.find(d => d.id === columnId)).filter(Boolean)) != null ? _right$map$filter : [];
213
+ const centerColumns = leafColumns.filter(column => !(left != null && left.includes(column.id)) && !(right != null && right.includes(column.id)));
214
+ const headerGroups = buildHeaderGroups(allColumns, [...leftColumns, ...centerColumns, ...rightColumns], table);
215
+ return headerGroups;
216
+ }, {
217
+ key: process.env.NODE_ENV === 'development' && 'getHeaderGroups',
218
+ debug: () => {
219
+ var _table$options$debugA;
220
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugHeaders;
221
+ }
222
+ }),
223
+ getCenterHeaderGroups: memo(() => [table.getAllColumns(), table.getVisibleLeafColumns(), table.getState().columnPinning.left, table.getState().columnPinning.right], (allColumns, leafColumns, left, right) => {
224
+ leafColumns = leafColumns.filter(column => !(left != null && left.includes(column.id)) && !(right != null && right.includes(column.id)));
225
+ return buildHeaderGroups(allColumns, leafColumns, table, 'center');
226
+ }, {
227
+ key: process.env.NODE_ENV === 'development' && 'getCenterHeaderGroups',
228
+ debug: () => {
229
+ var _table$options$debugA2;
230
+ return (_table$options$debugA2 = table.options.debugAll) != null ? _table$options$debugA2 : table.options.debugHeaders;
231
+ }
232
+ }),
233
+ getLeftHeaderGroups: memo(() => [table.getAllColumns(), table.getVisibleLeafColumns(), table.getState().columnPinning.left], (allColumns, leafColumns, left) => {
234
+ var _left$map$filter2;
235
+ const orderedLeafColumns = (_left$map$filter2 = left == null ? void 0 : left.map(columnId => leafColumns.find(d => d.id === columnId)).filter(Boolean)) != null ? _left$map$filter2 : [];
236
+ return buildHeaderGroups(allColumns, orderedLeafColumns, table, 'left');
237
+ }, {
238
+ key: process.env.NODE_ENV === 'development' && 'getLeftHeaderGroups',
239
+ debug: () => {
240
+ var _table$options$debugA3;
241
+ return (_table$options$debugA3 = table.options.debugAll) != null ? _table$options$debugA3 : table.options.debugHeaders;
242
+ }
243
+ }),
244
+ getRightHeaderGroups: memo(() => [table.getAllColumns(), table.getVisibleLeafColumns(), table.getState().columnPinning.right], (allColumns, leafColumns, right) => {
245
+ var _right$map$filter2;
246
+ const orderedLeafColumns = (_right$map$filter2 = right == null ? void 0 : right.map(columnId => leafColumns.find(d => d.id === columnId)).filter(Boolean)) != null ? _right$map$filter2 : [];
247
+ return buildHeaderGroups(allColumns, orderedLeafColumns, table, 'right');
248
+ }, {
249
+ key: process.env.NODE_ENV === 'development' && 'getRightHeaderGroups',
250
+ debug: () => {
251
+ var _table$options$debugA4;
252
+ return (_table$options$debugA4 = table.options.debugAll) != null ? _table$options$debugA4 : table.options.debugHeaders;
253
+ }
254
+ }),
255
+ // Footer Groups
256
+
257
+ getFooterGroups: memo(() => [table.getHeaderGroups()], headerGroups => {
258
+ return [...headerGroups].reverse();
259
+ }, {
260
+ key: process.env.NODE_ENV === 'development' && 'getFooterGroups',
261
+ debug: () => {
262
+ var _table$options$debugA5;
263
+ return (_table$options$debugA5 = table.options.debugAll) != null ? _table$options$debugA5 : table.options.debugHeaders;
264
+ }
265
+ }),
266
+ getLeftFooterGroups: memo(() => [table.getLeftHeaderGroups()], headerGroups => {
267
+ return [...headerGroups].reverse();
268
+ }, {
269
+ key: process.env.NODE_ENV === 'development' && 'getLeftFooterGroups',
270
+ debug: () => {
271
+ var _table$options$debugA6;
272
+ return (_table$options$debugA6 = table.options.debugAll) != null ? _table$options$debugA6 : table.options.debugHeaders;
273
+ }
274
+ }),
275
+ getCenterFooterGroups: memo(() => [table.getCenterHeaderGroups()], headerGroups => {
276
+ return [...headerGroups].reverse();
277
+ }, {
278
+ key: process.env.NODE_ENV === 'development' && 'getCenterFooterGroups',
279
+ debug: () => {
280
+ var _table$options$debugA7;
281
+ return (_table$options$debugA7 = table.options.debugAll) != null ? _table$options$debugA7 : table.options.debugHeaders;
282
+ }
283
+ }),
284
+ getRightFooterGroups: memo(() => [table.getRightHeaderGroups()], headerGroups => {
285
+ return [...headerGroups].reverse();
286
+ }, {
287
+ key: process.env.NODE_ENV === 'development' && 'getRightFooterGroups',
288
+ debug: () => {
289
+ var _table$options$debugA8;
290
+ return (_table$options$debugA8 = table.options.debugAll) != null ? _table$options$debugA8 : table.options.debugHeaders;
291
+ }
292
+ }),
293
+ // Flat Headers
294
+
295
+ getFlatHeaders: memo(() => [table.getHeaderGroups()], headerGroups => {
296
+ return headerGroups.map(headerGroup => {
297
+ return headerGroup.headers;
298
+ }).flat();
299
+ }, {
300
+ key: process.env.NODE_ENV === 'development' && 'getFlatHeaders',
301
+ debug: () => {
302
+ var _table$options$debugA9;
303
+ return (_table$options$debugA9 = table.options.debugAll) != null ? _table$options$debugA9 : table.options.debugHeaders;
304
+ }
305
+ }),
306
+ getLeftFlatHeaders: memo(() => [table.getLeftHeaderGroups()], left => {
307
+ return left.map(headerGroup => {
308
+ return headerGroup.headers;
309
+ }).flat();
310
+ }, {
311
+ key: process.env.NODE_ENV === 'development' && 'getLeftFlatHeaders',
312
+ debug: () => {
313
+ var _table$options$debugA10;
314
+ return (_table$options$debugA10 = table.options.debugAll) != null ? _table$options$debugA10 : table.options.debugHeaders;
315
+ }
316
+ }),
317
+ getCenterFlatHeaders: memo(() => [table.getCenterHeaderGroups()], left => {
318
+ return left.map(headerGroup => {
319
+ return headerGroup.headers;
320
+ }).flat();
321
+ }, {
322
+ key: process.env.NODE_ENV === 'development' && 'getCenterFlatHeaders',
323
+ debug: () => {
324
+ var _table$options$debugA11;
325
+ return (_table$options$debugA11 = table.options.debugAll) != null ? _table$options$debugA11 : table.options.debugHeaders;
326
+ }
327
+ }),
328
+ getRightFlatHeaders: memo(() => [table.getRightHeaderGroups()], left => {
329
+ return left.map(headerGroup => {
330
+ return headerGroup.headers;
331
+ }).flat();
332
+ }, {
333
+ key: process.env.NODE_ENV === 'development' && 'getRightFlatHeaders',
334
+ debug: () => {
335
+ var _table$options$debugA12;
336
+ return (_table$options$debugA12 = table.options.debugAll) != null ? _table$options$debugA12 : table.options.debugHeaders;
337
+ }
338
+ }),
339
+ // Leaf Headers
340
+
341
+ getCenterLeafHeaders: memo(() => [table.getCenterFlatHeaders()], flatHeaders => {
342
+ return flatHeaders.filter(header => {
343
+ var _header$subHeaders;
344
+ return !((_header$subHeaders = header.subHeaders) != null && _header$subHeaders.length);
345
+ });
346
+ }, {
347
+ key: process.env.NODE_ENV === 'development' && 'getCenterLeafHeaders',
348
+ debug: () => {
349
+ var _table$options$debugA13;
350
+ return (_table$options$debugA13 = table.options.debugAll) != null ? _table$options$debugA13 : table.options.debugHeaders;
351
+ }
352
+ }),
353
+ getLeftLeafHeaders: memo(() => [table.getLeftFlatHeaders()], flatHeaders => {
354
+ return flatHeaders.filter(header => {
355
+ var _header$subHeaders2;
356
+ return !((_header$subHeaders2 = header.subHeaders) != null && _header$subHeaders2.length);
357
+ });
358
+ }, {
359
+ key: process.env.NODE_ENV === 'development' && 'getLeftLeafHeaders',
360
+ debug: () => {
361
+ var _table$options$debugA14;
362
+ return (_table$options$debugA14 = table.options.debugAll) != null ? _table$options$debugA14 : table.options.debugHeaders;
363
+ }
364
+ }),
365
+ getRightLeafHeaders: memo(() => [table.getRightFlatHeaders()], flatHeaders => {
366
+ return flatHeaders.filter(header => {
367
+ var _header$subHeaders3;
368
+ return !((_header$subHeaders3 = header.subHeaders) != null && _header$subHeaders3.length);
369
+ });
370
+ }, {
371
+ key: process.env.NODE_ENV === 'development' && 'getRightLeafHeaders',
372
+ debug: () => {
373
+ var _table$options$debugA15;
374
+ return (_table$options$debugA15 = table.options.debugAll) != null ? _table$options$debugA15 : table.options.debugHeaders;
375
+ }
376
+ }),
377
+ getLeafHeaders: memo(() => [table.getLeftHeaderGroups(), table.getCenterHeaderGroups(), table.getRightHeaderGroups()], (left, center, right) => {
378
+ var _left$0$headers, _left$, _center$0$headers, _center$, _right$0$headers, _right$;
379
+ return [...((_left$0$headers = (_left$ = left[0]) == null ? void 0 : _left$.headers) != null ? _left$0$headers : []), ...((_center$0$headers = (_center$ = center[0]) == null ? void 0 : _center$.headers) != null ? _center$0$headers : []), ...((_right$0$headers = (_right$ = right[0]) == null ? void 0 : _right$.headers) != null ? _right$0$headers : [])].map(header => {
380
+ return header.getLeafHeaders();
381
+ }).flat();
382
+ }, {
383
+ key: process.env.NODE_ENV === 'development' && 'getLeafHeaders',
384
+ debug: () => {
385
+ var _table$options$debugA16;
386
+ return (_table$options$debugA16 = table.options.debugAll) != null ? _table$options$debugA16 : table.options.debugHeaders;
387
+ }
388
+ })
389
+ };
390
+ }
391
+ };
392
+ function buildHeaderGroups(allColumns, columnsToGroup, table, headerFamily) {
393
+ var _headerGroups$0$heade, _headerGroups$;
394
+ // Find the max depth of the columns:
395
+ // build the leaf column row
396
+ // build each buffer row going up
397
+ // placeholder for non-existent level
398
+ // real column for existing level
399
+
400
+ let maxDepth = 0;
401
+ const findMaxDepth = function (columns, depth) {
402
+ if (depth === void 0) {
403
+ depth = 1;
404
+ }
405
+ maxDepth = Math.max(maxDepth, depth);
406
+ columns.filter(column => column.getIsVisible()).forEach(column => {
407
+ var _column$columns;
408
+ if ((_column$columns = column.columns) != null && _column$columns.length) {
409
+ findMaxDepth(column.columns, depth + 1);
410
+ }
411
+ }, 0);
412
+ };
413
+ findMaxDepth(allColumns);
414
+ let headerGroups = [];
415
+ const createHeaderGroup = (headersToGroup, depth) => {
416
+ // The header group we are creating
417
+ const headerGroup = {
418
+ depth,
419
+ id: [headerFamily, `${depth}`].filter(Boolean).join('_'),
420
+ headers: []
421
+ };
422
+
423
+ // The parent columns we're going to scan next
424
+ const pendingParentHeaders = [];
425
+
426
+ // Scan each column for parents
427
+ headersToGroup.forEach(headerToGroup => {
428
+ // What is the latest (last) parent column?
429
+
430
+ const latestPendingParentHeader = [...pendingParentHeaders].reverse()[0];
431
+ const isLeafHeader = headerToGroup.column.depth === headerGroup.depth;
432
+ let column;
433
+ let isPlaceholder = false;
434
+ if (isLeafHeader && headerToGroup.column.parent) {
435
+ // The parent header is new
436
+ column = headerToGroup.column.parent;
437
+ } else {
438
+ // The parent header is repeated
439
+ column = headerToGroup.column;
440
+ isPlaceholder = true;
441
+ }
442
+ if (latestPendingParentHeader && (latestPendingParentHeader == null ? void 0 : latestPendingParentHeader.column) === column) {
443
+ // This column is repeated. Add it as a sub header to the next batch
444
+ latestPendingParentHeader.subHeaders.push(headerToGroup);
445
+ } else {
446
+ // This is a new header. Let's create it
447
+ const header = createHeader(table, column, {
448
+ id: [headerFamily, depth, column.id, headerToGroup == null ? void 0 : headerToGroup.id].filter(Boolean).join('_'),
449
+ isPlaceholder,
450
+ placeholderId: isPlaceholder ? `${pendingParentHeaders.filter(d => d.column === column).length}` : undefined,
451
+ depth,
452
+ index: pendingParentHeaders.length
453
+ });
454
+
455
+ // Add the headerToGroup as a subHeader of the new header
456
+ header.subHeaders.push(headerToGroup);
457
+ // Add the new header to the pendingParentHeaders to get grouped
458
+ // in the next batch
459
+ pendingParentHeaders.push(header);
460
+ }
461
+ headerGroup.headers.push(headerToGroup);
462
+ headerToGroup.headerGroup = headerGroup;
463
+ });
464
+ headerGroups.push(headerGroup);
465
+ if (depth > 0) {
466
+ createHeaderGroup(pendingParentHeaders, depth - 1);
467
+ }
468
+ };
469
+ const bottomHeaders = columnsToGroup.map((column, index) => createHeader(table, column, {
470
+ depth: maxDepth,
471
+ index
472
+ }));
473
+ createHeaderGroup(bottomHeaders, maxDepth - 1);
474
+ headerGroups.reverse();
475
+
476
+ // headerGroups = headerGroups.filter(headerGroup => {
477
+ // return !headerGroup.headers.every(header => header.isPlaceholder)
478
+ // })
479
+
480
+ const recurseHeadersForSpans = headers => {
481
+ const filteredHeaders = headers.filter(header => header.column.getIsVisible());
482
+ return filteredHeaders.map(header => {
483
+ let colSpan = 0;
484
+ let rowSpan = 0;
485
+ let childRowSpans = [0];
486
+ if (header.subHeaders && header.subHeaders.length) {
487
+ childRowSpans = [];
488
+ recurseHeadersForSpans(header.subHeaders).forEach(_ref => {
489
+ let {
490
+ colSpan: childColSpan,
491
+ rowSpan: childRowSpan
492
+ } = _ref;
493
+ colSpan += childColSpan;
494
+ childRowSpans.push(childRowSpan);
495
+ });
496
+ } else {
497
+ colSpan = 1;
498
+ }
499
+ const minChildRowSpan = Math.min(...childRowSpans);
500
+ rowSpan = rowSpan + minChildRowSpan;
501
+ header.colSpan = colSpan;
502
+ header.rowSpan = rowSpan;
503
+ return {
504
+ colSpan,
505
+ rowSpan
506
+ };
507
+ });
508
+ };
509
+ recurseHeadersForSpans((_headerGroups$0$heade = (_headerGroups$ = headerGroups[0]) == null ? void 0 : _headerGroups$.headers) != null ? _headerGroups$0$heade : []);
510
+ return headerGroups;
511
+ }
512
+
513
+ //
514
+
515
+ //
516
+
517
+ const defaultColumnSizing = {
518
+ size: 150,
519
+ minSize: 20,
520
+ maxSize: Number.MAX_SAFE_INTEGER
521
+ };
522
+ const getDefaultColumnSizingInfoState = () => ({
523
+ startOffset: null,
524
+ startSize: null,
525
+ deltaOffset: null,
526
+ deltaPercentage: null,
527
+ isResizingColumn: false,
528
+ columnSizingStart: []
529
+ });
530
+ const ColumnSizing = {
531
+ getDefaultColumnDef: () => {
532
+ return defaultColumnSizing;
533
+ },
534
+ getInitialState: state => {
535
+ return {
536
+ columnSizing: {},
537
+ columnSizingInfo: getDefaultColumnSizingInfoState(),
538
+ ...state
539
+ };
540
+ },
541
+ getDefaultOptions: table => {
542
+ return {
543
+ columnResizeMode: 'onEnd',
544
+ onColumnSizingChange: makeStateUpdater('columnSizing', table),
545
+ onColumnSizingInfoChange: makeStateUpdater('columnSizingInfo', table)
546
+ };
547
+ },
548
+ createColumn: (column, table) => {
549
+ return {
550
+ getSize: () => {
551
+ var _column$columnDef$min, _ref, _column$columnDef$max;
552
+ const columnSize = table.getState().columnSizing[column.id];
553
+ return Math.min(Math.max((_column$columnDef$min = column.columnDef.minSize) != null ? _column$columnDef$min : defaultColumnSizing.minSize, (_ref = columnSize != null ? columnSize : column.columnDef.size) != null ? _ref : defaultColumnSizing.size), (_column$columnDef$max = column.columnDef.maxSize) != null ? _column$columnDef$max : defaultColumnSizing.maxSize);
554
+ },
555
+ getStart: position => {
556
+ const columns = !position ? table.getVisibleLeafColumns() : position === 'left' ? table.getLeftVisibleLeafColumns() : table.getRightVisibleLeafColumns();
557
+ const index = columns.findIndex(d => d.id === column.id);
558
+ if (index > 0) {
559
+ const prevSiblingColumn = columns[index - 1];
560
+ return prevSiblingColumn.getStart(position) + prevSiblingColumn.getSize();
561
+ }
562
+ return 0;
563
+ },
564
+ resetSize: () => {
565
+ table.setColumnSizing(_ref2 => {
566
+ let {
567
+ [column.id]: _,
568
+ ...rest
569
+ } = _ref2;
570
+ return rest;
571
+ });
572
+ },
573
+ getCanResize: () => {
574
+ var _column$columnDef$ena, _table$options$enable;
575
+ return ((_column$columnDef$ena = column.columnDef.enableResizing) != null ? _column$columnDef$ena : true) && ((_table$options$enable = table.options.enableColumnResizing) != null ? _table$options$enable : true);
576
+ },
577
+ getIsResizing: () => {
578
+ return table.getState().columnSizingInfo.isResizingColumn === column.id;
579
+ }
580
+ };
581
+ },
582
+ createHeader: (header, table) => {
583
+ return {
584
+ getSize: () => {
585
+ let sum = 0;
586
+ const recurse = header => {
587
+ if (header.subHeaders.length) {
588
+ header.subHeaders.forEach(recurse);
589
+ } else {
590
+ var _header$column$getSiz;
591
+ sum += (_header$column$getSiz = header.column.getSize()) != null ? _header$column$getSiz : 0;
592
+ }
593
+ };
594
+ recurse(header);
595
+ return sum;
596
+ },
597
+ getStart: () => {
598
+ if (header.index > 0) {
599
+ const prevSiblingHeader = header.headerGroup.headers[header.index - 1];
600
+ return prevSiblingHeader.getStart() + prevSiblingHeader.getSize();
601
+ }
602
+ return 0;
603
+ },
604
+ getResizeHandler: () => {
605
+ const column = table.getColumn(header.column.id);
606
+ const canResize = column == null ? void 0 : column.getCanResize();
607
+ return e => {
608
+ if (!column || !canResize) {
609
+ return;
610
+ }
611
+ e.persist == null ? void 0 : e.persist();
612
+ if (isTouchStartEvent(e)) {
613
+ // lets not respond to multiple touches (e.g. 2 or 3 fingers)
614
+ if (e.touches && e.touches.length > 1) {
615
+ return;
616
+ }
617
+ }
618
+ const startSize = header.getSize();
619
+ const columnSizingStart = header ? header.getLeafHeaders().map(d => [d.column.id, d.column.getSize()]) : [[column.id, column.getSize()]];
620
+ const clientX = isTouchStartEvent(e) ? Math.round(e.touches[0].clientX) : e.clientX;
621
+ const newColumnSizing = {};
622
+ const updateOffset = (eventType, clientXPos) => {
623
+ if (typeof clientXPos !== 'number') {
624
+ return;
625
+ }
626
+ table.setColumnSizingInfo(old => {
627
+ var _old$startOffset, _old$startSize;
628
+ const deltaOffset = clientXPos - ((_old$startOffset = old == null ? void 0 : old.startOffset) != null ? _old$startOffset : 0);
629
+ const deltaPercentage = Math.max(deltaOffset / ((_old$startSize = old == null ? void 0 : old.startSize) != null ? _old$startSize : 0), -0.999999);
630
+ old.columnSizingStart.forEach(_ref3 => {
631
+ let [columnId, headerSize] = _ref3;
632
+ newColumnSizing[columnId] = Math.round(Math.max(headerSize + headerSize * deltaPercentage, 0) * 100) / 100;
633
+ });
634
+ return {
635
+ ...old,
636
+ deltaOffset,
637
+ deltaPercentage
638
+ };
639
+ });
640
+ if (table.options.columnResizeMode === 'onChange' || eventType === 'end') {
641
+ table.setColumnSizing(old => ({
642
+ ...old,
643
+ ...newColumnSizing
644
+ }));
645
+ }
646
+ };
647
+ const onMove = clientXPos => updateOffset('move', clientXPos);
648
+ const onEnd = clientXPos => {
649
+ updateOffset('end', clientXPos);
650
+ table.setColumnSizingInfo(old => ({
651
+ ...old,
652
+ isResizingColumn: false,
653
+ startOffset: null,
654
+ startSize: null,
655
+ deltaOffset: null,
656
+ deltaPercentage: null,
657
+ columnSizingStart: []
658
+ }));
659
+ };
660
+ const mouseEvents = {
661
+ moveHandler: e => onMove(e.clientX),
662
+ upHandler: e => {
663
+ document.removeEventListener('mousemove', mouseEvents.moveHandler);
664
+ document.removeEventListener('mouseup', mouseEvents.upHandler);
665
+ onEnd(e.clientX);
666
+ }
667
+ };
668
+ const touchEvents = {
669
+ moveHandler: e => {
670
+ if (e.cancelable) {
671
+ e.preventDefault();
672
+ e.stopPropagation();
673
+ }
674
+ onMove(e.touches[0].clientX);
675
+ return false;
676
+ },
677
+ upHandler: e => {
678
+ var _e$touches$;
679
+ document.removeEventListener('touchmove', touchEvents.moveHandler);
680
+ document.removeEventListener('touchend', touchEvents.upHandler);
681
+ if (e.cancelable) {
682
+ e.preventDefault();
683
+ e.stopPropagation();
684
+ }
685
+ onEnd((_e$touches$ = e.touches[0]) == null ? void 0 : _e$touches$.clientX);
686
+ }
687
+ };
688
+ const passiveIfSupported = passiveEventSupported() ? {
689
+ passive: false
690
+ } : false;
691
+ if (isTouchStartEvent(e)) {
692
+ document.addEventListener('touchmove', touchEvents.moveHandler, passiveIfSupported);
693
+ document.addEventListener('touchend', touchEvents.upHandler, passiveIfSupported);
694
+ } else {
695
+ document.addEventListener('mousemove', mouseEvents.moveHandler, passiveIfSupported);
696
+ document.addEventListener('mouseup', mouseEvents.upHandler, passiveIfSupported);
697
+ }
698
+ table.setColumnSizingInfo(old => ({
699
+ ...old,
700
+ startOffset: clientX,
701
+ startSize,
702
+ deltaOffset: 0,
703
+ deltaPercentage: 0,
704
+ columnSizingStart,
705
+ isResizingColumn: column.id
706
+ }));
707
+ };
708
+ }
709
+ };
710
+ },
711
+ createTable: table => {
712
+ return {
713
+ setColumnSizing: updater => table.options.onColumnSizingChange == null ? void 0 : table.options.onColumnSizingChange(updater),
714
+ setColumnSizingInfo: updater => table.options.onColumnSizingInfoChange == null ? void 0 : table.options.onColumnSizingInfoChange(updater),
715
+ resetColumnSizing: defaultState => {
716
+ var _table$initialState$c;
717
+ table.setColumnSizing(defaultState ? {} : (_table$initialState$c = table.initialState.columnSizing) != null ? _table$initialState$c : {});
718
+ },
719
+ resetHeaderSizeInfo: defaultState => {
720
+ var _table$initialState$c2;
721
+ table.setColumnSizingInfo(defaultState ? getDefaultColumnSizingInfoState() : (_table$initialState$c2 = table.initialState.columnSizingInfo) != null ? _table$initialState$c2 : getDefaultColumnSizingInfoState());
722
+ },
723
+ getTotalSize: () => {
724
+ var _table$getHeaderGroup, _table$getHeaderGroup2;
725
+ return (_table$getHeaderGroup = (_table$getHeaderGroup2 = table.getHeaderGroups()[0]) == null ? void 0 : _table$getHeaderGroup2.headers.reduce((sum, header) => {
726
+ return sum + header.getSize();
727
+ }, 0)) != null ? _table$getHeaderGroup : 0;
728
+ },
729
+ getLeftTotalSize: () => {
730
+ var _table$getLeftHeaderG, _table$getLeftHeaderG2;
731
+ return (_table$getLeftHeaderG = (_table$getLeftHeaderG2 = table.getLeftHeaderGroups()[0]) == null ? void 0 : _table$getLeftHeaderG2.headers.reduce((sum, header) => {
732
+ return sum + header.getSize();
733
+ }, 0)) != null ? _table$getLeftHeaderG : 0;
734
+ },
735
+ getCenterTotalSize: () => {
736
+ var _table$getCenterHeade, _table$getCenterHeade2;
737
+ return (_table$getCenterHeade = (_table$getCenterHeade2 = table.getCenterHeaderGroups()[0]) == null ? void 0 : _table$getCenterHeade2.headers.reduce((sum, header) => {
738
+ return sum + header.getSize();
739
+ }, 0)) != null ? _table$getCenterHeade : 0;
740
+ },
741
+ getRightTotalSize: () => {
742
+ var _table$getRightHeader, _table$getRightHeader2;
743
+ return (_table$getRightHeader = (_table$getRightHeader2 = table.getRightHeaderGroups()[0]) == null ? void 0 : _table$getRightHeader2.headers.reduce((sum, header) => {
744
+ return sum + header.getSize();
745
+ }, 0)) != null ? _table$getRightHeader : 0;
746
+ }
747
+ };
748
+ }
749
+ };
750
+ let passiveSupported = null;
751
+ function passiveEventSupported() {
752
+ if (typeof passiveSupported === 'boolean') return passiveSupported;
753
+ let supported = false;
754
+ try {
755
+ const options = {
756
+ get passive() {
757
+ supported = true;
758
+ return false;
759
+ }
760
+ };
761
+ const noop = () => {};
762
+ window.addEventListener('test', noop, options);
763
+ window.removeEventListener('test', noop);
764
+ } catch (err) {
765
+ supported = false;
766
+ }
767
+ passiveSupported = supported;
768
+ return passiveSupported;
769
+ }
770
+ function isTouchStartEvent(e) {
771
+ return e.type === 'touchstart';
772
+ }
773
+
774
+ //
775
+
776
+ const Expanding = {
777
+ getInitialState: state => {
778
+ return {
779
+ expanded: {},
780
+ ...state
781
+ };
782
+ },
783
+ getDefaultOptions: table => {
784
+ return {
785
+ onExpandedChange: makeStateUpdater('expanded', table),
786
+ paginateExpandedRows: true
787
+ };
788
+ },
789
+ createTable: table => {
790
+ let registered = false;
791
+ let queued = false;
792
+ return {
793
+ _autoResetExpanded: () => {
794
+ var _ref, _table$options$autoRe;
795
+ if (!registered) {
796
+ table._queue(() => {
797
+ registered = true;
798
+ });
799
+ return;
800
+ }
801
+ if ((_ref = (_table$options$autoRe = table.options.autoResetAll) != null ? _table$options$autoRe : table.options.autoResetExpanded) != null ? _ref : !table.options.manualExpanding) {
802
+ if (queued) return;
803
+ queued = true;
804
+ table._queue(() => {
805
+ table.resetExpanded();
806
+ queued = false;
807
+ });
808
+ }
809
+ },
810
+ setExpanded: updater => table.options.onExpandedChange == null ? void 0 : table.options.onExpandedChange(updater),
811
+ toggleAllRowsExpanded: expanded => {
812
+ if (expanded != null ? expanded : !table.getIsAllRowsExpanded()) {
813
+ table.setExpanded(true);
814
+ } else {
815
+ table.setExpanded({});
816
+ }
817
+ },
818
+ resetExpanded: defaultState => {
819
+ var _table$initialState$e, _table$initialState;
820
+ table.setExpanded(defaultState ? {} : (_table$initialState$e = (_table$initialState = table.initialState) == null ? void 0 : _table$initialState.expanded) != null ? _table$initialState$e : {});
821
+ },
822
+ getCanSomeRowsExpand: () => {
823
+ return table.getPrePaginationRowModel().flatRows.some(row => row.getCanExpand());
824
+ },
825
+ getToggleAllRowsExpandedHandler: () => {
826
+ return e => {
827
+ e.persist == null ? void 0 : e.persist();
828
+ table.toggleAllRowsExpanded();
829
+ };
830
+ },
831
+ getIsSomeRowsExpanded: () => {
832
+ const expanded = table.getState().expanded;
833
+ return expanded === true || Object.values(expanded).some(Boolean);
834
+ },
835
+ getIsAllRowsExpanded: () => {
836
+ const expanded = table.getState().expanded;
837
+
838
+ // If expanded is true, save some cycles and return true
839
+ if (typeof expanded === 'boolean') {
840
+ return expanded === true;
841
+ }
842
+ if (!Object.keys(expanded).length) {
843
+ return false;
844
+ }
845
+
846
+ // If any row is not expanded, return false
847
+ if (table.getRowModel().flatRows.some(row => !row.getIsExpanded())) {
848
+ return false;
849
+ }
850
+
851
+ // They must all be expanded :shrug:
852
+ return true;
853
+ },
854
+ getExpandedDepth: () => {
855
+ let maxDepth = 0;
856
+ const rowIds = table.getState().expanded === true ? Object.keys(table.getRowModel().rowsById) : Object.keys(table.getState().expanded);
857
+ rowIds.forEach(id => {
858
+ const splitId = id.split('.');
859
+ maxDepth = Math.max(maxDepth, splitId.length);
860
+ });
861
+ return maxDepth;
862
+ },
863
+ getPreExpandedRowModel: () => table.getSortedRowModel(),
864
+ getExpandedRowModel: () => {
865
+ if (!table._getExpandedRowModel && table.options.getExpandedRowModel) {
866
+ table._getExpandedRowModel = table.options.getExpandedRowModel(table);
867
+ }
868
+ if (table.options.manualExpanding || !table._getExpandedRowModel) {
869
+ return table.getPreExpandedRowModel();
870
+ }
871
+ return table._getExpandedRowModel();
872
+ }
873
+ };
874
+ },
875
+ createRow: (row, table) => {
876
+ return {
877
+ toggleExpanded: expanded => {
878
+ table.setExpanded(old => {
879
+ var _expanded;
880
+ const exists = old === true ? true : !!(old != null && old[row.id]);
881
+ let oldExpanded = {};
882
+ if (old === true) {
883
+ Object.keys(table.getRowModel().rowsById).forEach(rowId => {
884
+ oldExpanded[rowId] = true;
885
+ });
886
+ } else {
887
+ oldExpanded = old;
888
+ }
889
+ expanded = (_expanded = expanded) != null ? _expanded : !exists;
890
+ if (!exists && expanded) {
891
+ return {
892
+ ...oldExpanded,
893
+ [row.id]: true
894
+ };
895
+ }
896
+ if (exists && !expanded) {
897
+ const {
898
+ [row.id]: _,
899
+ ...rest
900
+ } = oldExpanded;
901
+ return rest;
902
+ }
903
+ return old;
904
+ });
905
+ },
906
+ getIsExpanded: () => {
907
+ var _table$options$getIsR;
908
+ const expanded = table.getState().expanded;
909
+ return !!((_table$options$getIsR = table.options.getIsRowExpanded == null ? void 0 : table.options.getIsRowExpanded(row)) != null ? _table$options$getIsR : expanded === true || (expanded == null ? void 0 : expanded[row.id]));
910
+ },
911
+ getCanExpand: () => {
912
+ var _table$options$getRow, _table$options$enable, _row$subRows;
913
+ return (_table$options$getRow = table.options.getRowCanExpand == null ? void 0 : table.options.getRowCanExpand(row)) != null ? _table$options$getRow : ((_table$options$enable = table.options.enableExpanding) != null ? _table$options$enable : true) && !!((_row$subRows = row.subRows) != null && _row$subRows.length);
914
+ },
915
+ getToggleExpandedHandler: () => {
916
+ const canExpand = row.getCanExpand();
917
+ return () => {
918
+ if (!canExpand) return;
919
+ row.toggleExpanded();
920
+ };
921
+ }
922
+ };
923
+ }
924
+ };
925
+
926
+ const includesString = (row, columnId, filterValue) => {
927
+ var _row$getValue, _row$getValue$toStrin, _row$getValue$toStrin2;
928
+ const search = filterValue.toLowerCase();
929
+ return Boolean((_row$getValue = row.getValue(columnId)) == null ? void 0 : (_row$getValue$toStrin = _row$getValue.toString()) == null ? void 0 : (_row$getValue$toStrin2 = _row$getValue$toStrin.toLowerCase()) == null ? void 0 : _row$getValue$toStrin2.includes(search));
930
+ };
931
+ includesString.autoRemove = val => testFalsey(val);
932
+ const includesStringSensitive = (row, columnId, filterValue) => {
933
+ var _row$getValue2, _row$getValue2$toStri;
934
+ return Boolean((_row$getValue2 = row.getValue(columnId)) == null ? void 0 : (_row$getValue2$toStri = _row$getValue2.toString()) == null ? void 0 : _row$getValue2$toStri.includes(filterValue));
935
+ };
936
+ includesStringSensitive.autoRemove = val => testFalsey(val);
937
+ const equalsString = (row, columnId, filterValue) => {
938
+ var _row$getValue3, _row$getValue3$toStri;
939
+ return ((_row$getValue3 = row.getValue(columnId)) == null ? void 0 : (_row$getValue3$toStri = _row$getValue3.toString()) == null ? void 0 : _row$getValue3$toStri.toLowerCase()) === (filterValue == null ? void 0 : filterValue.toLowerCase());
940
+ };
941
+ equalsString.autoRemove = val => testFalsey(val);
942
+ const arrIncludes = (row, columnId, filterValue) => {
943
+ var _row$getValue4;
944
+ return (_row$getValue4 = row.getValue(columnId)) == null ? void 0 : _row$getValue4.includes(filterValue);
945
+ };
946
+ arrIncludes.autoRemove = val => testFalsey(val) || !(val != null && val.length);
947
+ const arrIncludesAll = (row, columnId, filterValue) => {
948
+ return !filterValue.some(val => {
949
+ var _row$getValue5;
950
+ return !((_row$getValue5 = row.getValue(columnId)) != null && _row$getValue5.includes(val));
951
+ });
952
+ };
953
+ arrIncludesAll.autoRemove = val => testFalsey(val) || !(val != null && val.length);
954
+ const arrIncludesSome = (row, columnId, filterValue) => {
955
+ return filterValue.some(val => {
956
+ var _row$getValue6;
957
+ return (_row$getValue6 = row.getValue(columnId)) == null ? void 0 : _row$getValue6.includes(val);
958
+ });
959
+ };
960
+ arrIncludesSome.autoRemove = val => testFalsey(val) || !(val != null && val.length);
961
+ const equals = (row, columnId, filterValue) => {
962
+ return row.getValue(columnId) === filterValue;
963
+ };
964
+ equals.autoRemove = val => testFalsey(val);
965
+ const weakEquals = (row, columnId, filterValue) => {
966
+ return row.getValue(columnId) == filterValue;
967
+ };
968
+ weakEquals.autoRemove = val => testFalsey(val);
969
+ const inNumberRange = (row, columnId, filterValue) => {
970
+ let [min, max] = filterValue;
971
+ const rowValue = row.getValue(columnId);
972
+ return rowValue >= min && rowValue <= max;
973
+ };
974
+ inNumberRange.resolveFilterValue = val => {
975
+ let [unsafeMin, unsafeMax] = val;
976
+ let parsedMin = typeof unsafeMin !== 'number' ? parseFloat(unsafeMin) : unsafeMin;
977
+ let parsedMax = typeof unsafeMax !== 'number' ? parseFloat(unsafeMax) : unsafeMax;
978
+ let min = unsafeMin === null || Number.isNaN(parsedMin) ? -Infinity : parsedMin;
979
+ let max = unsafeMax === null || Number.isNaN(parsedMax) ? Infinity : parsedMax;
980
+ if (min > max) {
981
+ const temp = min;
982
+ min = max;
983
+ max = temp;
984
+ }
985
+ return [min, max];
986
+ };
987
+ inNumberRange.autoRemove = val => testFalsey(val) || testFalsey(val[0]) && testFalsey(val[1]);
988
+
989
+ // Export
990
+
991
+ const filterFns = {
992
+ includesString,
993
+ includesStringSensitive,
994
+ equalsString,
995
+ arrIncludes,
996
+ arrIncludesAll,
997
+ arrIncludesSome,
998
+ equals,
999
+ weakEquals,
1000
+ inNumberRange
1001
+ };
1002
+ // Utils
1003
+
1004
+ function testFalsey(val) {
1005
+ return val === undefined || val === null || val === '';
1006
+ }
1007
+
1008
+ //
1009
+
1010
+ const Filters = {
1011
+ getDefaultColumnDef: () => {
1012
+ return {
1013
+ filterFn: 'auto'
1014
+ };
1015
+ },
1016
+ getInitialState: state => {
1017
+ return {
1018
+ columnFilters: [],
1019
+ globalFilter: undefined,
1020
+ // filtersProgress: 1,
1021
+ // facetProgress: {},
1022
+ ...state
1023
+ };
1024
+ },
1025
+ getDefaultOptions: table => {
1026
+ return {
1027
+ onColumnFiltersChange: makeStateUpdater('columnFilters', table),
1028
+ onGlobalFilterChange: makeStateUpdater('globalFilter', table),
1029
+ filterFromLeafRows: false,
1030
+ maxLeafRowFilterDepth: 100,
1031
+ globalFilterFn: 'auto',
1032
+ getColumnCanGlobalFilter: column => {
1033
+ var _table$getCoreRowMode, _table$getCoreRowMode2;
1034
+ const value = (_table$getCoreRowMode = table.getCoreRowModel().flatRows[0]) == null ? void 0 : (_table$getCoreRowMode2 = _table$getCoreRowMode._getAllCellsByColumnId()[column.id]) == null ? void 0 : _table$getCoreRowMode2.getValue();
1035
+ return typeof value === 'string' || typeof value === 'number';
1036
+ }
1037
+ };
1038
+ },
1039
+ createColumn: (column, table) => {
1040
+ return {
1041
+ getAutoFilterFn: () => {
1042
+ const firstRow = table.getCoreRowModel().flatRows[0];
1043
+ const value = firstRow == null ? void 0 : firstRow.getValue(column.id);
1044
+ if (typeof value === 'string') {
1045
+ return filterFns.includesString;
1046
+ }
1047
+ if (typeof value === 'number') {
1048
+ return filterFns.inNumberRange;
1049
+ }
1050
+ if (typeof value === 'boolean') {
1051
+ return filterFns.equals;
1052
+ }
1053
+ if (value !== null && typeof value === 'object') {
1054
+ return filterFns.equals;
1055
+ }
1056
+ if (Array.isArray(value)) {
1057
+ return filterFns.arrIncludes;
1058
+ }
1059
+ return filterFns.weakEquals;
1060
+ },
1061
+ getFilterFn: () => {
1062
+ var _table$options$filter, _table$options$filter2;
1063
+ return isFunction(column.columnDef.filterFn) ? column.columnDef.filterFn : column.columnDef.filterFn === 'auto' ? column.getAutoFilterFn()
1064
+ // @ts-ignore
1065
+ : (_table$options$filter = (_table$options$filter2 = table.options.filterFns) == null ? void 0 : _table$options$filter2[column.columnDef.filterFn]) != null ? _table$options$filter : filterFns[column.columnDef.filterFn];
1066
+ },
1067
+ getCanFilter: () => {
1068
+ var _column$columnDef$ena, _table$options$enable, _table$options$enable2;
1069
+ return ((_column$columnDef$ena = column.columnDef.enableColumnFilter) != null ? _column$columnDef$ena : true) && ((_table$options$enable = table.options.enableColumnFilters) != null ? _table$options$enable : true) && ((_table$options$enable2 = table.options.enableFilters) != null ? _table$options$enable2 : true) && !!column.accessorFn;
1070
+ },
1071
+ getCanGlobalFilter: () => {
1072
+ var _column$columnDef$ena2, _table$options$enable3, _table$options$enable4, _table$options$getCol;
1073
+ return ((_column$columnDef$ena2 = column.columnDef.enableGlobalFilter) != null ? _column$columnDef$ena2 : true) && ((_table$options$enable3 = table.options.enableGlobalFilter) != null ? _table$options$enable3 : true) && ((_table$options$enable4 = table.options.enableFilters) != null ? _table$options$enable4 : true) && ((_table$options$getCol = table.options.getColumnCanGlobalFilter == null ? void 0 : table.options.getColumnCanGlobalFilter(column)) != null ? _table$options$getCol : true) && !!column.accessorFn;
1074
+ },
1075
+ getIsFiltered: () => column.getFilterIndex() > -1,
1076
+ getFilterValue: () => {
1077
+ var _table$getState$colum, _table$getState$colum2;
1078
+ return (_table$getState$colum = table.getState().columnFilters) == null ? void 0 : (_table$getState$colum2 = _table$getState$colum.find(d => d.id === column.id)) == null ? void 0 : _table$getState$colum2.value;
1079
+ },
1080
+ getFilterIndex: () => {
1081
+ var _table$getState$colum3, _table$getState$colum4;
1082
+ return (_table$getState$colum3 = (_table$getState$colum4 = table.getState().columnFilters) == null ? void 0 : _table$getState$colum4.findIndex(d => d.id === column.id)) != null ? _table$getState$colum3 : -1;
1083
+ },
1084
+ setFilterValue: value => {
1085
+ table.setColumnFilters(old => {
1086
+ const filterFn = column.getFilterFn();
1087
+ const previousfilter = old == null ? void 0 : old.find(d => d.id === column.id);
1088
+ const newFilter = functionalUpdate(value, previousfilter ? previousfilter.value : undefined);
1089
+
1090
+ //
1091
+ if (shouldAutoRemoveFilter(filterFn, newFilter, column)) {
1092
+ var _old$filter;
1093
+ return (_old$filter = old == null ? void 0 : old.filter(d => d.id !== column.id)) != null ? _old$filter : [];
1094
+ }
1095
+ const newFilterObj = {
1096
+ id: column.id,
1097
+ value: newFilter
1098
+ };
1099
+ if (previousfilter) {
1100
+ var _old$map;
1101
+ return (_old$map = old == null ? void 0 : old.map(d => {
1102
+ if (d.id === column.id) {
1103
+ return newFilterObj;
1104
+ }
1105
+ return d;
1106
+ })) != null ? _old$map : [];
1107
+ }
1108
+ if (old != null && old.length) {
1109
+ return [...old, newFilterObj];
1110
+ }
1111
+ return [newFilterObj];
1112
+ });
1113
+ },
1114
+ _getFacetedRowModel: table.options.getFacetedRowModel && table.options.getFacetedRowModel(table, column.id),
1115
+ getFacetedRowModel: () => {
1116
+ if (!column._getFacetedRowModel) {
1117
+ return table.getPreFilteredRowModel();
1118
+ }
1119
+ return column._getFacetedRowModel();
1120
+ },
1121
+ _getFacetedUniqueValues: table.options.getFacetedUniqueValues && table.options.getFacetedUniqueValues(table, column.id),
1122
+ getFacetedUniqueValues: () => {
1123
+ if (!column._getFacetedUniqueValues) {
1124
+ return new Map();
1125
+ }
1126
+ return column._getFacetedUniqueValues();
1127
+ },
1128
+ _getFacetedMinMaxValues: table.options.getFacetedMinMaxValues && table.options.getFacetedMinMaxValues(table, column.id),
1129
+ getFacetedMinMaxValues: () => {
1130
+ if (!column._getFacetedMinMaxValues) {
1131
+ return undefined;
1132
+ }
1133
+ return column._getFacetedMinMaxValues();
1134
+ }
1135
+ // () => [column.getFacetedRowModel()],
1136
+ // facetedRowModel => getRowModelMinMaxValues(facetedRowModel, column.id),
1137
+ };
1138
+ },
1139
+
1140
+ createRow: (row, table) => {
1141
+ return {
1142
+ columnFilters: {},
1143
+ columnFiltersMeta: {}
1144
+ };
1145
+ },
1146
+ createTable: table => {
1147
+ return {
1148
+ getGlobalAutoFilterFn: () => {
1149
+ return filterFns.includesString;
1150
+ },
1151
+ getGlobalFilterFn: () => {
1152
+ var _table$options$filter3, _table$options$filter4;
1153
+ const {
1154
+ globalFilterFn: globalFilterFn
1155
+ } = table.options;
1156
+ return isFunction(globalFilterFn) ? globalFilterFn : globalFilterFn === 'auto' ? table.getGlobalAutoFilterFn()
1157
+ // @ts-ignore
1158
+ : (_table$options$filter3 = (_table$options$filter4 = table.options.filterFns) == null ? void 0 : _table$options$filter4[globalFilterFn]) != null ? _table$options$filter3 : filterFns[globalFilterFn];
1159
+ },
1160
+ setColumnFilters: updater => {
1161
+ const leafColumns = table.getAllLeafColumns();
1162
+ const updateFn = old => {
1163
+ var _functionalUpdate;
1164
+ return (_functionalUpdate = functionalUpdate(updater, old)) == null ? void 0 : _functionalUpdate.filter(filter => {
1165
+ const column = leafColumns.find(d => d.id === filter.id);
1166
+ if (column) {
1167
+ const filterFn = column.getFilterFn();
1168
+ if (shouldAutoRemoveFilter(filterFn, filter.value, column)) {
1169
+ return false;
1170
+ }
1171
+ }
1172
+ return true;
1173
+ });
1174
+ };
1175
+ table.options.onColumnFiltersChange == null ? void 0 : table.options.onColumnFiltersChange(updateFn);
1176
+ },
1177
+ setGlobalFilter: updater => {
1178
+ table.options.onGlobalFilterChange == null ? void 0 : table.options.onGlobalFilterChange(updater);
1179
+ },
1180
+ resetGlobalFilter: defaultState => {
1181
+ table.setGlobalFilter(defaultState ? undefined : table.initialState.globalFilter);
1182
+ },
1183
+ resetColumnFilters: defaultState => {
1184
+ var _table$initialState$c, _table$initialState;
1185
+ table.setColumnFilters(defaultState ? [] : (_table$initialState$c = (_table$initialState = table.initialState) == null ? void 0 : _table$initialState.columnFilters) != null ? _table$initialState$c : []);
1186
+ },
1187
+ getPreFilteredRowModel: () => table.getCoreRowModel(),
1188
+ getFilteredRowModel: () => {
1189
+ if (!table._getFilteredRowModel && table.options.getFilteredRowModel) {
1190
+ table._getFilteredRowModel = table.options.getFilteredRowModel(table);
1191
+ }
1192
+ if (table.options.manualFiltering || !table._getFilteredRowModel) {
1193
+ return table.getPreFilteredRowModel();
1194
+ }
1195
+ return table._getFilteredRowModel();
1196
+ },
1197
+ _getGlobalFacetedRowModel: table.options.getFacetedRowModel && table.options.getFacetedRowModel(table, '__global__'),
1198
+ getGlobalFacetedRowModel: () => {
1199
+ if (table.options.manualFiltering || !table._getGlobalFacetedRowModel) {
1200
+ return table.getPreFilteredRowModel();
1201
+ }
1202
+ return table._getGlobalFacetedRowModel();
1203
+ },
1204
+ _getGlobalFacetedUniqueValues: table.options.getFacetedUniqueValues && table.options.getFacetedUniqueValues(table, '__global__'),
1205
+ getGlobalFacetedUniqueValues: () => {
1206
+ if (!table._getGlobalFacetedUniqueValues) {
1207
+ return new Map();
1208
+ }
1209
+ return table._getGlobalFacetedUniqueValues();
1210
+ },
1211
+ _getGlobalFacetedMinMaxValues: table.options.getFacetedMinMaxValues && table.options.getFacetedMinMaxValues(table, '__global__'),
1212
+ getGlobalFacetedMinMaxValues: () => {
1213
+ if (!table._getGlobalFacetedMinMaxValues) {
1214
+ return;
1215
+ }
1216
+ return table._getGlobalFacetedMinMaxValues();
1217
+ }
1218
+ };
1219
+ }
1220
+ };
1221
+ function shouldAutoRemoveFilter(filterFn, value, column) {
1222
+ return (filterFn && filterFn.autoRemove ? filterFn.autoRemove(value, column) : false) || typeof value === 'undefined' || typeof value === 'string' && !value;
1223
+ }
1224
+
1225
+ const sum = (columnId, _leafRows, childRows) => {
1226
+ // It's faster to just add the aggregations together instead of
1227
+ // process leaf nodes individually
1228
+ return childRows.reduce((sum, next) => {
1229
+ const nextValue = next.getValue(columnId);
1230
+ return sum + (typeof nextValue === 'number' ? nextValue : 0);
1231
+ }, 0);
1232
+ };
1233
+ const min = (columnId, _leafRows, childRows) => {
1234
+ let min;
1235
+ childRows.forEach(row => {
1236
+ const value = row.getValue(columnId);
1237
+ if (value != null && (min > value || min === undefined && value >= value)) {
1238
+ min = value;
1239
+ }
1240
+ });
1241
+ return min;
1242
+ };
1243
+ const max = (columnId, _leafRows, childRows) => {
1244
+ let max;
1245
+ childRows.forEach(row => {
1246
+ const value = row.getValue(columnId);
1247
+ if (value != null && (max < value || max === undefined && value >= value)) {
1248
+ max = value;
1249
+ }
1250
+ });
1251
+ return max;
1252
+ };
1253
+ const extent = (columnId, _leafRows, childRows) => {
1254
+ let min;
1255
+ let max;
1256
+ childRows.forEach(row => {
1257
+ const value = row.getValue(columnId);
1258
+ if (value != null) {
1259
+ if (min === undefined) {
1260
+ if (value >= value) min = max = value;
1261
+ } else {
1262
+ if (min > value) min = value;
1263
+ if (max < value) max = value;
1264
+ }
1265
+ }
1266
+ });
1267
+ return [min, max];
1268
+ };
1269
+ const mean = (columnId, leafRows) => {
1270
+ let count = 0;
1271
+ let sum = 0;
1272
+ leafRows.forEach(row => {
1273
+ let value = row.getValue(columnId);
1274
+ if (value != null && (value = +value) >= value) {
1275
+ ++count, sum += value;
1276
+ }
1277
+ });
1278
+ if (count) return sum / count;
1279
+ return;
1280
+ };
1281
+ const median = (columnId, leafRows) => {
1282
+ if (!leafRows.length) {
1283
+ return;
1284
+ }
1285
+ const values = leafRows.map(row => row.getValue(columnId));
1286
+ if (!isNumberArray(values)) {
1287
+ return;
1288
+ }
1289
+ if (values.length === 1) {
1290
+ return values[0];
1291
+ }
1292
+ const mid = Math.floor(values.length / 2);
1293
+ const nums = values.sort((a, b) => a - b);
1294
+ return values.length % 2 !== 0 ? nums[mid] : (nums[mid - 1] + nums[mid]) / 2;
1295
+ };
1296
+ const unique = (columnId, leafRows) => {
1297
+ return Array.from(new Set(leafRows.map(d => d.getValue(columnId))).values());
1298
+ };
1299
+ const uniqueCount = (columnId, leafRows) => {
1300
+ return new Set(leafRows.map(d => d.getValue(columnId))).size;
1301
+ };
1302
+ const count = (_columnId, leafRows) => {
1303
+ return leafRows.length;
1304
+ };
1305
+ const aggregationFns = {
1306
+ sum,
1307
+ min,
1308
+ max,
1309
+ extent,
1310
+ mean,
1311
+ median,
1312
+ unique,
1313
+ uniqueCount,
1314
+ count
1315
+ };
1316
+
1317
+ //
1318
+
1319
+ const Grouping = {
1320
+ getDefaultColumnDef: () => {
1321
+ return {
1322
+ aggregatedCell: props => {
1323
+ var _toString, _props$getValue;
1324
+ return (_toString = (_props$getValue = props.getValue()) == null ? void 0 : _props$getValue.toString == null ? void 0 : _props$getValue.toString()) != null ? _toString : null;
1325
+ },
1326
+ aggregationFn: 'auto'
1327
+ };
1328
+ },
1329
+ getInitialState: state => {
1330
+ return {
1331
+ grouping: [],
1332
+ ...state
1333
+ };
1334
+ },
1335
+ getDefaultOptions: table => {
1336
+ return {
1337
+ onGroupingChange: makeStateUpdater('grouping', table),
1338
+ groupedColumnMode: 'reorder'
1339
+ };
1340
+ },
1341
+ createColumn: (column, table) => {
1342
+ return {
1343
+ toggleGrouping: () => {
1344
+ table.setGrouping(old => {
1345
+ // Find any existing grouping for this column
1346
+ if (old != null && old.includes(column.id)) {
1347
+ return old.filter(d => d !== column.id);
1348
+ }
1349
+ return [...(old != null ? old : []), column.id];
1350
+ });
1351
+ },
1352
+ getCanGroup: () => {
1353
+ var _ref, _ref2, _ref3, _column$columnDef$ena;
1354
+ return (_ref = (_ref2 = (_ref3 = (_column$columnDef$ena = column.columnDef.enableGrouping) != null ? _column$columnDef$ena : true) != null ? _ref3 : table.options.enableGrouping) != null ? _ref2 : true) != null ? _ref : !!column.accessorFn;
1355
+ },
1356
+ getIsGrouped: () => {
1357
+ var _table$getState$group;
1358
+ return (_table$getState$group = table.getState().grouping) == null ? void 0 : _table$getState$group.includes(column.id);
1359
+ },
1360
+ getGroupedIndex: () => {
1361
+ var _table$getState$group2;
1362
+ return (_table$getState$group2 = table.getState().grouping) == null ? void 0 : _table$getState$group2.indexOf(column.id);
1363
+ },
1364
+ getToggleGroupingHandler: () => {
1365
+ const canGroup = column.getCanGroup();
1366
+ return () => {
1367
+ if (!canGroup) return;
1368
+ column.toggleGrouping();
1369
+ };
1370
+ },
1371
+ getAutoAggregationFn: () => {
1372
+ const firstRow = table.getCoreRowModel().flatRows[0];
1373
+ const value = firstRow == null ? void 0 : firstRow.getValue(column.id);
1374
+ if (typeof value === 'number') {
1375
+ return aggregationFns.sum;
1376
+ }
1377
+ if (Object.prototype.toString.call(value) === '[object Date]') {
1378
+ return aggregationFns.extent;
1379
+ }
1380
+ },
1381
+ getAggregationFn: () => {
1382
+ var _table$options$aggreg, _table$options$aggreg2;
1383
+ if (!column) {
1384
+ throw new Error();
1385
+ }
1386
+ return isFunction(column.columnDef.aggregationFn) ? column.columnDef.aggregationFn : column.columnDef.aggregationFn === 'auto' ? column.getAutoAggregationFn() : (_table$options$aggreg = (_table$options$aggreg2 = table.options.aggregationFns) == null ? void 0 : _table$options$aggreg2[column.columnDef.aggregationFn]) != null ? _table$options$aggreg : aggregationFns[column.columnDef.aggregationFn];
1387
+ }
1388
+ };
1389
+ },
1390
+ createTable: table => {
1391
+ return {
1392
+ setGrouping: updater => table.options.onGroupingChange == null ? void 0 : table.options.onGroupingChange(updater),
1393
+ resetGrouping: defaultState => {
1394
+ var _table$initialState$g, _table$initialState;
1395
+ table.setGrouping(defaultState ? [] : (_table$initialState$g = (_table$initialState = table.initialState) == null ? void 0 : _table$initialState.grouping) != null ? _table$initialState$g : []);
1396
+ },
1397
+ getPreGroupedRowModel: () => table.getFilteredRowModel(),
1398
+ getGroupedRowModel: () => {
1399
+ if (!table._getGroupedRowModel && table.options.getGroupedRowModel) {
1400
+ table._getGroupedRowModel = table.options.getGroupedRowModel(table);
1401
+ }
1402
+ if (table.options.manualGrouping || !table._getGroupedRowModel) {
1403
+ return table.getPreGroupedRowModel();
1404
+ }
1405
+ return table._getGroupedRowModel();
1406
+ }
1407
+ };
1408
+ },
1409
+ createRow: (row, table) => {
1410
+ return {
1411
+ getIsGrouped: () => !!row.groupingColumnId,
1412
+ getGroupingValue: columnId => {
1413
+ if (row._groupingValuesCache.hasOwnProperty(columnId)) {
1414
+ return row._groupingValuesCache[columnId];
1415
+ }
1416
+ const column = table.getColumn(columnId);
1417
+ if (!(column != null && column.columnDef.getGroupingValue)) {
1418
+ return row.getValue(columnId);
1419
+ }
1420
+ row._groupingValuesCache[columnId] = column.columnDef.getGroupingValue(row.original);
1421
+ return row._groupingValuesCache[columnId];
1422
+ },
1423
+ _groupingValuesCache: {}
1424
+ };
1425
+ },
1426
+ createCell: (cell, column, row, table) => {
1427
+ return {
1428
+ getIsGrouped: () => column.getIsGrouped() && column.id === row.groupingColumnId,
1429
+ getIsPlaceholder: () => !cell.getIsGrouped() && column.getIsGrouped(),
1430
+ getIsAggregated: () => {
1431
+ var _row$subRows;
1432
+ return !cell.getIsGrouped() && !cell.getIsPlaceholder() && !!((_row$subRows = row.subRows) != null && _row$subRows.length);
1433
+ }
1434
+ };
1435
+ }
1436
+ };
1437
+ function orderColumns(leafColumns, grouping, groupedColumnMode) {
1438
+ if (!(grouping != null && grouping.length) || !groupedColumnMode) {
1439
+ return leafColumns;
1440
+ }
1441
+ const nonGroupingColumns = leafColumns.filter(col => !grouping.includes(col.id));
1442
+ if (groupedColumnMode === 'remove') {
1443
+ return nonGroupingColumns;
1444
+ }
1445
+ const groupingColumns = grouping.map(g => leafColumns.find(col => col.id === g)).filter(Boolean);
1446
+ return [...groupingColumns, ...nonGroupingColumns];
1447
+ }
1448
+
1449
+ //
1450
+
1451
+ const Ordering = {
1452
+ getInitialState: state => {
1453
+ return {
1454
+ columnOrder: [],
1455
+ ...state
1456
+ };
1457
+ },
1458
+ getDefaultOptions: table => {
1459
+ return {
1460
+ onColumnOrderChange: makeStateUpdater('columnOrder', table)
1461
+ };
1462
+ },
1463
+ createTable: table => {
1464
+ return {
1465
+ setColumnOrder: updater => table.options.onColumnOrderChange == null ? void 0 : table.options.onColumnOrderChange(updater),
1466
+ resetColumnOrder: defaultState => {
1467
+ var _table$initialState$c;
1468
+ table.setColumnOrder(defaultState ? [] : (_table$initialState$c = table.initialState.columnOrder) != null ? _table$initialState$c : []);
1469
+ },
1470
+ _getOrderColumnsFn: memo(() => [table.getState().columnOrder, table.getState().grouping, table.options.groupedColumnMode], (columnOrder, grouping, groupedColumnMode) => columns => {
1471
+ // Sort grouped columns to the start of the column list
1472
+ // before the headers are built
1473
+ let orderedColumns = [];
1474
+
1475
+ // If there is no order, return the normal columns
1476
+ if (!(columnOrder != null && columnOrder.length)) {
1477
+ orderedColumns = columns;
1478
+ } else {
1479
+ const columnOrderCopy = [...columnOrder];
1480
+
1481
+ // If there is an order, make a copy of the columns
1482
+ const columnsCopy = [...columns];
1483
+
1484
+ // And make a new ordered array of the columns
1485
+
1486
+ // Loop over the columns and place them in order into the new array
1487
+ while (columnsCopy.length && columnOrderCopy.length) {
1488
+ const targetColumnId = columnOrderCopy.shift();
1489
+ const foundIndex = columnsCopy.findIndex(d => d.id === targetColumnId);
1490
+ if (foundIndex > -1) {
1491
+ orderedColumns.push(columnsCopy.splice(foundIndex, 1)[0]);
1492
+ }
1493
+ }
1494
+
1495
+ // If there are any columns left, add them to the end
1496
+ orderedColumns = [...orderedColumns, ...columnsCopy];
1497
+ }
1498
+ return orderColumns(orderedColumns, grouping, groupedColumnMode);
1499
+ }, {
1500
+ key: process.env.NODE_ENV === 'development' && 'getOrderColumnsFn'
1501
+ // debug: () => table.options.debugAll ?? table.options.debugTable,
1502
+ })
1503
+ };
1504
+ }
1505
+ };
1506
+
1507
+ //
1508
+
1509
+ const defaultPageIndex = 0;
1510
+ const defaultPageSize = 10;
1511
+ const getDefaultPaginationState = () => ({
1512
+ pageIndex: defaultPageIndex,
1513
+ pageSize: defaultPageSize
1514
+ });
1515
+ const Pagination = {
1516
+ getInitialState: state => {
1517
+ return {
1518
+ ...state,
1519
+ pagination: {
1520
+ ...getDefaultPaginationState(),
1521
+ ...(state == null ? void 0 : state.pagination)
1522
+ }
1523
+ };
1524
+ },
1525
+ getDefaultOptions: table => {
1526
+ return {
1527
+ onPaginationChange: makeStateUpdater('pagination', table)
1528
+ };
1529
+ },
1530
+ createTable: table => {
1531
+ let registered = false;
1532
+ let queued = false;
1533
+ return {
1534
+ _autoResetPageIndex: () => {
1535
+ var _ref, _table$options$autoRe;
1536
+ if (!registered) {
1537
+ table._queue(() => {
1538
+ registered = true;
1539
+ });
1540
+ return;
1541
+ }
1542
+ if ((_ref = (_table$options$autoRe = table.options.autoResetAll) != null ? _table$options$autoRe : table.options.autoResetPageIndex) != null ? _ref : !table.options.manualPagination) {
1543
+ if (queued) return;
1544
+ queued = true;
1545
+ table._queue(() => {
1546
+ table.resetPageIndex();
1547
+ queued = false;
1548
+ });
1549
+ }
1550
+ },
1551
+ setPagination: updater => {
1552
+ const safeUpdater = old => {
1553
+ let newState = functionalUpdate(updater, old);
1554
+ return newState;
1555
+ };
1556
+ return table.options.onPaginationChange == null ? void 0 : table.options.onPaginationChange(safeUpdater);
1557
+ },
1558
+ resetPagination: defaultState => {
1559
+ var _table$initialState$p;
1560
+ table.setPagination(defaultState ? getDefaultPaginationState() : (_table$initialState$p = table.initialState.pagination) != null ? _table$initialState$p : getDefaultPaginationState());
1561
+ },
1562
+ setPageIndex: updater => {
1563
+ table.setPagination(old => {
1564
+ let pageIndex = functionalUpdate(updater, old.pageIndex);
1565
+ const maxPageIndex = typeof table.options.pageCount === 'undefined' || table.options.pageCount === -1 ? Number.MAX_SAFE_INTEGER : table.options.pageCount - 1;
1566
+ pageIndex = Math.max(0, Math.min(pageIndex, maxPageIndex));
1567
+ return {
1568
+ ...old,
1569
+ pageIndex
1570
+ };
1571
+ });
1572
+ },
1573
+ resetPageIndex: defaultState => {
1574
+ var _table$initialState$p2, _table$initialState, _table$initialState$p3;
1575
+ table.setPageIndex(defaultState ? defaultPageIndex : (_table$initialState$p2 = (_table$initialState = table.initialState) == null ? void 0 : (_table$initialState$p3 = _table$initialState.pagination) == null ? void 0 : _table$initialState$p3.pageIndex) != null ? _table$initialState$p2 : defaultPageIndex);
1576
+ },
1577
+ resetPageSize: defaultState => {
1578
+ var _table$initialState$p4, _table$initialState2, _table$initialState2$;
1579
+ table.setPageSize(defaultState ? defaultPageSize : (_table$initialState$p4 = (_table$initialState2 = table.initialState) == null ? void 0 : (_table$initialState2$ = _table$initialState2.pagination) == null ? void 0 : _table$initialState2$.pageSize) != null ? _table$initialState$p4 : defaultPageSize);
1580
+ },
1581
+ setPageSize: updater => {
1582
+ table.setPagination(old => {
1583
+ const pageSize = Math.max(1, functionalUpdate(updater, old.pageSize));
1584
+ const topRowIndex = old.pageSize * old.pageIndex;
1585
+ const pageIndex = Math.floor(topRowIndex / pageSize);
1586
+ return {
1587
+ ...old,
1588
+ pageIndex,
1589
+ pageSize
1590
+ };
1591
+ });
1592
+ },
1593
+ setPageCount: updater => table.setPagination(old => {
1594
+ var _table$options$pageCo;
1595
+ let newPageCount = functionalUpdate(updater, (_table$options$pageCo = table.options.pageCount) != null ? _table$options$pageCo : -1);
1596
+ if (typeof newPageCount === 'number') {
1597
+ newPageCount = Math.max(-1, newPageCount);
1598
+ }
1599
+ return {
1600
+ ...old,
1601
+ pageCount: newPageCount
1602
+ };
1603
+ }),
1604
+ getPageOptions: memo(() => [table.getPageCount()], pageCount => {
1605
+ let pageOptions = [];
1606
+ if (pageCount && pageCount > 0) {
1607
+ pageOptions = [...new Array(pageCount)].fill(null).map((_, i) => i);
1608
+ }
1609
+ return pageOptions;
1610
+ }, {
1611
+ key: process.env.NODE_ENV === 'development' && 'getPageOptions',
1612
+ debug: () => {
1613
+ var _table$options$debugA;
1614
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugTable;
1615
+ }
1616
+ }),
1617
+ getCanPreviousPage: () => table.getState().pagination.pageIndex > 0,
1618
+ getCanNextPage: () => {
1619
+ const {
1620
+ pageIndex
1621
+ } = table.getState().pagination;
1622
+ const pageCount = table.getPageCount();
1623
+ if (pageCount === -1) {
1624
+ return true;
1625
+ }
1626
+ if (pageCount === 0) {
1627
+ return false;
1628
+ }
1629
+ return pageIndex < pageCount - 1;
1630
+ },
1631
+ previousPage: () => {
1632
+ return table.setPageIndex(old => old - 1);
1633
+ },
1634
+ nextPage: () => {
1635
+ return table.setPageIndex(old => {
1636
+ return old + 1;
1637
+ });
1638
+ },
1639
+ getPrePaginationRowModel: () => table.getExpandedRowModel(),
1640
+ getPaginationRowModel: () => {
1641
+ if (!table._getPaginationRowModel && table.options.getPaginationRowModel) {
1642
+ table._getPaginationRowModel = table.options.getPaginationRowModel(table);
1643
+ }
1644
+ if (table.options.manualPagination || !table._getPaginationRowModel) {
1645
+ return table.getPrePaginationRowModel();
1646
+ }
1647
+ return table._getPaginationRowModel();
1648
+ },
1649
+ getPageCount: () => {
1650
+ var _table$options$pageCo2;
1651
+ return (_table$options$pageCo2 = table.options.pageCount) != null ? _table$options$pageCo2 : Math.ceil(table.getPrePaginationRowModel().rows.length / table.getState().pagination.pageSize);
1652
+ }
1653
+ };
1654
+ }
1655
+ };
1656
+
1657
+ //
1658
+
1659
+ const getDefaultPinningState = () => ({
1660
+ left: [],
1661
+ right: []
1662
+ });
1663
+ const Pinning = {
1664
+ getInitialState: state => {
1665
+ return {
1666
+ columnPinning: getDefaultPinningState(),
1667
+ ...state
1668
+ };
1669
+ },
1670
+ getDefaultOptions: table => {
1671
+ return {
1672
+ onColumnPinningChange: makeStateUpdater('columnPinning', table)
1673
+ };
1674
+ },
1675
+ createColumn: (column, table) => {
1676
+ return {
1677
+ pin: position => {
1678
+ const columnIds = column.getLeafColumns().map(d => d.id).filter(Boolean);
1679
+ table.setColumnPinning(old => {
1680
+ var _old$left3, _old$right3;
1681
+ if (position === 'right') {
1682
+ var _old$left, _old$right;
1683
+ return {
1684
+ left: ((_old$left = old == null ? void 0 : old.left) != null ? _old$left : []).filter(d => !(columnIds != null && columnIds.includes(d))),
1685
+ right: [...((_old$right = old == null ? void 0 : old.right) != null ? _old$right : []).filter(d => !(columnIds != null && columnIds.includes(d))), ...columnIds]
1686
+ };
1687
+ }
1688
+ if (position === 'left') {
1689
+ var _old$left2, _old$right2;
1690
+ return {
1691
+ left: [...((_old$left2 = old == null ? void 0 : old.left) != null ? _old$left2 : []).filter(d => !(columnIds != null && columnIds.includes(d))), ...columnIds],
1692
+ right: ((_old$right2 = old == null ? void 0 : old.right) != null ? _old$right2 : []).filter(d => !(columnIds != null && columnIds.includes(d)))
1693
+ };
1694
+ }
1695
+ return {
1696
+ left: ((_old$left3 = old == null ? void 0 : old.left) != null ? _old$left3 : []).filter(d => !(columnIds != null && columnIds.includes(d))),
1697
+ right: ((_old$right3 = old == null ? void 0 : old.right) != null ? _old$right3 : []).filter(d => !(columnIds != null && columnIds.includes(d)))
1698
+ };
1699
+ });
1700
+ },
1701
+ getCanPin: () => {
1702
+ const leafColumns = column.getLeafColumns();
1703
+ return leafColumns.some(d => {
1704
+ var _d$columnDef$enablePi, _table$options$enable;
1705
+ return ((_d$columnDef$enablePi = d.columnDef.enablePinning) != null ? _d$columnDef$enablePi : true) && ((_table$options$enable = table.options.enablePinning) != null ? _table$options$enable : true);
1706
+ });
1707
+ },
1708
+ getIsPinned: () => {
1709
+ const leafColumnIds = column.getLeafColumns().map(d => d.id);
1710
+ const {
1711
+ left,
1712
+ right
1713
+ } = table.getState().columnPinning;
1714
+ const isLeft = leafColumnIds.some(d => left == null ? void 0 : left.includes(d));
1715
+ const isRight = leafColumnIds.some(d => right == null ? void 0 : right.includes(d));
1716
+ return isLeft ? 'left' : isRight ? 'right' : false;
1717
+ },
1718
+ getPinnedIndex: () => {
1719
+ var _table$getState$colum, _table$getState$colum2, _table$getState$colum3;
1720
+ const position = column.getIsPinned();
1721
+ return position ? (_table$getState$colum = (_table$getState$colum2 = table.getState().columnPinning) == null ? void 0 : (_table$getState$colum3 = _table$getState$colum2[position]) == null ? void 0 : _table$getState$colum3.indexOf(column.id)) != null ? _table$getState$colum : -1 : 0;
1722
+ }
1723
+ };
1724
+ },
1725
+ createRow: (row, table) => {
1726
+ return {
1727
+ getCenterVisibleCells: memo(() => [row._getAllVisibleCells(), table.getState().columnPinning.left, table.getState().columnPinning.right], (allCells, left, right) => {
1728
+ const leftAndRight = [...(left != null ? left : []), ...(right != null ? right : [])];
1729
+ return allCells.filter(d => !leftAndRight.includes(d.column.id));
1730
+ }, {
1731
+ key: process.env.NODE_ENV === 'production' && 'row.getCenterVisibleCells',
1732
+ debug: () => {
1733
+ var _table$options$debugA;
1734
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugRows;
1735
+ }
1736
+ }),
1737
+ getLeftVisibleCells: memo(() => [row._getAllVisibleCells(), table.getState().columnPinning.left,,], (allCells, left) => {
1738
+ const cells = (left != null ? left : []).map(columnId => allCells.find(cell => cell.column.id === columnId)).filter(Boolean).map(d => ({
1739
+ ...d,
1740
+ position: 'left'
1741
+ }));
1742
+ return cells;
1743
+ }, {
1744
+ key: process.env.NODE_ENV === 'production' && 'row.getLeftVisibleCells',
1745
+ debug: () => {
1746
+ var _table$options$debugA2;
1747
+ return (_table$options$debugA2 = table.options.debugAll) != null ? _table$options$debugA2 : table.options.debugRows;
1748
+ }
1749
+ }),
1750
+ getRightVisibleCells: memo(() => [row._getAllVisibleCells(), table.getState().columnPinning.right], (allCells, right) => {
1751
+ const cells = (right != null ? right : []).map(columnId => allCells.find(cell => cell.column.id === columnId)).filter(Boolean).map(d => ({
1752
+ ...d,
1753
+ position: 'right'
1754
+ }));
1755
+ return cells;
1756
+ }, {
1757
+ key: process.env.NODE_ENV === 'production' && 'row.getRightVisibleCells',
1758
+ debug: () => {
1759
+ var _table$options$debugA3;
1760
+ return (_table$options$debugA3 = table.options.debugAll) != null ? _table$options$debugA3 : table.options.debugRows;
1761
+ }
1762
+ })
1763
+ };
1764
+ },
1765
+ createTable: table => {
1766
+ return {
1767
+ setColumnPinning: updater => table.options.onColumnPinningChange == null ? void 0 : table.options.onColumnPinningChange(updater),
1768
+ resetColumnPinning: defaultState => {
1769
+ var _table$initialState$c, _table$initialState;
1770
+ return table.setColumnPinning(defaultState ? getDefaultPinningState() : (_table$initialState$c = (_table$initialState = table.initialState) == null ? void 0 : _table$initialState.columnPinning) != null ? _table$initialState$c : getDefaultPinningState());
1771
+ },
1772
+ getIsSomeColumnsPinned: position => {
1773
+ var _pinningState$positio;
1774
+ const pinningState = table.getState().columnPinning;
1775
+ if (!position) {
1776
+ var _pinningState$left, _pinningState$right;
1777
+ return Boolean(((_pinningState$left = pinningState.left) == null ? void 0 : _pinningState$left.length) || ((_pinningState$right = pinningState.right) == null ? void 0 : _pinningState$right.length));
1778
+ }
1779
+ return Boolean((_pinningState$positio = pinningState[position]) == null ? void 0 : _pinningState$positio.length);
1780
+ },
1781
+ getLeftLeafColumns: memo(() => [table.getAllLeafColumns(), table.getState().columnPinning.left], (allColumns, left) => {
1782
+ return (left != null ? left : []).map(columnId => allColumns.find(column => column.id === columnId)).filter(Boolean);
1783
+ }, {
1784
+ key: process.env.NODE_ENV === 'development' && 'getLeftLeafColumns',
1785
+ debug: () => {
1786
+ var _table$options$debugA4;
1787
+ return (_table$options$debugA4 = table.options.debugAll) != null ? _table$options$debugA4 : table.options.debugColumns;
1788
+ }
1789
+ }),
1790
+ getRightLeafColumns: memo(() => [table.getAllLeafColumns(), table.getState().columnPinning.right], (allColumns, right) => {
1791
+ return (right != null ? right : []).map(columnId => allColumns.find(column => column.id === columnId)).filter(Boolean);
1792
+ }, {
1793
+ key: process.env.NODE_ENV === 'development' && 'getRightLeafColumns',
1794
+ debug: () => {
1795
+ var _table$options$debugA5;
1796
+ return (_table$options$debugA5 = table.options.debugAll) != null ? _table$options$debugA5 : table.options.debugColumns;
1797
+ }
1798
+ }),
1799
+ getCenterLeafColumns: memo(() => [table.getAllLeafColumns(), table.getState().columnPinning.left, table.getState().columnPinning.right], (allColumns, left, right) => {
1800
+ const leftAndRight = [...(left != null ? left : []), ...(right != null ? right : [])];
1801
+ return allColumns.filter(d => !leftAndRight.includes(d.id));
1802
+ }, {
1803
+ key: process.env.NODE_ENV === 'development' && 'getCenterLeafColumns',
1804
+ debug: () => {
1805
+ var _table$options$debugA6;
1806
+ return (_table$options$debugA6 = table.options.debugAll) != null ? _table$options$debugA6 : table.options.debugColumns;
1807
+ }
1808
+ })
1809
+ };
1810
+ }
1811
+ };
1812
+
1813
+ //
1814
+
1815
+ const RowSelection = {
1816
+ getInitialState: state => {
1817
+ return {
1818
+ rowSelection: {},
1819
+ ...state
1820
+ };
1821
+ },
1822
+ getDefaultOptions: table => {
1823
+ return {
1824
+ onRowSelectionChange: makeStateUpdater('rowSelection', table),
1825
+ enableRowSelection: true,
1826
+ enableMultiRowSelection: true,
1827
+ enableSubRowSelection: true
1828
+ // enableGroupingRowSelection: false,
1829
+ // isAdditiveSelectEvent: (e: unknown) => !!e.metaKey,
1830
+ // isInclusiveSelectEvent: (e: unknown) => !!e.shiftKey,
1831
+ };
1832
+ },
1833
+
1834
+ createTable: table => {
1835
+ return {
1836
+ setRowSelection: updater => table.options.onRowSelectionChange == null ? void 0 : table.options.onRowSelectionChange(updater),
1837
+ resetRowSelection: defaultState => {
1838
+ var _table$initialState$r;
1839
+ return table.setRowSelection(defaultState ? {} : (_table$initialState$r = table.initialState.rowSelection) != null ? _table$initialState$r : {});
1840
+ },
1841
+ toggleAllRowsSelected: value => {
1842
+ table.setRowSelection(old => {
1843
+ value = typeof value !== 'undefined' ? value : !table.getIsAllRowsSelected();
1844
+ const rowSelection = {
1845
+ ...old
1846
+ };
1847
+ const preGroupedFlatRows = table.getPreGroupedRowModel().flatRows;
1848
+
1849
+ // We don't use `mutateRowIsSelected` here for performance reasons.
1850
+ // All of the rows are flat already, so it wouldn't be worth it
1851
+ if (value) {
1852
+ preGroupedFlatRows.forEach(row => {
1853
+ if (!row.getCanSelect()) {
1854
+ return;
1855
+ }
1856
+ rowSelection[row.id] = true;
1857
+ });
1858
+ } else {
1859
+ preGroupedFlatRows.forEach(row => {
1860
+ delete rowSelection[row.id];
1861
+ });
1862
+ }
1863
+ return rowSelection;
1864
+ });
1865
+ },
1866
+ toggleAllPageRowsSelected: value => table.setRowSelection(old => {
1867
+ const resolvedValue = typeof value !== 'undefined' ? value : !table.getIsAllPageRowsSelected();
1868
+ const rowSelection = {
1869
+ ...old
1870
+ };
1871
+ table.getRowModel().rows.forEach(row => {
1872
+ mutateRowIsSelected(rowSelection, row.id, resolvedValue, table);
1873
+ });
1874
+ return rowSelection;
1875
+ }),
1876
+ // addRowSelectionRange: rowId => {
1877
+ // const {
1878
+ // rows,
1879
+ // rowsById,
1880
+ // options: { selectGroupingRows, selectSubRows },
1881
+ // } = table
1882
+
1883
+ // const findSelectedRow = (rows: Row[]) => {
1884
+ // let found
1885
+ // rows.find(d => {
1886
+ // if (d.getIsSelected()) {
1887
+ // found = d
1888
+ // return true
1889
+ // }
1890
+ // const subFound = findSelectedRow(d.subRows || [])
1891
+ // if (subFound) {
1892
+ // found = subFound
1893
+ // return true
1894
+ // }
1895
+ // return false
1896
+ // })
1897
+ // return found
1898
+ // }
1899
+
1900
+ // const firstRow = findSelectedRow(rows) || rows[0]
1901
+ // const lastRow = rowsById[rowId]
1902
+
1903
+ // let include = false
1904
+ // const selectedRowIds = {}
1905
+
1906
+ // const addRow = (row: Row) => {
1907
+ // mutateRowIsSelected(selectedRowIds, row.id, true, {
1908
+ // rowsById,
1909
+ // selectGroupingRows: selectGroupingRows!,
1910
+ // selectSubRows: selectSubRows!,
1911
+ // })
1912
+ // }
1913
+
1914
+ // table.rows.forEach(row => {
1915
+ // const isFirstRow = row.id === firstRow.id
1916
+ // const isLastRow = row.id === lastRow.id
1917
+
1918
+ // if (isFirstRow || isLastRow) {
1919
+ // if (!include) {
1920
+ // include = true
1921
+ // } else if (include) {
1922
+ // addRow(row)
1923
+ // include = false
1924
+ // }
1925
+ // }
1926
+
1927
+ // if (include) {
1928
+ // addRow(row)
1929
+ // }
1930
+ // })
1931
+
1932
+ // table.setRowSelection(selectedRowIds)
1933
+ // },
1934
+ getPreSelectedRowModel: () => table.getCoreRowModel(),
1935
+ getSelectedRowModel: memo(() => [table.getState().rowSelection, table.getCoreRowModel()], (rowSelection, rowModel) => {
1936
+ if (!Object.keys(rowSelection).length) {
1937
+ return {
1938
+ rows: [],
1939
+ flatRows: [],
1940
+ rowsById: {}
1941
+ };
1942
+ }
1943
+ return selectRowsFn(table, rowModel);
1944
+ }, {
1945
+ key: process.env.NODE_ENV === 'development' && 'getSelectedRowModel',
1946
+ debug: () => {
1947
+ var _table$options$debugA;
1948
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugTable;
1949
+ }
1950
+ }),
1951
+ getFilteredSelectedRowModel: memo(() => [table.getState().rowSelection, table.getFilteredRowModel()], (rowSelection, rowModel) => {
1952
+ if (!Object.keys(rowSelection).length) {
1953
+ return {
1954
+ rows: [],
1955
+ flatRows: [],
1956
+ rowsById: {}
1957
+ };
1958
+ }
1959
+ return selectRowsFn(table, rowModel);
1960
+ }, {
1961
+ key: process.env.NODE_ENV === 'production' && 'getFilteredSelectedRowModel',
1962
+ debug: () => {
1963
+ var _table$options$debugA2;
1964
+ return (_table$options$debugA2 = table.options.debugAll) != null ? _table$options$debugA2 : table.options.debugTable;
1965
+ }
1966
+ }),
1967
+ getGroupedSelectedRowModel: memo(() => [table.getState().rowSelection, table.getSortedRowModel()], (rowSelection, rowModel) => {
1968
+ if (!Object.keys(rowSelection).length) {
1969
+ return {
1970
+ rows: [],
1971
+ flatRows: [],
1972
+ rowsById: {}
1973
+ };
1974
+ }
1975
+ return selectRowsFn(table, rowModel);
1976
+ }, {
1977
+ key: process.env.NODE_ENV === 'production' && 'getGroupedSelectedRowModel',
1978
+ debug: () => {
1979
+ var _table$options$debugA3;
1980
+ return (_table$options$debugA3 = table.options.debugAll) != null ? _table$options$debugA3 : table.options.debugTable;
1981
+ }
1982
+ }),
1983
+ ///
1984
+
1985
+ // getGroupingRowCanSelect: rowId => {
1986
+ // const row = table.getRow(rowId)
1987
+
1988
+ // if (!row) {
1989
+ // throw new Error()
1990
+ // }
1991
+
1992
+ // if (typeof table.options.enableGroupingRowSelection === 'function') {
1993
+ // return table.options.enableGroupingRowSelection(row)
1994
+ // }
1995
+
1996
+ // return table.options.enableGroupingRowSelection ?? false
1997
+ // },
1998
+
1999
+ getIsAllRowsSelected: () => {
2000
+ const preGroupedFlatRows = table.getFilteredRowModel().flatRows;
2001
+ const {
2002
+ rowSelection
2003
+ } = table.getState();
2004
+ let isAllRowsSelected = Boolean(preGroupedFlatRows.length && Object.keys(rowSelection).length);
2005
+ if (isAllRowsSelected) {
2006
+ if (preGroupedFlatRows.some(row => row.getCanSelect() && !rowSelection[row.id])) {
2007
+ isAllRowsSelected = false;
2008
+ }
2009
+ }
2010
+ return isAllRowsSelected;
2011
+ },
2012
+ getIsAllPageRowsSelected: () => {
2013
+ const paginationFlatRows = table.getPaginationRowModel().flatRows.filter(row => row.getCanSelect());
2014
+ const {
2015
+ rowSelection
2016
+ } = table.getState();
2017
+ let isAllPageRowsSelected = !!paginationFlatRows.length;
2018
+ if (isAllPageRowsSelected && paginationFlatRows.some(row => !rowSelection[row.id])) {
2019
+ isAllPageRowsSelected = false;
2020
+ }
2021
+ return isAllPageRowsSelected;
2022
+ },
2023
+ getIsSomeRowsSelected: () => {
2024
+ var _table$getState$rowSe;
2025
+ const totalSelected = Object.keys((_table$getState$rowSe = table.getState().rowSelection) != null ? _table$getState$rowSe : {}).length;
2026
+ return totalSelected > 0 && totalSelected < table.getFilteredRowModel().flatRows.length;
2027
+ },
2028
+ getIsSomePageRowsSelected: () => {
2029
+ const paginationFlatRows = table.getPaginationRowModel().flatRows;
2030
+ return table.getIsAllPageRowsSelected() ? false : paginationFlatRows.filter(row => row.getCanSelect()).some(d => d.getIsSelected() || d.getIsSomeSelected());
2031
+ },
2032
+ getToggleAllRowsSelectedHandler: () => {
2033
+ return e => {
2034
+ table.toggleAllRowsSelected(e.target.checked);
2035
+ };
2036
+ },
2037
+ getToggleAllPageRowsSelectedHandler: () => {
2038
+ return e => {
2039
+ table.toggleAllPageRowsSelected(e.target.checked);
2040
+ };
2041
+ }
2042
+ };
2043
+ },
2044
+ createRow: (row, table) => {
2045
+ return {
2046
+ toggleSelected: value => {
2047
+ const isSelected = row.getIsSelected();
2048
+ table.setRowSelection(old => {
2049
+ value = typeof value !== 'undefined' ? value : !isSelected;
2050
+ if (isSelected === value) {
2051
+ return old;
2052
+ }
2053
+ const selectedRowIds = {
2054
+ ...old
2055
+ };
2056
+ mutateRowIsSelected(selectedRowIds, row.id, value, table);
2057
+ return selectedRowIds;
2058
+ });
2059
+ },
2060
+ getIsSelected: () => {
2061
+ const {
2062
+ rowSelection
2063
+ } = table.getState();
2064
+ return isRowSelected(row, rowSelection);
2065
+ },
2066
+ getIsSomeSelected: () => {
2067
+ const {
2068
+ rowSelection
2069
+ } = table.getState();
2070
+ return isSubRowSelected(row, rowSelection) === 'some';
2071
+ },
2072
+ getIsAllSubRowsSelected: () => {
2073
+ const {
2074
+ rowSelection
2075
+ } = table.getState();
2076
+ return isSubRowSelected(row, rowSelection) === 'all';
2077
+ },
2078
+ getCanSelect: () => {
2079
+ var _table$options$enable;
2080
+ if (typeof table.options.enableRowSelection === 'function') {
2081
+ return table.options.enableRowSelection(row);
2082
+ }
2083
+ return (_table$options$enable = table.options.enableRowSelection) != null ? _table$options$enable : true;
2084
+ },
2085
+ getCanSelectSubRows: () => {
2086
+ var _table$options$enable2;
2087
+ if (typeof table.options.enableSubRowSelection === 'function') {
2088
+ return table.options.enableSubRowSelection(row);
2089
+ }
2090
+ return (_table$options$enable2 = table.options.enableSubRowSelection) != null ? _table$options$enable2 : true;
2091
+ },
2092
+ getCanMultiSelect: () => {
2093
+ var _table$options$enable3;
2094
+ if (typeof table.options.enableMultiRowSelection === 'function') {
2095
+ return table.options.enableMultiRowSelection(row);
2096
+ }
2097
+ return (_table$options$enable3 = table.options.enableMultiRowSelection) != null ? _table$options$enable3 : true;
2098
+ },
2099
+ getToggleSelectedHandler: () => {
2100
+ const canSelect = row.getCanSelect();
2101
+ return e => {
2102
+ var _target;
2103
+ if (!canSelect) return;
2104
+ row.toggleSelected((_target = e.target) == null ? void 0 : _target.checked);
2105
+ };
2106
+ }
2107
+ };
2108
+ }
2109
+ };
2110
+ const mutateRowIsSelected = (selectedRowIds, id, value, table) => {
2111
+ var _row$subRows;
2112
+ const row = table.getRow(id);
2113
+
2114
+ // const isGrouped = row.getIsGrouped()
2115
+
2116
+ // if ( // TODO: enforce grouping row selection rules
2117
+ // !isGrouped ||
2118
+ // (isGrouped && table.options.enableGroupingRowSelection)
2119
+ // ) {
2120
+ if (value) {
2121
+ if (!row.getCanMultiSelect()) {
2122
+ Object.keys(selectedRowIds).forEach(key => delete selectedRowIds[key]);
2123
+ }
2124
+ if (row.getCanSelect()) {
2125
+ selectedRowIds[id] = true;
2126
+ }
2127
+ } else {
2128
+ delete selectedRowIds[id];
2129
+ }
2130
+ // }
2131
+
2132
+ if ((_row$subRows = row.subRows) != null && _row$subRows.length && row.getCanSelectSubRows()) {
2133
+ row.subRows.forEach(row => mutateRowIsSelected(selectedRowIds, row.id, value, table));
2134
+ }
2135
+ };
2136
+ function selectRowsFn(table, rowModel) {
2137
+ const rowSelection = table.getState().rowSelection;
2138
+ const newSelectedFlatRows = [];
2139
+ const newSelectedRowsById = {};
2140
+
2141
+ // Filters top level and nested rows
2142
+ const recurseRows = function (rows, depth) {
2143
+ return rows.map(row => {
2144
+ var _row$subRows2;
2145
+ const isSelected = isRowSelected(row, rowSelection);
2146
+ if (isSelected) {
2147
+ newSelectedFlatRows.push(row);
2148
+ newSelectedRowsById[row.id] = row;
2149
+ }
2150
+ if ((_row$subRows2 = row.subRows) != null && _row$subRows2.length) {
2151
+ row = {
2152
+ ...row,
2153
+ subRows: recurseRows(row.subRows)
2154
+ };
2155
+ }
2156
+ if (isSelected) {
2157
+ return row;
2158
+ }
2159
+ }).filter(Boolean);
2160
+ };
2161
+ return {
2162
+ rows: recurseRows(rowModel.rows),
2163
+ flatRows: newSelectedFlatRows,
2164
+ rowsById: newSelectedRowsById
2165
+ };
2166
+ }
2167
+ function isRowSelected(row, selection) {
2168
+ var _selection$row$id;
2169
+ return (_selection$row$id = selection[row.id]) != null ? _selection$row$id : false;
2170
+ }
2171
+ function isSubRowSelected(row, selection, table) {
2172
+ if (row.subRows && row.subRows.length) {
2173
+ let allChildrenSelected = true;
2174
+ let someSelected = false;
2175
+ row.subRows.forEach(subRow => {
2176
+ // Bail out early if we know both of these
2177
+ if (someSelected && !allChildrenSelected) {
2178
+ return;
2179
+ }
2180
+ if (isRowSelected(subRow, selection)) {
2181
+ someSelected = true;
2182
+ } else {
2183
+ allChildrenSelected = false;
2184
+ }
2185
+ });
2186
+ return allChildrenSelected ? 'all' : someSelected ? 'some' : false;
2187
+ }
2188
+ return false;
2189
+ }
2190
+
2191
+ const reSplitAlphaNumeric = /([0-9]+)/gm;
2192
+ const alphanumeric = (rowA, rowB, columnId) => {
2193
+ return compareAlphanumeric(toString(rowA.getValue(columnId)).toLowerCase(), toString(rowB.getValue(columnId)).toLowerCase());
2194
+ };
2195
+ const alphanumericCaseSensitive = (rowA, rowB, columnId) => {
2196
+ return compareAlphanumeric(toString(rowA.getValue(columnId)), toString(rowB.getValue(columnId)));
2197
+ };
2198
+
2199
+ // The text filter is more basic (less numeric support)
2200
+ // but is much faster
2201
+ const text = (rowA, rowB, columnId) => {
2202
+ return compareBasic(toString(rowA.getValue(columnId)).toLowerCase(), toString(rowB.getValue(columnId)).toLowerCase());
2203
+ };
2204
+
2205
+ // The text filter is more basic (less numeric support)
2206
+ // but is much faster
2207
+ const textCaseSensitive = (rowA, rowB, columnId) => {
2208
+ return compareBasic(toString(rowA.getValue(columnId)), toString(rowB.getValue(columnId)));
2209
+ };
2210
+ const datetime = (rowA, rowB, columnId) => {
2211
+ const a = rowA.getValue(columnId);
2212
+ const b = rowB.getValue(columnId);
2213
+
2214
+ // Can handle nullish values
2215
+ // Use > and < because == (and ===) doesn't work with
2216
+ // Date objects (would require calling getTime()).
2217
+ return a > b ? 1 : a < b ? -1 : 0;
2218
+ };
2219
+ const basic = (rowA, rowB, columnId) => {
2220
+ return compareBasic(rowA.getValue(columnId), rowB.getValue(columnId));
2221
+ };
2222
+
2223
+ // Utils
2224
+
2225
+ function compareBasic(a, b) {
2226
+ return a === b ? 0 : a > b ? 1 : -1;
2227
+ }
2228
+ function toString(a) {
2229
+ if (typeof a === 'number') {
2230
+ if (isNaN(a) || a === Infinity || a === -Infinity) {
2231
+ return '';
2232
+ }
2233
+ return String(a);
2234
+ }
2235
+ if (typeof a === 'string') {
2236
+ return a;
2237
+ }
2238
+ return '';
2239
+ }
2240
+
2241
+ // Mixed sorting is slow, but very inclusive of many edge cases.
2242
+ // It handles numbers, mixed alphanumeric combinations, and even
2243
+ // null, undefined, and Infinity
2244
+ function compareAlphanumeric(aStr, bStr) {
2245
+ // Split on number groups, but keep the delimiter
2246
+ // Then remove falsey split values
2247
+ const a = aStr.split(reSplitAlphaNumeric).filter(Boolean);
2248
+ const b = bStr.split(reSplitAlphaNumeric).filter(Boolean);
2249
+
2250
+ // While
2251
+ while (a.length && b.length) {
2252
+ const aa = a.shift();
2253
+ const bb = b.shift();
2254
+ const an = parseInt(aa, 10);
2255
+ const bn = parseInt(bb, 10);
2256
+ const combo = [an, bn].sort();
2257
+
2258
+ // Both are string
2259
+ if (isNaN(combo[0])) {
2260
+ if (aa > bb) {
2261
+ return 1;
2262
+ }
2263
+ if (bb > aa) {
2264
+ return -1;
2265
+ }
2266
+ continue;
2267
+ }
2268
+
2269
+ // One is a string, one is a number
2270
+ if (isNaN(combo[1])) {
2271
+ return isNaN(an) ? -1 : 1;
2272
+ }
2273
+
2274
+ // Both are numbers
2275
+ if (an > bn) {
2276
+ return 1;
2277
+ }
2278
+ if (bn > an) {
2279
+ return -1;
2280
+ }
2281
+ }
2282
+ return a.length - b.length;
2283
+ }
2284
+
2285
+ // Exports
2286
+
2287
+ const sortingFns = {
2288
+ alphanumeric,
2289
+ alphanumericCaseSensitive,
2290
+ text,
2291
+ textCaseSensitive,
2292
+ datetime,
2293
+ basic
2294
+ };
2295
+
2296
+ //
2297
+
2298
+ const Sorting = {
2299
+ getInitialState: state => {
2300
+ return {
2301
+ sorting: [],
2302
+ ...state
2303
+ };
2304
+ },
2305
+ getDefaultColumnDef: () => {
2306
+ return {
2307
+ sortingFn: 'auto'
2308
+ };
2309
+ },
2310
+ getDefaultOptions: table => {
2311
+ return {
2312
+ onSortingChange: makeStateUpdater('sorting', table),
2313
+ isMultiSortEvent: e => {
2314
+ return e.shiftKey;
2315
+ }
2316
+ };
2317
+ },
2318
+ createColumn: (column, table) => {
2319
+ return {
2320
+ getAutoSortingFn: () => {
2321
+ const firstRows = table.getFilteredRowModel().flatRows.slice(10);
2322
+ let isString = false;
2323
+ for (const row of firstRows) {
2324
+ const value = row == null ? void 0 : row.getValue(column.id);
2325
+ if (Object.prototype.toString.call(value) === '[object Date]') {
2326
+ return sortingFns.datetime;
2327
+ }
2328
+ if (typeof value === 'string') {
2329
+ isString = true;
2330
+ if (value.split(reSplitAlphaNumeric).length > 1) {
2331
+ return sortingFns.alphanumeric;
2332
+ }
2333
+ }
2334
+ }
2335
+ if (isString) {
2336
+ return sortingFns.text;
2337
+ }
2338
+ return sortingFns.basic;
2339
+ },
2340
+ getAutoSortDir: () => {
2341
+ const firstRow = table.getFilteredRowModel().flatRows[0];
2342
+ const value = firstRow == null ? void 0 : firstRow.getValue(column.id);
2343
+ if (typeof value === 'string') {
2344
+ return 'asc';
2345
+ }
2346
+ return 'desc';
2347
+ },
2348
+ getSortingFn: () => {
2349
+ var _table$options$sortin, _table$options$sortin2;
2350
+ if (!column) {
2351
+ throw new Error();
2352
+ }
2353
+ return isFunction(column.columnDef.sortingFn) ? column.columnDef.sortingFn : column.columnDef.sortingFn === 'auto' ? column.getAutoSortingFn() : (_table$options$sortin = (_table$options$sortin2 = table.options.sortingFns) == null ? void 0 : _table$options$sortin2[column.columnDef.sortingFn]) != null ? _table$options$sortin : sortingFns[column.columnDef.sortingFn];
2354
+ },
2355
+ toggleSorting: (desc, multi) => {
2356
+ // if (column.columns.length) {
2357
+ // column.columns.forEach((c, i) => {
2358
+ // if (c.id) {
2359
+ // table.toggleColumnSorting(c.id, undefined, multi || !!i)
2360
+ // }
2361
+ // })
2362
+ // return
2363
+ // }
2364
+
2365
+ // this needs to be outside of table.setSorting to be in sync with rerender
2366
+ const nextSortingOrder = column.getNextSortingOrder();
2367
+ const hasManualValue = typeof desc !== 'undefined' && desc !== null;
2368
+ table.setSorting(old => {
2369
+ // Find any existing sorting for this column
2370
+ const existingSorting = old == null ? void 0 : old.find(d => d.id === column.id);
2371
+ const existingIndex = old == null ? void 0 : old.findIndex(d => d.id === column.id);
2372
+ let newSorting = [];
2373
+
2374
+ // What should we do with this sort action?
2375
+ let sortAction;
2376
+ let nextDesc = hasManualValue ? desc : nextSortingOrder === 'desc';
2377
+
2378
+ // Multi-mode
2379
+ if (old != null && old.length && column.getCanMultiSort() && multi) {
2380
+ if (existingSorting) {
2381
+ sortAction = 'toggle';
2382
+ } else {
2383
+ sortAction = 'add';
2384
+ }
2385
+ } else {
2386
+ // Normal mode
2387
+ if (old != null && old.length && existingIndex !== old.length - 1) {
2388
+ sortAction = 'replace';
2389
+ } else if (existingSorting) {
2390
+ sortAction = 'toggle';
2391
+ } else {
2392
+ sortAction = 'replace';
2393
+ }
2394
+ }
2395
+
2396
+ // Handle toggle states that will remove the sorting
2397
+ if (sortAction === 'toggle') {
2398
+ // If we are "actually" toggling (not a manual set value), should we remove the sorting?
2399
+ if (!hasManualValue) {
2400
+ // Is our intention to remove?
2401
+ if (!nextSortingOrder) {
2402
+ sortAction = 'remove';
2403
+ }
2404
+ }
2405
+ }
2406
+ if (sortAction === 'add') {
2407
+ var _table$options$maxMul;
2408
+ newSorting = [...old, {
2409
+ id: column.id,
2410
+ desc: nextDesc
2411
+ }];
2412
+ // Take latest n columns
2413
+ newSorting.splice(0, newSorting.length - ((_table$options$maxMul = table.options.maxMultiSortColCount) != null ? _table$options$maxMul : Number.MAX_SAFE_INTEGER));
2414
+ } else if (sortAction === 'toggle') {
2415
+ // This flips (or sets) the
2416
+ newSorting = old.map(d => {
2417
+ if (d.id === column.id) {
2418
+ return {
2419
+ ...d,
2420
+ desc: nextDesc
2421
+ };
2422
+ }
2423
+ return d;
2424
+ });
2425
+ } else if (sortAction === 'remove') {
2426
+ newSorting = old.filter(d => d.id !== column.id);
2427
+ } else {
2428
+ newSorting = [{
2429
+ id: column.id,
2430
+ desc: nextDesc
2431
+ }];
2432
+ }
2433
+ return newSorting;
2434
+ });
2435
+ },
2436
+ getFirstSortDir: () => {
2437
+ var _ref, _column$columnDef$sor;
2438
+ const sortDescFirst = (_ref = (_column$columnDef$sor = column.columnDef.sortDescFirst) != null ? _column$columnDef$sor : table.options.sortDescFirst) != null ? _ref : column.getAutoSortDir() === 'desc';
2439
+ return sortDescFirst ? 'desc' : 'asc';
2440
+ },
2441
+ getNextSortingOrder: multi => {
2442
+ var _table$options$enable, _table$options$enable2;
2443
+ const firstSortDirection = column.getFirstSortDir();
2444
+ const isSorted = column.getIsSorted();
2445
+ if (!isSorted) {
2446
+ return firstSortDirection;
2447
+ }
2448
+ if (isSorted !== firstSortDirection && ((_table$options$enable = table.options.enableSortingRemoval) != null ? _table$options$enable : true) && (
2449
+ // If enableSortRemove, enable in general
2450
+ multi ? (_table$options$enable2 = table.options.enableMultiRemove) != null ? _table$options$enable2 : true : true) // If multi, don't allow if enableMultiRemove))
2451
+ ) {
2452
+ return false;
2453
+ }
2454
+ return isSorted === 'desc' ? 'asc' : 'desc';
2455
+ },
2456
+ getCanSort: () => {
2457
+ var _column$columnDef$ena, _table$options$enable3;
2458
+ return ((_column$columnDef$ena = column.columnDef.enableSorting) != null ? _column$columnDef$ena : true) && ((_table$options$enable3 = table.options.enableSorting) != null ? _table$options$enable3 : true) && !!column.accessorFn;
2459
+ },
2460
+ getCanMultiSort: () => {
2461
+ var _ref2, _column$columnDef$ena2;
2462
+ return (_ref2 = (_column$columnDef$ena2 = column.columnDef.enableMultiSort) != null ? _column$columnDef$ena2 : table.options.enableMultiSort) != null ? _ref2 : !!column.accessorFn;
2463
+ },
2464
+ getIsSorted: () => {
2465
+ var _table$getState$sorti;
2466
+ const columnSort = (_table$getState$sorti = table.getState().sorting) == null ? void 0 : _table$getState$sorti.find(d => d.id === column.id);
2467
+ return !columnSort ? false : columnSort.desc ? 'desc' : 'asc';
2468
+ },
2469
+ getSortIndex: () => {
2470
+ var _table$getState$sorti2, _table$getState$sorti3;
2471
+ return (_table$getState$sorti2 = (_table$getState$sorti3 = table.getState().sorting) == null ? void 0 : _table$getState$sorti3.findIndex(d => d.id === column.id)) != null ? _table$getState$sorti2 : -1;
2472
+ },
2473
+ clearSorting: () => {
2474
+ //clear sorting for just 1 column
2475
+ table.setSorting(old => old != null && old.length ? old.filter(d => d.id !== column.id) : []);
2476
+ },
2477
+ getToggleSortingHandler: () => {
2478
+ const canSort = column.getCanSort();
2479
+ return e => {
2480
+ if (!canSort) return;
2481
+ e.persist == null ? void 0 : e.persist();
2482
+ column.toggleSorting == null ? void 0 : column.toggleSorting(undefined, column.getCanMultiSort() ? table.options.isMultiSortEvent == null ? void 0 : table.options.isMultiSortEvent(e) : false);
2483
+ };
2484
+ }
2485
+ };
2486
+ },
2487
+ createTable: table => {
2488
+ return {
2489
+ setSorting: updater => table.options.onSortingChange == null ? void 0 : table.options.onSortingChange(updater),
2490
+ resetSorting: defaultState => {
2491
+ var _table$initialState$s, _table$initialState;
2492
+ table.setSorting(defaultState ? [] : (_table$initialState$s = (_table$initialState = table.initialState) == null ? void 0 : _table$initialState.sorting) != null ? _table$initialState$s : []);
2493
+ },
2494
+ getPreSortedRowModel: () => table.getGroupedRowModel(),
2495
+ getSortedRowModel: () => {
2496
+ if (!table._getSortedRowModel && table.options.getSortedRowModel) {
2497
+ table._getSortedRowModel = table.options.getSortedRowModel(table);
2498
+ }
2499
+ if (table.options.manualSorting || !table._getSortedRowModel) {
2500
+ return table.getPreSortedRowModel();
2501
+ }
2502
+ return table._getSortedRowModel();
2503
+ }
2504
+ };
2505
+ }
2506
+ };
2507
+
2508
+ //
2509
+
2510
+ const Visibility = {
2511
+ getInitialState: state => {
2512
+ return {
2513
+ columnVisibility: {},
2514
+ ...state
2515
+ };
2516
+ },
2517
+ getDefaultOptions: table => {
2518
+ return {
2519
+ onColumnVisibilityChange: makeStateUpdater('columnVisibility', table)
2520
+ };
2521
+ },
2522
+ createColumn: (column, table) => {
2523
+ return {
2524
+ toggleVisibility: value => {
2525
+ if (column.getCanHide()) {
2526
+ table.setColumnVisibility(old => ({
2527
+ ...old,
2528
+ [column.id]: value != null ? value : !column.getIsVisible()
2529
+ }));
2530
+ }
2531
+ },
2532
+ getIsVisible: () => {
2533
+ var _table$getState$colum, _table$getState$colum2;
2534
+ return (_table$getState$colum = (_table$getState$colum2 = table.getState().columnVisibility) == null ? void 0 : _table$getState$colum2[column.id]) != null ? _table$getState$colum : true;
2535
+ },
2536
+ getCanHide: () => {
2537
+ var _column$columnDef$ena, _table$options$enable;
2538
+ return ((_column$columnDef$ena = column.columnDef.enableHiding) != null ? _column$columnDef$ena : true) && ((_table$options$enable = table.options.enableHiding) != null ? _table$options$enable : true);
2539
+ },
2540
+ getToggleVisibilityHandler: () => {
2541
+ return e => {
2542
+ column.toggleVisibility == null ? void 0 : column.toggleVisibility(e.target.checked);
2543
+ };
2544
+ }
2545
+ };
2546
+ },
2547
+ createRow: (row, table) => {
2548
+ return {
2549
+ _getAllVisibleCells: memo(() => [row.getAllCells(), table.getState().columnVisibility], cells => {
2550
+ return cells.filter(cell => cell.column.getIsVisible());
2551
+ }, {
2552
+ key: process.env.NODE_ENV === 'production' && 'row._getAllVisibleCells',
2553
+ debug: () => {
2554
+ var _table$options$debugA;
2555
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugRows;
2556
+ }
2557
+ }),
2558
+ getVisibleCells: memo(() => [row.getLeftVisibleCells(), row.getCenterVisibleCells(), row.getRightVisibleCells()], (left, center, right) => [...left, ...center, ...right], {
2559
+ key: process.env.NODE_ENV === 'development' && 'row.getVisibleCells',
2560
+ debug: () => {
2561
+ var _table$options$debugA2;
2562
+ return (_table$options$debugA2 = table.options.debugAll) != null ? _table$options$debugA2 : table.options.debugRows;
2563
+ }
2564
+ })
2565
+ };
2566
+ },
2567
+ createTable: table => {
2568
+ const makeVisibleColumnsMethod = (key, getColumns) => {
2569
+ return memo(() => [getColumns(), getColumns().filter(d => d.getIsVisible()).map(d => d.id).join('_')], columns => {
2570
+ return columns.filter(d => d.getIsVisible == null ? void 0 : d.getIsVisible());
2571
+ }, {
2572
+ key,
2573
+ debug: () => {
2574
+ var _table$options$debugA3;
2575
+ return (_table$options$debugA3 = table.options.debugAll) != null ? _table$options$debugA3 : table.options.debugColumns;
2576
+ }
2577
+ });
2578
+ };
2579
+ return {
2580
+ getVisibleFlatColumns: makeVisibleColumnsMethod('getVisibleFlatColumns', () => table.getAllFlatColumns()),
2581
+ getVisibleLeafColumns: makeVisibleColumnsMethod('getVisibleLeafColumns', () => table.getAllLeafColumns()),
2582
+ getLeftVisibleLeafColumns: makeVisibleColumnsMethod('getLeftVisibleLeafColumns', () => table.getLeftLeafColumns()),
2583
+ getRightVisibleLeafColumns: makeVisibleColumnsMethod('getRightVisibleLeafColumns', () => table.getRightLeafColumns()),
2584
+ getCenterVisibleLeafColumns: makeVisibleColumnsMethod('getCenterVisibleLeafColumns', () => table.getCenterLeafColumns()),
2585
+ setColumnVisibility: updater => table.options.onColumnVisibilityChange == null ? void 0 : table.options.onColumnVisibilityChange(updater),
2586
+ resetColumnVisibility: defaultState => {
2587
+ var _table$initialState$c;
2588
+ table.setColumnVisibility(defaultState ? {} : (_table$initialState$c = table.initialState.columnVisibility) != null ? _table$initialState$c : {});
2589
+ },
2590
+ toggleAllColumnsVisible: value => {
2591
+ var _value;
2592
+ value = (_value = value) != null ? _value : !table.getIsAllColumnsVisible();
2593
+ table.setColumnVisibility(table.getAllLeafColumns().reduce((obj, column) => ({
2594
+ ...obj,
2595
+ [column.id]: !value ? !(column.getCanHide != null && column.getCanHide()) : value
2596
+ }), {}));
2597
+ },
2598
+ getIsAllColumnsVisible: () => !table.getAllLeafColumns().some(column => !(column.getIsVisible != null && column.getIsVisible())),
2599
+ getIsSomeColumnsVisible: () => table.getAllLeafColumns().some(column => column.getIsVisible == null ? void 0 : column.getIsVisible()),
2600
+ getToggleAllColumnsVisibilityHandler: () => {
2601
+ return e => {
2602
+ var _target;
2603
+ table.toggleAllColumnsVisible((_target = e.target) == null ? void 0 : _target.checked);
2604
+ };
2605
+ }
2606
+ };
2607
+ }
2608
+ };
2609
+
2610
+ const features = [Headers, Visibility, Ordering, Pinning, Filters, Sorting, Grouping, Expanding, Pagination, RowSelection, ColumnSizing];
2611
+
2612
+ //
2613
+
2614
+ function createTable(options) {
2615
+ var _options$initialState;
2616
+ if (options.debugAll || options.debugTable) {
2617
+ console.info('Creating Table Instance...');
2618
+ }
2619
+ let table = {
2620
+ _features: features
2621
+ };
2622
+ const defaultOptions = table._features.reduce((obj, feature) => {
2623
+ return Object.assign(obj, feature.getDefaultOptions == null ? void 0 : feature.getDefaultOptions(table));
2624
+ }, {});
2625
+ const mergeOptions = options => {
2626
+ if (table.options.mergeOptions) {
2627
+ return table.options.mergeOptions(defaultOptions, options);
2628
+ }
2629
+ return {
2630
+ ...defaultOptions,
2631
+ ...options
2632
+ };
2633
+ };
2634
+ const coreInitialState = {};
2635
+ let initialState = {
2636
+ ...coreInitialState,
2637
+ ...((_options$initialState = options.initialState) != null ? _options$initialState : {})
2638
+ };
2639
+ table._features.forEach(feature => {
2640
+ var _feature$getInitialSt;
2641
+ initialState = (_feature$getInitialSt = feature.getInitialState == null ? void 0 : feature.getInitialState(initialState)) != null ? _feature$getInitialSt : initialState;
2642
+ });
2643
+ const queued = [];
2644
+ let queuedTimeout = false;
2645
+ const coreInstance = {
2646
+ _features: features,
2647
+ options: {
2648
+ ...defaultOptions,
2649
+ ...options
2650
+ },
2651
+ initialState,
2652
+ _queue: cb => {
2653
+ queued.push(cb);
2654
+ if (!queuedTimeout) {
2655
+ queuedTimeout = true;
2656
+
2657
+ // Schedule a microtask to run the queued callbacks after
2658
+ // the current call stack (render, etc) has finished.
2659
+ Promise.resolve().then(() => {
2660
+ while (queued.length) {
2661
+ queued.shift()();
2662
+ }
2663
+ queuedTimeout = false;
2664
+ }).catch(error => setTimeout(() => {
2665
+ throw error;
2666
+ }));
2667
+ }
2668
+ },
2669
+ reset: () => {
2670
+ table.setState(table.initialState);
2671
+ },
2672
+ setOptions: updater => {
2673
+ const newOptions = functionalUpdate(updater, table.options);
2674
+ table.options = mergeOptions(newOptions);
2675
+ },
2676
+ getState: () => {
2677
+ return table.options.state;
2678
+ },
2679
+ setState: updater => {
2680
+ table.options.onStateChange == null ? void 0 : table.options.onStateChange(updater);
2681
+ },
2682
+ _getRowId: (row, index, parent) => {
2683
+ var _table$options$getRow;
2684
+ return (_table$options$getRow = table.options.getRowId == null ? void 0 : table.options.getRowId(row, index, parent)) != null ? _table$options$getRow : `${parent ? [parent.id, index].join('.') : index}`;
2685
+ },
2686
+ getCoreRowModel: () => {
2687
+ if (!table._getCoreRowModel) {
2688
+ table._getCoreRowModel = table.options.getCoreRowModel(table);
2689
+ }
2690
+ return table._getCoreRowModel();
2691
+ },
2692
+ // The final calls start at the bottom of the model,
2693
+ // expanded rows, which then work their way up
2694
+
2695
+ getRowModel: () => {
2696
+ return table.getPaginationRowModel();
2697
+ },
2698
+ getRow: id => {
2699
+ const row = table.getRowModel().rowsById[id];
2700
+ if (!row) {
2701
+ if (process.env.NODE_ENV !== 'production') {
2702
+ throw new Error(`getRow expected an ID, but got ${id}`);
2703
+ }
2704
+ throw new Error();
2705
+ }
2706
+ return row;
2707
+ },
2708
+ _getDefaultColumnDef: memo(() => [table.options.defaultColumn], defaultColumn => {
2709
+ var _defaultColumn;
2710
+ defaultColumn = (_defaultColumn = defaultColumn) != null ? _defaultColumn : {};
2711
+ return {
2712
+ header: props => {
2713
+ const resolvedColumnDef = props.header.column.columnDef;
2714
+ if (resolvedColumnDef.accessorKey) {
2715
+ return resolvedColumnDef.accessorKey;
2716
+ }
2717
+ if (resolvedColumnDef.accessorFn) {
2718
+ return resolvedColumnDef.id;
2719
+ }
2720
+ return null;
2721
+ },
2722
+ // footer: props => props.header.column.id,
2723
+ cell: props => {
2724
+ var _props$renderValue$to, _props$renderValue;
2725
+ return (_props$renderValue$to = (_props$renderValue = props.renderValue()) == null ? void 0 : _props$renderValue.toString == null ? void 0 : _props$renderValue.toString()) != null ? _props$renderValue$to : null;
2726
+ },
2727
+ ...table._features.reduce((obj, feature) => {
2728
+ return Object.assign(obj, feature.getDefaultColumnDef == null ? void 0 : feature.getDefaultColumnDef());
2729
+ }, {}),
2730
+ ...defaultColumn
2731
+ };
2732
+ }, {
2733
+ debug: () => {
2734
+ var _table$options$debugA;
2735
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugColumns;
2736
+ },
2737
+ key: process.env.NODE_ENV === 'development' && 'getDefaultColumnDef'
2738
+ }),
2739
+ _getColumnDefs: () => table.options.columns,
2740
+ getAllColumns: memo(() => [table._getColumnDefs()], columnDefs => {
2741
+ const recurseColumns = function (columnDefs, parent, depth) {
2742
+ if (depth === void 0) {
2743
+ depth = 0;
2744
+ }
2745
+ return columnDefs.map(columnDef => {
2746
+ const column = createColumn(table, columnDef, depth, parent);
2747
+ const groupingColumnDef = columnDef;
2748
+ column.columns = groupingColumnDef.columns ? recurseColumns(groupingColumnDef.columns, column, depth + 1) : [];
2749
+ return column;
2750
+ });
2751
+ };
2752
+ return recurseColumns(columnDefs);
2753
+ }, {
2754
+ key: process.env.NODE_ENV === 'development' && 'getAllColumns',
2755
+ debug: () => {
2756
+ var _table$options$debugA2;
2757
+ return (_table$options$debugA2 = table.options.debugAll) != null ? _table$options$debugA2 : table.options.debugColumns;
2758
+ }
2759
+ }),
2760
+ getAllFlatColumns: memo(() => [table.getAllColumns()], allColumns => {
2761
+ return allColumns.flatMap(column => {
2762
+ return column.getFlatColumns();
2763
+ });
2764
+ }, {
2765
+ key: process.env.NODE_ENV === 'development' && 'getAllFlatColumns',
2766
+ debug: () => {
2767
+ var _table$options$debugA3;
2768
+ return (_table$options$debugA3 = table.options.debugAll) != null ? _table$options$debugA3 : table.options.debugColumns;
2769
+ }
2770
+ }),
2771
+ _getAllFlatColumnsById: memo(() => [table.getAllFlatColumns()], flatColumns => {
2772
+ return flatColumns.reduce((acc, column) => {
2773
+ acc[column.id] = column;
2774
+ return acc;
2775
+ }, {});
2776
+ }, {
2777
+ key: process.env.NODE_ENV === 'development' && 'getAllFlatColumnsById',
2778
+ debug: () => {
2779
+ var _table$options$debugA4;
2780
+ return (_table$options$debugA4 = table.options.debugAll) != null ? _table$options$debugA4 : table.options.debugColumns;
2781
+ }
2782
+ }),
2783
+ getAllLeafColumns: memo(() => [table.getAllColumns(), table._getOrderColumnsFn()], (allColumns, orderColumns) => {
2784
+ let leafColumns = allColumns.flatMap(column => column.getLeafColumns());
2785
+ return orderColumns(leafColumns);
2786
+ }, {
2787
+ key: process.env.NODE_ENV === 'development' && 'getAllLeafColumns',
2788
+ debug: () => {
2789
+ var _table$options$debugA5;
2790
+ return (_table$options$debugA5 = table.options.debugAll) != null ? _table$options$debugA5 : table.options.debugColumns;
2791
+ }
2792
+ }),
2793
+ getColumn: columnId => {
2794
+ const column = table._getAllFlatColumnsById()[columnId];
2795
+ if (process.env.NODE_ENV !== 'production' && !column) {
2796
+ console.error(`[Table] Column with id '${columnId}' does not exist.`);
2797
+ }
2798
+ return column;
2799
+ }
2800
+ };
2801
+ Object.assign(table, coreInstance);
2802
+ table._features.forEach(feature => {
2803
+ return Object.assign(table, feature.createTable == null ? void 0 : feature.createTable(table));
2804
+ });
2805
+ return table;
2806
+ }
2807
+
2808
+ function createCell(table, row, column, columnId) {
2809
+ const getRenderValue = () => {
2810
+ var _cell$getValue;
2811
+ return (_cell$getValue = cell.getValue()) != null ? _cell$getValue : table.options.renderFallbackValue;
2812
+ };
2813
+ const cell = {
2814
+ id: `${row.id}_${column.id}`,
2815
+ row,
2816
+ column,
2817
+ getValue: () => row.getValue(columnId),
2818
+ renderValue: getRenderValue,
2819
+ getContext: memo(() => [table, column, row, cell], (table, column, row, cell) => ({
2820
+ table,
2821
+ column,
2822
+ row,
2823
+ cell: cell,
2824
+ getValue: cell.getValue,
2825
+ renderValue: cell.renderValue
2826
+ }), {
2827
+ key: process.env.NODE_ENV === 'development' && 'cell.getContext',
2828
+ debug: () => table.options.debugAll
2829
+ })
2830
+ };
2831
+ table._features.forEach(feature => {
2832
+ Object.assign(cell, feature.createCell == null ? void 0 : feature.createCell(cell, column, row, table));
2833
+ }, {});
2834
+ return cell;
2835
+ }
2836
+
2837
+ const createRow = (table, id, original, rowIndex, depth, subRows, parentId) => {
2838
+ let row = {
2839
+ id,
2840
+ index: rowIndex,
2841
+ original,
2842
+ depth,
2843
+ parentId,
2844
+ _valuesCache: {},
2845
+ _uniqueValuesCache: {},
2846
+ getValue: columnId => {
2847
+ if (row._valuesCache.hasOwnProperty(columnId)) {
2848
+ return row._valuesCache[columnId];
2849
+ }
2850
+ const column = table.getColumn(columnId);
2851
+ if (!(column != null && column.accessorFn)) {
2852
+ return undefined;
2853
+ }
2854
+ row._valuesCache[columnId] = column.accessorFn(row.original, rowIndex);
2855
+ return row._valuesCache[columnId];
2856
+ },
2857
+ getUniqueValues: columnId => {
2858
+ if (row._uniqueValuesCache.hasOwnProperty(columnId)) {
2859
+ return row._uniqueValuesCache[columnId];
2860
+ }
2861
+ const column = table.getColumn(columnId);
2862
+ if (!(column != null && column.accessorFn)) {
2863
+ return undefined;
2864
+ }
2865
+ if (!column.columnDef.getUniqueValues) {
2866
+ row._uniqueValuesCache[columnId] = [row.getValue(columnId)];
2867
+ return row._uniqueValuesCache[columnId];
2868
+ }
2869
+ row._uniqueValuesCache[columnId] = column.columnDef.getUniqueValues(row.original, rowIndex);
2870
+ return row._uniqueValuesCache[columnId];
2871
+ },
2872
+ renderValue: columnId => {
2873
+ var _row$getValue;
2874
+ return (_row$getValue = row.getValue(columnId)) != null ? _row$getValue : table.options.renderFallbackValue;
2875
+ },
2876
+ subRows: subRows != null ? subRows : [],
2877
+ getLeafRows: () => flattenBy(row.subRows, d => d.subRows),
2878
+ getParentRow: () => row.parentId ? table.getRow(row.parentId) : undefined,
2879
+ getParentRows: () => {
2880
+ let parentRows = [];
2881
+ let currentRow = row;
2882
+ while (true) {
2883
+ const parentRow = currentRow.getParentRow();
2884
+ if (!parentRow) break;
2885
+ parentRows.push(parentRow);
2886
+ currentRow = parentRow;
2887
+ }
2888
+ return parentRows.reverse();
2889
+ },
2890
+ getAllCells: memo(() => [table.getAllLeafColumns()], leafColumns => {
2891
+ return leafColumns.map(column => {
2892
+ return createCell(table, row, column, column.id);
2893
+ });
2894
+ }, {
2895
+ key: process.env.NODE_ENV === 'development' && 'row.getAllCells',
2896
+ debug: () => {
2897
+ var _table$options$debugA;
2898
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugRows;
2899
+ }
2900
+ }),
2901
+ _getAllCellsByColumnId: memo(() => [row.getAllCells()], allCells => {
2902
+ return allCells.reduce((acc, cell) => {
2903
+ acc[cell.column.id] = cell;
2904
+ return acc;
2905
+ }, {});
2906
+ }, {
2907
+ key: process.env.NODE_ENV === 'production' && 'row.getAllCellsByColumnId',
2908
+ debug: () => {
2909
+ var _table$options$debugA2;
2910
+ return (_table$options$debugA2 = table.options.debugAll) != null ? _table$options$debugA2 : table.options.debugRows;
2911
+ }
2912
+ })
2913
+ };
2914
+ for (let i = 0; i < table._features.length; i++) {
2915
+ const feature = table._features[i];
2916
+ Object.assign(row, feature == null ? void 0 : feature.createRow == null ? void 0 : feature.createRow(row, table));
2917
+ }
2918
+ return row;
2919
+ };
2920
+
2921
+ function getCoreRowModel() {
2922
+ return table => memo(() => [table.options.data], data => {
2923
+ const rowModel = {
2924
+ rows: [],
2925
+ flatRows: [],
2926
+ rowsById: {}
2927
+ };
2928
+ const accessRows = function (originalRows, depth, parentRow) {
2929
+ if (depth === void 0) {
2930
+ depth = 0;
2931
+ }
2932
+ const rows = [];
2933
+ for (let i = 0; i < originalRows.length; i++) {
2934
+ // This could be an expensive check at scale, so we should move it somewhere else, but where?
2935
+ // if (!id) {
2936
+ // if (process.env.NODE_ENV !== 'production') {
2937
+ // throw new Error(`getRowId expected an ID, but got ${id}`)
2938
+ // }
2939
+ // }
2940
+
2941
+ // Make the row
2942
+ const row = createRow(table, table._getRowId(originalRows[i], i, parentRow), originalRows[i], i, depth, undefined, parentRow == null ? void 0 : parentRow.id);
2943
+
2944
+ // Keep track of every row in a flat array
2945
+ rowModel.flatRows.push(row);
2946
+ // Also keep track of every row by its ID
2947
+ rowModel.rowsById[row.id] = row;
2948
+ // Push table row into parent
2949
+ rows.push(row);
2950
+
2951
+ // Get the original subrows
2952
+ if (table.options.getSubRows) {
2953
+ var _row$originalSubRows;
2954
+ row.originalSubRows = table.options.getSubRows(originalRows[i], i);
2955
+
2956
+ // Then recursively access them
2957
+ if ((_row$originalSubRows = row.originalSubRows) != null && _row$originalSubRows.length) {
2958
+ row.subRows = accessRows(row.originalSubRows, depth + 1, row);
2959
+ }
2960
+ }
2961
+ }
2962
+ return rows;
2963
+ };
2964
+ rowModel.rows = accessRows(data);
2965
+ return rowModel;
2966
+ }, {
2967
+ key: process.env.NODE_ENV === 'development' && 'getRowModel',
2968
+ debug: () => {
2969
+ var _table$options$debugA;
2970
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugTable;
2971
+ },
2972
+ onChange: () => {
2973
+ table._autoResetPageIndex();
2974
+ }
2975
+ });
2976
+ }
2977
+
2978
+ function filterRows(rows, filterRowImpl, table) {
2979
+ if (table.options.filterFromLeafRows) {
2980
+ return filterRowModelFromLeafs(rows, filterRowImpl, table);
2981
+ }
2982
+ return filterRowModelFromRoot(rows, filterRowImpl, table);
2983
+ }
2984
+ function filterRowModelFromLeafs(rowsToFilter, filterRow, table) {
2985
+ var _table$options$maxLea;
2986
+ const newFilteredFlatRows = [];
2987
+ const newFilteredRowsById = {};
2988
+ const maxDepth = (_table$options$maxLea = table.options.maxLeafRowFilterDepth) != null ? _table$options$maxLea : 100;
2989
+ const recurseFilterRows = function (rowsToFilter, depth) {
2990
+ if (depth === void 0) {
2991
+ depth = 0;
2992
+ }
2993
+ const rows = [];
2994
+
2995
+ // Filter from children up first
2996
+ for (let i = 0; i < rowsToFilter.length; i++) {
2997
+ var _row$subRows;
2998
+ let row = rowsToFilter[i];
2999
+ const newRow = createRow(table, row.id, row.original, row.index, row.depth, undefined, row.parentId);
3000
+ newRow.columnFilters = row.columnFilters;
3001
+ if ((_row$subRows = row.subRows) != null && _row$subRows.length && depth < maxDepth) {
3002
+ newRow.subRows = recurseFilterRows(row.subRows, depth + 1);
3003
+ row = newRow;
3004
+ if (filterRow(row) && !newRow.subRows.length) {
3005
+ rows.push(row);
3006
+ newFilteredRowsById[row.id] = row;
3007
+ newFilteredRowsById[i] = row;
3008
+ continue;
3009
+ }
3010
+ if (filterRow(row) || newRow.subRows.length) {
3011
+ rows.push(row);
3012
+ newFilteredRowsById[row.id] = row;
3013
+ newFilteredRowsById[i] = row;
3014
+ continue;
3015
+ }
3016
+ } else {
3017
+ row = newRow;
3018
+ if (filterRow(row)) {
3019
+ rows.push(row);
3020
+ newFilteredRowsById[row.id] = row;
3021
+ newFilteredRowsById[i] = row;
3022
+ }
3023
+ }
3024
+ }
3025
+ return rows;
3026
+ };
3027
+ return {
3028
+ rows: recurseFilterRows(rowsToFilter),
3029
+ flatRows: newFilteredFlatRows,
3030
+ rowsById: newFilteredRowsById
3031
+ };
3032
+ }
3033
+ function filterRowModelFromRoot(rowsToFilter, filterRow, table) {
3034
+ var _table$options$maxLea2;
3035
+ const newFilteredFlatRows = [];
3036
+ const newFilteredRowsById = {};
3037
+ const maxDepth = (_table$options$maxLea2 = table.options.maxLeafRowFilterDepth) != null ? _table$options$maxLea2 : 100;
3038
+
3039
+ // Filters top level and nested rows
3040
+ const recurseFilterRows = function (rowsToFilter, depth) {
3041
+ if (depth === void 0) {
3042
+ depth = 0;
3043
+ }
3044
+ // Filter from parents downward first
3045
+
3046
+ const rows = [];
3047
+
3048
+ // Apply the filter to any subRows
3049
+ for (let i = 0; i < rowsToFilter.length; i++) {
3050
+ let row = rowsToFilter[i];
3051
+ const pass = filterRow(row);
3052
+ if (pass) {
3053
+ var _row$subRows2;
3054
+ if ((_row$subRows2 = row.subRows) != null && _row$subRows2.length && depth < maxDepth) {
3055
+ const newRow = createRow(table, row.id, row.original, row.index, row.depth, undefined, row.parentId);
3056
+ newRow.subRows = recurseFilterRows(row.subRows, depth + 1);
3057
+ row = newRow;
3058
+ }
3059
+ rows.push(row);
3060
+ newFilteredFlatRows.push(row);
3061
+ newFilteredRowsById[row.id] = row;
3062
+ }
3063
+ }
3064
+ return rows;
3065
+ };
3066
+ return {
3067
+ rows: recurseFilterRows(rowsToFilter),
3068
+ flatRows: newFilteredFlatRows,
3069
+ rowsById: newFilteredRowsById
3070
+ };
3071
+ }
3072
+
3073
+ function getFilteredRowModel() {
3074
+ return table => memo(() => [table.getPreFilteredRowModel(), table.getState().columnFilters, table.getState().globalFilter], (rowModel, columnFilters, globalFilter) => {
3075
+ if (!rowModel.rows.length || !(columnFilters != null && columnFilters.length) && !globalFilter) {
3076
+ for (let i = 0; i < rowModel.flatRows.length; i++) {
3077
+ rowModel.flatRows[i].columnFilters = {};
3078
+ rowModel.flatRows[i].columnFiltersMeta = {};
3079
+ }
3080
+ return rowModel;
3081
+ }
3082
+ const resolvedColumnFilters = [];
3083
+ const resolvedGlobalFilters = [];
3084
+ (columnFilters != null ? columnFilters : []).forEach(d => {
3085
+ var _filterFn$resolveFilt;
3086
+ const column = table.getColumn(d.id);
3087
+ if (!column) {
3088
+ return;
3089
+ }
3090
+ const filterFn = column.getFilterFn();
3091
+ if (!filterFn) {
3092
+ if (process.env.NODE_ENV !== 'production') {
3093
+ console.warn(`Could not find a valid 'column.filterFn' for column with the ID: ${column.id}.`);
3094
+ }
3095
+ return;
3096
+ }
3097
+ resolvedColumnFilters.push({
3098
+ id: d.id,
3099
+ filterFn,
3100
+ resolvedValue: (_filterFn$resolveFilt = filterFn.resolveFilterValue == null ? void 0 : filterFn.resolveFilterValue(d.value)) != null ? _filterFn$resolveFilt : d.value
3101
+ });
3102
+ });
3103
+ const filterableIds = columnFilters.map(d => d.id);
3104
+ const globalFilterFn = table.getGlobalFilterFn();
3105
+ const globallyFilterableColumns = table.getAllLeafColumns().filter(column => column.getCanGlobalFilter());
3106
+ if (globalFilter && globalFilterFn && globallyFilterableColumns.length) {
3107
+ filterableIds.push('__global__');
3108
+ globallyFilterableColumns.forEach(column => {
3109
+ var _globalFilterFn$resol;
3110
+ resolvedGlobalFilters.push({
3111
+ id: column.id,
3112
+ filterFn: globalFilterFn,
3113
+ resolvedValue: (_globalFilterFn$resol = globalFilterFn.resolveFilterValue == null ? void 0 : globalFilterFn.resolveFilterValue(globalFilter)) != null ? _globalFilterFn$resol : globalFilter
3114
+ });
3115
+ });
3116
+ }
3117
+ let currentColumnFilter;
3118
+ let currentGlobalFilter;
3119
+
3120
+ // Flag the prefiltered row model with each filter state
3121
+ for (let j = 0; j < rowModel.flatRows.length; j++) {
3122
+ const row = rowModel.flatRows[j];
3123
+ row.columnFilters = {};
3124
+ if (resolvedColumnFilters.length) {
3125
+ for (let i = 0; i < resolvedColumnFilters.length; i++) {
3126
+ currentColumnFilter = resolvedColumnFilters[i];
3127
+ const id = currentColumnFilter.id;
3128
+
3129
+ // Tag the row with the column filter state
3130
+ row.columnFilters[id] = currentColumnFilter.filterFn(row, id, currentColumnFilter.resolvedValue, filterMeta => {
3131
+ row.columnFiltersMeta[id] = filterMeta;
3132
+ });
3133
+ }
3134
+ }
3135
+ if (resolvedGlobalFilters.length) {
3136
+ for (let i = 0; i < resolvedGlobalFilters.length; i++) {
3137
+ currentGlobalFilter = resolvedGlobalFilters[i];
3138
+ const id = currentGlobalFilter.id;
3139
+ // Tag the row with the first truthy global filter state
3140
+ if (currentGlobalFilter.filterFn(row, id, currentGlobalFilter.resolvedValue, filterMeta => {
3141
+ row.columnFiltersMeta[id] = filterMeta;
3142
+ })) {
3143
+ row.columnFilters.__global__ = true;
3144
+ break;
3145
+ }
3146
+ }
3147
+ if (row.columnFilters.__global__ !== true) {
3148
+ row.columnFilters.__global__ = false;
3149
+ }
3150
+ }
3151
+ }
3152
+ const filterRowsImpl = row => {
3153
+ // Horizontally filter rows through each column
3154
+ for (let i = 0; i < filterableIds.length; i++) {
3155
+ if (row.columnFilters[filterableIds[i]] === false) {
3156
+ return false;
3157
+ }
3158
+ }
3159
+ return true;
3160
+ };
3161
+
3162
+ // Filter final rows using all of the active filters
3163
+ return filterRows(rowModel.rows, filterRowsImpl, table);
3164
+ }, {
3165
+ key: process.env.NODE_ENV === 'development' && 'getFilteredRowModel',
3166
+ debug: () => {
3167
+ var _table$options$debugA;
3168
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugTable;
3169
+ },
3170
+ onChange: () => {
3171
+ table._autoResetPageIndex();
3172
+ }
3173
+ });
3174
+ }
3175
+
3176
+ function getSortedRowModel() {
3177
+ return table => memo(() => [table.getState().sorting, table.getPreSortedRowModel()], (sorting, rowModel) => {
3178
+ if (!rowModel.rows.length || !(sorting != null && sorting.length)) {
3179
+ return rowModel;
3180
+ }
3181
+ const sortingState = table.getState().sorting;
3182
+ const sortedFlatRows = [];
3183
+
3184
+ // Filter out sortings that correspond to non existing columns
3185
+ const availableSorting = sortingState.filter(sort => {
3186
+ var _table$getColumn;
3187
+ return (_table$getColumn = table.getColumn(sort.id)) == null ? void 0 : _table$getColumn.getCanSort();
3188
+ });
3189
+ const columnInfoById = {};
3190
+ availableSorting.forEach(sortEntry => {
3191
+ const column = table.getColumn(sortEntry.id);
3192
+ if (!column) return;
3193
+ columnInfoById[sortEntry.id] = {
3194
+ sortUndefined: column.columnDef.sortUndefined,
3195
+ invertSorting: column.columnDef.invertSorting,
3196
+ sortingFn: column.getSortingFn()
3197
+ };
3198
+ });
3199
+ const sortData = rows => {
3200
+ // This will also perform a stable sorting using the row index
3201
+ // if needed.
3202
+ const sortedData = [...rows];
3203
+ sortedData.sort((rowA, rowB) => {
3204
+ for (let i = 0; i < availableSorting.length; i += 1) {
3205
+ var _sortEntry$desc;
3206
+ const sortEntry = availableSorting[i];
3207
+ const columnInfo = columnInfoById[sortEntry.id];
3208
+ const isDesc = (_sortEntry$desc = sortEntry == null ? void 0 : sortEntry.desc) != null ? _sortEntry$desc : false;
3209
+ if (columnInfo.sortUndefined) {
3210
+ const aValue = rowA.getValue(sortEntry.id);
3211
+ const bValue = rowB.getValue(sortEntry.id);
3212
+ const aUndefined = typeof aValue === 'undefined';
3213
+ const bUndefined = typeof bValue === 'undefined';
3214
+ if (aUndefined || bUndefined) {
3215
+ let undefinedSort = aUndefined && bUndefined ? 0 : aUndefined ? columnInfo.sortUndefined : -columnInfo.sortUndefined;
3216
+ if (isDesc && undefinedSort !== 0) {
3217
+ undefinedSort *= -1;
3218
+ }
3219
+ return undefinedSort;
3220
+ }
3221
+ }
3222
+
3223
+ // This function should always return in ascending order
3224
+ let sortInt = columnInfo.sortingFn(rowA, rowB, sortEntry.id);
3225
+ if (sortInt !== 0) {
3226
+ if (isDesc) {
3227
+ sortInt *= -1;
3228
+ }
3229
+ if (columnInfo.invertSorting) {
3230
+ sortInt *= -1;
3231
+ }
3232
+ return sortInt;
3233
+ }
3234
+ }
3235
+ return rowA.index - rowB.index;
3236
+ });
3237
+
3238
+ // If there are sub-rows, sort them
3239
+ sortedData.forEach(row => {
3240
+ var _row$subRows;
3241
+ sortedFlatRows.push(row);
3242
+ if ((_row$subRows = row.subRows) != null && _row$subRows.length) {
3243
+ row.subRows = sortData(row.subRows);
3244
+ }
3245
+ });
3246
+ return sortedData;
3247
+ };
3248
+ return {
3249
+ rows: sortData(rowModel.rows),
3250
+ flatRows: sortedFlatRows,
3251
+ rowsById: rowModel.rowsById
3252
+ };
3253
+ }, {
3254
+ key: process.env.NODE_ENV === 'development' && 'getSortedRowModel',
3255
+ debug: () => {
3256
+ var _table$options$debugA;
3257
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugTable;
3258
+ },
3259
+ onChange: () => {
3260
+ table._autoResetPageIndex();
3261
+ }
3262
+ });
3263
+ }
3264
+
3265
+ function getExpandedRowModel() {
3266
+ return table => memo(() => [table.getState().expanded, table.getPreExpandedRowModel(), table.options.paginateExpandedRows], (expanded, rowModel, paginateExpandedRows) => {
3267
+ if (!rowModel.rows.length || expanded !== true && !Object.keys(expanded != null ? expanded : {}).length) {
3268
+ return rowModel;
3269
+ }
3270
+ if (!paginateExpandedRows) {
3271
+ // Only expand rows at this point if they are being paginated
3272
+ return rowModel;
3273
+ }
3274
+ return expandRows(rowModel);
3275
+ }, {
3276
+ key: process.env.NODE_ENV === 'development' && 'getExpandedRowModel',
3277
+ debug: () => {
3278
+ var _table$options$debugA;
3279
+ return (_table$options$debugA = table.options.debugAll) != null ? _table$options$debugA : table.options.debugTable;
3280
+ }
3281
+ });
3282
+ }
3283
+ function expandRows(rowModel) {
3284
+ const expandedRows = [];
3285
+ const handleRow = row => {
3286
+ var _row$subRows;
3287
+ expandedRows.push(row);
3288
+ if ((_row$subRows = row.subRows) != null && _row$subRows.length && row.getIsExpanded()) {
3289
+ row.subRows.forEach(handleRow);
3290
+ }
3291
+ };
3292
+ rowModel.rows.forEach(handleRow);
3293
+ return {
3294
+ rows: expandedRows,
3295
+ flatRows: rowModel.flatRows,
3296
+ rowsById: rowModel.rowsById
3297
+ };
3298
+ }
3299
+
3300
+ exports.ColumnSizing = ColumnSizing;
3301
+ exports.Expanding = Expanding;
3302
+ exports.Filters = Filters;
3303
+ exports.Grouping = Grouping;
3304
+ exports.Headers = Headers;
3305
+ exports.Ordering = Ordering;
3306
+ exports.Pagination = Pagination;
3307
+ exports.Pinning = Pinning;
3308
+ exports.RowSelection = RowSelection;
3309
+ exports.Sorting = Sorting;
3310
+ exports.Visibility = Visibility;
3311
+ exports.aggregationFns = aggregationFns;
3312
+ exports.buildHeaderGroups = buildHeaderGroups;
3313
+ exports.createCell = createCell;
3314
+ exports.createColumn = createColumn;
3315
+ exports.createRow = createRow;
3316
+ exports.createTable = createTable;
3317
+ exports.defaultColumnSizing = defaultColumnSizing;
3318
+ exports.expandRows = expandRows;
3319
+ exports.filterFns = filterFns;
3320
+ exports.flattenBy = flattenBy;
3321
+ exports.functionalUpdate = functionalUpdate;
3322
+ exports.getCoreRowModel = getCoreRowModel;
3323
+ exports.getExpandedRowModel = getExpandedRowModel;
3324
+ exports.getFilteredRowModel = getFilteredRowModel;
3325
+ exports.getSortedRowModel = getSortedRowModel;
3326
+ exports.isFunction = isFunction;
3327
+ exports.isNumberArray = isNumberArray;
3328
+ exports.isRowSelected = isRowSelected;
3329
+ exports.isSubRowSelected = isSubRowSelected;
3330
+ exports.makeStateUpdater = makeStateUpdater;
3331
+ exports.memo = memo;
3332
+ exports.orderColumns = orderColumns;
3333
+ exports.passiveEventSupported = passiveEventSupported;
3334
+ exports.reSplitAlphaNumeric = reSplitAlphaNumeric;
3335
+ exports.selectRowsFn = selectRowsFn;
3336
+ exports.shouldAutoRemoveFilter = shouldAutoRemoveFilter;
3337
+ exports.sortingFns = sortingFns;
3338
+ //# sourceMappingURL=index.cjs.map