@react-spectrum/table 3.17.10 → 3.18.0

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 (263) hide show
  1. package/dist/import.mjs +2 -6
  2. package/dist/main.js +8 -12
  3. package/dist/main.js.map +1 -1
  4. package/dist/module.js +2 -6
  5. package/dist/module.js.map +1 -1
  6. package/dist/types/src/index.d.ts +3 -0
  7. package/package.json +14 -52
  8. package/src/index.ts +3 -18
  9. package/dist/DragPreview.main.js +0 -54
  10. package/dist/DragPreview.main.js.map +0 -1
  11. package/dist/DragPreview.mjs +0 -49
  12. package/dist/DragPreview.module.js +0 -49
  13. package/dist/DragPreview.module.js.map +0 -1
  14. package/dist/InsertionIndicator.main.js +0 -64
  15. package/dist/InsertionIndicator.main.js.map +0 -1
  16. package/dist/InsertionIndicator.mjs +0 -59
  17. package/dist/InsertionIndicator.module.js +0 -59
  18. package/dist/InsertionIndicator.module.js.map +0 -1
  19. package/dist/Nubbin.main.js +0 -62
  20. package/dist/Nubbin.main.js.map +0 -1
  21. package/dist/Nubbin.mjs +0 -53
  22. package/dist/Nubbin.module.js +0 -53
  23. package/dist/Nubbin.module.js.map +0 -1
  24. package/dist/Resizer.main.js +0 -150
  25. package/dist/Resizer.main.js.map +0 -1
  26. package/dist/Resizer.mjs +0 -144
  27. package/dist/Resizer.module.js +0 -144
  28. package/dist/Resizer.module.js.map +0 -1
  29. package/dist/RootDropIndicator.main.js +0 -57
  30. package/dist/RootDropIndicator.main.js.map +0 -1
  31. package/dist/RootDropIndicator.mjs +0 -48
  32. package/dist/RootDropIndicator.module.js +0 -48
  33. package/dist/RootDropIndicator.module.js.map +0 -1
  34. package/dist/TableView.main.js +0 -49
  35. package/dist/TableView.main.js.map +0 -1
  36. package/dist/TableView.mjs +0 -40
  37. package/dist/TableView.module.js +0 -40
  38. package/dist/TableView.module.js.map +0 -1
  39. package/dist/TableViewBase.main.js +0 -1239
  40. package/dist/TableViewBase.main.js.map +0 -1
  41. package/dist/TableViewBase.mjs +0 -1232
  42. package/dist/TableViewBase.module.js +0 -1232
  43. package/dist/TableViewBase.module.js.map +0 -1
  44. package/dist/TableViewLayout.main.js +0 -101
  45. package/dist/TableViewLayout.main.js.map +0 -1
  46. package/dist/TableViewLayout.mjs +0 -96
  47. package/dist/TableViewLayout.module.js +0 -96
  48. package/dist/TableViewLayout.module.js.map +0 -1
  49. package/dist/TableViewWrapper.main.js +0 -45
  50. package/dist/TableViewWrapper.main.js.map +0 -1
  51. package/dist/TableViewWrapper.mjs +0 -36
  52. package/dist/TableViewWrapper.module.js +0 -36
  53. package/dist/TableViewWrapper.module.js.map +0 -1
  54. package/dist/TreeGridTableView.main.js +0 -49
  55. package/dist/TreeGridTableView.main.js.map +0 -1
  56. package/dist/TreeGridTableView.mjs +0 -40
  57. package/dist/TreeGridTableView.module.js +0 -40
  58. package/dist/TreeGridTableView.module.js.map +0 -1
  59. package/dist/ar-AE.main.js +0 -14
  60. package/dist/ar-AE.main.js.map +0 -1
  61. package/dist/ar-AE.mjs +0 -16
  62. package/dist/ar-AE.module.js +0 -16
  63. package/dist/ar-AE.module.js.map +0 -1
  64. package/dist/bg-BG.main.js +0 -14
  65. package/dist/bg-BG.main.js.map +0 -1
  66. package/dist/bg-BG.mjs +0 -16
  67. package/dist/bg-BG.module.js +0 -16
  68. package/dist/bg-BG.module.js.map +0 -1
  69. package/dist/cs-CZ.main.js +0 -14
  70. package/dist/cs-CZ.main.js.map +0 -1
  71. package/dist/cs-CZ.mjs +0 -16
  72. package/dist/cs-CZ.module.js +0 -16
  73. package/dist/cs-CZ.module.js.map +0 -1
  74. package/dist/da-DK.main.js +0 -14
  75. package/dist/da-DK.main.js.map +0 -1
  76. package/dist/da-DK.mjs +0 -16
  77. package/dist/da-DK.module.js +0 -16
  78. package/dist/da-DK.module.js.map +0 -1
  79. package/dist/de-DE.main.js +0 -14
  80. package/dist/de-DE.main.js.map +0 -1
  81. package/dist/de-DE.mjs +0 -16
  82. package/dist/de-DE.module.js +0 -16
  83. package/dist/de-DE.module.js.map +0 -1
  84. package/dist/el-GR.main.js +0 -14
  85. package/dist/el-GR.main.js.map +0 -1
  86. package/dist/el-GR.mjs +0 -16
  87. package/dist/el-GR.module.js +0 -16
  88. package/dist/el-GR.module.js.map +0 -1
  89. package/dist/en-US.main.js +0 -14
  90. package/dist/en-US.main.js.map +0 -1
  91. package/dist/en-US.mjs +0 -16
  92. package/dist/en-US.module.js +0 -16
  93. package/dist/en-US.module.js.map +0 -1
  94. package/dist/es-ES.main.js +0 -14
  95. package/dist/es-ES.main.js.map +0 -1
  96. package/dist/es-ES.mjs +0 -16
  97. package/dist/es-ES.module.js +0 -16
  98. package/dist/es-ES.module.js.map +0 -1
  99. package/dist/et-EE.main.js +0 -14
  100. package/dist/et-EE.main.js.map +0 -1
  101. package/dist/et-EE.mjs +0 -16
  102. package/dist/et-EE.module.js +0 -16
  103. package/dist/et-EE.module.js.map +0 -1
  104. package/dist/fi-FI.main.js +0 -14
  105. package/dist/fi-FI.main.js.map +0 -1
  106. package/dist/fi-FI.mjs +0 -16
  107. package/dist/fi-FI.module.js +0 -16
  108. package/dist/fi-FI.module.js.map +0 -1
  109. package/dist/fr-FR.main.js +0 -14
  110. package/dist/fr-FR.main.js.map +0 -1
  111. package/dist/fr-FR.mjs +0 -16
  112. package/dist/fr-FR.module.js +0 -16
  113. package/dist/fr-FR.module.js.map +0 -1
  114. package/dist/he-IL.main.js +0 -14
  115. package/dist/he-IL.main.js.map +0 -1
  116. package/dist/he-IL.mjs +0 -16
  117. package/dist/he-IL.module.js +0 -16
  118. package/dist/he-IL.module.js.map +0 -1
  119. package/dist/hr-HR.main.js +0 -14
  120. package/dist/hr-HR.main.js.map +0 -1
  121. package/dist/hr-HR.mjs +0 -16
  122. package/dist/hr-HR.module.js +0 -16
  123. package/dist/hr-HR.module.js.map +0 -1
  124. package/dist/hu-HU.main.js +0 -14
  125. package/dist/hu-HU.main.js.map +0 -1
  126. package/dist/hu-HU.mjs +0 -16
  127. package/dist/hu-HU.module.js +0 -16
  128. package/dist/hu-HU.module.js.map +0 -1
  129. package/dist/intlStrings.main.js +0 -108
  130. package/dist/intlStrings.main.js.map +0 -1
  131. package/dist/intlStrings.mjs +0 -110
  132. package/dist/intlStrings.module.js +0 -110
  133. package/dist/intlStrings.module.js.map +0 -1
  134. package/dist/it-IT.main.js +0 -14
  135. package/dist/it-IT.main.js.map +0 -1
  136. package/dist/it-IT.mjs +0 -16
  137. package/dist/it-IT.module.js +0 -16
  138. package/dist/it-IT.module.js.map +0 -1
  139. package/dist/ja-JP.main.js +0 -14
  140. package/dist/ja-JP.main.js.map +0 -1
  141. package/dist/ja-JP.mjs +0 -16
  142. package/dist/ja-JP.module.js +0 -16
  143. package/dist/ja-JP.module.js.map +0 -1
  144. package/dist/ko-KR.main.js +0 -14
  145. package/dist/ko-KR.main.js.map +0 -1
  146. package/dist/ko-KR.mjs +0 -16
  147. package/dist/ko-KR.module.js +0 -16
  148. package/dist/ko-KR.module.js.map +0 -1
  149. package/dist/lt-LT.main.js +0 -14
  150. package/dist/lt-LT.main.js.map +0 -1
  151. package/dist/lt-LT.mjs +0 -16
  152. package/dist/lt-LT.module.js +0 -16
  153. package/dist/lt-LT.module.js.map +0 -1
  154. package/dist/lv-LV.main.js +0 -14
  155. package/dist/lv-LV.main.js.map +0 -1
  156. package/dist/lv-LV.mjs +0 -16
  157. package/dist/lv-LV.module.js +0 -16
  158. package/dist/lv-LV.module.js.map +0 -1
  159. package/dist/nb-NO.main.js +0 -14
  160. package/dist/nb-NO.main.js.map +0 -1
  161. package/dist/nb-NO.mjs +0 -16
  162. package/dist/nb-NO.module.js +0 -16
  163. package/dist/nb-NO.module.js.map +0 -1
  164. package/dist/nl-NL.main.js +0 -14
  165. package/dist/nl-NL.main.js.map +0 -1
  166. package/dist/nl-NL.mjs +0 -16
  167. package/dist/nl-NL.module.js +0 -16
  168. package/dist/nl-NL.module.js.map +0 -1
  169. package/dist/pl-PL.main.js +0 -14
  170. package/dist/pl-PL.main.js.map +0 -1
  171. package/dist/pl-PL.mjs +0 -16
  172. package/dist/pl-PL.module.js +0 -16
  173. package/dist/pl-PL.module.js.map +0 -1
  174. package/dist/pt-BR.main.js +0 -14
  175. package/dist/pt-BR.main.js.map +0 -1
  176. package/dist/pt-BR.mjs +0 -16
  177. package/dist/pt-BR.module.js +0 -16
  178. package/dist/pt-BR.module.js.map +0 -1
  179. package/dist/pt-PT.main.js +0 -14
  180. package/dist/pt-PT.main.js.map +0 -1
  181. package/dist/pt-PT.mjs +0 -16
  182. package/dist/pt-PT.module.js +0 -16
  183. package/dist/pt-PT.module.js.map +0 -1
  184. package/dist/ro-RO.main.js +0 -14
  185. package/dist/ro-RO.main.js.map +0 -1
  186. package/dist/ro-RO.mjs +0 -16
  187. package/dist/ro-RO.module.js +0 -16
  188. package/dist/ro-RO.module.js.map +0 -1
  189. package/dist/ru-RU.main.js +0 -14
  190. package/dist/ru-RU.main.js.map +0 -1
  191. package/dist/ru-RU.mjs +0 -16
  192. package/dist/ru-RU.module.js +0 -16
  193. package/dist/ru-RU.module.js.map +0 -1
  194. package/dist/sk-SK.main.js +0 -14
  195. package/dist/sk-SK.main.js.map +0 -1
  196. package/dist/sk-SK.mjs +0 -16
  197. package/dist/sk-SK.module.js +0 -16
  198. package/dist/sk-SK.module.js.map +0 -1
  199. package/dist/sl-SI.main.js +0 -14
  200. package/dist/sl-SI.main.js.map +0 -1
  201. package/dist/sl-SI.mjs +0 -16
  202. package/dist/sl-SI.module.js +0 -16
  203. package/dist/sl-SI.module.js.map +0 -1
  204. package/dist/sr-SP.main.js +0 -14
  205. package/dist/sr-SP.main.js.map +0 -1
  206. package/dist/sr-SP.mjs +0 -16
  207. package/dist/sr-SP.module.js +0 -16
  208. package/dist/sr-SP.module.js.map +0 -1
  209. package/dist/sv-SE.main.js +0 -14
  210. package/dist/sv-SE.main.js.map +0 -1
  211. package/dist/sv-SE.mjs +0 -16
  212. package/dist/sv-SE.module.js +0 -16
  213. package/dist/sv-SE.module.js.map +0 -1
  214. package/dist/table.0cdc494a.css +0 -992
  215. package/dist/table.0cdc494a.css.map +0 -1
  216. package/dist/table.11fc8462.css +0 -220
  217. package/dist/table.11fc8462.css.map +0 -1
  218. package/dist/table_css.main.js +0 -74
  219. package/dist/table_css.main.js.map +0 -1
  220. package/dist/table_css.mjs +0 -76
  221. package/dist/table_css.module.js +0 -76
  222. package/dist/table_css.module.js.map +0 -1
  223. package/dist/table_vars_css.main.js +0 -197
  224. package/dist/table_vars_css.main.js.map +0 -1
  225. package/dist/table_vars_css.mjs +0 -199
  226. package/dist/table_vars_css.module.js +0 -199
  227. package/dist/table_vars_css.module.js.map +0 -1
  228. package/dist/tr-TR.main.js +0 -14
  229. package/dist/tr-TR.main.js.map +0 -1
  230. package/dist/tr-TR.mjs +0 -16
  231. package/dist/tr-TR.module.js +0 -16
  232. package/dist/tr-TR.module.js.map +0 -1
  233. package/dist/types.d.ts +0 -85
  234. package/dist/types.d.ts.map +0 -1
  235. package/dist/uk-UA.main.js +0 -14
  236. package/dist/uk-UA.main.js.map +0 -1
  237. package/dist/uk-UA.mjs +0 -16
  238. package/dist/uk-UA.module.js +0 -16
  239. package/dist/uk-UA.module.js.map +0 -1
  240. package/dist/zh-CN.main.js +0 -14
  241. package/dist/zh-CN.main.js.map +0 -1
  242. package/dist/zh-CN.mjs +0 -16
  243. package/dist/zh-CN.module.js +0 -16
  244. package/dist/zh-CN.module.js.map +0 -1
  245. package/dist/zh-TW.main.js +0 -14
  246. package/dist/zh-TW.main.js.map +0 -1
  247. package/dist/zh-TW.mjs +0 -16
  248. package/dist/zh-TW.module.js +0 -16
  249. package/dist/zh-TW.module.js.map +0 -1
  250. package/src/DragPreview.tsx +0 -77
  251. package/src/InsertionIndicator.tsx +0 -62
  252. package/src/Nubbin.tsx +0 -28
  253. package/src/Resizer.tsx +0 -137
  254. package/src/RootDropIndicator.tsx +0 -40
  255. package/src/TableView.tsx +0 -44
  256. package/src/TableViewBase.tsx +0 -1569
  257. package/src/TableViewLayout.ts +0 -102
  258. package/src/TableViewWrapper.tsx +0 -103
  259. package/src/TreeGridTableView.tsx +0 -44
  260. package/src/cursors/Cur_MoveHorizontal_9_9.svg +0 -10
  261. package/src/cursors/Cur_MoveToLeft_9_9.svg +0 -10
  262. package/src/cursors/Cur_MoveToRight_9_9.svg +0 -10
  263. package/src/table.css +0 -235
@@ -1,1239 +0,0 @@
1
- var $c44674ca7612e997$exports = require("./InsertionIndicator.main.js");
2
- var $1a3d6ad53eb75d54$exports = require("./intlStrings.main.js");
3
- var $18b3deb5c431fa13$exports = require("./Nubbin.main.js");
4
- var $2877766f94c67a67$exports = require("./Resizer.main.js");
5
- var $4a98adf416b1ae5d$exports = require("./RootDropIndicator.main.js");
6
- var $f65d44d222cc509b$exports = require("./DragPreview.main.js");
7
- require("./table.0cdc494a.css");
8
- var $982885d0a34882ea$exports = require("./table_vars_css.main.js");
9
- require("./table.11fc8462.css");
10
- var $4afcd54cfd94dbb9$exports = require("./table_css.main.js");
11
- var $2b402d473779c595$exports = require("./TableViewLayout.main.js");
12
- var $idLTj$spectrumiconsuiArrowDownSmall = require("@spectrum-icons/ui/ArrowDownSmall");
13
- var $idLTj$reactspectrumcheckbox = require("@react-spectrum/checkbox");
14
- var $idLTj$spectrumiconsuiChevronDownMedium = require("@spectrum-icons/ui/ChevronDownMedium");
15
- var $idLTj$spectrumiconsuiChevronLeftMedium = require("@spectrum-icons/ui/ChevronLeftMedium");
16
- var $idLTj$spectrumiconsuiChevronRightMedium = require("@spectrum-icons/ui/ChevronRightMedium");
17
- var $idLTj$reactspectrumutils = require("@react-spectrum/utils");
18
- var $idLTj$reactariafocus = require("@react-aria/focus");
19
- var $idLTj$reactariainteractions = require("@react-aria/interactions");
20
- var $idLTj$reactariautils = require("@react-aria/utils");
21
- var $idLTj$reactspectrummenu = require("@react-spectrum/menu");
22
- var $idLTj$reactstatelyvirtualizer = require("@react-stately/virtualizer");
23
- var $idLTj$reactariavirtualizer = require("@react-aria/virtualizer");
24
- var $idLTj$spectrumiconsuiListGripper = require("@spectrum-icons/ui/ListGripper");
25
- var $idLTj$reactariaselection = require("@react-aria/selection");
26
- var $idLTj$reactspectrumprogress = require("@react-spectrum/progress");
27
- var $idLTj$react = require("react");
28
- var $idLTj$reactstatelytable = require("@react-stately/table");
29
- var $idLTj$reactspectrumtooltip = require("@react-spectrum/tooltip");
30
- var $idLTj$reactariabutton = require("@react-aria/button");
31
- var $idLTj$reactariai18n = require("@react-aria/i18n");
32
- var $idLTj$reactspectrumprovider = require("@react-spectrum/provider");
33
- var $idLTj$reactariatable = require("@react-aria/table");
34
- var $idLTj$reactariavisuallyhidden = require("@react-aria/visually-hidden");
35
-
36
-
37
- function $parcel$interopDefault(a) {
38
- return a && a.__esModule ? a.default : a;
39
- }
40
-
41
- function $parcel$export(e, n, v, s) {
42
- Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
43
- }
44
-
45
- $parcel$export(module.exports, "useTableContext", () => $e39c6de4eb69450d$export$3cb274deb6c2d854);
46
- $parcel$export(module.exports, "useVirtualizerContext", () => $e39c6de4eb69450d$export$3f8f74b6bfd2c5df);
47
- $parcel$export(module.exports, "TableViewBase", () => $e39c6de4eb69450d$export$517e02184d273d69);
48
- /*
49
- * Copyright 2023 Adobe. All rights reserved.
50
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
51
- * you may not use this file except in compliance with the License. You may obtain a copy
52
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
53
- *
54
- * Unless required by applicable law or agreed to in writing, software distributed under
55
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
56
- * OF ANY KIND, either express or implied. See the License for the specific language
57
- * governing permissions and limitations under the License.
58
- */
59
-
60
-
61
-
62
-
63
-
64
-
65
-
66
-
67
-
68
-
69
-
70
-
71
-
72
-
73
-
74
-
75
-
76
-
77
-
78
-
79
-
80
-
81
-
82
-
83
-
84
-
85
-
86
-
87
-
88
-
89
-
90
- const $e39c6de4eb69450d$var$DEFAULT_HEADER_HEIGHT = {
91
- medium: 34,
92
- large: 40
93
- };
94
- const $e39c6de4eb69450d$var$DEFAULT_HIDE_HEADER_CELL_WIDTH = {
95
- medium: 38,
96
- large: 46
97
- };
98
- const $e39c6de4eb69450d$var$ROW_HEIGHTS = {
99
- compact: {
100
- medium: 32,
101
- large: 40
102
- },
103
- regular: {
104
- medium: 40,
105
- large: 50
106
- },
107
- spacious: {
108
- medium: 48,
109
- large: 60
110
- }
111
- };
112
- const $e39c6de4eb69450d$var$SELECTION_CELL_DEFAULT_WIDTH = {
113
- medium: 38,
114
- large: 48
115
- };
116
- const $e39c6de4eb69450d$var$DRAG_BUTTON_CELL_DEFAULT_WIDTH = {
117
- medium: 16,
118
- large: 20
119
- };
120
- const $e39c6de4eb69450d$var$LEVEL_OFFSET_WIDTH = {
121
- medium: 16,
122
- large: 20
123
- };
124
- const $e39c6de4eb69450d$export$93e4b0b2cc49b648 = /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createContext(null);
125
- function $e39c6de4eb69450d$export$3cb274deb6c2d854() {
126
- return (0, $idLTj$react.useContext)($e39c6de4eb69450d$export$93e4b0b2cc49b648);
127
- }
128
- const $e39c6de4eb69450d$export$d288a7dd40372bc = /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createContext(null);
129
- function $e39c6de4eb69450d$export$3f8f74b6bfd2c5df() {
130
- return (0, $idLTj$react.useContext)($e39c6de4eb69450d$export$d288a7dd40372bc);
131
- }
132
- function $e39c6de4eb69450d$var$TableViewBase(props, ref) {
133
- var _dropState_target, _dragAndDropHooks_isVirtualDragging, _dragAndDropHooks_isVirtualDragging1;
134
- props = (0, $idLTj$reactspectrumprovider.useProviderProps)(props);
135
- let { isQuiet: isQuiet, onAction: onAction, onResizeStart: propsOnResizeStart, onResizeEnd: propsOnResizeEnd, dragAndDropHooks: dragAndDropHooks, state: state } = props;
136
- let isTableDraggable = !!(dragAndDropHooks === null || dragAndDropHooks === void 0 ? void 0 : dragAndDropHooks.useDraggableCollectionState);
137
- let isTableDroppable = !!(dragAndDropHooks === null || dragAndDropHooks === void 0 ? void 0 : dragAndDropHooks.useDroppableCollectionState);
138
- let dragHooksProvided = (0, $idLTj$react.useRef)(isTableDraggable);
139
- let dropHooksProvided = (0, $idLTj$react.useRef)(isTableDroppable);
140
- (0, $idLTj$react.useEffect)(()=>{
141
- if (process.env.NODE_ENV === 'production') return;
142
- if (dragHooksProvided.current !== isTableDraggable) console.warn('Drag hooks were provided during one render, but not another. This should be avoided as it may produce unexpected behavior.');
143
- if (dropHooksProvided.current !== isTableDroppable) console.warn('Drop hooks were provided during one render, but not another. This should be avoided as it may produce unexpected behavior.');
144
- if ('expandedKeys' in state && (isTableDraggable || isTableDroppable)) console.warn('Drag and drop is not yet fully supported with expandable rows and may produce unexpected results.');
145
- }, [
146
- isTableDraggable,
147
- isTableDroppable,
148
- state
149
- ]);
150
- let { styleProps: styleProps } = (0, $idLTj$reactspectrumutils.useStyleProps)(props);
151
- let { scale: scale } = (0, $idLTj$reactspectrumprovider.useProvider)();
152
- // Starts when the user selects resize from the menu, ends when resizing ends
153
- // used to control the visibility of the resizer Nubbin
154
- let [isInResizeMode, setIsInResizeMode] = (0, $idLTj$react.useState)(false);
155
- // Starts when the resizer is actually moved
156
- // entering resizing/exiting resizing doesn't trigger a render
157
- // with table layout, so we need to track it here
158
- let [, setIsResizing] = (0, $idLTj$react.useState)(false);
159
- let domRef = (0, $idLTj$reactspectrumutils.useDOMRef)(ref);
160
- let headerRef = (0, $idLTj$react.useRef)(null);
161
- let bodyRef = (0, $idLTj$react.useRef)(null);
162
- let density = props.density || 'regular';
163
- let layout = (0, $idLTj$react.useMemo)(()=>new (0, $2b402d473779c595$exports.TableViewLayout)({
164
- // If props.rowHeight is auto, then use estimated heights based on scale, otherwise use fixed heights.
165
- rowHeight: props.overflowMode === 'wrap' ? undefined : $e39c6de4eb69450d$var$ROW_HEIGHTS[density][scale],
166
- estimatedRowHeight: props.overflowMode === 'wrap' ? $e39c6de4eb69450d$var$ROW_HEIGHTS[density][scale] : undefined,
167
- headingHeight: props.overflowMode === 'wrap' ? undefined : $e39c6de4eb69450d$var$DEFAULT_HEADER_HEIGHT[scale],
168
- estimatedHeadingHeight: props.overflowMode === 'wrap' ? $e39c6de4eb69450d$var$DEFAULT_HEADER_HEIGHT[scale] : undefined
169
- }), // don't recompute when state.collection changes, only used for initial value
170
- [
171
- props.overflowMode,
172
- scale,
173
- density
174
- ]);
175
- let dragState = null;
176
- let preview = (0, $idLTj$react.useRef)(null);
177
- if (isTableDraggable && dragAndDropHooks) {
178
- dragState = dragAndDropHooks.useDraggableCollectionState({
179
- collection: state.collection,
180
- selectionManager: state.selectionManager,
181
- preview: preview
182
- });
183
- dragAndDropHooks.useDraggableCollection({}, dragState, domRef);
184
- }
185
- let DragPreview = dragAndDropHooks === null || dragAndDropHooks === void 0 ? void 0 : dragAndDropHooks.DragPreview;
186
- let dropState = null;
187
- let droppableCollection = null;
188
- let isRootDropTarget = false;
189
- if (isTableDroppable && dragAndDropHooks) {
190
- dropState = dragAndDropHooks.useDroppableCollectionState({
191
- collection: state.collection,
192
- selectionManager: state.selectionManager
193
- });
194
- droppableCollection = dragAndDropHooks.useDroppableCollection({
195
- keyboardDelegate: new (0, $idLTj$reactariaselection.ListKeyboardDelegate)({
196
- collection: state.collection,
197
- disabledKeys: state.selectionManager.disabledKeys,
198
- ref: domRef,
199
- layoutDelegate: layout
200
- }),
201
- dropTargetDelegate: layout
202
- }, dropState, domRef);
203
- isRootDropTarget = dropState.isDropTarget({
204
- type: 'root'
205
- });
206
- }
207
- let { gridProps: gridProps } = (0, $idLTj$reactariatable.useTable)({
208
- ...props,
209
- isVirtualized: true,
210
- layoutDelegate: layout,
211
- onRowAction: onAction,
212
- scrollRef: bodyRef
213
- }, state, domRef);
214
- let [headerMenuOpen, setHeaderMenuOpen] = (0, $idLTj$react.useState)(false);
215
- let [headerRowHovered, setHeaderRowHovered] = (0, $idLTj$react.useState)(false);
216
- // This overrides collection view's renderWrapper to support DOM hierarchy.
217
- let renderWrapper = (0, $idLTj$react.useCallback)((parent, reusableView, children, renderChildren)=>{
218
- var _parent_layoutInfo;
219
- if (reusableView.viewType === 'rowgroup') return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableRowGroup, {
220
- key: reusableView.key,
221
- layoutInfo: reusableView.layoutInfo,
222
- parent: (_parent_layoutInfo = parent === null || parent === void 0 ? void 0 : parent.layoutInfo) !== null && _parent_layoutInfo !== void 0 ? _parent_layoutInfo : null,
223
- // Override the default role="rowgroup" with role="presentation",
224
- // in favor or adding role="rowgroup" to the ScrollView with
225
- // ref={bodyRef} in the TableVirtualizer below.
226
- role: "presentation"
227
- }, renderChildren(children));
228
- var _parent_layoutInfo1;
229
- if (reusableView.viewType === 'header') return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableHeader, {
230
- key: reusableView.key,
231
- layoutInfo: reusableView.layoutInfo,
232
- parent: (_parent_layoutInfo1 = parent === null || parent === void 0 ? void 0 : parent.layoutInfo) !== null && _parent_layoutInfo1 !== void 0 ? _parent_layoutInfo1 : null
233
- }, renderChildren(children));
234
- var _parent_layoutInfo2;
235
- if (reusableView.viewType === 'row') return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableRow, {
236
- key: reusableView.key,
237
- item: reusableView.content,
238
- layoutInfo: reusableView.layoutInfo,
239
- parent: (_parent_layoutInfo2 = parent === null || parent === void 0 ? void 0 : parent.layoutInfo) !== null && _parent_layoutInfo2 !== void 0 ? _parent_layoutInfo2 : null
240
- }, renderChildren(children));
241
- var _parent_layoutInfo3;
242
- if (reusableView.viewType === 'headerrow') return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableHeaderRow, {
243
- onHoverChange: setHeaderRowHovered,
244
- key: reusableView.key,
245
- layoutInfo: reusableView.layoutInfo,
246
- parent: (_parent_layoutInfo3 = parent === null || parent === void 0 ? void 0 : parent.layoutInfo) !== null && _parent_layoutInfo3 !== void 0 ? _parent_layoutInfo3 : null,
247
- item: reusableView.content
248
- }, renderChildren(children));
249
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableCellWrapper, {
250
- key: reusableView.key,
251
- layoutInfo: reusableView.layoutInfo,
252
- virtualizer: reusableView.virtualizer,
253
- parent: parent
254
- }, reusableView.rendered);
255
- }, []);
256
- let renderView = (0, $idLTj$react.useCallback)((type, item)=>{
257
- switch(type){
258
- case 'header':
259
- case 'rowgroup':
260
- case 'section':
261
- case 'row':
262
- case 'headerrow':
263
- return null;
264
- case 'cell':
265
- if (item.props.isSelectionCell) return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableCheckboxCell, {
266
- cell: item
267
- });
268
- if (item.props.isDragButtonCell) return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableDragCell, {
269
- cell: item
270
- });
271
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableCell, {
272
- cell: item
273
- });
274
- case 'placeholder':
275
- // TODO: move to react-aria?
276
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
277
- role: "gridcell",
278
- "aria-colindex": item.index + 1,
279
- "aria-colspan": item.colSpan != null && item.colSpan > 1 ? item.colSpan : undefined
280
- });
281
- case 'column':
282
- if (item.props.isSelectionCell) return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableSelectAllCell, {
283
- column: item
284
- });
285
- if (item.props.isDragButtonCell) return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableDragHeaderCell, {
286
- column: item
287
- });
288
- // TODO: consider this case, what if we have hidden headers and a empty table
289
- if (item.props.hideHeader) return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrumtooltip.TooltipTrigger), {
290
- placement: "top",
291
- trigger: "focus"
292
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableColumnHeader, {
293
- column: item
294
- }), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrumtooltip.Tooltip), {
295
- placement: "top"
296
- }, item.rendered));
297
- if (item.props.allowsResizing && !item.hasChildNodes) return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$ResizableTableColumnHeader, {
298
- column: item
299
- });
300
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableColumnHeader, {
301
- column: item
302
- });
303
- case 'loader':
304
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$LoadingState, null);
305
- case 'empty':
306
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$EmptyState, null);
307
- }
308
- return null;
309
- }, []);
310
- let [isVerticalScrollbarVisible, setVerticalScollbarVisible] = (0, $idLTj$react.useState)(false);
311
- let [isHorizontalScrollbarVisible, setHorizontalScollbarVisible] = (0, $idLTj$react.useState)(false);
312
- let viewport = (0, $idLTj$react.useRef)({
313
- x: 0,
314
- y: 0,
315
- width: 0,
316
- height: 0
317
- });
318
- let onVisibleRectChange = (0, $idLTj$react.useCallback)((e)=>{
319
- if (viewport.current.width === e.width && viewport.current.height === e.height) return;
320
- viewport.current = e;
321
- if (bodyRef.current) {
322
- setVerticalScollbarVisible(bodyRef.current.clientWidth + 2 < bodyRef.current.offsetWidth);
323
- setHorizontalScollbarVisible(bodyRef.current.clientHeight + 2 < bodyRef.current.offsetHeight);
324
- }
325
- }, []);
326
- let { isFocusVisible: isFocusVisible, focusProps: focusProps } = (0, $idLTj$reactariafocus.useFocusRing)();
327
- let isEmpty = state.collection.size === 0;
328
- let onFocusedResizer = ()=>{
329
- if (bodyRef.current && headerRef.current) bodyRef.current.scrollLeft = headerRef.current.scrollLeft;
330
- };
331
- let onResizeStart = (0, $idLTj$react.useCallback)((widths)=>{
332
- setIsResizing(true);
333
- propsOnResizeStart === null || propsOnResizeStart === void 0 ? void 0 : propsOnResizeStart(widths);
334
- }, [
335
- setIsResizing,
336
- propsOnResizeStart
337
- ]);
338
- let onResizeEnd = (0, $idLTj$react.useCallback)((widths)=>{
339
- setIsInResizeMode(false);
340
- setIsResizing(false);
341
- propsOnResizeEnd === null || propsOnResizeEnd === void 0 ? void 0 : propsOnResizeEnd(widths);
342
- }, [
343
- propsOnResizeEnd,
344
- setIsInResizeMode,
345
- setIsResizing
346
- ]);
347
- let focusedKey = state.selectionManager.focusedKey;
348
- let dropTargetKey = null;
349
- if ((dropState === null || dropState === void 0 ? void 0 : (_dropState_target = dropState.target) === null || _dropState_target === void 0 ? void 0 : _dropState_target.type) === 'item') {
350
- dropTargetKey = dropState.target.key;
351
- if (dropState.target.dropPosition === 'before' && dropTargetKey !== state.collection.getFirstKey()) // Normalize to the "after" drop position since we only render those in the DOM.
352
- // The exception to this is for the first row in the table, where we also render the "before" position.
353
- dropTargetKey = state.collection.getKeyBefore(dropTargetKey);
354
- }
355
- let persistedKeys = (0, $idLTj$react.useMemo)(()=>{
356
- return new Set([
357
- focusedKey,
358
- dropTargetKey
359
- ].filter((k)=>k !== null));
360
- }, [
361
- focusedKey,
362
- dropTargetKey
363
- ]);
364
- let mergedProps = (0, $idLTj$reactariautils.mergeProps)(isTableDroppable ? droppableCollection === null || droppableCollection === void 0 ? void 0 : droppableCollection.collectionProps : null, gridProps, focusProps);
365
- if (dragAndDropHooks === null || dragAndDropHooks === void 0 ? void 0 : (_dragAndDropHooks_isVirtualDragging = dragAndDropHooks.isVirtualDragging) === null || _dragAndDropHooks_isVirtualDragging === void 0 ? void 0 : _dragAndDropHooks_isVirtualDragging.call(dragAndDropHooks)) mergedProps.tabIndex = undefined;
366
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$export$93e4b0b2cc49b648.Provider, {
367
- value: {
368
- state: state,
369
- dragState: dragState,
370
- dropState: dropState,
371
- dragAndDropHooks: dragAndDropHooks,
372
- isTableDraggable: isTableDraggable,
373
- isTableDroppable: isTableDroppable,
374
- layout: layout,
375
- onResizeStart: onResizeStart,
376
- onResize: props.onResize,
377
- onResizeEnd: onResizeEnd,
378
- headerRowHovered: headerRowHovered,
379
- isInResizeMode: isInResizeMode,
380
- setIsInResizeMode: setIsInResizeMode,
381
- isEmpty: isEmpty,
382
- onFocusedResizer: onFocusedResizer,
383
- headerMenuOpen: headerMenuOpen,
384
- setHeaderMenuOpen: setHeaderMenuOpen,
385
- renderEmptyState: props.renderEmptyState
386
- }
387
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableVirtualizer, {
388
- ...mergedProps,
389
- ...styleProps,
390
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table', `spectrum-Table--${density}`, {
391
- 'spectrum-Table--quiet': isQuiet,
392
- 'spectrum-Table--wrap': props.overflowMode === 'wrap',
393
- 'spectrum-Table--loadingMore': state.collection.body.props.loadingState === 'loadingMore',
394
- 'spectrum-Table--isVerticalScrollbarVisible': isVerticalScrollbarVisible,
395
- 'spectrum-Table--isHorizontalScrollbarVisible': isHorizontalScrollbarVisible
396
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table'), styleProps.className),
397
- tableState: state,
398
- layout: layout,
399
- collection: state.collection,
400
- persistedKeys: persistedKeys,
401
- renderView: renderView,
402
- renderWrapper: renderWrapper,
403
- onVisibleRectChange: onVisibleRectChange,
404
- domRef: domRef,
405
- headerRef: headerRef,
406
- bodyRef: bodyRef,
407
- isFocusVisible: isFocusVisible,
408
- isVirtualDragging: (dragAndDropHooks === null || dragAndDropHooks === void 0 ? void 0 : (_dragAndDropHooks_isVirtualDragging1 = dragAndDropHooks.isVirtualDragging) === null || _dragAndDropHooks_isVirtualDragging1 === void 0 ? void 0 : _dragAndDropHooks_isVirtualDragging1.call(dragAndDropHooks)) || false,
409
- isRootDropTarget: isRootDropTarget
410
- }), DragPreview && isTableDraggable && dragAndDropHooks && dragState && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement(DragPreview, {
411
- ref: preview
412
- }, ()=>{
413
- if (dragState.draggedKey == null) return null;
414
- if (dragAndDropHooks.renderPreview) return dragAndDropHooks.renderPreview(dragState.draggingKeys, dragState.draggedKey);
415
- let itemCount = dragState.draggingKeys.size;
416
- let maxWidth = bodyRef.current.getBoundingClientRect().width;
417
- let height = $e39c6de4eb69450d$var$ROW_HEIGHTS[density][scale];
418
- let itemText = state.collection.getTextValue(dragState.draggedKey);
419
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $f65d44d222cc509b$exports.DragPreview), {
420
- itemText: itemText,
421
- itemCount: itemCount,
422
- height: height,
423
- maxWidth: maxWidth
424
- });
425
- }));
426
- }
427
- // This is a custom Virtualizer that also has a header that syncs its scroll position with the body.
428
- function $e39c6de4eb69450d$var$TableVirtualizer(props) {
429
- var _layout_getLayoutInfo;
430
- let { tableState: tableState, layout: layout, collection: collection, persistedKeys: persistedKeys, renderView: renderView, renderWrapper: renderWrapper, domRef: domRef, bodyRef: bodyRef, headerRef: headerRef, onVisibleRectChange: onVisibleRectChangeProp, isFocusVisible: isFocusVisible, isVirtualDragging: isVirtualDragging, isRootDropTarget: isRootDropTarget, ...otherProps } = props;
431
- let { direction: direction } = (0, $idLTj$reactariai18n.useLocale)();
432
- let loadingState = collection.body.props.loadingState;
433
- let isLoading = loadingState === 'loading' || loadingState === 'loadingMore';
434
- let onLoadMore = collection.body.props.onLoadMore;
435
- let [tableWidth, setTableWidth] = (0, $idLTj$react.useState)(0);
436
- let { scale: scale } = (0, $idLTj$reactspectrumprovider.useProvider)();
437
- const getDefaultWidth = (0, $idLTj$react.useCallback)(({ props: { hideHeader: hideHeader, isSelectionCell: isSelectionCell, showDivider: showDivider, isDragButtonCell: isDragButtonCell } })=>{
438
- if (hideHeader) {
439
- let width = $e39c6de4eb69450d$var$DEFAULT_HIDE_HEADER_CELL_WIDTH[scale];
440
- return showDivider ? width + 1 : width;
441
- } else if (isSelectionCell) return $e39c6de4eb69450d$var$SELECTION_CELL_DEFAULT_WIDTH[scale];
442
- else if (isDragButtonCell) return $e39c6de4eb69450d$var$DRAG_BUTTON_CELL_DEFAULT_WIDTH[scale];
443
- }, [
444
- scale
445
- ]);
446
- const getDefaultMinWidth = (0, $idLTj$react.useCallback)(({ props: { hideHeader: hideHeader, isSelectionCell: isSelectionCell, showDivider: showDivider, isDragButtonCell: isDragButtonCell } })=>{
447
- if (hideHeader) {
448
- let width = $e39c6de4eb69450d$var$DEFAULT_HIDE_HEADER_CELL_WIDTH[scale];
449
- return showDivider ? width + 1 : width;
450
- } else if (isSelectionCell) return $e39c6de4eb69450d$var$SELECTION_CELL_DEFAULT_WIDTH[scale];
451
- else if (isDragButtonCell) return $e39c6de4eb69450d$var$DRAG_BUTTON_CELL_DEFAULT_WIDTH[scale];
452
- return 75;
453
- }, [
454
- scale
455
- ]);
456
- let columnResizeState = (0, $idLTj$reactstatelytable.useTableColumnResizeState)({
457
- tableWidth: tableWidth,
458
- getDefaultWidth: getDefaultWidth,
459
- getDefaultMinWidth: getDefaultMinWidth
460
- }, tableState);
461
- let state = (0, $idLTj$reactstatelyvirtualizer.useVirtualizerState)({
462
- layout: layout,
463
- collection: collection,
464
- renderView: renderView,
465
- onVisibleRectChange (rect) {
466
- if (bodyRef.current) {
467
- bodyRef.current.scrollTop = rect.y;
468
- (0, $idLTj$reactariavirtualizer.setScrollLeft)(bodyRef.current, direction, rect.x);
469
- }
470
- },
471
- persistedKeys: persistedKeys,
472
- layoutOptions: (0, $idLTj$react.useMemo)(()=>({
473
- columnWidths: columnResizeState.columnWidths
474
- }), [
475
- columnResizeState.columnWidths
476
- ])
477
- });
478
- (0, $idLTj$reactariautils.useLoadMore)({
479
- isLoading: isLoading,
480
- onLoadMore: onLoadMore,
481
- scrollOffset: 1
482
- }, bodyRef);
483
- let onVisibleRectChange = (0, $idLTj$react.useCallback)((rect)=>{
484
- state.setVisibleRect(rect);
485
- }, [
486
- state
487
- ]);
488
- let onVisibleRectChangeMemo = (0, $idLTj$react.useCallback)((rect)=>{
489
- setTableWidth(rect.width);
490
- onVisibleRectChange(rect);
491
- onVisibleRectChangeProp(rect);
492
- }, [
493
- onVisibleRectChange,
494
- onVisibleRectChangeProp
495
- ]);
496
- // this effect runs whenever the contentSize changes, it doesn't matter what the content size is
497
- // only that it changes in a resize, and when that happens, we want to sync the body to the
498
- // header scroll position
499
- (0, $idLTj$react.useEffect)(()=>{
500
- if ((0, $idLTj$reactariainteractions.getInteractionModality)() === 'keyboard' && headerRef.current && (0, $idLTj$reactariautils.nodeContains)(headerRef.current, document.activeElement) && bodyRef.current) {
501
- (0, $idLTj$reactariautils.scrollIntoView)(headerRef.current, document.activeElement);
502
- (0, $idLTj$reactariautils.scrollIntoViewport)(document.activeElement, {
503
- containingElement: domRef.current
504
- });
505
- bodyRef.current.scrollLeft = headerRef.current.scrollLeft;
506
- }
507
- }, [
508
- state.contentSize,
509
- headerRef,
510
- bodyRef,
511
- domRef
512
- ]);
513
- let headerHeight = ((_layout_getLayoutInfo = layout.getLayoutInfo('header')) === null || _layout_getLayoutInfo === void 0 ? void 0 : _layout_getLayoutInfo.rect.height) || 0;
514
- // Sync the scroll position from the table body to the header container.
515
- let onScroll = (0, $idLTj$react.useCallback)(()=>{
516
- if (headerRef.current && bodyRef.current) headerRef.current.scrollLeft = bodyRef.current.scrollLeft;
517
- }, [
518
- bodyRef,
519
- headerRef
520
- ]);
521
- let resizerPosition = columnResizeState.resizingColumn != null ? layout.getLayoutInfo(columnResizeState.resizingColumn).rect.maxX - 2 : 0;
522
- let resizerAtEdge = resizerPosition > Math.max(state.virtualizer.contentSize.width, state.virtualizer.visibleRect.width) - 3;
523
- // this should be fine, every movement of the resizer causes a rerender
524
- // scrolling can cause it to lag for a moment, but it's always updated
525
- let resizerInVisibleRegion = resizerPosition < state.virtualizer.visibleRect.maxX;
526
- let shouldHardCornerResizeCorner = resizerAtEdge && resizerInVisibleRegion;
527
- // minimize re-render caused on Resizers by memoing this
528
- let resizingColumnWidth = columnResizeState.resizingColumn != null ? columnResizeState.getColumnWidth(columnResizeState.resizingColumn) : 0;
529
- let resizingColumn = (0, $idLTj$react.useMemo)(()=>({
530
- width: resizingColumnWidth,
531
- key: columnResizeState.resizingColumn
532
- }), [
533
- resizingColumnWidth,
534
- columnResizeState.resizingColumn
535
- ]);
536
- if (isVirtualDragging) otherProps.tabIndex = undefined;
537
- let firstColumn = collection.columns[0];
538
- let scrollPadding = 0;
539
- if (firstColumn.props.isSelectionCell || firstColumn.props.isDragButtonCell) scrollPadding = columnResizeState.getColumnWidth(firstColumn.key);
540
- let visibleViews = $e39c6de4eb69450d$var$renderChildren(null, state.visibleViews, renderWrapper);
541
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$export$d288a7dd40372bc.Provider, {
542
- value: resizingColumn
543
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusScope), null, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
544
- ...otherProps,
545
- ref: domRef
546
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
547
- role: "presentation",
548
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headWrapper'),
549
- style: {
550
- height: headerHeight,
551
- overflow: 'hidden',
552
- position: 'relative',
553
- willChange: state.isScrolling ? 'scroll-position' : undefined,
554
- scrollPaddingInlineStart: scrollPadding
555
- },
556
- ref: headerRef
557
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $2877766f94c67a67$exports.ResizeStateContext).Provider, {
558
- value: columnResizeState
559
- }, visibleViews[0])), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariavirtualizer.ScrollView), {
560
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-body', {
561
- 'focus-ring': isFocusVisible,
562
- 'spectrum-Table-body--resizerAtTableEdge': shouldHardCornerResizeCorner
563
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-body', {
564
- 'react-spectrum-Table-body--dropTarget': !!isRootDropTarget
565
- })),
566
- // Firefox and Chrome make generic elements using CSS overflow 'scroll' or 'auto' tabbable,
567
- // including them within the accessibility tree, which breaks the table structure in Firefox.
568
- // Using tabIndex={-1} prevents the ScrollView from being tabbable, and using role="rowgroup"
569
- // here and role="presentation" on the table body content fixes the table structure.
570
- role: "rowgroup",
571
- tabIndex: isVirtualDragging ? undefined : -1,
572
- style: {
573
- flex: 1,
574
- scrollPaddingInlineStart: scrollPadding
575
- },
576
- innerStyle: {
577
- overflow: 'visible'
578
- },
579
- ref: bodyRef,
580
- contentSize: state.contentSize,
581
- onVisibleRectChange: onVisibleRectChangeMemo,
582
- onScrollStart: state.startScrolling,
583
- onScrollEnd: state.endScrolling,
584
- onScroll: onScroll
585
- }, visibleViews[1], /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
586
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-bodyResizeIndicator'),
587
- style: {
588
- [direction === 'ltr' ? 'left' : 'right']: `${resizerPosition}px`,
589
- height: `${Math.max(state.virtualizer.contentSize.height, state.virtualizer.visibleRect.height)}px`,
590
- display: columnResizeState.resizingColumn ? 'block' : 'none'
591
- }
592
- })))));
593
- }
594
- function $e39c6de4eb69450d$var$renderChildren(parent, views, renderWrapper) {
595
- return views.map((view)=>{
596
- return renderWrapper(parent, view, view.children ? Array.from(view.children) : [], (childViews)=>$e39c6de4eb69450d$var$renderChildren(view, childViews, renderWrapper));
597
- });
598
- }
599
- function $e39c6de4eb69450d$var$useStyle(layoutInfo, parent) {
600
- let { direction: direction } = (0, $idLTj$reactariai18n.useLocale)();
601
- let style = (0, $idLTj$reactariavirtualizer.layoutInfoToStyle)(layoutInfo, direction, parent);
602
- if (style.overflow === 'hidden') style.overflow = 'visible'; // needed to support position: sticky
603
- return style;
604
- }
605
- function $e39c6de4eb69450d$var$TableHeader({ children: children, layoutInfo: layoutInfo, parent: parent, ...otherProps }) {
606
- let { rowGroupProps: rowGroupProps } = (0, $idLTj$reactariatable.useTableRowGroup)();
607
- let style = $e39c6de4eb69450d$var$useStyle(layoutInfo, parent);
608
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
609
- ...rowGroupProps,
610
- ...otherProps,
611
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-head'),
612
- style: style
613
- }, children);
614
- }
615
- function $e39c6de4eb69450d$var$TableColumnHeader(props) {
616
- var _state_sortDescriptor, _state_sortDescriptor1, _state_sortDescriptor2, _state_sortDescriptor3;
617
- let { column: column } = props;
618
- let ref = (0, $idLTj$react.useRef)(null);
619
- let { state: state, isEmpty: isEmpty } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
620
- let { pressProps: pressProps, isPressed: isPressed } = (0, $idLTj$reactariainteractions.usePress)({
621
- isDisabled: isEmpty
622
- });
623
- let columnProps = column.props;
624
- (0, $idLTj$react.useEffect)(()=>{
625
- if (column.hasChildNodes && columnProps.allowsResizing && process.env.NODE_ENV !== 'production') console.warn(`Column key: ${column.key}. Columns with child columns don't allow resizing.`);
626
- }, [
627
- column.hasChildNodes,
628
- column.key,
629
- columnProps.allowsResizing
630
- ]);
631
- let { columnHeaderProps: columnHeaderProps } = (0, $idLTj$reactariatable.useTableColumnHeader)({
632
- node: column,
633
- isVirtualized: true
634
- }, state, ref);
635
- let { hoverProps: hoverProps, isHovered: isHovered } = (0, $idLTj$reactariainteractions.useHover)({
636
- ...props,
637
- isDisabled: isEmpty
638
- });
639
- const allProps = [
640
- columnHeaderProps,
641
- hoverProps,
642
- pressProps
643
- ];
644
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
645
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'focus-ring')
646
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
647
- ...(0, $idLTj$reactariautils.mergeProps)(...allProps),
648
- ref: ref,
649
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headCell', {
650
- 'is-active': isPressed,
651
- 'is-sortable': columnProps.allowsSorting,
652
- 'is-sorted-desc': ((_state_sortDescriptor = state.sortDescriptor) === null || _state_sortDescriptor === void 0 ? void 0 : _state_sortDescriptor.column) === column.key && ((_state_sortDescriptor1 = state.sortDescriptor) === null || _state_sortDescriptor1 === void 0 ? void 0 : _state_sortDescriptor1.direction) === 'descending',
653
- 'is-sorted-asc': ((_state_sortDescriptor2 = state.sortDescriptor) === null || _state_sortDescriptor2 === void 0 ? void 0 : _state_sortDescriptor2.column) === column.key && ((_state_sortDescriptor3 = state.sortDescriptor) === null || _state_sortDescriptor3 === void 0 ? void 0 : _state_sortDescriptor3.direction) === 'ascending',
654
- 'is-hovered': isHovered,
655
- 'spectrum-Table-cell--hideHeader': columnProps.hideHeader
656
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-cell', {
657
- 'react-spectrum-Table-cell--alignCenter': columnProps.align === 'center' || column.colSpan > 1,
658
- 'react-spectrum-Table-cell--alignEnd': columnProps.align === 'end'
659
- }))
660
- }, columnProps.allowsSorting && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, ($parcel$interopDefault($idLTj$spectrumiconsuiArrowDownSmall))), {
661
- UNSAFE_className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-sortedIcon')
662
- }), columnProps.hideHeader ? /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariavisuallyhidden.VisuallyHidden), null, column.rendered) : /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
663
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headCellContents')
664
- }, column.rendered)));
665
- }
666
- let $e39c6de4eb69450d$var$ForwardTableColumnHeaderButton = (props, ref)=>{
667
- let { focusProps: focusProps, alignment: alignment, ...otherProps } = props;
668
- let { isEmpty: isEmpty } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
669
- let domRef = (0, $idLTj$reactspectrumutils.useFocusableRef)(ref);
670
- let { buttonProps: buttonProps } = (0, $idLTj$reactariabutton.useButton)({
671
- ...otherProps,
672
- elementType: 'div',
673
- isDisabled: isEmpty
674
- }, domRef);
675
- let { hoverProps: hoverProps, isHovered: isHovered } = (0, $idLTj$reactariainteractions.useHover)({
676
- ...otherProps,
677
- isDisabled: isEmpty
678
- });
679
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
680
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headCellContents', {
681
- 'is-hovered': isHovered
682
- }),
683
- ...hoverProps
684
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
685
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headCellButton', {
686
- 'spectrum-Table-headCellButton--alignStart': alignment === 'start',
687
- 'spectrum-Table-headCellButton--alignCenter': alignment === 'center',
688
- 'spectrum-Table-headCellButton--alignEnd': alignment === 'end'
689
- }),
690
- ...(0, $idLTj$reactariautils.mergeProps)(buttonProps, focusProps),
691
- ref: domRef
692
- }, props.children));
693
- };
694
- let $e39c6de4eb69450d$var$TableColumnHeaderButton = /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).forwardRef($e39c6de4eb69450d$var$ForwardTableColumnHeaderButton);
695
- function $e39c6de4eb69450d$var$ResizableTableColumnHeader(props) {
696
- var _column_props, _state_sortDescriptor, _state_sortDescriptor1, _state_sortDescriptor2, _state_sortDescriptor3;
697
- let { column: column } = props;
698
- let ref = (0, $idLTj$react.useRef)(null);
699
- let triggerRef = (0, $idLTj$react.useRef)(null);
700
- let resizingRef = (0, $idLTj$react.useRef)(null);
701
- let { state: state, onResizeStart: onResizeStart, onResize: onResize, onResizeEnd: onResizeEnd, headerRowHovered: headerRowHovered, setIsInResizeMode: setIsInResizeMode, isEmpty: isEmpty, isInResizeMode: isInResizeMode, headerMenuOpen: headerMenuOpen, setHeaderMenuOpen: setHeaderMenuOpen } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
702
- let columnResizeState = (0, $idLTj$react.useContext)((0, $2877766f94c67a67$exports.ResizeStateContext));
703
- let stringFormatter = (0, $idLTj$reactariai18n.useLocalizedStringFormatter)((0, ($parcel$interopDefault($1a3d6ad53eb75d54$exports))), '@react-spectrum/table');
704
- let { pressProps: pressProps, isPressed: isPressed } = (0, $idLTj$reactariainteractions.usePress)({
705
- isDisabled: isEmpty
706
- });
707
- let { columnHeaderProps: columnHeaderProps } = (0, $idLTj$reactariatable.useTableColumnHeader)({
708
- node: column,
709
- isVirtualized: true
710
- }, state, ref);
711
- let { hoverProps: hoverProps, isHovered: isHovered } = (0, $idLTj$reactariainteractions.useHover)({
712
- ...props,
713
- isDisabled: isEmpty || headerMenuOpen
714
- });
715
- const allProps = [
716
- columnHeaderProps,
717
- pressProps,
718
- hoverProps
719
- ];
720
- let columnProps = column.props;
721
- let { isFocusVisible: isFocusVisible, focusProps: focusProps } = (0, $idLTj$reactariafocus.useFocusRing)();
722
- const onMenuSelect = (key)=>{
723
- switch(key){
724
- case 'sort-asc':
725
- state.sort(column.key, 'ascending');
726
- break;
727
- case 'sort-desc':
728
- state.sort(column.key, 'descending');
729
- break;
730
- case 'resize':
731
- columnResizeState.startResize(column.key);
732
- setIsInResizeMode(true);
733
- state.setKeyboardNavigationDisabled(true);
734
- break;
735
- }
736
- };
737
- let allowsSorting = (_column_props = column.props) === null || _column_props === void 0 ? void 0 : _column_props.allowsSorting;
738
- let items = (0, $idLTj$react.useMemo)(()=>{
739
- let options = [];
740
- if (allowsSorting) {
741
- options.push({
742
- label: stringFormatter.format('sortAscending'),
743
- id: 'sort-asc'
744
- });
745
- options.push({
746
- label: stringFormatter.format('sortDescending'),
747
- id: 'sort-desc'
748
- });
749
- }
750
- options.push({
751
- label: stringFormatter.format('resizeColumn'),
752
- id: 'resize'
753
- });
754
- return options;
755
- // eslint-disable-next-line react-hooks/exhaustive-deps
756
- }, [
757
- allowsSorting
758
- ]);
759
- let resizingColumn = columnResizeState.resizingColumn;
760
- let showResizer = !isEmpty && (headerRowHovered && (0, $idLTj$reactariainteractions.getInteractionModality)() !== 'keyboard' || resizingColumn != null);
761
- let alignment = 'start';
762
- let menuAlign = 'start';
763
- if (columnProps.align === 'center' || column.colSpan > 1) alignment = 'center';
764
- else if (columnProps.align === 'end') {
765
- alignment = 'end';
766
- menuAlign = 'end';
767
- }
768
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
769
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'focus-ring')
770
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
771
- ...(0, $idLTj$reactariautils.mergeProps)(...allProps),
772
- ref: ref,
773
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headCell', {
774
- 'is-active': isPressed,
775
- 'is-resizable': columnProps.allowsResizing,
776
- 'is-sortable': columnProps.allowsSorting,
777
- 'is-sorted-desc': ((_state_sortDescriptor = state.sortDescriptor) === null || _state_sortDescriptor === void 0 ? void 0 : _state_sortDescriptor.column) === column.key && ((_state_sortDescriptor1 = state.sortDescriptor) === null || _state_sortDescriptor1 === void 0 ? void 0 : _state_sortDescriptor1.direction) === 'descending',
778
- 'is-sorted-asc': ((_state_sortDescriptor2 = state.sortDescriptor) === null || _state_sortDescriptor2 === void 0 ? void 0 : _state_sortDescriptor2.column) === column.key && ((_state_sortDescriptor3 = state.sortDescriptor) === null || _state_sortDescriptor3 === void 0 ? void 0 : _state_sortDescriptor3.direction) === 'ascending',
779
- 'is-hovered': isHovered,
780
- 'focus-ring': isFocusVisible,
781
- 'spectrum-Table-cell--hideHeader': columnProps.hideHeader
782
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-cell', {
783
- 'react-spectrum-Table-cell--alignCenter': alignment === 'center',
784
- 'react-spectrum-Table-cell--alignEnd': alignment === 'end'
785
- }))
786
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrummenu.MenuTrigger), {
787
- onOpenChange: setHeaderMenuOpen,
788
- align: menuAlign
789
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableColumnHeaderButton, {
790
- alignment: alignment,
791
- ref: triggerRef,
792
- focusProps: focusProps
793
- }, columnProps.allowsSorting && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, ($parcel$interopDefault($idLTj$spectrumiconsuiArrowDownSmall))), {
794
- UNSAFE_className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-sortedIcon')
795
- }), columnProps.hideHeader ? /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariavisuallyhidden.VisuallyHidden), null, column.rendered) : /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
796
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headerCellText')
797
- }, column.rendered), columnProps.allowsResizing && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, ($parcel$interopDefault($idLTj$spectrumiconsuiChevronDownMedium))), {
798
- UNSAFE_className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-menuChevron')
799
- })), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrummenu.Menu), {
800
- onAction: onMenuSelect,
801
- minWidth: "size-2000",
802
- items: items
803
- }, (item)=>/*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrummenu.Item), null, item.label))), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $2877766f94c67a67$exports.Resizer), {
804
- ref: resizingRef,
805
- column: column,
806
- showResizer: showResizer,
807
- onResizeStart: onResizeStart,
808
- onResize: onResize,
809
- onResizeEnd: onResizeEnd,
810
- triggerRef: (0, $idLTj$reactspectrumutils.useUnwrapDOMRef)(triggerRef)
811
- }), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
812
- "aria-hidden": true,
813
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-colResizeIndicator', {
814
- 'spectrum-Table-colResizeIndicator--visible': resizingColumn != null,
815
- 'spectrum-Table-colResizeIndicator--resizing': resizingColumn === column.key
816
- })
817
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
818
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-colResizeNubbin', {
819
- 'spectrum-Table-colResizeNubbin--visible': isInResizeMode && resizingColumn === column.key
820
- })
821
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $18b3deb5c431fa13$exports.Nubbin), null)))));
822
- }
823
- function $e39c6de4eb69450d$var$TableSelectAllCell({ column: column }) {
824
- let ref = (0, $idLTj$react.useRef)(null);
825
- let { state: state } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
826
- let isSingleSelectionMode = state.selectionManager.selectionMode === 'single';
827
- let { columnHeaderProps: columnHeaderProps } = (0, $idLTj$reactariatable.useTableColumnHeader)({
828
- node: column,
829
- isVirtualized: true
830
- }, state, ref);
831
- let { checkboxProps: checkboxProps } = (0, $idLTj$reactariatable.useTableSelectAllCheckbox)(state);
832
- let { hoverProps: hoverProps, isHovered: isHovered } = (0, $idLTj$reactariainteractions.useHover)({});
833
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
834
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'focus-ring')
835
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
836
- ...(0, $idLTj$reactariautils.mergeProps)(columnHeaderProps, hoverProps),
837
- ref: ref,
838
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headCell', 'spectrum-Table-checkboxCell', {
839
- 'is-hovered': isHovered
840
- })
841
- }, /*
842
- In single selection mode, the checkbox will be hidden.
843
- So to avoid leaving a column header with no accessible content,
844
- we use a VisuallyHidden component to include the aria-label from the checkbox,
845
- which for single selection will be "Select."
846
- */ isSingleSelectionMode && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariavisuallyhidden.VisuallyHidden), null, checkboxProps['aria-label']), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrumcheckbox.Checkbox), {
847
- ...checkboxProps,
848
- "data-testid": "selectAll",
849
- isEmphasized: true,
850
- UNSAFE_style: isSingleSelectionMode ? {
851
- visibility: 'hidden'
852
- } : undefined,
853
- UNSAFE_className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-checkbox')
854
- })));
855
- }
856
- function $e39c6de4eb69450d$var$TableDragHeaderCell({ column: column }) {
857
- let ref = (0, $idLTj$react.useRef)(null);
858
- let { state: state } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
859
- let { columnHeaderProps: columnHeaderProps } = (0, $idLTj$reactariatable.useTableColumnHeader)({
860
- node: column,
861
- isVirtualized: true
862
- }, state, ref);
863
- let stringFormatter = (0, $idLTj$reactariai18n.useLocalizedStringFormatter)((0, ($parcel$interopDefault($1a3d6ad53eb75d54$exports))), '@react-spectrum/table');
864
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
865
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'focus-ring')
866
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
867
- ...columnHeaderProps,
868
- ref: ref,
869
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-headCell', (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-headCell', 'react-spectrum-Table-dragButtonHeadCell'))
870
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariavisuallyhidden.VisuallyHidden), null, stringFormatter.format('drag'))));
871
- }
872
- function $e39c6de4eb69450d$var$TableRowGroup({ children: children, layoutInfo: layoutInfo, parent: parent, ...otherProps }) {
873
- let { rowGroupProps: rowGroupProps } = (0, $idLTj$reactariatable.useTableRowGroup)();
874
- let { isTableDroppable: isTableDroppable } = (0, $idLTj$react.useContext)($e39c6de4eb69450d$export$93e4b0b2cc49b648);
875
- let style = $e39c6de4eb69450d$var$useStyle(layoutInfo, parent);
876
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
877
- ...rowGroupProps,
878
- style: style,
879
- ...otherProps
880
- }, isTableDroppable && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $4a98adf416b1ae5d$exports.RootDropIndicator), {
881
- key: "root"
882
- }), children);
883
- }
884
- function $e39c6de4eb69450d$var$DragButton() {
885
- let { dragButtonProps: dragButtonProps, dragButtonRef: dragButtonRef, isFocusVisibleWithin: isFocusVisibleWithin } = $e39c6de4eb69450d$export$cd7c5802f9e21187();
886
- let { visuallyHiddenProps: visuallyHiddenProps } = (0, $idLTj$reactariavisuallyhidden.useVisuallyHidden)();
887
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
888
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'focus-ring')
889
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
890
- ...dragButtonProps,
891
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-dragButton'),
892
- style: !isFocusVisibleWithin ? {
893
- ...visuallyHiddenProps.style
894
- } : {},
895
- ref: dragButtonRef,
896
- draggable: "true"
897
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, ($parcel$interopDefault($idLTj$spectrumiconsuiListGripper))), {
898
- UNSAFE_className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))))
899
- })));
900
- }
901
- const $e39c6de4eb69450d$var$TableRowContext = /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createContext(null);
902
- function $e39c6de4eb69450d$export$cd7c5802f9e21187() {
903
- return (0, $idLTj$react.useContext)($e39c6de4eb69450d$var$TableRowContext);
904
- }
905
- function $e39c6de4eb69450d$var$TableRow({ item: item, children: children, layoutInfo: layoutInfo, parent: parent, ...otherProps }) {
906
- var _state_collection_rows_find, _layout_getContentSize, _layout_virtualizer, // Remove tab index from list row if performing a screenreader drag. This prevents TalkBack from focusing the row,
907
- // allowing for single swipe navigation between row drop indicator
908
- _dragAndDropHooks_isVirtualDragging;
909
- let ref = (0, $idLTj$react.useRef)(null);
910
- let { state: state, layout: layout, dragAndDropHooks: dragAndDropHooks, isTableDraggable: isTableDraggable, isTableDroppable: isTableDroppable, dragState: dragState, dropState: dropState } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
911
- let isSelected = state.selectionManager.isSelected(item.key);
912
- let { rowProps: rowProps, hasAction: hasAction, allowsSelection: allowsSelection } = (0, $idLTj$reactariatable.useTableRow)({
913
- node: item,
914
- isVirtualized: true,
915
- shouldSelectOnPressUp: isTableDraggable
916
- }, state, ref);
917
- let isDisabled = state.selectionManager.isDisabled(item.key);
918
- let isInteractive = !isDisabled && (hasAction || allowsSelection || isTableDraggable);
919
- let { pressProps: pressProps, isPressed: isPressed } = (0, $idLTj$reactariainteractions.usePress)({
920
- isDisabled: !isInteractive
921
- });
922
- // The row should show the focus background style when any cell inside it is focused.
923
- // If the row itself is focused, then it should have a blue focus indicator on the left.
924
- let { isFocusVisible: isFocusVisibleWithin, focusProps: focusWithinProps } = (0, $idLTj$reactariafocus.useFocusRing)({
925
- within: true
926
- });
927
- let { isFocusVisible: isFocusVisible, focusProps: focusProps } = (0, $idLTj$reactariafocus.useFocusRing)();
928
- let { hoverProps: hoverProps, isHovered: isHovered } = (0, $idLTj$reactariainteractions.useHover)({
929
- isDisabled: !isInteractive
930
- });
931
- let isFirstRow = ((_state_collection_rows_find = state.collection.rows.find((row)=>row.level === 1)) === null || _state_collection_rows_find === void 0 ? void 0 : _state_collection_rows_find.key) === item.key;
932
- let isLastRow = item.nextKey == null;
933
- // Figure out if the TableView content is equal or greater in height to the container. If so, we'll need to round the bottom
934
- // border corners of the last row when selected.
935
- let isFlushWithContainerBottom = false;
936
- var _layout_virtualizer_visibleRect_height;
937
- if (isLastRow) {
938
- if (((_layout_getContentSize = layout.getContentSize()) === null || _layout_getContentSize === void 0 ? void 0 : _layout_getContentSize.height) >= ((_layout_virtualizer_visibleRect_height = (_layout_virtualizer = layout.virtualizer) === null || _layout_virtualizer === void 0 ? void 0 : _layout_virtualizer.visibleRect.height) !== null && _layout_virtualizer_visibleRect_height !== void 0 ? _layout_virtualizer_visibleRect_height : 0)) isFlushWithContainerBottom = true;
939
- }
940
- let draggableItem = null;
941
- if (isTableDraggable && dragAndDropHooks && dragState) {
942
- draggableItem = dragAndDropHooks.useDraggableItem({
943
- key: item.key,
944
- hasDragButton: true
945
- }, dragState);
946
- if (isDisabled) draggableItem = null;
947
- }
948
- let isDropTarget = false;
949
- let dropIndicator = null;
950
- let dropIndicatorRef = (0, $idLTj$react.useRef)(null);
951
- if (isTableDroppable && dragAndDropHooks && dropState) {
952
- let target = {
953
- type: 'item',
954
- key: item.key,
955
- dropPosition: 'on'
956
- };
957
- isDropTarget = dropState.isDropTarget(target);
958
- dropIndicator = dragAndDropHooks.useDropIndicator({
959
- target: target
960
- }, dropState, dropIndicatorRef);
961
- }
962
- let dragButtonRef = (0, ($parcel$interopDefault($idLTj$react))).useRef(null);
963
- let { buttonProps: dragButtonProps } = (0, $idLTj$reactariabutton.useButton)({
964
- ...draggableItem === null || draggableItem === void 0 ? void 0 : draggableItem.dragButtonProps,
965
- elementType: 'div'
966
- }, dragButtonRef);
967
- let style = $e39c6de4eb69450d$var$useStyle(layoutInfo, parent);
968
- let props = (0, $idLTj$reactariautils.mergeProps)(rowProps, otherProps, {
969
- style: style
970
- }, focusWithinProps, focusProps, hoverProps, pressProps, draggableItem === null || draggableItem === void 0 ? void 0 : draggableItem.dragProps, (dragAndDropHooks === null || dragAndDropHooks === void 0 ? void 0 : (_dragAndDropHooks_isVirtualDragging = dragAndDropHooks.isVirtualDragging) === null || _dragAndDropHooks_isVirtualDragging === void 0 ? void 0 : _dragAndDropHooks_isVirtualDragging.call(dragAndDropHooks)) ? {
971
- tabIndex: null
972
- } : null);
973
- let { visuallyHiddenProps: visuallyHiddenProps } = (0, $idLTj$reactariavisuallyhidden.useVisuallyHidden)();
974
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$TableRowContext.Provider, {
975
- value: {
976
- dragButtonProps: dragButtonProps,
977
- dragButtonRef: dragButtonRef,
978
- isFocusVisibleWithin: isFocusVisibleWithin
979
- }
980
- }, isTableDroppable && isFirstRow && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $c44674ca7612e997$exports.InsertionIndicator), {
981
- rowProps: props,
982
- key: `${item.key}-before`,
983
- target: {
984
- key: item.key,
985
- type: 'item',
986
- dropPosition: 'before'
987
- }
988
- }), isTableDroppable && !(dropIndicator === null || dropIndicator === void 0 ? void 0 : dropIndicator.isHidden) && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
989
- role: "row",
990
- ...visuallyHiddenProps
991
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
992
- role: "gridcell"
993
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
994
- role: "button",
995
- ...dropIndicator === null || dropIndicator === void 0 ? void 0 : dropIndicator.dropIndicatorProps,
996
- ref: dropIndicatorRef
997
- }))), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
998
- ...props,
999
- ref: ref,
1000
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-row', {
1001
- 'is-active': isPressed,
1002
- 'is-selected': isSelected,
1003
- 'spectrum-Table-row--highlightSelection': state.selectionManager.selectionBehavior === 'replace',
1004
- 'is-next-selected': item.nextKey != null && state.selectionManager.isSelected(item.nextKey),
1005
- 'is-focused': isFocusVisibleWithin,
1006
- 'focus-ring': isFocusVisible,
1007
- 'is-hovered': isHovered,
1008
- 'is-disabled': isDisabled,
1009
- 'spectrum-Table-row--firstRow': isFirstRow,
1010
- 'spectrum-Table-row--lastRow': isLastRow,
1011
- 'spectrum-Table-row--isFlushBottom': isFlushWithContainerBottom
1012
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-row', {
1013
- 'react-spectrum-Table-row--dropTarget': isDropTarget
1014
- }))
1015
- }, children), isTableDroppable && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $c44674ca7612e997$exports.InsertionIndicator), {
1016
- rowProps: props,
1017
- key: `${item.key}-after`,
1018
- target: {
1019
- key: item.key,
1020
- type: 'item',
1021
- dropPosition: 'after'
1022
- }
1023
- }));
1024
- }
1025
- function $e39c6de4eb69450d$var$TableHeaderRow({ item: item, children: children, layoutInfo: layoutInfo, parent: parent, ...props }) {
1026
- let { state: state, headerMenuOpen: headerMenuOpen } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
1027
- let ref = (0, $idLTj$react.useRef)(null);
1028
- let { rowProps: rowProps } = (0, $idLTj$reactariatable.useTableHeaderRow)({
1029
- node: item,
1030
- isVirtualized: true
1031
- }, state, ref);
1032
- let { hoverProps: hoverProps } = (0, $idLTj$reactariainteractions.useHover)({
1033
- ...props,
1034
- isDisabled: headerMenuOpen
1035
- });
1036
- let style = $e39c6de4eb69450d$var$useStyle(layoutInfo, parent);
1037
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
1038
- ...(0, $idLTj$reactariautils.mergeProps)(rowProps, hoverProps),
1039
- ref: ref,
1040
- style: style
1041
- }, children);
1042
- }
1043
- function $e39c6de4eb69450d$var$TableDragCell({ cell: cell }) {
1044
- let ref = (0, $idLTj$react.useRef)(null);
1045
- let { state: state, isTableDraggable: isTableDraggable } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
1046
- let isDisabled = state.selectionManager.isDisabled(cell.parentKey);
1047
- let { gridCellProps: gridCellProps } = (0, $idLTj$reactariatable.useTableCell)({
1048
- node: cell,
1049
- isVirtualized: true
1050
- }, state, ref);
1051
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
1052
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'focus-ring')
1053
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
1054
- ...gridCellProps,
1055
- ref: ref,
1056
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-cell', {
1057
- 'is-disabled': isDisabled
1058
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-cell', 'react-spectrum-Table-dragButtonCell'))
1059
- }, isTableDraggable && !isDisabled && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$DragButton, null)));
1060
- }
1061
- function $e39c6de4eb69450d$var$TableCheckboxCell({ cell: cell }) {
1062
- let ref = (0, $idLTj$react.useRef)(null);
1063
- let { state: state } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
1064
- // The TableCheckbox should always render its disabled status if the row is disabled, regardless of disabledBehavior,
1065
- // but the cell itself should not render its disabled styles if disabledBehavior="selection" because the row might have actions on it.
1066
- let isSelectionDisabled = state.disabledKeys.has(cell.parentKey);
1067
- let isDisabled = state.selectionManager.isDisabled(cell.parentKey);
1068
- let { gridCellProps: gridCellProps } = (0, $idLTj$reactariatable.useTableCell)({
1069
- node: cell,
1070
- isVirtualized: true
1071
- }, state, ref);
1072
- let { checkboxProps: checkboxProps } = (0, $idLTj$reactariatable.useTableSelectionCheckbox)({
1073
- key: cell.parentKey
1074
- }, state);
1075
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
1076
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'focus-ring')
1077
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
1078
- ...gridCellProps,
1079
- ref: ref,
1080
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-cell', 'spectrum-Table-checkboxCell', {
1081
- 'is-disabled': isDisabled
1082
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-cell'))
1083
- }, state.selectionManager.selectionMode !== 'none' && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrumcheckbox.Checkbox), {
1084
- ...checkboxProps,
1085
- isEmphasized: true,
1086
- isDisabled: isSelectionDisabled,
1087
- UNSAFE_className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-checkbox')
1088
- })));
1089
- }
1090
- function $e39c6de4eb69450d$var$TableCell({ cell: cell }) {
1091
- let { scale: scale } = (0, $idLTj$reactspectrumprovider.useProvider)();
1092
- let { state: state } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
1093
- let isExpandableTable = 'expandedKeys' in state;
1094
- let ref = (0, $idLTj$react.useRef)(null);
1095
- let columnProps = cell.column.props;
1096
- let isDisabled = state.selectionManager.isDisabled(cell.parentKey);
1097
- let { gridCellProps: gridCellProps } = (0, $idLTj$reactariatable.useTableCell)({
1098
- node: cell,
1099
- isVirtualized: true
1100
- }, state, ref);
1101
- let { id: id, ...otherGridCellProps } = gridCellProps;
1102
- let isFirstRowHeaderCell = state.collection.rowHeaderColumnKeys.keys().next().value === cell.column.key;
1103
- let isRowExpandable = false;
1104
- let showExpandCollapseButton = false;
1105
- let levelOffset = 0;
1106
- if ('expandedKeys' in state) {
1107
- var _state_keyMap_get_props_UNSTABLE_childItems, _state_keyMap_get, _state_keyMap_get_props_children, _state_keyMap_get_props, _state_keyMap_get1;
1108
- isRowExpandable = ((_state_keyMap_get = state.keyMap.get(cell.parentKey)) === null || _state_keyMap_get === void 0 ? void 0 : (_state_keyMap_get_props_UNSTABLE_childItems = _state_keyMap_get.props.UNSTABLE_childItems) === null || _state_keyMap_get_props_UNSTABLE_childItems === void 0 ? void 0 : _state_keyMap_get_props_UNSTABLE_childItems.length) > 0 || ((_state_keyMap_get1 = state.keyMap.get(cell.parentKey)) === null || _state_keyMap_get1 === void 0 ? void 0 : (_state_keyMap_get_props = _state_keyMap_get1.props) === null || _state_keyMap_get_props === void 0 ? void 0 : (_state_keyMap_get_props_children = _state_keyMap_get_props.children) === null || _state_keyMap_get_props_children === void 0 ? void 0 : _state_keyMap_get_props_children.length) > state.userColumnCount;
1109
- showExpandCollapseButton = isFirstRowHeaderCell && isRowExpandable;
1110
- // Offset based on level, and add additional offset if there is no expand/collapse button on a row
1111
- levelOffset = (cell.level - 2) * $e39c6de4eb69450d$var$LEVEL_OFFSET_WIDTH[scale] + (!showExpandCollapseButton ? $e39c6de4eb69450d$var$LEVEL_OFFSET_WIDTH[scale] * 2 : 0);
1112
- }
1113
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariafocus.FocusRing), {
1114
- focusRingClass: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'focus-ring')
1115
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
1116
- ...otherGridCellProps,
1117
- "aria-labelledby": id,
1118
- ref: ref,
1119
- style: isExpandableTable && isFirstRowHeaderCell ? {
1120
- paddingInlineStart: levelOffset
1121
- } : {},
1122
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-cell', {
1123
- 'spectrum-Table-cell--divider': columnProps.showDivider && cell.column.nextKey !== null,
1124
- 'spectrum-Table-cell--hideHeader': columnProps.hideHeader,
1125
- 'spectrum-Table-cell--hasExpandCollapseButton': showExpandCollapseButton,
1126
- 'is-disabled': isDisabled
1127
- }, (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-cell', {
1128
- 'react-spectrum-Table-cell--alignStart': columnProps.align === 'start',
1129
- 'react-spectrum-Table-cell--alignCenter': columnProps.align === 'center',
1130
- 'react-spectrum-Table-cell--alignEnd': columnProps.align === 'end'
1131
- }))
1132
- }, showExpandCollapseButton && /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$ExpandableRowChevron, {
1133
- cell: cell
1134
- }), /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("span", {
1135
- id: id,
1136
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-cellContents')
1137
- }, cell.rendered)));
1138
- }
1139
- function $e39c6de4eb69450d$var$TableCellWrapper({ layoutInfo: layoutInfo, virtualizer: virtualizer, parent: parent, children: children }) {
1140
- let { isTableDroppable: isTableDroppable, dropState: dropState } = (0, $idLTj$react.useContext)($e39c6de4eb69450d$export$93e4b0b2cc49b648);
1141
- let isDropTarget = false;
1142
- let isRootDroptarget = false;
1143
- if (isTableDroppable && dropState) {
1144
- if (parent.content) isDropTarget = dropState.isDropTarget({
1145
- type: 'item',
1146
- dropPosition: 'on',
1147
- key: parent.content.key
1148
- });
1149
- isRootDroptarget = dropState.isDropTarget({
1150
- type: 'root'
1151
- });
1152
- }
1153
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactariavirtualizer.VirtualizerItem), {
1154
- layoutInfo: layoutInfo,
1155
- virtualizer: virtualizer,
1156
- parent: parent === null || parent === void 0 ? void 0 : parent.layoutInfo,
1157
- className: (0, $idLTj$react.useMemo)(()=>(0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-cellWrapper', (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), {
1158
- 'react-spectrum-Table-cellWrapper': !layoutInfo.estimatedSize,
1159
- 'react-spectrum-Table-cellWrapper--dropTarget': isDropTarget || isRootDroptarget
1160
- })), [
1161
- layoutInfo.estimatedSize,
1162
- isDropTarget,
1163
- isRootDroptarget
1164
- ])
1165
- }, children);
1166
- }
1167
- function $e39c6de4eb69450d$var$ExpandableRowChevron({ cell: cell }) {
1168
- // TODO: move some/all of the chevron button setup into a separate hook?
1169
- let { direction: direction } = (0, $idLTj$reactariai18n.useLocale)();
1170
- let { state: state } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
1171
- let expandButtonRef = (0, $idLTj$react.useRef)(null);
1172
- let stringFormatter = (0, $idLTj$reactariai18n.useLocalizedStringFormatter)((0, ($parcel$interopDefault($1a3d6ad53eb75d54$exports))), '@react-spectrum/table');
1173
- let isExpanded;
1174
- if ('expandedKeys' in state) isExpanded = state.expandedKeys === 'all' || state.expandedKeys.has(cell.parentKey);
1175
- // Will need to keep the chevron as a button for iOS VO at all times since VO doesn't focus the cell. Also keep as button if cellAction is defined by the user in the future
1176
- let { buttonProps: buttonProps } = (0, $idLTj$reactariabutton.useButton)({
1177
- // Desktop and mobile both toggle expansion of a native expandable row on mouse/touch up
1178
- onPress: ()=>{
1179
- state.toggleKey(cell.parentKey);
1180
- if (!(0, $idLTj$reactariainteractions.isFocusVisible)()) {
1181
- state.selectionManager.setFocused(true);
1182
- state.selectionManager.setFocusedKey(cell.parentKey);
1183
- }
1184
- },
1185
- elementType: 'span',
1186
- 'aria-label': isExpanded ? stringFormatter.format('collapse') : stringFormatter.format('expand')
1187
- }, expandButtonRef);
1188
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("span", {
1189
- ...buttonProps,
1190
- ref: expandButtonRef,
1191
- // Override tabindex so that grid keyboard nav skips over it. Needs -1 so android talkback can actually "focus" it
1192
- tabIndex: (0, $idLTj$reactariautils.isAndroid)() ? -1 : undefined,
1193
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($982885d0a34882ea$exports))), 'spectrum-Table-expandButton', {
1194
- 'is-open': isExpanded
1195
- })
1196
- }, direction === 'ltr' ? /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, ($parcel$interopDefault($idLTj$spectrumiconsuiChevronRightMedium))), null) : /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, ($parcel$interopDefault($idLTj$spectrumiconsuiChevronLeftMedium))), null));
1197
- }
1198
- function $e39c6de4eb69450d$var$LoadingState() {
1199
- let { state: state } = (0, $idLTj$react.useContext)($e39c6de4eb69450d$export$93e4b0b2cc49b648);
1200
- let stringFormatter = (0, $idLTj$reactariai18n.useLocalizedStringFormatter)((0, ($parcel$interopDefault($1a3d6ad53eb75d54$exports))), '@react-spectrum/table');
1201
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$CenteredWrapper, null, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement((0, $idLTj$reactspectrumprogress.ProgressCircle), {
1202
- isIndeterminate: true,
1203
- "aria-label": state.collection.size > 0 ? stringFormatter.format('loadingMore') : stringFormatter.format('loading')
1204
- }));
1205
- }
1206
- function $e39c6de4eb69450d$var$EmptyState() {
1207
- let { renderEmptyState: renderEmptyState } = (0, $idLTj$react.useContext)($e39c6de4eb69450d$export$93e4b0b2cc49b648);
1208
- let emptyState = renderEmptyState ? renderEmptyState() : null;
1209
- if (emptyState == null) return null;
1210
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement($e39c6de4eb69450d$var$CenteredWrapper, null, emptyState);
1211
- }
1212
- function $e39c6de4eb69450d$var$CenteredWrapper({ children: children }) {
1213
- let { state: state } = $e39c6de4eb69450d$export$3cb274deb6c2d854();
1214
- let rowProps;
1215
- if ('expandedKeys' in state) {
1216
- let topLevelRowCount = [
1217
- ...state.collection.body.childNodes
1218
- ].length;
1219
- rowProps = {
1220
- 'aria-level': 1,
1221
- 'aria-posinset': topLevelRowCount + 1,
1222
- 'aria-setsize': topLevelRowCount + 1
1223
- };
1224
- } else rowProps = {
1225
- 'aria-rowindex': state.collection.headerRows.length + state.collection.size + 1
1226
- };
1227
- return /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
1228
- role: "row",
1229
- ...rowProps,
1230
- className: (0, $idLTj$reactspectrumutils.classNames)((0, ($parcel$interopDefault($4afcd54cfd94dbb9$exports))), 'react-spectrum-Table-centeredWrapper')
1231
- }, /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).createElement("div", {
1232
- role: "rowheader",
1233
- "aria-colspan": state.collection.columns.length
1234
- }, children));
1235
- }
1236
- const $e39c6de4eb69450d$export$517e02184d273d69 = /*#__PURE__*/ (0, ($parcel$interopDefault($idLTj$react))).forwardRef($e39c6de4eb69450d$var$TableViewBase);
1237
-
1238
-
1239
- //# sourceMappingURL=TableViewBase.main.js.map