@oracle/oraclejet-preact 20.0.3 → 20.1.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 (1847) hide show
  1. package/amd/BarChart-e3c190b5.js +2 -0
  2. package/amd/BarChart-e3c190b5.js.map +1 -0
  3. package/amd/BaseCardView-16fda4c3.js +2 -0
  4. package/amd/BaseCardView-16fda4c3.js.map +1 -0
  5. package/amd/BaseDiagram-b9695479.js +2 -0
  6. package/amd/BaseDiagram-b9695479.js.map +1 -0
  7. package/amd/ButtonSetButton-ded680bb.js +2 -0
  8. package/amd/ButtonSetButton-ded680bb.js.map +1 -0
  9. package/amd/ButtonSetIconButton-c4dcbd9a.js +2 -0
  10. package/amd/ButtonSetIconButton-c4dcbd9a.js.map +1 -0
  11. package/amd/ButtonSetItem-4d644b7d.js +2 -0
  12. package/amd/ButtonSetItem-4d644b7d.js.map +1 -0
  13. package/amd/CardFlexView-d3eb7373.js +2 -0
  14. package/amd/CardFlexView-d3eb7373.js.map +1 -0
  15. package/amd/CardGridView-842f70cd.js +2 -0
  16. package/amd/CardGridView-842f70cd.js.map +1 -0
  17. package/amd/Chart-00a1b01f.js +2 -0
  18. package/amd/Chart-00a1b01f.js.map +1 -0
  19. package/amd/ComboChart-36e22cb8.js +2 -0
  20. package/amd/ComboChart-36e22cb8.js.map +1 -0
  21. package/amd/ContainerDiagram-6f41a26a.js +2 -0
  22. package/amd/ContainerDiagram-6f41a26a.js.map +1 -0
  23. package/amd/DatePicker-cf0e3fcd.js +2 -0
  24. package/amd/DatePicker-cf0e3fcd.js.map +1 -0
  25. package/amd/DatePickerHeader-406aa5c6.js +2 -0
  26. package/amd/DatePickerHeader-406aa5c6.js.map +1 -0
  27. package/amd/Diagram-6072b867.js +2 -0
  28. package/amd/Diagram-6072b867.js.map +1 -0
  29. package/amd/Dropdown-7cc463f6.js +2 -0
  30. package/amd/Dropdown-7cc463f6.js.map +1 -0
  31. package/amd/IconMenuButton-ec28ecfb.js +2 -0
  32. package/amd/IconMenuButton-ec28ecfb.js.map +1 -0
  33. package/amd/IconSwitchButton-28f4854a.js +2 -0
  34. package/amd/IconSwitchButton-28f4854a.js.map +1 -0
  35. package/amd/IconToggleButton-56035aa0.js +2 -0
  36. package/amd/IconToggleButton-56035aa0.js.map +1 -0
  37. package/amd/InlineSelectSingle-a1c1f520.js +2 -0
  38. package/amd/InlineSelectSingle-a1c1f520.js.map +1 -0
  39. package/amd/InputColor-bde91b03.js +2 -0
  40. package/amd/InputColor-bde91b03.js.map +1 -0
  41. package/amd/InputDatePicker-3351af0f.js +2 -0
  42. package/amd/InputDatePicker-3351af0f.js.map +1 -0
  43. package/amd/InputPassword-59369c13.js +2 -0
  44. package/amd/InputPassword-59369c13.js.map +1 -0
  45. package/amd/InputSensitiveText-ad79acc4.js +2 -0
  46. package/amd/InputSensitiveText-ad79acc4.js.map +1 -0
  47. package/amd/Legend-482f99eb.js +2 -0
  48. package/amd/Legend-482f99eb.js.map +1 -0
  49. package/amd/LineAreaChart-6f5dabc1.js +2 -0
  50. package/amd/LineAreaChart-6f5dabc1.js.map +1 -0
  51. package/amd/Link-20f7e72d.js +2 -0
  52. package/amd/Link-20f7e72d.js.map +1 -0
  53. package/amd/LinkVariants.styles.css +0 -1
  54. package/amd/LinkVariants.styles2.css +0 -1
  55. package/amd/ListView-dfbd3f41.js +2 -0
  56. package/amd/ListView-dfbd3f41.js.map +1 -0
  57. package/amd/Menu-0c8295f2.js +2 -0
  58. package/amd/Menu-0c8295f2.js.map +1 -0
  59. package/amd/MenuButton-1fbc486e.js +2 -0
  60. package/amd/MenuButton-1fbc486e.js.map +1 -0
  61. package/amd/MenuItem-f3de5e35.js +2 -0
  62. package/amd/MenuItem-f3de5e35.js.map +1 -0
  63. package/amd/MonthView-effa60a5.js +2 -0
  64. package/amd/MonthView-effa60a5.js.map +1 -0
  65. package/amd/NavigationListItem-0e162c3e.js +2 -0
  66. package/amd/NavigationListItem-0e162c3e.js.map +1 -0
  67. package/amd/NavigationListLinkItem-161049bb.js +2 -0
  68. package/amd/NavigationListLinkItem-161049bb.js.map +1 -0
  69. package/amd/OverflowTabBar-aa6557e2.js +2 -0
  70. package/amd/OverflowTabBar-aa6557e2.js.map +1 -0
  71. package/amd/OverflowTabBarItem-f05a778f.js +2 -0
  72. package/amd/OverflowTabBarItem-f05a778f.js.map +1 -0
  73. package/amd/PRIVATE_BaseCardView.js +1 -1
  74. package/amd/PRIVATE_BaseDiagram.js +1 -1
  75. package/amd/PRIVATE_Chart.js +1 -1
  76. package/amd/PRIVATE_DatePickerHeader.js +1 -1
  77. package/amd/PRIVATE_FormControls.js +1 -1
  78. package/amd/PRIVATE_IconSwitchButton.js +1 -1
  79. package/amd/PRIVATE_MonthView.js +1 -1
  80. package/amd/PRIVATE_MonthYearGridView.js +1 -1
  81. package/amd/PRIVATE_RevealToggleIcon.js +1 -1
  82. package/amd/PRIVATE_SelectCommon.js +1 -1
  83. package/amd/PRIVATE_StyledDatePickerButton/themes/StyledDatePickerButtonStyles.css.js +1 -1
  84. package/amd/PRIVATE_StyledDatePickerButton.js +1 -1
  85. package/amd/PRIVATE_Table.js +1 -1
  86. package/amd/PRIVATE_TableList.js +1 -1
  87. package/amd/PRIVATE_TruncatingLink.js +1 -1
  88. package/amd/PictoChart-c303675a.js +2 -0
  89. package/amd/PictoChart-c303675a.js.map +1 -0
  90. package/amd/PieChart-df15d363.js +2 -0
  91. package/amd/PieChart-df15d363.js.map +1 -0
  92. package/amd/RemovableNavigationListItem-e298c5de.js +2 -0
  93. package/amd/RemovableNavigationListItem-e298c5de.js.map +1 -0
  94. package/amd/ReorderableTabBar-e82d2982.js +2 -0
  95. package/amd/ReorderableTabBar-e82d2982.js.map +1 -0
  96. package/amd/RevealToggleIcon-be164a7b.js +2 -0
  97. package/amd/RevealToggleIcon-be164a7b.js.map +1 -0
  98. package/amd/ScatterChart-88bc2872.js +2 -0
  99. package/amd/ScatterChart-88bc2872.js.map +1 -0
  100. package/amd/SectionalLegend-3bae380b.js +2 -0
  101. package/amd/SectionalLegend-3bae380b.js.map +1 -0
  102. package/amd/SectionedContent-878a2df1.js +2 -0
  103. package/amd/SectionedContent-878a2df1.js.map +1 -0
  104. package/amd/SelectMenuItem-5bd09f45.js +2 -0
  105. package/amd/SelectMenuItem-5bd09f45.js.map +1 -0
  106. package/amd/SelectMobileFieldInput-d8be9c82.js +2 -0
  107. package/amd/SelectMobileFieldInput-d8be9c82.js.map +1 -0
  108. package/amd/SelectMultiple-467c640d.js +2 -0
  109. package/amd/SelectMultiple-467c640d.js.map +1 -0
  110. package/amd/SelectSingle-a600e403.js +2 -0
  111. package/amd/SelectSingle-a600e403.js.map +1 -0
  112. package/amd/SplitMenuButton-42f95b11.js +2 -0
  113. package/amd/SplitMenuButton-42f95b11.js.map +1 -0
  114. package/amd/StyledDatePickerButton-416ddc14.js +2 -0
  115. package/amd/StyledDatePickerButton-416ddc14.js.map +1 -0
  116. package/amd/StyledDatePickerButtonStyles.styles.css +18 -12
  117. package/amd/Submenu-f8ab8c2e.js +2 -0
  118. package/amd/Submenu-f8ab8c2e.js.map +1 -0
  119. package/amd/TabBar-61d65c39.js +2 -0
  120. package/amd/TabBar-61d65c39.js.map +1 -0
  121. package/amd/TabBarContextMenu-6977866c.js +2 -0
  122. package/amd/TabBarContextMenu-6977866c.js.map +1 -0
  123. package/amd/TabBarMixed-092116bd.js +2 -0
  124. package/amd/TabBarMixed-092116bd.js.map +1 -0
  125. package/amd/Table-225ba4db.js +2 -0
  126. package/amd/Table-225ba4db.js.map +1 -0
  127. package/amd/TableView-f7990126.js +2 -0
  128. package/amd/TableView-f7990126.js.map +1 -0
  129. package/amd/TagCloud-69af60c1.js +2 -0
  130. package/amd/TagCloud-69af60c1.js.map +1 -0
  131. package/amd/Theme-redwood/theme.css +178 -178
  132. package/amd/Theme-stable/theme.css +351 -351
  133. package/amd/ToggleButton-c9e433d4.js +2 -0
  134. package/amd/ToggleButton-c9e433d4.js.map +1 -0
  135. package/amd/ToggleButtonLabel-367494b8.js +2 -0
  136. package/amd/ToggleButtonLabel-367494b8.js.map +1 -0
  137. package/amd/TruncatingLink-2e947915.js +2 -0
  138. package/amd/TruncatingLink-2e947915.js.map +1 -0
  139. package/amd/UNSAFE_BarChart/__test__/BarChart.spec.js +1 -1
  140. package/amd/UNSAFE_BarChart.js +1 -1
  141. package/amd/UNSAFE_ButtonLayout/tests/ButtonLayout.spec.js +1 -1
  142. package/amd/UNSAFE_ButtonSetButton.js +1 -1
  143. package/amd/UNSAFE_ButtonSetIconButton.js +1 -1
  144. package/amd/UNSAFE_ButtonSetItem.js +1 -1
  145. package/amd/UNSAFE_CardFlexView.js +1 -1
  146. package/amd/UNSAFE_CardGridView.js +1 -1
  147. package/amd/UNSAFE_ComboChart.js +1 -1
  148. package/amd/UNSAFE_ContainerDiagram.js +1 -1
  149. package/amd/UNSAFE_DatePicker.js +1 -1
  150. package/amd/UNSAFE_Diagram.js +1 -1
  151. package/amd/UNSAFE_Dropdown.js +1 -1
  152. package/amd/UNSAFE_IconMenuButton.js +1 -1
  153. package/amd/UNSAFE_IconToggleButton.js +1 -1
  154. package/amd/UNSAFE_InlineSelectSingle.js +1 -1
  155. package/amd/UNSAFE_InputColor.js +1 -1
  156. package/amd/UNSAFE_InputDatePicker.js +1 -1
  157. package/amd/UNSAFE_InputPassword.js +1 -1
  158. package/amd/UNSAFE_InputSensitiveText.js +1 -1
  159. package/amd/UNSAFE_LabelledLink.js +1 -1
  160. package/amd/UNSAFE_LabelledLink.js.map +1 -1
  161. package/amd/UNSAFE_Legend.js +1 -1
  162. package/amd/UNSAFE_LineAreaChart.js +1 -1
  163. package/amd/UNSAFE_Link/themes/LinkStyles.css.js +1 -1
  164. package/amd/UNSAFE_Link.js +1 -1
  165. package/amd/UNSAFE_ListView.js +1 -1
  166. package/amd/UNSAFE_Menu.js +1 -1
  167. package/amd/UNSAFE_MenuButton.js +1 -1
  168. package/amd/UNSAFE_NavigationList.js +1 -1
  169. package/amd/UNSAFE_NavigationListCommon.js +1 -1
  170. package/amd/UNSAFE_OverflowTabBar.js +1 -1
  171. package/amd/UNSAFE_PictoChart.js +1 -1
  172. package/amd/UNSAFE_PieChart/__test__/PieChart.spec.js +1 -1
  173. package/amd/UNSAFE_PieChart.js +1 -1
  174. package/amd/UNSAFE_ReorderableTabBar.js +1 -1
  175. package/amd/UNSAFE_ScatterChart.js +1 -1
  176. package/amd/UNSAFE_SectionalLegend.js +1 -1
  177. package/amd/UNSAFE_SelectMultiple.js +1 -1
  178. package/amd/UNSAFE_SelectSingle.js +1 -1
  179. package/amd/UNSAFE_SplitMenuButton.js +1 -1
  180. package/amd/UNSAFE_TabBar.js +1 -1
  181. package/amd/UNSAFE_TabBarCommon.js +1 -1
  182. package/amd/UNSAFE_TabBarMixed.js +1 -1
  183. package/amd/UNSAFE_TableView.js +1 -1
  184. package/amd/UNSAFE_TagCloud.js +1 -1
  185. package/amd/UNSAFE_ToggleButton.js +1 -1
  186. package/amd/UNSAFE_ToggleButtonLabel.js +1 -1
  187. package/amd/UNSAFE_Toolbar/tests/Toolbar.spec.js +1 -1
  188. package/amd/YearsGridView-09b45b4e.js +2 -0
  189. package/amd/YearsGridView-09b45b4e.js.map +1 -0
  190. package/amd/hooks/PRIVATE_useChartContextMenu.js +1 -1
  191. package/amd/hooks/PRIVATE_useChartMarquee.js +1 -1
  192. package/amd/hooks/PRIVATE_useMiddleEllipsis.js +2 -0
  193. package/amd/hooks/PRIVATE_useMiddleEllipsis.js.map +1 -0
  194. package/amd/hooks/PRIVATE_useTabBar.js +1 -1
  195. package/amd/hooks/PRIVATE_useVisContextMenu.js +1 -1
  196. package/amd/hooks/PRIVATE_useVisDragModeControls.js +1 -1
  197. package/amd/listViewSelectionTests-e7898c59.js +2 -0
  198. package/amd/listViewSelectionTests-e7898c59.js.map +1 -0
  199. package/amd/useChartContextMenu-9abf418f.js +2 -0
  200. package/amd/useChartContextMenu-9abf418f.js.map +1 -0
  201. package/amd/useChartMarquee-ec70d86c.js +2 -0
  202. package/amd/useChartMarquee-ec70d86c.js.map +1 -0
  203. package/amd/useContextMenu-49bd8ffb.js +2 -0
  204. package/amd/useContextMenu-49bd8ffb.js.map +1 -0
  205. package/amd/useDisplayValue-8b0c1851.js +2 -0
  206. package/amd/useDisplayValue-8b0c1851.js.map +1 -0
  207. package/amd/useLegendContextMenu-90023a78.js +2 -0
  208. package/amd/useLegendContextMenu-90023a78.js.map +1 -0
  209. package/amd/useMiddleEllipsis-9ade43e6.js +2 -0
  210. package/amd/useMiddleEllipsis-9ade43e6.js.map +1 -0
  211. package/amd/useSelectCommon-af642fe7.js +2 -0
  212. package/amd/useSelectCommon-af642fe7.js.map +1 -0
  213. package/amd/useTabBar-430d9e32.js +2 -0
  214. package/amd/useTabBar-430d9e32.js.map +1 -0
  215. package/amd/useVisDragModeControls-c1d2abc6.js +2 -0
  216. package/amd/useVisDragModeControls-c1d2abc6.js.map +1 -0
  217. package/cjs/BaseButton-15b86552.js +86 -0
  218. package/cjs/BaseButton-15b86552.js.map +1 -0
  219. package/cjs/BaseCardView-ba63723a.js +6 -6
  220. package/cjs/BaseDiagram-576c2a13.js +2956 -0
  221. package/cjs/BaseDiagram-576c2a13.js.map +1 -0
  222. package/cjs/BaseRichSelection-c7cad1af.js +9 -9
  223. package/cjs/BaseSelector-2dc69917.js +1 -1
  224. package/cjs/BaseSwatchView-76da473f.js +2 -2
  225. package/cjs/Button-d79df225.js +24 -0
  226. package/cjs/Button-d79df225.js.map +1 -0
  227. package/cjs/ButtonSet-ed013090.js +2 -2
  228. package/cjs/ButtonSetButton-a7384fb3.js +35 -0
  229. package/cjs/ButtonSetButton-a7384fb3.js.map +1 -0
  230. package/cjs/ButtonSetIconButton-345ead86.js +40 -0
  231. package/cjs/ButtonSetIconButton-345ead86.js.map +1 -0
  232. package/cjs/ButtonSetItem-1f2f6742.js +67 -0
  233. package/cjs/ButtonSetItem-1f2f6742.js.map +1 -0
  234. package/cjs/Center-a23cf0cd.js +18 -0
  235. package/cjs/Center-a23cf0cd.js.map +1 -0
  236. package/cjs/Chart-3360191e.js +754 -0
  237. package/cjs/Chart-3360191e.js.map +1 -0
  238. package/cjs/CheckboxControl-d37c7764.js +6 -6
  239. package/cjs/CheckboxRadioField-24e06523.js +6 -6
  240. package/cjs/CheckboxRadioLabelValueLayout-0ed43779.js +1 -1
  241. package/cjs/CheckboxSetContext-c62db26d.js +12 -0
  242. package/cjs/CheckboxSetContext-c62db26d.js.map +1 -0
  243. package/cjs/Chip-b2dd59ed.js +1 -1
  244. package/cjs/ClearIcon-f61fc0b9.js +1 -1
  245. package/cjs/CollapseIcon-9fbe13a9.js +1 -1
  246. package/cjs/Collapsible-9315585f.js +2 -2
  247. package/cjs/ColorPalette-9f041744.js +83 -0
  248. package/cjs/ColorPalette-9f041744.js.map +1 -0
  249. package/cjs/ColorPicker-24ca67b6.js +25 -0
  250. package/cjs/ColorPicker-24ca67b6.js.map +1 -0
  251. package/cjs/ColorSwatch-cddebd6b.js +4 -4
  252. package/cjs/CompactLabelAssistance-f7b3b814.js +95 -0
  253. package/cjs/CompactLabelAssistance-f7b3b814.js.map +1 -0
  254. package/cjs/CompactUserAssistance-a5f1bb2b.js +5 -5
  255. package/cjs/ComponentMessageContainer-b692adf3.js +4 -4
  256. package/cjs/DatePicker-c4d49200.js +601 -0
  257. package/cjs/DatePicker-c4d49200.js.map +1 -0
  258. package/cjs/DatePickerHeader-9bcd2308.js +48 -0
  259. package/cjs/DatePickerHeader-9bcd2308.js.map +1 -0
  260. package/cjs/Dialog-871d9a7c.js +389 -0
  261. package/cjs/Dialog-871d9a7c.js.map +1 -0
  262. package/cjs/DirectionalCollapseArrowIcon-392d6599.js +1 -1
  263. package/cjs/DirectionalExpandArrowIcon-ff9f6f78.js +1 -1
  264. package/cjs/Dropdown-b73f547b.js +337 -0
  265. package/cjs/Dropdown-b73f547b.js.map +1 -0
  266. package/cjs/EmbeddedIconButton-f2e69758.js +13 -0
  267. package/cjs/EmbeddedIconButton-f2e69758.js.map +1 -0
  268. package/cjs/EnvironmentProvider-932667b2.js +61 -0
  269. package/cjs/EnvironmentProvider-932667b2.js.map +1 -0
  270. package/cjs/Expander-f4c574e5.js +1 -1
  271. package/cjs/Flex-ec48072d.js +32 -0
  272. package/cjs/Flex-ec48072d.js.map +1 -0
  273. package/cjs/Floating-de219e52.js +467 -0
  274. package/cjs/Floating-de219e52.js.map +1 -0
  275. package/cjs/Grid-156807d4.js +29 -0
  276. package/cjs/Grid-156807d4.js.map +1 -0
  277. package/cjs/GroupLoadingIndicator-7e035ba2.js +1 -1
  278. package/cjs/HighlightText-93f2fea0.js +33 -0
  279. package/cjs/HighlightText-93f2fea0.js.map +1 -0
  280. package/cjs/Icon-56789beb.js +3 -3
  281. package/cjs/IconButton-7503293b.js +4 -4
  282. package/cjs/IconSwitchButton-550d6ced.js +44 -0
  283. package/cjs/IconSwitchButton-550d6ced.js.map +1 -0
  284. package/cjs/IconToggleButton-b7a72539.js +43 -0
  285. package/cjs/IconToggleButton-b7a72539.js.map +1 -0
  286. package/cjs/IconUserAssistance-848c227c.js +76 -0
  287. package/cjs/IconUserAssistance-848c227c.js.map +1 -0
  288. package/cjs/InlineHelp-2add2d34.js +1 -1
  289. package/cjs/InlineUserAssistance-cfaa3d3e.js +5 -5
  290. package/cjs/InputDateMask-c7baadd4.js +7 -7
  291. package/cjs/Label-eb654b0e.js +8 -8
  292. package/cjs/LabelValueLayout-d67109b3.js +1 -1
  293. package/cjs/Layer-06e11b9c.js +94 -0
  294. package/cjs/Layer-06e11b9c.js.map +1 -0
  295. package/cjs/LayerHost-21391a0d.js +46 -0
  296. package/cjs/LayerHost-21391a0d.js.map +1 -0
  297. package/cjs/LayerManager-fd7f4d2f.js +36 -0
  298. package/cjs/LayerManager-fd7f4d2f.js.map +1 -0
  299. package/cjs/Link-f8403e9f.js +35 -0
  300. package/cjs/Link-f8403e9f.js.map +1 -0
  301. package/cjs/LinkVariants.styles.css +0 -1
  302. package/cjs/LinkVariants.styles2.css +0 -1
  303. package/cjs/List-afcfa338.js +5 -5
  304. package/cjs/LiveRegion-60535481.js +41 -0
  305. package/cjs/LiveRegion-60535481.js.map +1 -0
  306. package/cjs/MaxLengthLiveRegion-82e6c492.js +28 -0
  307. package/cjs/MaxLengthLiveRegion-82e6c492.js.map +1 -0
  308. package/cjs/Message-258e59da.js +2 -2
  309. package/cjs/MessageLayer-a18a7c26.js +61 -0
  310. package/cjs/MessageLayer-a18a7c26.js.map +1 -0
  311. package/cjs/MessagesManager-cba4bc60.js +3 -3
  312. package/cjs/Modal-b751b643.js +3 -3
  313. package/cjs/MonthView-25653876.js +231 -0
  314. package/cjs/MonthView-25653876.js.map +1 -0
  315. package/cjs/NavigationListItem-ef597eb9.js +312 -0
  316. package/cjs/NavigationListItem-ef597eb9.js.map +1 -0
  317. package/cjs/NavigationListLinkItem-62c3912e.js +237 -0
  318. package/cjs/NavigationListLinkItem-62c3912e.js.map +1 -0
  319. package/cjs/NumberInputText-36164d46.js +6 -6
  320. package/cjs/OverflowTabBarItem-4053a20b.js +262 -0
  321. package/cjs/OverflowTabBarItem-4053a20b.js.map +1 -0
  322. package/cjs/PRIVATE_BaseCardView.js +22 -22
  323. package/cjs/PRIVATE_BaseDiagram.js +38 -38
  324. package/cjs/PRIVATE_BaseSelector.js +17 -17
  325. package/cjs/PRIVATE_BaseSwatchView.js +18 -18
  326. package/cjs/PRIVATE_Chart.js +48 -48
  327. package/cjs/PRIVATE_CheckboxControl.js +25 -25
  328. package/cjs/PRIVATE_CheckboxRadioField.js +27 -27
  329. package/cjs/PRIVATE_ClearIcon.js +18 -18
  330. package/cjs/PRIVATE_CollapsibleNavigationList.js +20 -20
  331. package/cjs/PRIVATE_DatePickerHeader.js +23 -23
  332. package/cjs/PRIVATE_DatePickerLayout.js +4 -4
  333. package/cjs/PRIVATE_EmbeddedIconButton.js +6 -6
  334. package/cjs/PRIVATE_Expander.js +19 -19
  335. package/cjs/PRIVATE_FormControls.js +21 -21
  336. package/cjs/PRIVATE_IconSwitchButton.js +19 -19
  337. package/cjs/PRIVATE_Icons/CheckboxCrossed.js +16 -16
  338. package/cjs/PRIVATE_Icons/CheckboxMixed.js +16 -16
  339. package/cjs/PRIVATE_Icons/CheckboxOff.js +16 -16
  340. package/cjs/PRIVATE_Icons/CheckboxOn.js +16 -16
  341. package/cjs/PRIVATE_Icons/DragV.js +16 -16
  342. package/cjs/PRIVATE_Icons/None.js +16 -16
  343. package/cjs/PRIVATE_List.js +21 -21
  344. package/cjs/PRIVATE_Message.js +20 -20
  345. package/cjs/PRIVATE_MessageLayer.js +12 -12
  346. package/cjs/PRIVATE_MonthView.js +81 -8
  347. package/cjs/PRIVATE_MonthView.js.map +1 -1
  348. package/cjs/PRIVATE_MonthYearGridView.js +8 -8
  349. package/cjs/PRIVATE_PlotArea.js +5 -5
  350. package/cjs/PRIVATE_RevealToggleIcon.js +21 -21
  351. package/cjs/PRIVATE_RichSelectionCommon.js +28 -28
  352. package/cjs/PRIVATE_SelectCommon.js +34 -34
  353. package/cjs/PRIVATE_StyledCard.js +3 -3
  354. package/cjs/PRIVATE_StyledCheckbox.js +16 -16
  355. package/cjs/PRIVATE_StyledDatePickerButton/themes/StyledDatePickerButtonStyles.css.js +1 -1
  356. package/cjs/PRIVATE_StyledDatePickerButton.js +1 -1
  357. package/cjs/PRIVATE_StyledSwitch.js +4 -4
  358. package/cjs/PRIVATE_SwatchFlexView.js +18 -18
  359. package/cjs/PRIVATE_Table.js +38 -38
  360. package/cjs/PRIVATE_TableDisplay.js +19 -19
  361. package/cjs/PRIVATE_TableList.js +27 -27
  362. package/cjs/PRIVATE_ThemedIcons/CalendarIcon.js +16 -16
  363. package/cjs/PRIVATE_ThemedIcons/ChartMarqueeSelectIcon.js +16 -16
  364. package/cjs/PRIVATE_ThemedIcons/ChartPanIcon.js +16 -16
  365. package/cjs/PRIVATE_ThemedIcons/ChartZoomIcon.js +16 -16
  366. package/cjs/PRIVATE_ThemedIcons/CheckIcon.js +16 -16
  367. package/cjs/PRIVATE_ThemedIcons/CheckboxCrossedIcon.js +16 -16
  368. package/cjs/PRIVATE_ThemedIcons/CheckboxMixedIcon.js +16 -16
  369. package/cjs/PRIVATE_ThemedIcons/CheckboxOffIcon.js +16 -16
  370. package/cjs/PRIVATE_ThemedIcons/CheckboxOnIcon.js +16 -16
  371. package/cjs/PRIVATE_ThemedIcons/CloseIcon.js +16 -16
  372. package/cjs/PRIVATE_ThemedIcons/CollapseIcon.js +17 -17
  373. package/cjs/PRIVATE_ThemedIcons/CollapseUpIcon.js +16 -16
  374. package/cjs/PRIVATE_ThemedIcons/DecrementIcon.js +16 -16
  375. package/cjs/PRIVATE_ThemedIcons/DeleteIcon.js +16 -16
  376. package/cjs/PRIVATE_ThemedIcons/DirectionalCollapseArrowIcon.js +17 -17
  377. package/cjs/PRIVATE_ThemedIcons/DirectionalExpandArrowIcon.js +17 -17
  378. package/cjs/PRIVATE_ThemedIcons/DragHandleIcon.js +16 -16
  379. package/cjs/PRIVATE_ThemedIcons/DropdownArrowIcon.js +16 -16
  380. package/cjs/PRIVATE_ThemedIcons/ExpandIcon.js +16 -16
  381. package/cjs/PRIVATE_ThemedIcons/HelpIcon.js +16 -16
  382. package/cjs/PRIVATE_ThemedIcons/IncrementIcon.js +16 -16
  383. package/cjs/PRIVATE_ThemedIcons/MenuButtonDropdownIcon.js +16 -16
  384. package/cjs/PRIVATE_ThemedIcons/MessageConfirmationIcon.js +16 -16
  385. package/cjs/PRIVATE_ThemedIcons/MessageErrorIcon.js +16 -16
  386. package/cjs/PRIVATE_ThemedIcons/MessageInfoIcon.js +16 -16
  387. package/cjs/PRIVATE_ThemedIcons/MessageWarningIcon.js +16 -16
  388. package/cjs/PRIVATE_ThemedIcons/MinusIcon.js +16 -16
  389. package/cjs/PRIVATE_ThemedIcons/NavDownIcon.js +16 -16
  390. package/cjs/PRIVATE_ThemedIcons/None.js +16 -16
  391. package/cjs/PRIVATE_ThemedIcons/OverviewHorizontalDragHandleIcon.js +16 -16
  392. package/cjs/PRIVATE_ThemedIcons/PlusIcon.js +16 -16
  393. package/cjs/PRIVATE_ThemedIcons/RadioOffIcon.js +16 -16
  394. package/cjs/PRIVATE_ThemedIcons/RadioOnIcon.js +16 -16
  395. package/cjs/PRIVATE_ThemedIcons/SortAscendingIcon.js +16 -16
  396. package/cjs/PRIVATE_ThemedIcons/SortDescendingIcon.js +16 -16
  397. package/cjs/PRIVATE_ThemedIcons/ViewHideIcon.js +16 -16
  398. package/cjs/PRIVATE_ThemedIcons/ViewIcon.js +16 -16
  399. package/cjs/PRIVATE_TimeComponent.js +19 -19
  400. package/cjs/PRIVATE_TruncatingLink.js +20 -17
  401. package/cjs/PRIVATE_TruncatingLink.js.map +1 -1
  402. package/cjs/PRIVATE_VisOverview.js +16 -16
  403. package/cjs/PRIVATE_VisStatusMessage.js +5 -5
  404. package/cjs/PRIVATE_VisTabularDatatip.js +4 -4
  405. package/cjs/Popup-6de390dd.js +300 -0
  406. package/cjs/Popup-6de390dd.js.map +1 -0
  407. package/cjs/ProgressButtonLabelLayout-2e429893.js +3 -3
  408. package/cjs/ProgressCircle-f9c43168.js +50 -0
  409. package/cjs/ProgressCircle-f9c43168.js.map +1 -0
  410. package/cjs/RadioItem-c74ac827.js +6 -6
  411. package/cjs/ReadonlyTextFieldInput-60965d77.js +1 -1
  412. package/cjs/ReferenceLineArea-d00d2b33.js +592 -0
  413. package/cjs/ReferenceLineArea-d00d2b33.js.map +1 -0
  414. package/cjs/RevealToggleIcon-6a86726c.js +28 -0
  415. package/cjs/RevealToggleIcon-6a86726c.js.map +1 -0
  416. package/cjs/SectionedContent-463bf70e.js +68 -0
  417. package/cjs/SectionedContent-463bf70e.js.map +1 -0
  418. package/cjs/SelectMenuGroupContext-002c9144.js +563 -0
  419. package/cjs/SelectMenuGroupContext-002c9144.js.map +1 -0
  420. package/cjs/SelectMobileFieldInput-2adf002d.js +248 -0
  421. package/cjs/SelectMobileFieldInput-2adf002d.js.map +1 -0
  422. package/cjs/SelectorAll-2905a1c9.js +53 -0
  423. package/cjs/SelectorAll-2905a1c9.js.map +1 -0
  424. package/cjs/Sheet-1d6e8cf8.js +2 -2
  425. package/cjs/SortControl-8c15705b.js +3 -3
  426. package/cjs/StyledCard-13c323e4.js +1 -1
  427. package/cjs/StyledDatePickerButton-f20c0596.js +34 -0
  428. package/cjs/StyledDatePickerButton-f20c0596.js.map +1 -0
  429. package/cjs/StyledDatePickerButtonStyles.styles.css +18 -12
  430. package/cjs/StyledLabelValueLayout-3ee66ef1.js +22 -0
  431. package/cjs/StyledLabelValueLayout-3ee66ef1.js.map +1 -0
  432. package/cjs/StyledSwitch-17127a03.js +2 -2
  433. package/cjs/StyledTextField-7839c90d.js +5 -5
  434. package/cjs/Submenu-fb652ff4.js +251 -0
  435. package/cjs/Submenu-fb652ff4.js.map +1 -0
  436. package/cjs/TabBar-1e6a97b5.js +73 -0
  437. package/cjs/TabBar-1e6a97b5.js.map +1 -0
  438. package/cjs/TabBarContextMenu-f7acee3d.js +102 -0
  439. package/cjs/TabBarContextMenu-f7acee3d.js.map +1 -0
  440. package/cjs/TabBarLayout-ca8af14b.js +1 -1
  441. package/cjs/TabBarLinkItem-8f54f16d.js +15 -0
  442. package/cjs/TabBarLinkItem-8f54f16d.js.map +1 -0
  443. package/cjs/Table-daa93733.js +4114 -0
  444. package/cjs/Table-daa93733.js.map +1 -0
  445. package/cjs/TableColGroup-b7e1e296.js +1 -1
  446. package/cjs/TextArea-85d34b3e.js +229 -0
  447. package/cjs/TextArea-85d34b3e.js.map +1 -0
  448. package/cjs/TextField-5c164264.js +3 -3
  449. package/cjs/Theme-redwood/theme.css +145 -145
  450. package/cjs/Theme-stable/theme.css +138 -138
  451. package/cjs/TimeComponentCanvas2D-baa58795.js +6 -6
  452. package/cjs/ToggleButton-0ec0c75b.js +30 -0
  453. package/cjs/ToggleButton-0ec0c75b.js.map +1 -0
  454. package/cjs/ToggleButtonLabel-ce19879c.js +77 -0
  455. package/cjs/ToggleButtonLabel-ce19879c.js.map +1 -0
  456. package/cjs/TruncatingLink-f6a80ee5.js +95 -0
  457. package/cjs/TruncatingLink-f6a80ee5.js.map +1 -0
  458. package/cjs/TruncatingText-ac1f6793.js +1 -1
  459. package/cjs/UNSAFE_AccordionItemMultiple.js +18 -18
  460. package/cjs/UNSAFE_AccordionItemSingle.js +18 -18
  461. package/cjs/UNSAFE_ActionCard.js +2 -2
  462. package/cjs/UNSAFE_BarChart.js +49 -49
  463. package/cjs/UNSAFE_BareButton.js +2 -2
  464. package/cjs/UNSAFE_BaseButton.js +5 -5
  465. package/cjs/UNSAFE_Button.js +6 -6
  466. package/cjs/UNSAFE_ButtonSet.js +4 -4
  467. package/cjs/UNSAFE_ButtonSetButton.js +7 -7
  468. package/cjs/UNSAFE_ButtonSetIconButton.js +19 -19
  469. package/cjs/UNSAFE_ButtonSetItem.js +22 -22
  470. package/cjs/UNSAFE_ButtonSetMultiple.js +4 -4
  471. package/cjs/UNSAFE_ButtonSetSingle.js +4 -4
  472. package/cjs/UNSAFE_Card.js +3 -3
  473. package/cjs/UNSAFE_CardFlexView.js +22 -22
  474. package/cjs/UNSAFE_CardGridView.js +22 -22
  475. package/cjs/UNSAFE_Center.js +5 -5
  476. package/cjs/UNSAFE_Checkbox.js +25 -25
  477. package/cjs/UNSAFE_CheckboxItem.js +71 -132
  478. package/cjs/UNSAFE_CheckboxItem.js.map +1 -1
  479. package/cjs/UNSAFE_CheckboxRadioField.js +4 -4
  480. package/cjs/UNSAFE_CheckboxSet.js +75 -46
  481. package/cjs/UNSAFE_CheckboxSet.js.map +1 -1
  482. package/cjs/UNSAFE_Chip.js +2 -2
  483. package/cjs/UNSAFE_Collapsible.js +18 -18
  484. package/cjs/UNSAFE_ColorPalette.js +95 -95
  485. package/cjs/UNSAFE_ColorPicker.js +77 -77
  486. package/cjs/UNSAFE_ColorSwatch.js +17 -17
  487. package/cjs/UNSAFE_ComboChart.js +49 -49
  488. package/cjs/UNSAFE_ComponentMessage.js +20 -20
  489. package/cjs/UNSAFE_ContainerDiagram.js +38 -38
  490. package/cjs/UNSAFE_ConveyorBelt.js +18 -18
  491. package/cjs/UNSAFE_DatePicker.js +54 -31
  492. package/cjs/UNSAFE_DatePicker.js.map +1 -1
  493. package/cjs/UNSAFE_Diagram.js +38 -38
  494. package/cjs/UNSAFE_Dialog.js +22 -22
  495. package/cjs/UNSAFE_DragHandle.js +17 -17
  496. package/cjs/UNSAFE_DrawerLayout.js +12 -12
  497. package/cjs/UNSAFE_DrawerPopup.js +11 -11
  498. package/cjs/UNSAFE_Dropdown.js +15 -15
  499. package/cjs/UNSAFE_Environment.js +4 -4
  500. package/cjs/UNSAFE_ExpandableList.js +25 -25
  501. package/cjs/UNSAFE_FilePicker.js +4 -4
  502. package/cjs/UNSAFE_FlatTreeView.js +25 -25
  503. package/cjs/UNSAFE_Flex.js +4 -4
  504. package/cjs/UNSAFE_Floating.js +11 -11
  505. package/cjs/UNSAFE_FormLayout.js +2 -2
  506. package/cjs/UNSAFE_Gantt.js +23 -23
  507. package/cjs/UNSAFE_Grid.js +4 -4
  508. package/cjs/UNSAFE_HighlightText.js +4 -4
  509. package/cjs/UNSAFE_Icon.js +16 -16
  510. package/cjs/UNSAFE_IconButton.js +17 -17
  511. package/cjs/UNSAFE_IconMenuButton.js +26 -26
  512. package/cjs/UNSAFE_IconProgressButton.js +21 -21
  513. package/cjs/UNSAFE_IconToggleButton.js +19 -19
  514. package/cjs/UNSAFE_Indexer.js +19 -19
  515. package/cjs/UNSAFE_InlineSelectSingle.js +34 -34
  516. package/cjs/UNSAFE_InputColor.js +42 -42
  517. package/cjs/UNSAFE_InputDateMask.js +26 -26
  518. package/cjs/UNSAFE_InputDatePicker.js +149 -127
  519. package/cjs/UNSAFE_InputDatePicker.js.map +1 -1
  520. package/cjs/UNSAFE_InputPassword.js +29 -29
  521. package/cjs/UNSAFE_InputSensitiveText.js +30 -30
  522. package/cjs/UNSAFE_InputText.js +28 -28
  523. package/cjs/UNSAFE_InputTimeMask.js +26 -26
  524. package/cjs/UNSAFE_Label.js +25 -25
  525. package/cjs/UNSAFE_LabelValueLayout.js +4 -4
  526. package/cjs/UNSAFE_LabelledLink.js +36 -31
  527. package/cjs/UNSAFE_LabelledLink.js.map +1 -1
  528. package/cjs/UNSAFE_Layer.js +8 -8
  529. package/cjs/UNSAFE_Legend.js +30 -30
  530. package/cjs/UNSAFE_LineAreaChart.js +49 -49
  531. package/cjs/UNSAFE_Link/themes/LinkStyles.css.js +1 -1
  532. package/cjs/UNSAFE_Link.js +3 -3
  533. package/cjs/UNSAFE_ListItemLayout.js +4 -4
  534. package/cjs/UNSAFE_ListView.js +29 -29
  535. package/cjs/UNSAFE_LiveRegion.js +4 -4
  536. package/cjs/UNSAFE_Menu.js +28 -28
  537. package/cjs/UNSAFE_MenuButton.js +26 -26
  538. package/cjs/UNSAFE_MessageBanner.js +20 -20
  539. package/cjs/UNSAFE_MessageToast.js +22 -22
  540. package/cjs/UNSAFE_MeterBar.js +16 -16
  541. package/cjs/UNSAFE_MeterCircle.js +17 -17
  542. package/cjs/UNSAFE_Modal.js +8 -8
  543. package/cjs/UNSAFE_NavigationList.js +38 -40
  544. package/cjs/UNSAFE_NavigationList.js.map +1 -1
  545. package/cjs/UNSAFE_NavigationListCommon.js +33 -34
  546. package/cjs/UNSAFE_NavigationListCommon.js.map +1 -1
  547. package/cjs/UNSAFE_NumberInputText.js +28 -28
  548. package/cjs/UNSAFE_OverflowTabBar.js +85 -88
  549. package/cjs/UNSAFE_OverflowTabBar.js.map +1 -1
  550. package/cjs/UNSAFE_PictoChart.js +27 -27
  551. package/cjs/UNSAFE_PieChart.js +28 -28
  552. package/cjs/UNSAFE_Popup.js +18 -18
  553. package/cjs/UNSAFE_ProgressBar.js +4 -4
  554. package/cjs/UNSAFE_ProgressButton.js +21 -21
  555. package/cjs/UNSAFE_ProgressButtonLabelLayout.js +10 -10
  556. package/cjs/UNSAFE_ProgressCircle.js +4 -4
  557. package/cjs/UNSAFE_RadioItem.js +25 -25
  558. package/cjs/UNSAFE_RadioSet.js +27 -27
  559. package/cjs/UNSAFE_RatingGauge.js +18 -18
  560. package/cjs/UNSAFE_ReorderableTabBar.js +44 -57
  561. package/cjs/UNSAFE_ReorderableTabBar.js.map +1 -1
  562. package/cjs/UNSAFE_RichCheckboxSet.js +64 -68
  563. package/cjs/UNSAFE_RichCheckboxSet.js.map +1 -1
  564. package/cjs/UNSAFE_RichRadioSet.js +29 -29
  565. package/cjs/UNSAFE_RichSelectionItem.js +112 -175
  566. package/cjs/UNSAFE_RichSelectionItem.js.map +1 -1
  567. package/cjs/UNSAFE_ScatterChart.js +49 -49
  568. package/cjs/UNSAFE_SectionalLegend.js +30 -30
  569. package/cjs/UNSAFE_SelectMultiple.js +38 -38
  570. package/cjs/UNSAFE_SelectSingle.js +38 -38
  571. package/cjs/UNSAFE_SelectionCard.js +3 -3
  572. package/cjs/UNSAFE_Selector.js +17 -17
  573. package/cjs/UNSAFE_SelectorAll.js +19 -19
  574. package/cjs/UNSAFE_Sheet.js +11 -11
  575. package/cjs/UNSAFE_SortControl.js +20 -20
  576. package/cjs/UNSAFE_SplitMenuButton.js +27 -27
  577. package/cjs/UNSAFE_SplitMenuButton.js.map +1 -1
  578. package/cjs/UNSAFE_Switch.js +26 -26
  579. package/cjs/UNSAFE_TabBar.js +87 -90
  580. package/cjs/UNSAFE_TabBar.js.map +1 -1
  581. package/cjs/UNSAFE_TabBarCommon.js +100 -103
  582. package/cjs/UNSAFE_TabBarCommon.js.map +1 -1
  583. package/cjs/UNSAFE_TabBarMixed.js +61 -64
  584. package/cjs/UNSAFE_TabBarMixed.js.map +1 -1
  585. package/cjs/UNSAFE_TableView.js +38 -38
  586. package/cjs/UNSAFE_TagCloud.js +28 -28
  587. package/cjs/UNSAFE_TextArea.js +119 -234
  588. package/cjs/UNSAFE_TextArea.js.map +1 -1
  589. package/cjs/UNSAFE_TextAreaAutosize.js +30 -30
  590. package/cjs/UNSAFE_TextAreaAutosize.js.map +1 -1
  591. package/cjs/UNSAFE_TextField.js +20 -20
  592. package/cjs/UNSAFE_ToggleButton.js +7 -7
  593. package/cjs/UNSAFE_ToggleButtonLabel.js +1 -1
  594. package/cjs/UNSAFE_Toolbar.js +4 -4
  595. package/cjs/UNSAFE_Train.js +17 -17
  596. package/cjs/UNSAFE_TruncatingBadge.js +17 -17
  597. package/cjs/UNSAFE_TruncatingText.js +17 -17
  598. package/cjs/UNSAFE_UserAssistance.js +26 -26
  599. package/cjs/UNSAFE_View.js +7 -7
  600. package/cjs/UNSAFE_VirtualizedListView.js +21 -21
  601. package/cjs/UNSAFE_VisInvalidDataMessage.js +6 -6
  602. package/cjs/UNSAFE_VisNoDataMessage.js +6 -6
  603. package/cjs/UNSAFE_VisProgressiveLoader.js +5 -5
  604. package/cjs/UNSAFE_WindowOverlay.js +4 -4
  605. package/cjs/View-67ff7d0e.js +170 -0
  606. package/cjs/View-67ff7d0e.js.map +1 -0
  607. package/cjs/VisStatusMessage-3ca153ac.js +31 -0
  608. package/cjs/VisStatusMessage-3ca153ac.js.map +1 -0
  609. package/cjs/VisTabularDatatip-e79da9de.js +26 -0
  610. package/cjs/VisTabularDatatip-e79da9de.js.map +1 -0
  611. package/cjs/WindowOverlay-b9595d88.js +112 -0
  612. package/cjs/WindowOverlay-b9595d88.js.map +1 -0
  613. package/cjs/YearsGridView-9fd78c0f.js +190 -0
  614. package/cjs/YearsGridView-9fd78c0f.js.map +1 -0
  615. package/cjs/hoc/PRIVATE_withDirectionIcon.js +4 -4
  616. package/cjs/hoc/PRIVATE_withThemeIcon.js +3 -3
  617. package/cjs/hoc/UNSAFE_withThemeProps.js +3 -3
  618. package/cjs/hooks/PRIVATE_useChartContextMenu.js +26 -26
  619. package/cjs/hooks/PRIVATE_useChartDatatip.js +14 -14
  620. package/cjs/hooks/PRIVATE_useChartEvents.js +19 -19
  621. package/cjs/hooks/PRIVATE_useChartMarquee.js +26 -26
  622. package/cjs/hooks/PRIVATE_useCollectionFocusRing.js +17 -17
  623. package/cjs/hooks/PRIVATE_useCssVars.js +7 -7
  624. package/cjs/hooks/PRIVATE_useCurrentKey.js +4 -4
  625. package/cjs/hooks/PRIVATE_useDatatip.js +12 -12
  626. package/cjs/hooks/PRIVATE_useDetectHorizontalOverflow.js +16 -16
  627. package/cjs/hooks/PRIVATE_useFloating.js +4 -4
  628. package/cjs/hooks/PRIVATE_useItemAction.js +17 -17
  629. package/cjs/hooks/PRIVATE_useListCommon.js +19 -19
  630. package/cjs/hooks/PRIVATE_useMiddleEllipsis.js +12 -0
  631. package/cjs/hooks/PRIVATE_useMiddleEllipsis.js.map +1 -0
  632. package/cjs/hooks/PRIVATE_useOutsideMousedown.js +9 -9
  633. package/cjs/hooks/PRIVATE_useRadioFocusManager.js +4 -4
  634. package/cjs/hooks/PRIVATE_useReorderable.js +19 -19
  635. package/cjs/hooks/PRIVATE_useRovingTabIndexContainer.js +4 -4
  636. package/cjs/hooks/PRIVATE_useSelection.js +4 -4
  637. package/cjs/hooks/PRIVATE_useTabBar.js +29 -29
  638. package/cjs/hooks/PRIVATE_useTabbableModeSet.js +17 -17
  639. package/cjs/hooks/PRIVATE_useTooltipOnTruncation.js +17 -17
  640. package/cjs/hooks/PRIVATE_useVisContextMenu.js +25 -25
  641. package/cjs/hooks/PRIVATE_useVisDragModeControls.js +25 -25
  642. package/cjs/hooks/PRIVATE_useVisEvents.js +4 -4
  643. package/cjs/hooks/PRIVATE_useVisMeterEvents.js +14 -14
  644. package/cjs/hooks/PRIVATE_useVisSelection.js +15 -15
  645. package/cjs/hooks/UNSAFE_useBareButton.js +2 -2
  646. package/cjs/hooks/UNSAFE_useColorScheme.js +3 -3
  647. package/cjs/hooks/UNSAFE_useCurrentBgColor.js +2 -2
  648. package/cjs/hooks/UNSAFE_useDensity.js +3 -3
  649. package/cjs/hooks/UNSAFE_useHiddenTestMethod.js +3 -3
  650. package/cjs/hooks/UNSAFE_useOutsideClick.js +8 -8
  651. package/cjs/hooks/UNSAFE_usePrefixSuffix.js +4 -4
  652. package/cjs/hooks/UNSAFE_useScale.js +3 -3
  653. package/cjs/hooks/UNSAFE_useTestId.js +3 -3
  654. package/cjs/hooks/UNSAFE_useTheme.js +3 -3
  655. package/cjs/hooks/UNSAFE_useThemeInterpolations.js +6 -6
  656. package/cjs/hooks/UNSAFE_useTooltip.js +17 -17
  657. package/cjs/hooks/UNSAFE_useTranslationBundle.js +3 -3
  658. package/cjs/hooks/UNSAFE_useUser.js +3 -3
  659. package/cjs/popupUtils-79656e59.js +31 -0
  660. package/cjs/popupUtils-79656e59.js.map +1 -0
  661. package/cjs/tooltipUtils-c554343d.js +115 -0
  662. package/cjs/tooltipUtils-c554343d.js.map +1 -0
  663. package/cjs/useBareButton-463210c9.js +1 -1
  664. package/cjs/useCellNavigation-09201a92.js +1 -1
  665. package/cjs/useChartContextMenu-c961873c.js +125 -0
  666. package/cjs/useChartContextMenu-c961873c.js.map +1 -0
  667. package/cjs/useChartDatatip-0ead533e.js +341 -0
  668. package/cjs/useChartDatatip-0ead533e.js.map +1 -0
  669. package/cjs/useChartMarquee-ade8e91c.js +306 -0
  670. package/cjs/useChartMarquee-ade8e91c.js.map +1 -0
  671. package/cjs/useColorScheme-852ec82e.js +21 -0
  672. package/cjs/useColorScheme-852ec82e.js.map +1 -0
  673. package/cjs/useContextMenu-c02f8dee.js +119 -0
  674. package/cjs/useContextMenu-c02f8dee.js.map +1 -0
  675. package/cjs/useCssVars-b7192b44.js +60 -0
  676. package/cjs/useCssVars-b7192b44.js.map +1 -0
  677. package/cjs/useCurrentKey-b66cf089.js +85 -0
  678. package/cjs/useCurrentKey-b66cf089.js.map +1 -0
  679. package/cjs/useDatatip-3462cc49.js +96 -0
  680. package/cjs/useDatatip-3462cc49.js.map +1 -0
  681. package/cjs/useDensity-2a45f4dd.js +21 -0
  682. package/cjs/useDensity-2a45f4dd.js.map +1 -0
  683. package/cjs/useDisplayValue-047ff360.js +82 -0
  684. package/cjs/useDisplayValue-047ff360.js.map +1 -0
  685. package/cjs/useExpandCollapse-359c0224.js +72 -0
  686. package/cjs/useExpandCollapse-359c0224.js.map +1 -0
  687. package/cjs/useFloating-c408d4be.js +1926 -0
  688. package/cjs/useFloating-c408d4be.js.map +1 -0
  689. package/cjs/useHiddenTestMethod-620e91e0.js +30 -0
  690. package/cjs/useHiddenTestMethod-620e91e0.js.map +1 -0
  691. package/cjs/useKeyboardEvents-d9528b16.js +88 -0
  692. package/cjs/useKeyboardEvents-d9528b16.js.map +1 -0
  693. package/cjs/useLegendContextMenu-b7993cf0.js +285 -0
  694. package/cjs/useLegendContextMenu-b7993cf0.js.map +1 -0
  695. package/cjs/useMeterDatatip-fdab9ee5.js +76 -0
  696. package/cjs/useMeterDatatip-fdab9ee5.js.map +1 -0
  697. package/cjs/useMiddleEllipsis-792e61a9.js +230 -0
  698. package/cjs/useMiddleEllipsis-792e61a9.js.map +1 -0
  699. package/cjs/useNavigation-fa3f5a50.js +1 -1
  700. package/cjs/useOutsideClick-5c31ee35.js +117 -0
  701. package/cjs/useOutsideClick-5c31ee35.js.map +1 -0
  702. package/cjs/useOutsideMousedown-eda95637.js +50 -0
  703. package/cjs/useOutsideMousedown-eda95637.js.map +1 -0
  704. package/cjs/usePopupAnimation-985e90a2.js +87 -0
  705. package/cjs/usePopupAnimation-985e90a2.js.map +1 -0
  706. package/cjs/usePrefixSuffix-a6a1b772.js +72 -0
  707. package/cjs/usePrefixSuffix-a6a1b772.js.map +1 -0
  708. package/cjs/useRadioFocusManager-58e51026.js +110 -0
  709. package/cjs/useRadioFocusManager-58e51026.js.map +1 -0
  710. package/cjs/useReorderableItem-969a3eac.js +299 -0
  711. package/cjs/useReorderableItem-969a3eac.js.map +1 -0
  712. package/cjs/useRovingTabIndexContainer-46b897fd.js +108 -0
  713. package/cjs/useRovingTabIndexContainer-46b897fd.js.map +1 -0
  714. package/cjs/useScale-529046e3.js +21 -0
  715. package/cjs/useScale-529046e3.js.map +1 -0
  716. package/cjs/useSelectCommon-728573f9.js +507 -0
  717. package/cjs/useSelectCommon-728573f9.js.map +1 -0
  718. package/cjs/useSelectDrill-813d4fbe.js +114 -0
  719. package/cjs/useSelectDrill-813d4fbe.js.map +1 -0
  720. package/cjs/useSelection-0b3dd2cf.js +188 -0
  721. package/cjs/useSelection-0b3dd2cf.js.map +1 -0
  722. package/cjs/useSelection-0ef0ee3c.js +260 -0
  723. package/cjs/useSelection-0ef0ee3c.js.map +1 -0
  724. package/cjs/useTabBar-114caa2f.js +309 -0
  725. package/cjs/useTabBar-114caa2f.js.map +1 -0
  726. package/cjs/useTestId-a8b07506.js +23 -0
  727. package/cjs/useTestId-a8b07506.js.map +1 -0
  728. package/cjs/useTheme-71e406b0.js +21 -0
  729. package/cjs/useTheme-71e406b0.js.map +1 -0
  730. package/cjs/useThemeInterpolations-ca3ddfd9.js +71 -0
  731. package/cjs/useThemeInterpolations-ca3ddfd9.js.map +1 -0
  732. package/cjs/useTooltip-d1200aff.js +51 -0
  733. package/cjs/useTooltip-d1200aff.js.map +1 -0
  734. package/cjs/useTooltipControlled-0dc34549.js +376 -0
  735. package/cjs/useTooltipControlled-0dc34549.js.map +1 -0
  736. package/cjs/useTooltipOnTruncation-d8253c7e.js +29 -0
  737. package/cjs/useTooltipOnTruncation-d8253c7e.js.map +1 -0
  738. package/cjs/useTranslationBundle-990e7928.js +31 -0
  739. package/cjs/useTranslationBundle-990e7928.js.map +1 -0
  740. package/cjs/useUser-cc045b3e.js +21 -0
  741. package/cjs/useUser-cc045b3e.js.map +1 -0
  742. package/cjs/useVisDragModeControls-737aa2dd.js +89 -0
  743. package/cjs/useVisDragModeControls-737aa2dd.js.map +1 -0
  744. package/cjs/useVisEvents-4ad7b798.js +155 -0
  745. package/cjs/useVisEvents-4ad7b798.js.map +1 -0
  746. package/cjs/utils/PRIVATE_collectionUtils.js +17 -17
  747. package/cjs/utils/PRIVATE_tabBarUtils.js +17 -17
  748. package/cjs/utils/PRIVATE_tooltipUtils.js +14 -14
  749. package/cjs/utils/PRIVATE_visTestUtils.js +4 -4
  750. package/cjs/utils/UNSAFE_popupUtils.js +8 -8
  751. package/cjs/withDirectionIcon-a14b071b.js +16 -0
  752. package/cjs/withDirectionIcon-a14b071b.js.map +1 -0
  753. package/cjs/withThemeProps-894a40fc.js +2 -2
  754. package/es/BaseButton-243d200f.js +84 -0
  755. package/es/BaseButton-243d200f.js.map +1 -0
  756. package/es/BaseCardView-85b9a71e.js +631 -0
  757. package/es/BaseCardView-85b9a71e.js.map +1 -0
  758. package/es/BaseDiagram-19f481a0.js +2954 -0
  759. package/es/BaseDiagram-19f481a0.js.map +1 -0
  760. package/es/BaseRichSelection-223d9830.js +9 -9
  761. package/es/BaseSelector-7cbc48bc.js +1 -1
  762. package/es/BaseSwatchView-2e1e6bd2.js +2 -2
  763. package/es/Button-a76ecfa8.js +22 -0
  764. package/es/Button-a76ecfa8.js.map +1 -0
  765. package/es/ButtonSet-b7464e9a.js +2 -2
  766. package/es/ButtonSetButton-5e07834a.js +33 -0
  767. package/es/ButtonSetButton-5e07834a.js.map +1 -0
  768. package/es/ButtonSetIconButton-7e6573a0.js +38 -0
  769. package/es/ButtonSetIconButton-7e6573a0.js.map +1 -0
  770. package/es/ButtonSetItem-08dd9bd2.js +65 -0
  771. package/es/ButtonSetItem-08dd9bd2.js.map +1 -0
  772. package/es/Center-3860fe60.js +16 -0
  773. package/es/Center-3860fe60.js.map +1 -0
  774. package/es/Chart-aeda6a0c.js +752 -0
  775. package/es/Chart-aeda6a0c.js.map +1 -0
  776. package/es/CheckboxControl-c008372a.js +6 -6
  777. package/es/CheckboxRadioField-a387b3cb.js +6 -6
  778. package/es/CheckboxRadioLabelValueLayout-e3845f16.js +1 -1
  779. package/es/CheckboxSet-3aab5935.js +1 -1
  780. package/es/Chip-4efea02e.js +1 -1
  781. package/es/ClearIcon-f85ea340.js +1 -1
  782. package/es/CollapseIcon-84f6ba8e.js +1 -1
  783. package/es/Collapsible-2608ce3b.js +2 -2
  784. package/es/ColorPalette-950c6fc6.js +2 -2
  785. package/es/ColorPicker-8c297849.js +23 -0
  786. package/es/ColorPicker-8c297849.js.map +1 -0
  787. package/es/ColorSwatch-8339ee2f.js +4 -4
  788. package/es/CompactLabelAssistance-50ff3f7e.js +92 -0
  789. package/es/CompactLabelAssistance-50ff3f7e.js.map +1 -0
  790. package/es/CompactUserAssistance-6aa8894b.js +5 -5
  791. package/es/ComponentMessageContainer-d16c8b1f.js +4 -4
  792. package/es/DatePicker-6861ae90.js +599 -0
  793. package/es/DatePicker-6861ae90.js.map +1 -0
  794. package/es/DatePickerHeader-1a050945.js +46 -0
  795. package/es/DatePickerHeader-1a050945.js.map +1 -0
  796. package/es/DiagramStyles.styles2.css +10 -16
  797. package/es/DiagramStyles.styles3.css +16 -10
  798. package/es/Dialog-d1de5b06.js +387 -0
  799. package/es/Dialog-d1de5b06.js.map +1 -0
  800. package/es/DirectionalCollapseArrowIcon-132761da.js +1 -1
  801. package/es/DirectionalExpandArrowIcon-5bc45cad.js +1 -1
  802. package/es/Dropdown-f7992670.js +322 -0
  803. package/es/Dropdown-f7992670.js.map +1 -0
  804. package/es/EmbeddedIconButton-9f0e56b7.js +11 -0
  805. package/es/EmbeddedIconButton-9f0e56b7.js.map +1 -0
  806. package/es/EnvironmentProvider-6cf8ed37.js +58 -0
  807. package/es/EnvironmentProvider-6cf8ed37.js.map +1 -0
  808. package/es/Expander-1347e769.js +1 -1
  809. package/es/Flex-fc483125.js +30 -0
  810. package/es/Flex-fc483125.js.map +1 -0
  811. package/es/Floating-be4c0cb6.js +465 -0
  812. package/es/Floating-be4c0cb6.js.map +1 -0
  813. package/es/Grid-6f92d323.js +27 -0
  814. package/es/Grid-6f92d323.js.map +1 -0
  815. package/es/GroupLoadingIndicator-19c6545a.js +1 -1
  816. package/es/HighlightText-dd484ffd.js +31 -0
  817. package/es/HighlightText-dd484ffd.js.map +1 -0
  818. package/es/Icon-4983d06e.js +3 -3
  819. package/es/IconButton-7f91481c.js +4 -4
  820. package/es/IconSwitchButton-0ef3178f.js +42 -0
  821. package/es/IconSwitchButton-0ef3178f.js.map +1 -0
  822. package/es/IconToggleButton-7d9efcb3.js +41 -0
  823. package/es/IconToggleButton-7d9efcb3.js.map +1 -0
  824. package/es/IconUserAssistance-6abc7837.js +74 -0
  825. package/es/IconUserAssistance-6abc7837.js.map +1 -0
  826. package/es/InlineHelp-9eaac91c.js +1 -1
  827. package/es/InlineUserAssistance-890293dd.js +5 -5
  828. package/es/InputDateMask-ec27aee7.js +7 -7
  829. package/es/Label-5d1ae8d7.js +8 -8
  830. package/es/LabelValueLayout-c6b9945a.js +1 -1
  831. package/es/Layer-6c27170e.js +91 -0
  832. package/es/Layer-6c27170e.js.map +1 -0
  833. package/es/LayerHost-3cf255a6.js +41 -0
  834. package/es/LayerHost-3cf255a6.js.map +1 -0
  835. package/es/LayerManager-e30fbfd6.js +34 -0
  836. package/es/LayerManager-e30fbfd6.js.map +1 -0
  837. package/es/Link-db2fdeab.js +33 -0
  838. package/es/Link-db2fdeab.js.map +1 -0
  839. package/es/LinkVariants.styles.css +0 -1
  840. package/es/LinkVariants.styles2.css +0 -1
  841. package/es/List-4636ba9b.js +5 -5
  842. package/es/LiveRegion-2e8830ae.js +39 -0
  843. package/es/LiveRegion-2e8830ae.js.map +1 -0
  844. package/es/MaxLengthLiveRegion-8f552ae2.js +26 -0
  845. package/es/MaxLengthLiveRegion-8f552ae2.js.map +1 -0
  846. package/es/Message-510c2db8.js +2 -2
  847. package/es/MessageLayer-1dbdc0b6.js +58 -0
  848. package/es/MessageLayer-1dbdc0b6.js.map +1 -0
  849. package/es/MessagesManager-47000438.js +3 -3
  850. package/es/Modal-c0f730b8.js +3 -3
  851. package/es/MonthView-6628071f.js +229 -0
  852. package/es/MonthView-6628071f.js.map +1 -0
  853. package/es/NavigationListItem-3a9e0951.js +291 -0
  854. package/es/NavigationListItem-3a9e0951.js.map +1 -0
  855. package/es/NavigationListLinkItem-e28fd846.js +5 -5
  856. package/es/NumberInputText-60be5757.js +6 -6
  857. package/es/OverflowTabBarItem-ee746856.js +257 -0
  858. package/es/OverflowTabBarItem-ee746856.js.map +1 -0
  859. package/es/PRIVATE_BaseCardView.js +23 -23
  860. package/es/PRIVATE_BaseDiagram.js +38 -38
  861. package/es/PRIVATE_BaseSelector.js +17 -17
  862. package/es/PRIVATE_BaseSwatchView.js +18 -18
  863. package/es/PRIVATE_Chart.js +45 -45
  864. package/es/PRIVATE_CheckboxControl.js +25 -25
  865. package/es/PRIVATE_CheckboxRadioField.js +27 -27
  866. package/es/PRIVATE_ClearIcon.js +18 -18
  867. package/es/PRIVATE_CollapsibleNavigationList.js +20 -20
  868. package/es/PRIVATE_DatePickerHeader.js +23 -23
  869. package/es/PRIVATE_DatePickerLayout.js +4 -4
  870. package/es/PRIVATE_EmbeddedIconButton.js +6 -6
  871. package/es/PRIVATE_Expander.js +19 -19
  872. package/es/PRIVATE_FormControls.js +21 -21
  873. package/es/PRIVATE_IconSwitchButton.js +19 -19
  874. package/es/PRIVATE_Icons/CheckboxCrossed.js +16 -16
  875. package/es/PRIVATE_Icons/CheckboxMixed.js +16 -16
  876. package/es/PRIVATE_Icons/CheckboxOff.js +16 -16
  877. package/es/PRIVATE_Icons/CheckboxOn.js +16 -16
  878. package/es/PRIVATE_Icons/DragV.js +16 -16
  879. package/es/PRIVATE_Icons/None.js +16 -16
  880. package/es/PRIVATE_List.js +21 -21
  881. package/es/PRIVATE_Message.js +20 -20
  882. package/es/PRIVATE_MessageLayer.js +12 -12
  883. package/es/PRIVATE_MonthView.js +81 -8
  884. package/es/PRIVATE_MonthView.js.map +1 -1
  885. package/es/PRIVATE_MonthYearGridView.js +8 -8
  886. package/es/PRIVATE_PlotArea.js +5 -5
  887. package/es/PRIVATE_RevealToggleIcon.js +21 -21
  888. package/es/PRIVATE_RichSelectionCommon.js +28 -28
  889. package/es/PRIVATE_SelectCommon.js +34 -34
  890. package/es/PRIVATE_StyledCard.js +3 -3
  891. package/es/PRIVATE_StyledCheckbox.js +16 -16
  892. package/es/PRIVATE_StyledDatePickerButton/themes/StyledDatePickerButtonStyles.css.js +1 -1
  893. package/es/PRIVATE_StyledDatePickerButton.js +1 -1
  894. package/es/PRIVATE_StyledSwitch.js +4 -4
  895. package/es/PRIVATE_SwatchFlexView.js +18 -18
  896. package/es/PRIVATE_Table.js +38 -38
  897. package/es/PRIVATE_TableDisplay.js +19 -19
  898. package/es/PRIVATE_TableList.js +31 -31
  899. package/es/PRIVATE_ThemedIcons/CalendarIcon.js +16 -16
  900. package/es/PRIVATE_ThemedIcons/ChartMarqueeSelectIcon.js +16 -16
  901. package/es/PRIVATE_ThemedIcons/ChartPanIcon.js +16 -16
  902. package/es/PRIVATE_ThemedIcons/ChartZoomIcon.js +16 -16
  903. package/es/PRIVATE_ThemedIcons/CheckIcon.js +16 -16
  904. package/es/PRIVATE_ThemedIcons/CheckboxCrossedIcon.js +16 -16
  905. package/es/PRIVATE_ThemedIcons/CheckboxMixedIcon.js +16 -16
  906. package/es/PRIVATE_ThemedIcons/CheckboxOffIcon.js +16 -16
  907. package/es/PRIVATE_ThemedIcons/CheckboxOnIcon.js +16 -16
  908. package/es/PRIVATE_ThemedIcons/CloseIcon.js +16 -16
  909. package/es/PRIVATE_ThemedIcons/CollapseIcon.js +17 -17
  910. package/es/PRIVATE_ThemedIcons/CollapseUpIcon.js +16 -16
  911. package/es/PRIVATE_ThemedIcons/DecrementIcon.js +16 -16
  912. package/es/PRIVATE_ThemedIcons/DeleteIcon.js +16 -16
  913. package/es/PRIVATE_ThemedIcons/DirectionalCollapseArrowIcon.js +17 -17
  914. package/es/PRIVATE_ThemedIcons/DirectionalExpandArrowIcon.js +17 -17
  915. package/es/PRIVATE_ThemedIcons/DragHandleIcon.js +16 -16
  916. package/es/PRIVATE_ThemedIcons/DropdownArrowIcon.js +16 -16
  917. package/es/PRIVATE_ThemedIcons/ExpandIcon.js +16 -16
  918. package/es/PRIVATE_ThemedIcons/HelpIcon.js +16 -16
  919. package/es/PRIVATE_ThemedIcons/IncrementIcon.js +16 -16
  920. package/es/PRIVATE_ThemedIcons/MenuButtonDropdownIcon.js +16 -16
  921. package/es/PRIVATE_ThemedIcons/MessageConfirmationIcon.js +16 -16
  922. package/es/PRIVATE_ThemedIcons/MessageErrorIcon.js +16 -16
  923. package/es/PRIVATE_ThemedIcons/MessageInfoIcon.js +16 -16
  924. package/es/PRIVATE_ThemedIcons/MessageWarningIcon.js +16 -16
  925. package/es/PRIVATE_ThemedIcons/MinusIcon.js +16 -16
  926. package/es/PRIVATE_ThemedIcons/NavDownIcon.js +16 -16
  927. package/es/PRIVATE_ThemedIcons/None.js +16 -16
  928. package/es/PRIVATE_ThemedIcons/OverviewHorizontalDragHandleIcon.js +16 -16
  929. package/es/PRIVATE_ThemedIcons/PlusIcon.js +16 -16
  930. package/es/PRIVATE_ThemedIcons/RadioOffIcon.js +16 -16
  931. package/es/PRIVATE_ThemedIcons/RadioOnIcon.js +16 -16
  932. package/es/PRIVATE_ThemedIcons/SortAscendingIcon.js +16 -16
  933. package/es/PRIVATE_ThemedIcons/SortDescendingIcon.js +16 -16
  934. package/es/PRIVATE_ThemedIcons/ViewHideIcon.js +16 -16
  935. package/es/PRIVATE_ThemedIcons/ViewIcon.js +16 -16
  936. package/es/PRIVATE_TimeComponent.js +19 -19
  937. package/es/PRIVATE_TruncatingLink.js +20 -17
  938. package/es/PRIVATE_TruncatingLink.js.map +1 -1
  939. package/es/PRIVATE_VisOverview.js +16 -16
  940. package/es/PRIVATE_VisStatusMessage.js +5 -5
  941. package/es/PRIVATE_VisTabularDatatip.js +4 -4
  942. package/es/Popup-22d51095.js +298 -0
  943. package/es/Popup-22d51095.js.map +1 -0
  944. package/es/ProgressButtonLabelLayout-69549cf9.js +3 -3
  945. package/es/ProgressCircle-bce87dad.js +48 -0
  946. package/es/ProgressCircle-bce87dad.js.map +1 -0
  947. package/es/RadioItem-94909632.js +6 -6
  948. package/es/ReadonlyTextFieldInput-106ce959.js +1 -1
  949. package/es/ReferenceLineArea-cc72b070.js +586 -0
  950. package/es/ReferenceLineArea-cc72b070.js.map +1 -0
  951. package/es/RevealToggleIcon-c5d9d731.js +26 -0
  952. package/es/RevealToggleIcon-c5d9d731.js.map +1 -0
  953. package/es/SectionedContent-ac90a3d0.js +65 -0
  954. package/es/SectionedContent-ac90a3d0.js.map +1 -0
  955. package/es/SegmentStyles.styles.css +12 -9
  956. package/es/SegmentStyles.styles2.css +9 -12
  957. package/es/SelectMenuGroupContext-130a850c.js +554 -0
  958. package/es/SelectMenuGroupContext-130a850c.js.map +1 -0
  959. package/es/SelectMobileFieldInput-5ca800d5.js +241 -0
  960. package/es/SelectMobileFieldInput-5ca800d5.js.map +1 -0
  961. package/es/SelectorAll-3d39196b.js +51 -0
  962. package/es/SelectorAll-3d39196b.js.map +1 -0
  963. package/es/Sheet-f9f8a4a4.js +2 -2
  964. package/es/SortControl-1044fcd9.js +3 -3
  965. package/es/StyledCard-77623731.js +1 -1
  966. package/es/StyledDatePickerButton-a7782821.js +32 -0
  967. package/es/StyledDatePickerButton-a7782821.js.map +1 -0
  968. package/es/StyledDatePickerButtonStyles.styles.css +18 -12
  969. package/es/StyledLabelValueLayout-bddfb884.js +18 -0
  970. package/es/StyledLabelValueLayout-bddfb884.js.map +1 -0
  971. package/es/StyledSwitch-dbf29d95.js +2 -2
  972. package/es/StyledTextField-7605d76a.js +5 -5
  973. package/es/Submenu-fa7c2b4f.js +247 -0
  974. package/es/Submenu-fa7c2b4f.js.map +1 -0
  975. package/es/TabBar-fd31ca03.js +69 -0
  976. package/es/TabBar-fd31ca03.js.map +1 -0
  977. package/es/TabBarContextMenu-3bf4dc64.js +99 -0
  978. package/es/TabBarContextMenu-3bf4dc64.js.map +1 -0
  979. package/es/TabBarLayout-9b67d1b6.js +1 -1
  980. package/es/TabBarLinkItem-43854314.js +13 -0
  981. package/es/TabBarLinkItem-43854314.js.map +1 -0
  982. package/es/Table-535987d0.js +4112 -0
  983. package/es/Table-535987d0.js.map +1 -0
  984. package/es/TableColGroup-d74bd4f5.js +1 -1
  985. package/es/TextField-7884fcd7.js +3 -3
  986. package/es/Theme-redwood/theme.css +432 -432
  987. package/es/Theme-stable/theme.css +474 -474
  988. package/es/TimeComponentCanvas2D-cfb0066d.js +6 -6
  989. package/es/ToggleButton-65f5d293.js +28 -0
  990. package/es/ToggleButton-65f5d293.js.map +1 -0
  991. package/es/ToggleButtonLabel-bf4e1599.js +75 -0
  992. package/es/ToggleButtonLabel-bf4e1599.js.map +1 -0
  993. package/es/TrainVariants.styles.css +6 -6
  994. package/es/TrainVariants.styles2.css +6 -6
  995. package/es/TruncatingLink-6aaf40b9.js +93 -0
  996. package/es/TruncatingLink-6aaf40b9.js.map +1 -0
  997. package/es/TruncatingText-1bf00351.js +1 -1
  998. package/es/UNSAFE_AccordionItemMultiple.js +18 -18
  999. package/es/UNSAFE_AccordionItemSingle.js +18 -18
  1000. package/es/UNSAFE_ActionCard.js +2 -2
  1001. package/es/UNSAFE_BarChart.js +46 -46
  1002. package/es/UNSAFE_BareButton.js +2 -2
  1003. package/es/UNSAFE_BaseButton.js +5 -5
  1004. package/es/UNSAFE_Button.js +6 -6
  1005. package/es/UNSAFE_ButtonSet.js +4 -4
  1006. package/es/UNSAFE_ButtonSetButton.js +7 -7
  1007. package/es/UNSAFE_ButtonSetIconButton.js +19 -19
  1008. package/es/UNSAFE_ButtonSetItem.js +22 -22
  1009. package/es/UNSAFE_ButtonSetMultiple.js +4 -4
  1010. package/es/UNSAFE_ButtonSetSingle.js +4 -4
  1011. package/es/UNSAFE_Card.js +3 -3
  1012. package/es/UNSAFE_CardFlexView.js +23 -23
  1013. package/es/UNSAFE_CardGridView.js +23 -23
  1014. package/es/UNSAFE_Center.js +5 -5
  1015. package/es/UNSAFE_Checkbox.js +25 -25
  1016. package/es/UNSAFE_CheckboxItem.js +27 -27
  1017. package/es/UNSAFE_CheckboxRadioField.js +4 -4
  1018. package/es/UNSAFE_CheckboxSet.js +26 -26
  1019. package/es/UNSAFE_Chip.js +2 -2
  1020. package/es/UNSAFE_Collapsible.js +18 -18
  1021. package/es/UNSAFE_ColorPalette.js +19 -19
  1022. package/es/UNSAFE_ColorPicker.js +21 -21
  1023. package/es/UNSAFE_ColorSwatch.js +17 -17
  1024. package/es/UNSAFE_ComboChart.js +46 -46
  1025. package/es/UNSAFE_ComponentMessage.js +20 -20
  1026. package/es/UNSAFE_ContainerDiagram/themes/DiagramStyles.css.js +1 -1
  1027. package/es/UNSAFE_ContainerDiagram.js +38 -38
  1028. package/es/UNSAFE_ConveyorBelt.js +18 -18
  1029. package/es/UNSAFE_DatePicker.js +54 -31
  1030. package/es/UNSAFE_DatePicker.js.map +1 -1
  1031. package/es/UNSAFE_Diagram/themes/DiagramStyles.css.js +1 -1
  1032. package/es/UNSAFE_Diagram.js +38 -38
  1033. package/es/UNSAFE_Dialog.js +22 -22
  1034. package/es/UNSAFE_DragHandle.js +17 -17
  1035. package/es/UNSAFE_DrawerLayout.js +12 -12
  1036. package/es/UNSAFE_DrawerPopup.js +11 -11
  1037. package/es/UNSAFE_Dropdown.js +15 -15
  1038. package/es/UNSAFE_Environment.js +4 -4
  1039. package/es/UNSAFE_ExpandableList.js +25 -25
  1040. package/es/UNSAFE_FilePicker.js +4 -4
  1041. package/es/UNSAFE_FlatTreeView.js +25 -25
  1042. package/es/UNSAFE_Flex.js +4 -4
  1043. package/es/UNSAFE_Floating.js +11 -11
  1044. package/es/UNSAFE_FormLayout.js +2 -2
  1045. package/es/UNSAFE_Gantt.js +23 -23
  1046. package/es/UNSAFE_Grid.js +4 -4
  1047. package/es/UNSAFE_HighlightText.js +4 -4
  1048. package/es/UNSAFE_Icon.js +16 -16
  1049. package/es/UNSAFE_IconButton.js +17 -17
  1050. package/es/UNSAFE_IconMenuButton.js +26 -26
  1051. package/es/UNSAFE_IconProgressButton.js +21 -21
  1052. package/es/UNSAFE_IconToggleButton.js +19 -19
  1053. package/es/UNSAFE_Indexer.js +19 -19
  1054. package/es/UNSAFE_InlineSelectSingle.js +34 -34
  1055. package/es/UNSAFE_InputColor.js +32 -32
  1056. package/es/UNSAFE_InputDateMask/themes/SegmentStyles.css.js +1 -1
  1057. package/es/UNSAFE_InputDateMask.js +27 -27
  1058. package/es/UNSAFE_InputDatePicker.js +64 -42
  1059. package/es/UNSAFE_InputDatePicker.js.map +1 -1
  1060. package/es/UNSAFE_InputPassword.js +29 -29
  1061. package/es/UNSAFE_InputSensitiveText.js +30 -30
  1062. package/es/UNSAFE_InputText.js +28 -28
  1063. package/es/UNSAFE_InputTimeMask/themes/SegmentStyles.css.js +1 -1
  1064. package/es/UNSAFE_InputTimeMask.js +27 -27
  1065. package/es/UNSAFE_Label.js +25 -25
  1066. package/es/UNSAFE_LabelValueLayout.js +4 -4
  1067. package/es/UNSAFE_LabelledLink.js +36 -31
  1068. package/es/UNSAFE_LabelledLink.js.map +1 -1
  1069. package/es/UNSAFE_Layer.js +8 -8
  1070. package/es/UNSAFE_Legend.js +30 -30
  1071. package/es/UNSAFE_LineAreaChart.js +46 -46
  1072. package/es/UNSAFE_Link/themes/LinkStyles.css.js +1 -1
  1073. package/es/UNSAFE_Link.js +3 -3
  1074. package/es/UNSAFE_ListItemLayout.js +4 -4
  1075. package/es/UNSAFE_ListView.js +75 -75
  1076. package/es/UNSAFE_LiveRegion.js +4 -4
  1077. package/es/UNSAFE_Menu.js +29 -29
  1078. package/es/UNSAFE_MenuButton.js +26 -26
  1079. package/es/UNSAFE_MessageBanner.js +20 -20
  1080. package/es/UNSAFE_MessageToast.js +22 -22
  1081. package/es/UNSAFE_MeterBar.js +16 -16
  1082. package/es/UNSAFE_MeterCircle.js +17 -17
  1083. package/es/UNSAFE_Modal.js +8 -8
  1084. package/es/UNSAFE_NavigationList.js +42 -42
  1085. package/es/UNSAFE_NavigationListCommon.js +20 -20
  1086. package/es/UNSAFE_NumberInputText.js +28 -28
  1087. package/es/UNSAFE_OverflowTabBar.js +42 -42
  1088. package/es/UNSAFE_PictoChart.js +27 -27
  1089. package/es/UNSAFE_PieChart.js +28 -28
  1090. package/es/UNSAFE_Popup.js +18 -18
  1091. package/es/UNSAFE_ProgressBar.js +4 -4
  1092. package/es/UNSAFE_ProgressButton.js +21 -21
  1093. package/es/UNSAFE_ProgressButtonLabelLayout.js +10 -10
  1094. package/es/UNSAFE_ProgressCircle.js +4 -4
  1095. package/es/UNSAFE_RadioItem.js +25 -25
  1096. package/es/UNSAFE_RadioSet.js +27 -27
  1097. package/es/UNSAFE_RatingGauge.js +18 -18
  1098. package/es/UNSAFE_ReorderableTabBar.js +42 -42
  1099. package/es/UNSAFE_RichCheckboxSet.js +28 -28
  1100. package/es/UNSAFE_RichRadioSet.js +29 -29
  1101. package/es/UNSAFE_RichSelectionItem.js +30 -30
  1102. package/es/UNSAFE_ScatterChart.js +46 -46
  1103. package/es/UNSAFE_SectionalLegend.js +30 -30
  1104. package/es/UNSAFE_SelectMultiple.js +38 -38
  1105. package/es/UNSAFE_SelectSingle.js +38 -38
  1106. package/es/UNSAFE_SelectionCard.js +3 -3
  1107. package/es/UNSAFE_Selector.js +17 -17
  1108. package/es/UNSAFE_SelectorAll.js +19 -19
  1109. package/es/UNSAFE_Sheet.js +11 -11
  1110. package/es/UNSAFE_SortControl.js +20 -20
  1111. package/es/UNSAFE_SplitMenuButton.js +27 -27
  1112. package/es/UNSAFE_SplitMenuButton.js.map +1 -1
  1113. package/es/UNSAFE_Switch.js +26 -26
  1114. package/es/UNSAFE_TabBar.js +43 -43
  1115. package/es/UNSAFE_TabBarCommon.js +33 -33
  1116. package/es/UNSAFE_TabBarMixed.js +41 -41
  1117. package/es/UNSAFE_TableView.js +38 -38
  1118. package/es/UNSAFE_TagCloud.js +28 -28
  1119. package/es/UNSAFE_TextArea.js +237 -117
  1120. package/es/UNSAFE_TextArea.js.map +1 -1
  1121. package/es/UNSAFE_TextAreaAutosize.js +28 -28
  1122. package/es/UNSAFE_TextField.js +20 -20
  1123. package/es/UNSAFE_ToggleButton.js +7 -7
  1124. package/es/UNSAFE_ToggleButtonLabel.js +1 -1
  1125. package/es/UNSAFE_Toolbar.js +4 -4
  1126. package/es/UNSAFE_Train/themes/redwood/TrainTheme.js +1 -1
  1127. package/es/UNSAFE_Train/themes/redwood/TrainVariants.css.js +1 -1
  1128. package/es/UNSAFE_Train/themes/stable/TrainTheme.js +1 -1
  1129. package/es/UNSAFE_Train/themes/stable/TrainVariants.css.js +1 -1
  1130. package/es/UNSAFE_Train.js +18 -18
  1131. package/es/UNSAFE_TruncatingBadge.js +17 -17
  1132. package/es/UNSAFE_TruncatingText.js +17 -17
  1133. package/es/UNSAFE_UserAssistance.js +26 -26
  1134. package/es/UNSAFE_View.js +7 -7
  1135. package/es/UNSAFE_VirtualizedListView.js +21 -21
  1136. package/es/UNSAFE_VisInvalidDataMessage.js +6 -6
  1137. package/es/UNSAFE_VisNoDataMessage.js +6 -6
  1138. package/es/UNSAFE_VisProgressiveLoader.js +5 -5
  1139. package/es/UNSAFE_WindowOverlay.js +4 -4
  1140. package/es/View-818f2f31.js +167 -0
  1141. package/es/View-818f2f31.js.map +1 -0
  1142. package/es/VisStatusMessage-09c532e3.js +29 -0
  1143. package/es/VisStatusMessage-09c532e3.js.map +1 -0
  1144. package/es/VisTabularDatatip-f45069f1.js +24 -0
  1145. package/es/VisTabularDatatip-f45069f1.js.map +1 -0
  1146. package/es/WindowOverlay-467c2d12.js +110 -0
  1147. package/es/WindowOverlay-467c2d12.js.map +1 -0
  1148. package/es/YearsGridView-27d6fa06.js +187 -0
  1149. package/es/YearsGridView-27d6fa06.js.map +1 -0
  1150. package/es/hoc/PRIVATE_withDirectionIcon.js +4 -4
  1151. package/es/hoc/PRIVATE_withThemeIcon.js +3 -3
  1152. package/es/hoc/UNSAFE_withThemeProps.js +3 -3
  1153. package/es/hooks/PRIVATE_useChartContextMenu.js +26 -26
  1154. package/es/hooks/PRIVATE_useChartDatatip.js +14 -14
  1155. package/es/hooks/PRIVATE_useChartEvents.js +19 -19
  1156. package/es/hooks/PRIVATE_useChartMarquee.js +26 -26
  1157. package/es/hooks/PRIVATE_useCollectionFocusRing.js +17 -17
  1158. package/es/hooks/PRIVATE_useCssVars.js +7 -7
  1159. package/es/hooks/PRIVATE_useCurrentKey.js +4 -4
  1160. package/es/hooks/PRIVATE_useDatatip.js +12 -12
  1161. package/es/hooks/PRIVATE_useDetectHorizontalOverflow.js +16 -16
  1162. package/es/hooks/PRIVATE_useFloating.js +4 -4
  1163. package/es/hooks/PRIVATE_useItemAction.js +17 -17
  1164. package/es/hooks/PRIVATE_useListCommon.js +19 -19
  1165. package/es/hooks/PRIVATE_useMiddleEllipsis.js +4 -0
  1166. package/es/hooks/PRIVATE_useMiddleEllipsis.js.map +1 -0
  1167. package/es/hooks/PRIVATE_useOutsideMousedown.js +9 -9
  1168. package/es/hooks/PRIVATE_useRadioFocusManager.js +4 -4
  1169. package/es/hooks/PRIVATE_useReorderable.js +19 -19
  1170. package/es/hooks/PRIVATE_useRovingTabIndexContainer.js +4 -4
  1171. package/es/hooks/PRIVATE_useSelection.js +4 -4
  1172. package/es/hooks/PRIVATE_useTabBar.js +29 -29
  1173. package/es/hooks/PRIVATE_useTabbableModeSet.js +17 -17
  1174. package/es/hooks/PRIVATE_useTooltipOnTruncation.js +17 -17
  1175. package/es/hooks/PRIVATE_useVisContextMenu.js +25 -25
  1176. package/es/hooks/PRIVATE_useVisDragModeControls.js +25 -25
  1177. package/es/hooks/PRIVATE_useVisEvents.js +4 -4
  1178. package/es/hooks/PRIVATE_useVisMeterEvents.js +14 -14
  1179. package/es/hooks/PRIVATE_useVisSelection.js +15 -15
  1180. package/es/hooks/UNSAFE_useBareButton.js +2 -2
  1181. package/es/hooks/UNSAFE_useColorScheme.js +3 -3
  1182. package/es/hooks/UNSAFE_useCurrentBgColor.js +2 -2
  1183. package/es/hooks/UNSAFE_useDensity.js +3 -3
  1184. package/es/hooks/UNSAFE_useHiddenTestMethod.js +3 -3
  1185. package/es/hooks/UNSAFE_useOutsideClick.js +8 -8
  1186. package/es/hooks/UNSAFE_usePrefixSuffix.js +4 -4
  1187. package/es/hooks/UNSAFE_useScale.js +3 -3
  1188. package/es/hooks/UNSAFE_useTestId.js +3 -3
  1189. package/es/hooks/UNSAFE_useTheme.js +3 -3
  1190. package/es/hooks/UNSAFE_useThemeInterpolations.js +6 -6
  1191. package/es/hooks/UNSAFE_useTooltip.js +17 -17
  1192. package/es/hooks/UNSAFE_useTranslationBundle.js +3 -3
  1193. package/es/hooks/UNSAFE_useUser.js +3 -3
  1194. package/es/popupUtils-7774330e.js +29 -0
  1195. package/es/popupUtils-7774330e.js.map +1 -0
  1196. package/es/tooltipUtils-90fb656f.js +110 -0
  1197. package/es/tooltipUtils-90fb656f.js.map +1 -0
  1198. package/es/useBareButton-ff4bd21e.js +1 -1
  1199. package/es/useCellNavigation-0565b6dd.js +1 -1
  1200. package/es/useChartContextMenu-933091d8.js +123 -0
  1201. package/es/useChartContextMenu-933091d8.js.map +1 -0
  1202. package/es/useChartDatatip-cba78e0f.js +336 -0
  1203. package/es/useChartDatatip-cba78e0f.js.map +1 -0
  1204. package/es/useChartMarquee-914929b6.js +304 -0
  1205. package/es/useChartMarquee-914929b6.js.map +1 -0
  1206. package/es/useColorScheme-67245285.js +19 -0
  1207. package/es/useColorScheme-67245285.js.map +1 -0
  1208. package/es/useContextMenu-8a1230a3.js +116 -0
  1209. package/es/useContextMenu-8a1230a3.js.map +1 -0
  1210. package/es/useCssVars-048a52d8.js +58 -0
  1211. package/es/useCssVars-048a52d8.js.map +1 -0
  1212. package/es/useCurrentKey-38e5f097.js +83 -0
  1213. package/es/useCurrentKey-38e5f097.js.map +1 -0
  1214. package/es/useDatatip-ef5c47a7.js +94 -0
  1215. package/es/useDatatip-ef5c47a7.js.map +1 -0
  1216. package/es/useDensity-969273f3.js +19 -0
  1217. package/es/useDensity-969273f3.js.map +1 -0
  1218. package/es/useDisplayValue-29f03329.js +78 -0
  1219. package/es/useDisplayValue-29f03329.js.map +1 -0
  1220. package/es/useExpandCollapse-51f9bb4b.js +70 -0
  1221. package/es/useExpandCollapse-51f9bb4b.js.map +1 -0
  1222. package/es/useFloating-c74a7f54.js +1916 -0
  1223. package/es/useFloating-c74a7f54.js.map +1 -0
  1224. package/es/useHiddenTestMethod-ec7b3989.js +28 -0
  1225. package/es/useHiddenTestMethod-ec7b3989.js.map +1 -0
  1226. package/es/useKeyboardEvents-a1495728.js +85 -0
  1227. package/es/useKeyboardEvents-a1495728.js.map +1 -0
  1228. package/es/useLegendContextMenu-6ea00771.js +279 -0
  1229. package/es/useLegendContextMenu-6ea00771.js.map +1 -0
  1230. package/es/useMeterDatatip-f61ca3e0.js +73 -0
  1231. package/es/useMeterDatatip-f61ca3e0.js.map +1 -0
  1232. package/es/useMiddleEllipsis-b073ca6b.js +228 -0
  1233. package/es/useMiddleEllipsis-b073ca6b.js.map +1 -0
  1234. package/es/useNavigation-b257c33a.js +1 -1
  1235. package/es/useOutsideClick-01f3d3e1.js +115 -0
  1236. package/es/useOutsideClick-01f3d3e1.js.map +1 -0
  1237. package/es/useOutsideMousedown-e0866d58.js +48 -0
  1238. package/es/useOutsideMousedown-e0866d58.js.map +1 -0
  1239. package/es/usePopupAnimation-7c5db425.js +85 -0
  1240. package/es/usePopupAnimation-7c5db425.js.map +1 -0
  1241. package/es/usePrefixSuffix-95fc00fd.js +70 -0
  1242. package/es/usePrefixSuffix-95fc00fd.js.map +1 -0
  1243. package/es/useRadioFocusManager-d9eecfb4.js +108 -0
  1244. package/es/useRadioFocusManager-d9eecfb4.js.map +1 -0
  1245. package/es/useReorderableItem-06bd7a7b.js +296 -0
  1246. package/es/useReorderableItem-06bd7a7b.js.map +1 -0
  1247. package/es/useRovingTabIndexContainer-c0356f5d.js +106 -0
  1248. package/es/useRovingTabIndexContainer-c0356f5d.js.map +1 -0
  1249. package/es/useScale-93490e54.js +19 -0
  1250. package/es/useScale-93490e54.js.map +1 -0
  1251. package/es/useSelectCommon-c70bb10f.js +489 -0
  1252. package/es/useSelectCommon-c70bb10f.js.map +1 -0
  1253. package/es/useSelectDrill-2f855daa.js +111 -0
  1254. package/es/useSelectDrill-2f855daa.js.map +1 -0
  1255. package/es/useSelection-10ed8060.js +186 -0
  1256. package/es/useSelection-10ed8060.js.map +1 -0
  1257. package/es/useSelection-d6fefa3d.js +258 -0
  1258. package/es/useSelection-d6fefa3d.js.map +1 -0
  1259. package/es/useTabBar-27e8c4ea.js +305 -0
  1260. package/es/useTabBar-27e8c4ea.js.map +1 -0
  1261. package/es/useTestId-ab1bede6.js +21 -0
  1262. package/es/useTestId-ab1bede6.js.map +1 -0
  1263. package/es/useTextAreaAltEnter-ac460f4c.js +61 -0
  1264. package/es/useTextAreaAltEnter-ac460f4c.js.map +1 -0
  1265. package/es/useTheme-c2cfbc29.js +19 -0
  1266. package/es/useTheme-c2cfbc29.js.map +1 -0
  1267. package/es/useThemeInterpolations-5f358139.js +68 -0
  1268. package/es/useThemeInterpolations-5f358139.js.map +1 -0
  1269. package/es/useTooltip-ab739df0.js +49 -0
  1270. package/es/useTooltip-ab739df0.js.map +1 -0
  1271. package/es/useTooltipControlled-b7f30aee.js +373 -0
  1272. package/es/useTooltipControlled-b7f30aee.js.map +1 -0
  1273. package/es/useTooltipOnTruncation-31afc3f2.js +27 -0
  1274. package/es/useTooltipOnTruncation-31afc3f2.js.map +1 -0
  1275. package/es/useTranslationBundle-bc6e0896.js +29 -0
  1276. package/es/useTranslationBundle-bc6e0896.js.map +1 -0
  1277. package/es/useUser-e543b73c.js +19 -0
  1278. package/es/useUser-e543b73c.js.map +1 -0
  1279. package/es/useVisDragModeControls-6865056f.js +87 -0
  1280. package/es/useVisDragModeControls-6865056f.js.map +1 -0
  1281. package/es/useVisEvents-0edc925f.js +153 -0
  1282. package/es/useVisEvents-0edc925f.js.map +1 -0
  1283. package/es/utils/PRIVATE_collectionUtils.js +17 -17
  1284. package/es/utils/PRIVATE_tabBarUtils.js +17 -17
  1285. package/es/utils/PRIVATE_tooltipUtils.js +14 -14
  1286. package/es/utils/PRIVATE_visTestUtils.js +4 -4
  1287. package/es/utils/UNSAFE_popupUtils.js +8 -8
  1288. package/es/withDirectionIcon-b725a6d7.js +14 -0
  1289. package/es/withDirectionIcon-b725a6d7.js.map +1 -0
  1290. package/es/withThemeProps-dbd4fedf.js +2 -2
  1291. package/package.json +2 -2
  1292. package/types/UNSAFE_Dropdown/Dropdown.d.ts +5 -1
  1293. package/types/UNSAFE_LabelledLink/LabelledLink.d.ts +5 -1
  1294. package/types/UNSAFE_Link/themes/LinkStyles.css.d.ts +0 -1
  1295. package/types/UNSAFE_Link/themes/redwood/LinkVariants.css.d.ts +0 -1
  1296. package/types/UNSAFE_Link/themes/stable/LinkVariants.css.d.ts +0 -1
  1297. package/types/UNSAFE_Menu/DropdownMenu.d.ts +1 -0
  1298. package/amd/BarChart-f429b382.js +0 -2
  1299. package/amd/BarChart-f429b382.js.map +0 -1
  1300. package/amd/BaseCardView-b8119561.js +0 -2
  1301. package/amd/BaseCardView-b8119561.js.map +0 -1
  1302. package/amd/BaseDiagram-00ea8628.js +0 -2
  1303. package/amd/BaseDiagram-00ea8628.js.map +0 -1
  1304. package/amd/ButtonSetButton-fa0256aa.js +0 -2
  1305. package/amd/ButtonSetButton-fa0256aa.js.map +0 -1
  1306. package/amd/ButtonSetIconButton-9010f20c.js +0 -2
  1307. package/amd/ButtonSetIconButton-9010f20c.js.map +0 -1
  1308. package/amd/ButtonSetItem-4b29107a.js +0 -2
  1309. package/amd/ButtonSetItem-4b29107a.js.map +0 -1
  1310. package/amd/CardFlexView-aa2f3de8.js +0 -2
  1311. package/amd/CardFlexView-aa2f3de8.js.map +0 -1
  1312. package/amd/CardGridView-85f90c75.js +0 -2
  1313. package/amd/CardGridView-85f90c75.js.map +0 -1
  1314. package/amd/Chart-57965de4.js +0 -2
  1315. package/amd/Chart-57965de4.js.map +0 -1
  1316. package/amd/ComboChart-c42ed049.js +0 -2
  1317. package/amd/ComboChart-c42ed049.js.map +0 -1
  1318. package/amd/ContainerDiagram-678f9746.js +0 -2
  1319. package/amd/ContainerDiagram-678f9746.js.map +0 -1
  1320. package/amd/DatePicker-bf521b1c.js +0 -2
  1321. package/amd/DatePicker-bf521b1c.js.map +0 -1
  1322. package/amd/DatePickerHeader-82f4f285.js +0 -2
  1323. package/amd/DatePickerHeader-82f4f285.js.map +0 -1
  1324. package/amd/Diagram-492f8b21.js +0 -2
  1325. package/amd/Diagram-492f8b21.js.map +0 -1
  1326. package/amd/Dropdown-7eca9554.js +0 -2
  1327. package/amd/Dropdown-7eca9554.js.map +0 -1
  1328. package/amd/IconMenuButton-82b8431d.js +0 -2
  1329. package/amd/IconMenuButton-82b8431d.js.map +0 -1
  1330. package/amd/IconSwitchButton-c44e0edf.js +0 -2
  1331. package/amd/IconSwitchButton-c44e0edf.js.map +0 -1
  1332. package/amd/IconToggleButton-0ab34b44.js +0 -2
  1333. package/amd/IconToggleButton-0ab34b44.js.map +0 -1
  1334. package/amd/InlineSelectSingle-87bc8a45.js +0 -2
  1335. package/amd/InlineSelectSingle-87bc8a45.js.map +0 -1
  1336. package/amd/InputColor-58e3fce3.js +0 -2
  1337. package/amd/InputColor-58e3fce3.js.map +0 -1
  1338. package/amd/InputDatePicker-7227a858.js +0 -2
  1339. package/amd/InputDatePicker-7227a858.js.map +0 -1
  1340. package/amd/InputPassword-450915c8.js +0 -2
  1341. package/amd/InputPassword-450915c8.js.map +0 -1
  1342. package/amd/InputSensitiveText-d94d24f0.js +0 -2
  1343. package/amd/InputSensitiveText-d94d24f0.js.map +0 -1
  1344. package/amd/Legend-47a1bf23.js +0 -2
  1345. package/amd/Legend-47a1bf23.js.map +0 -1
  1346. package/amd/LineAreaChart-48efb7f7.js +0 -2
  1347. package/amd/LineAreaChart-48efb7f7.js.map +0 -1
  1348. package/amd/Link-a8fad252.js +0 -2
  1349. package/amd/Link-a8fad252.js.map +0 -1
  1350. package/amd/ListView-2678b2af.js +0 -2
  1351. package/amd/ListView-2678b2af.js.map +0 -1
  1352. package/amd/Menu-1b8fefc5.js +0 -2
  1353. package/amd/Menu-1b8fefc5.js.map +0 -1
  1354. package/amd/MenuButton-2fe1ef2c.js +0 -2
  1355. package/amd/MenuButton-2fe1ef2c.js.map +0 -1
  1356. package/amd/MenuItem-85e4ffdc.js +0 -2
  1357. package/amd/MenuItem-85e4ffdc.js.map +0 -1
  1358. package/amd/MonthView-96fafba4.js +0 -2
  1359. package/amd/MonthView-96fafba4.js.map +0 -1
  1360. package/amd/NavigationList-a6bb123d.js +0 -2
  1361. package/amd/NavigationList-a6bb123d.js.map +0 -1
  1362. package/amd/NavigationListItem-10bf6656.js +0 -2
  1363. package/amd/NavigationListItem-10bf6656.js.map +0 -1
  1364. package/amd/NavigationListLinkItem-df1826e6.js +0 -2
  1365. package/amd/NavigationListLinkItem-df1826e6.js.map +0 -1
  1366. package/amd/OverflowTabBar-f8bf9356.js +0 -2
  1367. package/amd/OverflowTabBar-f8bf9356.js.map +0 -1
  1368. package/amd/OverflowTabBarItem-0aa39512.js +0 -2
  1369. package/amd/OverflowTabBarItem-0aa39512.js.map +0 -1
  1370. package/amd/PictoChart-ab426a71.js +0 -2
  1371. package/amd/PictoChart-ab426a71.js.map +0 -1
  1372. package/amd/PieChart-57ffe4c0.js +0 -2
  1373. package/amd/PieChart-57ffe4c0.js.map +0 -1
  1374. package/amd/RemovableNavigationListItem-60593d4c.js +0 -2
  1375. package/amd/RemovableNavigationListItem-60593d4c.js.map +0 -1
  1376. package/amd/ReorderableTabBar-19a503c7.js +0 -2
  1377. package/amd/ReorderableTabBar-19a503c7.js.map +0 -1
  1378. package/amd/RevealToggleIcon-093f60c4.js +0 -2
  1379. package/amd/RevealToggleIcon-093f60c4.js.map +0 -1
  1380. package/amd/ScatterChart-6427e7ec.js +0 -2
  1381. package/amd/ScatterChart-6427e7ec.js.map +0 -1
  1382. package/amd/SectionalLegend-bd980f3f.js +0 -2
  1383. package/amd/SectionalLegend-bd980f3f.js.map +0 -1
  1384. package/amd/SectionedContent-74559d9d.js +0 -2
  1385. package/amd/SectionedContent-74559d9d.js.map +0 -1
  1386. package/amd/SelectMenuItem-affab9f3.js +0 -2
  1387. package/amd/SelectMenuItem-affab9f3.js.map +0 -1
  1388. package/amd/SelectMobileFieldInput-4795a794.js +0 -2
  1389. package/amd/SelectMobileFieldInput-4795a794.js.map +0 -1
  1390. package/amd/SelectMultiple-e216b16c.js +0 -2
  1391. package/amd/SelectMultiple-e216b16c.js.map +0 -1
  1392. package/amd/SelectSingle-d53cf202.js +0 -2
  1393. package/amd/SelectSingle-d53cf202.js.map +0 -1
  1394. package/amd/SplitMenuButton-76adec12.js +0 -2
  1395. package/amd/SplitMenuButton-76adec12.js.map +0 -1
  1396. package/amd/StyledDatePickerButton-bceb62e1.js +0 -2
  1397. package/amd/StyledDatePickerButton-bceb62e1.js.map +0 -1
  1398. package/amd/Submenu-52ec8bfb.js +0 -2
  1399. package/amd/Submenu-52ec8bfb.js.map +0 -1
  1400. package/amd/TabBar-92bac52f.js +0 -2
  1401. package/amd/TabBar-92bac52f.js.map +0 -1
  1402. package/amd/TabBarContextMenu-6a167e27.js +0 -2
  1403. package/amd/TabBarContextMenu-6a167e27.js.map +0 -1
  1404. package/amd/TabBarMixed-5b5a5047.js +0 -2
  1405. package/amd/TabBarMixed-5b5a5047.js.map +0 -1
  1406. package/amd/Table-74566993.js +0 -2
  1407. package/amd/Table-74566993.js.map +0 -1
  1408. package/amd/TableView-3d82855c.js +0 -2
  1409. package/amd/TableView-3d82855c.js.map +0 -1
  1410. package/amd/TagCloud-c10a166e.js +0 -2
  1411. package/amd/TagCloud-c10a166e.js.map +0 -1
  1412. package/amd/ToggleButton-b77486fe.js +0 -2
  1413. package/amd/ToggleButton-b77486fe.js.map +0 -1
  1414. package/amd/ToggleButtonLabel-87364773.js +0 -2
  1415. package/amd/ToggleButtonLabel-87364773.js.map +0 -1
  1416. package/amd/TruncatingLink-591e7ff1.js +0 -2
  1417. package/amd/TruncatingLink-591e7ff1.js.map +0 -1
  1418. package/amd/YearsGridView-561c3074.js +0 -2
  1419. package/amd/YearsGridView-561c3074.js.map +0 -1
  1420. package/amd/listViewSelectionTests-7d18f09e.js +0 -2
  1421. package/amd/listViewSelectionTests-7d18f09e.js.map +0 -1
  1422. package/amd/useChartContextMenu-abadeabc.js +0 -2
  1423. package/amd/useChartContextMenu-abadeabc.js.map +0 -1
  1424. package/amd/useChartMarquee-3865426f.js +0 -2
  1425. package/amd/useChartMarquee-3865426f.js.map +0 -1
  1426. package/amd/useContextMenu-67972d45.js +0 -2
  1427. package/amd/useContextMenu-67972d45.js.map +0 -1
  1428. package/amd/useDisplayValue-9b671893.js +0 -2
  1429. package/amd/useDisplayValue-9b671893.js.map +0 -1
  1430. package/amd/useLegendContextMenu-55fedade.js +0 -2
  1431. package/amd/useLegendContextMenu-55fedade.js.map +0 -1
  1432. package/amd/useNavigationListItem-582f5564.js +0 -2
  1433. package/amd/useNavigationListItem-582f5564.js.map +0 -1
  1434. package/amd/useSelectCommon-f33709d2.js +0 -2
  1435. package/amd/useSelectCommon-f33709d2.js.map +0 -1
  1436. package/amd/useTabBar-b05edef0.js +0 -2
  1437. package/amd/useTabBar-b05edef0.js.map +0 -1
  1438. package/amd/useVisDragModeControls-5f059d09.js +0 -2
  1439. package/amd/useVisDragModeControls-5f059d09.js.map +0 -1
  1440. package/cjs/BaseButton-d8f96bfa.js +0 -86
  1441. package/cjs/BaseButton-d8f96bfa.js.map +0 -1
  1442. package/cjs/BaseDiagram-ce4f1a20.js +0 -2956
  1443. package/cjs/BaseDiagram-ce4f1a20.js.map +0 -1
  1444. package/cjs/Button-020e0381.js +0 -24
  1445. package/cjs/Button-020e0381.js.map +0 -1
  1446. package/cjs/ButtonSetButton-569e0efb.js +0 -35
  1447. package/cjs/ButtonSetButton-569e0efb.js.map +0 -1
  1448. package/cjs/ButtonSetIconButton-3778ac7b.js +0 -40
  1449. package/cjs/ButtonSetIconButton-3778ac7b.js.map +0 -1
  1450. package/cjs/ButtonSetItem-4322c957.js +0 -67
  1451. package/cjs/ButtonSetItem-4322c957.js.map +0 -1
  1452. package/cjs/Center-9a0ee4f3.js +0 -18
  1453. package/cjs/Center-9a0ee4f3.js.map +0 -1
  1454. package/cjs/Chart-966da017.js +0 -754
  1455. package/cjs/Chart-966da017.js.map +0 -1
  1456. package/cjs/CheckboxSet-6865f4fd.js +0 -55
  1457. package/cjs/CheckboxSet-6865f4fd.js.map +0 -1
  1458. package/cjs/ColorPalette-b14114d8.js +0 -83
  1459. package/cjs/ColorPalette-b14114d8.js.map +0 -1
  1460. package/cjs/ColorPicker-8f0b6000.js +0 -25
  1461. package/cjs/ColorPicker-8f0b6000.js.map +0 -1
  1462. package/cjs/CompactLabelAssistance-e910bb56.js +0 -95
  1463. package/cjs/CompactLabelAssistance-e910bb56.js.map +0 -1
  1464. package/cjs/DatePicker-b60f8a7e.js +0 -601
  1465. package/cjs/DatePicker-b60f8a7e.js.map +0 -1
  1466. package/cjs/DatePickerHeader-1010204c.js +0 -48
  1467. package/cjs/DatePickerHeader-1010204c.js.map +0 -1
  1468. package/cjs/Dialog-8b65180c.js +0 -389
  1469. package/cjs/Dialog-8b65180c.js.map +0 -1
  1470. package/cjs/Dropdown-1ba432a8.js +0 -333
  1471. package/cjs/Dropdown-1ba432a8.js.map +0 -1
  1472. package/cjs/EmbeddedIconButton-cc159a01.js +0 -13
  1473. package/cjs/EmbeddedIconButton-cc159a01.js.map +0 -1
  1474. package/cjs/EnvironmentProvider-5f2435e6.js +0 -61
  1475. package/cjs/EnvironmentProvider-5f2435e6.js.map +0 -1
  1476. package/cjs/Flex-3a257bc3.js +0 -32
  1477. package/cjs/Flex-3a257bc3.js.map +0 -1
  1478. package/cjs/Floating-79cbe5ad.js +0 -467
  1479. package/cjs/Floating-79cbe5ad.js.map +0 -1
  1480. package/cjs/Grid-cef20569.js +0 -29
  1481. package/cjs/Grid-cef20569.js.map +0 -1
  1482. package/cjs/HighlightText-f4535f3d.js +0 -33
  1483. package/cjs/HighlightText-f4535f3d.js.map +0 -1
  1484. package/cjs/IconSwitchButton-9b0df2d6.js +0 -44
  1485. package/cjs/IconSwitchButton-9b0df2d6.js.map +0 -1
  1486. package/cjs/IconToggleButton-d2147159.js +0 -43
  1487. package/cjs/IconToggleButton-d2147159.js.map +0 -1
  1488. package/cjs/IconUserAssistance-89913ad1.js +0 -76
  1489. package/cjs/IconUserAssistance-89913ad1.js.map +0 -1
  1490. package/cjs/Layer-b60deb1b.js +0 -94
  1491. package/cjs/Layer-b60deb1b.js.map +0 -1
  1492. package/cjs/LayerHost-3cd73603.js +0 -46
  1493. package/cjs/LayerHost-3cd73603.js.map +0 -1
  1494. package/cjs/LayerManager-c535d963.js +0 -36
  1495. package/cjs/LayerManager-c535d963.js.map +0 -1
  1496. package/cjs/Link-cc34e4c1.js +0 -35
  1497. package/cjs/Link-cc34e4c1.js.map +0 -1
  1498. package/cjs/LiveRegion-62ce9ac7.js +0 -41
  1499. package/cjs/LiveRegion-62ce9ac7.js.map +0 -1
  1500. package/cjs/MaxLengthLiveRegion-0a6ba765.js +0 -28
  1501. package/cjs/MaxLengthLiveRegion-0a6ba765.js.map +0 -1
  1502. package/cjs/MessageLayer-8e6e3d98.js +0 -61
  1503. package/cjs/MessageLayer-8e6e3d98.js.map +0 -1
  1504. package/cjs/MonthView-a2661a58.js +0 -210
  1505. package/cjs/MonthView-a2661a58.js.map +0 -1
  1506. package/cjs/NavigationList-d0d74565.js +0 -307
  1507. package/cjs/NavigationList-d0d74565.js.map +0 -1
  1508. package/cjs/NavigationListItem-b0b03089.js +0 -12
  1509. package/cjs/NavigationListItem-b0b03089.js.map +0 -1
  1510. package/cjs/NavigationListLinkItem-317a5200.js +0 -146
  1511. package/cjs/NavigationListLinkItem-317a5200.js.map +0 -1
  1512. package/cjs/OverflowTabBarItem-19ad4971.js +0 -264
  1513. package/cjs/OverflowTabBarItem-19ad4971.js.map +0 -1
  1514. package/cjs/Popup-de16d915.js +0 -300
  1515. package/cjs/Popup-de16d915.js.map +0 -1
  1516. package/cjs/ProgressCircle-cac3c03a.js +0 -50
  1517. package/cjs/ProgressCircle-cac3c03a.js.map +0 -1
  1518. package/cjs/ReferenceLineArea-7bc34276.js +0 -592
  1519. package/cjs/ReferenceLineArea-7bc34276.js.map +0 -1
  1520. package/cjs/RevealToggleIcon-a6a4f8db.js +0 -28
  1521. package/cjs/RevealToggleIcon-a6a4f8db.js.map +0 -1
  1522. package/cjs/SectionedContent-5eff5dce.js +0 -68
  1523. package/cjs/SectionedContent-5eff5dce.js.map +0 -1
  1524. package/cjs/SelectMenuGroupContext-a349d259.js +0 -551
  1525. package/cjs/SelectMenuGroupContext-a349d259.js.map +0 -1
  1526. package/cjs/SelectMobileFieldInput-cbf57541.js +0 -248
  1527. package/cjs/SelectMobileFieldInput-cbf57541.js.map +0 -1
  1528. package/cjs/SelectorAll-9118eb07.js +0 -53
  1529. package/cjs/SelectorAll-9118eb07.js.map +0 -1
  1530. package/cjs/StyledDatePickerButton-becd2a7d.js +0 -33
  1531. package/cjs/StyledDatePickerButton-becd2a7d.js.map +0 -1
  1532. package/cjs/StyledLabelValueLayout-48da61b9.js +0 -22
  1533. package/cjs/StyledLabelValueLayout-48da61b9.js.map +0 -1
  1534. package/cjs/Submenu-8e92469f.js +0 -251
  1535. package/cjs/Submenu-8e92469f.js.map +0 -1
  1536. package/cjs/TabBar-d84e222e.js +0 -79
  1537. package/cjs/TabBar-d84e222e.js.map +0 -1
  1538. package/cjs/TabBarContextMenu-d9bf65c2.js +0 -102
  1539. package/cjs/TabBarContextMenu-d9bf65c2.js.map +0 -1
  1540. package/cjs/TabBarLinkItem-e924f83b.js +0 -15
  1541. package/cjs/TabBarLinkItem-e924f83b.js.map +0 -1
  1542. package/cjs/Table-a102e1ee.js +0 -4114
  1543. package/cjs/Table-a102e1ee.js.map +0 -1
  1544. package/cjs/ToggleButton-5ebfe20e.js +0 -30
  1545. package/cjs/ToggleButton-5ebfe20e.js.map +0 -1
  1546. package/cjs/ToggleButtonLabel-c8f36317.js +0 -73
  1547. package/cjs/ToggleButtonLabel-c8f36317.js.map +0 -1
  1548. package/cjs/TruncatingLink-867da10e.js +0 -58
  1549. package/cjs/TruncatingLink-867da10e.js.map +0 -1
  1550. package/cjs/View-ed116d78.js +0 -170
  1551. package/cjs/View-ed116d78.js.map +0 -1
  1552. package/cjs/VisStatusMessage-07e63c6e.js +0 -31
  1553. package/cjs/VisStatusMessage-07e63c6e.js.map +0 -1
  1554. package/cjs/VisTabularDatatip-abfef042.js +0 -26
  1555. package/cjs/VisTabularDatatip-abfef042.js.map +0 -1
  1556. package/cjs/WindowOverlay-85d999fa.js +0 -112
  1557. package/cjs/WindowOverlay-85d999fa.js.map +0 -1
  1558. package/cjs/YearsGridView-d0d4e8e1.js +0 -190
  1559. package/cjs/YearsGridView-d0d4e8e1.js.map +0 -1
  1560. package/cjs/popupUtils-1d123cbe.js +0 -31
  1561. package/cjs/popupUtils-1d123cbe.js.map +0 -1
  1562. package/cjs/tooltipUtils-2bc15136.js +0 -115
  1563. package/cjs/tooltipUtils-2bc15136.js.map +0 -1
  1564. package/cjs/useChartContextMenu-af989b4f.js +0 -125
  1565. package/cjs/useChartContextMenu-af989b4f.js.map +0 -1
  1566. package/cjs/useChartDatatip-1bceba5d.js +0 -341
  1567. package/cjs/useChartDatatip-1bceba5d.js.map +0 -1
  1568. package/cjs/useChartMarquee-ede5cae4.js +0 -306
  1569. package/cjs/useChartMarquee-ede5cae4.js.map +0 -1
  1570. package/cjs/useColorScheme-f8b1447d.js +0 -21
  1571. package/cjs/useColorScheme-f8b1447d.js.map +0 -1
  1572. package/cjs/useContextMenu-2500df06.js +0 -119
  1573. package/cjs/useContextMenu-2500df06.js.map +0 -1
  1574. package/cjs/useCssVars-8e83d496.js +0 -60
  1575. package/cjs/useCssVars-8e83d496.js.map +0 -1
  1576. package/cjs/useCurrentKey-1b9e3382.js +0 -85
  1577. package/cjs/useCurrentKey-1b9e3382.js.map +0 -1
  1578. package/cjs/useDatatip-b7b4f13f.js +0 -96
  1579. package/cjs/useDatatip-b7b4f13f.js.map +0 -1
  1580. package/cjs/useDensity-0b9fd9ca.js +0 -21
  1581. package/cjs/useDensity-0b9fd9ca.js.map +0 -1
  1582. package/cjs/useDisplayValue-4ace417c.js +0 -82
  1583. package/cjs/useDisplayValue-4ace417c.js.map +0 -1
  1584. package/cjs/useExpandCollapse-ef990199.js +0 -72
  1585. package/cjs/useExpandCollapse-ef990199.js.map +0 -1
  1586. package/cjs/useFloating-c753a7f9.js +0 -1926
  1587. package/cjs/useFloating-c753a7f9.js.map +0 -1
  1588. package/cjs/useHiddenTestMethod-eae1d48b.js +0 -30
  1589. package/cjs/useHiddenTestMethod-eae1d48b.js.map +0 -1
  1590. package/cjs/useKeyboardEvents-0ab70381.js +0 -88
  1591. package/cjs/useKeyboardEvents-0ab70381.js.map +0 -1
  1592. package/cjs/useLegendContextMenu-2cf579d7.js +0 -285
  1593. package/cjs/useLegendContextMenu-2cf579d7.js.map +0 -1
  1594. package/cjs/useMeterDatatip-92ca91d9.js +0 -76
  1595. package/cjs/useMeterDatatip-92ca91d9.js.map +0 -1
  1596. package/cjs/useNavigationListItem-b97e76d5.js +0 -104
  1597. package/cjs/useNavigationListItem-b97e76d5.js.map +0 -1
  1598. package/cjs/useOutsideClick-dbf3d604.js +0 -117
  1599. package/cjs/useOutsideClick-dbf3d604.js.map +0 -1
  1600. package/cjs/useOutsideMousedown-70f36cca.js +0 -50
  1601. package/cjs/useOutsideMousedown-70f36cca.js.map +0 -1
  1602. package/cjs/usePopupAnimation-f3b34413.js +0 -87
  1603. package/cjs/usePopupAnimation-f3b34413.js.map +0 -1
  1604. package/cjs/usePrefixSuffix-23d1cc33.js +0 -72
  1605. package/cjs/usePrefixSuffix-23d1cc33.js.map +0 -1
  1606. package/cjs/useRadioFocusManager-a11750e7.js +0 -110
  1607. package/cjs/useRadioFocusManager-a11750e7.js.map +0 -1
  1608. package/cjs/useReorderableItem-64be8d2b.js +0 -299
  1609. package/cjs/useReorderableItem-64be8d2b.js.map +0 -1
  1610. package/cjs/useRovingTabIndexContainer-0ce4681d.js +0 -108
  1611. package/cjs/useRovingTabIndexContainer-0ce4681d.js.map +0 -1
  1612. package/cjs/useScale-db16c2b8.js +0 -21
  1613. package/cjs/useScale-db16c2b8.js.map +0 -1
  1614. package/cjs/useSelectCommon-27afecfa.js +0 -507
  1615. package/cjs/useSelectCommon-27afecfa.js.map +0 -1
  1616. package/cjs/useSelectDrill-0b4b47ec.js +0 -114
  1617. package/cjs/useSelectDrill-0b4b47ec.js.map +0 -1
  1618. package/cjs/useSelection-37939f09.js +0 -260
  1619. package/cjs/useSelection-37939f09.js.map +0 -1
  1620. package/cjs/useSelection-da64e28e.js +0 -188
  1621. package/cjs/useSelection-da64e28e.js.map +0 -1
  1622. package/cjs/useTabBar-35b73d10.js +0 -309
  1623. package/cjs/useTabBar-35b73d10.js.map +0 -1
  1624. package/cjs/useTestId-4f53d561.js +0 -23
  1625. package/cjs/useTestId-4f53d561.js.map +0 -1
  1626. package/cjs/useTextAreaAltEnter-11424062.js +0 -64
  1627. package/cjs/useTextAreaAltEnter-11424062.js.map +0 -1
  1628. package/cjs/useTheme-2a034a21.js +0 -21
  1629. package/cjs/useTheme-2a034a21.js.map +0 -1
  1630. package/cjs/useThemeInterpolations-a37b37d9.js +0 -71
  1631. package/cjs/useThemeInterpolations-a37b37d9.js.map +0 -1
  1632. package/cjs/useTooltip-34accecc.js +0 -51
  1633. package/cjs/useTooltip-34accecc.js.map +0 -1
  1634. package/cjs/useTooltipControlled-0a95856c.js +0 -376
  1635. package/cjs/useTooltipControlled-0a95856c.js.map +0 -1
  1636. package/cjs/useTooltipOnTruncation-8867b10e.js +0 -29
  1637. package/cjs/useTooltipOnTruncation-8867b10e.js.map +0 -1
  1638. package/cjs/useTranslationBundle-12dd087d.js +0 -31
  1639. package/cjs/useTranslationBundle-12dd087d.js.map +0 -1
  1640. package/cjs/useUser-1295b5cb.js +0 -21
  1641. package/cjs/useUser-1295b5cb.js.map +0 -1
  1642. package/cjs/useVisDragModeControls-2443a4e0.js +0 -89
  1643. package/cjs/useVisDragModeControls-2443a4e0.js.map +0 -1
  1644. package/cjs/useVisEvents-334c2c8d.js +0 -155
  1645. package/cjs/useVisEvents-334c2c8d.js.map +0 -1
  1646. package/cjs/withDirectionIcon-4940a248.js +0 -16
  1647. package/cjs/withDirectionIcon-4940a248.js.map +0 -1
  1648. package/es/BaseButton-41068c85.js +0 -84
  1649. package/es/BaseButton-41068c85.js.map +0 -1
  1650. package/es/BaseCardView-b3d8bae0.js +0 -634
  1651. package/es/BaseCardView-b3d8bae0.js.map +0 -1
  1652. package/es/BaseDiagram-b5b22e53.js +0 -2954
  1653. package/es/BaseDiagram-b5b22e53.js.map +0 -1
  1654. package/es/Button-956f51c7.js +0 -22
  1655. package/es/Button-956f51c7.js.map +0 -1
  1656. package/es/ButtonSetButton-8685c752.js +0 -33
  1657. package/es/ButtonSetButton-8685c752.js.map +0 -1
  1658. package/es/ButtonSetIconButton-c8ed85f9.js +0 -38
  1659. package/es/ButtonSetIconButton-c8ed85f9.js.map +0 -1
  1660. package/es/ButtonSetItem-280755f3.js +0 -65
  1661. package/es/ButtonSetItem-280755f3.js.map +0 -1
  1662. package/es/Center-71a03e65.js +0 -16
  1663. package/es/Center-71a03e65.js.map +0 -1
  1664. package/es/Chart-8c63da28.js +0 -752
  1665. package/es/Chart-8c63da28.js.map +0 -1
  1666. package/es/ColorPicker-ae648c4c.js +0 -23
  1667. package/es/ColorPicker-ae648c4c.js.map +0 -1
  1668. package/es/CompactLabelAssistance-e2fcfcab.js +0 -92
  1669. package/es/CompactLabelAssistance-e2fcfcab.js.map +0 -1
  1670. package/es/DatePicker-7287f0f9.js +0 -599
  1671. package/es/DatePicker-7287f0f9.js.map +0 -1
  1672. package/es/DatePickerHeader-f8cf86bb.js +0 -46
  1673. package/es/DatePickerHeader-f8cf86bb.js.map +0 -1
  1674. package/es/Dialog-83368f52.js +0 -387
  1675. package/es/Dialog-83368f52.js.map +0 -1
  1676. package/es/Dropdown-019aba37.js +0 -318
  1677. package/es/Dropdown-019aba37.js.map +0 -1
  1678. package/es/EmbeddedIconButton-46434710.js +0 -11
  1679. package/es/EmbeddedIconButton-46434710.js.map +0 -1
  1680. package/es/EnvironmentProvider-6a0a8212.js +0 -58
  1681. package/es/EnvironmentProvider-6a0a8212.js.map +0 -1
  1682. package/es/Flex-03129963.js +0 -30
  1683. package/es/Flex-03129963.js.map +0 -1
  1684. package/es/Floating-4a82db94.js +0 -465
  1685. package/es/Floating-4a82db94.js.map +0 -1
  1686. package/es/Grid-9e4b4f19.js +0 -27
  1687. package/es/Grid-9e4b4f19.js.map +0 -1
  1688. package/es/HighlightText-0205faef.js +0 -31
  1689. package/es/HighlightText-0205faef.js.map +0 -1
  1690. package/es/IconSwitchButton-05f1f602.js +0 -42
  1691. package/es/IconSwitchButton-05f1f602.js.map +0 -1
  1692. package/es/IconToggleButton-808818f5.js +0 -41
  1693. package/es/IconToggleButton-808818f5.js.map +0 -1
  1694. package/es/IconUserAssistance-61978211.js +0 -74
  1695. package/es/IconUserAssistance-61978211.js.map +0 -1
  1696. package/es/Layer-535577b5.js +0 -91
  1697. package/es/Layer-535577b5.js.map +0 -1
  1698. package/es/LayerHost-7931b424.js +0 -41
  1699. package/es/LayerHost-7931b424.js.map +0 -1
  1700. package/es/LayerManager-52a26c55.js +0 -34
  1701. package/es/LayerManager-52a26c55.js.map +0 -1
  1702. package/es/Link-8503aab2.js +0 -33
  1703. package/es/Link-8503aab2.js.map +0 -1
  1704. package/es/LiveRegion-cebac18d.js +0 -39
  1705. package/es/LiveRegion-cebac18d.js.map +0 -1
  1706. package/es/MaxLengthLiveRegion-8099fde5.js +0 -26
  1707. package/es/MaxLengthLiveRegion-8099fde5.js.map +0 -1
  1708. package/es/MessageLayer-2a7fdec7.js +0 -58
  1709. package/es/MessageLayer-2a7fdec7.js.map +0 -1
  1710. package/es/MonthView-4b2b483a.js +0 -208
  1711. package/es/MonthView-4b2b483a.js.map +0 -1
  1712. package/es/NavigationListItem-340ab770.js +0 -309
  1713. package/es/NavigationListItem-340ab770.js.map +0 -1
  1714. package/es/OverflowTabBarItem-aa0ce915.js +0 -257
  1715. package/es/OverflowTabBarItem-aa0ce915.js.map +0 -1
  1716. package/es/Popup-992b6c27.js +0 -298
  1717. package/es/Popup-992b6c27.js.map +0 -1
  1718. package/es/ProgressCircle-46084d0b.js +0 -48
  1719. package/es/ProgressCircle-46084d0b.js.map +0 -1
  1720. package/es/ReferenceLineArea-53129f72.js +0 -586
  1721. package/es/ReferenceLineArea-53129f72.js.map +0 -1
  1722. package/es/RevealToggleIcon-2d622d8f.js +0 -26
  1723. package/es/RevealToggleIcon-2d622d8f.js.map +0 -1
  1724. package/es/SectionedContent-30e5bf98.js +0 -65
  1725. package/es/SectionedContent-30e5bf98.js.map +0 -1
  1726. package/es/SelectMenuGroupContext-aa1fe822.js +0 -542
  1727. package/es/SelectMenuGroupContext-aa1fe822.js.map +0 -1
  1728. package/es/SelectMobileFieldInput-345c4d45.js +0 -241
  1729. package/es/SelectMobileFieldInput-345c4d45.js.map +0 -1
  1730. package/es/SelectorAll-de7ba2e1.js +0 -51
  1731. package/es/SelectorAll-de7ba2e1.js.map +0 -1
  1732. package/es/StyledDatePickerButton-78f2f6e8.js +0 -31
  1733. package/es/StyledDatePickerButton-78f2f6e8.js.map +0 -1
  1734. package/es/StyledLabelValueLayout-bb05f474.js +0 -18
  1735. package/es/StyledLabelValueLayout-bb05f474.js.map +0 -1
  1736. package/es/Submenu-cbd77756.js +0 -247
  1737. package/es/Submenu-cbd77756.js.map +0 -1
  1738. package/es/TabBar-67ca442c.js +0 -71
  1739. package/es/TabBar-67ca442c.js.map +0 -1
  1740. package/es/TabBarContextMenu-c3326d67.js +0 -99
  1741. package/es/TabBarContextMenu-c3326d67.js.map +0 -1
  1742. package/es/TabBarLinkItem-e7be54fa.js +0 -13
  1743. package/es/TabBarLinkItem-e7be54fa.js.map +0 -1
  1744. package/es/Table-2f197c6a.js +0 -4112
  1745. package/es/Table-2f197c6a.js.map +0 -1
  1746. package/es/TextArea-93ce78a7.js +0 -225
  1747. package/es/TextArea-93ce78a7.js.map +0 -1
  1748. package/es/ToggleButton-bb69cf10.js +0 -28
  1749. package/es/ToggleButton-bb69cf10.js.map +0 -1
  1750. package/es/ToggleButtonLabel-7f53fbee.js +0 -71
  1751. package/es/ToggleButtonLabel-7f53fbee.js.map +0 -1
  1752. package/es/TruncatingLink-298c6343.js +0 -56
  1753. package/es/TruncatingLink-298c6343.js.map +0 -1
  1754. package/es/View-5bdd9b3c.js +0 -167
  1755. package/es/View-5bdd9b3c.js.map +0 -1
  1756. package/es/VisStatusMessage-e2d629bb.js +0 -29
  1757. package/es/VisStatusMessage-e2d629bb.js.map +0 -1
  1758. package/es/VisTabularDatatip-85b00c1b.js +0 -24
  1759. package/es/VisTabularDatatip-85b00c1b.js.map +0 -1
  1760. package/es/WindowOverlay-7264c44a.js +0 -110
  1761. package/es/WindowOverlay-7264c44a.js.map +0 -1
  1762. package/es/YearsGridView-6c18094a.js +0 -187
  1763. package/es/YearsGridView-6c18094a.js.map +0 -1
  1764. package/es/popupUtils-51366a29.js +0 -29
  1765. package/es/popupUtils-51366a29.js.map +0 -1
  1766. package/es/tooltipUtils-af0abd38.js +0 -110
  1767. package/es/tooltipUtils-af0abd38.js.map +0 -1
  1768. package/es/useChartContextMenu-5de82cd7.js +0 -123
  1769. package/es/useChartContextMenu-5de82cd7.js.map +0 -1
  1770. package/es/useChartDatatip-8dd22b71.js +0 -336
  1771. package/es/useChartDatatip-8dd22b71.js.map +0 -1
  1772. package/es/useChartMarquee-761eb7db.js +0 -304
  1773. package/es/useChartMarquee-761eb7db.js.map +0 -1
  1774. package/es/useColorScheme-c4f6caab.js +0 -19
  1775. package/es/useColorScheme-c4f6caab.js.map +0 -1
  1776. package/es/useContextMenu-730d6c12.js +0 -116
  1777. package/es/useContextMenu-730d6c12.js.map +0 -1
  1778. package/es/useCssVars-bc2527ac.js +0 -58
  1779. package/es/useCssVars-bc2527ac.js.map +0 -1
  1780. package/es/useCurrentKey-5f865bbd.js +0 -83
  1781. package/es/useCurrentKey-5f865bbd.js.map +0 -1
  1782. package/es/useDatatip-4895a07a.js +0 -94
  1783. package/es/useDatatip-4895a07a.js.map +0 -1
  1784. package/es/useDensity-1acb0153.js +0 -19
  1785. package/es/useDensity-1acb0153.js.map +0 -1
  1786. package/es/useDisplayValue-65bbc74e.js +0 -78
  1787. package/es/useDisplayValue-65bbc74e.js.map +0 -1
  1788. package/es/useExpandCollapse-5739cfd2.js +0 -70
  1789. package/es/useExpandCollapse-5739cfd2.js.map +0 -1
  1790. package/es/useFloating-b9d680f7.js +0 -1916
  1791. package/es/useFloating-b9d680f7.js.map +0 -1
  1792. package/es/useHiddenTestMethod-f3f25093.js +0 -28
  1793. package/es/useHiddenTestMethod-f3f25093.js.map +0 -1
  1794. package/es/useKeyboardEvents-9aae7ea3.js +0 -85
  1795. package/es/useKeyboardEvents-9aae7ea3.js.map +0 -1
  1796. package/es/useLegendContextMenu-a678b26f.js +0 -279
  1797. package/es/useLegendContextMenu-a678b26f.js.map +0 -1
  1798. package/es/useMeterDatatip-538a4d53.js +0 -73
  1799. package/es/useMeterDatatip-538a4d53.js.map +0 -1
  1800. package/es/useOutsideClick-b777a43e.js +0 -115
  1801. package/es/useOutsideClick-b777a43e.js.map +0 -1
  1802. package/es/useOutsideMousedown-c45c22c0.js +0 -48
  1803. package/es/useOutsideMousedown-c45c22c0.js.map +0 -1
  1804. package/es/usePopupAnimation-96d2bc83.js +0 -85
  1805. package/es/usePopupAnimation-96d2bc83.js.map +0 -1
  1806. package/es/usePrefixSuffix-f981b65f.js +0 -70
  1807. package/es/usePrefixSuffix-f981b65f.js.map +0 -1
  1808. package/es/useRadioFocusManager-36eb283e.js +0 -108
  1809. package/es/useRadioFocusManager-36eb283e.js.map +0 -1
  1810. package/es/useReorderableItem-857636b7.js +0 -296
  1811. package/es/useReorderableItem-857636b7.js.map +0 -1
  1812. package/es/useRovingTabIndexContainer-5992e107.js +0 -106
  1813. package/es/useRovingTabIndexContainer-5992e107.js.map +0 -1
  1814. package/es/useScale-434ad939.js +0 -19
  1815. package/es/useScale-434ad939.js.map +0 -1
  1816. package/es/useSelectCommon-a3c69d60.js +0 -489
  1817. package/es/useSelectCommon-a3c69d60.js.map +0 -1
  1818. package/es/useSelectDrill-f669e729.js +0 -111
  1819. package/es/useSelectDrill-f669e729.js.map +0 -1
  1820. package/es/useSelection-65134722.js +0 -258
  1821. package/es/useSelection-65134722.js.map +0 -1
  1822. package/es/useSelection-82bec039.js +0 -186
  1823. package/es/useSelection-82bec039.js.map +0 -1
  1824. package/es/useTabBar-c5558e77.js +0 -305
  1825. package/es/useTabBar-c5558e77.js.map +0 -1
  1826. package/es/useTestId-f24ac480.js +0 -21
  1827. package/es/useTestId-f24ac480.js.map +0 -1
  1828. package/es/useTheme-0e7497db.js +0 -19
  1829. package/es/useTheme-0e7497db.js.map +0 -1
  1830. package/es/useThemeInterpolations-e144e8ec.js +0 -68
  1831. package/es/useThemeInterpolations-e144e8ec.js.map +0 -1
  1832. package/es/useTooltip-94af94d4.js +0 -49
  1833. package/es/useTooltip-94af94d4.js.map +0 -1
  1834. package/es/useTooltipControlled-f2cfa454.js +0 -373
  1835. package/es/useTooltipControlled-f2cfa454.js.map +0 -1
  1836. package/es/useTooltipOnTruncation-94282e75.js +0 -27
  1837. package/es/useTooltipOnTruncation-94282e75.js.map +0 -1
  1838. package/es/useTranslationBundle-4822502f.js +0 -29
  1839. package/es/useTranslationBundle-4822502f.js.map +0 -1
  1840. package/es/useUser-06d34d19.js +0 -19
  1841. package/es/useUser-06d34d19.js.map +0 -1
  1842. package/es/useVisDragModeControls-af64848c.js +0 -87
  1843. package/es/useVisDragModeControls-af64848c.js.map +0 -1
  1844. package/es/useVisEvents-256dee29.js +0 -153
  1845. package/es/useVisEvents-256dee29.js.map +0 -1
  1846. package/es/withDirectionIcon-a8d84a3d.js +0 -14
  1847. package/es/withDirectionIcon-a8d84a3d.js.map +0 -1
@@ -0,0 +1,4112 @@
1
+ /* @oracle/oraclejet-preact: undefined */
2
+ import { jsx, Fragment, jsxs } from 'preact/jsx-runtime';
3
+ import { Fragment as Fragment$1, createRef } from 'preact';
4
+ import { memo, forwardRef } from 'preact/compat';
5
+ import { useRef, useState, useCallback, useEffect, useMemo, useImperativeHandle, useLayoutEffect } from 'preact/hooks';
6
+ import './CollectionInteractionContext-7cf19abc.js';
7
+ import { u as useCollectionInteractionContext } from './useCollectionInteractionContext-3895c632.js';
8
+ import { u as useComponentTheme } from './useComponentTheme-d2f9e47f.js';
9
+ import { u as useId } from './useId-03dbfdf0.js';
10
+ import { T as TabbableModeContext } from './TabbableModeContext-7d8ad946.js';
11
+ import { u as useTestId } from './useTestId-ab1bede6.js';
12
+ import { u as useUser } from './useUser-e543b73c.js';
13
+ import { c as classNames } from './classNames-4e12b00d.js';
14
+ import { F as FocusTracker } from './FocusTracker-70300f1c.js';
15
+ import { g as getCellType, a as getRowKey, u as useDataManager } from './ScrollUtils-8a50c01e.js';
16
+ import { m as mergeProps } from './mergeProps-88ea8306.js';
17
+ import { u as useContextMenuGesture } from './useContextMenuGesture-e09f4c69.js';
18
+ import { i as isAutoFocusCell, g as getElementFromCell, a as applyScrollDetail, r as resetVerticalScrollPosition, b as getBoundaryColumnKey, T as TABLE_FOCUSABLE_SELECTOR, l as logicalCellExtractor, c as getColumnKey, h as hasFooterCells, d as getLastRenderedRowKey, e as TABLE_ROW_SELECTOR, f as hasLoadMoreCell, j as getFirstRenderedRowKey, k as hasNoDataCell, m as getVerticalScrollPosition, n as getRowIndexForRowKey, o as getScrollerBottom, p as getRowKeyForRowIndex, q as getColumnIndexForHeaderFooterElement, s as getRowIndexForRowElement, t as getHeaderRowElement, u as TABLE_HEADER_SELECTOR, v as useScrollHandling, w as getHorizontalScrollPosition, x as getTableBodyElement, y as getNoDataCellElement, z as getDataCellClassArray, A as getFormTextAlign, B as TableSkeletonRow, C as getHeaderFooterCellClassArray, D as useSizingManager, E as TableColGroup } from './TableColGroup-d74bd4f5.js';
19
+ import { u as useTranslationBundle } from './useTranslationBundle-bc6e0896.js';
20
+ import { B as Button } from './Button-a76ecfa8.js';
21
+ import { D as Dialog } from './Dialog-d1de5b06.js';
22
+ import { F as Flex } from './Flex-fc483125.js';
23
+ import { M as Menu, a as MenuItem } from './SelectMenuGroupContext-130a850c.js';
24
+ import { S as Submenu, a as SelectSingleMenuGroup, b as SelectMenuItem } from './Submenu-fa7c2b4f.js';
25
+ import './logger-c92f309c.js';
26
+ import './UNSAFE_Separator/themes/SeparatorStyles.css.js';
27
+ import './MenuSeparatorStyles.styles.css';
28
+ import './UNSAFE_Menu/themes/redwood/MenuSeparatorBaseTheme.styles.css';
29
+ import './UNSAFE_Menu/themes/redwood/MenuSeparatorVariants.css.js';
30
+ import { N as NumberInputText } from './NumberInputText-60be5757.js';
31
+ import { u as useColorScheme } from './useColorScheme-67245285.js';
32
+ import { u as useScale } from './useScale-93490e54.js';
33
+ import { T as TooltipContent } from './useTooltipControlled-b7f30aee.js';
34
+ import { S as SHOW_TOOLTIP_DELAY, g as getWrappedTooltipContent, H as HIDE_TOOLTIP_DELAY, a as getGlobalTooltipManager } from './tooltipUtils-90fb656f.js';
35
+ import { g as getElementContainsFunc, o as handleEnterActionableMode, p as handleWrapActionableFocus, f as findElementByKey, k as keyExtractor } from './collectionUtils-5313629f.js';
36
+ import { a as allTabbableElements, g as getActiveElement, c as getBodyElement, i as isTabbableElement } from './tabbableUtils-c8311ec6.js';
37
+ import { g as getRowActionGestureContext, i as isLogicalCtrl, h as handleRowActionGesture } from './EventUtils-e1b93d3a.js';
38
+ import { c as containsKey, a as addKey, r as removeKey, e as isSameKey } from './keys-49c92dbb.js';
39
+ import { g as getClientHints } from './clientHints-a42b510c.js';
40
+ import { g as getIsSelectionPending, c as clearElementSelection } from './textSelectionUtils-e87a47ff.js';
41
+ import { backgroundStyles, tableDragIndicatorStyles, tableFooterRowStyles, tableHeaderCellTextStyles, tableHeaderSortContainerStyles, tableHeaderRowStyles, innerTableStyles, scrollerStyles, userSelectStyles } from './PRIVATE_Table/themes/Table.css.js';
42
+ import { tableSkeletonStylesHC, tableSkeletonStyles } from './PRIVATE_Table/themes/TableSkeletonStyles.css.js';
43
+ import { TableRedwoodTheme } from './PRIVATE_Table/themes/redwood/TableTheme.js';
44
+ import { a as LoadMoreCollection } from './LoadMoreCollection-d9f22790.js';
45
+ import { tableRowStyles, tableRowStylesHC } from './PRIVATE_Table/themes/TableRowStyles.css.js';
46
+ import { TableNoDataRedwoodTheme } from './PRIVATE_Table/themes/redwood/TableNoDataTheme.js';
47
+ import { u as useInteractionStyle } from './useInteractionStyle-99e32c23.js';
48
+ import { S as Selector } from './Selector-23bccbe7.js';
49
+ import { F as FormContext } from './FormContext-55fb8000.js';
50
+ import { preventBrowserTooltipStyle, justifyContentStyles } from './PRIVATE_TableCommon/themes/Common.css.js';
51
+ import { S as SortableContext } from './useSortableContext-88a0fc5a.js';
52
+ import { S as SelectorAll } from './SelectorAll-3d39196b.js';
53
+ import { S as SortControl } from './SortControl-1044fcd9.js';
54
+ import { tableHeaderCellStyles } from './PRIVATE_Table/themes/TableHeaderCellStyles.css.js';
55
+
56
+ /**
57
+ * The internal component used to render a custom context menu on the Table
58
+ */
59
+ function TableContextMenu({ contextMenuConfig, contextMenuContext, ...menuProps }) {
60
+ const translations = useTranslationBundle('@oracle/oraclejet-preact');
61
+ const accessibleLabel = contextMenuConfig.accessibleLabel != null
62
+ ? contextMenuConfig.accessibleLabel
63
+ : translations.accContextMenuLabel();
64
+ return contextMenuConfig.itemsRenderer(contextMenuContext) != null ? (jsx(Menu, { "aria-label": accessibleLabel, ...menuProps, children: menuProps.isOpen && contextMenuConfig.itemsRenderer(contextMenuContext) })) : (jsx(Fragment, {}));
65
+ }
66
+ /**
67
+ * The internal component used to render the context menu sort item on the Table
68
+ */
69
+ function TableContextMenuSort({ columnKey, isDisabled, currentSortDirection, onSortCriterionChange }) {
70
+ const translations = useTranslationBundle('@oracle/oraclejet-preact');
71
+ const _handleSort = ({ value }) => {
72
+ if (onSortCriterionChange != null && value !== currentSortDirection) {
73
+ onSortCriterionChange([
74
+ { key: columnKey, sortDirection: value === 'ascending' ? 'ascending' : 'descending' }
75
+ ]);
76
+ }
77
+ };
78
+ return (jsx(Submenu, { label: translations.collection_sortColumnMenu(), children: jsxs(SelectSingleMenuGroup, { value: currentSortDirection, onCommit: _handleSort, children: [jsx(SelectMenuItem, { isDisabled: isDisabled, value: "ascending", label: translations.collection_sortAscendingSubMenu() }), jsx(SelectMenuItem, { isDisabled: isDisabled, value: "descending", label: translations.collection_sortDescendingSubMenu() })] }) }));
79
+ }
80
+ /**
81
+ * The internal component used to render the context menu column resize item on the Table
82
+ */
83
+ function TableContextMenuResize({ isDisabled, setIsResizeDialogOpen }) {
84
+ const translations = useTranslationBundle('@oracle/oraclejet-preact');
85
+ const handleResize = () => {
86
+ setIsResizeDialogOpen(true);
87
+ };
88
+ return (jsx(MenuItem, { label: translations.collection_resizeColumnMenu(), onAction: handleResize, isDisabled: isDisabled }));
89
+ }
90
+ /**
91
+ * The internal component used to render the column resize dialog on the Table
92
+ */
93
+ function TableResizeColumnDialog({ isOpen, columnKey, onColumnResize, appliedColumnWidths, setIsResizeDialogOpen }) {
94
+ const translations = useTranslationBundle('@oracle/oraclejet-preact');
95
+ const initialWidth = Math.round(appliedColumnWidths.netColumnWidths[columnKey]);
96
+ const initialWidthRef = useRef(initialWidth);
97
+ const numberInputRef = useRef(null);
98
+ const [widthValue, setWidthValue] = useState(String(initialWidth));
99
+ let isDisabled;
100
+ let messages;
101
+ if (widthValue == null ||
102
+ Number.isNaN(parseInt(widthValue)) ||
103
+ String(parseInt(widthValue)) !== widthValue.trim() ||
104
+ parseInt(widthValue) < 16 ||
105
+ parseInt(widthValue) > 100000) {
106
+ messages = [
107
+ {
108
+ severity: 'error',
109
+ detail: translations.collection_resizeMessageDetail({ MIN: '16', MAX: '100000' })
110
+ }
111
+ ];
112
+ isDisabled = true;
113
+ }
114
+ else {
115
+ isDisabled = false;
116
+ }
117
+ const apply = useCallback(() => {
118
+ if (columnKey != null && onColumnResize != null && widthValue != null) {
119
+ if (parseInt(widthValue) !== initialWidthRef.current) {
120
+ onColumnResize({
121
+ key: columnKey,
122
+ newWidth: parseInt(widthValue),
123
+ allColumnWidths: appliedColumnWidths.netColumnWidths,
124
+ paddingWidth: appliedColumnWidths.totalBorderOffset,
125
+ gesture: 'contextMenu',
126
+ type: 'absolute'
127
+ });
128
+ }
129
+ }
130
+ setIsResizeDialogOpen(false);
131
+ }, [columnKey, onColumnResize, widthValue, appliedColumnWidths, setIsResizeDialogOpen]);
132
+ const handleKeyDown = useCallback((event) => {
133
+ if (event.key === 'Enter' && !isDisabled) {
134
+ apply();
135
+ }
136
+ }, [apply, isDisabled]);
137
+ const cancel = useCallback(() => {
138
+ setIsResizeDialogOpen(false);
139
+ }, [setIsResizeDialogOpen]);
140
+ const handleOnInput = useCallback((detail) => {
141
+ setWidthValue(detail.value);
142
+ }, []);
143
+ const footer = (jsxs(Flex, { gap: "2x", children: [jsx(Button, { onAction: cancel, label: translations.collection_cancel() }), jsx(Button, { variant: "callToAction", onAction: apply, label: translations.collection_apply(), isDisabled: isDisabled })] }));
144
+ return (jsx(Dialog, { autoFocusRef: numberInputRef, isOpen: isOpen, modality: 'modal', header: translations.collection_resizeColumnDialog(), footer: footer, children: jsx("div", { onKeyDown: handleKeyDown, children: jsx(NumberInputText, { label: translations.collection_width(), onInput: handleOnInput, suffix: translations.collection_pixels(), messages: messages, isRequired: true, isRequiredShown: true, ref: numberInputRef, value: widthValue }) }) }));
145
+ }
146
+
147
+ /**
148
+ * Helper function to determine if a given active cell represents a 'transient' state.
149
+ */
150
+ function isTransientCell(activeCell) {
151
+ return (activeCell != null &&
152
+ (activeCell.type === 'loadMore' ||
153
+ activeCell.type === 'loading' ||
154
+ activeCell.type === 'pending'));
155
+ }
156
+ /**
157
+ * Helper function to compare two given cell descriptors.
158
+ */
159
+ function cellComparator(cell1, cell2) {
160
+ if (cell1 == null) {
161
+ return cell2 == null;
162
+ }
163
+ if (cell2 == null) {
164
+ return false;
165
+ }
166
+ if (cell1.type === cell2.type && cell1.rowKey === cell2.rowKey) {
167
+ // special case the transient 'loading' cell types as column keys are hints used for when a user
168
+ // navigates back to another region using the keyboard - otherwise we'd go to the first column
169
+ if (cell1.type === 'loading' || cell1.type === 'loadMore' || cell1.type === 'pending') {
170
+ return true;
171
+ }
172
+ return cell1.columnKey === cell2.columnKey;
173
+ }
174
+ return false;
175
+ }
176
+ function getCellContextMenuContextFromCell(tableData, columnsArray, setIsResizeDialogOpen, cell, sortCriterion, onSortCriterionChange) {
177
+ if (cell?.type === 'data' || cell?.type === 'header' || cell?.type === 'footer') {
178
+ let isSortable = false;
179
+ let isResizable = false;
180
+ for (let i = 0; i < columnsArray.length; i++) {
181
+ const column = columnsArray[i];
182
+ if (column.key === cell.columnKey) {
183
+ isSortable = column.value.sortable === 'enabled';
184
+ isResizable = column.value.resizable === 'enabled';
185
+ break;
186
+ }
187
+ }
188
+ let currentSortDirection;
189
+ if (sortCriterion != null) {
190
+ for (const criterion of sortCriterion) {
191
+ if (criterion.key === cell.columnKey) {
192
+ currentSortDirection = criterion.sortDirection;
193
+ break;
194
+ }
195
+ }
196
+ }
197
+ const allMenuItems = {
198
+ resizeColumn: (jsx(TableContextMenuResize, { isDisabled: !isResizable, setIsResizeDialogOpen: setIsResizeDialogOpen })),
199
+ sortColumn: (jsx(TableContextMenuSort, { columnKey: cell.columnKey, isDisabled: !isSortable, currentSortDirection: currentSortDirection, onSortCriterionChange: onSortCriterionChange }))
200
+ };
201
+ const hasResizableColumns = columnsArray.some((column) => {
202
+ return column.value.resizable === 'enabled';
203
+ });
204
+ const hasSortableColumns = columnsArray.some((column) => {
205
+ return column.value.sortable === 'enabled';
206
+ });
207
+ const defaultMenuItems = hasResizableColumns || hasSortableColumns ? (jsxs(Fragment, { children: [hasResizableColumns ? allMenuItems['resizeColumn'] : undefined, hasSortableColumns ? allMenuItems['sortColumn'] : undefined] })) : undefined;
208
+ if (cell.type === 'data') {
209
+ for (const rowData of tableData) {
210
+ if (rowData.metadata.key === cell.rowKey) {
211
+ return {
212
+ allMenuItems,
213
+ defaultMenuItems,
214
+ rowData: rowData.data,
215
+ rowKey: cell.rowKey,
216
+ columnKey: cell.columnKey,
217
+ type: 'data'
218
+ };
219
+ }
220
+ }
221
+ }
222
+ else {
223
+ return {
224
+ allMenuItems,
225
+ defaultMenuItems,
226
+ columnKey: cell.columnKey,
227
+ type: cell.type
228
+ };
229
+ }
230
+ }
231
+ return undefined;
232
+ }
233
+ /**
234
+ * Helper function to determine the resulting cell from a cell override.
235
+ */
236
+ function _getCellFromCellOverride(tableData, columnsArray, cellOverride, currentCell) {
237
+ let cellType;
238
+ let cellRowKey;
239
+ let cellColumnKey;
240
+ if (cellOverride.rowKey != null) {
241
+ cellType = 'data';
242
+ cellRowKey = cellOverride.rowKey;
243
+ if (cellOverride.columnKey != null) {
244
+ cellColumnKey = cellOverride.columnKey;
245
+ }
246
+ else if (currentCell?.columnKey != null) {
247
+ cellColumnKey = currentCell.columnKey;
248
+ }
249
+ else {
250
+ cellColumnKey = getBoundaryColumnKey(columnsArray, true);
251
+ }
252
+ if (cellColumnKey == null) {
253
+ return undefined;
254
+ }
255
+ }
256
+ else if (cellOverride.columnKey != null) {
257
+ cellColumnKey = cellOverride.columnKey;
258
+ if (cellOverride.type != null) {
259
+ cellType = cellOverride.type;
260
+ }
261
+ else if (currentCell?.type != null && currentCell.type !== 'noData') {
262
+ cellType = currentCell.type;
263
+ }
264
+ else {
265
+ cellType = 'header';
266
+ }
267
+ if (cellType === 'data') {
268
+ if (currentCell?.rowKey != null) {
269
+ cellRowKey = currentCell.rowKey;
270
+ }
271
+ else if (tableData.length > 0) {
272
+ cellRowKey = tableData[0].metadata.key;
273
+ }
274
+ if (cellRowKey == null) {
275
+ return undefined;
276
+ }
277
+ }
278
+ }
279
+ else if (cellOverride.type != null) {
280
+ cellType = cellOverride.type;
281
+ if (cellType !== 'noData') {
282
+ if (currentCell?.columnKey != null) {
283
+ cellColumnKey = currentCell.columnKey;
284
+ }
285
+ else {
286
+ cellColumnKey = getBoundaryColumnKey(columnsArray, true);
287
+ }
288
+ if (cellColumnKey == null) {
289
+ return undefined;
290
+ }
291
+ if (cellType === 'data') {
292
+ if (currentCell?.rowKey != null) {
293
+ cellRowKey = currentCell.rowKey;
294
+ }
295
+ else if (tableData.length > 0) {
296
+ cellRowKey = tableData[0].metadata.key;
297
+ }
298
+ if (cellRowKey == null) {
299
+ return undefined;
300
+ }
301
+ }
302
+ }
303
+ }
304
+ else {
305
+ return undefined;
306
+ }
307
+ return { type: cellType, rowKey: cellRowKey, columnKey: cellColumnKey };
308
+ }
309
+ /**
310
+ * Helper function to determine the resulting cell type from a cell override.
311
+ */
312
+ function _getCellTypeFromCellOverride(cellOverride, currentCell) {
313
+ if (cellOverride.type != null) {
314
+ return cellOverride.type;
315
+ }
316
+ if (cellOverride.rowKey != null) {
317
+ return 'data';
318
+ }
319
+ // if no type or rowKey was given, a columnKey must have been given
320
+ if (currentCell?.type != null && currentCell.type !== 'noData') {
321
+ return currentCell.type;
322
+ }
323
+ return 'header';
324
+ }
325
+ /**
326
+ * Helper function to apply a current cell override if necessary.
327
+ */
328
+ function applyCurrentCellOverride(rootElement, scrollerElement, viewportInfo, tableId, tableData, columnsArray, stickyColumnInfo, sizingInfo, overflowInfo, currencyStatusRef, onActiveCellChanged, isEmbeddedSelect, isPendingLayout, isDataLoaded, isRtl, currentCellOverride, appliedColumnWidths) {
329
+ // when embedded select, use most recent non-null current cell value as override base
330
+ const currentCell = isEmbeddedSelect
331
+ ? currencyStatusRef.current.previousEmbeddedSelectCurrentCell
332
+ : currencyStatusRef.current.currentCell;
333
+ // ensure any new currentCellOverride settings are applied if necessary
334
+ if (currencyStatusRef.current.hasPendingCurrentCellOverride ||
335
+ currencyStatusRef.current.currentCellOverride !== currentCellOverride) {
336
+ if (currentCellOverride != null) {
337
+ // attempt to find the cell the override specifies
338
+ const realizedCell = _getCellFromCellOverride(tableData, columnsArray, currentCellOverride, currentCell);
339
+ if (realizedCell != null) {
340
+ // override cell was determined - apply the override immediately
341
+ onActiveCellChanged({ value: realizedCell }, isAutoFocusCell(rootElement, tableId, realizedCell), false, true);
342
+ currencyStatusRef.current.currentCellOverride = currentCellOverride;
343
+ currencyStatusRef.current.hasPendingCurrentCellOverride = false;
344
+ if (isEmbeddedSelect) {
345
+ // scroll 'current-cell-override' vertically into view immediately for embedded select
346
+ // otherwise, cell will be scrolled into view once the component or cell receives focus
347
+ if (!isPendingLayout && getElementFromCell(rootElement, tableId, realizedCell) != null) {
348
+ applyScrollDetail(rootElement, scrollerElement, viewportInfo, tableId, columnsArray, stickyColumnInfo, sizingInfo, overflowInfo, { cell: realizedCell, locationY: 'inView' }, isRtl, appliedColumnWidths);
349
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
350
+ }
351
+ else if (isPendingLayout || !isDataLoaded) {
352
+ // corresponding element was not found - data is not ready for scrolling
353
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = true;
354
+ }
355
+ else {
356
+ // corresponding element was not found - value was garbage
357
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
358
+ }
359
+ }
360
+ else {
361
+ // not in an embedded select, so no scrolling should be performed
362
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
363
+ }
364
+ }
365
+ else if (!isDataLoaded) {
366
+ // override cell could not be determined - data is still fetching
367
+ currencyStatusRef.current.hasPendingCurrentCellOverride = true;
368
+ }
369
+ else {
370
+ // override cell could not be determined - value was garbage
371
+ currencyStatusRef.current.currentCellOverride = currentCellOverride;
372
+ currencyStatusRef.current.hasPendingCurrentCellOverride = false;
373
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
374
+ }
375
+ }
376
+ else {
377
+ // override is set to clear the current cell
378
+ onActiveCellChanged({ value: currentCellOverride });
379
+ currencyStatusRef.current.currentCellOverride = currentCellOverride;
380
+ currencyStatusRef.current.hasPendingCurrentCellOverride = false;
381
+ if (isEmbeddedSelect) {
382
+ // scroll back to the top for embedded select
383
+ resetVerticalScrollPosition(scrollerElement);
384
+ }
385
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
386
+ }
387
+ }
388
+ else if (currencyStatusRef.current.hasPendingCurrentCellOverrideScroll) {
389
+ // try and apply any pending scroll from a previous cell override at this time
390
+ if (currencyStatusRef.current.currentCell != null) {
391
+ if (!isPendingLayout &&
392
+ getElementFromCell(rootElement, tableId, currencyStatusRef.current.currentCell) != null) {
393
+ applyScrollDetail(rootElement, scrollerElement, viewportInfo, tableId, columnsArray, stickyColumnInfo, sizingInfo, overflowInfo, { cell: currencyStatusRef.current.currentCell, locationY: 'inView' }, isRtl, appliedColumnWidths);
394
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
395
+ }
396
+ else if (!isPendingLayout && isDataLoaded) {
397
+ // corresponding element was not found - value was garbage
398
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
399
+ }
400
+ }
401
+ else {
402
+ // there is no longer a current cell to try and scroll to
403
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
404
+ }
405
+ }
406
+ }
407
+ /**
408
+ * Helper to determine if the given render state includes the cell specified.
409
+ */
410
+ function _renderIncludesCell(cell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters) {
411
+ // pending layout is special as other regions exist, but are not yet navigable
412
+ if (isPendingLayout) {
413
+ return cell.type === 'pending';
414
+ }
415
+ if (cell.type === 'header' || (hasFooters && cell.type === 'footer')) {
416
+ for (let i = 0; i < columnsArray.length; i++) {
417
+ if (columnsArray[i].key === cell.columnKey) {
418
+ return true;
419
+ }
420
+ }
421
+ }
422
+ else if (tableData.length > 0) {
423
+ if (cell.type === 'loadMore') {
424
+ return hasMore;
425
+ }
426
+ if (cell.type === 'data') {
427
+ let isColumnValid = false;
428
+ for (let i = 0; i < columnsArray.length; i++) {
429
+ if (columnsArray[i].key === cell.columnKey) {
430
+ isColumnValid = true;
431
+ break;
432
+ }
433
+ }
434
+ if (isColumnValid) {
435
+ for (let i = 0; i < tableData.length; i++) {
436
+ if (tableData[i].metadata.key === cell.rowKey) {
437
+ return true;
438
+ }
439
+ }
440
+ }
441
+ }
442
+ }
443
+ else {
444
+ return (cell.type === 'loading' && hasMore) || (cell.type === 'noData' && !hasMore);
445
+ }
446
+ return false;
447
+ }
448
+ /**
449
+ * Helper to get the cell that should currently be a tab stop for the given render state.
450
+ */
451
+ function determineActiveCell(columnsArray, currencyStatusRef, tableData, hasMore, isPendingLayout, isEmbeddedSelect, hasFooters, currentCellOverride) {
452
+ if (isPendingLayout) {
453
+ return { type: 'pending' };
454
+ }
455
+ // if no columns are specified, it is a special case 'noData' display
456
+ const firstColumnKey = getBoundaryColumnKey(columnsArray, true);
457
+ if (firstColumnKey == null) {
458
+ return { type: 'noData' };
459
+ }
460
+ // if nothing specifies where focus should go, use the first header cell
461
+ const defaultFirstCell = {
462
+ type: 'header',
463
+ columnKey: firstColumnKey
464
+ };
465
+ // when embedded select, use most recent non-null current cell value as override base
466
+ const currentCell = isEmbeddedSelect
467
+ ? currencyStatusRef.current.previousEmbeddedSelectCurrentCell
468
+ : currencyStatusRef.current.currentCell;
469
+ if (currencyStatusRef.current.hasPendingCurrentCellOverride ||
470
+ currencyStatusRef.current.currentCellOverride !== currentCellOverride) {
471
+ if (currentCellOverride != null) {
472
+ // attempt to find the cell the override specifies
473
+ const realizedCell = _getCellFromCellOverride(tableData, columnsArray, currentCellOverride, currentCell);
474
+ if (realizedCell != null &&
475
+ _renderIncludesCell(realizedCell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
476
+ return realizedCell;
477
+ }
478
+ // if here, the resulting cell from the override could not be determined or was not valid
479
+ const overrideCellType = _getCellTypeFromCellOverride(currentCellOverride, currentCell);
480
+ if (overrideCellType === 'data') {
481
+ if (tableData.length === 0 && hasMore) {
482
+ // pending 'data' override when 'loading' skeletons are shown
483
+ return { type: 'loading', columnKey: currentCell?.columnKey };
484
+ }
485
+ }
486
+ else if (overrideCellType === 'noData' && tableData.length === 0 && hasMore) {
487
+ // pending 'noData' override when 'loading' skeletons are shown
488
+ return { type: 'loading', columnKey: currentCell?.columnKey };
489
+ }
490
+ }
491
+ else if (_renderIncludesCell(defaultFirstCell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
492
+ return defaultFirstCell;
493
+ }
494
+ else {
495
+ return undefined;
496
+ }
497
+ }
498
+ // if here, there is no current cell override that can be applied during this render
499
+ const activeCell = currencyStatusRef.current.activeCell;
500
+ if (activeCell != null) {
501
+ if (activeCell.type === 'loadMore') {
502
+ const initialData = currencyStatusRef.current.loadMoreInitialData;
503
+ // if loadMore skeletons are no longer shown, or the data has changed, shift to
504
+ // the next row in the data set if possible - otherwise just the closest row
505
+ if (tableData.length > 0 && tableData !== initialData) {
506
+ const rowKey = initialData != null && tableData.length > initialData.length
507
+ ? tableData[initialData.length].metadata.key
508
+ : tableData[tableData.length - 1].metadata.key;
509
+ const columnKey = currentCell?.columnKey != null ? currentCell.columnKey : firstColumnKey;
510
+ const cell = { type: 'data', rowKey: rowKey, columnKey: columnKey };
511
+ if (_renderIncludesCell(cell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
512
+ return cell;
513
+ }
514
+ }
515
+ else if (tableData.length === 0) {
516
+ if (hasMore) {
517
+ return { type: 'loading', columnKey: currentCell?.columnKey };
518
+ }
519
+ else {
520
+ return { type: 'noData' };
521
+ }
522
+ }
523
+ }
524
+ if (_renderIncludesCell(activeCell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
525
+ return activeCell;
526
+ }
527
+ else if (activeCell.type === 'loading') {
528
+ if (currentCell != null && (currentCell.type === 'data' || currentCell.type === 'noData')) {
529
+ // if the current cell is already set to 'data' or 'noData', and is now available, return it
530
+ if (_renderIncludesCell(currentCell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
531
+ return currentCell;
532
+ }
533
+ }
534
+ // otherwise, find the first row if available, and try and maintain the columnKey
535
+ if (tableData.length > 0) {
536
+ const rowKey = tableData[0].metadata.key;
537
+ const columnKey = currentCell?.columnKey != null ? currentCell.columnKey : firstColumnKey;
538
+ const cell = { type: 'data', rowKey: rowKey, columnKey: columnKey };
539
+ if (_renderIncludesCell(cell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
540
+ return cell;
541
+ }
542
+ }
543
+ else {
544
+ return { type: 'noData' };
545
+ }
546
+ }
547
+ }
548
+ // if here, there is no active cell, or the active cell is no longer valid
549
+ if (currentCell != null) {
550
+ if (_renderIncludesCell(currentCell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
551
+ return currentCell;
552
+ }
553
+ if (currentCell.type === 'data') {
554
+ if (tableData.length === 0 && hasMore) {
555
+ // pending 'data' override when 'loading' skeletons are shown
556
+ return { type: 'loading', columnKey: currentCell.columnKey };
557
+ }
558
+ }
559
+ else if (currentCell.type === 'noData' && tableData.length === 0 && hasMore) {
560
+ // pending 'noData' override when 'loading' skeletons are shown
561
+ return { type: 'loading', columnKey: firstColumnKey };
562
+ }
563
+ }
564
+ if (_renderIncludesCell(defaultFirstCell, columnsArray, tableData, hasMore, isPendingLayout, hasFooters)) {
565
+ return defaultFirstCell;
566
+ }
567
+ return undefined;
568
+ }
569
+
570
+ const TOUCH_OFFSET_VALUE = 40;
571
+ const menuPropGestureStates = {
572
+ mouse: {
573
+ initialFocus: 'menu',
574
+ placement: 'bottom-start',
575
+ offsetValue: 2
576
+ },
577
+ keyboard: {
578
+ initialFocus: 'firstItem',
579
+ placement: 'bottom-start',
580
+ offsetValue: 0
581
+ },
582
+ touch: {
583
+ initialFocus: 'menu',
584
+ placement: 'end',
585
+ offsetValue: TOUCH_OFFSET_VALUE
586
+ }
587
+ };
588
+ const _initialMenuProps = {
589
+ isOpen: false,
590
+ initialFocus: 'menu',
591
+ placement: 'bottom-start',
592
+ offsetValue: 0,
593
+ anchorRef: { current: null }
594
+ };
595
+ const useContextMenu = (rootRef, tableId, tableData, columnsArray, contextMenuConfig, sortCriterion, onSortCriterionChange) => {
596
+ const [contextMenuContext, setContextMenuContext] = useState();
597
+ const [menuProps, setMenuProps] = useState(_initialMenuProps);
598
+ const currentCellElementRef = useRef();
599
+ const [isResizeDialogOpen, setIsResizeDialogOpen] = useState(false);
600
+ const { triggerProps } = useContextMenuGesture(({ gesture, anchor, target }) => {
601
+ if (rootRef.current) {
602
+ // find the cell element the menu is being launched from
603
+ const cellElement = target.closest(`[${TABLE_FOCUSABLE_SELECTOR}='${tableId}']`);
604
+ if (cellElement != null) {
605
+ const targetCell = logicalCellExtractor(cellElement, tableId, columnsArray);
606
+ if (targetCell != null) {
607
+ const cellContextMenuContext = getCellContextMenuContextFromCell(tableData, columnsArray, setIsResizeDialogOpen, targetCell, sortCriterion, onSortCriterionChange);
608
+ if (cellContextMenuContext != null) {
609
+ currentCellElementRef.current = cellElement;
610
+ const anchorBasedOnGesture = gesture === 'keyboard' ? cellElement : anchor;
611
+ setContextMenuContext(cellContextMenuContext);
612
+ setMenuProps({
613
+ ...menuPropGestureStates[gesture],
614
+ anchorRef: { current: anchorBasedOnGesture },
615
+ isOpen: true
616
+ });
617
+ }
618
+ }
619
+ }
620
+ }
621
+ }, { isDisabled: !contextMenuConfig });
622
+ const handleCloseContextMenu = useCallback((detail) => {
623
+ // set focus back on the cell that was determined as the initial target
624
+ if (detail.reason === 'dismissed' || detail.reason === 'itemAction') {
625
+ currentCellElementRef.current?.focus({ preventScroll: true });
626
+ }
627
+ // close the menu
628
+ setMenuProps({ ..._initialMenuProps });
629
+ }, []);
630
+ return {
631
+ menuProps: { ...menuProps, onClose: handleCloseContextMenu },
632
+ contextMenuContext: contextMenuContext,
633
+ contextMenuTriggerProps: triggerProps,
634
+ isResizeDialogOpen: isResizeDialogOpen,
635
+ setIsResizeDialogOpen: setIsResizeDialogOpen
636
+ };
637
+ };
638
+
639
+ /**
640
+ * Browser zoom levels are not handled identically between Range sizes and Element sizes, so this offset
641
+ * should be used when comparing horizontal widths. Using a smaller value (0.01 for example) causes false
642
+ * positives, while using a larger value (0.05 for example) causes actual truncations to be missed.
643
+ */
644
+ const HORIZONTAL_TRUNCATION_OFFSET = 0.015;
645
+ /**
646
+ * Default Redwood line-height overrides cause false positives as the Range sizes are always for a 'normal'
647
+ * line-height, and none of the default scale fonts have 'normal' line-height values. This causes offsets
648
+ * of between 0.5px and 1.5px. As a true truncation will cause an offset of closer to a full line height
649
+ * (at least 12px for 2xs text), use a larger offset value than the currently observed 1.5px max for safety.
650
+ */
651
+ const VERTICAL_TRUNCATION_OFFSET = 5;
652
+ /**
653
+ * Helper method to determine if a given cell contains truncated text.
654
+ */
655
+ const hasTruncatedText = (cellElement) => {
656
+ if (cellElement.getAttribute('data-oj-table-tooltip') !== 'enabled') {
657
+ return false;
658
+ }
659
+ const innerText = String(cellElement.innerText).trim();
660
+ if (innerText === '') {
661
+ return false;
662
+ }
663
+ const walker = document.createTreeWalker(cellElement, NodeFilter.SHOW_TEXT);
664
+ while (walker.nextNode()) {
665
+ const range = new Range();
666
+ const textNode = walker.currentNode;
667
+ range.selectNodeContents(textNode);
668
+ const untruncatedTextLength = range.getBoundingClientRect().width;
669
+ const untruncatedTextHeight = range.getBoundingClientRect().height;
670
+ let firstParent = true;
671
+ let parentElement = textNode.parentElement;
672
+ while (parentElement != null) {
673
+ const parentStyles = getComputedStyle(parentElement);
674
+ if (firstParent) {
675
+ // only verify truncation status of 'visible' text nodes
676
+ if (untruncatedTextLength === 0 || parentStyles.visibility === 'hidden') {
677
+ break;
678
+ }
679
+ firstParent = false;
680
+ }
681
+ const horizontalPadding = parseFloat(parentStyles.paddingLeft) + parseFloat(parentStyles.paddingRight);
682
+ const horizontalBorder = parseFloat(parentStyles.borderLeft) + parseFloat(parentStyles.borderRight);
683
+ const renderedTextLength = parentElement.getBoundingClientRect().width - horizontalPadding - horizontalBorder;
684
+ const verticalPadding = parseFloat(parentStyles.paddingTop) + parseFloat(parentStyles.paddingBottom);
685
+ const verticalBorder = parseFloat(parentStyles.borderTop) + parseFloat(parentStyles.borderBottom);
686
+ const renderedTextHeight = parentElement.getBoundingClientRect().height - verticalPadding - verticalBorder;
687
+ if (untruncatedTextLength - renderedTextLength > HORIZONTAL_TRUNCATION_OFFSET ||
688
+ untruncatedTextHeight - renderedTextHeight > VERTICAL_TRUNCATION_OFFSET) {
689
+ return true;
690
+ }
691
+ if (parentElement === cellElement) {
692
+ break;
693
+ }
694
+ parentElement = parentElement.parentElement;
695
+ }
696
+ }
697
+ return false;
698
+ };
699
+ /**
700
+ * Helper function to handle updating the Table's tooltip due to a focus navigation gesture.
701
+ */
702
+ function handleNavigationTooltipGesture(rootElement, tableId, cell, showTooltip, hideTooltip) {
703
+ hideTooltip(true);
704
+ if (cell.type === 'data' || cell.type === 'header' || cell.type === 'footer') {
705
+ const cellElement = getElementFromCell(rootElement, tableId, cell);
706
+ if (cellElement != null) {
707
+ showTooltip(cell);
708
+ }
709
+ }
710
+ }
711
+ /**
712
+ * Helper function to handle updating the Table's tooltip due to a pointer move gesture.
713
+ */
714
+ function handleMoveTooltipGesture(tableId, columnsArray, event, showTooltip, hideTooltip, tooltipId) {
715
+ let tooltipShown = false;
716
+ const targetElement = event.relatedTarget;
717
+ if (targetElement != null && targetElement.closest(`#${tooltipId}`) != null) {
718
+ return;
719
+ }
720
+ const cellElement = event.target.closest(`[${TABLE_FOCUSABLE_SELECTOR}='${tableId}']`);
721
+ if (cellElement != null) {
722
+ const type = getCellType(cellElement);
723
+ if (type === 'data' || type === 'header' || type === 'footer') {
724
+ showTooltip(logicalCellExtractor(cellElement, tableId, columnsArray));
725
+ tooltipShown = true;
726
+ }
727
+ }
728
+ if (!tooltipShown) {
729
+ hideTooltip();
730
+ }
731
+ }
732
+ /**
733
+ * Helper function to handle updating the Table's tooltip due to a pointer leave gesture.
734
+ */
735
+ const handleLeaveTableTooltipGesture = (rootElement, event, hideTooltip, tooltipId) => {
736
+ const targetElement = event.relatedTarget;
737
+ if (targetElement != null && targetElement.closest(`#${tooltipId}`) != null) {
738
+ // the pointer 'left' the table, but is only over a cell tooltip - in most cases, we want
739
+ // to just return here as the pointer is still 'over' the table. however, this can also
740
+ // occur when the pointer is technically outside of the table's bounds, and in that case
741
+ // we don't actually want to return as we should clear out our cell tooltip as expected
742
+ const boundingRect = rootElement.getBoundingClientRect();
743
+ const isOutOfBounds = event.clientX < boundingRect.left ||
744
+ event.clientX > boundingRect.right ||
745
+ event.clientY < boundingRect.top ||
746
+ event.clientY > boundingRect.bottom;
747
+ if (!isOutOfBounds) {
748
+ return;
749
+ }
750
+ }
751
+ hideTooltip();
752
+ };
753
+
754
+ // delay small interaction times concerning a tooltip
755
+ const SMALL_INTERACTION_DELAY = 50;
756
+ const TABLE_HIDE_TOOLTIP_DELAY = Math.max(Math.min(SHOW_TOOLTIP_DELAY - SMALL_INTERACTION_DELAY, HIDE_TOOLTIP_DELAY), 0);
757
+ /**
758
+ * Hook that manages cell template tooltip interactions on the Table when truncation is present.
759
+ */
760
+ function useTruncationTooltip({ rootRef, tableId, resizeInfoRef }) {
761
+ const globalTooltipManager = getGlobalTooltipManager();
762
+ const tooltipId = useId();
763
+ const tooltipCellRef = useRef();
764
+ const pendingShowTooltipCellRef = useRef();
765
+ const tooltipAnchorRef = useRef();
766
+ const tooltipTextRef = useRef();
767
+ const [tooltipText, setTooltipText] = useState();
768
+ const pointerDownRef = useRef(false);
769
+ const pointerDownTimeoutRef = useRef();
770
+ const showTooltipTimeoutRef = useRef();
771
+ const hideTooltipTimeoutRef = useRef();
772
+ // helper method for clearing the hide tooltip timeout
773
+ const _clearHideTooltipTimeout = useCallback(() => {
774
+ clearTimeout(hideTooltipTimeoutRef.current);
775
+ hideTooltipTimeoutRef.current = undefined;
776
+ }, []);
777
+ // helper method for clearing the show tooltip timeout
778
+ const _clearShowTooltipTimeout = useCallback(() => {
779
+ clearTimeout(showTooltipTimeoutRef.current);
780
+ showTooltipTimeoutRef.current = undefined;
781
+ pendingShowTooltipCellRef.current = undefined;
782
+ }, []);
783
+ // helper method for setting up the show tooltip timeout
784
+ const _setupShowTooltipTimeout = useCallback(() => {
785
+ showTooltipTimeoutRef.current = setTimeout(function () {
786
+ // when showing a tooltip, clear any pending 'clear tooltip timeouts'
787
+ if (hideTooltipTimeoutRef.current != null) {
788
+ _clearHideTooltipTimeout();
789
+ }
790
+ // only show a tooltip if not currently performing a column resize gesture
791
+ if (!resizeInfoRef.current.isResizing) {
792
+ showTooltipTimeoutRef.current = undefined;
793
+ const cell = pendingShowTooltipCellRef.current;
794
+ const rootElement = rootRef.current;
795
+ if (rootElement != null && cell != null) {
796
+ const cellElement = getElementFromCell(rootElement, tableId, cell);
797
+ if (cellElement != null && hasTruncatedText(cellElement)) {
798
+ setTooltipText(String(cellElement.innerText).trim());
799
+ tooltipAnchorRef.current = cellElement;
800
+ tooltipCellRef.current = cell;
801
+ }
802
+ }
803
+ }
804
+ pendingShowTooltipCellRef.current = undefined;
805
+ }, SHOW_TOOLTIP_DELAY);
806
+ }, [rootRef, tableId, resizeInfoRef, _clearHideTooltipTimeout]);
807
+ // helper method for setting up the hide tooltip timeout
808
+ const _setupHideTooltipTimeout = useCallback(() => {
809
+ hideTooltipTimeoutRef.current = setTimeout(function () {
810
+ // unlike in the showtooltip timeout logic, we do not want to clear
811
+ // pending show tooltip timeouts when clearing a tooltip as it could
812
+ // still be waiting to be shown in another location at this time
813
+ hideTooltipTimeoutRef.current = undefined;
814
+ setTooltipText(undefined);
815
+ tooltipAnchorRef.current = undefined;
816
+ tooltipCellRef.current = undefined;
817
+ }, TABLE_HIDE_TOOLTIP_DELAY);
818
+ }, []);
819
+ // callback method to signal a tooltip is desired on the given cell
820
+ const showTooltip = useCallback((anchorCell) => {
821
+ if (cellComparator(tooltipCellRef.current, anchorCell)) {
822
+ // if the tooltip is already showing in the right cell, clear all timeouts
823
+ if (showTooltipTimeoutRef.current != null) {
824
+ _clearShowTooltipTimeout();
825
+ }
826
+ if (hideTooltipTimeoutRef.current != null) {
827
+ _clearHideTooltipTimeout();
828
+ }
829
+ return;
830
+ }
831
+ if (showTooltipTimeoutRef.current == null) {
832
+ // if no tooltip is already pending, start a new tooltip timeout
833
+ pendingShowTooltipCellRef.current = anchorCell;
834
+ _setupShowTooltipTimeout();
835
+ }
836
+ else if (!cellComparator(pendingShowTooltipCellRef.current, anchorCell)) {
837
+ // if a different tooltip is already pending, start a new tooltip timeout
838
+ _clearShowTooltipTimeout();
839
+ pendingShowTooltipCellRef.current = anchorCell;
840
+ _setupShowTooltipTimeout();
841
+ }
842
+ if (tooltipCellRef.current != null && hideTooltipTimeoutRef.current == null) {
843
+ // if the tooltip is showing on a different cell, ensure a hide timeout is setup
844
+ _setupHideTooltipTimeout();
845
+ }
846
+ }, [
847
+ _setupShowTooltipTimeout,
848
+ _setupHideTooltipTimeout,
849
+ _clearShowTooltipTimeout,
850
+ _clearHideTooltipTimeout
851
+ ]);
852
+ // callback method to signal the current tooltip is no longer desired
853
+ const hideTooltip = useCallback((isImmediate) => {
854
+ // ignore hide tooltip calls if due to focus loss from a pointer down on the tooltip itself
855
+ if (pointerDownRef.current) {
856
+ return;
857
+ }
858
+ if (showTooltipTimeoutRef.current != null) {
859
+ _clearShowTooltipTimeout();
860
+ }
861
+ if (isImmediate) {
862
+ if (hideTooltipTimeoutRef.current != null) {
863
+ _clearHideTooltipTimeout();
864
+ }
865
+ setTooltipText(undefined);
866
+ tooltipAnchorRef.current = undefined;
867
+ tooltipCellRef.current = undefined;
868
+ }
869
+ else if (hideTooltipTimeoutRef.current == null) {
870
+ _setupHideTooltipTimeout();
871
+ }
872
+ }, [_setupHideTooltipTimeout, _clearShowTooltipTimeout, _clearHideTooltipTimeout]);
873
+ // Pointer move handler for the tooltip.
874
+ const _pointerMoveHandler = useCallback((_event) => {
875
+ if (showTooltipTimeoutRef.current != null) {
876
+ clearTimeout(showTooltipTimeoutRef.current);
877
+ showTooltipTimeoutRef.current = undefined;
878
+ pendingShowTooltipCellRef.current = undefined;
879
+ }
880
+ if (hideTooltipTimeoutRef.current != null) {
881
+ clearTimeout(hideTooltipTimeoutRef.current);
882
+ hideTooltipTimeoutRef.current = undefined;
883
+ }
884
+ }, []);
885
+ // Pointer leave handler for the tooltip.
886
+ const _pointerLeaveHandler = useCallback((event) => {
887
+ const targetElement = event.relatedTarget;
888
+ if (targetElement != null && targetElement.closest(`#${tableId}`) != null) {
889
+ return;
890
+ }
891
+ hideTooltip();
892
+ }, [tableId, hideTooltip]);
893
+ // Pointer down handler for the tooltip.
894
+ const _pointerDownHandler = useCallback((_event) => {
895
+ pointerDownRef.current = true;
896
+ if (pointerDownTimeoutRef.current != null) {
897
+ clearTimeout(pointerDownTimeoutRef.current);
898
+ }
899
+ pointerDownTimeoutRef.current = setTimeout(function () {
900
+ pointerDownRef.current = false;
901
+ pointerDownTimeoutRef.current = undefined;
902
+ }, SMALL_INTERACTION_DELAY);
903
+ }, []);
904
+ // handles logic involving competing tooltips managed outside of the TableView.
905
+ // make sure this check runs BEFORE the rendered content is created below
906
+ const isOpenOverrideRef = useRef(true);
907
+ if (tooltipText != null && tooltipText !== tooltipTextRef.current) {
908
+ isOpenOverrideRef.current = true;
909
+ }
910
+ const tooltipPointerProps = {
911
+ onPointerLeave: _pointerLeaveHandler,
912
+ onPointerMove: _pointerMoveHandler,
913
+ onPointerDown: _pointerDownHandler
914
+ };
915
+ // avoid applying undefined text after initial render completes as it can appear
916
+ // while the tooltip is going through its closing animation and looks broken
917
+ const renderRawContent = (jsx(TooltipContent, { ...tooltipPointerProps, id: tooltipId, isOpen: isOpenOverrideRef.current, isDatatip: false, children: tooltipText != null ? tooltipText : tooltipTextRef.current }));
918
+ // make sure these are in sync AFTER the rendered content is created above - this helps ensure
919
+ // that empty text does not show up while the tooltip is going through a closing animation.
920
+ tooltipTextRef.current = tooltipText;
921
+ // offsets attempt to show the tooltip without overlapping content of nearby cells
922
+ const scale = useScale();
923
+ let mainAxisOffset = -8;
924
+ let crossAxisOffset = -14;
925
+ if (scale === 'md') {
926
+ mainAxisOffset = -7;
927
+ crossAxisOffset = -12;
928
+ }
929
+ else if (scale === 'sm') {
930
+ mainAxisOffset = -6;
931
+ crossAxisOffset = -11;
932
+ }
933
+ const currentColorScheme = useColorScheme();
934
+ const tooltipContent = tooltipAnchorRef.current != null
935
+ ? getWrappedTooltipContent(renderRawContent, 'tooltip', currentColorScheme, tooltipAnchorRef, 'end-top', { mainAxis: mainAxisOffset, crossAxis: crossAxisOffset })
936
+ : undefined;
937
+ const destroyCallback = useCallback(() => {
938
+ hideTooltip(true);
939
+ }, [hideTooltip]);
940
+ useEffect(() => {
941
+ if (isOpenOverrideRef.current && tooltipAnchorRef.current != null) {
942
+ globalTooltipManager.register(destroyCallback);
943
+ }
944
+ else {
945
+ globalTooltipManager.unregister(destroyCallback);
946
+ }
947
+ }, [tooltipAnchorRef, destroyCallback, tooltipText, globalTooltipManager]);
948
+ return { tooltipContent, tooltipId, showTooltip, hideTooltip, tooltipAnchorRef };
949
+ }
950
+
951
+ // constant timeout values for delays following a input gesture until enabling focus rings
952
+ const MOUSE_FOCUS_SHIFT_TIMEOUT = 100;
953
+ const TOUCH_FOCUS_SHIFT_TIMEOUT = 200;
954
+ // constant event.key values that trigger focus ring logic
955
+ const NAVIGATION_KEYS = [
956
+ ' ',
957
+ 'F2',
958
+ 'Enter',
959
+ 'Esc', // Firefox 36 and earlier uses 'Esc' instead of 'Escape'
960
+ 'Escape',
961
+ 'ArrowLeft',
962
+ 'ArrowUp',
963
+ 'ArrowRight',
964
+ 'ArrowDown',
965
+ 'Home',
966
+ 'End',
967
+ 'PageUp',
968
+ 'PageDown'
969
+ ];
970
+ // constant event.key values that trigger 'scroll to current' logic
971
+ const SCROLL_KEYS = [
972
+ ' ',
973
+ 'F2',
974
+ 'Enter',
975
+ 'Esc', // Firefox 36 and earlier uses 'Esc' instead of 'Escape'
976
+ 'Escape'
977
+ ];
978
+ /**
979
+ * Hook that manages focus interactions on the Preact Table
980
+ */
981
+ function useFocusHandling({ rootRef, viewportInfo, tableId, isRtl, tableData, hasMore, hasFooters, columnsArray, stickyColumnInfo, sizingInfoRef, overflowInfoRef, selectionExtensionElementRef, cellSupportsTabbable, appliedColumnWidths, currentCellOverride, onPersistCurrentCell, showTooltip, hideTooltip, isPendingLayout, isEmbedded, isDataLoaded }) {
982
+ // tracks whether the most recent 'blur' was caused by focus being lost by the browser window (or iframe)
983
+ // used when determining whether scrolling active into view should be skipped when focus is regained
984
+ const blurFromWindowRef = useRef(false);
985
+ // tracks whether a keydown 'tab' is currently detected - used when handling a keyup 'tab' event to scroll
986
+ // the active cell into view in the event that focus is received from outside of the page (or iframe)
987
+ const isTabDownDetectedRef = useRef(false);
988
+ // tracks focus loss during render cycle for potential focus recapture cases
989
+ const isRenderCycle = useRef(true);
990
+ isRenderCycle.current = true;
991
+ const blurredRenderCycleElementRef = useRef(null);
992
+ const isPendingLayoutFocusRef = useRef(false);
993
+ // track current 'focus info' state
994
+ const hasFocusRef = useRef(false);
995
+ const [isTabbableMode, setIsTabbableMode] = useState(false);
996
+ const [isShowFocusRing, setIsShowFocusRing] = useState(false);
997
+ // track pointer down information
998
+ const recentPointerRef = useRef(false);
999
+ const pointerTimerRef = useRef(null);
1000
+ const isShowFocusRingOverrideRef = useRef(null);
1001
+ // track the active and current cell information
1002
+ const [activeCell, setActiveCell] = useState(undefined);
1003
+ const currencyStatusRef = useRef({
1004
+ hasPendingCurrentCellOverride: false,
1005
+ hasPendingCurrentCellOverrideScroll: false
1006
+ });
1007
+ // track pending scrolls to minimize 'flash' of focus rings when scrolling
1008
+ const [deferredScrollDetail, setDeferredScrollDetail] = useState(undefined);
1009
+ const deferredScrollDetailRef = useRef();
1010
+ // keep state and ref in-sync to avoid edge cases where a gesture updating the scroll detail is handled
1011
+ // inbetween a render cycle that changes the scroll detail and the useEffect that applies the detail
1012
+ const updateDeferredScrollDetail = useCallback((scrollDetail) => {
1013
+ setDeferredScrollDetail(scrollDetail);
1014
+ deferredScrollDetailRef.current = scrollDetail;
1015
+ }, []);
1016
+ const wasTransient = isTransientCell(currencyStatusRef.current.activeCell);
1017
+ const currentActiveCell = determineActiveCell(columnsArray, currencyStatusRef, tableData, hasMore, isPendingLayout, isEmbedded, hasFooters, currentCellOverride);
1018
+ // intercept onPersistCurrentCell calls to ensure internal state is updated appropriately
1019
+ const onActiveCellChanged = useMemo(() => {
1020
+ return (detail, isAutoFocus, isSelectionExtension, skipScrollCellIntoView) => {
1021
+ const newActiveCell = detail.value;
1022
+ if (!cellComparator(currencyStatusRef.current.activeCell, newActiveCell)) {
1023
+ setActiveCell(newActiveCell);
1024
+ currencyStatusRef.current.activeCell = newActiveCell;
1025
+ if (!isTransientCell(newActiveCell)) {
1026
+ const newCurrentCell = newActiveCell;
1027
+ // only update current cell when 'active' is not one of the transient 'skeleton' regions
1028
+ if (onPersistCurrentCell != null) {
1029
+ onPersistCurrentCell({ value: newCurrentCell });
1030
+ }
1031
+ currencyStatusRef.current.currentCell = newCurrentCell;
1032
+ // make sure pending current cell override states are updated on current changed
1033
+ if (newCurrentCell != null) {
1034
+ currencyStatusRef.current.previousEmbeddedSelectCurrentCell = newCurrentCell;
1035
+ }
1036
+ currencyStatusRef.current.currentCellOverride = currentCellOverride;
1037
+ currencyStatusRef.current.hasPendingCurrentCellOverride = false;
1038
+ currencyStatusRef.current.hasPendingCurrentCellOverrideScroll = false;
1039
+ }
1040
+ else if (newActiveCell?.type === 'loadMore') {
1041
+ currencyStatusRef.current.loadMoreInitialData = tableData;
1042
+ }
1043
+ if (!isSelectionExtension) {
1044
+ selectionExtensionElementRef.current = undefined;
1045
+ if (isAutoFocus && newActiveCell != null && cellSupportsTabbable(newActiveCell)) {
1046
+ // attempt to auto-focus cell contents
1047
+ setIsTabbableMode(true);
1048
+ setIsShowFocusRing(false);
1049
+ }
1050
+ else if (isTabbableMode) {
1051
+ // exit tabbable mode when navigating away from auto-focus cell
1052
+ setIsTabbableMode(false);
1053
+ }
1054
+ }
1055
+ }
1056
+ if (newActiveCell != null && !recentPointerRef.current && !skipScrollCellIntoView) {
1057
+ updateDeferredScrollDetail({
1058
+ cell: newActiveCell,
1059
+ locationX: 'inView',
1060
+ locationY: 'inView'
1061
+ });
1062
+ }
1063
+ };
1064
+ }, [
1065
+ currentCellOverride,
1066
+ isTabbableMode,
1067
+ cellSupportsTabbable,
1068
+ tableData,
1069
+ onPersistCurrentCell,
1070
+ selectionExtensionElementRef,
1071
+ updateDeferredScrollDetail
1072
+ ]);
1073
+ // Helper function to set the Table's focus tracking state to reflect that it is inactive.
1074
+ const _setAsInactive = useCallback(() => {
1075
+ hasFocusRef.current = false;
1076
+ isPendingLayoutFocusRef.current = false;
1077
+ setIsTabbableMode(false);
1078
+ setIsShowFocusRing(false);
1079
+ hideTooltip();
1080
+ }, [hideTooltip]);
1081
+ // Helper function to set the Table's focus tracking state to reflect that one of its cells has focus.
1082
+ const _enableNavigationMode = useCallback((cell, skipScrollCellIntoView) => {
1083
+ const rootElement = rootRef.current;
1084
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
1085
+ if (rootElement != null && scrollerElement != null) {
1086
+ setIsTabbableMode(false);
1087
+ const focusRingState = isShowFocusRingOverrideRef.current !== null
1088
+ ? isShowFocusRingOverrideRef.current
1089
+ : !recentPointerRef.current;
1090
+ setIsShowFocusRing(focusRingState);
1091
+ if (focusRingState) {
1092
+ handleNavigationTooltipGesture(rootElement, tableId, cell, showTooltip, hideTooltip);
1093
+ }
1094
+ onActiveCellChanged({ value: cell }, false, false, skipScrollCellIntoView);
1095
+ }
1096
+ }, [rootRef, viewportInfo, tableId, onActiveCellChanged, showTooltip, hideTooltip]);
1097
+ // Helper function to set the Table's focus tracking state to reflect that it is tabbable.
1098
+ const _enableTabbableMode = useCallback((cell, isKeyboard, skipScrollCellIntoView) => {
1099
+ const rootElement = rootRef.current;
1100
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
1101
+ if (rootElement != null && scrollerElement != null) {
1102
+ setIsTabbableMode(true);
1103
+ if (!isKeyboard) {
1104
+ setIsShowFocusRing(false);
1105
+ onActiveCellChanged({ value: cell }, true, false, skipScrollCellIntoView);
1106
+ }
1107
+ }
1108
+ }, [rootRef, viewportInfo, onActiveCellChanged]);
1109
+ // Helper function to set the Table's focus tracking state to reflect that a user has
1110
+ // exited tabbable mode via the keyboard (esc or 'F2')
1111
+ const _disableTabbableMode = useCallback((cell) => {
1112
+ const rootElement = rootRef.current;
1113
+ if (rootElement != null) {
1114
+ setIsTabbableMode(false);
1115
+ const cellElement = getElementFromCell(rootElement, tableId, cell);
1116
+ if (cellElement != null) {
1117
+ cellElement.focus({ preventScroll: true });
1118
+ }
1119
+ else {
1120
+ rootElement.focus({ preventScroll: true });
1121
+ }
1122
+ }
1123
+ }, [rootRef, tableId]);
1124
+ const notifyFocusFromPointer = useCallback((isTouch) => {
1125
+ if (pointerTimerRef.current != null) {
1126
+ clearTimeout(pointerTimerRef.current);
1127
+ }
1128
+ recentPointerRef.current = true;
1129
+ pointerTimerRef.current = setTimeout(() => {
1130
+ recentPointerRef.current = false;
1131
+ }, isTouch ? TOUCH_FOCUS_SHIFT_TIMEOUT : MOUSE_FOCUS_SHIFT_TIMEOUT);
1132
+ }, []);
1133
+ // PointerDown handler for the outer Table. Focus transfers that occur following a pointerdown
1134
+ // on desktop devices should not result in a focus ring being shown on the focused element
1135
+ const _pointerDownHandler = useCallback((event) => {
1136
+ if (isShowFocusRing) {
1137
+ setIsShowFocusRing(false);
1138
+ }
1139
+ if (event.pointerType !== 'touch') {
1140
+ notifyFocusFromPointer(false);
1141
+ }
1142
+ }, [isShowFocusRing, notifyFocusFromPointer]);
1143
+ // PointerUp handler for the outer Table. Focus transfers that occur following a pointerup
1144
+ // on any type of device should not result in a focus ring being shown on the focused element
1145
+ const _pointerUpHandler = useCallback((event) => {
1146
+ notifyFocusFromPointer(event.pointerType === 'touch');
1147
+ }, [notifyFocusFromPointer]);
1148
+ // Focus handler for the outer Table. On focus, a focusable area needs to be 'active'.
1149
+ // If an 'active' area already exists, nothing further is needed. Otherwise, the first
1150
+ // focusable element should be made 'active'.
1151
+ const _onFocusHandler = (event) => {
1152
+ hasFocusRef.current = true;
1153
+ const rootElement = rootRef.current;
1154
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
1155
+ if (rootElement != null) {
1156
+ // don't scroll active into view if previous blur was due to window focus loss
1157
+ const skipScrollCellIntoView = blurFromWindowRef.current || isPendingLayout;
1158
+ blurFromWindowRef.current = false;
1159
+ const targetElement = event.target;
1160
+ if (targetElement === rootElement || targetElement === scrollerElement) {
1161
+ if (currentActiveCell != null) {
1162
+ _enableNavigationMode(currentActiveCell, skipScrollCellIntoView);
1163
+ }
1164
+ }
1165
+ else {
1166
+ const cell = logicalCellExtractor(targetElement, tableId, columnsArray);
1167
+ if (cell != null) {
1168
+ if (getCellType(targetElement) != null) {
1169
+ // handle individual focusable regions receiving focus
1170
+ _enableNavigationMode(cell, skipScrollCellIntoView);
1171
+ }
1172
+ else {
1173
+ _enableTabbableMode(cell, false, skipScrollCellIntoView);
1174
+ }
1175
+ }
1176
+ }
1177
+ }
1178
+ isShowFocusRingOverrideRef.current = null;
1179
+ };
1180
+ // Blur handler for the outer Table. When a blur is caused by the browser window itself
1181
+ // losing focus (changing tabs or leaving an iframe for example), an eventual re-focus due
1182
+ // to the window re-gaining focus needs to be handled differently (no auto-scroll mostly).
1183
+ const _onBlurHandler = useCallback((event) => {
1184
+ const rootElement = rootRef.current;
1185
+ if (rootElement != null) {
1186
+ if (event.target === document.activeElement) {
1187
+ // save focus ring state so it's set once focus comes back
1188
+ isShowFocusRingOverrideRef.current = isShowFocusRing;
1189
+ }
1190
+ const relatedTarget = event.relatedTarget;
1191
+ const isUnknownRelatedTarget = relatedTarget == null;
1192
+ blurFromWindowRef.current = isUnknownRelatedTarget;
1193
+ if (isUnknownRelatedTarget || !getElementContainsFunc(rootElement, true)(relatedTarget)) {
1194
+ _setAsInactive();
1195
+ if (isRenderCycle.current) {
1196
+ // store element that loses focus during a render cycle for recapturing focus logic
1197
+ blurredRenderCycleElementRef.current = event.target;
1198
+ }
1199
+ // reset tab down detection when component loses focus
1200
+ isTabDownDetectedRef.current = false;
1201
+ }
1202
+ }
1203
+ }, [rootRef, isShowFocusRing, _setAsInactive]);
1204
+ // KeyDown handler for the outer Table. This specific handler tracks 'focus' transfer keys
1205
+ // Esc, F2, Enter, and Tab. It also ensures the active cell is scrolled into view on any key
1206
+ const _onKeyDownHandler = useCallback((event) => {
1207
+ if (event.key === 'Tab') {
1208
+ isTabDownDetectedRef.current = true;
1209
+ }
1210
+ const rootElement = rootRef.current;
1211
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
1212
+ if (rootElement != null && scrollerElement != null) {
1213
+ const isNavigationKey = NAVIGATION_KEYS.indexOf(event.key) > -1;
1214
+ if (isNavigationKey) {
1215
+ if (pointerTimerRef.current != null) {
1216
+ clearTimeout(pointerTimerRef.current);
1217
+ }
1218
+ pointerTimerRef.current = null;
1219
+ recentPointerRef.current = false;
1220
+ }
1221
+ if (isPendingLayout) {
1222
+ if (isNavigationKey) {
1223
+ setIsShowFocusRing(true);
1224
+ }
1225
+ }
1226
+ else if (activeCell != null) {
1227
+ if (cellSupportsTabbable(activeCell)) {
1228
+ if (event.key === 'F2') {
1229
+ if (isTabbableMode) {
1230
+ _disableTabbableMode(activeCell);
1231
+ }
1232
+ else {
1233
+ _enableTabbableMode(activeCell, true);
1234
+ }
1235
+ }
1236
+ else if (event.key === 'Esc' || event.key === 'Escape') {
1237
+ // Firefox 36 and earlier uses 'Esc' instead of 'Escape'
1238
+ _disableTabbableMode(activeCell);
1239
+ }
1240
+ else if (event.key === 'Enter' && !isTabbableMode && !isEmbedded) {
1241
+ _enableTabbableMode(activeCell, true);
1242
+ }
1243
+ }
1244
+ if (!isTabbableMode) {
1245
+ if (isNavigationKey) {
1246
+ setIsShowFocusRing(true);
1247
+ }
1248
+ if (SCROLL_KEYS.indexOf(event.key) > -1) {
1249
+ updateDeferredScrollDetail({
1250
+ cell: activeCell,
1251
+ locationX: 'inView',
1252
+ locationY: 'inView'
1253
+ });
1254
+ }
1255
+ }
1256
+ }
1257
+ }
1258
+ }, [
1259
+ rootRef,
1260
+ viewportInfo,
1261
+ isTabbableMode,
1262
+ isEmbedded,
1263
+ activeCell,
1264
+ cellSupportsTabbable,
1265
+ isPendingLayout,
1266
+ _enableTabbableMode,
1267
+ _disableTabbableMode,
1268
+ updateDeferredScrollDetail
1269
+ ]);
1270
+ // KeyUp handler for the outer Table. This specific handler tracks the 'tab' key
1271
+ // It ensures the active cell is scrolled into view when tabbing into the component
1272
+ const _onKeyUpHandler = useCallback((event) => {
1273
+ if (event.key === 'Tab') {
1274
+ // if a keyup 'tab' event is detected without a matching keydown 'tab', scroll active
1275
+ // cell into view to handle case where focus is gained from outside the page (or iframe)
1276
+ if (activeCell != null && !isTabDownDetectedRef.current) {
1277
+ updateDeferredScrollDetail({
1278
+ cell: activeCell,
1279
+ locationX: 'inView',
1280
+ locationY: 'inView'
1281
+ });
1282
+ }
1283
+ isTabDownDetectedRef.current = false;
1284
+ }
1285
+ }, [activeCell, updateDeferredScrollDetail]);
1286
+ // Callback for the outer Table's FocusTracker usage.
1287
+ const onStartFocusTracking = useCallback((detail) => {
1288
+ const rootElement = rootRef.current;
1289
+ if (rootElement != null && activeCell != null) {
1290
+ handleEnterActionableMode(detail.hasFocusWithin && getCellType(detail.activeElement) == null, allTabbableElements(getElementFromCell(rootElement, tableId, activeCell)), (value) => {
1291
+ setIsTabbableMode(value != undefined);
1292
+ });
1293
+ }
1294
+ }, [rootRef, activeCell, tableId]);
1295
+ // Callback for the outer Table's FocusTracker usage.
1296
+ const onFocusStartEdge = useCallback((detail) => {
1297
+ handleWrapActionableFocus(true, detail.tabbableElements, (value) => {
1298
+ setIsTabbableMode(value != undefined);
1299
+ });
1300
+ }, []);
1301
+ // Callback for the outer Table's FocusTracker usage.
1302
+ const onFocusEndEdge = useCallback((detail) => {
1303
+ handleWrapActionableFocus(false, detail.tabbableElements, (value) => {
1304
+ setIsTabbableMode(value != undefined);
1305
+ });
1306
+ }, []);
1307
+ // Ensure focus is properly set at the completion of every render cycle
1308
+ // NO DEPENDENCY ARRAY HERE TO ENSURE THIS RUNS ON EVERY RENDER CYCLE
1309
+ useEffect(() => {
1310
+ const rootElement = rootRef.current;
1311
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
1312
+ if (rootElement != null && scrollerElement != null) {
1313
+ // internal method responsible for ensuring focus is applied to the appropriate cells or contents
1314
+ const _applyInternalFocus = (rootElement, activeElement, isCaptureFocus) => {
1315
+ if (currentActiveCell != null) {
1316
+ // ensure real browser focus is on the correct cell element
1317
+ const cellElement = getElementFromCell(rootElement, tableId, currentActiveCell);
1318
+ if (cellElement != null) {
1319
+ if (isCaptureFocus) {
1320
+ applyScrollDetail(rootElement, scrollerElement, viewportInfo, tableId, columnsArray, stickyColumnInfo, sizingInfoRef.current, overflowInfoRef.current, {
1321
+ cell: currentActiveCell,
1322
+ locationX: 'inView',
1323
+ locationY: 'inView'
1324
+ }, isRtl, appliedColumnWidths);
1325
+ }
1326
+ // cell is valid, so set focus on it if needed
1327
+ if (!isTabbableMode && activeElement !== cellElement) {
1328
+ if (wasTransient &&
1329
+ !isTransientCell(currentActiveCell) &&
1330
+ isAutoFocusCell(rootElement, tableId, currentActiveCell) &&
1331
+ cellSupportsTabbable(currentActiveCell)) {
1332
+ _enableTabbableMode(currentActiveCell);
1333
+ }
1334
+ else {
1335
+ cellElement.focus({ preventScroll: true });
1336
+ }
1337
+ return;
1338
+ }
1339
+ else if (isTabbableMode &&
1340
+ !getElementContainsFunc(cellElement, true)(activeElement)) {
1341
+ if (isCaptureFocus && !isAutoFocusCell(rootElement, tableId, currentActiveCell)) {
1342
+ _disableTabbableMode(currentActiveCell);
1343
+ }
1344
+ else {
1345
+ handleEnterActionableMode(false, allTabbableElements(cellElement), (value) => {
1346
+ setIsTabbableMode(value != undefined);
1347
+ if (isCaptureFocus) {
1348
+ rootElement.focus({ preventScroll: true });
1349
+ }
1350
+ }, true);
1351
+ }
1352
+ return;
1353
+ }
1354
+ else if (activeCell !== currentActiveCell) {
1355
+ // if element is already focused, ensure state is up to date
1356
+ onActiveCellChanged({ value: currentActiveCell }, false, false, true);
1357
+ }
1358
+ }
1359
+ }
1360
+ if (isCaptureFocus) {
1361
+ rootElement.focus({ preventScroll: true });
1362
+ }
1363
+ };
1364
+ // ensure the current cell is scrolled into view when necessary
1365
+ // only run if the state and ref match - otherwise another render cycle may be pending
1366
+ if (deferredScrollDetail != null &&
1367
+ deferredScrollDetail === deferredScrollDetailRef.current) {
1368
+ applyScrollDetail(rootElement, scrollerElement, viewportInfo, tableId, columnsArray, stickyColumnInfo, sizingInfoRef.current, overflowInfoRef.current, deferredScrollDetail, isRtl, appliedColumnWidths);
1369
+ deferredScrollDetailRef.current = undefined;
1370
+ }
1371
+ // ensure current-cell-override is up to date on each render
1372
+ applyCurrentCellOverride(rootElement, scrollerElement, viewportInfo, tableId, tableData, columnsArray, stickyColumnInfo, sizingInfoRef.current, overflowInfoRef.current, currencyStatusRef, onActiveCellChanged, isEmbedded, isPendingLayout, isDataLoaded, isRtl, currentCellOverride, appliedColumnWidths);
1373
+ const blurredRenderCycleElement = blurredRenderCycleElementRef.current;
1374
+ blurredRenderCycleElementRef.current = null;
1375
+ isRenderCycle.current = false;
1376
+ const activeElement = getActiveElement(rootElement);
1377
+ // if we were tracking focus during the render cycle, ensure we recapture focus if needed
1378
+ if (blurredRenderCycleElement != null &&
1379
+ activeElement === getBodyElement(rootElement) &&
1380
+ (!getElementContainsFunc(rootElement, true)(blurredRenderCycleElement) ||
1381
+ !isTabbableElement(blurredRenderCycleElement, true))) {
1382
+ deferredScrollDetailRef.current = undefined;
1383
+ _applyInternalFocus(rootElement, activeElement, true);
1384
+ }
1385
+ else if (hasFocusRef.current &&
1386
+ cellComparator(activeCell, currencyStatusRef.current.activeCell)) {
1387
+ _applyInternalFocus(rootElement, activeElement);
1388
+ }
1389
+ }
1390
+ });
1391
+ return {
1392
+ focusHandlingProps: {
1393
+ onPointerDown: _pointerDownHandler,
1394
+ onPointerUp: _pointerUpHandler,
1395
+ onFocus: _onFocusHandler,
1396
+ onBlur: _onBlurHandler,
1397
+ onKeyDown: _onKeyDownHandler,
1398
+ onKeyUp: _onKeyUpHandler
1399
+ },
1400
+ activeCell,
1401
+ onActiveCellChanged,
1402
+ currentCell: currencyStatusRef.current.currentCell,
1403
+ currentActiveCell,
1404
+ isShowFocusRing,
1405
+ isTabbableMode,
1406
+ onStartFocusTracking,
1407
+ onFocusStartEdge,
1408
+ onFocusEndEdge,
1409
+ updateDeferredScrollDetail
1410
+ };
1411
+ }
1412
+
1413
+ /**
1414
+ * Helper function to get the row action context from row information
1415
+ */
1416
+ const getActionContext = (_index, key, data) => {
1417
+ return { key, data };
1418
+ };
1419
+ /**
1420
+ * Helper function to determine if a pointer or keyboard event should trigger a sort action gesture
1421
+ */
1422
+ const isSortActionGesture = (columnsArray, columnKey) => {
1423
+ for (const column of columnsArray) {
1424
+ if (column.key === columnKey) {
1425
+ return column.value.sortable === 'enabled';
1426
+ }
1427
+ }
1428
+ return false;
1429
+ };
1430
+ /**
1431
+ * Helper function to handle a sort action gesture
1432
+ */
1433
+ const handleSortActionGesture = (columnsArray, columnKey, onSortCriterionChange, sortCriterion) => {
1434
+ if (isSortActionGesture(columnsArray, columnKey)) {
1435
+ let sortDirection;
1436
+ if (sortCriterion != null) {
1437
+ for (const criterion of sortCriterion) {
1438
+ if (criterion.key === columnKey) {
1439
+ sortDirection = criterion.sortDirection;
1440
+ break;
1441
+ }
1442
+ }
1443
+ }
1444
+ const newDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
1445
+ onSortCriterionChange([{ key: columnKey, sortDirection: newDirection }]);
1446
+ return true;
1447
+ }
1448
+ return false;
1449
+ };
1450
+
1451
+ /**
1452
+ * Helper function to handle a hover gesture over a column header or footer region.
1453
+ */
1454
+ function handleOverColumnHeaderFooterGesture(tableId, event, setHoverStyleColumnInfo, hoverStyleColumnInfo) {
1455
+ // only track 'hover' information for mouse events
1456
+ if (event.pointerType === 'mouse') {
1457
+ const cellElement = event.target.closest(`[${TABLE_FOCUSABLE_SELECTOR}='${tableId}']`);
1458
+ if (cellElement != null) {
1459
+ const cellType = getCellType(cellElement);
1460
+ if (cellType === 'header' || cellType === 'footer') {
1461
+ const isHeader = cellType === 'header';
1462
+ const columnKey = getColumnKey(cellElement);
1463
+ if (columnKey !== hoverStyleColumnInfo?.key ||
1464
+ !hoverStyleColumnInfo?.isHeader !== isHeader) {
1465
+ setHoverStyleColumnInfo({ key: columnKey, isHeader: cellType === 'header' });
1466
+ return;
1467
+ }
1468
+ }
1469
+ }
1470
+ }
1471
+ handleEndInteractionColumnHeaderFooterGesture(setHoverStyleColumnInfo, hoverStyleColumnInfo);
1472
+ }
1473
+ /**
1474
+ * Helper function to handle an active gesture over a column header or footer region.
1475
+ */
1476
+ function handleActiveColumnHeaderFooterGesture(tableId, event, setActiveStyleColumnInfo, activeStyleColumnInfo, activeCell) {
1477
+ let cellType;
1478
+ let columnKey;
1479
+ if (activeCell != null) {
1480
+ cellType = activeCell.type;
1481
+ columnKey = activeCell.columnKey;
1482
+ }
1483
+ else if (event instanceof PointerEvent && event.pointerType === 'touch') {
1484
+ // only handle touch events since hover events have the same treatment
1485
+ const cellElement = event.target.closest(`[${TABLE_FOCUSABLE_SELECTOR}='${tableId}']`);
1486
+ if (cellElement != null) {
1487
+ cellType = getCellType(cellElement);
1488
+ columnKey = getColumnKey(cellElement);
1489
+ }
1490
+ }
1491
+ if (columnKey != null && (cellType === 'header' || cellType === 'footer')) {
1492
+ const isHeader = cellType === 'header';
1493
+ if (columnKey !== activeStyleColumnInfo?.key || !activeStyleColumnInfo?.isHeader !== isHeader) {
1494
+ setActiveStyleColumnInfo({ key: columnKey, isHeader: cellType === 'header' });
1495
+ return;
1496
+ }
1497
+ }
1498
+ handleEndInteractionColumnHeaderFooterGesture(setActiveStyleColumnInfo, activeStyleColumnInfo);
1499
+ }
1500
+ /**
1501
+ * Helper function to handle the end of an interaction style gesture for the table region.
1502
+ */
1503
+ function handleEndInteractionColumnHeaderFooterGesture(setInteractionStyleColumnInfo, interactionStyleColumnInfo) {
1504
+ if (interactionStyleColumnInfo != null) {
1505
+ setInteractionStyleColumnInfo(undefined);
1506
+ }
1507
+ }
1508
+
1509
+ /**
1510
+ * Helper function to handle an 'Up' or 'Down' arrow key press.
1511
+ * Up - Moves to the same cell in the previous row (including headers and footers). No op if already on the first row.
1512
+ * Down - Moves to the same cell in the next row (including headers and footers). No op if already on the last row.
1513
+ */
1514
+ function handleAdjacentRowGesture(rootElement, tableId, columnsArray, initialCell, onActiveCellChanged, isPrevious, isExtendSelectionGesture, hideTooltip, updateDeferredScrollDetail) {
1515
+ const firstColumnKey = getBoundaryColumnKey(columnsArray, true);
1516
+ if (firstColumnKey == null) {
1517
+ return;
1518
+ }
1519
+ let newCell = initialCell;
1520
+ const cellType = initialCell.type;
1521
+ if (cellType === 'noData') {
1522
+ const newColumnKey = firstColumnKey;
1523
+ if (isPrevious) {
1524
+ newCell = { columnKey: newColumnKey, type: 'header' };
1525
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1526
+ }
1527
+ else if (hasFooterCells(rootElement, tableId)) {
1528
+ newCell = { columnKey: newColumnKey, type: 'footer' };
1529
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1530
+ }
1531
+ }
1532
+ else if (cellType === 'loading') {
1533
+ if (isPrevious) {
1534
+ newCell = { columnKey: initialCell.columnKey, type: 'header' };
1535
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1536
+ }
1537
+ else if (hasFooterCells(rootElement, tableId)) {
1538
+ newCell = { columnKey: initialCell.columnKey, type: 'footer' };
1539
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1540
+ }
1541
+ }
1542
+ else if (cellType === 'loadMore') {
1543
+ if (isPrevious) {
1544
+ const rowKey = getLastRenderedRowKey(rootElement, tableId);
1545
+ if (rowKey != null) {
1546
+ newCell = { rowKey: rowKey, columnKey: initialCell.columnKey, type: 'data' };
1547
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1548
+ }
1549
+ }
1550
+ else if (hasFooterCells(rootElement, tableId)) {
1551
+ newCell = { columnKey: initialCell.columnKey, type: 'footer' };
1552
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1553
+ }
1554
+ }
1555
+ else if (cellType !== 'pending') {
1556
+ if (cellType === 'data') {
1557
+ const currentRowKey = initialCell.rowKey;
1558
+ const currentRowElement = findElementByKey(rootElement, currentRowKey, `[${TABLE_ROW_SELECTOR}='${tableId}']`);
1559
+ if (currentRowElement != null) {
1560
+ const rowElements = [
1561
+ ...rootElement.querySelectorAll(`[${TABLE_ROW_SELECTOR}='${tableId}']`)
1562
+ ];
1563
+ const currentRowIndex = rowElements.indexOf(currentRowElement);
1564
+ let adjacentRowElement;
1565
+ if (isPrevious && currentRowIndex > 0) {
1566
+ adjacentRowElement = rowElements[currentRowIndex - 1];
1567
+ }
1568
+ else if (!isPrevious && currentRowIndex < rowElements.length - 1) {
1569
+ adjacentRowElement = rowElements[currentRowIndex + 1];
1570
+ }
1571
+ if (adjacentRowElement != null) {
1572
+ const rowKey = getRowKey(adjacentRowElement);
1573
+ if (rowKey != null) {
1574
+ newCell = { rowKey: rowKey, columnKey: initialCell.columnKey, type: 'data' };
1575
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell), isExtendSelectionGesture);
1576
+ }
1577
+ }
1578
+ else if (!isExtendSelectionGesture) {
1579
+ if (isPrevious) {
1580
+ newCell = { columnKey: initialCell.columnKey, type: 'header' };
1581
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1582
+ }
1583
+ else if (hasLoadMoreCell(rootElement, tableId)) {
1584
+ newCell = { columnKey: initialCell.columnKey, type: 'loadMore' };
1585
+ if (getElementFromCell(rootElement, tableId, newCell) != null) {
1586
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1587
+ }
1588
+ }
1589
+ else if (hasFooterCells(rootElement, tableId)) {
1590
+ newCell = { columnKey: initialCell.columnKey, type: 'footer' };
1591
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1592
+ }
1593
+ }
1594
+ }
1595
+ }
1596
+ else if (cellType === 'header' && !isPrevious) {
1597
+ const rowKey = getFirstRenderedRowKey(rootElement, tableId);
1598
+ if (rowKey != null) {
1599
+ newCell = { rowKey: rowKey, columnKey: initialCell.columnKey, type: 'data' };
1600
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1601
+ }
1602
+ else if (hasNoDataCell(rootElement, tableId)) {
1603
+ newCell = { type: 'noData' };
1604
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1605
+ }
1606
+ else {
1607
+ newCell = { columnKey: initialCell.columnKey, type: 'loading' };
1608
+ if (getElementFromCell(rootElement, tableId, newCell) != null) {
1609
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1610
+ }
1611
+ else if (hasFooterCells(rootElement, tableId)) {
1612
+ newCell = { columnKey: initialCell.columnKey, type: 'footer' };
1613
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1614
+ }
1615
+ }
1616
+ }
1617
+ else if (cellType === 'footer' && isPrevious) {
1618
+ if (hasNoDataCell(rootElement, tableId)) {
1619
+ newCell = { type: 'noData' };
1620
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1621
+ }
1622
+ else {
1623
+ newCell = { columnKey: initialCell.columnKey, type: 'loading' };
1624
+ if (getElementFromCell(rootElement, tableId, newCell) != null) {
1625
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1626
+ }
1627
+ else {
1628
+ newCell = { columnKey: initialCell.columnKey, type: 'loadMore' };
1629
+ if (getElementFromCell(rootElement, tableId, newCell) != null) {
1630
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1631
+ }
1632
+ else {
1633
+ const rowKey = getLastRenderedRowKey(rootElement, tableId);
1634
+ if (rowKey != null) {
1635
+ newCell = { rowKey: rowKey, columnKey: initialCell.columnKey, type: 'data' };
1636
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1637
+ }
1638
+ else {
1639
+ newCell = { columnKey: initialCell.columnKey, type: 'header' };
1640
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1641
+ }
1642
+ }
1643
+ }
1644
+ }
1645
+ }
1646
+ }
1647
+ if (!cellComparator(initialCell, newCell)) {
1648
+ hideTooltip(true);
1649
+ }
1650
+ else {
1651
+ updateDeferredScrollDetail({ cell: newCell, locationX: 'inView', locationY: 'inView' });
1652
+ }
1653
+ }
1654
+ /**
1655
+ * Helper function to handle a 'PageUp' or 'PageDown' arrow key press.
1656
+ * PageUp - Moves to the same cell in the first visible row in the current viewport,
1657
+ * and scrolls the Table so it becomes the last visible row in the viewport when able.
1658
+ * PageDown - Moves to the same cell in the last visible row in the current viewport,
1659
+ * and scrolls the Table so it becomes the first visible row in the viewport when able.
1660
+ */
1661
+ function handlePageRowGesture(rootElement, scrollerElement, viewportInfo, tableId, sizingInfo, initialCell, onActiveCellChanged, isPrevious, hideTooltip, updateDeferredScrollDetail) {
1662
+ if (initialCell.type !== 'noData' && initialCell.type !== 'pending') {
1663
+ const rowElements = rootElement.querySelectorAll(`[${TABLE_ROW_SELECTOR}='${tableId}']`);
1664
+ if (rowElements.length > 0) {
1665
+ const verticalScrollPosition = getVerticalScrollPosition(rootElement, scrollerElement, viewportInfo, tableId);
1666
+ const verticalRowIndex = getRowIndexForRowKey(rootElement, tableId, verticalScrollPosition.rowKey);
1667
+ let targetRowIndex;
1668
+ if (isPrevious) {
1669
+ if (verticalScrollPosition.offsetY === 0) {
1670
+ targetRowIndex = Math.max(verticalRowIndex - 1, 0);
1671
+ }
1672
+ else {
1673
+ targetRowIndex = verticalRowIndex;
1674
+ }
1675
+ }
1676
+ else {
1677
+ const scrollerBottom = getScrollerBottom(rootElement, scrollerElement, viewportInfo.viewportConfig, sizingInfo, tableId);
1678
+ targetRowIndex = verticalRowIndex;
1679
+ while (rowElements.length > targetRowIndex + 1) {
1680
+ targetRowIndex += 1;
1681
+ const elementBottom = rowElements[targetRowIndex].getBoundingClientRect().bottom;
1682
+ if (elementBottom > scrollerBottom) {
1683
+ break;
1684
+ }
1685
+ }
1686
+ }
1687
+ const newRowKey = getRowKeyForRowIndex(rootElement, tableId, targetRowIndex);
1688
+ if (newRowKey != null) {
1689
+ const newCell = {
1690
+ rowKey: newRowKey,
1691
+ columnKey: initialCell.columnKey,
1692
+ type: 'data'
1693
+ };
1694
+ if (newRowKey !== initialCell.rowKey) {
1695
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell), false, true);
1696
+ }
1697
+ if (!cellComparator(initialCell, newCell)) {
1698
+ hideTooltip(true);
1699
+ }
1700
+ updateDeferredScrollDetail({
1701
+ cell: newCell,
1702
+ locationX: 'inView',
1703
+ locationY: isPrevious ? 'bottom' : 'top'
1704
+ });
1705
+ }
1706
+ }
1707
+ }
1708
+ }
1709
+ /**
1710
+ * Helper function to get the column key next to the given column key in the specified direction. Returns
1711
+ * null if there is no adjacent column in the direction specified.
1712
+ */
1713
+ function _getAdjacentColumnKey(initialKey, columnsArray, isPrevious) {
1714
+ let currentIndex = -1;
1715
+ const columnsCount = columnsArray.length;
1716
+ for (let i = 0; i < columnsCount; i++) {
1717
+ if (columnsArray[i].key === initialKey) {
1718
+ currentIndex = i;
1719
+ break;
1720
+ }
1721
+ }
1722
+ if (isPrevious && currentIndex !== 0) {
1723
+ return columnsArray[currentIndex - 1].key;
1724
+ }
1725
+ else if (!isPrevious && currentIndex !== columnsCount - 1) {
1726
+ return columnsArray[currentIndex + 1].key;
1727
+ }
1728
+ return undefined;
1729
+ }
1730
+ /**
1731
+ * Helper function to handle a 'Previous' or 'Next' arrow key press.
1732
+ * Previous - Moves to the previous cell in the current row. No op if already on the first cell in that row.
1733
+ * Next - Moves to the next cell in the current row. No op if already on the last cell in that row.
1734
+ */
1735
+ function handleAdjacentColumnGesture(rootElement, tableId, columnsArray, initialCell, onActiveCellChanged, isPrevious, hideTooltip, updateDeferredScrollDetail) {
1736
+ let newCell = initialCell;
1737
+ const cellType = initialCell.type;
1738
+ if (cellType === 'data' || cellType === 'header' || cellType === 'footer') {
1739
+ const initialKey = initialCell.columnKey;
1740
+ const newKey = _getAdjacentColumnKey(initialKey, columnsArray, isPrevious);
1741
+ if (newKey != null) {
1742
+ if (cellType === 'data') {
1743
+ newCell = { rowKey: initialCell.rowKey, columnKey: newKey, type: cellType };
1744
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1745
+ }
1746
+ else {
1747
+ newCell = { columnKey: newKey, type: cellType };
1748
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1749
+ }
1750
+ }
1751
+ }
1752
+ if (!cellComparator(initialCell, newCell)) {
1753
+ hideTooltip(true);
1754
+ }
1755
+ else {
1756
+ updateDeferredScrollDetail({ cell: newCell, locationX: 'inView', locationY: 'inView' });
1757
+ }
1758
+ }
1759
+ /**
1760
+ * Helper function to handle a 'Home' or 'End' key press.
1761
+ * Home - Jumps to the first cell in the current row. No op if already on the first cell in that row.
1762
+ * Ctrl/Cmd + Home - Jumps to the first cell in the first data row. If no data rows are present,
1763
+ * jumps to the first cell in the current region (header or footer). No op if already on that cell.
1764
+ * End - Jumps to the last cell in the current row. No op if already on the last cell in that row.
1765
+ * Ctrl/Cmd + End - Jumps to the last cell in the last data row. If no data rows are present,
1766
+ * jumps to the last cell in the current region (header or footer). No op if already on that cell.
1767
+ */
1768
+ function handleJumpColumnGesture(rootElement, tableId, columnsArray, initialCell, onActiveCellChanged, isPrevious, includeRows, hideTooltip, updateDeferredScrollDetail) {
1769
+ const newKey = getBoundaryColumnKey(columnsArray, isPrevious);
1770
+ if (newKey == null) {
1771
+ return;
1772
+ }
1773
+ let newCell = initialCell;
1774
+ const cellType = initialCell.type;
1775
+ if (cellType === 'data' || cellType === 'header' || cellType === 'footer') {
1776
+ const initialKey = initialCell.columnKey;
1777
+ if (includeRows) {
1778
+ if (hasNoDataCell(rootElement, tableId)) {
1779
+ newCell = { type: 'noData' };
1780
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1781
+ }
1782
+ else {
1783
+ const newRowKey = isPrevious
1784
+ ? getFirstRenderedRowKey(rootElement, tableId)
1785
+ : getLastRenderedRowKey(rootElement, tableId);
1786
+ if (newRowKey != null) {
1787
+ newCell = { rowKey: newRowKey, columnKey: newKey, type: 'data' };
1788
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1789
+ }
1790
+ }
1791
+ }
1792
+ else if (newKey !== initialKey) {
1793
+ if (cellType === 'data') {
1794
+ newCell = { rowKey: initialCell.rowKey, columnKey: newKey, type: cellType };
1795
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1796
+ }
1797
+ else {
1798
+ newCell = { columnKey: newKey, type: cellType };
1799
+ onActiveCellChanged({ value: newCell }, isAutoFocusCell(rootElement, tableId, newCell));
1800
+ }
1801
+ }
1802
+ }
1803
+ if (!cellComparator(initialCell, newCell)) {
1804
+ hideTooltip(true);
1805
+ }
1806
+ else {
1807
+ updateDeferredScrollDetail({ cell: newCell, locationX: 'inView', locationY: 'inView' });
1808
+ }
1809
+ }
1810
+
1811
+ /**
1812
+ * Helper function to handle a selection gesture (click, spacebar, etc...)
1813
+ */
1814
+ function handleSelectionGesture(rootElement, tableId, columnsArray, targetElement, isModifierKey, onSelectionChange, isDropDownSelection, selectionMode, selected) {
1815
+ const emptyKeys = { all: false, keys: new Set() };
1816
+ let selectedRows = selected?.row != null ? selected.row : emptyKeys;
1817
+ let selectedColumns = selected?.column != null ? selected.column : emptyKeys;
1818
+ const newRowKey = keyExtractor(targetElement, `[${TABLE_ROW_SELECTOR}='${tableId}']`);
1819
+ if (newRowKey != null) {
1820
+ if (selectionMode?.row === 'single' ||
1821
+ selectionMode?.row === 'multiple' ||
1822
+ selectionMode?.row === 'multipleToggle') {
1823
+ const isToggleSelectionMode = isDropDownSelection || selectionMode.row === 'multipleToggle';
1824
+ const isMultiSelectRowGesture = isModifierKey || isToggleSelectionMode;
1825
+ if (selectedRows == null) {
1826
+ selectedRows = { all: false, keys: new Set([newRowKey]) };
1827
+ }
1828
+ else if (!containsKey(selectedRows, newRowKey)) {
1829
+ if (isMultiSelectRowGesture && selectionMode.row !== 'single') {
1830
+ selectedRows = addKey(selectedRows, newRowKey);
1831
+ }
1832
+ else {
1833
+ selectedRows = { all: false, keys: new Set([newRowKey]) };
1834
+ }
1835
+ }
1836
+ else if (isMultiSelectRowGesture) {
1837
+ selectedRows = removeKey(selectedRows, newRowKey, false);
1838
+ }
1839
+ else {
1840
+ selectedRows = { all: false, keys: new Set([newRowKey]) };
1841
+ }
1842
+ selectedColumns = emptyKeys;
1843
+ }
1844
+ }
1845
+ else if (selectionMode?.column === 'single' || selectionMode?.column === 'multiple') {
1846
+ const cellElement = targetElement.closest(`[${TABLE_FOCUSABLE_SELECTOR}='${tableId}']`);
1847
+ if (cellElement != null) {
1848
+ const cellType = getCellType(cellElement);
1849
+ if (cellType === 'header' || cellType === 'footer') {
1850
+ const index = getColumnIndexForHeaderFooterElement(rootElement, tableId, cellElement, cellType === 'header');
1851
+ if (index != null) {
1852
+ const column = columnsArray[index];
1853
+ if (column.value.selectable !== 'disabled') {
1854
+ if (selectedColumns == null) {
1855
+ selectedColumns = { all: false, keys: new Set([column.key]) };
1856
+ }
1857
+ else if (!containsKey(selectedColumns, column.key)) {
1858
+ if (isModifierKey && selectionMode.column === 'multiple') {
1859
+ selectedColumns = addKey(selectedColumns, column.key);
1860
+ }
1861
+ else {
1862
+ selectedColumns = { all: false, keys: new Set([column.key]) };
1863
+ }
1864
+ }
1865
+ else if (isModifierKey) {
1866
+ selectedColumns = removeKey(selectedColumns, column.key, false);
1867
+ }
1868
+ else {
1869
+ selectedColumns = { all: false, keys: new Set([column.key]) };
1870
+ }
1871
+ selectedRows = emptyKeys;
1872
+ }
1873
+ }
1874
+ }
1875
+ }
1876
+ }
1877
+ if (!isSameKey(selectedRows, selected?.row) || !isSameKey(selectedColumns, selected?.column)) {
1878
+ onSelectionChange({ value: { row: selectedRows, column: selectedColumns }, target: targetElement }, false);
1879
+ }
1880
+ }
1881
+ /**
1882
+ * Helper function to calculate and apply a new selection state corresponding to the range provided
1883
+ */
1884
+ function _applyRangeSelection(rootElement, tableId, columnsArray, targetElement, startIndex, endIndex, isRowGesture, onSelectionChange, isDropDownSelection, selectionMode, selected, previousEndIndex) {
1885
+ const emptyKeys = { all: false, keys: new Set() };
1886
+ let selectedRows = selected?.row != null ? selected.row : emptyKeys;
1887
+ let selectedColumns = selected?.column != null ? selected.column : emptyKeys;
1888
+ if (isRowGesture) {
1889
+ selectedColumns = emptyKeys;
1890
+ if (selectionMode?.row === 'multiple' || selectionMode?.row === 'multipleToggle') {
1891
+ const isToggleSelectionMode = isDropDownSelection || selectionMode.row === 'multipleToggle';
1892
+ selectedRows = isToggleSelectionMode ? selectedRows : emptyKeys;
1893
+ // selected rows should be added in the order that they are selected
1894
+ if (startIndex <= endIndex) {
1895
+ for (let i = startIndex; i <= endIndex; i++) {
1896
+ const key = getRowKeyForRowIndex(rootElement, tableId, i);
1897
+ selectedRows = addKey(selectedRows, key);
1898
+ }
1899
+ // toggle selection gesture is additive except for rows added from previous gesture
1900
+ if (isToggleSelectionMode && previousEndIndex != null) {
1901
+ if (previousEndIndex > endIndex) {
1902
+ for (let i = previousEndIndex; i > endIndex; i--) {
1903
+ const key = getRowKeyForRowIndex(rootElement, tableId, i);
1904
+ selectedRows = removeKey(selectedRows, key, false);
1905
+ }
1906
+ }
1907
+ else if (previousEndIndex < startIndex) {
1908
+ for (let i = previousEndIndex; i < startIndex; i++) {
1909
+ const key = getRowKeyForRowIndex(rootElement, tableId, i);
1910
+ selectedRows = removeKey(selectedRows, key, false);
1911
+ }
1912
+ }
1913
+ }
1914
+ }
1915
+ else {
1916
+ for (let i = startIndex; i >= endIndex; i--) {
1917
+ const key = getRowKeyForRowIndex(rootElement, tableId, i);
1918
+ selectedRows = addKey(selectedRows, key);
1919
+ }
1920
+ // toggle selection gesture is additive except for rows added from previous gesture
1921
+ if (isToggleSelectionMode && previousEndIndex != null) {
1922
+ if (previousEndIndex < endIndex) {
1923
+ for (let i = previousEndIndex; i < endIndex; i++) {
1924
+ const key = getRowKeyForRowIndex(rootElement, tableId, i);
1925
+ selectedRows = removeKey(selectedRows, key, false);
1926
+ }
1927
+ }
1928
+ else if (previousEndIndex > startIndex) {
1929
+ for (let i = previousEndIndex; i > startIndex; i--) {
1930
+ const key = getRowKeyForRowIndex(rootElement, tableId, i);
1931
+ selectedRows = removeKey(selectedRows, key, false);
1932
+ }
1933
+ }
1934
+ }
1935
+ }
1936
+ }
1937
+ }
1938
+ else {
1939
+ selectedRows = emptyKeys;
1940
+ if (selectionMode?.column === 'multiple') {
1941
+ selectedColumns = emptyKeys;
1942
+ // selected columns should be added in the order that they are selected
1943
+ if (startIndex <= endIndex) {
1944
+ for (let i = startIndex; i <= endIndex; i++) {
1945
+ const column = columnsArray[i];
1946
+ if (column.value.selectable !== 'disabled') {
1947
+ selectedColumns = addKey(selectedColumns, column.key);
1948
+ }
1949
+ }
1950
+ }
1951
+ else {
1952
+ for (let i = startIndex; i >= endIndex; i--) {
1953
+ const column = columnsArray[i];
1954
+ if (column.value.selectable !== 'disabled') {
1955
+ selectedColumns = addKey(selectedColumns, column.key);
1956
+ }
1957
+ }
1958
+ }
1959
+ }
1960
+ }
1961
+ if (!isSameKey(selectedRows, selected?.row) || !isSameKey(selectedColumns, selected?.column)) {
1962
+ onSelectionChange({ value: { row: selectedRows, column: selectedColumns }, target: targetElement }, true);
1963
+ }
1964
+ }
1965
+ /**
1966
+ * Determines whether a potential range selection gesture is valid based on the given target
1967
+ */
1968
+ function isRangeSelectionGesture(rootElement, tableId, columnsArray, targetElement, activeCell, selectionMode) {
1969
+ const targetCell = logicalCellExtractor(targetElement, tableId, columnsArray);
1970
+ if ((((selectionMode?.row === 'multiple' || selectionMode?.row === 'multipleToggle') &&
1971
+ activeCell.type === 'data') ||
1972
+ (selectionMode?.column === 'multiple' &&
1973
+ (activeCell.type === 'header' || activeCell.type === 'footer'))) &&
1974
+ targetCell?.type === activeCell.type) {
1975
+ const activeCellElement = getElementFromCell(rootElement, tableId, activeCell);
1976
+ const targetCellElement = getElementFromCell(rootElement, tableId, targetCell);
1977
+ if (activeCellElement != null && targetCellElement != null) {
1978
+ const isRow = targetCell.type === 'data';
1979
+ if (isRow) {
1980
+ return (getRowIndexForRowElement(rootElement, tableId, activeCellElement.parentElement) != null &&
1981
+ getRowIndexForRowElement(rootElement, tableId, targetCellElement.parentElement) != null);
1982
+ }
1983
+ else if (targetCell.type === 'header' || targetCell.type === 'footer') {
1984
+ const isHeader = targetCell.type === 'header';
1985
+ return (getColumnIndexForHeaderFooterElement(rootElement, tableId, activeCellElement, isHeader) !=
1986
+ null &&
1987
+ getColumnIndexForHeaderFooterElement(rootElement, tableId, targetCellElement, isHeader) !=
1988
+ null);
1989
+ }
1990
+ }
1991
+ }
1992
+ return false;
1993
+ }
1994
+ /**
1995
+ * Helper function to handle a range selection gesture (shift+click)
1996
+ */
1997
+ function handleRangeSelectionGesture(rootElement, tableId, columnsArray, targetElement, activeCell, onActiveCellChanged, selectionExtensionElementRef, onSelectionChange, isDropDownSelection, selectionMode, selected) {
1998
+ const targetCell = logicalCellExtractor(targetElement, tableId, columnsArray);
1999
+ if (targetCell != null) {
2000
+ const activeCellElement = getElementFromCell(rootElement, tableId, activeCell);
2001
+ const targetCellElement = getElementFromCell(rootElement, tableId, targetCell);
2002
+ if (activeCellElement != null && targetCellElement != null) {
2003
+ if ((((selectionMode?.row === 'multiple' || selectionMode?.row === 'multipleToggle') &&
2004
+ targetCell.type === 'data') ||
2005
+ (selectionMode?.column === 'multiple' &&
2006
+ (targetCell.type === 'header' || targetCell.type === 'footer'))) &&
2007
+ targetCell.type === activeCell.type) {
2008
+ let startIndex;
2009
+ let endIndex;
2010
+ let previousEndIndex;
2011
+ let endElement;
2012
+ const isToggleSelectionMode = isDropDownSelection || selectionMode.row === 'multipleToggle';
2013
+ const isRow = targetCell.type === 'data';
2014
+ if (isRow) {
2015
+ endElement = targetCellElement.parentElement;
2016
+ const startElement = isToggleSelectionMode && selectionExtensionElementRef.current != null
2017
+ ? selectionExtensionElementRef.current
2018
+ : activeCellElement.parentElement;
2019
+ startIndex = getRowIndexForRowElement(rootElement, tableId, startElement);
2020
+ endIndex = getRowIndexForRowElement(rootElement, tableId, endElement);
2021
+ const previousElement = isToggleSelectionMode
2022
+ ? activeCellElement.parentElement
2023
+ : selectionExtensionElementRef.current;
2024
+ if (previousElement != null) {
2025
+ previousEndIndex = getRowIndexForRowElement(rootElement, tableId, previousElement);
2026
+ }
2027
+ }
2028
+ else if (targetCell.type === 'header' || targetCell.type === 'footer') {
2029
+ const isHeader = targetCell.type === 'header';
2030
+ endElement = targetCellElement;
2031
+ startIndex = getColumnIndexForHeaderFooterElement(rootElement, tableId, activeCellElement, isHeader);
2032
+ endIndex = getColumnIndexForHeaderFooterElement(rootElement, tableId, targetCellElement, isHeader);
2033
+ }
2034
+ if (startIndex != null && endIndex != null) {
2035
+ if (!isRow || !isToggleSelectionMode) {
2036
+ selectionExtensionElementRef.current = endElement;
2037
+ }
2038
+ else {
2039
+ if (selectionExtensionElementRef.current == null) {
2040
+ selectionExtensionElementRef.current = activeCellElement.parentElement;
2041
+ }
2042
+ onActiveCellChanged({ value: targetCell }, false, true);
2043
+ targetCellElement.focus({ preventScroll: true });
2044
+ }
2045
+ _applyRangeSelection(rootElement, tableId, columnsArray, targetElement, startIndex, endIndex, isRow, onSelectionChange, isDropDownSelection, selectionMode, selected, previousEndIndex);
2046
+ return true;
2047
+ }
2048
+ }
2049
+ }
2050
+ }
2051
+ return false;
2052
+ }
2053
+ /**
2054
+ * Helper function to handle a selection extension gesture (shift+arrow key)
2055
+ */
2056
+ function handleExtendSelectionGesture(rootElement, tableId, columnsArray, targetElement, isPrevious, activeCell, selectionExtensionElementRef, onSelectionChange, isDropDownSelection, updateDeferredScrollDetail, selectionMode, selected) {
2057
+ const activeCellElement = getElementFromCell(rootElement, tableId, activeCell);
2058
+ if (activeCellElement != null) {
2059
+ let startIndex;
2060
+ let startElement;
2061
+ const isToggleSelectionMode = isDropDownSelection || selectionMode?.row === 'multipleToggle';
2062
+ const isRow = activeCell.type === 'data';
2063
+ const isHeader = activeCell.type === 'header';
2064
+ if (isRow) {
2065
+ startElement =
2066
+ isToggleSelectionMode && selectionExtensionElementRef.current != null
2067
+ ? selectionExtensionElementRef.current
2068
+ : activeCellElement.parentElement;
2069
+ startIndex = getRowIndexForRowElement(rootElement, tableId, startElement);
2070
+ }
2071
+ else {
2072
+ startElement = activeCellElement;
2073
+ startIndex = getColumnIndexForHeaderFooterElement(rootElement, tableId, startElement, isHeader);
2074
+ }
2075
+ if (startIndex != null) {
2076
+ let endIndex;
2077
+ let previousEndIndex;
2078
+ let extendedElement;
2079
+ const cursorElement = isToggleSelectionMode && isRow
2080
+ ? activeCellElement.parentElement
2081
+ : selectionExtensionElementRef.current;
2082
+ if (cursorElement != null) {
2083
+ previousEndIndex = isRow
2084
+ ? getRowIndexForRowElement(rootElement, tableId, cursorElement)
2085
+ : getColumnIndexForHeaderFooterElement(rootElement, tableId, cursorElement, isHeader);
2086
+ extendedElement = isPrevious
2087
+ ? cursorElement.previousElementSibling
2088
+ : cursorElement.nextElementSibling;
2089
+ if (extendedElement != null && (!isRow || (isRow && getRowKey(extendedElement) != null))) {
2090
+ if (!isToggleSelectionMode || !isRow) {
2091
+ selectionExtensionElementRef.current = extendedElement;
2092
+ }
2093
+ else if (selectionExtensionElementRef.current == null) {
2094
+ selectionExtensionElementRef.current = activeCellElement.parentElement;
2095
+ }
2096
+ endIndex = isRow
2097
+ ? getRowIndexForRowElement(rootElement, tableId, extendedElement)
2098
+ : getColumnIndexForHeaderFooterElement(rootElement, tableId, extendedElement, isHeader);
2099
+ }
2100
+ else {
2101
+ endIndex = isRow
2102
+ ? getRowIndexForRowElement(rootElement, tableId, cursorElement)
2103
+ : getColumnIndexForHeaderFooterElement(rootElement, tableId, cursorElement, isHeader);
2104
+ }
2105
+ }
2106
+ else {
2107
+ extendedElement = isPrevious
2108
+ ? startElement.previousElementSibling
2109
+ : startElement.nextElementSibling;
2110
+ if (extendedElement != null && (!isRow || (isRow && getRowKey(extendedElement) != null))) {
2111
+ selectionExtensionElementRef.current = extendedElement;
2112
+ endIndex = isRow
2113
+ ? getRowIndexForRowElement(rootElement, tableId, extendedElement)
2114
+ : getColumnIndexForHeaderFooterElement(rootElement, tableId, extendedElement, isHeader);
2115
+ }
2116
+ else {
2117
+ endIndex = startIndex;
2118
+ }
2119
+ }
2120
+ if (endIndex != null) {
2121
+ _applyRangeSelection(rootElement, tableId, columnsArray, targetElement, startIndex, endIndex, isRow, onSelectionChange, isDropDownSelection, selectionMode, selected, previousEndIndex);
2122
+ }
2123
+ // scroll 'extensionElement' into view if focus is not shifted
2124
+ if (!isRow || !isToggleSelectionMode) {
2125
+ const extensionElement = selectionExtensionElementRef.current != null
2126
+ ? selectionExtensionElementRef.current
2127
+ : activeCellElement;
2128
+ let extensionCell;
2129
+ if (isRow) {
2130
+ const rowKey = keyExtractor(extensionElement, `[${TABLE_ROW_SELECTOR}='${tableId}']`);
2131
+ if (rowKey != null) {
2132
+ extensionCell = {
2133
+ type: activeCell.type,
2134
+ rowKey: rowKey,
2135
+ columnKey: activeCell.columnKey
2136
+ };
2137
+ }
2138
+ }
2139
+ else {
2140
+ extensionCell = logicalCellExtractor(extensionElement, tableId, columnsArray);
2141
+ }
2142
+ if (extensionCell != null) {
2143
+ updateDeferredScrollDetail({
2144
+ cell: extensionCell,
2145
+ locationX: 'inView',
2146
+ locationY: 'inView'
2147
+ });
2148
+ }
2149
+ }
2150
+ }
2151
+ }
2152
+ }
2153
+
2154
+ /**
2155
+ * Hook that manages keyboard interactions on the Preact Table
2156
+ */
2157
+ function useKeyboardHandling({ rootRef, viewportInfo, tableId, tableData, isRtl, isTabbableMode, columnsArray, sizingInfoRef, selectionExtensionElementRef, activeCell, onActiveCellChanged, isDropDownSelection, selectionMode, selected, onTableSelectionChange, activeStyleColumnInfo, setActiveStyleColumnInfo, onRowAction, sortCriterion, onSortCriterionChange, hideTooltip, updateDeferredScrollDetail }) {
2158
+ // state for the key that a space or enter keydown occurrs on for matching keyup handling
2159
+ const triggerDownKeyRef = useRef();
2160
+ // Keydown handler for the outer Table. This handles all internal
2161
+ // keyboard navigation for the Table.
2162
+ const _keyDownHandler = useCallback((event) => {
2163
+ const rootElement = rootRef.current;
2164
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
2165
+ if (rootElement != null && scrollerElement != null) {
2166
+ const keyHandlers = {
2167
+ ' ': function () {
2168
+ if (activeCell != null) {
2169
+ triggerDownKeyRef.current = activeCell.rowKey;
2170
+ if (!isTabbableMode) {
2171
+ handleActiveColumnHeaderFooterGesture(tableId, event, setActiveStyleColumnInfo, activeStyleColumnInfo, activeCell);
2172
+ // prevent default action on space to avoid scrolling during a selection
2173
+ event.preventDefault();
2174
+ }
2175
+ if (onRowAction != null &&
2176
+ getRowActionGestureContext(tableId, tableData, event.target, TABLE_ROW_SELECTOR, getActionContext, activeCell) != null) {
2177
+ event.stopPropagation();
2178
+ }
2179
+ }
2180
+ },
2181
+ Enter: function () {
2182
+ if (activeCell != null) {
2183
+ triggerDownKeyRef.current = activeCell.rowKey;
2184
+ if (activeCell.type === 'data') {
2185
+ if (isDropDownSelection && !isTabbableMode) {
2186
+ event.preventDefault();
2187
+ }
2188
+ if (onRowAction != null &&
2189
+ getRowActionGestureContext(tableId, tableData, event.target, TABLE_ROW_SELECTOR, getActionContext, activeCell) != null) {
2190
+ event.stopPropagation();
2191
+ }
2192
+ }
2193
+ else if (activeCell.type === 'header' &&
2194
+ !isTabbableMode &&
2195
+ onSortCriterionChange != null &&
2196
+ isSortActionGesture(columnsArray, activeCell.columnKey)) {
2197
+ event.stopPropagation();
2198
+ }
2199
+ }
2200
+ },
2201
+ ArrowUp: function () {
2202
+ if (activeCell != null &&
2203
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2204
+ let isExtendSelectionGesture = false;
2205
+ if (!isTabbableMode &&
2206
+ activeCell.type === 'data' &&
2207
+ event.shiftKey &&
2208
+ onTableSelectionChange != null &&
2209
+ (selectionMode?.row === 'multiple' || selectionMode?.row === 'multipleToggle')) {
2210
+ handleExtendSelectionGesture(rootElement, tableId, columnsArray, rootElement, true, activeCell, selectionExtensionElementRef, onTableSelectionChange, isDropDownSelection, updateDeferredScrollDetail, selectionMode, selected);
2211
+ isExtendSelectionGesture = true;
2212
+ }
2213
+ if (!isExtendSelectionGesture ||
2214
+ isDropDownSelection ||
2215
+ selectionMode?.row === 'multipleToggle') {
2216
+ handleAdjacentRowGesture(rootElement, tableId, columnsArray, activeCell, onActiveCellChanged, true, isExtendSelectionGesture, hideTooltip, updateDeferredScrollDetail);
2217
+ }
2218
+ event.preventDefault();
2219
+ }
2220
+ },
2221
+ ArrowDown: function () {
2222
+ if (activeCell != null &&
2223
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2224
+ let isExtendSelectionGesture = false;
2225
+ if (!isTabbableMode &&
2226
+ activeCell.type === 'data' &&
2227
+ event.shiftKey &&
2228
+ onTableSelectionChange != null &&
2229
+ (selectionMode?.row === 'multiple' || selectionMode?.row === 'multipleToggle')) {
2230
+ handleExtendSelectionGesture(rootElement, tableId, columnsArray, rootElement, false, activeCell, selectionExtensionElementRef, onTableSelectionChange, isDropDownSelection, updateDeferredScrollDetail, selectionMode, selected);
2231
+ isExtendSelectionGesture = true;
2232
+ }
2233
+ if (!isExtendSelectionGesture ||
2234
+ isDropDownSelection ||
2235
+ selectionMode?.row === 'multipleToggle') {
2236
+ handleAdjacentRowGesture(rootElement, tableId, columnsArray, activeCell, onActiveCellChanged, false, isExtendSelectionGesture, hideTooltip, updateDeferredScrollDetail);
2237
+ }
2238
+ event.preventDefault();
2239
+ }
2240
+ },
2241
+ ArrowLeft: function () {
2242
+ if (activeCell != null &&
2243
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2244
+ if (!isTabbableMode &&
2245
+ (activeCell.type === 'header' || activeCell.type === 'footer') &&
2246
+ event.shiftKey &&
2247
+ onTableSelectionChange != null &&
2248
+ selectionMode?.column === 'multiple') {
2249
+ handleExtendSelectionGesture(rootElement, tableId, columnsArray, rootElement, true, activeCell, selectionExtensionElementRef, onTableSelectionChange, isDropDownSelection, updateDeferredScrollDetail, selectionMode, selected);
2250
+ }
2251
+ else {
2252
+ handleAdjacentColumnGesture(rootElement, tableId, columnsArray, activeCell, onActiveCellChanged, !isRtl, hideTooltip, updateDeferredScrollDetail);
2253
+ }
2254
+ event.preventDefault();
2255
+ }
2256
+ },
2257
+ ArrowRight: function () {
2258
+ if (activeCell != null &&
2259
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2260
+ if (!isTabbableMode &&
2261
+ (activeCell.type === 'header' || activeCell.type === 'footer') &&
2262
+ event.shiftKey &&
2263
+ onTableSelectionChange != null &&
2264
+ selectionMode?.column === 'multiple') {
2265
+ handleExtendSelectionGesture(rootElement, tableId, columnsArray, rootElement, false, activeCell, selectionExtensionElementRef, onTableSelectionChange, isDropDownSelection, updateDeferredScrollDetail, selectionMode, selected);
2266
+ }
2267
+ else {
2268
+ handleAdjacentColumnGesture(rootElement, tableId, columnsArray, activeCell, onActiveCellChanged, isRtl, hideTooltip, updateDeferredScrollDetail);
2269
+ }
2270
+ event.preventDefault();
2271
+ }
2272
+ },
2273
+ PageUp: function () {
2274
+ if (activeCell != null &&
2275
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2276
+ handlePageRowGesture(rootElement, scrollerElement, viewportInfo, tableId, sizingInfoRef.current, activeCell, onActiveCellChanged, true, hideTooltip, updateDeferredScrollDetail);
2277
+ event.preventDefault();
2278
+ }
2279
+ },
2280
+ PageDown: function () {
2281
+ if (activeCell != null &&
2282
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2283
+ handlePageRowGesture(rootElement, scrollerElement, viewportInfo, tableId, sizingInfoRef.current, activeCell, onActiveCellChanged, false, hideTooltip, updateDeferredScrollDetail);
2284
+ event.preventDefault();
2285
+ }
2286
+ },
2287
+ Home: function () {
2288
+ if (activeCell != null &&
2289
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2290
+ handleJumpColumnGesture(rootElement, tableId, columnsArray, activeCell, onActiveCellChanged, true, isLogicalCtrl(event), hideTooltip, updateDeferredScrollDetail);
2291
+ event.preventDefault();
2292
+ }
2293
+ },
2294
+ End: function () {
2295
+ if (activeCell != null &&
2296
+ (!isTabbableMode || isAutoFocusCell(rootElement, tableId, activeCell))) {
2297
+ handleJumpColumnGesture(rootElement, tableId, columnsArray, activeCell, onActiveCellChanged, false, isLogicalCtrl(event), hideTooltip, updateDeferredScrollDetail);
2298
+ event.preventDefault();
2299
+ }
2300
+ }
2301
+ };
2302
+ if (Object.keys(keyHandlers).includes(event.key)) {
2303
+ keyHandlers[event.key]();
2304
+ }
2305
+ }
2306
+ }, [
2307
+ rootRef,
2308
+ viewportInfo,
2309
+ tableId,
2310
+ tableData,
2311
+ isRtl,
2312
+ isTabbableMode,
2313
+ columnsArray,
2314
+ sizingInfoRef,
2315
+ selectionExtensionElementRef,
2316
+ activeCell,
2317
+ onActiveCellChanged,
2318
+ isDropDownSelection,
2319
+ selectionMode,
2320
+ selected,
2321
+ onTableSelectionChange,
2322
+ activeStyleColumnInfo,
2323
+ setActiveStyleColumnInfo,
2324
+ onRowAction,
2325
+ onSortCriterionChange,
2326
+ hideTooltip,
2327
+ updateDeferredScrollDetail
2328
+ ]);
2329
+ // Keyup handler for the outer Table.
2330
+ const _keyUpHandler = useCallback((event) => {
2331
+ const rootElement = rootRef.current;
2332
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
2333
+ if (rootElement != null && scrollerElement != null) {
2334
+ const keyHandlers = {
2335
+ ' ': function () {
2336
+ if (activeCell != null) {
2337
+ handleEndInteractionColumnHeaderFooterGesture(setActiveStyleColumnInfo, activeStyleColumnInfo);
2338
+ if (triggerDownKeyRef.current === activeCell.rowKey) {
2339
+ if (!isTabbableMode) {
2340
+ if (onTableSelectionChange != null) {
2341
+ handleSelectionGesture(rootElement, tableId, columnsArray, getElementFromCell(rootElement, tableId, activeCell), true, onTableSelectionChange, isDropDownSelection, selectionMode, selected);
2342
+ }
2343
+ }
2344
+ if (onRowAction != null &&
2345
+ handleRowActionGesture(tableId, tableData, onRowAction, event.target, TABLE_ROW_SELECTOR, getActionContext, activeCell)) {
2346
+ event.stopPropagation();
2347
+ }
2348
+ }
2349
+ triggerDownKeyRef.current = undefined;
2350
+ }
2351
+ },
2352
+ Enter: function () {
2353
+ if (activeCell != null && triggerDownKeyRef.current === activeCell.rowKey) {
2354
+ if (activeCell.type === 'data') {
2355
+ if (isDropDownSelection && !isTabbableMode) {
2356
+ if (onTableSelectionChange != null) {
2357
+ handleSelectionGesture(rootElement, tableId, columnsArray, getElementFromCell(rootElement, tableId, activeCell), true, onTableSelectionChange, isDropDownSelection, selectionMode, selected);
2358
+ }
2359
+ }
2360
+ if (onRowAction != null &&
2361
+ handleRowActionGesture(tableId, tableData, onRowAction, event.target, TABLE_ROW_SELECTOR, getActionContext, activeCell)) {
2362
+ event.stopPropagation();
2363
+ }
2364
+ }
2365
+ else if (activeCell.type === 'header' &&
2366
+ !isTabbableMode &&
2367
+ onSortCriterionChange != null &&
2368
+ handleSortActionGesture(columnsArray, activeCell.columnKey, onSortCriterionChange, sortCriterion)) {
2369
+ event.stopPropagation();
2370
+ }
2371
+ }
2372
+ triggerDownKeyRef.current = undefined;
2373
+ }
2374
+ };
2375
+ if (Object.keys(keyHandlers).includes(event.key)) {
2376
+ keyHandlers[event.key]();
2377
+ }
2378
+ }
2379
+ }, [
2380
+ rootRef,
2381
+ viewportInfo,
2382
+ tableId,
2383
+ tableData,
2384
+ isTabbableMode,
2385
+ columnsArray,
2386
+ activeCell,
2387
+ activeStyleColumnInfo,
2388
+ setActiveStyleColumnInfo,
2389
+ isDropDownSelection,
2390
+ selectionMode,
2391
+ selected,
2392
+ onTableSelectionChange,
2393
+ onRowAction,
2394
+ sortCriterion,
2395
+ onSortCriterionChange
2396
+ ]);
2397
+ return { onKeyDown: _keyDownHandler, onKeyUp: _keyUpHandler };
2398
+ }
2399
+
2400
+ /**
2401
+ * Helper function to handle a hover over a resizable column region gesture.
2402
+ */
2403
+ function handleOverResizeRegionGesture(rootElement, tableId, event, columnsArray, resizeInfoRef, isRtl) {
2404
+ // handle hover feedback around potentially resizable columns
2405
+ _updateResizingState(rootElement, tableId, event, columnsArray, resizeInfoRef, isRtl);
2406
+ }
2407
+ /**
2408
+ * Helper function to handle a column resize start gesture (pointer down).
2409
+ */
2410
+ function handleColumnResizeStartGesture(rootElement, scrollerElement, tableId, event, columnsArray, appliedColumnWidths, resizeInfoRef, isRtl, hideTooltip, onColumnResizing) {
2411
+ if (resizeInfoRef.current.key == null) {
2412
+ _updateResizingState(rootElement, tableId, event, columnsArray, resizeInfoRef, isRtl);
2413
+ }
2414
+ if (resizeInfoRef.current.key != null) {
2415
+ const rect = scrollerElement.getBoundingClientRect();
2416
+ const pointerX = isRtl ? rect.right - event.clientX : event.clientX - rect.left;
2417
+ resizeInfoRef.current = {
2418
+ isResizing: true,
2419
+ isResizeHover: true,
2420
+ key: resizeInfoRef.current.key,
2421
+ startX: pointerX,
2422
+ delta: 0,
2423
+ ignoreClick: resizeInfoRef.current.ignoreClick
2424
+ };
2425
+ if (onColumnResizing != null) {
2426
+ onColumnResizing({
2427
+ key: resizeInfoRef.current.key,
2428
+ delta: 0,
2429
+ allColumnWidths: appliedColumnWidths.netColumnWidths,
2430
+ paddingWidth: appliedColumnWidths.totalBorderOffset
2431
+ });
2432
+ }
2433
+ hideTooltip(true);
2434
+ return true;
2435
+ }
2436
+ return false;
2437
+ }
2438
+ /**
2439
+ * Helper function to ensure the resizing state is updated based on the latest pointer event.
2440
+ */
2441
+ function _updateResizingState(rootElement, tableId, event, columnsArray, resizeInfoRef, isRtl) {
2442
+ const headerRowElement = getHeaderRowElement(rootElement, tableId);
2443
+ if (headerRowElement != null) {
2444
+ const headerElements = headerRowElement.querySelectorAll(`[${TABLE_HEADER_SELECTOR}='${tableId}']`);
2445
+ if (getElementContainsFunc(headerRowElement)(event.target)) {
2446
+ let isResizeHover = false;
2447
+ for (let i = 0; i < headerElements.length; i++) {
2448
+ const headerElement = headerElements[i];
2449
+ const cellRect = headerElement.getBoundingClientRect();
2450
+ const endEdge = isRtl ? cellRect.left : cellRect.right;
2451
+ if (Math.abs(endEdge - event.pageX) <= 8) {
2452
+ if (columnsArray[i].value.edgeResizable !== 'enabled') {
2453
+ break;
2454
+ }
2455
+ // resize operation on end side of header cell
2456
+ resizeInfoRef.current.key = columnsArray[i].key;
2457
+ headerRowElement.style.cursor = 'col-resize';
2458
+ isResizeHover = true;
2459
+ resizeInfoRef.current.isResizeHover = true;
2460
+ }
2461
+ }
2462
+ if (!isResizeHover) {
2463
+ headerRowElement.style.cursor = '';
2464
+ resizeInfoRef.current.key = undefined;
2465
+ resizeInfoRef.current.isResizeHover = false;
2466
+ }
2467
+ }
2468
+ else {
2469
+ if (headerRowElement != null) {
2470
+ headerRowElement.style.cursor = '';
2471
+ }
2472
+ resizeInfoRef.current.key = undefined;
2473
+ resizeInfoRef.current.isResizeHover = false;
2474
+ }
2475
+ }
2476
+ }
2477
+ /**
2478
+ * Helper function to handle a pointer move gesture during a column resize.
2479
+ */
2480
+ function handleColumnResizingGesture(scrollerElement, event, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResizing) {
2481
+ if (resizeInfoRef.current.isResizing) {
2482
+ const rect = scrollerElement.getBoundingClientRect();
2483
+ const currentX = isRtl ? rect.right - event.clientX : event.clientX - rect.left;
2484
+ resizeInfoRef.current.delta = currentX - resizeInfoRef.current.startX;
2485
+ // handle resize move operation
2486
+ if (onColumnResizing != null) {
2487
+ onColumnResizing({
2488
+ key: resizeInfoRef.current.key,
2489
+ delta: resizeInfoRef.current.delta,
2490
+ allColumnWidths: appliedColumnWidths.netColumnWidths,
2491
+ paddingWidth: appliedColumnWidths.totalBorderOffset
2492
+ });
2493
+ }
2494
+ }
2495
+ }
2496
+ /**
2497
+ * Helper function to handle a column resize end gesture (pointer up).
2498
+ */
2499
+ function handleColumnResizeEndGesture(scrollerElement, event, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResize) {
2500
+ if (resizeInfoRef.current.isResizing) {
2501
+ if (onColumnResize != null) {
2502
+ const rect = scrollerElement.getBoundingClientRect();
2503
+ const currentX = isRtl ? rect.right - event.clientX : event.clientX - rect.left;
2504
+ resizeInfoRef.current.delta = currentX - resizeInfoRef.current.startX;
2505
+ onColumnResize({
2506
+ key: resizeInfoRef.current.key,
2507
+ delta: resizeInfoRef.current.delta,
2508
+ allColumnWidths: appliedColumnWidths.netColumnWidths,
2509
+ paddingWidth: appliedColumnWidths.totalBorderOffset,
2510
+ gesture: 'pointer',
2511
+ type: 'delta'
2512
+ });
2513
+ }
2514
+ }
2515
+ resizeInfoRef.current = {
2516
+ isResizing: false,
2517
+ isResizeHover: resizeInfoRef.current.isResizeHover,
2518
+ ignoreClick: resizeInfoRef.current.ignoreClick
2519
+ };
2520
+ }
2521
+ /**
2522
+ * Helper function to handle the pointer leaving the entire Table when previously hovering
2523
+ * over a column resize region.
2524
+ */
2525
+ function handleLeaveResizingGesture(rootElement, tableId, resizeInfoRef) {
2526
+ if (!resizeInfoRef.current.isResizing) {
2527
+ const headerRowElement = getHeaderRowElement(rootElement, tableId);
2528
+ if (headerRowElement != null) {
2529
+ headerRowElement.style.cursor = '';
2530
+ }
2531
+ resizeInfoRef.current.isResizeHover = false;
2532
+ }
2533
+ }
2534
+ /**
2535
+ * Helper function to handle a pointer entering the Table when it was previously handling
2536
+ * a column resize gesture.
2537
+ */
2538
+ function handleEnterResizingGesture(scrollerElement, event, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResize) {
2539
+ // handle case where user was resizing, moved pointer out of the Table,
2540
+ // released the button, and has now entered the table once again
2541
+ if (resizeInfoRef.current.isResizing && event.buttons === 0) {
2542
+ handleColumnResizeEndGesture(scrollerElement, event, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResize);
2543
+ }
2544
+ }
2545
+
2546
+ /**
2547
+ * Hook that manages pointer interactions on the Preact Table
2548
+ */
2549
+ function usePointerHandling({ rootRef, viewportInfo, tableId, tableData, isRtl, columnsArray, appliedColumnWidths, resizeInfoRef, selectionExtensionElementRef, onColumnResizing, onColumnResize, activeCell, onActiveCellChanged, isDropDownSelection, selectionMode, selected, onTableSelectionChange, activeStyleColumnInfo, setActiveStyleColumnInfo, onRowAction, showTooltip, hideTooltip, tooltipId }) {
2550
+ // tracks whether the most recent 'pointerdown' event was due to a touch gesture
2551
+ const selectionTouchRef = useRef(false);
2552
+ // tracks the column key for any header or footer being hovered over
2553
+ const [hoverStyleColumnInfo, setHoverStyleColumnInfo] = useState();
2554
+ // tracks the current 'pointer over' element for comparison during 'click' event handling to
2555
+ // prevent screen readers from triggering undesired selection gestures from simulated events
2556
+ const pointerInfoRef = useRef();
2557
+ // Pointer move handler for the outer Table.
2558
+ const _pointerMoveHandler = useCallback((event) => {
2559
+ const rootElement = rootRef.current;
2560
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
2561
+ if (rootElement != null) {
2562
+ pointerInfoRef.current = { target: event.target, x: event.clientX, y: event.clientY };
2563
+ handleMoveTooltipGesture(tableId, columnsArray, event, showTooltip, hideTooltip, tooltipId);
2564
+ if (onColumnResizing != null) {
2565
+ if (!resizeInfoRef.current.isResizing) {
2566
+ handleOverResizeRegionGesture(rootElement, tableId, event, columnsArray, resizeInfoRef, isRtl);
2567
+ }
2568
+ else if (scrollerElement != null && appliedColumnWidths != null) {
2569
+ handleColumnResizingGesture(scrollerElement, event, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResizing);
2570
+ }
2571
+ }
2572
+ }
2573
+ }, [
2574
+ rootRef,
2575
+ viewportInfo,
2576
+ tableId,
2577
+ columnsArray,
2578
+ appliedColumnWidths,
2579
+ resizeInfoRef,
2580
+ isRtl,
2581
+ onColumnResizing,
2582
+ showTooltip,
2583
+ hideTooltip,
2584
+ tooltipId
2585
+ ]);
2586
+ // Pointer over handler for the outer Table.
2587
+ const _pointerOverHandler = useCallback((event) => {
2588
+ const rootElement = rootRef.current;
2589
+ if (rootElement != null) {
2590
+ pointerInfoRef.current = { target: event.target, x: event.clientX, y: event.clientY };
2591
+ handleOverColumnHeaderFooterGesture(tableId, event, setHoverStyleColumnInfo, hoverStyleColumnInfo);
2592
+ }
2593
+ }, [rootRef, tableId, hoverStyleColumnInfo]);
2594
+ // Pointer down handler for the outer Table. It ensures the area targeted is 'current'.
2595
+ // NOTE - This event handling is triggered prior to 'onFocus' handling and ensures the
2596
+ // 'pending current' area is set when an initial pointer interaction focuses the Table.
2597
+ const _pointerDownHandler = useCallback((event) => {
2598
+ handleActiveColumnHeaderFooterGesture(tableId, event, setActiveStyleColumnInfo, activeStyleColumnInfo);
2599
+ const rootElement = rootRef.current;
2600
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
2601
+ if (rootElement != null) {
2602
+ selectionTouchRef.current = event.pointerType === 'touch';
2603
+ const targetElement = event.target;
2604
+ if (onTableSelectionChange != null &&
2605
+ activeCell != null &&
2606
+ event.shiftKey &&
2607
+ isRangeSelectionGesture(rootElement, tableId, columnsArray, targetElement, activeCell, selectionMode)) {
2608
+ // prevent focus change on selection extension gesture
2609
+ if (!getIsSelectionPending()) {
2610
+ event.preventDefault();
2611
+ }
2612
+ }
2613
+ else if (scrollerElement != null &&
2614
+ appliedColumnWidths != null &&
2615
+ handleColumnResizeStartGesture(rootElement, scrollerElement, tableId, event, columnsArray, appliedColumnWidths, resizeInfoRef, isRtl, hideTooltip, onColumnResizing)) {
2616
+ // prevent focus change on column resize gesture
2617
+ event.preventDefault();
2618
+ resizeInfoRef.current.ignoreClick = true;
2619
+ }
2620
+ else if (logicalCellExtractor(targetElement, tableId, columnsArray) == null) {
2621
+ // prevent focus shift when interacting with 'non-focusable' regions (ie - scrollbar)
2622
+ event.preventDefault();
2623
+ }
2624
+ else {
2625
+ // in firefox, ctrl/cmd + click triggers browser selection of <tr> elements, which
2626
+ // conflicts with our multiple row selection gesture. to prevent this, schedule a
2627
+ // macro-task to remove any node-based selection to ensure there is no 'pending'
2628
+ // browser selection found during eventual click event handling
2629
+ if (getClientHints().browser === 'firefox' && isLogicalCtrl(event)) {
2630
+ setTimeout(() => {
2631
+ clearElementSelection();
2632
+ }, 0);
2633
+ }
2634
+ }
2635
+ }
2636
+ }, [
2637
+ rootRef,
2638
+ viewportInfo,
2639
+ tableId,
2640
+ columnsArray,
2641
+ appliedColumnWidths,
2642
+ resizeInfoRef,
2643
+ activeStyleColumnInfo,
2644
+ setActiveStyleColumnInfo,
2645
+ isRtl,
2646
+ hideTooltip,
2647
+ activeCell,
2648
+ selectionMode,
2649
+ onTableSelectionChange,
2650
+ onColumnResizing
2651
+ ]);
2652
+ // Pointer up handler for the outer Table.
2653
+ const _pointerUpHandler = useCallback((event) => {
2654
+ handleEndInteractionColumnHeaderFooterGesture(setActiveStyleColumnInfo, activeStyleColumnInfo);
2655
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
2656
+ if (scrollerElement != null && appliedColumnWidths != null) {
2657
+ handleColumnResizeEndGesture(scrollerElement, event, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResize);
2658
+ }
2659
+ }, [
2660
+ viewportInfo,
2661
+ appliedColumnWidths,
2662
+ resizeInfoRef,
2663
+ activeStyleColumnInfo,
2664
+ setActiveStyleColumnInfo,
2665
+ isRtl,
2666
+ onColumnResize
2667
+ ]);
2668
+ // Pointer leave handler for the outer Table.
2669
+ const _pointerLeaveHandler = useCallback((event) => {
2670
+ handleEndInteractionColumnHeaderFooterGesture(setHoverStyleColumnInfo, hoverStyleColumnInfo);
2671
+ handleEndInteractionColumnHeaderFooterGesture(setActiveStyleColumnInfo, activeStyleColumnInfo);
2672
+ const rootElement = rootRef.current;
2673
+ if (rootElement != null) {
2674
+ handleLeaveResizingGesture(rootElement, tableId, resizeInfoRef);
2675
+ handleLeaveTableTooltipGesture(rootElement, event, hideTooltip, tooltipId);
2676
+ }
2677
+ pointerInfoRef.current = undefined;
2678
+ }, [
2679
+ rootRef,
2680
+ tableId,
2681
+ resizeInfoRef,
2682
+ activeStyleColumnInfo,
2683
+ setActiveStyleColumnInfo,
2684
+ hoverStyleColumnInfo,
2685
+ hideTooltip,
2686
+ tooltipId
2687
+ ]);
2688
+ // Pointer enter handler for the outer Table.
2689
+ const _pointerEnterHandler = useCallback((event) => {
2690
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
2691
+ if (scrollerElement != null && appliedColumnWidths != null) {
2692
+ handleEnterResizingGesture(scrollerElement, event, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResize);
2693
+ }
2694
+ }, [viewportInfo, appliedColumnWidths, resizeInfoRef, isRtl, onColumnResize]);
2695
+ // Click handler for the outer Table. It ensures the Table's selection state is
2696
+ // updated to reflect the area targeted, and any action events are fired correctly.
2697
+ const _clickHandler = useCallback((event) => {
2698
+ const rootElement = rootRef.current;
2699
+ if (rootElement != null) {
2700
+ // only handle click events that match the latest mouse over/move info to prevent screen readers
2701
+ // from triggering undesired selections due to simulated click events when transferring focus
2702
+ if (selectionTouchRef.current ||
2703
+ (pointerInfoRef.current != null &&
2704
+ pointerInfoRef.current.target === event.target &&
2705
+ Math.abs(pointerInfoRef.current.x - event.clientX) <= 1 &&
2706
+ Math.abs(pointerInfoRef.current.y - event.clientY) <= 1)) {
2707
+ let isSelectionExtension = false;
2708
+ const target = event.target;
2709
+ if (onTableSelectionChange != null &&
2710
+ !resizeInfoRef.current.ignoreClick &&
2711
+ !getIsSelectionPending()) {
2712
+ if (activeCell != null && event.shiftKey) {
2713
+ isSelectionExtension = handleRangeSelectionGesture(rootElement, tableId, columnsArray, target, activeCell, onActiveCellChanged, selectionExtensionElementRef, onTableSelectionChange, isDropDownSelection, selectionMode, selected);
2714
+ }
2715
+ if (!isSelectionExtension) {
2716
+ handleSelectionGesture(rootElement, tableId, columnsArray, target, isLogicalCtrl(event) || selectionTouchRef.current, onTableSelectionChange, isDropDownSelection, selectionMode, selected);
2717
+ }
2718
+ }
2719
+ if (onRowAction != null &&
2720
+ !getIsSelectionPending() &&
2721
+ handleRowActionGesture(tableId, tableData, onRowAction, target, TABLE_ROW_SELECTOR, getActionContext)) {
2722
+ event.stopPropagation();
2723
+ }
2724
+ }
2725
+ }
2726
+ resizeInfoRef.current.ignoreClick = false;
2727
+ }, [
2728
+ rootRef,
2729
+ tableId,
2730
+ columnsArray,
2731
+ tableData,
2732
+ resizeInfoRef,
2733
+ selectionExtensionElementRef,
2734
+ activeCell,
2735
+ onActiveCellChanged,
2736
+ isDropDownSelection,
2737
+ selectionMode,
2738
+ selected,
2739
+ onTableSelectionChange,
2740
+ onRowAction
2741
+ ]);
2742
+ return {
2743
+ pointerHandlingProps: {
2744
+ onPointerOver: _pointerOverHandler,
2745
+ onPointerMove: _pointerMoveHandler,
2746
+ onPointerDown: _pointerDownHandler,
2747
+ onPointerUp: _pointerUpHandler,
2748
+ onPointerLeave: _pointerLeaveHandler,
2749
+ onPointerEnter: _pointerEnterHandler,
2750
+ onClick: _clickHandler
2751
+ },
2752
+ hoverStyleColumnInfo
2753
+ };
2754
+ }
2755
+
2756
+ const _defaultDisabledRowInteractionKeys = ['enter'];
2757
+ /**
2758
+ * Hook that manages interactions and events on the Preact Table
2759
+ */
2760
+ function useInteractionManager({ rootRef, viewportInfo, ref, tableId, tableData, hasMore, hasFooters, isRtl, columnsArray, stickyColumnInfo, appliedColumnWidths, isLayoutRequired, sizingInfoRef, overflowInfoRef, stickyEdgesState, setStickyEdgesState, cellHasRenderer, horizontalScrollPositionOverride, verticalScrollPositionOverride, onColumnResizing, onColumnResize, currentCellOverride, onPersistCurrentCell, selectionMode, selected, onSelectionChange, onRowAction, sortCriterion, onSortCriterionChange, isPendingLayout, isEmbedded, contextMenuConfig }) {
2761
+ // tracks the current column resize state
2762
+ const resizeInfoRef = useRef({
2763
+ isResizing: false,
2764
+ isResizeHover: false,
2765
+ ignoreClick: false
2766
+ });
2767
+ // tracks the column key for any header or footer being hovered over
2768
+ const [activeStyleColumnInfo, setActiveStyleColumnInfo] = useState();
2769
+ // handles default tooltip state management
2770
+ const { tooltipContent, tooltipId, tooltipAnchorRef, showTooltip, hideTooltip } = useTruncationTooltip({ rootRef, tableId, resizeInfoRef });
2771
+ // whether row selection is triggered on 'enter' keypresses in addition to 'spacebar'
2772
+ const disabledRowInteractionKeys = isEmbedded ? undefined : _defaultDisabledRowInteractionKeys;
2773
+ // tracks the current selection extension element (if any)
2774
+ const selectionExtensionElementRef = useRef();
2775
+ // intercept onSelectionChange calls to ensure local selectionExtensionElementRef is cleared
2776
+ const onTableSelectionChange = useMemo(() => {
2777
+ return onSelectionChange != null
2778
+ ? (detail, isExtendableSelection) => {
2779
+ if (!isExtendableSelection) {
2780
+ selectionExtensionElementRef.current = undefined;
2781
+ }
2782
+ onSelectionChange(detail);
2783
+ }
2784
+ : undefined;
2785
+ }, [onSelectionChange]);
2786
+ // setup focus tracking using the useFocusHandling hook
2787
+ const { focusHandlingProps, activeCell, onActiveCellChanged, currentActiveCell, currentCell, isShowFocusRing, isTabbableMode, onStartFocusTracking, onFocusStartEdge, onFocusEndEdge, updateDeferredScrollDetail } = useFocusHandling({
2788
+ rootRef,
2789
+ viewportInfo,
2790
+ tableId,
2791
+ tableData,
2792
+ hasMore,
2793
+ hasFooters,
2794
+ columnsArray,
2795
+ stickyColumnInfo,
2796
+ sizingInfoRef,
2797
+ overflowInfoRef,
2798
+ selectionExtensionElementRef,
2799
+ isRtl,
2800
+ cellSupportsTabbable: cellHasRenderer,
2801
+ appliedColumnWidths,
2802
+ currentCellOverride,
2803
+ onPersistCurrentCell,
2804
+ showTooltip,
2805
+ hideTooltip,
2806
+ isPendingLayout,
2807
+ isEmbedded,
2808
+ isDataLoaded: !hasMore || tableData.length > 0
2809
+ });
2810
+ const keyboardHandlingProps = useKeyboardHandling({
2811
+ rootRef,
2812
+ viewportInfo,
2813
+ tableId,
2814
+ tableData,
2815
+ isRtl,
2816
+ isTabbableMode,
2817
+ columnsArray,
2818
+ sizingInfoRef,
2819
+ selectionExtensionElementRef,
2820
+ activeCell,
2821
+ onActiveCellChanged,
2822
+ isDropDownSelection: isEmbedded,
2823
+ selectionMode,
2824
+ selected,
2825
+ onTableSelectionChange,
2826
+ activeStyleColumnInfo,
2827
+ setActiveStyleColumnInfo,
2828
+ onRowAction,
2829
+ sortCriterion,
2830
+ onSortCriterionChange,
2831
+ hideTooltip,
2832
+ updateDeferredScrollDetail
2833
+ });
2834
+ const { hoverStyleColumnInfo, pointerHandlingProps } = usePointerHandling({
2835
+ rootRef,
2836
+ viewportInfo,
2837
+ tableId,
2838
+ tableData,
2839
+ isRtl,
2840
+ columnsArray,
2841
+ appliedColumnWidths,
2842
+ resizeInfoRef,
2843
+ selectionExtensionElementRef,
2844
+ onColumnResizing,
2845
+ onColumnResize,
2846
+ activeCell,
2847
+ onActiveCellChanged,
2848
+ isDropDownSelection: isEmbedded,
2849
+ selectionMode,
2850
+ selected,
2851
+ onTableSelectionChange,
2852
+ activeStyleColumnInfo,
2853
+ setActiveStyleColumnInfo,
2854
+ onRowAction,
2855
+ showTooltip,
2856
+ hideTooltip,
2857
+ tooltipId
2858
+ });
2859
+ const scrollHandlingProps = useScrollHandling({
2860
+ rootRef,
2861
+ viewportInfo,
2862
+ tableId,
2863
+ isLayoutRequired,
2864
+ sizingInfoRef,
2865
+ overflowInfoRef,
2866
+ columnsArray,
2867
+ stickyColumnInfo,
2868
+ stickyEdgesState,
2869
+ setStickyEdgesState,
2870
+ fullColumnWidths: appliedColumnWidths?.fullColumnWidths,
2871
+ horizontalScrollPositionOverride,
2872
+ verticalScrollPositionOverride,
2873
+ tooltipAnchorRef,
2874
+ hideTooltip,
2875
+ isPendingLayout,
2876
+ isRtl
2877
+ });
2878
+ const { contextMenuTriggerProps, menuProps, contextMenuContext, isResizeDialogOpen, setIsResizeDialogOpen } = useContextMenu(rootRef, tableId, tableData, columnsArray, contextMenuConfig, sortCriterion, onSortCriterionChange);
2879
+ const interactionManagerProps = !isPendingLayout
2880
+ ? mergeProps(focusHandlingProps, keyboardHandlingProps, pointerHandlingProps, contextMenuTriggerProps)
2881
+ : focusHandlingProps;
2882
+ // setup imperative handle implementation
2883
+ useImperativeHandle(ref, () => {
2884
+ const rootElement = rootRef.current;
2885
+ const scrollerElement = viewportInfo.viewportConfig.scrollerRef.current;
2886
+ return {
2887
+ focus: () => {
2888
+ if (rootElement != null) {
2889
+ if (currentActiveCell != null) {
2890
+ const cellElement = getElementFromCell(rootElement, tableId, currentActiveCell);
2891
+ if (cellElement != null) {
2892
+ cellElement.focus();
2893
+ return;
2894
+ }
2895
+ }
2896
+ // if no current cell element was found, just focus the root element
2897
+ rootElement.focus();
2898
+ }
2899
+ },
2900
+ getHorizontalScrollPosition: () => {
2901
+ if (rootElement == null ||
2902
+ scrollerElement == null ||
2903
+ isLayoutRequired ||
2904
+ appliedColumnWidths == null) {
2905
+ return {};
2906
+ }
2907
+ return getHorizontalScrollPosition(rootElement, scrollerElement, viewportInfo, sizingInfoRef.current, overflowInfoRef.current, columnsArray, appliedColumnWidths.fullColumnWidths, isRtl);
2908
+ },
2909
+ getVerticalScrollPosition: () => {
2910
+ if (rootElement == null || scrollerElement == null || isLayoutRequired) {
2911
+ return {};
2912
+ }
2913
+ return getVerticalScrollPosition(rootElement, scrollerElement, viewportInfo, tableId);
2914
+ }
2915
+ };
2916
+ }, [
2917
+ rootRef,
2918
+ viewportInfo,
2919
+ tableId,
2920
+ columnsArray,
2921
+ currentActiveCell,
2922
+ isLayoutRequired,
2923
+ appliedColumnWidths,
2924
+ sizingInfoRef,
2925
+ overflowInfoRef,
2926
+ isRtl
2927
+ ]);
2928
+ return {
2929
+ interactionManagerProps,
2930
+ scrollHandlingProps,
2931
+ onTableSelectionChange,
2932
+ isShowFocusRing,
2933
+ isTabbableMode,
2934
+ currentCell,
2935
+ currentActiveCell,
2936
+ resizeInfoRef,
2937
+ onStartFocusTracking,
2938
+ onFocusStartEdge,
2939
+ onFocusEndEdge,
2940
+ activeStyleColumnInfo,
2941
+ hoverStyleColumnInfo,
2942
+ tooltipContent,
2943
+ contextMenuContext,
2944
+ menuProps,
2945
+ isResizeDialogOpen,
2946
+ setIsResizeDialogOpen,
2947
+ disabledRowInteractionKeys
2948
+ };
2949
+ }
2950
+
2951
+ /**
2952
+ * The internal component used to render an empty table cell in a TableBody.
2953
+ */
2954
+ function TableNoData({ rootRef, tableId, columnsCount, isShowFocusRing, hasTabIndex, isTabbableMode, ariaRowIndex, renderer }) {
2955
+ const browser = getClientHints().browser;
2956
+ const translations = useTranslationBundle('@oracle/oraclejet-preact');
2957
+ const rowClasses = classNames([tableRowStyles.base]);
2958
+ const { classes: themeClasses } = useComponentTheme(TableNoDataRedwoodTheme, {
2959
+ defaultRenderer: renderer == null ? 'isDefaultRenderer' : 'notDefaultRenderer',
2960
+ showFocusRing: isShowFocusRing ? 'isShowFocusRing' : 'notShowFocusRing'
2961
+ });
2962
+ const cellClasses = classNames([themeClasses]);
2963
+ function defaultContentRenderer() {
2964
+ return translations.collection_noData();
2965
+ }
2966
+ const contentRenderer = renderer != null ? renderer : defaultContentRenderer;
2967
+ // in firefox, table element heights are not stretched unless explicitly set in some cases
2968
+ useLayoutEffect(() => {
2969
+ if (browser === 'firefox') {
2970
+ const rootElement = rootRef.current;
2971
+ if (rootElement != null) {
2972
+ const tableBodyElement = getTableBodyElement(rootElement, tableId);
2973
+ const noDataElement = getNoDataCellElement(rootElement, tableId);
2974
+ if (tableBodyElement != null && noDataElement != null) {
2975
+ noDataElement.style.height = '';
2976
+ noDataElement.style.height = `${tableBodyElement.getBoundingClientRect().height}px`;
2977
+ }
2978
+ }
2979
+ }
2980
+ });
2981
+ return (jsx("tr", { "aria-rowindex": ariaRowIndex, class: rowClasses, role: 'row', children: jsx("td", { "aria-colindex": 1, class: cellClasses, style: browser !== 'firefox' ? 'height: 100%;' : undefined, tabIndex: hasTabIndex ? 0 : -1, role: 'gridcell', colSpan: columnsCount, "data-oj-cell-type": 'noData', "data-oj-table-focusable": tableId, "data-oj-table-nodata": tableId, children: contentRenderer({ isTabbable: isTabbableMode }) }) }));
2982
+ }
2983
+
2984
+ /**
2985
+ * @license
2986
+ * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.
2987
+ * The Universal Permissive License (UPL), Version 1.0
2988
+ * as shown at https://oss.oracle.com/licenses/upl/
2989
+ * @ignore
2990
+ */
2991
+ // Pointer Enter handler for elements that need to prevent default browser tooltips
2992
+ const _pointerEnterHandler = (event) => {
2993
+ const targetElement = event.target;
2994
+ targetElement.classList.add(preventBrowserTooltipStyle);
2995
+ };
2996
+ // Pointer Leave handler for elements that need to prevent default browser tooltips
2997
+ const _pointerLeaveHandler = (event) => {
2998
+ const targetElement = event.target;
2999
+ targetElement.classList.remove(preventBrowserTooltipStyle);
3000
+ };
3001
+ /*
3002
+ * Props that can be spread on elements that need to prevent default browser tooltips
3003
+ */
3004
+ const preventBrowserTooltipProps = {
3005
+ onPointerEnter: _pointerEnterHandler,
3006
+ onPointerLeave: _pointerLeaveHandler
3007
+ };
3008
+
3009
+ function _defaultCellRenderer({ rowData, field }) {
3010
+ return field != null ? String(rowData[field]) : undefined;
3011
+ }
3012
+ /**
3013
+ * The internal component used to render a single cell in a TableRow.
3014
+ */
3015
+ function TableCell({ tableId, rowData, field, columnKey, columnIndex, rowKey, rowIndex, isFinalRowIndex, isFinalColumnIndex, isFirstLogicalColumnIndex, isFinalLogicalColumnIndex, hasVerticalGridlines, hasHorizontalGridlines, hasFooters, hasVerticalUnderflow, hasMore, isRowSelected, isPreviousRowSelected, isColumnSelected, isNextColumnSelected, isPreviousColumnSelected, isSticky, isShowFocusRing, hasTabIndex, isTabbableMode, isAccRowHeader, focusTarget = 'cell', renderer = _defaultCellRenderer, selectorRenderer, isRowSelectionEnabled, isRowSingleSelection, variant, applyActiveStyle, applyHoverStyle, applyPseudoHoverStyle, isStickyStartEdge, isStickyEndEdge, hasStartEdge, hasEndEdge, isRtl, isHighContrast, padding, tooltip, horizontalAlignment = 'start', verticalAlignment = 'center' }) {
3016
+ const browser = getClientHints().browser;
3017
+ const rowContext = { key: rowKey, data: rowData };
3018
+ const columnPadding = typeof padding === 'function' ? padding(rowContext) : padding;
3019
+ const columnTooltip = typeof tooltip === 'function' ? tooltip(rowContext) : tooltip;
3020
+ const supportsDefaultTooltip = columnTooltip !== 'disabled';
3021
+ const hasLastHorizontalGridline = hasHorizontalGridlines && (hasMore || hasVerticalUnderflow || !hasFooters);
3022
+ const cellClasses = classNames(getDataCellClassArray({
3023
+ isFirstColumnIndex: columnIndex === 0 || isFirstLogicalColumnIndex,
3024
+ isFinalColumnIndex: isFinalColumnIndex || isFinalLogicalColumnIndex,
3025
+ isFirstRowIndex: rowIndex === 0,
3026
+ isFinalRowIndex,
3027
+ hasVerticalGridlines,
3028
+ hasHorizontalGridlines,
3029
+ hasLastHorizontalGridline,
3030
+ isRowSelected,
3031
+ isPreviousRowSelected,
3032
+ isColumnSelected,
3033
+ isNextColumnSelected,
3034
+ isPreviousColumnSelected,
3035
+ isSticky,
3036
+ hasStartEdge,
3037
+ hasEndEdge,
3038
+ isShowFocusRing,
3039
+ isRowSelectionEnabled,
3040
+ isRowSingleSelection,
3041
+ isActive: applyActiveStyle,
3042
+ isHover: applyHoverStyle,
3043
+ isPseudoHover: applyPseudoHoverStyle,
3044
+ isStickyStartEdge,
3045
+ isStickyEndEdge,
3046
+ isRtl,
3047
+ isHighContrast,
3048
+ horizontalAlignment,
3049
+ verticalAlignment,
3050
+ variant,
3051
+ padding: columnPadding
3052
+ }));
3053
+ const cellRendererProps = {
3054
+ rowData: rowData,
3055
+ rowKey: rowKey,
3056
+ field: field,
3057
+ columnKey: columnKey,
3058
+ selector: selectorRenderer,
3059
+ isTabbable: isTabbableMode
3060
+ };
3061
+ const supportsAutoFocus = typeof focusTarget === 'function'
3062
+ ? focusTarget(rowContext) === 'content'
3063
+ : focusTarget === 'content';
3064
+ return (jsx("td", { "aria-colindex": columnIndex + 1, class: cellClasses, tabIndex: hasTabIndex ? 0 : -1, role: isAccRowHeader ? 'rowheader' : 'gridcell', "data-oj-cell-type": 'data', "data-oj-column-key": columnKey, "data-oj-table-focusable": tableId, "data-oj-table-data": tableId, "data-oj-table-tooltip": supportsDefaultTooltip ? 'enabled' : undefined, "data-oj-table-auto-focus": supportsAutoFocus ? 'enabled' : undefined, ...(supportsDefaultTooltip && browser === 'safari' ? preventBrowserTooltipProps : {}), ...(isColumnSelected ? { 'aria-selected': true } : {}), children: jsx(FormContext.Provider, { value: { textAlign: getFormTextAlign(horizontalAlignment, isRtl) }, children: renderer(cellRendererProps) }) }));
3065
+ }
3066
+
3067
+ /**
3068
+ * The internal component used to render a single row in Table.
3069
+ */
3070
+ function TableRow({ tableId, rowKey, rowData, rowIndex, isFinalRow, columnsArray, rowHeaderColumnKeys, hasVerticalGridlines, hasHorizontalGridlines, hasFooters, hasVerticalUnderflow, hasMore, isSelected, isPreviousSelected, isRowSelectionEnabled, isSingleRowSelectionEnabled, selectedRowKeys = { all: false, keys: new Set() }, isShowFocusRing, activeColumnKey, isTabbableMode, selectedColumnKeys = { all: false, keys: new Set() }, variant, disabledInteractionKeys, onSelectionChange, startStickyEdge, endStickyEdge, firstStickyColumnIndex, finalStickyColumnIndex, columnBorderEdges, isRtl, isHighContrast }) {
3071
+ const translations = useTranslationBundle('@oracle/oraclejet-preact');
3072
+ const { interactionProps, applyActiveStyle, applyHoverStyle, applyPseudoHoverStyle } = useInteractionStyle({ disabledKeys: disabledInteractionKeys });
3073
+ const rowStyles = isHighContrast ? tableRowStylesHC : tableRowStyles;
3074
+ const classArray = [rowStyles.base, isFinalRow ? rowStyles.lastRowHeight : rowStyles.rowHeight];
3075
+ const classes = classNames(classArray);
3076
+ const accessibleRowName = (rowIndex + 2).toString();
3077
+ const handleRowSelectorChange = (detail) => {
3078
+ if (onSelectionChange != null) {
3079
+ onSelectionChange({
3080
+ value: {
3081
+ row: detail.value,
3082
+ column: { all: false, keys: new Set() }
3083
+ },
3084
+ target: detail.target
3085
+ }, false);
3086
+ }
3087
+ };
3088
+ const selectorRenderer = isRowSelectionEnabled && !isSingleRowSelectionEnabled
3089
+ ? () => {
3090
+ // conversion from 0-based index and adding the header row as it is always rendered
3091
+ return (jsx(Selector, { "aria-label": translations.collection_selectRow({ ROW_NAME: accessibleRowName }), onChange: handleRowSelectorChange, rowKey: rowKey, selectedKeys: selectedRowKeys }));
3092
+ }
3093
+ : undefined;
3094
+ let isPreviousColumnSelected = false;
3095
+ let isPreviousStickyColumnSelected = false;
3096
+ return (jsx("tr", { "aria-rowindex": rowIndex + 2, class: classes, role: 'row', "data-oj-key": rowKey, "data-oj-table-row": tableId, ...(isRowSelectionEnabled
3097
+ ? isSelected
3098
+ ? { 'aria-selected': true }
3099
+ : { 'aria-selected': false }
3100
+ : {}), ...(typeof rowKey === 'number' && { 'data-oj-key-type': 'number' }), ...(isRowSelectionEnabled && interactionProps), children: columnsArray.map((column, columnIndex) => {
3101
+ const columnKey = column.key;
3102
+ const isColumnSelected = containsKey(selectedColumnKeys, columnKey);
3103
+ const isActive = columnKey === activeColumnKey;
3104
+ const hasTabIndex = isActive && !isTabbableMode;
3105
+ const isSticky = column.value.sticky === 'enabled';
3106
+ let nextVisibleColumn;
3107
+ let isNextVisibleColumnSelected = false;
3108
+ let isPreviousVisibleColumnSelected = false;
3109
+ let isFirstLogicalColumnIndex = false;
3110
+ let isFinalLogicalColumnIndex = false;
3111
+ if (isSticky) {
3112
+ if (startStickyEdge != null && firstStickyColumnIndex === columnIndex) {
3113
+ isFirstLogicalColumnIndex = true;
3114
+ }
3115
+ if (endStickyEdge != null && finalStickyColumnIndex === columnIndex) {
3116
+ isFinalLogicalColumnIndex = true;
3117
+ }
3118
+ if ((startStickyEdge != null && startStickyEdge > columnIndex) ||
3119
+ (endStickyEdge != null && endStickyEdge <= columnIndex)) {
3120
+ for (let i = columnIndex + 1; i < columnsArray.length; i++) {
3121
+ if (columnsArray[i].value.sticky === 'enabled') {
3122
+ nextVisibleColumn = columnsArray[i];
3123
+ break;
3124
+ }
3125
+ }
3126
+ }
3127
+ else {
3128
+ nextVisibleColumn =
3129
+ columnIndex < columnsArray.length - 1 ? columnsArray[columnIndex + 1] : undefined;
3130
+ }
3131
+ isNextVisibleColumnSelected =
3132
+ startStickyEdge === columnIndex
3133
+ ? false
3134
+ : nextVisibleColumn != null && containsKey(selectedColumnKeys, nextVisibleColumn.key);
3135
+ if ((startStickyEdge != null && startStickyEdge >= columnIndex) ||
3136
+ (endStickyEdge != null && endStickyEdge < columnIndex)) {
3137
+ isPreviousVisibleColumnSelected = isPreviousStickyColumnSelected;
3138
+ }
3139
+ else if (endStickyEdge !== columnIndex) {
3140
+ isPreviousVisibleColumnSelected = isPreviousColumnSelected;
3141
+ }
3142
+ }
3143
+ else {
3144
+ isPreviousVisibleColumnSelected = isPreviousColumnSelected;
3145
+ }
3146
+ const cellProps = {
3147
+ tableId: tableId,
3148
+ rowData: rowData,
3149
+ field: column.value.field,
3150
+ stickyColumn: column.value.sticky,
3151
+ columnKey: columnKey,
3152
+ columnIndex: columnIndex,
3153
+ rowKey: rowKey,
3154
+ rowIndex: rowIndex,
3155
+ isFinalRowIndex: isFinalRow,
3156
+ isFinalColumnIndex: columnIndex === columnsArray.length - 1,
3157
+ isFirstLogicalColumnIndex: isFirstLogicalColumnIndex,
3158
+ isFinalLogicalColumnIndex: isFinalLogicalColumnIndex,
3159
+ hasVerticalGridlines: hasVerticalGridlines,
3160
+ hasHorizontalGridlines: hasHorizontalGridlines,
3161
+ hasFooters: hasFooters,
3162
+ hasVerticalUnderflow: hasVerticalUnderflow,
3163
+ hasMore: hasMore,
3164
+ isRowSelected: isSelected,
3165
+ isPreviousRowSelected: isPreviousSelected,
3166
+ isSticky: isSticky,
3167
+ isColumnSelected: isColumnSelected,
3168
+ isNextColumnSelected: isNextVisibleColumnSelected,
3169
+ isPreviousColumnSelected: isPreviousVisibleColumnSelected,
3170
+ isShowFocusRing: isShowFocusRing && isActive,
3171
+ hasTabIndex: hasTabIndex,
3172
+ isTabbableMode: isTabbableMode,
3173
+ isAccRowHeader: rowHeaderColumnKeys.has(column.key),
3174
+ renderer: column.value.renderer,
3175
+ selectorRenderer: selectorRenderer,
3176
+ isRowSelectionEnabled: isRowSelectionEnabled,
3177
+ variant: variant,
3178
+ isRowSingleSelection: isSingleRowSelectionEnabled,
3179
+ applyActiveStyle: applyActiveStyle,
3180
+ applyHoverStyle: applyHoverStyle,
3181
+ applyPseudoHoverStyle: applyPseudoHoverStyle,
3182
+ isStickyStartEdge: columnIndex === startStickyEdge,
3183
+ isStickyEndEdge: columnIndex === endStickyEdge,
3184
+ hasStartEdge: columnBorderEdges[columnIndex].hasStart,
3185
+ hasEndEdge: columnBorderEdges[columnIndex].hasEnd,
3186
+ isRtl: isRtl,
3187
+ isHighContrast: isHighContrast,
3188
+ padding: column.value.padding,
3189
+ tooltip: column.value.tooltip,
3190
+ focusTarget: column.value.focusTarget,
3191
+ horizontalAlignment: column.value.alignment?.horizontal != null
3192
+ ? column.value.alignment.horizontal
3193
+ : column.value.horizontalAlignment,
3194
+ verticalAlignment: column.value.alignment?.vertical
3195
+ };
3196
+ isPreviousColumnSelected = isColumnSelected;
3197
+ if (isSticky) {
3198
+ isPreviousStickyColumnSelected = isColumnSelected;
3199
+ }
3200
+ return jsx(TableCell, { ...cellProps });
3201
+ }) }, rowKey));
3202
+ }
3203
+ const _areStringSetsEquivalent = (set1, set2) => {
3204
+ if (set1 == null) {
3205
+ return set2 == null;
3206
+ }
3207
+ if (set2 == null) {
3208
+ return false;
3209
+ }
3210
+ return set1.size === set2.size && [...set1].every((x) => set2.has(x));
3211
+ };
3212
+ const _areColumnsArraysEquivalent = (columnsArray1, columnsArray2) => {
3213
+ if (columnsArray1.length === columnsArray2.length) {
3214
+ for (let i = 0; i < columnsArray1.length; i++) {
3215
+ if (columnsArray1[i].key !== columnsArray2[i].key ||
3216
+ columnsArray1[i].value !== columnsArray2[i].value) {
3217
+ return false;
3218
+ }
3219
+ }
3220
+ return true;
3221
+ }
3222
+ return false;
3223
+ };
3224
+ const MemoizeTableRow = memo(TableRow, (prev, next) => {
3225
+ if (prev && next) {
3226
+ return (prev.tableId === next.tableId &&
3227
+ prev.rowKey === next.rowKey &&
3228
+ prev.rowData === next.rowData &&
3229
+ prev.rowIndex === next.rowIndex &&
3230
+ prev.isFinalRow === next.isFinalRow &&
3231
+ _areColumnsArraysEquivalent(prev.columnsArray, next.columnsArray) &&
3232
+ prev.hasHorizontalGridlines === next.hasHorizontalGridlines &&
3233
+ prev.hasVerticalGridlines === next.hasVerticalGridlines &&
3234
+ (!next.isFinalRow ||
3235
+ (prev.hasFooters === next.hasFooters &&
3236
+ prev.hasVerticalUnderflow === next.hasVerticalUnderflow &&
3237
+ prev.hasMore === next.hasMore)) &&
3238
+ _areStringSetsEquivalent(prev.rowHeaderColumnKeys, next.rowHeaderColumnKeys) &&
3239
+ prev.isSelected === next.isSelected &&
3240
+ prev.isPreviousSelected === next.isPreviousSelected &&
3241
+ prev.isRowSelectionEnabled === next.isRowSelectionEnabled &&
3242
+ prev.isSingleRowSelectionEnabled === next.isSingleRowSelectionEnabled &&
3243
+ (prev.isRowSelectionEnabled && !prev.isSingleRowSelectionEnabled
3244
+ ? isSameKey(prev.selectedRowKeys, next.selectedRowKeys)
3245
+ : true) &&
3246
+ isSameKey(prev.selectedColumnKeys, next.selectedColumnKeys) &&
3247
+ prev.isShowFocusRing === next.isShowFocusRing &&
3248
+ prev.activeColumnKey === next.activeColumnKey &&
3249
+ prev.isTabbableMode === next.isTabbableMode &&
3250
+ prev.variant === next.variant &&
3251
+ prev.onSelectionChange === next.onSelectionChange &&
3252
+ prev.startStickyEdge === next.startStickyEdge &&
3253
+ prev.endStickyEdge === next.endStickyEdge &&
3254
+ prev.firstStickyColumnIndex === next.firstStickyColumnIndex &&
3255
+ prev.finalStickyColumnIndex === next.finalStickyColumnIndex &&
3256
+ prev.columnBorderEdges === next.columnBorderEdges &&
3257
+ prev.isRtl === next.isRtl &&
3258
+ prev.isHighContrast === next.isHighContrast &&
3259
+ prev.disabledInteractionKeys === next.disabledInteractionKeys);
3260
+ }
3261
+ return false;
3262
+ });
3263
+
3264
+ /**
3265
+ * The internal component used to render the tbody of a Table.
3266
+ */
3267
+ function TableBody({ rootRef, viewportInfo, tableId, isValidRender, getAccessibleRowHeaders, tableData, columnsArray, hasVerticalGridlines, hasHorizontalGridlines, hasFooters, hasVerticalUnderflow, isShowFocusRing, isTabbableMode, hasMore, onLoadMore, activeCell, currentRowKey, currentRowVariant, selected, isRowSelectionEnabled, isSingleRowSelectionEnabled, disabledInteractionKeys, onSelectionChange, noDataRenderer, startStickyEdge, endStickyEdge, firstStickyColumnIndex, finalStickyColumnIndex, columnBorderEdges, isRtl, isEmbedded, isHighContrast }) {
3268
+ const browser = getClientHints().browser;
3269
+ // returns a TableRowContext based on ItemContext (added key)
3270
+ const getRowContext = useCallback((context) => {
3271
+ return {
3272
+ index: context.index,
3273
+ data: context.data.data,
3274
+ key: context.data.metadata.key
3275
+ };
3276
+ }, []);
3277
+ let isPreviousSelected = false;
3278
+ const collectionChildrenFunc = (context) => {
3279
+ const tableRowContext = getRowContext(context);
3280
+ const rowKey = tableRowContext.key;
3281
+ const containsActiveCell = activeCell?.rowKey === rowKey;
3282
+ const activeColumnKey = containsActiveCell ? activeCell.columnKey : undefined;
3283
+ const isSelected = containsKey(selected.row, rowKey);
3284
+ const rowProps = {
3285
+ tableId,
3286
+ columnsArray,
3287
+ rowHeaderColumnKeys: getAccessibleRowHeaders(tableRowContext),
3288
+ hasVerticalGridlines,
3289
+ hasHorizontalGridlines,
3290
+ hasFooters,
3291
+ hasVerticalUnderflow,
3292
+ hasMore,
3293
+ isSelected,
3294
+ isPreviousSelected,
3295
+ disabledInteractionKeys,
3296
+ onSelectionChange,
3297
+ isRowSelectionEnabled,
3298
+ isSingleRowSelectionEnabled,
3299
+ variant: currentRowKey === rowKey ? currentRowVariant : 'none',
3300
+ isShowFocusRing: isShowFocusRing && containsActiveCell,
3301
+ activeColumnKey,
3302
+ isTabbableMode,
3303
+ selectedRowKeys: selected.row,
3304
+ selectedColumnKeys: selected.column,
3305
+ rowIndex: tableRowContext.index,
3306
+ rowKey,
3307
+ rowData: tableRowContext.data,
3308
+ isFinalRow: tableRowContext.index === tableData.length - 1,
3309
+ startStickyEdge,
3310
+ endStickyEdge,
3311
+ firstStickyColumnIndex: firstStickyColumnIndex,
3312
+ finalStickyColumnIndex: finalStickyColumnIndex,
3313
+ columnBorderEdges,
3314
+ isRtl,
3315
+ isHighContrast
3316
+ };
3317
+ isPreviousSelected = isSelected;
3318
+ return jsx(MemoizeTableRow, { ...rowProps });
3319
+ };
3320
+ const getNoDataProps = () => {
3321
+ const isActive = activeCell?.type === 'noData';
3322
+ const hasTabIndex = isActive && !isTabbableMode;
3323
+ return {
3324
+ rootRef,
3325
+ tableId,
3326
+ columnsCount: columnsArray.length,
3327
+ isShowFocusRing: isShowFocusRing && isActive,
3328
+ hasTabIndex,
3329
+ isTabbableMode,
3330
+ ariaRowIndex: isValidRender ? 2 : 1,
3331
+ renderer: isValidRender ? noDataRenderer : undefined
3332
+ };
3333
+ };
3334
+ const isShowEmptyLoading = tableData.length === 0 && hasMore;
3335
+ const isShowNoData = tableData.length === 0 && !hasMore;
3336
+ return (jsx("tbody", { class: backgroundStyles.inherit, role: 'presentation', "data-oj-table-body": tableId, children: isShowNoData || !isValidRender ? (jsx(TableNoData, { ...getNoDataProps() })) : (jsxs(Fragment$1, { children: [jsx(LoadMoreCollection, { data: tableData, loadMoreIndicator: jsx(TableSkeletonRow, { tableId: tableId, hasTabIndex: isShowEmptyLoading
3337
+ ? activeCell?.type === 'loading'
3338
+ : activeCell?.type === 'loadMore', colspan: columnsArray.length, isLoadMore: !isShowEmptyLoading, isShowFocusRing: isShowFocusRing &&
3339
+ (isShowEmptyLoading
3340
+ ? activeCell?.type === 'loading'
3341
+ : activeCell?.type === 'loadMore'), isEmbedded: isEmbedded, isHighContrast: isHighContrast }), hasMore: hasMore, onLoadMore: onLoadMore, viewportConfig: viewportInfo.viewportConfig, children: collectionChildrenFunc }), jsx("tr", { style: browser !== 'firefox' ? 'height: 100%;' : undefined, role: 'presentation', "data-oj-table-spacer": tableId })] })) }));
3342
+ }
3343
+
3344
+ /**
3345
+ * The internal component used to render a drag indicator line in the Table.
3346
+ */
3347
+ function TableDragIndicator({ position, isRtl, height }) {
3348
+ const tableDragIndicatorClasses = classNames([tableDragIndicatorStyles.base]);
3349
+ const getDragIndicatorStyle = () => {
3350
+ const heightString = height != null ? `height:${height}px;` : '';
3351
+ if (position != null) {
3352
+ return isRtl
3353
+ ? `right:${position}px;cursor:col-resize;${heightString}`
3354
+ : `left:${position}px;cursor:col-resize;${heightString}`;
3355
+ }
3356
+ return `display:none;`;
3357
+ };
3358
+ return jsx("div", { class: tableDragIndicatorClasses, style: getDragIndicatorStyle() });
3359
+ }
3360
+
3361
+ function _defaultFooterCellRenderer({ footerText }) {
3362
+ return footerText != null ? footerText : undefined;
3363
+ }
3364
+ /**
3365
+ * The internal component used to render a single cell in a TableFooterRow.
3366
+ */
3367
+ function TableFooterCell({ tableId, columnKey, columnIndex, isFinalColumnIndex, isFirstLogicalColumnIndex, isFinalLogicalColumnIndex, hasVerticalGridlines, isSelected, isNextColumnSelected, isPreviousColumnSelected, isSticky, isColumnSelectable, isShowFocusRing, hasTabIndex, isTabbableMode, stickyBottomOffset = 0, focusTarget = 'cell', footerText, renderer = _defaultFooterCellRenderer, isStickyStartEdge, isStickyEndEdge, hasStartEdge, hasEndEdge, isActiveStyle, isHoverStyle, isPreviousCellActiveStyle, isPreviousCellHoverStyle, isRtl, isHighContrast, padding, tooltip, horizontalAlignment = 'start', verticalAlignment = 'center' }) {
3368
+ const browser = getClientHints().browser;
3369
+ const supportsDefaultTooltip = tooltip !== 'disabled';
3370
+ const supportsAutoFocus = focusTarget === 'content';
3371
+ const cellClasses = classNames(getHeaderFooterCellClassArray({
3372
+ isHeader: false,
3373
+ isActiveStyle,
3374
+ isHoverStyle,
3375
+ isPreviousCellActiveStyle,
3376
+ isPreviousCellHoverStyle,
3377
+ isFirstColumnIndex: columnIndex === 0 || isFirstLogicalColumnIndex,
3378
+ isFinalColumnIndex: isFinalColumnIndex || isFinalLogicalColumnIndex,
3379
+ hasVerticalGridlines,
3380
+ isSelected,
3381
+ isNextColumnSelected,
3382
+ isPreviousColumnSelected,
3383
+ isSticky,
3384
+ hasStartEdge,
3385
+ hasEndEdge,
3386
+ isShowFocusRing,
3387
+ isStickyStartEdge,
3388
+ isStickyEndEdge,
3389
+ isRtl,
3390
+ horizontalAlignment,
3391
+ verticalAlignment,
3392
+ isHighContrast,
3393
+ padding
3394
+ }));
3395
+ const footerCellRendererProps = {
3396
+ key: columnKey,
3397
+ footerText: footerText,
3398
+ isTabbable: isTabbableMode
3399
+ };
3400
+ return (jsx("td", { "aria-colindex": columnIndex + 1, ...(isSelected
3401
+ ? { 'aria-selected': true }
3402
+ : isColumnSelectable
3403
+ ? { 'aria-selected': false }
3404
+ : {}), class: cellClasses, style: `bottom:${stickyBottomOffset}px;`, tabIndex: hasTabIndex ? 0 : -1, role: 'gridcell', "data-oj-cell-type": 'footer', "data-oj-column-key": columnKey, "data-oj-table-focusable": tableId, "data-oj-table-footer": tableId, "data-oj-table-tooltip": supportsDefaultTooltip ? 'enabled' : undefined, "data-oj-table-auto-focus": supportsAutoFocus ? 'enabled' : undefined, ...(supportsDefaultTooltip && browser === 'safari' ? preventBrowserTooltipProps : {}), children: jsx(FormContext.Provider, { value: { textAlign: getFormTextAlign(horizontalAlignment, isRtl) }, children: renderer(footerCellRendererProps) }) }));
3405
+ }
3406
+
3407
+ /**
3408
+ * The internal component used to render a footer region in Table.
3409
+ */
3410
+ function TableFooter({ tableId, isRendered, columnsArray, hasVerticalGridlines, activeKey, isTabbableMode, isShowFocusRing, selectedColumnKeys, isColumnSelectionEnabled, activeStyleKey, hoverStyleKey, stickyBottomOffset, startStickyEdge, endStickyEdge, firstStickyColumnIndex, finalStickyColumnIndex, columnBorderEdges, dataRowCount, isRtl, isHighContrast }) {
3411
+ const rowClasses = classNames([tableFooterRowStyles.base]);
3412
+ let previousColumnKey;
3413
+ let previousStickyColumnKey;
3414
+ let isPreviousSelectable = false;
3415
+ let isPreviousStickySelectable = false;
3416
+ let isPreviousColumnSelected = false;
3417
+ let isPreviousStickyColumnSelected = false;
3418
+ return isRendered ? (jsx("tfoot", { class: backgroundStyles.inherit, role: 'presentation', children: jsx("tr", { "aria-rowindex": Math.max(dataRowCount, 1) + 2, class: rowClasses, role: 'row', "data-oj-table-footer-row": tableId, children: columnsArray.map((column, columnIndex) => {
3419
+ const columnKey = column.key;
3420
+ const isSticky = column.value.sticky === 'enabled';
3421
+ const isSelectable = isColumnSelectionEnabled && column.value.selectable !== 'disabled';
3422
+ const isSelected = containsKey(selectedColumnKeys, columnKey);
3423
+ const isActive = columnKey === activeKey;
3424
+ const hasTabIndex = isActive && !isTabbableMode;
3425
+ let previousVisibleColumnKey;
3426
+ let isPreviousVisibleColumnSelectable = false;
3427
+ let isPreviousVisibleColumnSelected = false;
3428
+ let nextVisibleColumn;
3429
+ let isNextVisibleColumnSelected = false;
3430
+ let isFirstLogicalColumnIndex = false;
3431
+ let isFinalLogicalColumnIndex = false;
3432
+ if (isSticky) {
3433
+ if (startStickyEdge != null && firstStickyColumnIndex === columnIndex) {
3434
+ isFirstLogicalColumnIndex = true;
3435
+ }
3436
+ if (endStickyEdge != null && finalStickyColumnIndex === columnIndex) {
3437
+ isFinalLogicalColumnIndex = true;
3438
+ }
3439
+ if ((startStickyEdge != null && startStickyEdge > columnIndex) ||
3440
+ (endStickyEdge != null && endStickyEdge <= columnIndex)) {
3441
+ for (let i = columnIndex + 1; i < columnsArray.length; i++) {
3442
+ if (columnsArray[i].value.sticky === 'enabled') {
3443
+ nextVisibleColumn = columnsArray[i];
3444
+ break;
3445
+ }
3446
+ }
3447
+ }
3448
+ else {
3449
+ nextVisibleColumn =
3450
+ columnIndex < columnsArray.length - 1 ? columnsArray[columnIndex + 1] : undefined;
3451
+ }
3452
+ isNextVisibleColumnSelected =
3453
+ startStickyEdge === columnIndex
3454
+ ? false
3455
+ : nextVisibleColumn != null &&
3456
+ containsKey(selectedColumnKeys, nextVisibleColumn.key);
3457
+ if ((startStickyEdge != null && startStickyEdge >= columnIndex) ||
3458
+ (endStickyEdge != null && endStickyEdge < columnIndex)) {
3459
+ previousVisibleColumnKey = previousStickyColumnKey;
3460
+ isPreviousVisibleColumnSelectable = isPreviousStickySelectable;
3461
+ isPreviousVisibleColumnSelected = isPreviousStickyColumnSelected;
3462
+ }
3463
+ else if (endStickyEdge !== columnIndex) {
3464
+ previousVisibleColumnKey = previousColumnKey;
3465
+ isPreviousVisibleColumnSelectable = isPreviousSelectable;
3466
+ isPreviousVisibleColumnSelected = isPreviousColumnSelected;
3467
+ }
3468
+ }
3469
+ else {
3470
+ previousVisibleColumnKey = previousColumnKey;
3471
+ isPreviousVisibleColumnSelectable = isPreviousSelectable;
3472
+ isPreviousVisibleColumnSelected = isPreviousColumnSelected;
3473
+ }
3474
+ const footerCellProps = {
3475
+ tableId: tableId,
3476
+ columnKey: columnKey,
3477
+ columnIndex: columnIndex,
3478
+ isFinalColumnIndex: columnIndex === columnsArray.length - 1,
3479
+ isFirstLogicalColumnIndex: isFirstLogicalColumnIndex,
3480
+ isFinalLogicalColumnIndex: isFinalLogicalColumnIndex,
3481
+ hasVerticalGridlines: hasVerticalGridlines,
3482
+ stickyBottomOffset: stickyBottomOffset,
3483
+ isSticky: isSticky,
3484
+ isSelected: isSelected,
3485
+ isNextColumnSelected: isNextVisibleColumnSelected,
3486
+ isPreviousColumnSelected: isPreviousVisibleColumnSelected,
3487
+ hasStartEdge: columnBorderEdges[columnIndex].hasStart,
3488
+ hasEndEdge: columnBorderEdges[columnIndex].hasEnd,
3489
+ isColumnSelectable: isSelectable,
3490
+ isShowFocusRing: isShowFocusRing && isActive,
3491
+ hasTabIndex: hasTabIndex,
3492
+ isTabbableMode: isTabbableMode,
3493
+ footerText: column.value.footerText,
3494
+ renderer: column.value.footerRenderer,
3495
+ isStickyStartEdge: columnIndex === startStickyEdge,
3496
+ isStickyEndEdge: columnIndex === endStickyEdge,
3497
+ isActiveStyle: isSelectable && activeStyleKey === columnKey,
3498
+ isHoverStyle: isSelectable && hoverStyleKey === columnKey,
3499
+ isPreviousCellActiveStyle: activeStyleKey != null &&
3500
+ activeStyleKey === previousVisibleColumnKey &&
3501
+ isPreviousVisibleColumnSelectable,
3502
+ isPreviousCellHoverStyle: hoverStyleKey != null &&
3503
+ hoverStyleKey === previousVisibleColumnKey &&
3504
+ isPreviousVisibleColumnSelectable,
3505
+ isRtl: isRtl,
3506
+ isHighContrast: isHighContrast,
3507
+ padding: column.value.footerPadding,
3508
+ tooltip: column.value.footerTooltip,
3509
+ focusTarget: column.value.footerFocusTarget,
3510
+ horizontalAlignment: column.value.footerAlignment?.horizontal != null
3511
+ ? column.value.footerAlignment.horizontal
3512
+ : column.value.horizontalAlignment,
3513
+ verticalAlignment: column.value.footerAlignment?.vertical
3514
+ };
3515
+ previousColumnKey = columnKey;
3516
+ isPreviousSelectable = isSelectable;
3517
+ isPreviousColumnSelected = isSelected;
3518
+ if (isSticky) {
3519
+ previousStickyColumnKey = columnKey;
3520
+ isPreviousStickySelectable = isSelectable;
3521
+ isPreviousStickyColumnSelected = isSelected;
3522
+ }
3523
+ return jsx(TableFooterCell, { ...footerCellProps });
3524
+ }) }) })) : null;
3525
+ }
3526
+
3527
+ /**
3528
+ * The internal component used to render a single cell in a TableHeaderRow.
3529
+ */
3530
+ function TableHeaderCell({ tableId, columnKey, columnIndex, isFinalColumnIndex, isFirstLogicalColumnIndex, isFinalLogicalColumnIndex, hasVerticalGridlines, isSelected, isNextColumnSelected, isPreviousColumnSelected, isSticky, isColumnSelectable, isRowSelectionEnabled, selectedRowKeys = { all: false, keys: new Set() }, isShowFocusRing, hasTabIndex, isTabbableMode, headerText, stickyTopOffset = 0, focusTarget = 'cell', renderer, onSelectionChange, isShowSortIcon, sortable = 'disabled', sortDirection = 'unsorted', onSortCriterionChange, isStickyStartEdge, isStickyEndEdge, hasStartEdge, hasEndEdge, isActiveStyle, isHoverStyle, isPreviousCellActiveStyle, isPreviousCellHoverStyle, isRtl, isAccColumnHeader, isHighContrast, padding, tooltip, horizontalAlignment = 'start', verticalAlignment = 'center' }) {
3531
+ const browser = getClientHints().browser;
3532
+ const supportsDefaultTooltip = tooltip !== 'disabled';
3533
+ const supportsAutoFocus = focusTarget === 'content';
3534
+ const translations = useTranslationBundle('@oracle/oraclejet-preact');
3535
+ const cellClasses = classNames(getHeaderFooterCellClassArray({
3536
+ isHeader: true,
3537
+ isActiveStyle,
3538
+ isHoverStyle,
3539
+ isPreviousCellActiveStyle,
3540
+ isPreviousCellHoverStyle,
3541
+ isFirstColumnIndex: columnIndex === 0 || isFirstLogicalColumnIndex,
3542
+ isFinalColumnIndex: isFinalColumnIndex || isFinalLogicalColumnIndex,
3543
+ hasVerticalGridlines,
3544
+ isSelected,
3545
+ isNextColumnSelected,
3546
+ isPreviousColumnSelected,
3547
+ isSticky,
3548
+ isShowFocusRing,
3549
+ isStickyStartEdge,
3550
+ isStickyEndEdge,
3551
+ hasStartEdge,
3552
+ hasEndEdge,
3553
+ isRtl,
3554
+ horizontalAlignment,
3555
+ verticalAlignment,
3556
+ isHighContrast,
3557
+ padding
3558
+ }));
3559
+ let selectorAllState;
3560
+ if (isSameKey(selectedRowKeys, { all: true, deletedKeys: new Set() })) {
3561
+ selectorAllState = 'all';
3562
+ }
3563
+ else if (isSameKey(selectedRowKeys, { all: false, keys: new Set() })) {
3564
+ selectorAllState = 'none';
3565
+ }
3566
+ else {
3567
+ selectorAllState = 'partial';
3568
+ }
3569
+ const handleSelectorChange = (detail) => {
3570
+ if (onSelectionChange != null) {
3571
+ onSelectionChange({
3572
+ value: {
3573
+ row: detail.value,
3574
+ column: { all: false, keys: new Set() }
3575
+ },
3576
+ target: detail.target
3577
+ }, false);
3578
+ }
3579
+ };
3580
+ const selectorRenderer = isRowSelectionEnabled
3581
+ ? () => (jsx(SelectorAll, { "aria-label": translations.collection_selectAllRows(), onChange: handleSelectorChange, selected: selectorAllState }))
3582
+ : undefined;
3583
+ const handleSortGesture = useCallback(() => {
3584
+ if (onSortCriterionChange != null) {
3585
+ const newDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
3586
+ onSortCriterionChange([{ key: columnKey, sortDirection: newDirection }]);
3587
+ }
3588
+ }, [columnKey, sortDirection, onSortCriterionChange]);
3589
+ const headerCellRendererProps = {
3590
+ key: columnKey,
3591
+ headerText: headerText,
3592
+ sortable: sortable,
3593
+ sortDirection: sortDirection,
3594
+ selector: selectorRenderer,
3595
+ isTabbable: isTabbableMode
3596
+ };
3597
+ const getHeaderCellRenderer = useCallback(() => {
3598
+ if (renderer != null) {
3599
+ return renderer;
3600
+ }
3601
+ return ({ headerText, sortable, sortDirection }) => {
3602
+ const text = headerText != null ? (jsx("div", { class: tableHeaderCellTextStyles.base, children: jsx("span", { class: tableHeaderCellStyles.defaultRendererSpan, children: headerText }) })) : undefined;
3603
+ if (sortable === 'enabled' || sortDirection !== 'unsorted') {
3604
+ const isIconFirst = horizontalAlignment === 'end' ||
3605
+ (!isRtl && horizontalAlignment === 'right') ||
3606
+ (isRtl && horizontalAlignment === 'left');
3607
+ const containerClasses = classNames([
3608
+ tableHeaderSortContainerStyles.base,
3609
+ justifyContentStyles[horizontalAlignment]
3610
+ ]);
3611
+ return (jsxs("div", { class: containerClasses, children: [isIconFirst && jsx(SortControl, {}), text, !isIconFirst && jsx(SortControl, {})] }));
3612
+ }
3613
+ return text;
3614
+ };
3615
+ }, [renderer, horizontalAlignment, isRtl]);
3616
+ const getAriaSelected = () => {
3617
+ if (isSelected) {
3618
+ return { 'aria-selected': true };
3619
+ }
3620
+ return isColumnSelectable ? { 'aria-selected': false } : undefined;
3621
+ };
3622
+ const getAriaSort = () => {
3623
+ if (sortDirection === 'ascending' || sortDirection === 'descending') {
3624
+ return { 'aria-sort': sortDirection };
3625
+ }
3626
+ return undefined;
3627
+ };
3628
+ return (jsx(SortableContext.Provider, { value: { isRendered: isShowSortIcon, sortable, sortDirection, onSort: handleSortGesture }, children: jsx("th", { "aria-colindex": columnIndex + 1, ...getAriaSelected(), ...getAriaSort(), class: cellClasses, style: `top:${stickyTopOffset}px;`, tabIndex: hasTabIndex ? 0 : -1, role: isAccColumnHeader ? 'columnheader' : 'gridcell', "data-oj-cell-type": 'header', "data-oj-column-key": columnKey, "data-oj-table-focusable": tableId, "data-oj-table-header": tableId, "data-oj-table-tooltip": supportsDefaultTooltip ? 'enabled' : undefined, "data-oj-table-auto-focus": supportsAutoFocus ? 'enabled' : undefined, ...(supportsDefaultTooltip && browser === 'safari' ? preventBrowserTooltipProps : {}), children: jsx(FormContext.Provider, { value: { textAlign: getFormTextAlign(horizontalAlignment, isRtl) }, children: getHeaderCellRenderer()(headerCellRendererProps) }) }) }));
3629
+ }
3630
+
3631
+ /**
3632
+ * The internal component used to render a header region in Table.
3633
+ */
3634
+ function TableHeader({ tableId, isRendered, columnsArray, hasVerticalGridlines, activeKey, isTabbableMode, isShowFocusRing, selectedColumnKeys, selectedRowKeys, isColumnSelectionEnabled, isRowSelectionEnabled, onSelectionChange, isForceSortIcons, activeStyleKey, hoverStyleKey, sortCriterion, onSortCriterionChange, stickyTopOffset, startStickyEdge, endStickyEdge, firstStickyColumnIndex, finalStickyColumnIndex, columnBorderEdges, isResizeHover, isRtl, isHighContrast }) {
3635
+ const rowClasses = classNames([tableHeaderRowStyles.base]);
3636
+ const getStyle = () => {
3637
+ return isResizeHover ? 'cursor: col-resize;' : '';
3638
+ };
3639
+ let previousColumnKey;
3640
+ let previousStickyColumnKey;
3641
+ let isPreviousSelectable = false;
3642
+ let isPreviousStickySelectable = false;
3643
+ let isPreviousColumnSelected = false;
3644
+ let isPreviousStickyColumnSelected = false;
3645
+ return isRendered ? (jsx("thead", { class: backgroundStyles.inherit, role: 'presentation', children: jsx("tr", { "aria-rowindex": 1, class: rowClasses, role: 'row', style: getStyle(), "data-oj-table-header-row": tableId, children: columnsArray.map((column, columnIndex) => {
3646
+ const columnKey = column.key;
3647
+ let sortDirection;
3648
+ if (sortCriterion != null) {
3649
+ for (const criterion of sortCriterion) {
3650
+ if (criterion.key === columnKey) {
3651
+ sortDirection = criterion.sortDirection;
3652
+ break;
3653
+ }
3654
+ }
3655
+ }
3656
+ const sortable = column.value.sortable;
3657
+ const hasSortIcon = sortable === 'enabled' || sortDirection != null;
3658
+ const isShowSortIcon = hasSortIcon &&
3659
+ (isForceSortIcons || sortDirection != null || hoverStyleKey === columnKey);
3660
+ const isSticky = column.value.sticky === 'enabled';
3661
+ const isSelectable = isColumnSelectionEnabled && column.value.selectable !== 'disabled';
3662
+ const isSelected = containsKey(selectedColumnKeys, columnKey);
3663
+ const isActive = columnKey === activeKey;
3664
+ const hasTabIndex = isActive && !isTabbableMode;
3665
+ let previousVisibleColumnKey;
3666
+ let isPreviousVisibleColumnSelectable = false;
3667
+ let isPreviousVisibleColumnSelected = false;
3668
+ let nextVisibleColumn;
3669
+ let isNextVisibleColumnSelected = false;
3670
+ let isFirstLogicalColumnIndex = false;
3671
+ let isFinalLogicalColumnIndex = false;
3672
+ if (isSticky) {
3673
+ if (startStickyEdge != null && firstStickyColumnIndex === columnIndex) {
3674
+ isFirstLogicalColumnIndex = true;
3675
+ }
3676
+ if (endStickyEdge != null && finalStickyColumnIndex === columnIndex) {
3677
+ isFinalLogicalColumnIndex = true;
3678
+ }
3679
+ if ((startStickyEdge != null && startStickyEdge > columnIndex) ||
3680
+ (endStickyEdge != null && endStickyEdge <= columnIndex)) {
3681
+ for (let i = columnIndex + 1; i < columnsArray.length; i++) {
3682
+ if (columnsArray[i].value.sticky === 'enabled') {
3683
+ nextVisibleColumn = columnsArray[i];
3684
+ break;
3685
+ }
3686
+ }
3687
+ }
3688
+ else {
3689
+ nextVisibleColumn =
3690
+ columnIndex < columnsArray.length - 1 ? columnsArray[columnIndex + 1] : undefined;
3691
+ }
3692
+ isNextVisibleColumnSelected =
3693
+ startStickyEdge === columnIndex
3694
+ ? false
3695
+ : nextVisibleColumn != null &&
3696
+ containsKey(selectedColumnKeys, nextVisibleColumn.key);
3697
+ if ((startStickyEdge != null && startStickyEdge >= columnIndex) ||
3698
+ (endStickyEdge != null && endStickyEdge < columnIndex)) {
3699
+ previousVisibleColumnKey = previousStickyColumnKey;
3700
+ isPreviousVisibleColumnSelectable = isPreviousStickySelectable;
3701
+ isPreviousVisibleColumnSelected = isPreviousStickyColumnSelected;
3702
+ }
3703
+ else if (endStickyEdge !== columnIndex) {
3704
+ previousVisibleColumnKey = previousColumnKey;
3705
+ isPreviousVisibleColumnSelectable = isPreviousSelectable;
3706
+ isPreviousVisibleColumnSelected = isPreviousColumnSelected;
3707
+ }
3708
+ }
3709
+ else {
3710
+ previousVisibleColumnKey = previousColumnKey;
3711
+ isPreviousVisibleColumnSelectable = isPreviousSelectable;
3712
+ isPreviousVisibleColumnSelected = isPreviousColumnSelected;
3713
+ }
3714
+ const headerCellProps = {
3715
+ tableId: tableId,
3716
+ hasVerticalGridlines: hasVerticalGridlines,
3717
+ columnKey: columnKey,
3718
+ columnIndex: columnIndex,
3719
+ isFinalColumnIndex: columnIndex === columnsArray.length - 1,
3720
+ isFirstLogicalColumnIndex: isFirstLogicalColumnIndex,
3721
+ isFinalLogicalColumnIndex: isFinalLogicalColumnIndex,
3722
+ stickyTopOffset: stickyTopOffset,
3723
+ isSticky: isSticky,
3724
+ isSelected: isSelected,
3725
+ isNextColumnSelected: isNextVisibleColumnSelected,
3726
+ isPreviousColumnSelected: isPreviousVisibleColumnSelected,
3727
+ hasStartEdge: columnBorderEdges[columnIndex].hasStart,
3728
+ hasEndEdge: columnBorderEdges[columnIndex].hasEnd,
3729
+ selectedRowKeys: selectedRowKeys,
3730
+ isColumnSelectable: isSelectable,
3731
+ isRowSelectionEnabled: isRowSelectionEnabled,
3732
+ isShowFocusRing: isShowFocusRing && isActive,
3733
+ hasTabIndex: hasTabIndex,
3734
+ isTabbableMode: isTabbableMode,
3735
+ headerText: column.value.headerText,
3736
+ renderer: column.value.headerRenderer,
3737
+ onSelectionChange: onSelectionChange,
3738
+ isShowSortIcon: isShowSortIcon,
3739
+ sortable: sortable,
3740
+ sortDirection: sortDirection,
3741
+ onSortCriterionChange: onSortCriterionChange,
3742
+ isStickyStartEdge: columnIndex === startStickyEdge,
3743
+ isStickyEndEdge: columnIndex === endStickyEdge,
3744
+ isActiveStyle: isSelectable && activeStyleKey === columnKey,
3745
+ isHoverStyle: isSelectable && hoverStyleKey === columnKey,
3746
+ isPreviousCellActiveStyle: activeStyleKey != null &&
3747
+ activeStyleKey === previousVisibleColumnKey &&
3748
+ isPreviousVisibleColumnSelectable,
3749
+ isPreviousCellHoverStyle: hoverStyleKey != null &&
3750
+ hoverStyleKey === previousVisibleColumnKey &&
3751
+ isPreviousVisibleColumnSelectable,
3752
+ isRtl: isRtl,
3753
+ isAccColumnHeader: column.value.accessibleColumnHeader !== 'disabled',
3754
+ isHighContrast: isHighContrast,
3755
+ padding: column.value.headerPadding,
3756
+ tooltip: column.value.headerTooltip,
3757
+ focusTarget: column.value.headerFocusTarget,
3758
+ horizontalAlignment: column.value.headerAlignment?.horizontal != null
3759
+ ? column.value.headerAlignment.horizontal
3760
+ : column.value.horizontalAlignment,
3761
+ verticalAlignment: column.value.headerAlignment?.vertical
3762
+ };
3763
+ previousColumnKey = columnKey;
3764
+ isPreviousSelectable = isSelectable;
3765
+ isPreviousColumnSelected = isSelected;
3766
+ if (isSticky) {
3767
+ previousStickyColumnKey = columnKey;
3768
+ isPreviousStickySelectable = isSelectable;
3769
+ isPreviousStickyColumnSelected = isSelected;
3770
+ }
3771
+ return jsx(TableHeaderCell, { ...headerCellProps });
3772
+ }) }) })) : null;
3773
+ }
3774
+
3775
+ const _defaultSelected = {
3776
+ row: { all: false, keys: new Set() },
3777
+ column: { all: false, keys: new Set() }
3778
+ };
3779
+ const _disabledHeaderFooterInteractionKeys = ['enter'];
3780
+ /**
3781
+ * Component that renders data in a flat table.
3782
+ */
3783
+ const Table = forwardRef(function Table({ 'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledBy, 'aria-describedby': ariaDescribedBy, getAccessibleRowHeaders, columns, columnOrder, columnWidths, contextMenuConfig, viewportConfig, layout = 'contents', data, getRowKey, hasMore = false, onLoadMore = () => { }, currentCellOverride, onPersistCurrentCell, currentRowVariant, gridlines, selectionMode, selected = _defaultSelected, onSelectionChange, onRowAction, sortCriterion, onSortCriterionChange, horizontalScrollPositionOverride, verticalScrollPositionOverride, columnResizingIndicator, onColumnResizing, onColumnResize, noDataRenderer, scrollerRef, testId }, ref) {
3784
+ const tableId = useId();
3785
+ const testIdProps = useTestId(testId);
3786
+ // rootRef is callback-based to meet useResizeObserver hook's state management requirements
3787
+ const [rootRef, setRootRef] = useState(createRef());
3788
+ const rootRefCallback = useCallback((node) => {
3789
+ setRootRef({ current: node });
3790
+ }, []);
3791
+ // innerTableRef is callback-based to meet useResizeObserver hook's state management requirements
3792
+ const [innerTableRef, setInnerTableRef] = useState(createRef());
3793
+ const innerTableRefCallback = useCallback((node) => {
3794
+ setInnerTableRef({ current: node });
3795
+ }, []);
3796
+ const { direction, forcedColors } = useUser();
3797
+ const isHighContrast = forcedColors === 'active';
3798
+ const isRtl = direction === 'rtl';
3799
+ const isEmbedded = useCollectionInteractionContext() === 'embedded';
3800
+ const rowVariant = currentRowVariant ?? isEmbedded ? 'highlight' : 'none';
3801
+ const { managedData: tableData, onManagedLoadMore: onTableLoadMore } = useDataManager({
3802
+ data,
3803
+ getRowKey,
3804
+ hasMore,
3805
+ onLoadMore
3806
+ });
3807
+ const { columnBorderEdges, isLayoutRequired, viewportInfo, columnsArray, appliedColumnWidths, sizingInfoRef, overflowInfoRef, innerTableHeight, hasVerticalUnderflow, stickyEdgesState, setStickyEdgesState, stickyColumnInfo, scrollerRefCallback } = useSizingManager({
3808
+ rootRef,
3809
+ innerTableRef,
3810
+ tableId,
3811
+ tableData,
3812
+ viewportConfig,
3813
+ externalScrollerAccessRef: scrollerRef,
3814
+ layout,
3815
+ columns,
3816
+ columnOrder,
3817
+ columnWidths,
3818
+ isRtl,
3819
+ isHighContrast
3820
+ });
3821
+ const cellHasRenderer = useCallback((cell) => {
3822
+ let hasRenderer = false;
3823
+ if (cell.type === 'noData') {
3824
+ hasRenderer = noDataRenderer != null;
3825
+ }
3826
+ else if (cell.type !== 'loadMore' && cell.type !== 'loading' && cell.type !== 'pending') {
3827
+ for (const column of columnsArray) {
3828
+ if (column.key === cell.columnKey) {
3829
+ if (cell.type === 'data') {
3830
+ hasRenderer = column.value.renderer != null;
3831
+ }
3832
+ else if (cell.type === 'header') {
3833
+ hasRenderer = column.value.headerRenderer != null;
3834
+ }
3835
+ else if (cell.type === 'footer') {
3836
+ hasRenderer = column.value.footerRenderer != null;
3837
+ }
3838
+ break;
3839
+ }
3840
+ }
3841
+ }
3842
+ return hasRenderer;
3843
+ }, [columnsArray, noDataRenderer]);
3844
+ const isPendingLayout = layout === 'pending';
3845
+ // aria-rowcount includes header and footer rows
3846
+ const hasFooters = columnsArray.some((column) => {
3847
+ return column.value.footerRenderer != null || column.value.footerText != null;
3848
+ });
3849
+ const ariaRowCount = hasMore || isPendingLayout ? -1 : tableData.length + (hasFooters ? 2 : 1);
3850
+ const ariaColumnCount = Math.max(columnsArray.length, 1);
3851
+ const { interactionManagerProps, scrollHandlingProps, onTableSelectionChange, isShowFocusRing, isTabbableMode, currentCell, currentActiveCell, resizeInfoRef, onStartFocusTracking, onFocusStartEdge, onFocusEndEdge, activeStyleColumnInfo, hoverStyleColumnInfo, tooltipContent, contextMenuContext, menuProps, isResizeDialogOpen, setIsResizeDialogOpen, disabledRowInteractionKeys } = useInteractionManager({
3852
+ rootRef,
3853
+ viewportInfo,
3854
+ ref,
3855
+ tableId,
3856
+ tableData,
3857
+ hasMore,
3858
+ hasFooters,
3859
+ isRtl,
3860
+ columnsArray,
3861
+ stickyColumnInfo,
3862
+ appliedColumnWidths,
3863
+ isLayoutRequired,
3864
+ sizingInfoRef,
3865
+ overflowInfoRef,
3866
+ stickyEdgesState,
3867
+ setStickyEdgesState,
3868
+ cellHasRenderer,
3869
+ horizontalScrollPositionOverride,
3870
+ verticalScrollPositionOverride,
3871
+ onColumnResizing,
3872
+ onColumnResize,
3873
+ currentCellOverride,
3874
+ onPersistCurrentCell,
3875
+ selectionMode,
3876
+ selected,
3877
+ onSelectionChange,
3878
+ onRowAction,
3879
+ sortCriterion,
3880
+ onSortCriterionChange,
3881
+ isPendingLayout,
3882
+ isEmbedded,
3883
+ contextMenuConfig
3884
+ });
3885
+ // initialize base Table style classes
3886
+ const { classes: themeClasses } = useComponentTheme(TableRedwoodTheme, {
3887
+ pendingLayout: isPendingLayout ? 'isPendingLayout' : 'notPendingLayout',
3888
+ showFocusRing: isShowFocusRing ? 'isShowFocusRing' : 'notShowFocusRing',
3889
+ externalScroller: viewportInfo.isExternalScroller ? 'isExternalScroller' : 'notExternalScroller'
3890
+ });
3891
+ let scrollerStyle;
3892
+ let scrollerPadding = '';
3893
+ const scrollerClassArray = [scrollerStyles.base];
3894
+ if (viewportInfo.isExternalScroller) {
3895
+ scrollerClassArray.push(scrollerStyles.externalScroller);
3896
+ }
3897
+ else if (!sizingInfoRef.current.isScrollbarSizeKnown) {
3898
+ scrollerClassArray.push(scrollerStyles.forceScroll);
3899
+ }
3900
+ else {
3901
+ if (overflowInfoRef.current.isHorizontal) {
3902
+ scrollerClassArray.push(scrollerStyles.horizontalScroll);
3903
+ }
3904
+ else {
3905
+ scrollerClassArray.push(scrollerStyles.noHorizontalScroll);
3906
+ }
3907
+ if (overflowInfoRef.current.isVertical) {
3908
+ scrollerClassArray.push(scrollerStyles.verticalScroll);
3909
+ }
3910
+ else {
3911
+ scrollerClassArray.push(scrollerStyles.noVerticalScroll);
3912
+ scrollerPadding = `padding-inline-end: ${sizingInfoRef.current.defaultScrollbarWidth}px;`;
3913
+ }
3914
+ }
3915
+ // hide the table contents when layout is required and otherwise valid
3916
+ if (isLayoutRequired && columnsArray.length > 0) {
3917
+ scrollerStyle = `${scrollerPadding}opacity:0.001;`;
3918
+ }
3919
+ else {
3920
+ scrollerStyle = scrollerPadding;
3921
+ }
3922
+ const scrollerClasses = classNames(scrollerClassArray);
3923
+ const allowBrowserContextMenu = !(getClientHints().platform === 'ios' || getClientHints().platform === 'android');
3924
+ const classArray = [themeClasses];
3925
+ if (!allowBrowserContextMenu) {
3926
+ classArray.push(userSelectStyles.userSelect);
3927
+ }
3928
+ const classes = classNames(classArray);
3929
+ const tableClasses = classNames([innerTableStyles.base]);
3930
+ const startStickyEdge = stickyEdgesState.start;
3931
+ const endStickyEdge = stickyEdgesState.end;
3932
+ const hasVerticalGridlines = gridlines?.vertical === 'visible';
3933
+ const hasHorizontalGridlines = gridlines?.horizontal !== 'hidden';
3934
+ const isRowSelectionEnabled = selectionMode?.row === 'single' ||
3935
+ selectionMode?.row === 'multiple' ||
3936
+ selectionMode?.row === 'multipleToggle';
3937
+ const isColumnSelectionEnabled = selectionMode?.column === 'single' || selectionMode?.column === 'multiple';
3938
+ const supportsMultipleSelection = selectionMode?.column === 'multiple' ||
3939
+ selectionMode?.row === 'multiple' ||
3940
+ selectionMode?.row === 'multipleToggle';
3941
+ const getTableBodyProps = () => {
3942
+ return {
3943
+ rootRef,
3944
+ viewportInfo,
3945
+ tableId,
3946
+ isValidRender: columnsArray.length > 0,
3947
+ tableData,
3948
+ columnsArray,
3949
+ getAccessibleRowHeaders,
3950
+ hasVerticalGridlines,
3951
+ hasHorizontalGridlines,
3952
+ hasFooters,
3953
+ hasVerticalUnderflow,
3954
+ selected,
3955
+ isRowSelectionEnabled,
3956
+ isSingleRowSelectionEnabled: selectionMode?.row === 'single',
3957
+ activeCell: currentActiveCell,
3958
+ currentRowKey: currentCell?.type === 'data' ? currentCell.rowKey : undefined,
3959
+ currentRowVariant: rowVariant,
3960
+ isShowFocusRing,
3961
+ isTabbableMode,
3962
+ hasMore,
3963
+ onLoadMore: onTableLoadMore,
3964
+ noDataRenderer,
3965
+ disabledInteractionKeys: disabledRowInteractionKeys,
3966
+ onSelectionChange: onTableSelectionChange,
3967
+ startStickyEdge,
3968
+ endStickyEdge,
3969
+ firstStickyColumnIndex: stickyColumnInfo.firstStickyColumnIndex,
3970
+ finalStickyColumnIndex: stickyColumnInfo.finalStickyColumnIndex,
3971
+ columnBorderEdges,
3972
+ isRtl,
3973
+ isEmbedded,
3974
+ isHighContrast
3975
+ };
3976
+ };
3977
+ const getTableColGroupProps = () => {
3978
+ let columnWidthsArray;
3979
+ if (!isLayoutRequired && appliedColumnWidths?.realColumnWidths != null) {
3980
+ columnWidthsArray = appliedColumnWidths.realColumnWidths;
3981
+ }
3982
+ else if (layout === 'fixed') {
3983
+ // default to 100px for each column when layout is not yet available
3984
+ columnWidthsArray = [];
3985
+ for (let i = 0; i < columnsArray.length; i++) {
3986
+ columnWidthsArray[i] = 100;
3987
+ }
3988
+ }
3989
+ else {
3990
+ columnWidthsArray = [];
3991
+ for (let i = 0; i < columnsArray.length; i++) {
3992
+ columnWidthsArray[i] = undefined;
3993
+ }
3994
+ }
3995
+ return {
3996
+ tableId,
3997
+ isRendered: columnsArray.length > 0,
3998
+ columnWidthsArray
3999
+ };
4000
+ };
4001
+ const getTableHeaderProps = () => {
4002
+ return {
4003
+ tableId,
4004
+ isRendered: columnsArray.length > 0,
4005
+ columnsArray,
4006
+ hasVerticalGridlines,
4007
+ activeKey: currentActiveCell?.type === 'header' ? currentActiveCell.columnKey : undefined,
4008
+ isTabbableMode,
4009
+ selectedColumnKeys: selected.column,
4010
+ selectedRowKeys: selected.row,
4011
+ isColumnSelectionEnabled,
4012
+ isRowSelectionEnabled,
4013
+ disabledInteractionKeys: _disabledHeaderFooterInteractionKeys,
4014
+ onSelectionChange: onTableSelectionChange,
4015
+ isForceSortIcons: layout === 'contents' && isLayoutRequired,
4016
+ activeStyleKey: activeStyleColumnInfo?.isHeader ? activeStyleColumnInfo?.key : undefined,
4017
+ hoverStyleKey: hoverStyleColumnInfo?.isHeader ? hoverStyleColumnInfo?.key : undefined,
4018
+ sortCriterion,
4019
+ onSortCriterionChange,
4020
+ isShowFocusRing,
4021
+ stickyTopOffset: viewportInfo.viewportConfig.scrollerOffsetTop,
4022
+ startStickyEdge,
4023
+ endStickyEdge,
4024
+ firstStickyColumnIndex: stickyColumnInfo.firstStickyColumnIndex,
4025
+ finalStickyColumnIndex: stickyColumnInfo.finalStickyColumnIndex,
4026
+ columnBorderEdges,
4027
+ isResizeHover: resizeInfoRef.current.isResizeHover,
4028
+ isRtl,
4029
+ isHighContrast
4030
+ };
4031
+ };
4032
+ const getTableFooterProps = () => {
4033
+ return {
4034
+ tableId,
4035
+ isRendered: hasFooters,
4036
+ columnsArray,
4037
+ hasVerticalGridlines,
4038
+ activeKey: currentActiveCell?.type === 'footer' ? currentActiveCell.columnKey : undefined,
4039
+ isTabbableMode,
4040
+ selectedColumnKeys: selected.column,
4041
+ isColumnSelectionEnabled,
4042
+ activeStyleKey: !activeStyleColumnInfo?.isHeader ? activeStyleColumnInfo?.key : undefined,
4043
+ hoverStyleKey: !hoverStyleColumnInfo?.isHeader ? hoverStyleColumnInfo?.key : undefined,
4044
+ isShowFocusRing,
4045
+ disabledInteractionKeys: _disabledHeaderFooterInteractionKeys,
4046
+ stickyBottomOffset: viewportInfo.viewportConfig.scrollerOffsetBottom,
4047
+ startStickyEdge,
4048
+ endStickyEdge,
4049
+ firstStickyColumnIndex: stickyColumnInfo.firstStickyColumnIndex,
4050
+ finalStickyColumnIndex: stickyColumnInfo.finalStickyColumnIndex,
4051
+ columnBorderEdges,
4052
+ dataRowCount: tableData.length,
4053
+ isRtl,
4054
+ isHighContrast
4055
+ };
4056
+ };
4057
+ const getTableDragIndicator = () => {
4058
+ if (columnResizingIndicator != null &&
4059
+ !isLayoutRequired &&
4060
+ appliedColumnWidths?.fullColumnWidths != null) {
4061
+ let position = 0;
4062
+ for (let i = 0; i < columnsArray.length; i++) {
4063
+ position += appliedColumnWidths.fullColumnWidths[i];
4064
+ if (columnsArray[i].key === columnResizingIndicator.key) {
4065
+ if (columnResizingIndicator.delta != null) {
4066
+ position += columnResizingIndicator.delta;
4067
+ }
4068
+ break;
4069
+ }
4070
+ }
4071
+ return jsx(TableDragIndicator, { position: position, isRtl: isRtl, height: innerTableHeight });
4072
+ }
4073
+ return undefined;
4074
+ };
4075
+ const getTableStyle = () => {
4076
+ if (!isLayoutRequired && appliedColumnWidths?.realColumnWidths != null) {
4077
+ let totalWidth = 0;
4078
+ for (let i = 0; i < appliedColumnWidths.realColumnWidths.length; i++) {
4079
+ totalWidth += appliedColumnWidths.realColumnWidths[i];
4080
+ }
4081
+ return `width:${totalWidth}px;table-layout:fixed;`;
4082
+ }
4083
+ else if (columnsArray.length > 0) {
4084
+ if (layout === 'fixed') {
4085
+ // default to 100px for each column when layout is not yet available
4086
+ return `width:${columnsArray.length * 100}px;table-layout:fixed;`;
4087
+ }
4088
+ else {
4089
+ // shrink table down as much as possible when a 'contents' layout is required, otherwise
4090
+ // the sampled column widths will not reflect the true weight sizes with line-clamping
4091
+ return 'width:max-content;will-change:width;';
4092
+ }
4093
+ }
4094
+ // no columns are present
4095
+ return 'width:100%;';
4096
+ };
4097
+ const skeletonStyles = isHighContrast ? tableSkeletonStylesHC : tableSkeletonStyles;
4098
+ const getPendingLayoutSkeletons = () => {
4099
+ return isPendingLayout ? (jsx("div", { class: skeletonStyles.pendingLayout, children: jsx("table", { role: 'presentation', style: 'width:100%;table-layout:fixed;', children: jsx("tbody", { role: 'presentation', children: jsx(TableSkeletonRow, { tableId: tableId, hasTabIndex: currentActiveCell?.type === 'pending', colspan: ariaColumnCount, isPendingLayout: true, isShowFocusRing: false, isEmbedded: isEmbedded, isHighContrast: isHighContrast }) }) }) })) : undefined;
4100
+ };
4101
+ const ariaMultiSelectableProps = supportsMultipleSelection
4102
+ ? { 'aria-multiselectable': true }
4103
+ : isRowSelectionEnabled || isColumnSelectionEnabled
4104
+ ? { 'aria-multiselectable': false }
4105
+ : {};
4106
+ return (jsxs(Fragment, { children: [jsxs("div", { ...testIdProps, ref: rootRefCallback, "aria-colcount": ariaColumnCount, "aria-label": ariaLabel, "aria-labelledby": ariaLabelledBy, "aria-describedby": ariaDescribedBy, "aria-rowcount": ariaRowCount, ...ariaMultiSelectableProps, class: classes, id: tableId, role: 'grid', tabIndex: currentActiveCell != null ? -1 : 0, ...interactionManagerProps, children: [jsxs("div", { ref: scrollerRefCallback, class: scrollerClasses, role: 'rowgroup', style: scrollerStyle, tabIndex: -1, ...scrollHandlingProps, children: [jsxs(FocusTracker, { isDisabled: !isTabbableMode, onFocusStartEdge: onFocusStartEdge, onFocusEndEdge: onFocusEndEdge, onStartTracking: onStartFocusTracking, children: [jsx(TabbableModeContext.Provider, { value: { isTabbable: isTabbableMode }, children: jsxs("table", { ref: innerTableRefCallback, "aria-hidden": isPendingLayout ? true : undefined, class: tableClasses, role: 'presentation', style: getTableStyle(), "data-oj-table-inner-table": tableId, children: [jsx(TableColGroup, { ...getTableColGroupProps() }), jsx(TableHeader, { ...getTableHeaderProps() }), jsx(TableBody, { ...getTableBodyProps() }), jsx(TableFooter, { ...getTableFooterProps() })] }) }), getTableDragIndicator()] }), tooltipContent] }), getPendingLayoutSkeletons()] }), contextMenuConfig != null && contextMenuContext != null && (jsxs(Fragment, { children: [jsx(TableContextMenu, { ...menuProps, contextMenuConfig: contextMenuConfig, contextMenuContext: contextMenuContext }), isResizeDialogOpen &&
4107
+ currentActiveCell?.columnKey != null &&
4108
+ appliedColumnWidths != null ? (jsx(TableResizeColumnDialog, { isOpen: isResizeDialogOpen, columnKey: currentActiveCell.columnKey, appliedColumnWidths: appliedColumnWidths, onColumnResize: onColumnResize, setIsResizeDialogOpen: setIsResizeDialogOpen })) : undefined] }))] }));
4109
+ });
4110
+
4111
+ export { Table as T };
4112
+ //# sourceMappingURL=Table-535987d0.js.map