@tanstack/table-core 8.19.2 → 9.0.0-alpha.10

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 (302) hide show
  1. package/dist/cjs/aggregationFns.cjs +94 -0
  2. package/dist/cjs/aggregationFns.cjs.map +1 -0
  3. package/dist/cjs/aggregationFns.d.cts +14 -0
  4. package/dist/cjs/columnHelper.cjs +19 -0
  5. package/dist/cjs/columnHelper.cjs.map +1 -0
  6. package/dist/cjs/columnHelper.d.cts +9 -0
  7. package/dist/cjs/core/cell.cjs +38 -0
  8. package/dist/cjs/core/cell.cjs.map +1 -0
  9. package/dist/cjs/core/cell.d.cts +50 -0
  10. package/dist/cjs/core/column.cjs +81 -0
  11. package/dist/cjs/core/column.cjs.map +1 -0
  12. package/dist/cjs/core/column.d.cts +56 -0
  13. package/dist/cjs/core/headers.cjs +310 -0
  14. package/dist/cjs/core/headers.cjs.map +1 -0
  15. package/dist/cjs/core/headers.d.cts +195 -0
  16. package/dist/cjs/core/row.cjs +92 -0
  17. package/dist/cjs/core/row.cjs.map +1 -0
  18. package/dist/cjs/core/row.d.cts +92 -0
  19. package/dist/cjs/core/table.cjs +232 -0
  20. package/dist/cjs/core/table.cjs.map +1 -0
  21. package/dist/cjs/core/table.d.cts +229 -0
  22. package/dist/cjs/features/ColumnFaceting.cjs +29 -0
  23. package/dist/cjs/features/ColumnFaceting.cjs.map +1 -0
  24. package/dist/cjs/features/ColumnFaceting.d.cts +35 -0
  25. package/dist/cjs/features/ColumnFiltering.cjs +137 -0
  26. package/dist/cjs/features/ColumnFiltering.cjs.map +1 -0
  27. package/dist/cjs/features/ColumnFiltering.d.cts +195 -0
  28. package/dist/cjs/features/ColumnGrouping.cjs +133 -0
  29. package/dist/cjs/features/ColumnGrouping.cjs.map +1 -0
  30. package/dist/cjs/features/ColumnGrouping.d.cts +202 -0
  31. package/dist/cjs/features/ColumnOrdering.cjs +76 -0
  32. package/dist/cjs/features/ColumnOrdering.cjs.map +1 -0
  33. package/dist/cjs/features/ColumnOrdering.d.cts +54 -0
  34. package/dist/cjs/features/ColumnPinning.cjs +145 -0
  35. package/dist/cjs/features/ColumnPinning.cjs.map +1 -0
  36. package/dist/cjs/features/ColumnPinning.d.cts +127 -0
  37. package/dist/cjs/features/ColumnSizing.cjs +307 -0
  38. package/dist/cjs/features/ColumnSizing.cjs.map +1 -0
  39. package/dist/cjs/features/ColumnSizing.d.cts +194 -0
  40. package/dist/cjs/features/ColumnVisibility.cjs +144 -0
  41. package/dist/cjs/features/ColumnVisibility.cjs.map +1 -0
  42. package/dist/cjs/features/ColumnVisibility.d.cts +130 -0
  43. package/dist/cjs/features/GlobalFaceting.cjs +29 -0
  44. package/dist/cjs/features/GlobalFaceting.cjs.map +1 -0
  45. package/dist/cjs/features/GlobalFaceting.d.cts +27 -0
  46. package/dist/cjs/features/GlobalFiltering.cjs +50 -0
  47. package/dist/cjs/features/GlobalFiltering.cjs.map +1 -0
  48. package/dist/cjs/features/GlobalFiltering.d.cts +80 -0
  49. package/dist/cjs/features/RowExpanding.cjs +152 -0
  50. package/dist/cjs/features/RowExpanding.cjs.map +1 -0
  51. package/dist/cjs/features/RowExpanding.d.cts +155 -0
  52. package/dist/cjs/features/RowPagination.cjs +161 -0
  53. package/dist/cjs/features/RowPagination.cjs.map +1 -0
  54. package/dist/cjs/features/RowPagination.d.cts +166 -0
  55. package/dist/cjs/features/RowPinning.cjs +132 -0
  56. package/dist/cjs/features/RowPinning.cjs.map +1 -0
  57. package/dist/cjs/features/RowPinning.d.cts +99 -0
  58. package/dist/cjs/features/RowSelection.cjs +296 -0
  59. package/dist/cjs/features/RowSelection.cjs.map +1 -0
  60. package/dist/cjs/features/RowSelection.d.cts +177 -0
  61. package/dist/cjs/features/RowSorting.cjs +200 -0
  62. package/dist/cjs/features/RowSorting.cjs.map +1 -0
  63. package/dist/cjs/features/RowSorting.d.cts +238 -0
  64. package/dist/cjs/filterFns.cjs +88 -0
  65. package/dist/cjs/filterFns.cjs.map +1 -0
  66. package/dist/cjs/filterFns.d.cts +14 -0
  67. package/{build/lib/index.js → dist/cjs/index.cjs} +41 -53
  68. package/dist/cjs/index.cjs.map +1 -0
  69. package/dist/cjs/index.d.cts +34 -0
  70. package/{build/lib/sortingFns.js → dist/cjs/sortingFns.cjs} +23 -52
  71. package/dist/cjs/sortingFns.cjs.map +1 -0
  72. package/dist/cjs/sortingFns.d.cts +12 -0
  73. package/dist/cjs/types.d.cts +120 -0
  74. package/{build/lib/utils/filterRowsUtils.js → dist/cjs/utils/filterRowsUtils.cjs} +34 -46
  75. package/dist/cjs/utils/filterRowsUtils.cjs.map +1 -0
  76. package/dist/cjs/utils/filterRowsUtils.d.cts +3 -0
  77. package/dist/cjs/utils/getCoreRowModel.cjs +54 -0
  78. package/dist/cjs/utils/getCoreRowModel.cjs.map +1 -0
  79. package/dist/cjs/utils/getCoreRowModel.d.cts +3 -0
  80. package/dist/cjs/utils/getExpandedRowModel.cjs +41 -0
  81. package/dist/cjs/utils/getExpandedRowModel.cjs.map +1 -0
  82. package/dist/cjs/utils/getExpandedRowModel.d.cts +8 -0
  83. package/dist/cjs/utils/getFacetedMinMaxValues.cjs +35 -0
  84. package/dist/cjs/utils/getFacetedMinMaxValues.cjs.map +1 -0
  85. package/dist/cjs/utils/getFacetedMinMaxValues.d.cts +3 -0
  86. package/dist/cjs/utils/getFacetedRowModel.cjs +35 -0
  87. package/dist/cjs/utils/getFacetedRowModel.cjs.map +1 -0
  88. package/dist/cjs/utils/getFacetedRowModel.d.cts +3 -0
  89. package/dist/cjs/utils/getFacetedUniqueValues.cjs +37 -0
  90. package/dist/cjs/utils/getFacetedUniqueValues.cjs.map +1 -0
  91. package/dist/cjs/utils/getFacetedUniqueValues.d.cts +3 -0
  92. package/dist/cjs/utils/getFilteredRowModel.cjs +116 -0
  93. package/dist/cjs/utils/getFilteredRowModel.cjs.map +1 -0
  94. package/dist/cjs/utils/getFilteredRowModel.d.cts +3 -0
  95. package/dist/cjs/utils/getGroupedRowModel.cjs +118 -0
  96. package/dist/cjs/utils/getGroupedRowModel.cjs.map +1 -0
  97. package/dist/cjs/utils/getGroupedRowModel.d.cts +3 -0
  98. package/dist/cjs/utils/getPaginationRowModel.cjs +49 -0
  99. package/dist/cjs/utils/getPaginationRowModel.cjs.map +1 -0
  100. package/dist/cjs/utils/getPaginationRowModel.d.cts +5 -0
  101. package/dist/cjs/utils/getSortedRowModel.cjs +88 -0
  102. package/dist/cjs/utils/getSortedRowModel.cjs.map +1 -0
  103. package/dist/cjs/utils/getSortedRowModel.d.cts +3 -0
  104. package/{build/lib/utils.js → dist/cjs/utils.cjs} +26 -39
  105. package/dist/cjs/utils.cjs.map +1 -0
  106. package/dist/cjs/utils.d.cts +39 -0
  107. package/{build/lib → dist/esm}/aggregationFns.d.ts +2 -1
  108. package/dist/esm/aggregationFns.js +94 -0
  109. package/dist/esm/aggregationFns.js.map +1 -0
  110. package/{build/lib → dist/esm}/columnHelper.d.ts +3 -2
  111. package/dist/esm/columnHelper.js +19 -0
  112. package/{build/lib → dist/esm}/columnHelper.js.map +1 -1
  113. package/{build/lib → dist/esm}/core/cell.d.ts +2 -1
  114. package/dist/esm/core/cell.js +38 -0
  115. package/dist/esm/core/cell.js.map +1 -0
  116. package/{build/lib → dist/esm}/core/column.d.ts +2 -1
  117. package/dist/esm/core/column.js +81 -0
  118. package/dist/esm/core/column.js.map +1 -0
  119. package/{build/lib → dist/esm}/core/headers.d.ts +1 -0
  120. package/dist/esm/core/headers.js +310 -0
  121. package/dist/esm/core/headers.js.map +1 -0
  122. package/{build/lib → dist/esm}/core/row.d.ts +2 -1
  123. package/dist/esm/core/row.js +92 -0
  124. package/dist/esm/core/row.js.map +1 -0
  125. package/{build/lib → dist/esm}/core/table.d.ts +10 -1
  126. package/dist/esm/core/table.js +232 -0
  127. package/dist/esm/core/table.js.map +1 -0
  128. package/{build/lib → dist/esm}/features/ColumnFaceting.d.ts +1 -0
  129. package/{build/lib → dist/esm}/features/ColumnFaceting.js +6 -19
  130. package/{build/lib → dist/esm}/features/ColumnFaceting.js.map +1 -1
  131. package/{build/lib → dist/esm}/features/ColumnFiltering.d.ts +1 -0
  132. package/dist/esm/features/ColumnFiltering.js +137 -0
  133. package/dist/esm/features/ColumnFiltering.js.map +1 -0
  134. package/{build/lib → dist/esm}/features/ColumnGrouping.d.ts +1 -0
  135. package/dist/esm/features/ColumnGrouping.js +133 -0
  136. package/dist/esm/features/ColumnGrouping.js.map +1 -0
  137. package/{build/lib → dist/esm}/features/ColumnOrdering.d.ts +1 -0
  138. package/dist/esm/features/ColumnOrdering.js +76 -0
  139. package/dist/esm/features/ColumnOrdering.js.map +1 -0
  140. package/{build/lib → dist/esm}/features/ColumnPinning.d.ts +1 -0
  141. package/dist/esm/features/ColumnPinning.js +145 -0
  142. package/dist/esm/features/ColumnPinning.js.map +1 -0
  143. package/{build/lib → dist/esm}/features/ColumnSizing.d.ts +2 -1
  144. package/dist/esm/features/ColumnSizing.js +307 -0
  145. package/dist/esm/features/ColumnSizing.js.map +1 -0
  146. package/{build/lib → dist/esm}/features/ColumnVisibility.d.ts +1 -0
  147. package/dist/esm/features/ColumnVisibility.js +144 -0
  148. package/dist/esm/features/ColumnVisibility.js.map +1 -0
  149. package/{build/lib → dist/esm}/features/GlobalFaceting.d.ts +1 -0
  150. package/{build/lib → dist/esm}/features/GlobalFaceting.js +8 -21
  151. package/dist/esm/features/GlobalFaceting.js.map +1 -0
  152. package/{build/lib → dist/esm}/features/GlobalFiltering.d.ts +1 -0
  153. package/dist/esm/features/GlobalFiltering.js +50 -0
  154. package/dist/esm/features/GlobalFiltering.js.map +1 -0
  155. package/{build/lib → dist/esm}/features/RowExpanding.d.ts +1 -0
  156. package/{build/lib → dist/esm}/features/RowExpanding.js +37 -58
  157. package/dist/esm/features/RowExpanding.js.map +1 -0
  158. package/{build/lib → dist/esm}/features/RowPagination.d.ts +1 -0
  159. package/dist/esm/features/RowPagination.js +161 -0
  160. package/dist/esm/features/RowPagination.js.map +1 -0
  161. package/{build/lib → dist/esm}/features/RowPinning.d.ts +1 -0
  162. package/dist/esm/features/RowPinning.js +132 -0
  163. package/dist/esm/features/RowPinning.js.map +1 -0
  164. package/{build/lib → dist/esm}/features/RowSelection.d.ts +1 -0
  165. package/dist/esm/features/RowSelection.js +296 -0
  166. package/dist/esm/features/RowSelection.js.map +1 -0
  167. package/{build/lib → dist/esm}/features/RowSorting.d.ts +1 -0
  168. package/dist/esm/features/RowSorting.js +200 -0
  169. package/dist/esm/features/RowSorting.js.map +1 -0
  170. package/{build/lib → dist/esm}/filterFns.d.ts +2 -1
  171. package/dist/esm/filterFns.js +88 -0
  172. package/dist/esm/filterFns.js.map +1 -0
  173. package/dist/esm/index.d.ts +34 -0
  174. package/dist/esm/index.js +88 -0
  175. package/dist/esm/index.js.map +1 -0
  176. package/{build/lib → dist/esm}/sortingFns.d.ts +2 -1
  177. package/dist/esm/sortingFns.js +91 -0
  178. package/dist/esm/sortingFns.js.map +1 -0
  179. package/{build/lib → dist/esm}/types.d.ts +29 -28
  180. package/{build/lib → dist/esm}/utils/filterRowsUtils.d.ts +1 -0
  181. package/dist/esm/utils/filterRowsUtils.js +99 -0
  182. package/dist/esm/utils/filterRowsUtils.js.map +1 -0
  183. package/{build/lib → dist/esm}/utils/getCoreRowModel.d.ts +1 -0
  184. package/dist/esm/utils/getCoreRowModel.js +54 -0
  185. package/dist/esm/utils/getCoreRowModel.js.map +1 -0
  186. package/{build/lib → dist/esm}/utils/getExpandedRowModel.d.ts +1 -0
  187. package/dist/esm/utils/getExpandedRowModel.js +41 -0
  188. package/dist/esm/utils/getExpandedRowModel.js.map +1 -0
  189. package/{build/lib → dist/esm}/utils/getFacetedMinMaxValues.d.ts +1 -0
  190. package/dist/esm/utils/getFacetedMinMaxValues.js +35 -0
  191. package/dist/esm/utils/getFacetedMinMaxValues.js.map +1 -0
  192. package/{build/lib → dist/esm}/utils/getFacetedRowModel.d.ts +1 -0
  193. package/dist/esm/utils/getFacetedRowModel.js +35 -0
  194. package/{build/lib → dist/esm}/utils/getFacetedRowModel.js.map +1 -1
  195. package/{build/lib → dist/esm}/utils/getFacetedUniqueValues.d.ts +1 -0
  196. package/dist/esm/utils/getFacetedUniqueValues.js +37 -0
  197. package/dist/esm/utils/getFacetedUniqueValues.js.map +1 -0
  198. package/{build/lib → dist/esm}/utils/getFilteredRowModel.d.ts +1 -0
  199. package/dist/esm/utils/getFilteredRowModel.js +116 -0
  200. package/{build/lib → dist/esm}/utils/getFilteredRowModel.js.map +1 -1
  201. package/{build/lib → dist/esm}/utils/getGroupedRowModel.d.ts +1 -0
  202. package/dist/esm/utils/getGroupedRowModel.js +118 -0
  203. package/dist/esm/utils/getGroupedRowModel.js.map +1 -0
  204. package/{build/lib → dist/esm}/utils/getPaginationRowModel.d.ts +1 -0
  205. package/dist/esm/utils/getPaginationRowModel.js +49 -0
  206. package/dist/esm/utils/getPaginationRowModel.js.map +1 -0
  207. package/{build/lib → dist/esm}/utils/getSortedRowModel.d.ts +1 -0
  208. package/dist/esm/utils/getSortedRowModel.js +88 -0
  209. package/{build/lib → dist/esm}/utils/getSortedRowModel.js.map +1 -1
  210. package/{build/lib → dist/esm}/utils.d.ts +2 -1
  211. package/dist/esm/utils.js +98 -0
  212. package/{build/lib → dist/esm}/utils.js.map +1 -1
  213. package/package.json +14 -10
  214. package/src/core/cell.ts +2 -2
  215. package/src/core/column.ts +2 -2
  216. package/src/core/headers.ts +5 -5
  217. package/src/core/row.ts +4 -4
  218. package/src/core/table.ts +43 -7
  219. package/src/features/ColumnFaceting.ts +1 -1
  220. package/src/features/ColumnFiltering.ts +6 -6
  221. package/src/features/ColumnGrouping.ts +7 -7
  222. package/src/features/ColumnOrdering.ts +4 -4
  223. package/src/features/ColumnPinning.ts +5 -5
  224. package/src/features/ColumnSizing.ts +6 -6
  225. package/src/features/ColumnVisibility.ts +5 -5
  226. package/src/features/GlobalFaceting.ts +1 -1
  227. package/src/features/GlobalFiltering.ts +4 -4
  228. package/src/features/RowExpanding.ts +4 -4
  229. package/src/features/RowPagination.ts +3 -3
  230. package/src/features/RowPinning.ts +4 -4
  231. package/src/features/RowSelection.ts +4 -4
  232. package/src/features/RowSorting.ts +5 -5
  233. package/src/types.ts +8 -8
  234. package/src/utils/filterRowsUtils.ts +3 -3
  235. package/src/utils/getCoreRowModel.ts +2 -2
  236. package/src/utils/getGroupedRowModel.ts +2 -2
  237. package/build/lib/aggregationFns.js +0 -108
  238. package/build/lib/aggregationFns.js.map +0 -1
  239. package/build/lib/columnHelper.js +0 -71
  240. package/build/lib/core/cell.js +0 -42
  241. package/build/lib/core/cell.js.map +0 -1
  242. package/build/lib/core/column.js +0 -80
  243. package/build/lib/core/column.js.map +0 -1
  244. package/build/lib/core/headers.js +0 -270
  245. package/build/lib/core/headers.js.map +0 -1
  246. package/build/lib/core/row.js +0 -89
  247. package/build/lib/core/row.js.map +0 -1
  248. package/build/lib/core/table.js +0 -212
  249. package/build/lib/core/table.js.map +0 -1
  250. package/build/lib/features/ColumnFiltering.js +0 -151
  251. package/build/lib/features/ColumnFiltering.js.map +0 -1
  252. package/build/lib/features/ColumnGrouping.js +0 -142
  253. package/build/lib/features/ColumnGrouping.js.map +0 -1
  254. package/build/lib/features/ColumnOrdering.js +0 -84
  255. package/build/lib/features/ColumnOrdering.js.map +0 -1
  256. package/build/lib/features/ColumnPinning.js +0 -130
  257. package/build/lib/features/ColumnPinning.js.map +0 -1
  258. package/build/lib/features/ColumnSizing.js +0 -270
  259. package/build/lib/features/ColumnSizing.js.map +0 -1
  260. package/build/lib/features/ColumnVisibility.js +0 -99
  261. package/build/lib/features/ColumnVisibility.js.map +0 -1
  262. package/build/lib/features/GlobalFaceting.js.map +0 -1
  263. package/build/lib/features/GlobalFiltering.js +0 -63
  264. package/build/lib/features/GlobalFiltering.js.map +0 -1
  265. package/build/lib/features/RowExpanding.js.map +0 -1
  266. package/build/lib/features/RowPagination.js +0 -169
  267. package/build/lib/features/RowPagination.js.map +0 -1
  268. package/build/lib/features/RowPinning.js +0 -145
  269. package/build/lib/features/RowPinning.js.map +0 -1
  270. package/build/lib/features/RowSelection.js +0 -391
  271. package/build/lib/features/RowSelection.js.map +0 -1
  272. package/build/lib/features/RowSorting.js +0 -226
  273. package/build/lib/features/RowSorting.js.map +0 -1
  274. package/build/lib/filterFns.js +0 -96
  275. package/build/lib/filterFns.js.map +0 -1
  276. package/build/lib/index.d.ts +0 -34
  277. package/build/lib/index.esm.js +0 -3522
  278. package/build/lib/index.esm.js.map +0 -1
  279. package/build/lib/index.js.map +0 -1
  280. package/build/lib/index.mjs +0 -3522
  281. package/build/lib/index.mjs.map +0 -1
  282. package/build/lib/sortingFns.js.map +0 -1
  283. package/build/lib/utils/filterRowsUtils.js.map +0 -1
  284. package/build/lib/utils/getCoreRowModel.js +0 -65
  285. package/build/lib/utils/getCoreRowModel.js.map +0 -1
  286. package/build/lib/utils/getExpandedRowModel.js +0 -46
  287. package/build/lib/utils/getExpandedRowModel.js.map +0 -1
  288. package/build/lib/utils/getFacetedMinMaxValues.js +0 -43
  289. package/build/lib/utils/getFacetedMinMaxValues.js.map +0 -1
  290. package/build/lib/utils/getFacetedRowModel.js +0 -36
  291. package/build/lib/utils/getFacetedUniqueValues.js +0 -39
  292. package/build/lib/utils/getFacetedUniqueValues.js.map +0 -1
  293. package/build/lib/utils/getFilteredRowModel.js +0 -111
  294. package/build/lib/utils/getGroupedRowModel.js +0 -150
  295. package/build/lib/utils/getGroupedRowModel.js.map +0 -1
  296. package/build/lib/utils/getPaginationRowModel.js +0 -60
  297. package/build/lib/utils/getPaginationRowModel.js.map +0 -1
  298. package/build/lib/utils/getSortedRowModel.js +0 -102
  299. package/build/umd/index.development.js +0 -3578
  300. package/build/umd/index.development.js.map +0 -1
  301. package/build/umd/index.production.js +0 -12
  302. package/build/umd/index.production.js.map +0 -1
@@ -0,0 +1,200 @@
1
+ import { sortingFns, reSplitAlphaNumeric } from "../sortingFns.js";
2
+ import { makeStateUpdater, isFunction } from "../utils.js";
3
+ const RowSorting = {
4
+ _getInitialState: (state) => {
5
+ return {
6
+ sorting: [],
7
+ ...state
8
+ };
9
+ },
10
+ _getDefaultColumnDef: () => {
11
+ return {
12
+ sortingFn: "auto",
13
+ sortUndefined: 1
14
+ };
15
+ },
16
+ _getDefaultOptions: (table) => {
17
+ return {
18
+ onSortingChange: makeStateUpdater("sorting", table),
19
+ isMultiSortEvent: (e) => {
20
+ return e.shiftKey;
21
+ }
22
+ };
23
+ },
24
+ _createColumn: (column, table) => {
25
+ column.getAutoSortingFn = () => {
26
+ const firstRows = table.getFilteredRowModel().flatRows.slice(10);
27
+ let isString = false;
28
+ for (const row of firstRows) {
29
+ const value = row == null ? void 0 : row.getValue(column.id);
30
+ if (Object.prototype.toString.call(value) === "[object Date]") {
31
+ return sortingFns.datetime;
32
+ }
33
+ if (typeof value === "string") {
34
+ isString = true;
35
+ if (value.split(reSplitAlphaNumeric).length > 1) {
36
+ return sortingFns.alphanumeric;
37
+ }
38
+ }
39
+ }
40
+ if (isString) {
41
+ return sortingFns.text;
42
+ }
43
+ return sortingFns.basic;
44
+ };
45
+ column.getAutoSortDir = () => {
46
+ const firstRow = table.getFilteredRowModel().flatRows[0];
47
+ const value = firstRow == null ? void 0 : firstRow.getValue(column.id);
48
+ if (typeof value === "string") {
49
+ return "asc";
50
+ }
51
+ return "desc";
52
+ };
53
+ column.getSortingFn = () => {
54
+ var _a;
55
+ if (!column) {
56
+ throw new Error();
57
+ }
58
+ return isFunction(column.columnDef.sortingFn) ? column.columnDef.sortingFn : column.columnDef.sortingFn === "auto" ? column.getAutoSortingFn() : ((_a = table.options.sortingFns) == null ? void 0 : _a[column.columnDef.sortingFn]) ?? sortingFns[column.columnDef.sortingFn];
59
+ };
60
+ column.toggleSorting = (desc, multi) => {
61
+ const nextSortingOrder = column.getNextSortingOrder();
62
+ const hasManualValue = typeof desc !== "undefined" && desc !== null;
63
+ table.setSorting((old) => {
64
+ const existingSorting = old == null ? void 0 : old.find((d) => d.id === column.id);
65
+ const existingIndex = old == null ? void 0 : old.findIndex((d) => d.id === column.id);
66
+ let newSorting = [];
67
+ let sortAction;
68
+ let nextDesc = hasManualValue ? desc : nextSortingOrder === "desc";
69
+ if ((old == null ? void 0 : old.length) && column.getCanMultiSort() && multi) {
70
+ if (existingSorting) {
71
+ sortAction = "toggle";
72
+ } else {
73
+ sortAction = "add";
74
+ }
75
+ } else {
76
+ if ((old == null ? void 0 : old.length) && existingIndex !== old.length - 1) {
77
+ sortAction = "replace";
78
+ } else if (existingSorting) {
79
+ sortAction = "toggle";
80
+ } else {
81
+ sortAction = "replace";
82
+ }
83
+ }
84
+ if (sortAction === "toggle") {
85
+ if (!hasManualValue) {
86
+ if (!nextSortingOrder) {
87
+ sortAction = "remove";
88
+ }
89
+ }
90
+ }
91
+ if (sortAction === "add") {
92
+ newSorting = [
93
+ ...old,
94
+ {
95
+ id: column.id,
96
+ desc: nextDesc
97
+ }
98
+ ];
99
+ newSorting.splice(
100
+ 0,
101
+ newSorting.length - (table.options.maxMultiSortColCount ?? Number.MAX_SAFE_INTEGER)
102
+ );
103
+ } else if (sortAction === "toggle") {
104
+ newSorting = old.map((d) => {
105
+ if (d.id === column.id) {
106
+ return {
107
+ ...d,
108
+ desc: nextDesc
109
+ };
110
+ }
111
+ return d;
112
+ });
113
+ } else if (sortAction === "remove") {
114
+ newSorting = old.filter((d) => d.id !== column.id);
115
+ } else {
116
+ newSorting = [
117
+ {
118
+ id: column.id,
119
+ desc: nextDesc
120
+ }
121
+ ];
122
+ }
123
+ return newSorting;
124
+ });
125
+ };
126
+ column.getFirstSortDir = () => {
127
+ const sortDescFirst = column.columnDef.sortDescFirst ?? table.options.sortDescFirst ?? column.getAutoSortDir() === "desc";
128
+ return sortDescFirst ? "desc" : "asc";
129
+ };
130
+ column.getNextSortingOrder = (multi) => {
131
+ const firstSortDirection = column.getFirstSortDir();
132
+ const isSorted = column.getIsSorted();
133
+ if (!isSorted) {
134
+ return firstSortDirection;
135
+ }
136
+ if (isSorted !== firstSortDirection && (table.options.enableSortingRemoval ?? true) && // If enableSortRemove, enable in general
137
+ (multi ? table.options.enableMultiRemove ?? true : true)) {
138
+ return false;
139
+ }
140
+ return isSorted === "desc" ? "asc" : "desc";
141
+ };
142
+ column.getCanSort = () => {
143
+ return (column.columnDef.enableSorting ?? true) && (table.options.enableSorting ?? true) && !!column.accessorFn;
144
+ };
145
+ column.getCanMultiSort = () => {
146
+ return column.columnDef.enableMultiSort ?? table.options.enableMultiSort ?? !!column.accessorFn;
147
+ };
148
+ column.getIsSorted = () => {
149
+ var _a;
150
+ const columnSort = (_a = table.getState().sorting) == null ? void 0 : _a.find((d) => d.id === column.id);
151
+ return !columnSort ? false : columnSort.desc ? "desc" : "asc";
152
+ };
153
+ column.getSortIndex = () => {
154
+ var _a;
155
+ return ((_a = table.getState().sorting) == null ? void 0 : _a.findIndex((d) => d.id === column.id)) ?? -1;
156
+ };
157
+ column.clearSorting = () => {
158
+ table.setSorting(
159
+ (old) => (old == null ? void 0 : old.length) ? old.filter((d) => d.id !== column.id) : []
160
+ );
161
+ };
162
+ column.getToggleSortingHandler = () => {
163
+ const canSort = column.getCanSort();
164
+ return (e) => {
165
+ var _a, _b, _c, _d;
166
+ if (!canSort) return;
167
+ (_a = e.persist) == null ? void 0 : _a.call(e);
168
+ (_d = column.toggleSorting) == null ? void 0 : _d.call(
169
+ column,
170
+ void 0,
171
+ column.getCanMultiSort() ? (_c = (_b = table.options).isMultiSortEvent) == null ? void 0 : _c.call(_b, e) : false
172
+ );
173
+ };
174
+ };
175
+ },
176
+ _createTable: (table) => {
177
+ table.setSorting = (updater) => {
178
+ var _a, _b;
179
+ return (_b = (_a = table.options).onSortingChange) == null ? void 0 : _b.call(_a, updater);
180
+ };
181
+ table.resetSorting = (defaultState) => {
182
+ var _a;
183
+ table.setSorting(defaultState ? [] : ((_a = table.initialState) == null ? void 0 : _a.sorting) ?? []);
184
+ };
185
+ table.getPreSortedRowModel = () => table.getGroupedRowModel();
186
+ table.getSortedRowModel = () => {
187
+ if (!table._getSortedRowModel && table.options.getSortedRowModel) {
188
+ table._getSortedRowModel = table.options.getSortedRowModel(table);
189
+ }
190
+ if (table.options.manualSorting || !table._getSortedRowModel) {
191
+ return table.getPreSortedRowModel();
192
+ }
193
+ return table._getSortedRowModel();
194
+ };
195
+ }
196
+ };
197
+ export {
198
+ RowSorting
199
+ };
200
+ //# sourceMappingURL=RowSorting.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RowSorting.js","sources":["../../../src/features/RowSorting.ts"],"sourcesContent":["import { RowModel } from '..'\nimport {\n BuiltInSortingFn,\n reSplitAlphaNumeric,\n sortingFns,\n} from '../sortingFns'\n\nimport {\n Column,\n OnChangeFn,\n Table,\n Row,\n Updater,\n RowData,\n SortingFns,\n TableFeature,\n} from '../types'\n\nimport { isFunction, makeStateUpdater } from '../utils'\n\nexport type SortDirection = 'asc' | 'desc'\n\nexport interface ColumnSort {\n desc: boolean\n id: string\n}\n\nexport type SortingState = ColumnSort[]\n\nexport interface SortingTableState {\n sorting: SortingState\n}\n\nexport interface SortingFn<TData extends RowData> {\n (rowA: Row<TData>, rowB: Row<TData>, columnId: string): number\n}\n\nexport type CustomSortingFns<TData extends RowData> = Record<\n string,\n SortingFn<TData>\n>\n\nexport type SortingFnOption<TData extends RowData> =\n | 'auto'\n | keyof SortingFns\n | BuiltInSortingFn\n | SortingFn<TData>\n\nexport interface SortingColumnDef<TData extends RowData> {\n /**\n * Enables/Disables multi-sorting for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablemultisort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableMultiSort?: boolean\n /**\n * Enables/Disables sorting for this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablesorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableSorting?: boolean\n /**\n * Inverts the order of the sorting for this column. This is useful for values that have an inverted best/worst scale where lower numbers are better, eg. a ranking (1st, 2nd, 3rd) or golf-like scoring\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#invertsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n invertSorting?: boolean\n /**\n * Set to `true` for sorting toggles on this column to start in the descending direction.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortdescfirst)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortDescFirst?: boolean\n /**\n * The sorting function to use with this column.\n * - A `string` referencing a built-in sorting function\n * - A custom sorting function\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortingfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortingFn?: SortingFnOption<TData>\n /**\n * The priority of undefined values when sorting this column.\n * - `false`\n * - Undefined values will be considered tied and need to be sorted by the next column filter or original index (whichever applies)\n * - `-1`\n * - Undefined values will be sorted with higher priority (ascending) (if ascending, undefined will appear on the beginning of the list)\n * - `1`\n * - Undefined values will be sorted with lower priority (descending) (if ascending, undefined will appear on the end of the list)\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortundefined)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortUndefined?: false | -1 | 1 | 'first' | 'last'\n}\n\nexport interface SortingColumn<TData extends RowData> {\n /**\n * Removes this column from the table's sorting state\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#clearsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n clearSorting: () => void\n /**\n * Returns a sort direction automatically inferred based on the columns values.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getautosortdir)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getAutoSortDir: () => SortDirection\n /**\n * Returns a sorting function automatically inferred based on the columns values.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getautosortingfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getAutoSortingFn: () => SortingFn<TData>\n /**\n * Returns whether this column can be multi-sorted.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getcanmultisort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getCanMultiSort: () => boolean\n /**\n * Returns whether this column can be sorted.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getcansort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getCanSort: () => boolean\n /**\n * Returns the first direction that should be used when sorting this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getfirstsortdir)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getFirstSortDir: () => SortDirection\n /**\n * Returns the current sort direction of this column.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getissorted)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getIsSorted: () => false | SortDirection\n /**\n * Returns the next sorting order.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getnextsortingorder)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getNextSortingOrder: () => SortDirection | false\n /**\n * Returns the index position of this column's sorting within the sorting state\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortindex)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortIndex: () => number\n /**\n * Returns the resolved sorting function to be used for this column\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortingfn)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortingFn: () => SortingFn<TData>\n /**\n * Returns a function that can be used to toggle this column's sorting state. This is useful for attaching a click handler to the column header.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#gettogglesortinghandler)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getToggleSortingHandler: () => undefined | ((event: unknown) => void)\n /**\n * Toggles this columns sorting state. If `desc` is provided, it will force the sort direction to that value. If `isMulti` is provided, it will additivity multi-sort the column (or toggle it if it is already sorted).\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#togglesorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n toggleSorting: (desc?: boolean, isMulti?: boolean) => void\n}\n\ninterface SortingOptionsBase {\n /**\n * Enables/disables the ability to remove multi-sorts\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablemultiremove)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableMultiRemove?: boolean\n /**\n * Enables/Disables multi-sorting for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablemultisort)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableMultiSort?: boolean\n /**\n * Enables/Disables sorting for the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablesorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableSorting?: boolean\n /**\n * Enables/Disables the ability to remove sorting for the table.\n * - If `true` then changing sort order will circle like: 'none' -> 'desc' -> 'asc' -> 'none' -> ...\n * - If `false` then changing sort order will circle like: 'none' -> 'desc' -> 'asc' -> 'desc' -> 'asc' -> ...\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#enablesortingremoval)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n enableSortingRemoval?: boolean\n /**\n * This function is used to retrieve the sorted row model. If using server-side sorting, this function is not required. To use client-side sorting, pass the exported `getSortedRowModel()` from your adapter to your table or implement your own.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortedRowModel?: (table: Table<any>) => () => RowModel<any>\n /**\n * Pass a custom function that will be used to determine if a multi-sort event should be triggered. It is passed the event from the sort toggle handler and should return `true` if the event should trigger a multi-sort.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#ismultisortevent)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n isMultiSortEvent?: (e: unknown) => boolean\n /**\n * Enables manual sorting for the table. If this is `true`, you will be expected to sort your data before it is passed to the table. This is useful if you are doing server-side sorting.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#manualsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n manualSorting?: boolean\n /**\n * Set a maximum number of columns that can be multi-sorted.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#maxmultisortcolcount)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n maxMultiSortColCount?: number\n /**\n * If provided, this function will be called with an `updaterFn` when `state.sorting` changes. This overrides the default internal state management, so you will need to persist the state change either fully or partially outside of the table.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#onsortingchange)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n onSortingChange?: OnChangeFn<SortingState>\n /**\n * If `true`, all sorts will default to descending as their first toggle state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#sortdescfirst)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n sortDescFirst?: boolean\n}\n\ntype ResolvedSortingFns = keyof SortingFns extends never\n ? {\n sortingFns?: Record<string, SortingFn<any>>\n }\n : {\n sortingFns: Record<keyof SortingFns, SortingFn<any>>\n }\n\nexport interface SortingOptions<TData extends RowData>\n extends SortingOptionsBase,\n ResolvedSortingFns {}\n\nexport interface SortingInstance<TData extends RowData> {\n _getSortedRowModel?: () => RowModel<TData>\n /**\n * Returns the row model for the table before any sorting has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getpresortedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getPreSortedRowModel: () => RowModel<TData>\n /**\n * Returns the row model for the table after sorting has been applied.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#getsortedrowmodel)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n getSortedRowModel: () => RowModel<TData>\n /**\n * Resets the **sorting** state to `initialState.sorting`, or `true` can be passed to force a default blank state reset to `[]`.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#resetsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n resetSorting: (defaultState?: boolean) => void\n /**\n * Sets or updates the `state.sorting` state.\n * @link [API Docs](https://tanstack.com/table/v8/docs/api/features/sorting#setsorting)\n * @link [Guide](https://tanstack.com/table/v8/docs/guide/sorting)\n */\n setSorting: (updater: Updater<SortingState>) => void\n}\n\n//\n\nexport const RowSorting: TableFeature = {\n _getInitialState: (state): SortingTableState => {\n return {\n sorting: [],\n ...state,\n }\n },\n\n _getDefaultColumnDef: <TData extends RowData>(): SortingColumnDef<TData> => {\n return {\n sortingFn: 'auto',\n sortUndefined: 1,\n }\n },\n\n _getDefaultOptions: <TData extends RowData>(\n table: Table<TData>\n ): SortingOptions<TData> => {\n return {\n onSortingChange: makeStateUpdater('sorting', table),\n isMultiSortEvent: (e: unknown) => {\n return (e as MouseEvent).shiftKey\n },\n }\n },\n\n _createColumn: <TData extends RowData, TValue>(\n column: Column<TData, TValue>,\n table: Table<TData>\n ): void => {\n column.getAutoSortingFn = () => {\n const firstRows = table.getFilteredRowModel().flatRows.slice(10)\n\n let isString = false\n\n for (const row of firstRows) {\n const value = row?.getValue(column.id)\n\n if (Object.prototype.toString.call(value) === '[object Date]') {\n return sortingFns.datetime\n }\n\n if (typeof value === 'string') {\n isString = true\n\n if (value.split(reSplitAlphaNumeric).length > 1) {\n return sortingFns.alphanumeric\n }\n }\n }\n\n if (isString) {\n return sortingFns.text\n }\n\n return sortingFns.basic\n }\n column.getAutoSortDir = () => {\n const firstRow = table.getFilteredRowModel().flatRows[0]\n\n const value = firstRow?.getValue(column.id)\n\n if (typeof value === 'string') {\n return 'asc'\n }\n\n return 'desc'\n }\n column.getSortingFn = () => {\n if (!column) {\n throw new Error()\n }\n\n return isFunction(column.columnDef.sortingFn)\n ? column.columnDef.sortingFn\n : column.columnDef.sortingFn === 'auto'\n ? column.getAutoSortingFn()\n : table.options.sortingFns?.[column.columnDef.sortingFn as string] ??\n sortingFns[column.columnDef.sortingFn as BuiltInSortingFn]\n }\n column.toggleSorting = (desc, multi) => {\n // if (column.columns.length) {\n // column.columns.forEach((c, i) => {\n // if (c.id) {\n // table.toggleColumnSorting(c.id, undefined, multi || !!i)\n // }\n // })\n // return\n // }\n\n // this needs to be outside of table.setSorting to be in sync with rerender\n const nextSortingOrder = column.getNextSortingOrder()\n const hasManualValue = typeof desc !== 'undefined' && desc !== null\n\n table.setSorting(old => {\n // Find any existing sorting for this column\n const existingSorting = old?.find(d => d.id === column.id)\n const existingIndex = old?.findIndex(d => d.id === column.id)\n\n let newSorting: SortingState = []\n\n // What should we do with this sort action?\n let sortAction: 'add' | 'remove' | 'toggle' | 'replace'\n let nextDesc = hasManualValue ? desc : nextSortingOrder === 'desc'\n\n // Multi-mode\n if (old?.length && column.getCanMultiSort() && multi) {\n if (existingSorting) {\n sortAction = 'toggle'\n } else {\n sortAction = 'add'\n }\n } else {\n // Normal mode\n if (old?.length && existingIndex !== old.length - 1) {\n sortAction = 'replace'\n } else if (existingSorting) {\n sortAction = 'toggle'\n } else {\n sortAction = 'replace'\n }\n }\n\n // Handle toggle states that will remove the sorting\n if (sortAction === 'toggle') {\n // If we are \"actually\" toggling (not a manual set value), should we remove the sorting?\n if (!hasManualValue) {\n // Is our intention to remove?\n if (!nextSortingOrder) {\n sortAction = 'remove'\n }\n }\n }\n\n if (sortAction === 'add') {\n newSorting = [\n ...old,\n {\n id: column.id,\n desc: nextDesc,\n },\n ]\n // Take latest n columns\n newSorting.splice(\n 0,\n newSorting.length -\n (table.options.maxMultiSortColCount ?? Number.MAX_SAFE_INTEGER)\n )\n } else if (sortAction === 'toggle') {\n // This flips (or sets) the\n newSorting = old.map(d => {\n if (d.id === column.id) {\n return {\n ...d,\n desc: nextDesc,\n }\n }\n return d\n })\n } else if (sortAction === 'remove') {\n newSorting = old.filter(d => d.id !== column.id)\n } else {\n newSorting = [\n {\n id: column.id,\n desc: nextDesc,\n },\n ]\n }\n\n return newSorting\n })\n }\n\n column.getFirstSortDir = () => {\n const sortDescFirst =\n column.columnDef.sortDescFirst ??\n table.options.sortDescFirst ??\n column.getAutoSortDir() === 'desc'\n return sortDescFirst ? 'desc' : 'asc'\n }\n\n column.getNextSortingOrder = (multi?: boolean) => {\n const firstSortDirection = column.getFirstSortDir()\n const isSorted = column.getIsSorted()\n\n if (!isSorted) {\n return firstSortDirection\n }\n\n if (\n isSorted !== firstSortDirection &&\n (table.options.enableSortingRemoval ?? true) && // If enableSortRemove, enable in general\n (multi ? table.options.enableMultiRemove ?? true : true) // If multi, don't allow if enableMultiRemove))\n ) {\n return false\n }\n return isSorted === 'desc' ? 'asc' : 'desc'\n }\n\n column.getCanSort = () => {\n return (\n (column.columnDef.enableSorting ?? true) &&\n (table.options.enableSorting ?? true) &&\n !!column.accessorFn\n )\n }\n\n column.getCanMultiSort = () => {\n return (\n column.columnDef.enableMultiSort ??\n table.options.enableMultiSort ??\n !!column.accessorFn\n )\n }\n\n column.getIsSorted = () => {\n const columnSort = table.getState().sorting?.find(d => d.id === column.id)\n\n return !columnSort ? false : columnSort.desc ? 'desc' : 'asc'\n }\n\n column.getSortIndex = () =>\n table.getState().sorting?.findIndex(d => d.id === column.id) ?? -1\n\n column.clearSorting = () => {\n //clear sorting for just 1 column\n table.setSorting(old =>\n old?.length ? old.filter(d => d.id !== column.id) : []\n )\n }\n\n column.getToggleSortingHandler = () => {\n const canSort = column.getCanSort()\n\n return (e: unknown) => {\n if (!canSort) return\n ;(e as any).persist?.()\n column.toggleSorting?.(\n undefined,\n column.getCanMultiSort() ? table.options.isMultiSortEvent?.(e) : false\n )\n }\n }\n },\n\n _createTable: <TData extends RowData>(table: Table<TData>): void => {\n table.setSorting = updater => table.options.onSortingChange?.(updater)\n table.resetSorting = defaultState => {\n table.setSorting(defaultState ? [] : table.initialState?.sorting ?? [])\n }\n table.getPreSortedRowModel = () => table.getGroupedRowModel()\n table.getSortedRowModel = () => {\n if (!table._getSortedRowModel && table.options.getSortedRowModel) {\n table._getSortedRowModel = table.options.getSortedRowModel(table)\n }\n\n if (table.options.manualSorting || !table._getSortedRowModel) {\n return table.getPreSortedRowModel()\n }\n\n return table._getSortedRowModel()\n }\n },\n}\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,5 @@
1
- import { FilterFn } from './features/ColumnFiltering';
1
+ import { FilterFn } from './features/ColumnFiltering.js';
2
+
2
3
  export declare const filterFns: {
3
4
  includesString: FilterFn<any>;
4
5
  includesStringSensitive: FilterFn<any>;
@@ -0,0 +1,88 @@
1
+ const includesString = (row, columnId, filterValue) => {
2
+ var _a, _b, _c;
3
+ const search = filterValue.toLowerCase();
4
+ return Boolean(
5
+ (_c = (_b = (_a = row.getValue(columnId)) == null ? void 0 : _a.toString()) == null ? void 0 : _b.toLowerCase()) == null ? void 0 : _c.includes(search)
6
+ );
7
+ };
8
+ includesString.autoRemove = (val) => testFalsey(val);
9
+ const includesStringSensitive = (row, columnId, filterValue) => {
10
+ var _a, _b;
11
+ return Boolean(
12
+ (_b = (_a = row.getValue(columnId)) == null ? void 0 : _a.toString()) == null ? void 0 : _b.includes(filterValue)
13
+ );
14
+ };
15
+ includesStringSensitive.autoRemove = (val) => testFalsey(val);
16
+ const equalsString = (row, columnId, filterValue) => {
17
+ var _a, _b;
18
+ return ((_b = (_a = row.getValue(columnId)) == null ? void 0 : _a.toString()) == null ? void 0 : _b.toLowerCase()) === (filterValue == null ? void 0 : filterValue.toLowerCase());
19
+ };
20
+ equalsString.autoRemove = (val) => testFalsey(val);
21
+ const arrIncludes = (row, columnId, filterValue) => {
22
+ var _a;
23
+ return (_a = row.getValue(columnId)) == null ? void 0 : _a.includes(filterValue);
24
+ };
25
+ arrIncludes.autoRemove = (val) => testFalsey(val) || !(val == null ? void 0 : val.length);
26
+ const arrIncludesAll = (row, columnId, filterValue) => {
27
+ return !filterValue.some(
28
+ (val) => {
29
+ var _a;
30
+ return !((_a = row.getValue(columnId)) == null ? void 0 : _a.includes(val));
31
+ }
32
+ );
33
+ };
34
+ arrIncludesAll.autoRemove = (val) => testFalsey(val) || !(val == null ? void 0 : val.length);
35
+ const arrIncludesSome = (row, columnId, filterValue) => {
36
+ return filterValue.some(
37
+ (val) => {
38
+ var _a;
39
+ return (_a = row.getValue(columnId)) == null ? void 0 : _a.includes(val);
40
+ }
41
+ );
42
+ };
43
+ arrIncludesSome.autoRemove = (val) => testFalsey(val) || !(val == null ? void 0 : val.length);
44
+ const equals = (row, columnId, filterValue) => {
45
+ return row.getValue(columnId) === filterValue;
46
+ };
47
+ equals.autoRemove = (val) => testFalsey(val);
48
+ const weakEquals = (row, columnId, filterValue) => {
49
+ return row.getValue(columnId) == filterValue;
50
+ };
51
+ weakEquals.autoRemove = (val) => testFalsey(val);
52
+ const inNumberRange = (row, columnId, filterValue) => {
53
+ let [min, max] = filterValue;
54
+ const rowValue = row.getValue(columnId);
55
+ return rowValue >= min && rowValue <= max;
56
+ };
57
+ inNumberRange.resolveFilterValue = (val) => {
58
+ let [unsafeMin, unsafeMax] = val;
59
+ let parsedMin = typeof unsafeMin !== "number" ? parseFloat(unsafeMin) : unsafeMin;
60
+ let parsedMax = typeof unsafeMax !== "number" ? parseFloat(unsafeMax) : unsafeMax;
61
+ let min = unsafeMin === null || Number.isNaN(parsedMin) ? -Infinity : parsedMin;
62
+ let max = unsafeMax === null || Number.isNaN(parsedMax) ? Infinity : parsedMax;
63
+ if (min > max) {
64
+ const temp = min;
65
+ min = max;
66
+ max = temp;
67
+ }
68
+ return [min, max];
69
+ };
70
+ inNumberRange.autoRemove = (val) => testFalsey(val) || testFalsey(val[0]) && testFalsey(val[1]);
71
+ const filterFns = {
72
+ includesString,
73
+ includesStringSensitive,
74
+ equalsString,
75
+ arrIncludes,
76
+ arrIncludesAll,
77
+ arrIncludesSome,
78
+ equals,
79
+ weakEquals,
80
+ inNumberRange
81
+ };
82
+ function testFalsey(val) {
83
+ return val === void 0 || val === null || val === "";
84
+ }
85
+ export {
86
+ filterFns
87
+ };
88
+ //# sourceMappingURL=filterFns.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filterFns.js","sources":["../../src/filterFns.ts"],"sourcesContent":["import { FilterFn } from './features/ColumnFiltering'\n\nconst includesString: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: string\n) => {\n const search = filterValue.toLowerCase()\n return Boolean(\n row\n .getValue<string | null>(columnId)\n ?.toString()\n ?.toLowerCase()\n ?.includes(search)\n )\n}\n\nincludesString.autoRemove = (val: any) => testFalsey(val)\n\nconst includesStringSensitive: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: string\n) => {\n return Boolean(\n row.getValue<string | null>(columnId)?.toString()?.includes(filterValue)\n )\n}\n\nincludesStringSensitive.autoRemove = (val: any) => testFalsey(val)\n\nconst equalsString: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: string\n) => {\n return (\n row.getValue<string | null>(columnId)?.toString()?.toLowerCase() ===\n filterValue?.toLowerCase()\n )\n}\n\nequalsString.autoRemove = (val: any) => testFalsey(val)\n\nconst arrIncludes: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: unknown\n) => {\n return row.getValue<unknown[]>(columnId)?.includes(filterValue)\n}\n\narrIncludes.autoRemove = (val: any) => testFalsey(val) || !val?.length\n\nconst arrIncludesAll: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: unknown[]\n) => {\n return !filterValue.some(\n val => !row.getValue<unknown[]>(columnId)?.includes(val)\n )\n}\n\narrIncludesAll.autoRemove = (val: any) => testFalsey(val) || !val?.length\n\nconst arrIncludesSome: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: unknown[]\n) => {\n return filterValue.some(val =>\n row.getValue<unknown[]>(columnId)?.includes(val)\n )\n}\n\narrIncludesSome.autoRemove = (val: any) => testFalsey(val) || !val?.length\n\nconst equals: FilterFn<any> = (row, columnId: string, filterValue: unknown) => {\n return row.getValue(columnId) === filterValue\n}\n\nequals.autoRemove = (val: any) => testFalsey(val)\n\nconst weakEquals: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: unknown\n) => {\n return row.getValue(columnId) == filterValue\n}\n\nweakEquals.autoRemove = (val: any) => testFalsey(val)\n\nconst inNumberRange: FilterFn<any> = (\n row,\n columnId: string,\n filterValue: [number, number]\n) => {\n let [min, max] = filterValue\n\n const rowValue = row.getValue<number>(columnId)\n return rowValue >= min && rowValue <= max\n}\n\ninNumberRange.resolveFilterValue = (val: [any, any]) => {\n let [unsafeMin, unsafeMax] = val\n\n let parsedMin =\n typeof unsafeMin !== 'number' ? parseFloat(unsafeMin as string) : unsafeMin\n let parsedMax =\n typeof unsafeMax !== 'number' ? parseFloat(unsafeMax as string) : unsafeMax\n\n let min =\n unsafeMin === null || Number.isNaN(parsedMin) ? -Infinity : parsedMin\n let max = unsafeMax === null || Number.isNaN(parsedMax) ? Infinity : parsedMax\n\n if (min > max) {\n const temp = min\n min = max\n max = temp\n }\n\n return [min, max] as const\n}\n\ninNumberRange.autoRemove = (val: any) =>\n testFalsey(val) || (testFalsey(val[0]) && testFalsey(val[1]))\n\n// Export\n\nexport const filterFns = {\n includesString,\n includesStringSensitive,\n equalsString,\n arrIncludes,\n arrIncludesAll,\n arrIncludesSome,\n equals,\n weakEquals,\n inNumberRange,\n}\n\nexport type BuiltInFilterFn = keyof typeof filterFns\n\n// Utils\n\nfunction testFalsey(val: any) {\n return val === undefined || val === null || val === ''\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ export * from './columnHelper.js';
2
+ export * from './types.js';
3
+ export * from './core/cell.js';
4
+ export * from './core/column.js';
5
+ export * from './core/headers.js';
6
+ export * from './core/row.js';
7
+ export * from './core/table.js';
8
+ export * from './features/ColumnFaceting.js';
9
+ export * from './features/ColumnFiltering.js';
10
+ export * from './features/ColumnGrouping.js';
11
+ export * from './features/ColumnOrdering.js';
12
+ export * from './features/ColumnPinning.js';
13
+ export * from './features/ColumnSizing.js';
14
+ export * from './features/ColumnVisibility.js';
15
+ export * from './features/GlobalFaceting.js';
16
+ export * from './features/GlobalFiltering.js';
17
+ export * from './features/RowExpanding.js';
18
+ export * from './features/RowPagination.js';
19
+ export * from './features/RowPinning.js';
20
+ export * from './features/RowSelection.js';
21
+ export * from './features/RowSorting.js';
22
+ export * from './utils.js';
23
+ export * from './utils/getCoreRowModel.js';
24
+ export * from './utils/getExpandedRowModel.js';
25
+ export * from './utils/getFacetedMinMaxValues.js';
26
+ export * from './utils/getFacetedRowModel.js';
27
+ export * from './utils/getFacetedUniqueValues.js';
28
+ export * from './utils/getFilteredRowModel.js';
29
+ export * from './utils/getGroupedRowModel.js';
30
+ export * from './utils/getPaginationRowModel.js';
31
+ export * from './utils/getSortedRowModel.js';
32
+ export * from './aggregationFns.js';
33
+ export * from './filterFns.js';
34
+ export * from './sortingFns.js';
@@ -0,0 +1,88 @@
1
+ import { createColumnHelper } from "./columnHelper.js";
2
+ import { _createCell } from "./core/cell.js";
3
+ import { _createColumn } from "./core/column.js";
4
+ import { Headers, buildHeaderGroups } from "./core/headers.js";
5
+ import { _createRow } from "./core/row.js";
6
+ import { _createTable, tableOptions } from "./core/table.js";
7
+ import { ColumnFaceting } from "./features/ColumnFaceting.js";
8
+ import { ColumnFiltering, shouldAutoRemoveFilter } from "./features/ColumnFiltering.js";
9
+ import { ColumnGrouping, orderColumns } from "./features/ColumnGrouping.js";
10
+ import { ColumnOrdering } from "./features/ColumnOrdering.js";
11
+ import { ColumnPinning } from "./features/ColumnPinning.js";
12
+ import { ColumnSizing, defaultColumnSizing, passiveEventSupported } from "./features/ColumnSizing.js";
13
+ import { ColumnVisibility, _getVisibleLeafColumns } from "./features/ColumnVisibility.js";
14
+ import { GlobalFaceting } from "./features/GlobalFaceting.js";
15
+ import { GlobalFiltering } from "./features/GlobalFiltering.js";
16
+ import { RowExpanding } from "./features/RowExpanding.js";
17
+ import { RowPagination } from "./features/RowPagination.js";
18
+ import { RowPinning } from "./features/RowPinning.js";
19
+ import { RowSelection, isRowSelected, isSubRowSelected, selectRowsFn } from "./features/RowSelection.js";
20
+ import { RowSorting } from "./features/RowSorting.js";
21
+ import { flattenBy, functionalUpdate, getMemoOptions, isFunction, isNumberArray, makeStateUpdater, memo, noop } from "./utils.js";
22
+ import { getCoreRowModel } from "./utils/getCoreRowModel.js";
23
+ import { expandRows, getExpandedRowModel } from "./utils/getExpandedRowModel.js";
24
+ import { getFacetedMinMaxValues } from "./utils/getFacetedMinMaxValues.js";
25
+ import { getFacetedRowModel } from "./utils/getFacetedRowModel.js";
26
+ import { getFacetedUniqueValues } from "./utils/getFacetedUniqueValues.js";
27
+ import { getFilteredRowModel } from "./utils/getFilteredRowModel.js";
28
+ import { getGroupedRowModel } from "./utils/getGroupedRowModel.js";
29
+ import { getPaginationRowModel } from "./utils/getPaginationRowModel.js";
30
+ import { getSortedRowModel } from "./utils/getSortedRowModel.js";
31
+ import { aggregationFns } from "./aggregationFns.js";
32
+ import { filterFns } from "./filterFns.js";
33
+ import { reSplitAlphaNumeric, sortingFns } from "./sortingFns.js";
34
+ export {
35
+ ColumnFaceting,
36
+ ColumnFiltering,
37
+ ColumnGrouping,
38
+ ColumnOrdering,
39
+ ColumnPinning,
40
+ ColumnSizing,
41
+ ColumnVisibility,
42
+ GlobalFaceting,
43
+ GlobalFiltering,
44
+ Headers,
45
+ RowExpanding,
46
+ RowPagination,
47
+ RowPinning,
48
+ RowSelection,
49
+ RowSorting,
50
+ _createCell,
51
+ _createColumn,
52
+ _createRow,
53
+ _createTable,
54
+ _getVisibleLeafColumns,
55
+ aggregationFns,
56
+ buildHeaderGroups,
57
+ createColumnHelper,
58
+ defaultColumnSizing,
59
+ expandRows,
60
+ filterFns,
61
+ flattenBy,
62
+ functionalUpdate,
63
+ getCoreRowModel,
64
+ getExpandedRowModel,
65
+ getFacetedMinMaxValues,
66
+ getFacetedRowModel,
67
+ getFacetedUniqueValues,
68
+ getFilteredRowModel,
69
+ getGroupedRowModel,
70
+ getMemoOptions,
71
+ getPaginationRowModel,
72
+ getSortedRowModel,
73
+ isFunction,
74
+ isNumberArray,
75
+ isRowSelected,
76
+ isSubRowSelected,
77
+ makeStateUpdater,
78
+ memo,
79
+ noop,
80
+ orderColumns,
81
+ passiveEventSupported,
82
+ reSplitAlphaNumeric,
83
+ selectRowsFn,
84
+ shouldAutoRemoveFilter,
85
+ sortingFns,
86
+ tableOptions
87
+ };
88
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,4 +1,5 @@
1
- import { SortingFn } from './features/RowSorting';
1
+ import { SortingFn } from './features/RowSorting.js';
2
+
2
3
  export declare const reSplitAlphaNumeric: RegExp;
3
4
  export declare const sortingFns: {
4
5
  alphanumeric: SortingFn<any>;
@@ -0,0 +1,91 @@
1
+ const reSplitAlphaNumeric = /([0-9]+)/gm;
2
+ const alphanumeric = (rowA, rowB, columnId) => {
3
+ return compareAlphanumeric(
4
+ toString(rowA.getValue(columnId)).toLowerCase(),
5
+ toString(rowB.getValue(columnId)).toLowerCase()
6
+ );
7
+ };
8
+ const alphanumericCaseSensitive = (rowA, rowB, columnId) => {
9
+ return compareAlphanumeric(
10
+ toString(rowA.getValue(columnId)),
11
+ toString(rowB.getValue(columnId))
12
+ );
13
+ };
14
+ const text = (rowA, rowB, columnId) => {
15
+ return compareBasic(
16
+ toString(rowA.getValue(columnId)).toLowerCase(),
17
+ toString(rowB.getValue(columnId)).toLowerCase()
18
+ );
19
+ };
20
+ const textCaseSensitive = (rowA, rowB, columnId) => {
21
+ return compareBasic(
22
+ toString(rowA.getValue(columnId)),
23
+ toString(rowB.getValue(columnId))
24
+ );
25
+ };
26
+ const datetime = (rowA, rowB, columnId) => {
27
+ const a = rowA.getValue(columnId);
28
+ const b = rowB.getValue(columnId);
29
+ return a > b ? 1 : a < b ? -1 : 0;
30
+ };
31
+ const basic = (rowA, rowB, columnId) => {
32
+ return compareBasic(rowA.getValue(columnId), rowB.getValue(columnId));
33
+ };
34
+ function compareBasic(a, b) {
35
+ return a === b ? 0 : a > b ? 1 : -1;
36
+ }
37
+ function toString(a) {
38
+ if (typeof a === "number") {
39
+ if (isNaN(a) || a === Infinity || a === -Infinity) {
40
+ return "";
41
+ }
42
+ return String(a);
43
+ }
44
+ if (typeof a === "string") {
45
+ return a;
46
+ }
47
+ return "";
48
+ }
49
+ function compareAlphanumeric(aStr, bStr) {
50
+ const a = aStr.split(reSplitAlphaNumeric).filter(Boolean);
51
+ const b = bStr.split(reSplitAlphaNumeric).filter(Boolean);
52
+ while (a.length && b.length) {
53
+ const aa = a.shift();
54
+ const bb = b.shift();
55
+ const an = parseInt(aa, 10);
56
+ const bn = parseInt(bb, 10);
57
+ const combo = [an, bn].sort();
58
+ if (isNaN(combo[0])) {
59
+ if (aa > bb) {
60
+ return 1;
61
+ }
62
+ if (bb > aa) {
63
+ return -1;
64
+ }
65
+ continue;
66
+ }
67
+ if (isNaN(combo[1])) {
68
+ return isNaN(an) ? -1 : 1;
69
+ }
70
+ if (an > bn) {
71
+ return 1;
72
+ }
73
+ if (bn > an) {
74
+ return -1;
75
+ }
76
+ }
77
+ return a.length - b.length;
78
+ }
79
+ const sortingFns = {
80
+ alphanumeric,
81
+ alphanumericCaseSensitive,
82
+ text,
83
+ textCaseSensitive,
84
+ datetime,
85
+ basic
86
+ };
87
+ export {
88
+ reSplitAlphaNumeric,
89
+ sortingFns
90
+ };
91
+ //# sourceMappingURL=sortingFns.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sortingFns.js","sources":["../../src/sortingFns.ts"],"sourcesContent":["import { SortingFn } from './features/RowSorting'\n\nexport const reSplitAlphaNumeric = /([0-9]+)/gm\n\nconst alphanumeric: SortingFn<any> = (rowA, rowB, columnId) => {\n return compareAlphanumeric(\n toString(rowA.getValue(columnId)).toLowerCase(),\n toString(rowB.getValue(columnId)).toLowerCase()\n )\n}\n\nconst alphanumericCaseSensitive: SortingFn<any> = (rowA, rowB, columnId) => {\n return compareAlphanumeric(\n toString(rowA.getValue(columnId)),\n toString(rowB.getValue(columnId))\n )\n}\n\n// The text filter is more basic (less numeric support)\n// but is much faster\nconst text: SortingFn<any> = (rowA, rowB, columnId) => {\n return compareBasic(\n toString(rowA.getValue(columnId)).toLowerCase(),\n toString(rowB.getValue(columnId)).toLowerCase()\n )\n}\n\n// The text filter is more basic (less numeric support)\n// but is much faster\nconst textCaseSensitive: SortingFn<any> = (rowA, rowB, columnId) => {\n return compareBasic(\n toString(rowA.getValue(columnId)),\n toString(rowB.getValue(columnId))\n )\n}\n\nconst datetime: SortingFn<any> = (rowA, rowB, columnId) => {\n const a = rowA.getValue<Date>(columnId)\n const b = rowB.getValue<Date>(columnId)\n\n // Can handle nullish values\n // Use > and < because == (and ===) doesn't work with\n // Date objects (would require calling getTime()).\n return a > b ? 1 : a < b ? -1 : 0\n}\n\nconst basic: SortingFn<any> = (rowA, rowB, columnId) => {\n return compareBasic(rowA.getValue(columnId), rowB.getValue(columnId))\n}\n\n// Utils\n\nfunction compareBasic(a: any, b: any) {\n return a === b ? 0 : a > b ? 1 : -1\n}\n\nfunction toString(a: any) {\n if (typeof a === 'number') {\n if (isNaN(a) || a === Infinity || a === -Infinity) {\n return ''\n }\n return String(a)\n }\n if (typeof a === 'string') {\n return a\n }\n return ''\n}\n\n// Mixed sorting is slow, but very inclusive of many edge cases.\n// It handles numbers, mixed alphanumeric combinations, and even\n// null, undefined, and Infinity\nfunction compareAlphanumeric(aStr: string, bStr: string) {\n // Split on number groups, but keep the delimiter\n // Then remove falsey split values\n const a = aStr.split(reSplitAlphaNumeric).filter(Boolean)\n const b = bStr.split(reSplitAlphaNumeric).filter(Boolean)\n\n // While\n while (a.length && b.length) {\n const aa = a.shift()!\n const bb = b.shift()!\n\n const an = parseInt(aa, 10)\n const bn = parseInt(bb, 10)\n\n const combo = [an, bn].sort()\n\n // Both are string\n if (isNaN(combo[0]!)) {\n if (aa > bb) {\n return 1\n }\n if (bb > aa) {\n return -1\n }\n continue\n }\n\n // One is a string, one is a number\n if (isNaN(combo[1]!)) {\n return isNaN(an) ? -1 : 1\n }\n\n // Both are numbers\n if (an > bn) {\n return 1\n }\n if (bn > an) {\n return -1\n }\n }\n\n return a.length - b.length\n}\n\n// Exports\n\nexport const sortingFns = {\n alphanumeric,\n alphanumericCaseSensitive,\n text,\n textCaseSensitive,\n datetime,\n basic,\n}\n\nexport type BuiltInSortingFn = keyof typeof sortingFns\n"],"names":[],"mappings":"AAEO,MAAM,sBAAsB;AAEnC,MAAM,eAA+B,CAAC,MAAM,MAAM,aAAa;AACtD,SAAA;AAAA,IACL,SAAS,KAAK,SAAS,QAAQ,CAAC,EAAE,YAAY;AAAA,IAC9C,SAAS,KAAK,SAAS,QAAQ,CAAC,EAAE,YAAY;AAAA,EAAA;AAElD;AAEA,MAAM,4BAA4C,CAAC,MAAM,MAAM,aAAa;AACnE,SAAA;AAAA,IACL,SAAS,KAAK,SAAS,QAAQ,CAAC;AAAA,IAChC,SAAS,KAAK,SAAS,QAAQ,CAAC;AAAA,EAAA;AAEpC;AAIA,MAAM,OAAuB,CAAC,MAAM,MAAM,aAAa;AAC9C,SAAA;AAAA,IACL,SAAS,KAAK,SAAS,QAAQ,CAAC,EAAE,YAAY;AAAA,IAC9C,SAAS,KAAK,SAAS,QAAQ,CAAC,EAAE,YAAY;AAAA,EAAA;AAElD;AAIA,MAAM,oBAAoC,CAAC,MAAM,MAAM,aAAa;AAC3D,SAAA;AAAA,IACL,SAAS,KAAK,SAAS,QAAQ,CAAC;AAAA,IAChC,SAAS,KAAK,SAAS,QAAQ,CAAC;AAAA,EAAA;AAEpC;AAEA,MAAM,WAA2B,CAAC,MAAM,MAAM,aAAa;AACnD,QAAA,IAAI,KAAK,SAAe,QAAQ;AAChC,QAAA,IAAI,KAAK,SAAe,QAAQ;AAKtC,SAAO,IAAI,IAAI,IAAI,IAAI,IAAI,KAAK;AAClC;AAEA,MAAM,QAAwB,CAAC,MAAM,MAAM,aAAa;AAC/C,SAAA,aAAa,KAAK,SAAS,QAAQ,GAAG,KAAK,SAAS,QAAQ,CAAC;AACtE;AAIA,SAAS,aAAa,GAAQ,GAAQ;AACpC,SAAO,MAAM,IAAI,IAAI,IAAI,IAAI,IAAI;AACnC;AAEA,SAAS,SAAS,GAAQ;AACpB,MAAA,OAAO,MAAM,UAAU;AACzB,QAAI,MAAM,CAAC,KAAK,MAAM,YAAY,MAAM,WAAW;AAC1C,aAAA;AAAA,IACT;AACA,WAAO,OAAO,CAAC;AAAA,EACjB;AACI,MAAA,OAAO,MAAM,UAAU;AAClB,WAAA;AAAA,EACT;AACO,SAAA;AACT;AAKA,SAAS,oBAAoB,MAAc,MAAc;AAGvD,QAAM,IAAI,KAAK,MAAM,mBAAmB,EAAE,OAAO,OAAO;AACxD,QAAM,IAAI,KAAK,MAAM,mBAAmB,EAAE,OAAO,OAAO;AAGjD,SAAA,EAAE,UAAU,EAAE,QAAQ;AACrB,UAAA,KAAK,EAAE;AACP,UAAA,KAAK,EAAE;AAEP,UAAA,KAAK,SAAS,IAAI,EAAE;AACpB,UAAA,KAAK,SAAS,IAAI,EAAE;AAE1B,UAAM,QAAQ,CAAC,IAAI,EAAE,EAAE,KAAK;AAG5B,QAAI,MAAM,MAAM,CAAC,CAAE,GAAG;AACpB,UAAI,KAAK,IAAI;AACJ,eAAA;AAAA,MACT;AACA,UAAI,KAAK,IAAI;AACJ,eAAA;AAAA,MACT;AACA;AAAA,IACF;AAGA,QAAI,MAAM,MAAM,CAAC,CAAE,GAAG;AACb,aAAA,MAAM,EAAE,IAAI,KAAK;AAAA,IAC1B;AAGA,QAAI,KAAK,IAAI;AACJ,aAAA;AAAA,IACT;AACA,QAAI,KAAK,IAAI;AACJ,aAAA;AAAA,IACT;AAAA,EACF;AAEO,SAAA,EAAE,SAAS,EAAE;AACtB;AAIO,MAAM,aAAa;AAAA,EACxB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;"}