@oracle/oraclejet-preact 17.1.1 → 17.1.2

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 (1032) hide show
  1. package/amd/{BaseCardView-c5624c8a.js → BaseCardView-a11e4dec.js} +2 -2
  2. package/amd/{BaseCardView-c5624c8a.js.map → BaseCardView-a11e4dec.js.map} +1 -1
  3. package/amd/CardFlexView-9688d264.js +2 -0
  4. package/amd/{CardFlexView-14fada63.js.map → CardFlexView-9688d264.js.map} +1 -1
  5. package/amd/{CardGridView-00ba53a9.js → CardGridView-b7f4f205.js} +2 -2
  6. package/amd/{CardGridView-00ba53a9.js.map → CardGridView-b7f4f205.js.map} +1 -1
  7. package/amd/CheckboxSet-e523552e.js +2 -0
  8. package/amd/CheckboxSet-e523552e.js.map +1 -0
  9. package/amd/DrawerLayoutStyles.styles.css +1 -0
  10. package/amd/GroupLoadingIndicator-cd9192c9.js +1 -1
  11. package/amd/{Indexer-74c989ce.js → Indexer-6833ad40.js} +2 -2
  12. package/amd/{Indexer-74c989ce.js.map → Indexer-6833ad40.js.map} +1 -1
  13. package/amd/List-3ebac3fc.js +2 -0
  14. package/amd/{List-61d64cd6.js.map → List-3ebac3fc.js.map} +1 -1
  15. package/amd/{ListView-a49e52c3.js → ListView-c8082c0c.js} +2 -2
  16. package/amd/{ListView-a49e52c3.js.map → ListView-c8082c0c.js.map} +1 -1
  17. package/amd/LoadMoreCollection-a6adbc3f.js +2 -0
  18. package/amd/{LoadMoreCollection-83413a59.js.map → LoadMoreCollection-a6adbc3f.js.map} +1 -1
  19. package/amd/MaxLengthCounter-caafceef.js +2 -0
  20. package/amd/MaxLengthCounter-caafceef.js.map +1 -0
  21. package/amd/PRIVATE_BaseCardView.js +1 -1
  22. package/amd/PRIVATE_List.js +1 -1
  23. package/amd/PRIVATE_LoadMoreCollection.js +1 -1
  24. package/amd/PRIVATE_SelectCommon.js +1 -1
  25. package/amd/PRIVATE_Table.js +1 -1
  26. package/amd/PRIVATE_VirtualizedCollection.js +1 -1
  27. package/amd/{SelectMultiple-1ff92cc3.js → SelectMultiple-3eb4a268.js} +2 -2
  28. package/amd/{SelectMultiple-1ff92cc3.js.map → SelectMultiple-3eb4a268.js.map} +1 -1
  29. package/amd/{SelectSingle-641a4cac.js → SelectSingle-9fcc38fc.js} +2 -2
  30. package/amd/{SelectSingle-641a4cac.js.map → SelectSingle-9fcc38fc.js.map} +1 -1
  31. package/amd/{Table-986ae70c.js → Table-611e08d5.js} +2 -2
  32. package/amd/{Table-986ae70c.js.map → Table-611e08d5.js.map} +1 -1
  33. package/amd/{TableView-452fa547.js → TableView-cf113195.js} +2 -2
  34. package/amd/{TableView-452fa547.js.map → TableView-cf113195.js.map} +1 -1
  35. package/amd/TextArea-259d741c.js +2 -0
  36. package/amd/TextArea-259d741c.js.map +1 -0
  37. package/amd/TextAreaAutosize-e8dc13b4.js +2 -0
  38. package/amd/{TextAreaAutosize-1f47b470.js.map → TextAreaAutosize-e8dc13b4.js.map} +1 -1
  39. package/amd/Theme-redwood/theme.css +261 -261
  40. package/amd/Theme-stable/theme.css +373 -373
  41. package/amd/UNSAFE_CardFlexView.js +1 -1
  42. package/amd/UNSAFE_CardGridView.js +1 -1
  43. package/amd/UNSAFE_CheckboxItem.js +1 -1
  44. package/amd/UNSAFE_CheckboxItem.js.map +1 -1
  45. package/amd/UNSAFE_CheckboxSet.js +1 -1
  46. package/amd/UNSAFE_CheckboxSet.js.map +1 -1
  47. package/amd/UNSAFE_DrawerLayout.js +1 -1
  48. package/amd/UNSAFE_DrawerLayout.js.map +1 -1
  49. package/amd/UNSAFE_ExpandableList.js +1 -1
  50. package/amd/UNSAFE_Indexer.js +1 -1
  51. package/amd/UNSAFE_ListView.js +1 -1
  52. package/amd/UNSAFE_SelectMultiple.js +1 -1
  53. package/amd/UNSAFE_SelectSingle.js +1 -1
  54. package/amd/UNSAFE_TableView.js +1 -1
  55. package/amd/UNSAFE_TextArea.js +1 -1
  56. package/amd/UNSAFE_TextAreaAutosize.js +1 -1
  57. package/amd/UNSAFE_VirtualizedListView.js +1 -1
  58. package/amd/{VirtualizedCollection-897516a5.js → VirtualizedCollection-63223f5e.js} +2 -2
  59. package/amd/{VirtualizedCollection-897516a5.js.map → VirtualizedCollection-63223f5e.js.map} +1 -1
  60. package/amd/VirtualizedListView-cf795207.js +2 -0
  61. package/amd/{VirtualizedListView-96ddfd98.js.map → VirtualizedListView-cf795207.js.map} +1 -1
  62. package/amd/hooks/UNSAFE_useContainerBreakpointValues.js +1 -1
  63. package/amd/{useSelectCommon-4e256cf0.js → useSelectCommon-94d5e5bb.js} +2 -2
  64. package/amd/{useSelectCommon-4e256cf0.js.map → useSelectCommon-94d5e5bb.js.map} +1 -1
  65. package/cjs/ActionCard-ad0ecc2f.js +1 -1
  66. package/cjs/{BarChart-f132cd7c.js → BarChart-6b34be7b.js} +4 -4
  67. package/cjs/{BarChart-f132cd7c.js.map → BarChart-6b34be7b.js.map} +1 -1
  68. package/cjs/BaseButton-ae653e88.js +2 -2
  69. package/cjs/BaseCardView-55bc5e6f.js +6 -6
  70. package/cjs/{BaseCardViewSelectionTest-361f021d.js → BaseCardViewSelectionTest-7b06bd30.js} +6 -6
  71. package/cjs/{BaseCardViewSelectionTest-361f021d.js.map → BaseCardViewSelectionTest-7b06bd30.js.map} +1 -1
  72. package/cjs/BaseNavigationListItem-4b28f14e.js +1 -1
  73. package/cjs/ButtonSet-ce6a890f.js +2 -2
  74. package/cjs/ButtonSetIconButton-d1fb3616.js +3 -3
  75. package/cjs/{Center-c0baccb0.js → Center-9f407cb2.js} +2 -2
  76. package/cjs/{Center-c0baccb0.js.map → Center-9f407cb2.js.map} +1 -1
  77. package/cjs/{Chart-42a979a7.js → Chart-4eee682b.js} +11 -11
  78. package/cjs/{Chart-42a979a7.js.map → Chart-4eee682b.js.map} +1 -1
  79. package/cjs/CheckboxControl-2e5aac8b.js +6 -6
  80. package/cjs/CheckboxRadioField-0242222e.js +6 -6
  81. package/cjs/Chip-c49b21a5.js +1 -1
  82. package/cjs/ClearIcon-c8a14c1e.js +1 -1
  83. package/cjs/CollapseIcon-9480e8dd.js +1 -1
  84. package/cjs/Collapsible-ab17d063.js +2 -2
  85. package/cjs/CompactHelpSource-42019592.js +2 -2
  86. package/cjs/{CompactLabelAssistance-fa0fd800.js → CompactLabelAssistance-2e1cd369.js} +5 -5
  87. package/cjs/{CompactLabelAssistance-fa0fd800.js.map → CompactLabelAssistance-2e1cd369.js.map} +1 -1
  88. package/cjs/CompactUserAssistance-62055a51.js +4 -4
  89. package/cjs/ComponentMessageContainer-b6683330.js +4 -4
  90. package/cjs/ConveyorBeltItem-6ec033ae.js +2 -2
  91. package/cjs/{DatePicker-433b80d2.js → DatePicker-670a2473.js} +6 -6
  92. package/cjs/{DatePicker-433b80d2.js.map → DatePicker-670a2473.js.map} +1 -1
  93. package/cjs/DatePickerHeader-1030b799.js +3 -3
  94. package/cjs/{Diagram-5fd0306a.js → Diagram-240bfa89.js} +5 -5
  95. package/cjs/{Diagram-5fd0306a.js.map → Diagram-240bfa89.js.map} +1 -1
  96. package/cjs/{Dialog-c75ebc82.js → Dialog-be0da1e4.js} +6 -6
  97. package/cjs/{Dialog-c75ebc82.js.map → Dialog-be0da1e4.js.map} +1 -1
  98. package/cjs/DirectionalCollapseArrowIcon-6f4b267e.js +1 -1
  99. package/cjs/DirectionalExpandArrowIcon-da3e55cc.js +1 -1
  100. package/cjs/DragHandle-473e7e10.js +1 -1
  101. package/cjs/DrawerLayoutStyles.styles.css +1 -0
  102. package/cjs/{Dropdown-4554e9f9.js → Dropdown-62cd15ca.js} +5 -5
  103. package/cjs/{Dropdown-4554e9f9.js.map → Dropdown-62cd15ca.js.map} +1 -1
  104. package/cjs/{EnvironmentProvider-75eb79f3.js → EnvironmentProvider-bfd5febc.js} +3 -3
  105. package/cjs/{EnvironmentProvider-75eb79f3.js.map → EnvironmentProvider-bfd5febc.js.map} +1 -1
  106. package/cjs/FilePicker-7414764e.js +2 -2
  107. package/cjs/{Flex-e7a85bef.js → Flex-ce16a2fa.js} +2 -2
  108. package/cjs/{Flex-e7a85bef.js.map → Flex-ce16a2fa.js.map} +1 -1
  109. package/cjs/{Floating-25f4e655.js → Floating-43033e19.js} +4 -4
  110. package/cjs/{Floating-25f4e655.js.map → Floating-43033e19.js.map} +1 -1
  111. package/cjs/FormLayout-a7ac29be.js +1 -1
  112. package/cjs/Gantt-efe026b9.js +9 -9
  113. package/cjs/{Grid-a7316edd.js → Grid-b8fadf4a.js} +2 -2
  114. package/cjs/{Grid-a7316edd.js.map → Grid-b8fadf4a.js.map} +1 -1
  115. package/cjs/{Gridlines-b69b67fb.js → Gridlines-2dfe546a.js} +2 -2
  116. package/cjs/{Gridlines-b69b67fb.js.map → Gridlines-2dfe546a.js.map} +1 -1
  117. package/cjs/GroupLoadingIndicator-397feb37.js +1 -1
  118. package/cjs/{HighlightText-dd11dd32.js → HighlightText-2061d12d.js} +2 -2
  119. package/cjs/{HighlightText-dd11dd32.js.map → HighlightText-2061d12d.js.map} +1 -1
  120. package/cjs/Icon-0420d662.js +3 -3
  121. package/cjs/IconButton-e120d23e.js +3 -3
  122. package/cjs/IconMenuButton-64fa2ef1.js +4 -4
  123. package/cjs/IconProgressButton-d6e5198e.js +3 -3
  124. package/cjs/IconSwitchButton-7ff785b5.js +3 -3
  125. package/cjs/IconToggleButton-2661226f.js +3 -3
  126. package/cjs/{IconUserAssistance-4728958a.js → IconUserAssistance-9cb25135.js} +3 -3
  127. package/cjs/{IconUserAssistance-4728958a.js.map → IconUserAssistance-9cb25135.js.map} +1 -1
  128. package/cjs/Indexer-1dfa7ec4.js +4 -4
  129. package/cjs/InlineHelpSource-0549100d.js +1 -1
  130. package/cjs/InlineUserAssistance-5c7fe16e.js +5 -5
  131. package/cjs/InputDateMask-3642bfa3.js +7 -7
  132. package/cjs/{InputDatePicker-fe21408c.js → InputDatePicker-c2ef8b45.js} +10 -10
  133. package/cjs/{InputDatePicker-fe21408c.js.map → InputDatePicker-c2ef8b45.js.map} +1 -1
  134. package/cjs/InputPassword-ed0dcf1a.js +4 -4
  135. package/cjs/InputText-77261829.js +6 -6
  136. package/cjs/Label-47446013.js +5 -5
  137. package/cjs/LabelValueLayout-4049c1a1.js +1 -1
  138. package/cjs/{Layer-06ec1119.js → Layer-c0d7bdec.js} +3 -3
  139. package/cjs/{Layer-06ec1119.js.map → Layer-c0d7bdec.js.map} +1 -1
  140. package/cjs/{LayerHost-a8c7f182.js → LayerHost-7182bfaf.js} +2 -2
  141. package/cjs/{LayerHost-a8c7f182.js.map → LayerHost-7182bfaf.js.map} +1 -1
  142. package/cjs/{LayerManager-2d0b83ac.js → LayerManager-db087520.js} +2 -2
  143. package/cjs/{LayerManager-2d0b83ac.js.map → LayerManager-db087520.js.map} +1 -1
  144. package/cjs/Legend-fe6cc085.js +3 -3
  145. package/cjs/{LineAreaChart-70fae163.js → LineAreaChart-28268084.js} +4 -4
  146. package/cjs/{LineAreaChart-70fae163.js.map → LineAreaChart-28268084.js.map} +1 -1
  147. package/cjs/Link-41805241.js +1 -1
  148. package/cjs/List-2baf37ae.js +5 -5
  149. package/cjs/{ListItemLayout-a4f562c6.js → ListItemLayout-b29d8e9c.js} +2 -2
  150. package/cjs/{ListItemLayout-a4f562c6.js.map → ListItemLayout-b29d8e9c.js.map} +1 -1
  151. package/cjs/ListView-4db96cfd.js +3 -3
  152. package/cjs/{LiveRegion-567427c5.js → LiveRegion-3bc583c6.js} +2 -2
  153. package/cjs/{LiveRegion-567427c5.js.map → LiveRegion-3bc583c6.js.map} +1 -1
  154. package/cjs/{MaxLengthLiveRegion-f03f07c6.js → MaxLengthLiveRegion-5e31c44e.js} +3 -3
  155. package/cjs/{MaxLengthLiveRegion-f03f07c6.js.map → MaxLengthLiveRegion-5e31c44e.js.map} +1 -1
  156. package/cjs/{Menu-f3a85f19.js → Menu-748e93bd.js} +8 -8
  157. package/cjs/{Menu-f3a85f19.js.map → Menu-748e93bd.js.map} +1 -1
  158. package/cjs/MenuButton-03bc20b0.js +3 -3
  159. package/cjs/MenuItem-45d2edd5.js +1 -1
  160. package/cjs/Message-2c831019.js +2 -2
  161. package/cjs/{MessageLayer-a3792fec.js → MessageLayer-4e21820a.js} +6 -6
  162. package/cjs/{MessageLayer-a3792fec.js.map → MessageLayer-4e21820a.js.map} +1 -1
  163. package/cjs/MessageToast-3596e8d2.js +8 -8
  164. package/cjs/MessagesManager-a607a228.js +3 -3
  165. package/cjs/MeterBar-48231b79.js +5 -5
  166. package/cjs/MeterCircle-54562c98.js +5 -5
  167. package/cjs/{Modal-1c5c46ca.js → Modal-3a5d6576.js} +3 -3
  168. package/cjs/{Modal-1c5c46ca.js.map → Modal-3a5d6576.js.map} +1 -1
  169. package/cjs/{MonthView-f587275e.js → MonthView-dea031e2.js} +4 -4
  170. package/cjs/{MonthView-f587275e.js.map → MonthView-dea031e2.js.map} +1 -1
  171. package/cjs/NavigationListItem-7550547a.js +5 -5
  172. package/cjs/NumberInputText-17d50e9d.js +6 -6
  173. package/cjs/OverflowTabBarItem-76059bad.js +3 -3
  174. package/cjs/PRIVATE_BaseCardView.js +20 -20
  175. package/cjs/PRIVATE_Chart.js +34 -34
  176. package/cjs/PRIVATE_CheckboxControl.js +22 -22
  177. package/cjs/PRIVATE_CheckboxRadioField.js +23 -23
  178. package/cjs/PRIVATE_ClearIcon.js +17 -17
  179. package/cjs/PRIVATE_DatePickerHeader.js +19 -19
  180. package/cjs/PRIVATE_DatePickerLayout.js +4 -4
  181. package/cjs/PRIVATE_EmbeddedIconButton.js +3 -3
  182. package/cjs/PRIVATE_FormControls.js +19 -19
  183. package/cjs/PRIVATE_IconSwitchButton.js +15 -15
  184. package/cjs/PRIVATE_Icons/CheckboxMixed.js +15 -15
  185. package/cjs/PRIVATE_Icons/CheckboxOff.js +15 -15
  186. package/cjs/PRIVATE_Icons/CheckboxOn.js +15 -15
  187. package/cjs/PRIVATE_Icons/RadiobuttonOff.js +15 -15
  188. package/cjs/PRIVATE_Icons/RadiobuttonOn.js +15 -15
  189. package/cjs/PRIVATE_Icons/WarningS.js +15 -15
  190. package/cjs/PRIVATE_List.js +19 -19
  191. package/cjs/PRIVATE_Message.js +18 -18
  192. package/cjs/PRIVATE_MessageLayer.js +11 -11
  193. package/cjs/PRIVATE_MonthView.js +7 -7
  194. package/cjs/PRIVATE_MonthYearGridView.js +7 -7
  195. package/cjs/PRIVATE_PlotArea.js +4 -4
  196. package/cjs/PRIVATE_RevealToggleIcon.js +16 -16
  197. package/cjs/PRIVATE_SelectCommon.js +27 -27
  198. package/cjs/PRIVATE_StyledCheckbox.js +15 -15
  199. package/cjs/PRIVATE_Table.js +18 -18
  200. package/cjs/PRIVATE_ThemedIcons/CalendarIcon.js +15 -15
  201. package/cjs/PRIVATE_ThemedIcons/ChartMarqueeSelectIcon.js +15 -15
  202. package/cjs/PRIVATE_ThemedIcons/ChartPanIcon.js +15 -15
  203. package/cjs/PRIVATE_ThemedIcons/ChartZoomIcon.js +15 -15
  204. package/cjs/PRIVATE_ThemedIcons/CheckIcon.js +15 -15
  205. package/cjs/PRIVATE_ThemedIcons/CheckboxMixedIcon.js +15 -15
  206. package/cjs/PRIVATE_ThemedIcons/CheckboxOffIcon.js +15 -15
  207. package/cjs/PRIVATE_ThemedIcons/CheckboxOnIcon.js +15 -15
  208. package/cjs/PRIVATE_ThemedIcons/CloseIcon.js +15 -15
  209. package/cjs/PRIVATE_ThemedIcons/CollapseIcon.js +16 -16
  210. package/cjs/PRIVATE_ThemedIcons/CollapseUpIcon.js +15 -15
  211. package/cjs/PRIVATE_ThemedIcons/DecrementIcon.js +15 -15
  212. package/cjs/PRIVATE_ThemedIcons/DeleteIcon.js +15 -15
  213. package/cjs/PRIVATE_ThemedIcons/DirectionalCollapseArrowIcon.js +16 -16
  214. package/cjs/PRIVATE_ThemedIcons/DirectionalExpandArrowIcon.js +16 -16
  215. package/cjs/PRIVATE_ThemedIcons/DropdownArrowIcon.js +15 -15
  216. package/cjs/PRIVATE_ThemedIcons/ExpandIcon.js +15 -15
  217. package/cjs/PRIVATE_ThemedIcons/HelpIcon.js +15 -15
  218. package/cjs/PRIVATE_ThemedIcons/IncrementIcon.js +15 -15
  219. package/cjs/PRIVATE_ThemedIcons/MenuButtonDropdownIcon.js +15 -15
  220. package/cjs/PRIVATE_ThemedIcons/MessageConfirmationIcon.js +15 -15
  221. package/cjs/PRIVATE_ThemedIcons/MessageErrorIcon.js +15 -15
  222. package/cjs/PRIVATE_ThemedIcons/MessageInfoIcon.js +15 -15
  223. package/cjs/PRIVATE_ThemedIcons/MessageWarningIcon.js +15 -15
  224. package/cjs/PRIVATE_ThemedIcons/MinusIcon.js +15 -15
  225. package/cjs/PRIVATE_ThemedIcons/NavDownIcon.js +15 -15
  226. package/cjs/PRIVATE_ThemedIcons/PlusIcon.js +15 -15
  227. package/cjs/PRIVATE_ThemedIcons/RadioOffIcon.js +15 -15
  228. package/cjs/PRIVATE_ThemedIcons/RadioOnIcon.js +15 -15
  229. package/cjs/PRIVATE_ThemedIcons/SortAscendingIcon.js +15 -15
  230. package/cjs/PRIVATE_ThemedIcons/SortDefaultIcon.js +15 -15
  231. package/cjs/PRIVATE_ThemedIcons/SortDescendingIcon.js +15 -15
  232. package/cjs/PRIVATE_ThemedIcons/ViewHideIcon.js +15 -15
  233. package/cjs/PRIVATE_ThemedIcons/ViewIcon.js +15 -15
  234. package/cjs/PRIVATE_TimeComponent.js +18 -18
  235. package/cjs/PRIVATE_VisTabularDatatip.js +4 -4
  236. package/cjs/PictoChart-e9be6f36.js +6 -6
  237. package/cjs/{PieChart-31a4d639.js → PieChart-6d6e6330.js} +5 -5
  238. package/cjs/{PieChart-31a4d639.js.map → PieChart-6d6e6330.js.map} +1 -1
  239. package/cjs/{Popup-5bf59d47.js → Popup-cc742f4a.js} +9 -9
  240. package/cjs/{Popup-5bf59d47.js.map → Popup-cc742f4a.js.map} +1 -1
  241. package/cjs/{ProgressBar-8a5dc398.js → ProgressBar-3fa6bb2c.js} +3 -3
  242. package/cjs/{ProgressBar-8a5dc398.js.map → ProgressBar-3fa6bb2c.js.map} +1 -1
  243. package/cjs/ProgressButton-b33d7947.js +3 -3
  244. package/cjs/ProgressButtonLabelLayout-26719e28.js +3 -3
  245. package/cjs/{ProgressCircle-ea17b6f7.js → ProgressCircle-d5c3fb49.js} +2 -2
  246. package/cjs/{ProgressCircle-ea17b6f7.js.map → ProgressCircle-d5c3fb49.js.map} +1 -1
  247. package/cjs/RadioItem-b15d604f.js +6 -6
  248. package/cjs/RatingGauge-0e0b34d4.js +7 -7
  249. package/cjs/ReadonlyTextFieldInput-af4ddced.js +1 -1
  250. package/cjs/ReadonlyTextFieldVariants.styles.css +20 -20
  251. package/cjs/ReadonlyTextFieldVariants.styles2.css +20 -20
  252. package/cjs/RemovableNavigationListItem-727e53e8.js +1 -1
  253. package/cjs/RemovableTabBarItem-da075122.js +2 -2
  254. package/cjs/ReorderableTabBar-ded69f11.js +2 -2
  255. package/cjs/RevealToggleIcon-02ef5d24.js +1 -1
  256. package/cjs/SectionalLegend-fba43a68.js +4 -4
  257. package/cjs/{SectionedContent-855ddd57.js → SectionedContent-97955b41.js} +5 -5
  258. package/cjs/{SectionedContent-855ddd57.js.map → SectionedContent-97955b41.js.map} +1 -1
  259. package/cjs/SelectMultiple-2d4eba14.js +8 -8
  260. package/cjs/SelectSingle-731c2ecd.js +7 -7
  261. package/cjs/{SelectionCard-f26fdc87.js → SelectionCard-45a56f1b.js} +2 -2
  262. package/cjs/{SelectionCard-f26fdc87.js.map → SelectionCard-45a56f1b.js.map} +1 -1
  263. package/cjs/Selector-66230e31.js +1 -1
  264. package/cjs/{SelectorAll-f391f675.js → SelectorAll-f2d03afc.js} +7 -7
  265. package/cjs/{SelectorAll-f391f675.js.map → SelectorAll-f2d03afc.js.map} +1 -1
  266. package/cjs/{Sheet-d9371321.js → Sheet-1650f94c.js} +3 -3
  267. package/cjs/{Sheet-d9371321.js.map → Sheet-1650f94c.js.map} +1 -1
  268. package/cjs/SplitMenuButton-0cf8e5a6.js +3 -3
  269. package/cjs/StyledTextField-c9e9ba81.js +3 -3
  270. package/cjs/Submenu-fbcfb818.js +1 -1
  271. package/cjs/TabBar-c13ce35f.js +6 -6
  272. package/cjs/TabBarItem-5a7d5d03.js +3 -3
  273. package/cjs/TabBarLayout-846a4d9a.js +1 -1
  274. package/cjs/TabBarMixed-81309400.js +6 -6
  275. package/cjs/{TabBarMixedSeparator-0e258647.js → TabBarMixedSeparator-0f55c6f6.js} +2 -2
  276. package/cjs/{TabBarMixedSeparator-0e258647.js.map → TabBarMixedSeparator-0f55c6f6.js.map} +1 -1
  277. package/cjs/Table-b137c360.js +8 -8
  278. package/cjs/TagCloud-013c9587.js +9 -9
  279. package/cjs/TextArea-096f18ad.js +5 -5
  280. package/cjs/TextAreaAutosize-4d30faec.js +5 -5
  281. package/cjs/TextField-bb91aeef.js +3 -3
  282. package/cjs/TextFieldInput-a2e8dd01.js +1 -1
  283. package/cjs/Theme-redwood/theme.css +193 -193
  284. package/cjs/Theme-stable/theme.css +329 -329
  285. package/cjs/TimeComponentCanvas2D-4de3cd67.js +5 -5
  286. package/cjs/Toolbar-3be490b0.js +1 -1
  287. package/cjs/{TruncatingBadge-bc95a171.js → TruncatingBadge-6e6a04cd.js} +4 -4
  288. package/cjs/{TruncatingBadge-bc95a171.js.map → TruncatingBadge-6e6a04cd.js.map} +1 -1
  289. package/cjs/{TruncatingText-ba11c4fe.js → TruncatingText-c7ab9968.js} +4 -4
  290. package/cjs/{TruncatingText-ba11c4fe.js.map → TruncatingText-c7ab9968.js.map} +1 -1
  291. package/cjs/UNSAFE_ActionCard.js +2 -2
  292. package/cjs/UNSAFE_BarChart/__test__/BarChart.spec.js +35 -35
  293. package/cjs/UNSAFE_BarChart.js +35 -35
  294. package/cjs/UNSAFE_BaseButton.js +3 -3
  295. package/cjs/UNSAFE_Button.js +3 -3
  296. package/cjs/UNSAFE_ButtonLayout/tests/ButtonLayout.spec.js +19 -19
  297. package/cjs/UNSAFE_ButtonSet.js +4 -4
  298. package/cjs/UNSAFE_ButtonSetButton.js +3 -3
  299. package/cjs/UNSAFE_ButtonSetIconButton.js +15 -15
  300. package/cjs/UNSAFE_ButtonSetItem.js +15 -15
  301. package/cjs/UNSAFE_ButtonSetMultiple.js +4 -4
  302. package/cjs/UNSAFE_ButtonSetSingle.js +4 -4
  303. package/cjs/UNSAFE_CardFlexView.js +20 -20
  304. package/cjs/UNSAFE_CardGridView.js +20 -20
  305. package/cjs/UNSAFE_Center.js +5 -5
  306. package/cjs/UNSAFE_ChartWithLegend.js +4 -4
  307. package/cjs/UNSAFE_Checkbox.js +22 -22
  308. package/cjs/UNSAFE_CheckboxItem.js +23 -23
  309. package/cjs/UNSAFE_CheckboxSet.js +22 -22
  310. package/cjs/UNSAFE_Chip.js +2 -2
  311. package/cjs/UNSAFE_Collapsible.js +17 -17
  312. package/cjs/UNSAFE_ComponentMessage.js +18 -18
  313. package/cjs/UNSAFE_ConveyorBelt.js +15 -15
  314. package/cjs/UNSAFE_DatePicker.js +24 -24
  315. package/cjs/UNSAFE_Diagram.js +15 -15
  316. package/cjs/UNSAFE_Dialog.js +11 -11
  317. package/cjs/UNSAFE_DragHandle.js +16 -16
  318. package/cjs/UNSAFE_DrawerLayout.js +15 -13
  319. package/cjs/UNSAFE_DrawerLayout.js.map +1 -1
  320. package/cjs/UNSAFE_DrawerPopup.js +10 -10
  321. package/cjs/UNSAFE_Dropdown.js +12 -12
  322. package/cjs/UNSAFE_Environment.js +4 -4
  323. package/cjs/UNSAFE_ExpandableList.js +22 -22
  324. package/cjs/UNSAFE_FilePicker.js +4 -4
  325. package/cjs/UNSAFE_Flex.js +4 -4
  326. package/cjs/UNSAFE_Floating.js +10 -10
  327. package/cjs/UNSAFE_FormLayout.js +2 -2
  328. package/cjs/UNSAFE_Gantt.js +22 -22
  329. package/cjs/UNSAFE_Grid.js +4 -4
  330. package/cjs/UNSAFE_HighlightText.js +4 -4
  331. package/cjs/UNSAFE_Icon.js +15 -15
  332. package/cjs/UNSAFE_IconButton.js +15 -15
  333. package/cjs/UNSAFE_IconMenuButton.js +19 -19
  334. package/cjs/UNSAFE_IconProgressButton.js +19 -19
  335. package/cjs/UNSAFE_IconToggleButton.js +15 -15
  336. package/cjs/UNSAFE_Indexer.js +6 -6
  337. package/cjs/UNSAFE_InputDateMask.js +23 -23
  338. package/cjs/UNSAFE_InputDatePicker.js +111 -111
  339. package/cjs/UNSAFE_InputPassword.js +22 -22
  340. package/cjs/UNSAFE_InputSensitiveText.js +24 -24
  341. package/cjs/UNSAFE_InputText.js +25 -25
  342. package/cjs/UNSAFE_Label.js +22 -22
  343. package/cjs/UNSAFE_LabelValueLayout.js +4 -4
  344. package/cjs/UNSAFE_LabelledLink.js +24 -24
  345. package/cjs/UNSAFE_Layer.js +7 -7
  346. package/cjs/UNSAFE_Legend.js +22 -22
  347. package/cjs/UNSAFE_LineAreaChart/__test__/LineChart.spec.js +34 -34
  348. package/cjs/UNSAFE_LineAreaChart.js +35 -35
  349. package/cjs/UNSAFE_Link.js +2 -2
  350. package/cjs/UNSAFE_ListItemLayout.js +5 -5
  351. package/cjs/UNSAFE_ListView.js +25 -25
  352. package/cjs/UNSAFE_LiveRegion.js +4 -4
  353. package/cjs/UNSAFE_Menu.js +21 -21
  354. package/cjs/UNSAFE_MenuButton.js +19 -19
  355. package/cjs/UNSAFE_MessageBanner.js +18 -18
  356. package/cjs/UNSAFE_MessageToast.js +21 -21
  357. package/cjs/UNSAFE_MeterBar.js +16 -16
  358. package/cjs/UNSAFE_MeterCircle.js +16 -16
  359. package/cjs/UNSAFE_Modal.js +7 -7
  360. package/cjs/UNSAFE_NavigationList.js +19 -19
  361. package/cjs/UNSAFE_NavigationListCommon.js +17 -17
  362. package/cjs/UNSAFE_NumberInputText.js +24 -24
  363. package/cjs/UNSAFE_OverflowTabBar.js +24 -24
  364. package/cjs/UNSAFE_PictoChart.js +13 -13
  365. package/cjs/UNSAFE_PieChart/__test__/PieChart.spec.js +14 -14
  366. package/cjs/UNSAFE_PieChart.js +14 -14
  367. package/cjs/UNSAFE_Popup.js +15 -15
  368. package/cjs/UNSAFE_ProgressBar.js +5 -5
  369. package/cjs/UNSAFE_ProgressButton.js +19 -19
  370. package/cjs/UNSAFE_ProgressButtonLabelLayout.js +10 -10
  371. package/cjs/UNSAFE_ProgressCircle.js +4 -4
  372. package/cjs/UNSAFE_RadioItem.js +22 -22
  373. package/cjs/UNSAFE_RadioSet.js +22 -22
  374. package/cjs/UNSAFE_RatingGauge.js +16 -16
  375. package/cjs/UNSAFE_ReorderableTabBar.js +21 -21
  376. package/cjs/UNSAFE_SectionalLegend.js +23 -23
  377. package/cjs/UNSAFE_SelectMultiple.js +30 -30
  378. package/cjs/UNSAFE_SelectSingle.js +30 -30
  379. package/cjs/UNSAFE_SelectionCard.js +4 -4
  380. package/cjs/UNSAFE_Selector.js +15 -15
  381. package/cjs/UNSAFE_SelectorAll.js +19 -19
  382. package/cjs/UNSAFE_Sheet/__test__/Sheet.spec.js +13 -13
  383. package/cjs/UNSAFE_Sheet.js +10 -10
  384. package/cjs/UNSAFE_SplitMenuButton.js +19 -19
  385. package/cjs/UNSAFE_TabBar.js +25 -25
  386. package/cjs/UNSAFE_TabBarCommon.js +24 -24
  387. package/cjs/UNSAFE_TabBarMixed.js +28 -28
  388. package/cjs/UNSAFE_TableView.js +18 -18
  389. package/cjs/UNSAFE_TagCloud.js +22 -22
  390. package/cjs/UNSAFE_TextArea.js +24 -24
  391. package/cjs/UNSAFE_TextAreaAutosize.js +24 -24
  392. package/cjs/UNSAFE_TextField.js +7 -7
  393. package/cjs/UNSAFE_ToggleButton.js +3 -3
  394. package/cjs/UNSAFE_Toolbar/tests/Toolbar.spec.js +21 -21
  395. package/cjs/UNSAFE_Toolbar.js +4 -4
  396. package/cjs/UNSAFE_Train.js +16 -16
  397. package/cjs/UNSAFE_TruncatingBadge.js +17 -17
  398. package/cjs/UNSAFE_TruncatingText.js +17 -17
  399. package/cjs/UNSAFE_UserAssistance.js +23 -23
  400. package/cjs/UNSAFE_View.js +7 -7
  401. package/cjs/UNSAFE_VirtualizedListView.js +19 -19
  402. package/cjs/UNSAFE_VisProgressiveLoader/__test__/VisProgressiveLoader.spec.js +8 -8
  403. package/cjs/UNSAFE_VisProgressiveLoader.js +6 -6
  404. package/cjs/UNSAFE_VisStatusMessage.js +6 -6
  405. package/cjs/UNSAFE_WindowOverlay.js +4 -4
  406. package/cjs/{View-5930179e.js → View-145a402d.js} +5 -5
  407. package/cjs/{View-5930179e.js.map → View-145a402d.js.map} +1 -1
  408. package/cjs/{VisNoData-2a2477d9.js → VisNoData-d9717007.js} +3 -3
  409. package/cjs/{VisNoData-2a2477d9.js.map → VisNoData-d9717007.js.map} +1 -1
  410. package/cjs/{VisProgressiveLoader-dacfe618.js → VisProgressiveLoader-5ed4eb9d.js} +3 -3
  411. package/cjs/{VisProgressiveLoader-dacfe618.js.map → VisProgressiveLoader-5ed4eb9d.js.map} +1 -1
  412. package/cjs/{VisTabularDatatip-eca8aa8f.js → VisTabularDatatip-a06f4ca3.js} +2 -2
  413. package/cjs/{VisTabularDatatip-eca8aa8f.js.map → VisTabularDatatip-a06f4ca3.js.map} +1 -1
  414. package/cjs/{WindowOverlay-06408f56.js → WindowOverlay-de3bd373.js} +2 -2
  415. package/cjs/{WindowOverlay-06408f56.js.map → WindowOverlay-de3bd373.js.map} +1 -1
  416. package/cjs/{YearsGridView-a80db2d0.js → YearsGridView-c0c0a96d.js} +4 -4
  417. package/cjs/{YearsGridView-a80db2d0.js.map → YearsGridView-c0c0a96d.js.map} +1 -1
  418. package/cjs/hoc/PRIVATE_withDirectionIcon.js +4 -4
  419. package/cjs/hoc/PRIVATE_withThemeIcon.js +3 -3
  420. package/cjs/hoc/UNSAFE_withThemeProps.js +3 -3
  421. package/cjs/hooks/PRIVATE_useChartContextMenu.js +18 -18
  422. package/cjs/hooks/PRIVATE_useChartDatatip.js +13 -13
  423. package/cjs/hooks/PRIVATE_useChartEvents.js +17 -17
  424. package/cjs/hooks/PRIVATE_useChartMarquee.js +17 -17
  425. package/cjs/hooks/PRIVATE_useCssVars.js +7 -7
  426. package/cjs/hooks/PRIVATE_useCurrentKey.js +4 -4
  427. package/cjs/hooks/PRIVATE_useDatatip.js +11 -11
  428. package/cjs/hooks/PRIVATE_useFloating.js +4 -4
  429. package/cjs/hooks/PRIVATE_useReorderable.js +4 -4
  430. package/cjs/hooks/PRIVATE_useRovingTabIndexContainer.js +4 -4
  431. package/cjs/hooks/PRIVATE_useSelection.js +4 -4
  432. package/cjs/hooks/PRIVATE_useTabBar.js +5 -5
  433. package/cjs/hooks/PRIVATE_useVisContextMenu.js +18 -18
  434. package/cjs/hooks/PRIVATE_useVisEvents.js +4 -4
  435. package/cjs/hooks/PRIVATE_useVisMeterEvents.js +13 -13
  436. package/cjs/hooks/PRIVATE_useVisSelection.js +12 -12
  437. package/cjs/hooks/UNSAFE_useColorScheme.js +3 -3
  438. package/cjs/hooks/UNSAFE_useCurrentBgColor.js +3 -3
  439. package/cjs/hooks/UNSAFE_useDensity.js +3 -3
  440. package/cjs/hooks/UNSAFE_useOutsideClick.js +7 -7
  441. package/cjs/hooks/UNSAFE_usePrefixSuffix.js +4 -4
  442. package/cjs/hooks/UNSAFE_useScale.js +3 -3
  443. package/cjs/hooks/UNSAFE_useTestId.js +3 -3
  444. package/cjs/hooks/UNSAFE_useTheme.js +3 -3
  445. package/cjs/hooks/UNSAFE_useThemeInterpolations.js +5 -5
  446. package/cjs/hooks/UNSAFE_useTooltip.js +16 -16
  447. package/cjs/hooks/UNSAFE_useTranslationBundle.js +3 -3
  448. package/cjs/hooks/UNSAFE_useUser.js +3 -3
  449. package/cjs/{index-3be205e4.js → index-0693e95d.js} +2 -2
  450. package/cjs/index-0693e95d.js.map +1 -0
  451. package/cjs/listViewSelectionTests-b4a48819.js +4 -4
  452. package/cjs/{render-1f26ad67.js → render-0c893805.js} +3 -3
  453. package/cjs/{render-1f26ad67.js.map → render-0c893805.js.map} +1 -1
  454. package/cjs/{tabbableUtils-885d29a2.js → tabbableUtils-63f5918b.js} +3 -3
  455. package/cjs/{tabbableUtils-885d29a2.js.map → tabbableUtils-63f5918b.js.map} +1 -1
  456. package/cjs/{testData-d3502546.js → testData-f0b1927d.js} +3 -3
  457. package/cjs/{testData-d3502546.js.map → testData-f0b1927d.js.map} +1 -1
  458. package/cjs/{tooltipUtils-80224e2c.js → tooltipUtils-7857f698.js} +5 -5
  459. package/cjs/{tooltipUtils-80224e2c.js.map → tooltipUtils-7857f698.js.map} +1 -1
  460. package/cjs/useCellNavigation-6f7cd4c8.js +1 -1
  461. package/cjs/useChartContextMenu-1b415a9b.js +3 -3
  462. package/cjs/{useChartDatatip-95ef7e3b.js → useChartDatatip-bbe0ccc2.js} +4 -4
  463. package/cjs/{useChartDatatip-95ef7e3b.js.map → useChartDatatip-bbe0ccc2.js.map} +1 -1
  464. package/cjs/useChartMarquee-0900e36a.js +1 -1
  465. package/cjs/{useColorScheme-ce2a88b1.js → useColorScheme-e6bef5a4.js} +2 -2
  466. package/cjs/{useColorScheme-ce2a88b1.js.map → useColorScheme-e6bef5a4.js.map} +1 -1
  467. package/cjs/useContextMenu-0b63c292.js +3 -3
  468. package/cjs/{useCssVars-bd95e715.js → useCssVars-9bea15a9.js} +5 -5
  469. package/cjs/{useCssVars-bd95e715.js.map → useCssVars-9bea15a9.js.map} +1 -1
  470. package/cjs/{useCurrentBgColor-6e39eb3a.js → useCurrentBgColor-6835bf45.js} +2 -2
  471. package/cjs/{useCurrentBgColor-6e39eb3a.js.map → useCurrentBgColor-6835bf45.js.map} +1 -1
  472. package/cjs/{useCurrentKey-821dd4cf.js → useCurrentKey-3c1736a2.js} +2 -2
  473. package/cjs/{useCurrentKey-821dd4cf.js.map → useCurrentKey-3c1736a2.js.map} +1 -1
  474. package/cjs/{useDatatip-3d87ecae.js → useDatatip-36741e5a.js} +4 -4
  475. package/cjs/{useDatatip-3d87ecae.js.map → useDatatip-36741e5a.js.map} +1 -1
  476. package/cjs/{useDensity-1f8cc921.js → useDensity-38283c57.js} +2 -2
  477. package/cjs/{useDensity-1f8cc921.js.map → useDensity-38283c57.js.map} +1 -1
  478. package/cjs/{useFloating-f89e60f9.js → useFloating-2b73fcfb.js} +2 -2
  479. package/cjs/{useFloating-f89e60f9.js.map → useFloating-2b73fcfb.js.map} +1 -1
  480. package/cjs/{useKeyboardEvents-5e808fe3.js → useKeyboardEvents-7ab0d8ee.js} +2 -2
  481. package/cjs/{useKeyboardEvents-5e808fe3.js.map → useKeyboardEvents-7ab0d8ee.js.map} +1 -1
  482. package/cjs/useLegendContextMenu-44b38b7d.js +5 -5
  483. package/cjs/{useMeterDatatip-bb4cbbdb.js → useMeterDatatip-7a14c350.js} +3 -3
  484. package/cjs/{useMeterDatatip-bb4cbbdb.js.map → useMeterDatatip-7a14c350.js.map} +1 -1
  485. package/cjs/{useOutsideClick-fe4d642b.js → useOutsideClick-cc17641a.js} +2 -2
  486. package/cjs/{useOutsideClick-fe4d642b.js.map → useOutsideClick-cc17641a.js.map} +1 -1
  487. package/cjs/{usePopupAnimation-db67ce3c.js → usePopupAnimation-c88cbb64.js} +2 -2
  488. package/cjs/{usePopupAnimation-db67ce3c.js.map → usePopupAnimation-c88cbb64.js.map} +1 -1
  489. package/cjs/{usePrefixSuffix-23341de3.js → usePrefixSuffix-1de3a724.js} +2 -2
  490. package/cjs/{usePrefixSuffix-23341de3.js.map → usePrefixSuffix-1de3a724.js.map} +1 -1
  491. package/cjs/useReorderableItem-bd9f073e.js +2 -2
  492. package/cjs/{useRovingTabIndexContainer-1e61d935.js → useRovingTabIndexContainer-fcf1e77b.js} +2 -2
  493. package/cjs/{useRovingTabIndexContainer-1e61d935.js.map → useRovingTabIndexContainer-fcf1e77b.js.map} +1 -1
  494. package/cjs/{useScale-a681a5cb.js → useScale-a47864b4.js} +2 -2
  495. package/cjs/{useScale-a681a5cb.js.map → useScale-a47864b4.js.map} +1 -1
  496. package/cjs/useSelectCommon-12313cdd.js +11 -11
  497. package/cjs/{useSelectDrill-46b40346.js → useSelectDrill-fef4f69b.js} +3 -3
  498. package/cjs/{useSelectDrill-46b40346.js.map → useSelectDrill-fef4f69b.js.map} +1 -1
  499. package/cjs/{useSelection-b45ea7ae.js → useSelection-53bc100d.js} +2 -2
  500. package/cjs/{useSelection-b45ea7ae.js.map → useSelection-53bc100d.js.map} +1 -1
  501. package/cjs/{useSelection-c2d93034.js → useSelection-82cc9108.js} +5 -5
  502. package/cjs/{useSelection-c2d93034.js.map → useSelection-82cc9108.js.map} +1 -1
  503. package/cjs/{useTabBar-336e81bf.js → useTabBar-c4835f2d.js} +2 -2
  504. package/cjs/{useTabBar-336e81bf.js.map → useTabBar-c4835f2d.js.map} +1 -1
  505. package/cjs/{useTestId-5e6af45d.js → useTestId-e267a39d.js} +2 -2
  506. package/cjs/{useTestId-5e6af45d.js.map → useTestId-e267a39d.js.map} +1 -1
  507. package/cjs/{useTheme-8fb5546b.js → useTheme-6cedf9c8.js} +2 -2
  508. package/cjs/{useTheme-8fb5546b.js.map → useTheme-6cedf9c8.js.map} +1 -1
  509. package/cjs/{useThemeInterpolations-799504a1.js → useThemeInterpolations-67125573.js} +4 -4
  510. package/cjs/{useThemeInterpolations-799504a1.js.map → useThemeInterpolations-67125573.js.map} +1 -1
  511. package/cjs/{useTooltip-f27c5cd0.js → useTooltip-e96e07ae.js} +2 -2
  512. package/cjs/{useTooltip-f27c5cd0.js.map → useTooltip-e96e07ae.js.map} +1 -1
  513. package/cjs/{useTooltipControlled-31213955.js → useTooltipControlled-24a9c567.js} +5 -5
  514. package/cjs/{useTooltipControlled-31213955.js.map → useTooltipControlled-24a9c567.js.map} +1 -1
  515. package/cjs/{useTranslationBundle-51f4c22c.js → useTranslationBundle-6b0281a9.js} +2 -2
  516. package/cjs/{useTranslationBundle-51f4c22c.js.map → useTranslationBundle-6b0281a9.js.map} +1 -1
  517. package/cjs/{useUser-a4bfc560.js → useUser-8aaad5a7.js} +2 -2
  518. package/cjs/{useUser-a4bfc560.js.map → useUser-8aaad5a7.js.map} +1 -1
  519. package/cjs/{useVisEvents-fe2344c8.js → useVisEvents-63ddac11.js} +2 -2
  520. package/cjs/{useVisEvents-fe2344c8.js.map → useVisEvents-63ddac11.js.map} +1 -1
  521. package/cjs/utils/PRIVATE_tooltipUtils.js +13 -13
  522. package/cjs/utils/PRIVATE_visTestUtils.js +5 -5
  523. package/cjs/{withDirectionIcon-1affce30.js → withDirectionIcon-7f758093.js} +2 -2
  524. package/cjs/{withDirectionIcon-1affce30.js.map → withDirectionIcon-7f758093.js.map} +1 -1
  525. package/cjs/withThemeProps-6e15f1c3.js +2 -2
  526. package/es/ActionCard-ba1c946e.js +1 -1
  527. package/es/{BarChart-c68a559c.js → BarChart-cbd9c2bf.js} +4 -4
  528. package/es/{BarChart-c68a559c.js.map → BarChart-cbd9c2bf.js.map} +1 -1
  529. package/es/BaseButton-5a3335d9.js +2 -2
  530. package/es/BaseCardView-e0e8a69b.js +6 -6
  531. package/es/{BaseCardViewSelectionTest-120542e8.js → BaseCardViewSelectionTest-2159b609.js} +6 -6
  532. package/es/{BaseCardViewSelectionTest-120542e8.js.map → BaseCardViewSelectionTest-2159b609.js.map} +1 -1
  533. package/es/{useNavigationListItem-31226722.js → BaseNavigationListItem-ac7ef3c3.js} +41 -3
  534. package/es/BaseNavigationListItem-ac7ef3c3.js.map +1 -0
  535. package/es/ButtonLayoutVariants.styles.css +2 -2
  536. package/es/ButtonLayoutVariants.styles2.css +2 -2
  537. package/es/ButtonSet-ac76e6e2.js +2 -2
  538. package/es/ButtonSetIconButton-9241b9fb.js +3 -3
  539. package/es/{Center-8b48ab02.js → Center-9f355d44.js} +2 -2
  540. package/es/{Center-8b48ab02.js.map → Center-9f355d44.js.map} +1 -1
  541. package/es/{Chart-f2438968.js → Chart-8922a0b3.js} +11 -11
  542. package/es/{Chart-f2438968.js.map → Chart-8922a0b3.js.map} +1 -1
  543. package/es/CheckboxControl-f5e36d0d.js +6 -6
  544. package/es/CheckboxRadioField-bdda2573.js +6 -6
  545. package/es/Chip-f2df2078.js +1 -1
  546. package/es/ClearIcon-b5083cc8.js +1 -1
  547. package/es/CollapseIcon-de129943.js +1 -1
  548. package/es/Collapsible-09cc493a.js +2 -2
  549. package/es/CompactHelpSource-1686edf6.js +2 -2
  550. package/es/{CompactLabelAssistance-fa8264fa.js → CompactLabelAssistance-61df6dbf.js} +5 -5
  551. package/es/{CompactLabelAssistance-fa8264fa.js.map → CompactLabelAssistance-61df6dbf.js.map} +1 -1
  552. package/es/CompactUserAssistance-3a10afd4.js +4 -4
  553. package/es/ComponentMessageContainer-18e7fe34.js +4 -4
  554. package/es/ConveyorBeltItem-c8d4ba1b.js +2 -2
  555. package/es/{DatePicker-26b8d37b.js → DatePicker-d4e027c2.js} +6 -6
  556. package/es/{DatePicker-26b8d37b.js.map → DatePicker-d4e027c2.js.map} +1 -1
  557. package/es/DatePickerHeader-79f0b61b.js +3 -3
  558. package/es/{Diagram-6f1ad2ea.js → Diagram-d7fdc75f.js} +5 -5
  559. package/es/{Diagram-6f1ad2ea.js.map → Diagram-d7fdc75f.js.map} +1 -1
  560. package/es/{Dialog-5e92dcd1.js → Dialog-cf69547f.js} +6 -6
  561. package/es/{Dialog-5e92dcd1.js.map → Dialog-cf69547f.js.map} +1 -1
  562. package/es/DirectionalCollapseArrowIcon-20259aab.js +1 -1
  563. package/es/DirectionalExpandArrowIcon-36ba273c.js +1 -1
  564. package/es/DragHandle-3b768189.js +1 -1
  565. package/es/DrawerLayoutStyles.styles.css +1 -0
  566. package/es/{Dropdown-f45f823c.js → Dropdown-d017dd0a.js} +5 -5
  567. package/es/{Dropdown-f45f823c.js.map → Dropdown-d017dd0a.js.map} +1 -1
  568. package/es/{EnvironmentProvider-0fc2fd0c.js → EnvironmentProvider-a3819bde.js} +3 -3
  569. package/es/{EnvironmentProvider-0fc2fd0c.js.map → EnvironmentProvider-a3819bde.js.map} +1 -1
  570. package/es/FilePicker-f4582615.js +2 -2
  571. package/es/{Flex-8696b27b.js → Flex-2d51e914.js} +2 -2
  572. package/es/{Flex-8696b27b.js.map → Flex-2d51e914.js.map} +1 -1
  573. package/es/{Floating-f9bbd276.js → Floating-aebc0f85.js} +4 -4
  574. package/es/{Floating-f9bbd276.js.map → Floating-aebc0f85.js.map} +1 -1
  575. package/es/FormLayout-221e1aa8.js +1 -1
  576. package/es/Gantt-46f5f954.js +9 -9
  577. package/es/{Grid-7fd29a9e.js → Grid-c2385b22.js} +2 -2
  578. package/es/{Grid-7fd29a9e.js.map → Grid-c2385b22.js.map} +1 -1
  579. package/es/{Gridlines-dcdc34bc.js → Gridlines-0e7b33f5.js} +2 -2
  580. package/es/{Gridlines-dcdc34bc.js.map → Gridlines-0e7b33f5.js.map} +1 -1
  581. package/es/GroupLoadingIndicator-2bfdba44.js +1 -1
  582. package/es/{HighlightText-cc043982.js → HighlightText-d505bf35.js} +2 -2
  583. package/es/{HighlightText-cc043982.js.map → HighlightText-d505bf35.js.map} +1 -1
  584. package/es/Icon-4171c0d7.js +3 -3
  585. package/es/IconButton-451a225c.js +3 -3
  586. package/es/IconMenuButton-e46f8d54.js +4 -4
  587. package/es/IconProgressButton-8f2f6b27.js +3 -3
  588. package/es/IconSwitchButton-5ff7b0fe.js +3 -3
  589. package/es/IconToggleButton-375f006f.js +3 -3
  590. package/es/{IconUserAssistance-dd56b812.js → IconUserAssistance-7cfd1ed2.js} +3 -3
  591. package/es/{IconUserAssistance-dd56b812.js.map → IconUserAssistance-7cfd1ed2.js.map} +1 -1
  592. package/es/Indexer-658cee69.js +4 -4
  593. package/es/InlineHelpSource-fcdcd122.js +1 -1
  594. package/es/InlineUserAssistance-e6deb149.js +5 -5
  595. package/es/InputDateMask-3d511e39.js +7 -7
  596. package/es/{InputDatePicker-6a5d95c8.js → InputDatePicker-81a18a57.js} +10 -10
  597. package/es/{InputDatePicker-6a5d95c8.js.map → InputDatePicker-81a18a57.js.map} +1 -1
  598. package/es/InputPassword-47130b3c.js +4 -4
  599. package/es/InputText-4799b2ed.js +6 -6
  600. package/es/Label-ab276ca9.js +5 -5
  601. package/es/LabelValueLayout-bcf482be.js +1 -1
  602. package/es/{Layer-71fc666f.js → Layer-915d986a.js} +3 -3
  603. package/es/{Layer-71fc666f.js.map → Layer-915d986a.js.map} +1 -1
  604. package/es/{LayerHost-15b42a3e.js → LayerHost-7a2149f5.js} +2 -2
  605. package/es/{LayerHost-15b42a3e.js.map → LayerHost-7a2149f5.js.map} +1 -1
  606. package/es/{LayerManager-af39e736.js → LayerManager-be34be40.js} +2 -2
  607. package/es/{LayerManager-af39e736.js.map → LayerManager-be34be40.js.map} +1 -1
  608. package/es/Legend-ae0296f0.js +3 -3
  609. package/es/{LineAreaChart-3a7bc509.js → LineAreaChart-85b37b1c.js} +4 -4
  610. package/es/{LineAreaChart-3a7bc509.js.map → LineAreaChart-85b37b1c.js.map} +1 -1
  611. package/es/Link-9072aa54.js +1 -1
  612. package/es/List-1d23e84f.js +5 -5
  613. package/es/{ListItemLayout-32895900.js → ListItemLayout-01286b56.js} +2 -2
  614. package/es/{ListItemLayout-32895900.js.map → ListItemLayout-01286b56.js.map} +1 -1
  615. package/es/ListView-8eba90e8.js +3 -3
  616. package/es/{LiveRegion-cb4f8a54.js → LiveRegion-5302331c.js} +2 -2
  617. package/es/{LiveRegion-cb4f8a54.js.map → LiveRegion-5302331c.js.map} +1 -1
  618. package/es/{MaxLengthLiveRegion-59087064.js → MaxLengthLiveRegion-9b386b63.js} +3 -3
  619. package/es/{MaxLengthLiveRegion-59087064.js.map → MaxLengthLiveRegion-9b386b63.js.map} +1 -1
  620. package/es/{Menu-b5deea24.js → Menu-e44a3e0b.js} +8 -8
  621. package/es/{Menu-b5deea24.js.map → Menu-e44a3e0b.js.map} +1 -1
  622. package/es/MenuButton-49b7965d.js +3 -3
  623. package/es/MenuItem-be46866f.js +1 -1
  624. package/es/Message-322f8d63.js +2 -2
  625. package/es/{MessageLayer-34a390eb.js → MessageLayer-f09b0a1b.js} +6 -6
  626. package/es/{MessageLayer-34a390eb.js.map → MessageLayer-f09b0a1b.js.map} +1 -1
  627. package/es/MessageToast-66bdffe6.js +8 -8
  628. package/es/MessagesManager-a1c3e92e.js +3 -3
  629. package/es/MeterBar-9ad34b98.js +5 -5
  630. package/es/MeterCircle-6bd257c8.js +5 -5
  631. package/es/{Modal-3fd86d5a.js → Modal-862b8167.js} +3 -3
  632. package/es/{Modal-3fd86d5a.js.map → Modal-862b8167.js.map} +1 -1
  633. package/es/{MonthView-7521b583.js → MonthView-3d90f424.js} +5 -5
  634. package/es/{MonthView-7521b583.js.map → MonthView-3d90f424.js.map} +1 -1
  635. package/es/{NavigationList-d8f472fe.js → NavigationListItem-a336f06f.js} +22 -5
  636. package/es/NavigationListItem-a336f06f.js.map +1 -0
  637. package/es/NavigationListItemVariants.styles.css +5 -5
  638. package/es/NavigationListItemVariants.styles2.css +5 -5
  639. package/es/NumberInputText-eca11601.js +6 -6
  640. package/es/{OverflowTabBar-5f7698bb.js → OverflowTabBar-7d5212e3.js} +3 -3
  641. package/es/{OverflowTabBar-5f7698bb.js.map → OverflowTabBar-7d5212e3.js.map} +1 -1
  642. package/es/{OverflowTabBarItem-c0ef2c6b.js → OverflowTabBarItem-12249753.js} +6 -7
  643. package/es/{OverflowTabBarItem-c0ef2c6b.js.map → OverflowTabBarItem-12249753.js.map} +1 -1
  644. package/es/PRIVATE_BaseCardView.js +20 -20
  645. package/es/PRIVATE_Chart.js +34 -34
  646. package/es/PRIVATE_CheckboxControl.js +22 -22
  647. package/es/PRIVATE_CheckboxRadioField.js +23 -23
  648. package/es/PRIVATE_ClearIcon.js +17 -17
  649. package/es/PRIVATE_DatePickerHeader.js +19 -19
  650. package/es/PRIVATE_DatePickerLayout.js +4 -4
  651. package/es/PRIVATE_EmbeddedIconButton.js +3 -3
  652. package/es/PRIVATE_FormControls.js +19 -19
  653. package/es/PRIVATE_IconSwitchButton.js +15 -15
  654. package/es/PRIVATE_Icons/CheckboxMixed.js +15 -15
  655. package/es/PRIVATE_Icons/CheckboxOff.js +15 -15
  656. package/es/PRIVATE_Icons/CheckboxOn.js +15 -15
  657. package/es/PRIVATE_Icons/RadiobuttonOff.js +15 -15
  658. package/es/PRIVATE_Icons/RadiobuttonOn.js +15 -15
  659. package/es/PRIVATE_Icons/WarningS.js +15 -15
  660. package/es/PRIVATE_List.js +19 -19
  661. package/es/PRIVATE_Message.js +18 -18
  662. package/es/PRIVATE_MessageLayer.js +11 -11
  663. package/es/PRIVATE_MonthView.js +15 -15
  664. package/es/PRIVATE_MonthYearGridView.js +13 -13
  665. package/es/PRIVATE_PlotArea.js +4 -4
  666. package/es/PRIVATE_RevealToggleIcon.js +16 -16
  667. package/es/PRIVATE_SelectCommon.js +27 -27
  668. package/es/PRIVATE_StyledCheckbox.js +15 -15
  669. package/es/PRIVATE_Table.js +18 -18
  670. package/es/PRIVATE_ThemedIcons/CalendarIcon.js +15 -15
  671. package/es/PRIVATE_ThemedIcons/ChartMarqueeSelectIcon.js +15 -15
  672. package/es/PRIVATE_ThemedIcons/ChartPanIcon.js +15 -15
  673. package/es/PRIVATE_ThemedIcons/ChartZoomIcon.js +15 -15
  674. package/es/PRIVATE_ThemedIcons/CheckIcon.js +15 -15
  675. package/es/PRIVATE_ThemedIcons/CheckboxMixedIcon.js +15 -15
  676. package/es/PRIVATE_ThemedIcons/CheckboxOffIcon.js +15 -15
  677. package/es/PRIVATE_ThemedIcons/CheckboxOnIcon.js +15 -15
  678. package/es/PRIVATE_ThemedIcons/CloseIcon.js +15 -15
  679. package/es/PRIVATE_ThemedIcons/CollapseIcon.js +16 -16
  680. package/es/PRIVATE_ThemedIcons/CollapseUpIcon.js +15 -15
  681. package/es/PRIVATE_ThemedIcons/DecrementIcon.js +15 -15
  682. package/es/PRIVATE_ThemedIcons/DeleteIcon.js +15 -15
  683. package/es/PRIVATE_ThemedIcons/DirectionalCollapseArrowIcon.js +16 -16
  684. package/es/PRIVATE_ThemedIcons/DirectionalExpandArrowIcon.js +16 -16
  685. package/es/PRIVATE_ThemedIcons/DropdownArrowIcon.js +15 -15
  686. package/es/PRIVATE_ThemedIcons/ExpandIcon.js +15 -15
  687. package/es/PRIVATE_ThemedIcons/HelpIcon.js +15 -15
  688. package/es/PRIVATE_ThemedIcons/IncrementIcon.js +15 -15
  689. package/es/PRIVATE_ThemedIcons/MenuButtonDropdownIcon.js +15 -15
  690. package/es/PRIVATE_ThemedIcons/MessageConfirmationIcon.js +15 -15
  691. package/es/PRIVATE_ThemedIcons/MessageErrorIcon.js +15 -15
  692. package/es/PRIVATE_ThemedIcons/MessageInfoIcon.js +15 -15
  693. package/es/PRIVATE_ThemedIcons/MessageWarningIcon.js +15 -15
  694. package/es/PRIVATE_ThemedIcons/MinusIcon.js +15 -15
  695. package/es/PRIVATE_ThemedIcons/NavDownIcon.js +15 -15
  696. package/es/PRIVATE_ThemedIcons/PlusIcon.js +15 -15
  697. package/es/PRIVATE_ThemedIcons/RadioOffIcon.js +15 -15
  698. package/es/PRIVATE_ThemedIcons/RadioOnIcon.js +15 -15
  699. package/es/PRIVATE_ThemedIcons/SortAscendingIcon.js +15 -15
  700. package/es/PRIVATE_ThemedIcons/SortDefaultIcon.js +15 -15
  701. package/es/PRIVATE_ThemedIcons/SortDescendingIcon.js +15 -15
  702. package/es/PRIVATE_ThemedIcons/ViewHideIcon.js +15 -15
  703. package/es/PRIVATE_ThemedIcons/ViewIcon.js +15 -15
  704. package/es/PRIVATE_TimeComponent.js +18 -18
  705. package/es/PRIVATE_VisTabularDatatip.js +4 -4
  706. package/es/PictoChart-3dd90503.js +6 -6
  707. package/es/{PieChart-cdb56906.js → PieChart-d4f63bd8.js} +5 -5
  708. package/es/{PieChart-cdb56906.js.map → PieChart-d4f63bd8.js.map} +1 -1
  709. package/es/{Popup-8becd87a.js → Popup-7cc4028b.js} +9 -9
  710. package/es/{Popup-8becd87a.js.map → Popup-7cc4028b.js.map} +1 -1
  711. package/es/{ProgressBar-2565d814.js → ProgressBar-d647bba4.js} +3 -3
  712. package/es/{ProgressBar-2565d814.js.map → ProgressBar-d647bba4.js.map} +1 -1
  713. package/es/ProgressButton-645ce827.js +3 -3
  714. package/es/ProgressButtonLabelLayout-6cf150e0.js +3 -3
  715. package/es/{ProgressCircle-c7f945c0.js → ProgressCircle-13dc0e4f.js} +2 -2
  716. package/es/{ProgressCircle-c7f945c0.js.map → ProgressCircle-13dc0e4f.js.map} +1 -1
  717. package/es/RadioItem-af1bbece.js +6 -6
  718. package/es/RatingGauge-82a6a416.js +7 -7
  719. package/es/ReadonlyTextFieldInput-a15badb6.js +1 -1
  720. package/es/{RemovableNavigationListItem-1675a880.js → RemovableNavigationListItem-7032ce3e.js} +3 -4
  721. package/es/{RemovableNavigationListItem-1675a880.js.map → RemovableNavigationListItem-7032ce3e.js.map} +1 -1
  722. package/es/RemovableTabBarItem-16d04210.js +2 -2
  723. package/es/{ReorderableTabBar-8b432272.js → ReorderableTabBar-981af0f2.js} +4 -4
  724. package/es/{ReorderableTabBar-8b432272.js.map → ReorderableTabBar-981af0f2.js.map} +1 -1
  725. package/es/RevealToggleIcon-563c241c.js +1 -1
  726. package/es/SectionalLegend-a9b719ff.js +4 -4
  727. package/es/{SectionedContent-237bf539.js → SectionedContent-7e36073f.js} +5 -5
  728. package/es/{SectionedContent-237bf539.js.map → SectionedContent-7e36073f.js.map} +1 -1
  729. package/es/SelectMultiple-c1264885.js +8 -8
  730. package/es/SelectSingle-8336ec24.js +7 -7
  731. package/es/{SelectionCard-1711aae6.js → SelectionCard-a27bce15.js} +2 -2
  732. package/es/{SelectionCard-1711aae6.js.map → SelectionCard-a27bce15.js.map} +1 -1
  733. package/es/Selector-9f40e909.js +1 -1
  734. package/es/{SelectorAll-42ce8707.js → SelectorAll-40c76f0b.js} +7 -7
  735. package/es/{SelectorAll-42ce8707.js.map → SelectorAll-40c76f0b.js.map} +1 -1
  736. package/es/{Sheet-f7117b12.js → Sheet-34f3bcb4.js} +3 -3
  737. package/es/{Sheet-f7117b12.js.map → Sheet-34f3bcb4.js.map} +1 -1
  738. package/es/SplitMenuButton-74913bcc.js +3 -3
  739. package/es/StyledTextField-9df27ab4.js +3 -3
  740. package/es/Submenu-c6663c1d.js +1 -1
  741. package/es/{TabBar-dd778e55.js → TabBar-90cea652.js} +7 -12
  742. package/es/{TabBar-dd778e55.js.map → TabBar-90cea652.js.map} +1 -1
  743. package/es/TabBarItem-ba695c75.js +3 -3
  744. package/es/TabBarLayout-8caaa060.js +1 -1
  745. package/es/{TabBarMixed-995f2781.js → TabBarMixed-52ac388e.js} +7 -12
  746. package/es/{TabBarMixed-995f2781.js.map → TabBarMixed-52ac388e.js.map} +1 -1
  747. package/es/{TabBarMixedSeparator-da56f4c0.js → TabBarMixedSeparator-16c88691.js} +2 -2
  748. package/es/{TabBarMixedSeparator-da56f4c0.js.map → TabBarMixedSeparator-16c88691.js.map} +1 -1
  749. package/es/Table-3d484e2c.js +8 -8
  750. package/es/TagCloud-823b3d82.js +9 -9
  751. package/es/TextArea-6f18b955.js +5 -5
  752. package/es/TextAreaAutosize-4cf2754b.js +5 -5
  753. package/es/TextField-d4b4661d.js +3 -3
  754. package/es/TextFieldInput-84280715.js +1 -1
  755. package/es/Theme-redwood/theme.css +377 -377
  756. package/es/Theme-stable/theme.css +446 -446
  757. package/es/TimeComponentCanvas2D-72f4af98.js +5 -5
  758. package/es/Toolbar-85379f64.js +1 -1
  759. package/es/{TruncatingBadge-7eb77ed3.js → TruncatingBadge-e5f38bc8.js} +4 -4
  760. package/es/{TruncatingBadge-7eb77ed3.js.map → TruncatingBadge-e5f38bc8.js.map} +1 -1
  761. package/es/{TruncatingText-93807530.js → TruncatingText-c3719839.js} +4 -4
  762. package/es/{TruncatingText-93807530.js.map → TruncatingText-c3719839.js.map} +1 -1
  763. package/es/UNSAFE_ActionCard.js +2 -2
  764. package/es/UNSAFE_BarChart/__test__/BarChart.spec.js +35 -35
  765. package/es/UNSAFE_BarChart.js +35 -35
  766. package/es/UNSAFE_BaseButton.js +3 -3
  767. package/es/UNSAFE_Button.js +3 -3
  768. package/es/UNSAFE_ButtonLayout/tests/ButtonLayout.spec.js +20 -20
  769. package/es/UNSAFE_ButtonLayout/themes/redwood/ButtonLayoutTheme.js +1 -1
  770. package/es/UNSAFE_ButtonLayout/themes/redwood/ButtonLayoutVariants.css.js +1 -1
  771. package/es/UNSAFE_ButtonLayout/themes/stable/ButtonLayoutTheme.js +1 -1
  772. package/es/UNSAFE_ButtonLayout/themes/stable/ButtonLayoutVariants.css.js +1 -1
  773. package/es/UNSAFE_ButtonLayout.js +1 -1
  774. package/es/UNSAFE_ButtonSet.js +4 -4
  775. package/es/UNSAFE_ButtonSetButton.js +3 -3
  776. package/es/UNSAFE_ButtonSetIconButton.js +15 -15
  777. package/es/UNSAFE_ButtonSetItem.js +15 -15
  778. package/es/UNSAFE_ButtonSetMultiple.js +4 -4
  779. package/es/UNSAFE_ButtonSetSingle.js +4 -4
  780. package/es/UNSAFE_CardFlexView.js +20 -20
  781. package/es/UNSAFE_CardGridView.js +20 -20
  782. package/es/UNSAFE_Center.js +5 -5
  783. package/es/UNSAFE_ChartWithLegend.js +4 -4
  784. package/es/UNSAFE_Checkbox.js +22 -22
  785. package/es/UNSAFE_CheckboxItem.js +23 -23
  786. package/es/UNSAFE_CheckboxSet.js +22 -22
  787. package/es/UNSAFE_Chip.js +2 -2
  788. package/es/UNSAFE_Collapsible.js +17 -17
  789. package/es/UNSAFE_ComponentMessage.js +18 -18
  790. package/es/UNSAFE_ConveyorBelt.js +15 -15
  791. package/es/UNSAFE_DatePicker.js +27 -27
  792. package/es/UNSAFE_Diagram.js +15 -15
  793. package/es/UNSAFE_Dialog.js +11 -11
  794. package/es/UNSAFE_DragHandle.js +16 -16
  795. package/es/UNSAFE_DrawerLayout.js +15 -13
  796. package/es/UNSAFE_DrawerLayout.js.map +1 -1
  797. package/es/UNSAFE_DrawerPopup.js +10 -10
  798. package/es/UNSAFE_Dropdown.js +12 -12
  799. package/es/UNSAFE_Environment.js +4 -4
  800. package/es/UNSAFE_ExpandableList.js +22 -22
  801. package/es/UNSAFE_FilePicker.js +4 -4
  802. package/es/UNSAFE_Flex.js +4 -4
  803. package/es/UNSAFE_Floating.js +10 -10
  804. package/es/UNSAFE_FormLayout.js +2 -2
  805. package/es/UNSAFE_Gantt.js +22 -22
  806. package/es/UNSAFE_Grid.js +4 -4
  807. package/es/UNSAFE_HighlightText.js +4 -4
  808. package/es/UNSAFE_Icon.js +15 -15
  809. package/es/UNSAFE_IconButton.js +15 -15
  810. package/es/UNSAFE_IconMenuButton.js +19 -19
  811. package/es/UNSAFE_IconProgressButton.js +19 -19
  812. package/es/UNSAFE_IconToggleButton.js +15 -15
  813. package/es/UNSAFE_Indexer.js +6 -6
  814. package/es/UNSAFE_InputDateMask.js +23 -23
  815. package/es/UNSAFE_InputDatePicker.js +112 -112
  816. package/es/UNSAFE_InputPassword.js +22 -22
  817. package/es/UNSAFE_InputSensitiveText.js +24 -24
  818. package/es/UNSAFE_InputText.js +25 -25
  819. package/es/UNSAFE_Label.js +22 -22
  820. package/es/UNSAFE_LabelValueLayout.js +4 -4
  821. package/es/UNSAFE_LabelledLink.js +24 -24
  822. package/es/UNSAFE_Layer.js +7 -7
  823. package/es/UNSAFE_Legend.js +22 -22
  824. package/es/UNSAFE_LineAreaChart/__test__/LineChart.spec.js +34 -34
  825. package/es/UNSAFE_LineAreaChart.js +35 -35
  826. package/es/UNSAFE_Link.js +2 -2
  827. package/es/UNSAFE_ListItemLayout.js +5 -5
  828. package/es/UNSAFE_ListView.js +25 -25
  829. package/es/UNSAFE_LiveRegion.js +4 -4
  830. package/es/UNSAFE_Menu.js +21 -21
  831. package/es/UNSAFE_MenuButton.js +19 -19
  832. package/es/UNSAFE_MessageBanner.js +18 -18
  833. package/es/UNSAFE_MessageToast.js +21 -21
  834. package/es/UNSAFE_MeterBar.js +16 -16
  835. package/es/UNSAFE_MeterCircle.js +16 -16
  836. package/es/UNSAFE_Modal.js +7 -7
  837. package/es/UNSAFE_NavigationList/themes/redwood/NavigationListItemVariants.css.js +1 -1
  838. package/es/UNSAFE_NavigationList/themes/stable/NavigationListItemTheme.js +1 -1
  839. package/es/UNSAFE_NavigationList/themes/stable/NavigationListItemVariants.css.js +1 -1
  840. package/es/UNSAFE_NavigationList.js +33 -35
  841. package/es/UNSAFE_NavigationList.js.map +1 -1
  842. package/es/UNSAFE_NavigationListCommon/themes/redwood/NavigationListItemTheme.js +1 -1
  843. package/es/UNSAFE_NavigationListCommon.js +67 -68
  844. package/es/UNSAFE_NavigationListCommon.js.map +1 -1
  845. package/es/UNSAFE_NumberInputText.js +24 -24
  846. package/es/UNSAFE_OverflowTabBar.js +50 -52
  847. package/es/UNSAFE_OverflowTabBar.js.map +1 -1
  848. package/es/UNSAFE_PictoChart.js +13 -13
  849. package/es/UNSAFE_PieChart/__test__/PieChart.spec.js +14 -14
  850. package/es/UNSAFE_PieChart.js +14 -14
  851. package/es/UNSAFE_Popup.js +15 -15
  852. package/es/UNSAFE_ProgressBar.js +5 -5
  853. package/es/UNSAFE_ProgressButton.js +19 -19
  854. package/es/UNSAFE_ProgressButtonLabelLayout.js +10 -10
  855. package/es/UNSAFE_ProgressCircle.js +4 -4
  856. package/es/UNSAFE_RadioItem.js +22 -22
  857. package/es/UNSAFE_RadioSet.js +22 -22
  858. package/es/UNSAFE_RatingGauge.js +16 -16
  859. package/es/UNSAFE_ReorderableTabBar.js +29 -45
  860. package/es/UNSAFE_ReorderableTabBar.js.map +1 -1
  861. package/es/UNSAFE_SectionalLegend.js +23 -23
  862. package/es/UNSAFE_SelectMultiple.js +30 -30
  863. package/es/UNSAFE_SelectSingle.js +30 -30
  864. package/es/UNSAFE_SelectionCard.js +4 -4
  865. package/es/UNSAFE_Selector.js +15 -15
  866. package/es/UNSAFE_SelectorAll.js +19 -19
  867. package/es/UNSAFE_Sheet/__test__/Sheet.spec.js +13 -13
  868. package/es/UNSAFE_Sheet.js +10 -10
  869. package/es/UNSAFE_SplitMenuButton.js +19 -19
  870. package/es/UNSAFE_TabBar.js +50 -52
  871. package/es/UNSAFE_TabBar.js.map +1 -1
  872. package/es/UNSAFE_TabBarCommon.js +41 -43
  873. package/es/UNSAFE_TabBarCommon.js.map +1 -1
  874. package/es/UNSAFE_TabBarMixed.js +53 -55
  875. package/es/UNSAFE_TabBarMixed.js.map +1 -1
  876. package/es/UNSAFE_TableView.js +18 -18
  877. package/es/UNSAFE_TagCloud.js +22 -22
  878. package/es/UNSAFE_TextArea.js +24 -24
  879. package/es/UNSAFE_TextAreaAutosize.js +24 -24
  880. package/es/UNSAFE_TextField.js +7 -7
  881. package/es/UNSAFE_ToggleButton.js +3 -3
  882. package/es/UNSAFE_Toolbar/tests/Toolbar.spec.js +22 -22
  883. package/es/UNSAFE_Toolbar.js +5 -5
  884. package/es/UNSAFE_Train.js +16 -16
  885. package/es/UNSAFE_TruncatingBadge.js +17 -17
  886. package/es/UNSAFE_TruncatingText.js +17 -17
  887. package/es/UNSAFE_UserAssistance.js +23 -23
  888. package/es/UNSAFE_View.js +7 -7
  889. package/es/UNSAFE_VirtualizedListView.js +19 -19
  890. package/es/UNSAFE_VisProgressiveLoader/__test__/VisProgressiveLoader.spec.js +8 -8
  891. package/es/UNSAFE_VisProgressiveLoader.js +6 -6
  892. package/es/UNSAFE_VisStatusMessage.js +6 -6
  893. package/es/UNSAFE_WindowOverlay.js +4 -4
  894. package/es/{View-63980a9b.js → View-a8a64eb1.js} +5 -5
  895. package/es/{View-63980a9b.js.map → View-a8a64eb1.js.map} +1 -1
  896. package/es/{VisNoData-da540cbd.js → VisNoData-673b58e9.js} +3 -3
  897. package/es/{VisNoData-da540cbd.js.map → VisNoData-673b58e9.js.map} +1 -1
  898. package/es/{VisProgressiveLoader-2b2103c8.js → VisProgressiveLoader-66dde1ff.js} +3 -3
  899. package/es/{VisProgressiveLoader-2b2103c8.js.map → VisProgressiveLoader-66dde1ff.js.map} +1 -1
  900. package/es/{VisTabularDatatip-2ae7ee48.js → VisTabularDatatip-6aa607bb.js} +2 -2
  901. package/es/{VisTabularDatatip-2ae7ee48.js.map → VisTabularDatatip-6aa607bb.js.map} +1 -1
  902. package/es/{WindowOverlay-9b43e658.js → WindowOverlay-de5d0819.js} +2 -2
  903. package/es/{WindowOverlay-9b43e658.js.map → WindowOverlay-de5d0819.js.map} +1 -1
  904. package/es/{YearsGridView-e3bde50c.js → YearsGridView-5b5c1746.js} +5 -5
  905. package/es/{YearsGridView-e3bde50c.js.map → YearsGridView-5b5c1746.js.map} +1 -1
  906. package/es/hoc/PRIVATE_withDirectionIcon.js +4 -4
  907. package/es/hoc/PRIVATE_withThemeIcon.js +3 -3
  908. package/es/hoc/UNSAFE_withThemeProps.js +3 -3
  909. package/es/hooks/PRIVATE_useChartContextMenu.js +18 -18
  910. package/es/hooks/PRIVATE_useChartDatatip.js +13 -13
  911. package/es/hooks/PRIVATE_useChartEvents.js +17 -17
  912. package/es/hooks/PRIVATE_useChartMarquee.js +17 -17
  913. package/es/hooks/PRIVATE_useCssVars.js +7 -7
  914. package/es/hooks/PRIVATE_useCurrentKey.js +4 -4
  915. package/es/hooks/PRIVATE_useDatatip.js +11 -11
  916. package/es/hooks/PRIVATE_useFloating.js +4 -4
  917. package/es/hooks/PRIVATE_useReorderable.js +4 -4
  918. package/es/hooks/PRIVATE_useRovingTabIndexContainer.js +4 -4
  919. package/es/hooks/PRIVATE_useSelection.js +4 -4
  920. package/es/hooks/PRIVATE_useTabBar.js +5 -5
  921. package/es/hooks/PRIVATE_useVisContextMenu.js +18 -18
  922. package/es/hooks/PRIVATE_useVisEvents.js +4 -4
  923. package/es/hooks/PRIVATE_useVisMeterEvents.js +13 -13
  924. package/es/hooks/PRIVATE_useVisSelection.js +12 -12
  925. package/es/hooks/UNSAFE_useColorScheme.js +3 -3
  926. package/es/hooks/UNSAFE_useContainerBreakpointValues.js +1 -1
  927. package/es/hooks/UNSAFE_useCurrentBgColor.js +3 -3
  928. package/es/hooks/UNSAFE_useDensity.js +3 -3
  929. package/es/hooks/UNSAFE_useOutsideClick.js +7 -7
  930. package/es/hooks/UNSAFE_usePrefixSuffix.js +4 -4
  931. package/es/hooks/UNSAFE_useScale.js +3 -3
  932. package/es/hooks/UNSAFE_useTestId.js +3 -3
  933. package/es/hooks/UNSAFE_useTheme.js +3 -3
  934. package/es/hooks/UNSAFE_useThemeInterpolations.js +5 -5
  935. package/es/hooks/UNSAFE_useTooltip.js +16 -16
  936. package/es/hooks/UNSAFE_useTranslationBundle.js +3 -3
  937. package/es/hooks/UNSAFE_useUser.js +3 -3
  938. package/es/{index-e65c9009.js → index-fee93bf9.js} +2 -2
  939. package/es/index-fee93bf9.js.map +1 -0
  940. package/es/listViewSelectionTests-0dfdcc5d.js +4 -4
  941. package/es/{render-ff141a3d.js → render-d92a7051.js} +3 -3
  942. package/es/{render-ff141a3d.js.map → render-d92a7051.js.map} +1 -1
  943. package/es/{tabbableUtils-375a33ee.js → tabbableUtils-1b4c2eea.js} +3 -3
  944. package/es/{tabbableUtils-375a33ee.js.map → tabbableUtils-1b4c2eea.js.map} +1 -1
  945. package/es/{testData-748c19ef.js → testData-ca9503e6.js} +3 -3
  946. package/es/{testData-748c19ef.js.map → testData-ca9503e6.js.map} +1 -1
  947. package/es/{tooltipUtils-1131b3ca.js → tooltipUtils-06c93436.js} +5 -5
  948. package/es/{tooltipUtils-1131b3ca.js.map → tooltipUtils-06c93436.js.map} +1 -1
  949. package/es/useCellNavigation-00d575ca.js +1 -1
  950. package/es/useChartContextMenu-8c49f584.js +3 -3
  951. package/es/{useChartDatatip-25f6bc69.js → useChartDatatip-82dba484.js} +4 -4
  952. package/es/{useChartDatatip-25f6bc69.js.map → useChartDatatip-82dba484.js.map} +1 -1
  953. package/es/useChartMarquee-08025a83.js +1 -1
  954. package/es/{useColorScheme-d8a80e2b.js → useColorScheme-f69d53b5.js} +2 -2
  955. package/es/{useColorScheme-d8a80e2b.js.map → useColorScheme-f69d53b5.js.map} +1 -1
  956. package/es/useContextMenu-12845847.js +3 -3
  957. package/es/{useCssVars-8e6932f8.js → useCssVars-48595cd2.js} +5 -5
  958. package/es/{useCssVars-8e6932f8.js.map → useCssVars-48595cd2.js.map} +1 -1
  959. package/es/{useCurrentBgColor-5418492b.js → useCurrentBgColor-894d059b.js} +2 -2
  960. package/es/{useCurrentBgColor-5418492b.js.map → useCurrentBgColor-894d059b.js.map} +1 -1
  961. package/es/{useCurrentKey-76e7d7b1.js → useCurrentKey-55123e83.js} +2 -2
  962. package/es/{useCurrentKey-76e7d7b1.js.map → useCurrentKey-55123e83.js.map} +1 -1
  963. package/es/{useDatatip-73566627.js → useDatatip-01d7ddeb.js} +4 -4
  964. package/es/{useDatatip-73566627.js.map → useDatatip-01d7ddeb.js.map} +1 -1
  965. package/es/{useDensity-64ecb649.js → useDensity-04a01caf.js} +2 -2
  966. package/es/{useDensity-64ecb649.js.map → useDensity-04a01caf.js.map} +1 -1
  967. package/es/{useFloating-d60cc8b4.js → useFloating-c9278755.js} +2 -2
  968. package/es/{useFloating-d60cc8b4.js.map → useFloating-c9278755.js.map} +1 -1
  969. package/es/{useKeyboardEvents-5c311766.js → useKeyboardEvents-b02e5fda.js} +2 -2
  970. package/es/{useKeyboardEvents-5c311766.js.map → useKeyboardEvents-b02e5fda.js.map} +1 -1
  971. package/es/useLegendContextMenu-926aca66.js +5 -5
  972. package/es/{useMeterDatatip-2cedbd5c.js → useMeterDatatip-43e31c05.js} +3 -3
  973. package/es/{useMeterDatatip-2cedbd5c.js.map → useMeterDatatip-43e31c05.js.map} +1 -1
  974. package/es/{useOutsideClick-725542a2.js → useOutsideClick-388c62bd.js} +2 -2
  975. package/es/{useOutsideClick-725542a2.js.map → useOutsideClick-388c62bd.js.map} +1 -1
  976. package/es/{usePopupAnimation-340f04b6.js → usePopupAnimation-b4577940.js} +2 -2
  977. package/es/{usePopupAnimation-340f04b6.js.map → usePopupAnimation-b4577940.js.map} +1 -1
  978. package/es/{usePrefixSuffix-435a9c59.js → usePrefixSuffix-995d4cda.js} +2 -2
  979. package/es/{usePrefixSuffix-435a9c59.js.map → usePrefixSuffix-995d4cda.js.map} +1 -1
  980. package/es/useReorderableItem-c715c504.js +2 -2
  981. package/es/{useRovingTabIndexContainer-b9833086.js → useRovingTabIndexContainer-097f96a6.js} +2 -2
  982. package/es/{useRovingTabIndexContainer-b9833086.js.map → useRovingTabIndexContainer-097f96a6.js.map} +1 -1
  983. package/es/{useScale-c86ecc6e.js → useScale-3b323ab2.js} +2 -2
  984. package/es/{useScale-c86ecc6e.js.map → useScale-3b323ab2.js.map} +1 -1
  985. package/es/useSelectCommon-7ebc86eb.js +11 -11
  986. package/es/{useSelectDrill-fbe57d95.js → useSelectDrill-8b53d932.js} +3 -3
  987. package/es/{useSelectDrill-fbe57d95.js.map → useSelectDrill-8b53d932.js.map} +1 -1
  988. package/es/{useSelection-1e1e89df.js → useSelection-7c94a24f.js} +2 -2
  989. package/es/{useSelection-1e1e89df.js.map → useSelection-7c94a24f.js.map} +1 -1
  990. package/es/{useSelection-dfbd140d.js → useSelection-b7c3e75e.js} +5 -5
  991. package/es/{useSelection-dfbd140d.js.map → useSelection-b7c3e75e.js.map} +1 -1
  992. package/es/{useTabBar-b826570d.js → useTabBar-6c6847ef.js} +2 -2
  993. package/es/{useTabBar-b826570d.js.map → useTabBar-6c6847ef.js.map} +1 -1
  994. package/es/{useTestId-3bc3958c.js → useTestId-af32a9eb.js} +2 -2
  995. package/es/{useTestId-3bc3958c.js.map → useTestId-af32a9eb.js.map} +1 -1
  996. package/es/{useTheme-4b0f211c.js → useTheme-73aca0e4.js} +2 -2
  997. package/es/{useTheme-4b0f211c.js.map → useTheme-73aca0e4.js.map} +1 -1
  998. package/es/{useThemeInterpolations-41ac870d.js → useThemeInterpolations-4f6cc83c.js} +4 -4
  999. package/es/{useThemeInterpolations-41ac870d.js.map → useThemeInterpolations-4f6cc83c.js.map} +1 -1
  1000. package/es/{useTooltip-227887ea.js → useTooltip-e258ea41.js} +2 -2
  1001. package/es/{useTooltip-227887ea.js.map → useTooltip-e258ea41.js.map} +1 -1
  1002. package/es/{useTooltipControlled-7ccb5919.js → useTooltipControlled-50d5dac9.js} +5 -5
  1003. package/es/{useTooltipControlled-7ccb5919.js.map → useTooltipControlled-50d5dac9.js.map} +1 -1
  1004. package/es/{useTranslationBundle-98df6291.js → useTranslationBundle-6da03e52.js} +2 -2
  1005. package/es/{useTranslationBundle-98df6291.js.map → useTranslationBundle-6da03e52.js.map} +1 -1
  1006. package/es/{useUser-a15426fc.js → useUser-bca8cf2d.js} +2 -2
  1007. package/es/{useUser-a15426fc.js.map → useUser-bca8cf2d.js.map} +1 -1
  1008. package/es/{useVisEvents-ff4204b5.js → useVisEvents-cd3616aa.js} +2 -2
  1009. package/es/{useVisEvents-ff4204b5.js.map → useVisEvents-cd3616aa.js.map} +1 -1
  1010. package/es/utils/PRIVATE_tooltipUtils.js +13 -13
  1011. package/es/utils/PRIVATE_visTestUtils.js +6 -6
  1012. package/es/{withDirectionIcon-90d7c798.js → withDirectionIcon-389870a2.js} +2 -2
  1013. package/es/{withDirectionIcon-90d7c798.js.map → withDirectionIcon-389870a2.js.map} +1 -1
  1014. package/es/withThemeProps-6545df54.js +2 -2
  1015. package/package.json +2 -2
  1016. package/amd/CardFlexView-14fada63.js +0 -2
  1017. package/amd/CheckboxSetContext-2e486ea8.js +0 -2
  1018. package/amd/CheckboxSetContext-2e486ea8.js.map +0 -1
  1019. package/amd/List-61d64cd6.js +0 -2
  1020. package/amd/LoadMoreCollection-83413a59.js +0 -2
  1021. package/amd/TextArea-916c5bb1.js +0 -2
  1022. package/amd/TextArea-916c5bb1.js.map +0 -1
  1023. package/amd/TextAreaAutosize-1f47b470.js +0 -2
  1024. package/amd/VirtualizedListView-96ddfd98.js +0 -2
  1025. package/cjs/index-3be205e4.js.map +0 -1
  1026. package/es/BaseNavigationListItem-d2a00c8f.js +0 -47
  1027. package/es/BaseNavigationListItem-d2a00c8f.js.map +0 -1
  1028. package/es/NavigationList-d8f472fe.js.map +0 -1
  1029. package/es/NavigationListItem-20ff5d75.js +0 -10
  1030. package/es/NavigationListItem-20ff5d75.js.map +0 -1
  1031. package/es/index-e65c9009.js.map +0 -1
  1032. package/es/useNavigationListItem-31226722.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Indexer-74c989ce.js","sources":["../../src/UNSAFE_Indexer/IndexerItems.tsx","../../src/UNSAFE_Indexer/Indexer.tsx"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { Fragment } from 'preact';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { Flex } from '../UNSAFE_Flex';\nimport { useTranslationBundle } from '../hooks/UNSAFE_useTranslationBundle';\nimport type { BundleType } from '../resources/nls/bundle';\nimport { ItemContext } from 'src/UNSAFE_Collection';\nimport { forwardRef, ForwardedRef } from 'preact/compat';\nimport { useComponentTheme } from '../hooks/UNSAFE_useComponentTheme';\nimport { IndexerStyles, IndexerItemVariantOptions } from './themes/IndexerStyles.css';\nimport { IndexerRedwoodTheme } from './themes/redwood/IndexerTheme';\n\n/**\n * Type of a section\n */\nexport type Section<K> = {\n /**\n * The key of each section\n */\n key: K;\n /**\n * The label of each section\n */\n label?: string;\n /**\n * A property that indicates whether the section\n * is disabled or not. Typically, when Indexer is\n * used with ListView, a disabled section implies\n * that there's no corresponding items in the ListView\n */\n isDisabled?: boolean;\n};\n\n/**\n * The others section variable that application could use\n * to compare value\n */\n// const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\nexport const SECTION_OTHERS: Section<string> = Object.freeze({\n key: '__others__',\n label: '#'\n});\n\nexport const ITEM_SELECTOR = '[data-oj-key]';\n\nexport type SectionProps<K> = {\n context: ItemContext<Section<K>>;\n currentKey: K;\n selectedKey: K;\n valueNow: number; // the index of an item within currently visible sections\n isFocusRingVisible: boolean;\n};\n\nexport const SectionItem = forwardRef(\n <K extends string | number>(props: SectionProps<K>, ref: ForwardedRef<HTMLLIElement>) => {\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n\n const { context, selectedKey } = props;\n const isSelected = context.data.key === selectedKey;\n const commonProps = getCommonProps(props, ref);\n\n const { classes } = useComponentTheme<IndexerItemVariantOptions, IndexerStyles>(\n IndexerRedwoodTheme,\n {\n focused: commonProps.ref && commonProps.isFocusRingVisible ? 'isFocused' : 'notFocused',\n disabled: context.data.isDisabled ? 'isDisabled' : 'notDisabled',\n selected: isSelected ? 'isSelected' : 'notSelected'\n }\n );\n const itemClasses = classNames([classes]);\n\n const sectionLabel = context.data.label || context.data.key;\n const valueText = context.data.isDisabled\n ? translations.indexer_disabledLabel({ SECTION: `${sectionLabel}` })\n : `${sectionLabel}`;\n\n return (\n <li\n {...commonProps}\n class={itemClasses}\n data-oj-valuetext={valueText}\n data-oj-disabled={context.data.isDisabled}>\n {context.data.label || context.data.key}\n </li>\n );\n }\n);\n\nfunction getCommonProps<K>(\n { context, currentKey, valueNow, isFocusRingVisible }: SectionProps<K>,\n ref: ForwardedRef<HTMLLIElement>\n) {\n const isCurrent = context.data.key === currentKey;\n return {\n ...(isCurrent && { ref }),\n key: context.data.key,\n 'data-oj-key': context.data.key,\n 'data-oj-key-type': typeof context.data.key,\n 'data-oj-valuenow': valueNow,\n isFocusRingVisible: !!isFocusRingVisible\n };\n}\n\ntype LastSectionProps<K> = SectionProps<K> & {\n lastValueNow: number;\n};\n\n// render the last section, that contains the last character and others character\nexport const LastSectionItem = forwardRef(\n <K extends string | number>(\n { lastValueNow, ...sectionProps }: LastSectionProps<K>,\n ref: ForwardedRef<HTMLLIElement>\n ) => {\n const commonProps = { ...sectionProps, ref };\n return (\n <Fragment>\n <SectionItem {...commonProps} />\n <OthersItem\n {...commonProps}\n ref={ref}\n context={{ index: -1, data: SECTION_OTHERS } as ItemContext<Section<K>>}\n valueNow={lastValueNow}\n />\n </Fragment>\n );\n }\n);\n\nconst OthersItem = forwardRef(<K,>(props: SectionProps<K>, ref: ForwardedRef<HTMLLIElement>) => {\n const { context, selectedKey } = props;\n const commonProps = getCommonProps(props, ref);\n\n const isSelected = context.data.key === selectedKey;\n const { classes } = useComponentTheme<IndexerItemVariantOptions>(IndexerRedwoodTheme, {\n focused: commonProps.ref && commonProps.isFocusRingVisible ? 'isFocused' : 'notFocused',\n selected: isSelected ? 'isSelected' : 'notSelected'\n });\n const othersClasses = classNames([classes]);\n const othersValueText = SECTION_OTHERS.label;\n\n return (\n <li {...commonProps} class={othersClasses} data-oj-valuetext={othersValueText}>\n {context.data.label}\n </li>\n );\n});\n\ntype SeparatorProps<K> = SectionProps<K> & {\n sectionsPerTruncation: number;\n last: number;\n sections: Section<K>[];\n};\n\nexport const SeparatorItem = forwardRef(\n <K extends string | number>(props: SeparatorProps<K>, ref: ForwardedRef<HTMLLIElement>) => {\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n\n const { context, sections } = props;\n const commonProps = getCommonProps(props, ref);\n const { from, to } = getSeparatorRange(props);\n const {\n classes,\n styles: { dotStyle }\n } = useComponentTheme<IndexerItemVariantOptions, IndexerStyles>(IndexerRedwoodTheme, {\n focused: commonProps.ref && commonProps.isFocusRingVisible ? 'isFocused' : 'notFocused'\n });\n\n if (!isInSeparatorMiddle(context.index, from, to)) {\n return null;\n }\n\n const fromText = sections[from].label || sections[from].key;\n const toText = sections[to].label || sections[to].key;\n\n const separatorClasses = classNames([classes]);\n\n const separatorValueText = translations.indexer_separatorLabel({\n FROM_SECTION: `${fromText}`,\n TO_SECTION: `${toText}`\n });\n\n return (\n <li {...commonProps} class={separatorClasses} data-oj-valuetext={separatorValueText}>\n <Flex align=\"center\" justify=\"center\">\n <div class={dotStyle}></div>\n </Flex>\n </li>\n );\n }\n);\n\nexport function hasSeparator<K>(props: SeparatorProps<K>) {\n const { from, to } = getSeparatorRange(props);\n return isInSeparatorMiddle(props.context.index, from, to);\n}\n\nfunction getSeparatorRange<K>({ context, sectionsPerTruncation, last }: SeparatorProps<K>) {\n const from = context.index - (context.index % sectionsPerTruncation) + 1;\n let to = from + sectionsPerTruncation - 2;\n to = to >= last ? last - 1 : to;\n\n return { from, to };\n}\n\nfunction isInSeparatorMiddle(index: number, from: number, to: number) {\n return index === Math.floor((from + to) / 2);\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren, createRef, RefObject } from 'preact';\nimport { useEffect, useRef, useState, StateUpdater, useCallback, Dispatch } from 'preact/hooks';\nimport { Flex } from '../UNSAFE_Flex';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { useSingleSelection } from '../hooks/PRIVATE_useSingleSelection/useSingleSelection';\nimport { useCurrentKey } from '../hooks/PRIVATE_useCurrentKey';\nimport { useCollectionFocusRing } from '../hooks/PRIVATE_useCollectionFocusRing';\nimport { keyExtractor, getPrevNextKey, isMobile } from '../utils/PRIVATE_collectionUtils';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { useTranslationBundle } from '../hooks/UNSAFE_useTranslationBundle';\nimport type { BundleType } from '../resources/nls/bundle';\nimport { HiddenAccessible } from '../UNSAFE_HiddenAccessible';\nimport { ItemContext, CurrentKeyDetail, SingleSelectionDetail } from '../UNSAFE_Collection';\nimport { Collection } from '../PRIVATE_Collection';\nimport {\n Section,\n SectionItem,\n LastSectionItem,\n SeparatorItem,\n SECTION_OTHERS,\n hasSeparator,\n ITEM_SELECTOR\n} from './IndexerItems';\nimport { useComponentTheme } from '../hooks/UNSAFE_useComponentTheme';\nimport { IndexerStyles } from './themes/IndexerStyles.css';\nimport { IndexerRedwoodTheme } from './themes/redwood/IndexerTheme';\nimport { useTestId, TestIdProps } from '../hooks/UNSAFE_useTestId';\n\nexport type CommitDetail<K> = {\n value: K;\n};\n\ntype Props<K> = {\n /**\n * An array of sections, the default sections is an\n * array of 26 English alphabets and the # others character\n */\n sections?: Section<K>[];\n\n /**\n * The currently selected Section\n */\n value?: K;\n\n /**\n * A function that will be invoked when selection happens,\n * no matter the Section was selected before or not.\n */\n onCommit?: (detail: CommitDetail<K>) => void;\n};\n\nconst defaultSections: Section<string>[] = [\n { key: 'A' },\n { key: 'B' },\n { key: 'C' },\n { key: 'D' },\n { key: 'E' },\n { key: 'F' },\n { key: 'G' },\n { key: 'H' },\n { key: 'I' },\n { key: 'J' },\n { key: 'K' },\n { key: 'L' },\n { key: 'M' },\n { key: 'N' },\n { key: 'O' },\n { key: 'P' },\n { key: 'Q' },\n { key: 'R' },\n { key: 'S' },\n { key: 'T' },\n { key: 'U' },\n { key: 'V' },\n { key: 'W' },\n { key: 'X' },\n { key: 'Y' },\n { key: 'Z' }\n];\n\n/**\n * Pure Preact based component that consumes Collection component\n * and renders an indexer.\n */\nexport function Indexer<K extends string | number>({\n sections = defaultSections as Section<K>[],\n value,\n onCommit = () => {},\n testId\n}: Props<K> & TestIdProps) {\n const rootRef = useRef<HTMLDivElement>(null);\n const ulRef = useRef<HTMLUListElement>(null);\n const currElementRef = createRef<HTMLLIElement>();\n const [current, setCurrent] = useState<K | undefined>(sections[0]?.key);\n // the number of sections in each truncation\n const [sectionsPerTruncation, setSectionsPerTruncation] = useState<number>(-1);\n // the total number of rendered sections and separators\n const renderedSectionsCount = useRef<number>(-1);\n const itemHeightRef = useRef<number>(0);\n // the id for aria describedby\n const uniqueId = useId();\n\n const [showFocusRing, focusRingProps] = useCollectionFocusRing(rootRef, ['ArrowUp', 'ArrowDown']);\n\n const { currentKeyProps } = useCurrentKey(\n (element) => keyExtractor(element, ITEM_SELECTOR),\n true,\n getPrevNextKey(rootRef.current, current, true, ITEM_SELECTOR),\n getPrevNextKey(rootRef.current, current, false, ITEM_SELECTOR),\n undefined,\n undefined,\n current,\n (detail: CurrentKeyDetail<K>) => setCurrent(detail.value)\n );\n\n const { selectionProps } = useSingleSelection(\n (element) => handleKeyExtract(element, ulRef, current as K),\n // pass in undefined so onCommit handler will be called\n // no matter whether the Section was selected before or not\n undefined,\n (detail: SingleSelectionDetail<K>) => handleSelection(detail, onCommit, sections)\n );\n\n /**\n * Item renderer that will return a section item or a section separator\n * based on the sectionsPerTruncation and item context index.\n * @param context item context\n */\n const itemRenderer = (context: ItemContext<Section<K>>): ComponentChildren => {\n const last = sections.length - 1;\n renderedSectionsCount.current += 1;\n\n const commonProps = {\n context,\n ref: currElementRef,\n currentKey: current as K,\n selectedKey: value as K,\n valueNow: renderedSectionsCount.current,\n isFocusRingVisible: !!showFocusRing\n };\n\n // render the last and the others character, they are always present\n if (context.index === last) {\n return <LastSectionItem {...commonProps} lastValueNow={renderedSectionsCount.current + 1} />;\n }\n\n // render a section, in the non-truncation case or when it is the first in a truncation\n if (sectionsPerTruncation <= 1 || context.index % sectionsPerTruncation === 0) {\n return <SectionItem {...commonProps} />;\n }\n\n // render the separator in the middle of a truncation\n const separatorProps = { ...commonProps, sectionsPerTruncation, last, sections };\n if (hasSeparator(separatorProps)) {\n return <SeparatorItem {...separatorProps} />;\n }\n\n // remove the count for truncated sections\n renderedSectionsCount.current -= 1;\n\n return null;\n };\n\n // truncate the Indexer during resize\n const handleResize = useCallback(\n (entries: ResizeObserverEntry[]) => {\n for (const entry of entries) {\n updateSectionsPerTruncation(\n entry.contentRect.height,\n itemHeightRef.current,\n sections.length,\n sections[0]?.key,\n sectionsPerTruncation,\n setSectionsPerTruncation,\n setCurrent\n );\n }\n },\n [sections, sectionsPerTruncation]\n );\n\n useEffect(() => {\n if (ulRef.current) {\n // Get aria values from IndexerItem to update aria values on Indexer ul element\n ulRef.current.setAttribute('aria-valuemax', renderedSectionsCount.current + 1 + '');\n ulRef.current.setAttribute(\n 'aria-valuetext',\n currElementRef.current?.dataset?.['ojValuetext'] || ''\n );\n ulRef.current.setAttribute(\n 'aria-valuenow',\n currElementRef.current?.dataset?.['ojValuenow'] || ''\n );\n }\n renderedSectionsCount.current = -1;\n });\n\n /**\n * Set up the initial values for sectionsPerTruncation and event listeners\n */\n useEffect(() => {\n const root = rootRef.current;\n if (root) {\n itemHeightRef.current = root.querySelector('li')?.offsetHeight || 0;\n updateSectionsPerTruncation(\n root.offsetHeight,\n itemHeightRef.current,\n sections.length,\n sections[0]?.key,\n sectionsPerTruncation,\n setSectionsPerTruncation,\n setCurrent\n );\n }\n }, [sections, sectionsPerTruncation]);\n\n /**\n * Set up resize observer and refresh the resize observer when\n * sectionsPerTruncation is changed, otherwise it will only have the\n * old copy of sectionsPerTruncation.\n */\n useEffect(() => {\n const root = rootRef.current;\n if (root) {\n const resizeObserver = new ResizeObserver((entries: ResizeObserverEntry[]) => {\n handleResize(entries);\n });\n resizeObserver.observe(root);\n return () => {\n resizeObserver.unobserve(root);\n };\n }\n return undefined;\n }, [sectionsPerTruncation, handleResize]);\n\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n const {\n styles: { baseStyle, innerStyle }\n } = useComponentTheme<never, IndexerStyles>(IndexerRedwoodTheme);\n const testIdProps = useTestId(testId);\n\n return (\n <div ref={rootRef} class={baseStyle} {...testIdProps}>\n <Flex align=\"center\" width=\"6x\" height=\"100%\">\n <ul\n {...mergeProps(currentKeyProps, focusRingProps, selectionProps)}\n ref={ulRef}\n tabIndex={0}\n aria-label=\"Indexer\"\n aria-orientation=\"vertical\"\n aria-valuemin={0}\n aria-describedby={uniqueId}\n role=\"slider\"\n class={innerStyle}>\n <Collection items={sections}>{itemRenderer}</Collection>\n </ul>\n </Flex>\n <HiddenAccessible>\n <span id={uniqueId}>{getIndexerDescription(translations)}</span>\n </HiddenAccessible>\n </div>\n );\n}\n\n// A function to extract key for selection\nconst handleKeyExtract = <K extends string | number>(\n element: HTMLElement,\n rootRef: RefObject<HTMLElement>,\n current: K\n) => {\n if (element === rootRef.current) {\n return current === undefined ? null : current;\n }\n return keyExtractor(element, ITEM_SELECTOR) as K;\n};\n\nconst handleSelection = <K extends string | number>(\n detail: SingleSelectionDetail<K>,\n onCommit: (value: CommitDetail<K>) => void,\n sections: Section<K>[]\n) => {\n if (detail.value === SECTION_OTHERS.key) {\n onCommit({ value: SECTION_OTHERS.key as K });\n } else {\n const selectedSection = sections.find((section) => section.key === detail.value) as Section<K>;\n onCommit({ value: selectedSection.key as K });\n }\n};\n\n/**\n * A function that calculates the section count, based on\n * the container height and the number of sections\n * @param height height of Indexer container\n */\nconst updateSectionsPerTruncation = <K extends string | number>(\n height: number,\n itemHeight: number,\n sectionsLength: number,\n firstSectionKey: K,\n sectionsPerTruncation: number,\n setSectionsPerTruncation: Dispatch<StateUpdater<number>>,\n setCurrent: Dispatch<StateUpdater<K | undefined>>\n) => {\n if (height === 0 || itemHeight === 0) {\n return;\n }\n\n const maxSections = height / itemHeight;\n const last = sectionsLength - 1;\n\n // when the container size is too small to hold two sections\n if (maxSections < 2) {\n if (sectionsPerTruncation !== last) {\n setSectionsPerTruncation(last);\n setCurrent(firstSectionKey);\n }\n\n // no truncation\n // compare with < 0.01 for the deviation from calculation, when sectionsLength and maxSections\n // are about the same, maxNum === sectionsLength doesn't work\n } else if (maxSections > sectionsLength || sectionsLength - maxSections < 0.01) {\n if (sectionsPerTruncation > 1) {\n setSectionsPerTruncation(1);\n setCurrent(firstSectionKey);\n }\n\n // need truncation\n } else {\n const tempSectionCount = findSectionCount(maxSections, last);\n if (tempSectionCount !== sectionsPerTruncation && tempSectionCount < sectionsLength) {\n setSectionsPerTruncation(tempSectionCount);\n setCurrent(firstSectionKey);\n }\n }\n};\n\n/**\n * A helper function to find the best section count\n * in a truncation\n *\n * @param maxSections maximum number of sections allowed in a truncation\n * @param last the index of last section\n */\nconst findSectionCount = (maxSections: number, last: number) => {\n // need truncation\n maxSections -= 2; // minus the last character and the others character\n maxSections /= 2; // each truncation has a section and a separator\n\n const newSectionCount = Math.round(last / maxSections) + 1;\n const truncationLeftover = last % newSectionCount;\n const truncationCount = Math.floor(last / newSectionCount) + (truncationLeftover > 1 ? 1 : 0);\n\n // When the sectionCount becomes greater, it will result in\n // same truncations but with different sections appearing.\n // The following is to find the best sectionCount in this case\n // and prevent unnecessary truncations.\n let tempLeftover = last - (truncationCount - 1) * newSectionCount;\n let tempSectionCount = newSectionCount;\n while (tempSectionCount > tempLeftover) {\n tempSectionCount -= 1;\n tempLeftover = last - (truncationCount - 1) * tempSectionCount;\n }\n if (tempSectionCount != newSectionCount) {\n tempSectionCount += 1;\n }\n\n return tempSectionCount;\n};\n\n/**\n * Helper function to find the aria description for Indexer,\n * based on whether current device is a mobile device\n */\nfunction getIndexerDescription(translations: any) {\n if (isMobile()) {\n return translations.indexer_touchInstructionText();\n } else {\n return translations.indexer_keyboardInstructionText();\n }\n}\n"],"names":["SECTION_OTHERS","Object","freeze","key","label","ITEM_SELECTOR","SectionItem","forwardRef","props","ref","translations","useTranslationBundle","context","selectedKey","isSelected","data","commonProps","getCommonProps","classes","useComponentTheme","IndexerRedwoodTheme","focused","isFocusRingVisible","disabled","isDisabled","selected","itemClasses","classNames","sectionLabel","valueText","indexer_disabledLabel","SECTION","_jsx","jsx","class","children","currentKey","valueNow","LastSectionItem","lastValueNow","sectionProps","_jsxs","jsxs","Fragment","OthersItem","index","othersClasses","othersValueText","SeparatorItem","sections","from","to","getSeparatorRange","styles","dotStyle","isInSeparatorMiddle","fromText","toText","separatorClasses","separatorValueText","indexer_separatorLabel","FROM_SECTION","TO_SECTION","Flex","align","justify","sectionsPerTruncation","last","Math","floor","defaultSections","handleKeyExtract","element","rootRef","current","undefined","keyExtractor","handleSelection","detail","onCommit","value","find","section","updateSectionsPerTruncation","height","itemHeight","sectionsLength","firstSectionKey","setSectionsPerTruncation","setCurrent","maxSections","tempSectionCount","findSectionCount","newSectionCount","round","truncationLeftover","truncationCount","tempLeftover","getIndexerDescription","isMobile","indexer_touchInstructionText","indexer_keyboardInstructionText","testId","useRef","ulRef","currElementRef","createRef","useState","renderedSectionsCount","itemHeightRef","uniqueId","useId","showFocusRing","focusRingProps","useCollectionFocusRing","currentKeyProps","useCurrentKey","getPrevNextKey","selectionProps","useSingleSelection","handleResize","useCallback","entries","entry","contentRect","length","useEffect","setAttribute","dataset","root","querySelector","offsetHeight","resizeObserver","ResizeObserver","observe","unobserve","baseStyle","innerStyle","testIdProps","useTestId","width","mergeProps","tabIndex","role","Collection","items","separatorProps","hasSeparator","HiddenAccessible","id"],"mappings":"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"}
1
+ {"version":3,"file":"Indexer-6833ad40.js","sources":["../../src/UNSAFE_Indexer/IndexerItems.tsx","../../src/UNSAFE_Indexer/Indexer.tsx"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { Fragment } from 'preact';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { Flex } from '../UNSAFE_Flex';\nimport { useTranslationBundle } from '../hooks/UNSAFE_useTranslationBundle';\nimport type { BundleType } from '../resources/nls/bundle';\nimport { ItemContext } from 'src/UNSAFE_Collection';\nimport { forwardRef, ForwardedRef } from 'preact/compat';\nimport { useComponentTheme } from '../hooks/UNSAFE_useComponentTheme';\nimport { IndexerStyles, IndexerItemVariantOptions } from './themes/IndexerStyles.css';\nimport { IndexerRedwoodTheme } from './themes/redwood/IndexerTheme';\n\n/**\n * Type of a section\n */\nexport type Section<K> = {\n /**\n * The key of each section\n */\n key: K;\n /**\n * The label of each section\n */\n label?: string;\n /**\n * A property that indicates whether the section\n * is disabled or not. Typically, when Indexer is\n * used with ListView, a disabled section implies\n * that there's no corresponding items in the ListView\n */\n isDisabled?: boolean;\n};\n\n/**\n * The others section variable that application could use\n * to compare value\n */\n// const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\nexport const SECTION_OTHERS: Section<string> = Object.freeze({\n key: '__others__',\n label: '#'\n});\n\nexport const ITEM_SELECTOR = '[data-oj-key]';\n\nexport type SectionProps<K> = {\n context: ItemContext<Section<K>>;\n currentKey: K;\n selectedKey: K;\n valueNow: number; // the index of an item within currently visible sections\n isFocusRingVisible: boolean;\n};\n\nexport const SectionItem = forwardRef(\n <K extends string | number>(props: SectionProps<K>, ref: ForwardedRef<HTMLLIElement>) => {\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n\n const { context, selectedKey } = props;\n const isSelected = context.data.key === selectedKey;\n const commonProps = getCommonProps(props, ref);\n\n const { classes } = useComponentTheme<IndexerItemVariantOptions, IndexerStyles>(\n IndexerRedwoodTheme,\n {\n focused: commonProps.ref && commonProps.isFocusRingVisible ? 'isFocused' : 'notFocused',\n disabled: context.data.isDisabled ? 'isDisabled' : 'notDisabled',\n selected: isSelected ? 'isSelected' : 'notSelected'\n }\n );\n const itemClasses = classNames([classes]);\n\n const sectionLabel = context.data.label || context.data.key;\n const valueText = context.data.isDisabled\n ? translations.indexer_disabledLabel({ SECTION: `${sectionLabel}` })\n : `${sectionLabel}`;\n\n return (\n <li\n {...commonProps}\n class={itemClasses}\n data-oj-valuetext={valueText}\n data-oj-disabled={context.data.isDisabled}>\n {context.data.label || context.data.key}\n </li>\n );\n }\n);\n\nfunction getCommonProps<K>(\n { context, currentKey, valueNow, isFocusRingVisible }: SectionProps<K>,\n ref: ForwardedRef<HTMLLIElement>\n) {\n const isCurrent = context.data.key === currentKey;\n return {\n ...(isCurrent && { ref }),\n key: context.data.key,\n 'data-oj-key': context.data.key,\n 'data-oj-key-type': typeof context.data.key,\n 'data-oj-valuenow': valueNow,\n isFocusRingVisible: !!isFocusRingVisible\n };\n}\n\ntype LastSectionProps<K> = SectionProps<K> & {\n lastValueNow: number;\n};\n\n// render the last section, that contains the last character and others character\nexport const LastSectionItem = forwardRef(\n <K extends string | number>(\n { lastValueNow, ...sectionProps }: LastSectionProps<K>,\n ref: ForwardedRef<HTMLLIElement>\n ) => {\n const commonProps = { ...sectionProps, ref };\n return (\n <Fragment>\n <SectionItem {...commonProps} />\n <OthersItem\n {...commonProps}\n ref={ref}\n context={{ index: -1, data: SECTION_OTHERS } as ItemContext<Section<K>>}\n valueNow={lastValueNow}\n />\n </Fragment>\n );\n }\n);\n\nconst OthersItem = forwardRef(<K,>(props: SectionProps<K>, ref: ForwardedRef<HTMLLIElement>) => {\n const { context, selectedKey } = props;\n const commonProps = getCommonProps(props, ref);\n\n const isSelected = context.data.key === selectedKey;\n const { classes } = useComponentTheme<IndexerItemVariantOptions>(IndexerRedwoodTheme, {\n focused: commonProps.ref && commonProps.isFocusRingVisible ? 'isFocused' : 'notFocused',\n selected: isSelected ? 'isSelected' : 'notSelected'\n });\n const othersClasses = classNames([classes]);\n const othersValueText = SECTION_OTHERS.label;\n\n return (\n <li {...commonProps} class={othersClasses} data-oj-valuetext={othersValueText}>\n {context.data.label}\n </li>\n );\n});\n\ntype SeparatorProps<K> = SectionProps<K> & {\n sectionsPerTruncation: number;\n last: number;\n sections: Section<K>[];\n};\n\nexport const SeparatorItem = forwardRef(\n <K extends string | number>(props: SeparatorProps<K>, ref: ForwardedRef<HTMLLIElement>) => {\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n\n const { context, sections } = props;\n const commonProps = getCommonProps(props, ref);\n const { from, to } = getSeparatorRange(props);\n const {\n classes,\n styles: { dotStyle }\n } = useComponentTheme<IndexerItemVariantOptions, IndexerStyles>(IndexerRedwoodTheme, {\n focused: commonProps.ref && commonProps.isFocusRingVisible ? 'isFocused' : 'notFocused'\n });\n\n if (!isInSeparatorMiddle(context.index, from, to)) {\n return null;\n }\n\n const fromText = sections[from].label || sections[from].key;\n const toText = sections[to].label || sections[to].key;\n\n const separatorClasses = classNames([classes]);\n\n const separatorValueText = translations.indexer_separatorLabel({\n FROM_SECTION: `${fromText}`,\n TO_SECTION: `${toText}`\n });\n\n return (\n <li {...commonProps} class={separatorClasses} data-oj-valuetext={separatorValueText}>\n <Flex align=\"center\" justify=\"center\">\n <div class={dotStyle}></div>\n </Flex>\n </li>\n );\n }\n);\n\nexport function hasSeparator<K>(props: SeparatorProps<K>) {\n const { from, to } = getSeparatorRange(props);\n return isInSeparatorMiddle(props.context.index, from, to);\n}\n\nfunction getSeparatorRange<K>({ context, sectionsPerTruncation, last }: SeparatorProps<K>) {\n const from = context.index - (context.index % sectionsPerTruncation) + 1;\n let to = from + sectionsPerTruncation - 2;\n to = to >= last ? last - 1 : to;\n\n return { from, to };\n}\n\nfunction isInSeparatorMiddle(index: number, from: number, to: number) {\n return index === Math.floor((from + to) / 2);\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren, createRef, RefObject } from 'preact';\nimport { useEffect, useRef, useState, StateUpdater, useCallback, Dispatch } from 'preact/hooks';\nimport { Flex } from '../UNSAFE_Flex';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { useSingleSelection } from '../hooks/PRIVATE_useSingleSelection/useSingleSelection';\nimport { useCurrentKey } from '../hooks/PRIVATE_useCurrentKey';\nimport { useCollectionFocusRing } from '../hooks/PRIVATE_useCollectionFocusRing';\nimport { keyExtractor, getPrevNextKey, isMobile } from '../utils/PRIVATE_collectionUtils';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { useTranslationBundle } from '../hooks/UNSAFE_useTranslationBundle';\nimport type { BundleType } from '../resources/nls/bundle';\nimport { HiddenAccessible } from '../UNSAFE_HiddenAccessible';\nimport { ItemContext, CurrentKeyDetail, SingleSelectionDetail } from '../UNSAFE_Collection';\nimport { Collection } from '../PRIVATE_Collection';\nimport {\n Section,\n SectionItem,\n LastSectionItem,\n SeparatorItem,\n SECTION_OTHERS,\n hasSeparator,\n ITEM_SELECTOR\n} from './IndexerItems';\nimport { useComponentTheme } from '../hooks/UNSAFE_useComponentTheme';\nimport { IndexerStyles } from './themes/IndexerStyles.css';\nimport { IndexerRedwoodTheme } from './themes/redwood/IndexerTheme';\nimport { useTestId, TestIdProps } from '../hooks/UNSAFE_useTestId';\n\nexport type CommitDetail<K> = {\n value: K;\n};\n\ntype Props<K> = {\n /**\n * An array of sections, the default sections is an\n * array of 26 English alphabets and the # others character\n */\n sections?: Section<K>[];\n\n /**\n * The currently selected Section\n */\n value?: K;\n\n /**\n * A function that will be invoked when selection happens,\n * no matter the Section was selected before or not.\n */\n onCommit?: (detail: CommitDetail<K>) => void;\n};\n\nconst defaultSections: Section<string>[] = [\n { key: 'A' },\n { key: 'B' },\n { key: 'C' },\n { key: 'D' },\n { key: 'E' },\n { key: 'F' },\n { key: 'G' },\n { key: 'H' },\n { key: 'I' },\n { key: 'J' },\n { key: 'K' },\n { key: 'L' },\n { key: 'M' },\n { key: 'N' },\n { key: 'O' },\n { key: 'P' },\n { key: 'Q' },\n { key: 'R' },\n { key: 'S' },\n { key: 'T' },\n { key: 'U' },\n { key: 'V' },\n { key: 'W' },\n { key: 'X' },\n { key: 'Y' },\n { key: 'Z' }\n];\n\n/**\n * Pure Preact based component that consumes Collection component\n * and renders an indexer.\n */\nexport function Indexer<K extends string | number>({\n sections = defaultSections as Section<K>[],\n value,\n onCommit = () => {},\n testId\n}: Props<K> & TestIdProps) {\n const rootRef = useRef<HTMLDivElement>(null);\n const ulRef = useRef<HTMLUListElement>(null);\n const currElementRef = createRef<HTMLLIElement>();\n const [current, setCurrent] = useState<K | undefined>(sections[0]?.key);\n // the number of sections in each truncation\n const [sectionsPerTruncation, setSectionsPerTruncation] = useState<number>(-1);\n // the total number of rendered sections and separators\n const renderedSectionsCount = useRef<number>(-1);\n const itemHeightRef = useRef<number>(0);\n // the id for aria describedby\n const uniqueId = useId();\n\n const [showFocusRing, focusRingProps] = useCollectionFocusRing(rootRef, ['ArrowUp', 'ArrowDown']);\n\n const { currentKeyProps } = useCurrentKey(\n (element) => keyExtractor(element, ITEM_SELECTOR),\n true,\n getPrevNextKey(rootRef.current, current, true, ITEM_SELECTOR),\n getPrevNextKey(rootRef.current, current, false, ITEM_SELECTOR),\n undefined,\n undefined,\n current,\n (detail: CurrentKeyDetail<K>) => setCurrent(detail.value)\n );\n\n const { selectionProps } = useSingleSelection(\n (element) => handleKeyExtract(element, ulRef, current as K),\n // pass in undefined so onCommit handler will be called\n // no matter whether the Section was selected before or not\n undefined,\n (detail: SingleSelectionDetail<K>) => handleSelection(detail, onCommit, sections)\n );\n\n /**\n * Item renderer that will return a section item or a section separator\n * based on the sectionsPerTruncation and item context index.\n * @param context item context\n */\n const itemRenderer = (context: ItemContext<Section<K>>): ComponentChildren => {\n const last = sections.length - 1;\n renderedSectionsCount.current += 1;\n\n const commonProps = {\n context,\n ref: currElementRef,\n currentKey: current as K,\n selectedKey: value as K,\n valueNow: renderedSectionsCount.current,\n isFocusRingVisible: !!showFocusRing\n };\n\n // render the last and the others character, they are always present\n if (context.index === last) {\n return <LastSectionItem {...commonProps} lastValueNow={renderedSectionsCount.current + 1} />;\n }\n\n // render a section, in the non-truncation case or when it is the first in a truncation\n if (sectionsPerTruncation <= 1 || context.index % sectionsPerTruncation === 0) {\n return <SectionItem {...commonProps} />;\n }\n\n // render the separator in the middle of a truncation\n const separatorProps = { ...commonProps, sectionsPerTruncation, last, sections };\n if (hasSeparator(separatorProps)) {\n return <SeparatorItem {...separatorProps} />;\n }\n\n // remove the count for truncated sections\n renderedSectionsCount.current -= 1;\n\n return null;\n };\n\n // truncate the Indexer during resize\n const handleResize = useCallback(\n (entries: ResizeObserverEntry[]) => {\n for (const entry of entries) {\n updateSectionsPerTruncation(\n entry.contentRect.height,\n itemHeightRef.current,\n sections.length,\n sections[0]?.key,\n sectionsPerTruncation,\n setSectionsPerTruncation,\n setCurrent\n );\n }\n },\n [sections, sectionsPerTruncation]\n );\n\n useEffect(() => {\n if (ulRef.current) {\n // Get aria values from IndexerItem to update aria values on Indexer ul element\n ulRef.current.setAttribute('aria-valuemax', renderedSectionsCount.current + 1 + '');\n ulRef.current.setAttribute(\n 'aria-valuetext',\n currElementRef.current?.dataset?.['ojValuetext'] || ''\n );\n ulRef.current.setAttribute(\n 'aria-valuenow',\n currElementRef.current?.dataset?.['ojValuenow'] || ''\n );\n }\n renderedSectionsCount.current = -1;\n });\n\n /**\n * Set up the initial values for sectionsPerTruncation and event listeners\n */\n useEffect(() => {\n const root = rootRef.current;\n if (root) {\n itemHeightRef.current = root.querySelector('li')?.offsetHeight || 0;\n updateSectionsPerTruncation(\n root.offsetHeight,\n itemHeightRef.current,\n sections.length,\n sections[0]?.key,\n sectionsPerTruncation,\n setSectionsPerTruncation,\n setCurrent\n );\n }\n }, [sections, sectionsPerTruncation]);\n\n /**\n * Set up resize observer and refresh the resize observer when\n * sectionsPerTruncation is changed, otherwise it will only have the\n * old copy of sectionsPerTruncation.\n */\n useEffect(() => {\n const root = rootRef.current;\n if (root) {\n const resizeObserver = new ResizeObserver((entries: ResizeObserverEntry[]) => {\n handleResize(entries);\n });\n resizeObserver.observe(root);\n return () => {\n resizeObserver.unobserve(root);\n };\n }\n return undefined;\n }, [sectionsPerTruncation, handleResize]);\n\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n const {\n styles: { baseStyle, innerStyle }\n } = useComponentTheme<never, IndexerStyles>(IndexerRedwoodTheme);\n const testIdProps = useTestId(testId);\n\n return (\n <div ref={rootRef} class={baseStyle} {...testIdProps}>\n <Flex align=\"center\" width=\"6x\" height=\"100%\">\n <ul\n {...mergeProps(currentKeyProps, focusRingProps, selectionProps)}\n ref={ulRef}\n tabIndex={0}\n aria-label=\"Indexer\"\n aria-orientation=\"vertical\"\n aria-valuemin={0}\n aria-describedby={uniqueId}\n role=\"slider\"\n class={innerStyle}>\n <Collection items={sections}>{itemRenderer}</Collection>\n </ul>\n </Flex>\n <HiddenAccessible>\n <span id={uniqueId}>{getIndexerDescription(translations)}</span>\n </HiddenAccessible>\n </div>\n );\n}\n\n// A function to extract key for selection\nconst handleKeyExtract = <K extends string | number>(\n element: HTMLElement,\n rootRef: RefObject<HTMLElement>,\n current: K\n) => {\n if (element === rootRef.current) {\n return current === undefined ? null : current;\n }\n return keyExtractor(element, ITEM_SELECTOR) as K;\n};\n\nconst handleSelection = <K extends string | number>(\n detail: SingleSelectionDetail<K>,\n onCommit: (value: CommitDetail<K>) => void,\n sections: Section<K>[]\n) => {\n if (detail.value === SECTION_OTHERS.key) {\n onCommit({ value: SECTION_OTHERS.key as K });\n } else {\n const selectedSection = sections.find((section) => section.key === detail.value) as Section<K>;\n onCommit({ value: selectedSection.key as K });\n }\n};\n\n/**\n * A function that calculates the section count, based on\n * the container height and the number of sections\n * @param height height of Indexer container\n */\nconst updateSectionsPerTruncation = <K extends string | number>(\n height: number,\n itemHeight: number,\n sectionsLength: number,\n firstSectionKey: K,\n sectionsPerTruncation: number,\n setSectionsPerTruncation: Dispatch<StateUpdater<number>>,\n setCurrent: Dispatch<StateUpdater<K | undefined>>\n) => {\n if (height === 0 || itemHeight === 0) {\n return;\n }\n\n const maxSections = height / itemHeight;\n const last = sectionsLength - 1;\n\n // when the container size is too small to hold two sections\n if (maxSections < 2) {\n if (sectionsPerTruncation !== last) {\n setSectionsPerTruncation(last);\n setCurrent(firstSectionKey);\n }\n\n // no truncation\n // compare with < 0.01 for the deviation from calculation, when sectionsLength and maxSections\n // are about the same, maxNum === sectionsLength doesn't work\n } else if (maxSections > sectionsLength || sectionsLength - maxSections < 0.01) {\n if (sectionsPerTruncation > 1) {\n setSectionsPerTruncation(1);\n setCurrent(firstSectionKey);\n }\n\n // need truncation\n } else {\n const tempSectionCount = findSectionCount(maxSections, last);\n if (tempSectionCount !== sectionsPerTruncation && tempSectionCount < sectionsLength) {\n setSectionsPerTruncation(tempSectionCount);\n setCurrent(firstSectionKey);\n }\n }\n};\n\n/**\n * A helper function to find the best section count\n * in a truncation\n *\n * @param maxSections maximum number of sections allowed in a truncation\n * @param last the index of last section\n */\nconst findSectionCount = (maxSections: number, last: number) => {\n // need truncation\n maxSections -= 2; // minus the last character and the others character\n maxSections /= 2; // each truncation has a section and a separator\n\n const newSectionCount = Math.round(last / maxSections) + 1;\n const truncationLeftover = last % newSectionCount;\n const truncationCount = Math.floor(last / newSectionCount) + (truncationLeftover > 1 ? 1 : 0);\n\n // When the sectionCount becomes greater, it will result in\n // same truncations but with different sections appearing.\n // The following is to find the best sectionCount in this case\n // and prevent unnecessary truncations.\n let tempLeftover = last - (truncationCount - 1) * newSectionCount;\n let tempSectionCount = newSectionCount;\n while (tempSectionCount > tempLeftover) {\n tempSectionCount -= 1;\n tempLeftover = last - (truncationCount - 1) * tempSectionCount;\n }\n if (tempSectionCount != newSectionCount) {\n tempSectionCount += 1;\n }\n\n return tempSectionCount;\n};\n\n/**\n * Helper function to find the aria description for Indexer,\n * based on whether current device is a mobile device\n */\nfunction getIndexerDescription(translations: any) {\n if (isMobile()) {\n return translations.indexer_touchInstructionText();\n } else {\n return translations.indexer_keyboardInstructionText();\n }\n}\n"],"names":["SECTION_OTHERS","Object","freeze","key","label","ITEM_SELECTOR","SectionItem","forwardRef","props","ref","translations","useTranslationBundle","context","selectedKey","isSelected","data","commonProps","getCommonProps","classes","useComponentTheme","IndexerRedwoodTheme","focused","isFocusRingVisible","disabled","isDisabled","selected","itemClasses","classNames","sectionLabel","valueText","indexer_disabledLabel","SECTION","_jsx","jsx","class","children","currentKey","valueNow","LastSectionItem","lastValueNow","sectionProps","_jsxs","jsxs","Fragment","OthersItem","index","othersClasses","othersValueText","SeparatorItem","sections","from","to","getSeparatorRange","styles","dotStyle","isInSeparatorMiddle","fromText","toText","separatorClasses","separatorValueText","indexer_separatorLabel","FROM_SECTION","TO_SECTION","Flex","align","justify","sectionsPerTruncation","last","Math","floor","defaultSections","handleKeyExtract","element","rootRef","current","undefined","keyExtractor","handleSelection","detail","onCommit","value","find","section","updateSectionsPerTruncation","height","itemHeight","sectionsLength","firstSectionKey","setSectionsPerTruncation","setCurrent","maxSections","tempSectionCount","findSectionCount","newSectionCount","round","truncationLeftover","truncationCount","tempLeftover","getIndexerDescription","isMobile","indexer_touchInstructionText","indexer_keyboardInstructionText","testId","useRef","ulRef","currElementRef","createRef","useState","renderedSectionsCount","itemHeightRef","uniqueId","useId","showFocusRing","focusRingProps","useCollectionFocusRing","currentKeyProps","useCurrentKey","getPrevNextKey","selectionProps","useSingleSelection","handleResize","useCallback","entries","entry","contentRect","length","useEffect","setAttribute","dataset","root","querySelector","offsetHeight","resizeObserver","ResizeObserver","observe","unobserve","baseStyle","innerStyle","testIdProps","useTestId","width","mergeProps","tabIndex","role","Collection","items","separatorProps","hasSeparator","HiddenAccessible","id"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ define(['exports', 'preact/jsx-runtime', 'preact/hooks', './classNames-08d99695', './mergeProps-bcfa6a92', './keys-cc1cb01d', './LoadMoreCollection-a6adbc3f', './VirtualizedCollection-63223f5e', 'preact/compat', './TabbableModeContext-a9c97640', './useId-c9578d26', './FocusTrap-eb7cc3d2', './useInteractionStyle-726087e0', './mergeInterpolations-9ede4cf7', './flexitem-5db48325', './PRIVATE_List/themes/ListStyles.css', './collectionUtils-6740111c', './Skeleton-5839404b', './Flex-56ecdf4c', './Selector-039f7481', './ImageVars.css-17386400', './useTheme-ac980f9a', './useTestId-3a316499', './useSelection-e2791513', './useCurrentKey-1d869ff4', './useCollectionFocusRing-64636529', './useCollectionInteractionContext-173bc431', './useItemAction-66d976c4', './useTabbableModeSet-b4c18d1a', './useReorderableContext-652356ad', './Inset-d7d99801', 'module'], (function(e,t,i,s,r,n,l,o,a,c,u,d,g,m,b,f,y,v,p,h,x,S,k,C,I,w,K,T,R,V,j,A){"use strict";const P=e=>{switch(e){case"listbox":return{list:"listbox",item:"presentation",cell:"option"};case"treegrid":return{list:"treegrid",item:"row",cell:"gridcell"};default:return{list:"grid",item:"row",cell:"gridcell"}}},E="[data-oj-key]";function F({children:e,context:r,itemDepth:n,isFocused:l,isFocusRingVisible:o,isActive:a,isGridlineVisible:y,isSelected:v,isTopGridlineVisible:p=!1,isTabbable:h=!1,role:x,selectionMode:S,suggestion:k,currentItemVariant:C}){const I=i.useRef(null),w=i.useMemo((()=>P(x)),[x]),K=r.metadata.key,T=r.index,R="option"===w.cell?{role:w.cell,"aria-posinset":T+1,"aria-setsize":-1}:{role:w.cell},{interactionProps:V,applyActiveStyle:j,applyHoverStyle:A,applyPseudoHoverStyle:E}=g.useInteractionStyle(),F=f.listItemMultiVariantStyles({selectable:M(S,v)?"isSelectable":"notSelectable",selected:v?"isSelected":"notSelected",selectedSingle:v&&"single"===S?"isSelectedSingle":"notSelectedSingle",needsEventsHover:A?"isNeedsEventsHover":"notNeedsEventsHover",pseudoHover:E?"isPseudoHover":"notPseudoHover",active:j||a?"isActive":"notActive",focusHighlight:"highlight"===C&&l?"isFocusHighlight":"notFocusHighlight",focusRingVisible:o&&l?"isFocusRingVisible":"notFocusRingVisible",gridlineTop:p?"visible":"hidden",gridlineBottom:!y&&("end"!==k||y||v&&"single"===S)?"hidden":"visible"}),L=s.classNames([F]),H=m.mergeInterpolations([...Object.values(b.flexitemInterpolations)]),{class:z,...D}=H({flex:"1 1 auto",alignSelf:"center"}),N=s.classNames([z,"multiple"===S&&f.listItemStyles.checkboxContainer]);return t.jsx("div",{"aria-rowindex":"grid"===x?T+1:void 0,"aria-level":n,"data-oj-key":K,class:L,ref:I,role:w.item,...k&&{"data-oj-suggestion":!0},..."number"==typeof K&&{"data-oj-key-type":"number"},...V,children:t.jsx("div",{id:u.useId(),style:D,class:N,"aria-posinset":"grid"===x?void 0:T+1,"aria-setsize":"grid"===x?void 0:-1,onKeyDown:e=>{!h||"ArrowDown"!==e.key&&"ArrowUp"!==e.key||e.stopPropagation()},"aria-colindex":"grid"===x?1:void 0,"aria-selected":"none"!==S?v:void 0,...R,children:t.jsx(c.TabbableModeContext.Provider,{value:{isTabbable:h},children:t.jsx(d.FocusTrap,{isDisabled:!h,restoreFocusRef:!1,children:e(r)})})})})}const M=(e,t)=>"none"!==e&&("multiple"===e||!t),L=a.memo(F,((e,t)=>!(!e||!t)&&(e.children===t.children&&e.isFocused===t.isFocused&&e.isFocusRingVisible===t.isFocusRingVisible&&e.isSelected===t.isSelected&&e.isTabbable===t.isTabbable&&e.isActive===t.isActive&&e.suggestion===t.suggestion&&e.isGridlineVisible===t.isGridlineVisible&&e.isTopGridlineVisible===t.isTopGridlineVisible&&y.compareListItemContext(e.context,t.context))));function H({children:e,minimumCount:r=1}){const[n,l]=i.useState(!1);i.useEffect((()=>{setTimeout((()=>{l(!0)}),50)}),[]);const o=s.classNames([f.skeletonStyles.container]);return n&&e?t.jsx("div",{class:o,role:"presentation",children:[...Array(r)].map(((t,i)=>e(i)))}):null}const z="oj-collection-sparkle";function D({sparkleHeight:e}){const{name:i}=S.useTheme();if(e<=0)return null;const r=e+"px",n=s.classNames([f.sparkleStyles.base]),l=s.classNames([f.sparkleStyles.container,z,"redwood"===i&&x.globalImages]);return t.jsx("div",{class:l,children:t.jsx("div",{class:n,style:{height:r}})},"sparkle")}const N=(e,t)=>{if(0===t)return null;return e.slice(0,t).reduce(((e,i,s)=>{const r=i.metadata.key;return s===t-1?e.set(r,"end"):e.set(r,!0),e}),new Map)},O=(e,t,i)=>{if(e&&t&&(e.scrollIntoViewIfNeeded?e.scrollIntoViewIfNeeded():e.scrollIntoView({block:"nearest"}),i>0)){const s=t.getBoundingClientRect(),r=e.getBoundingClientRect(),n=s.top+i-r.top;n>0&&(t.scrollTop=t.scrollTop-n)}},G=(e,t)=>{const i=t.data.map((e=>e.metadata.key)),s=i.indexOf(e.value.start),r=i.indexOf(e.value.end),n=Math.min(s,r),l=Math.max(s,r);return-1===n?{offset:0,count:t.totalSize}:i.slice(n,l+1)},B=e=>!(!e.parentElement||!e.parentElement.classList.contains("oj-listview-expander"));const _=(e,t)=>t??{scroller:()=>e.current},U={all:!1,keys:new Set},q=t.jsx(H,{minimumCount:25,children:()=>t.jsx(j.Inset,{variant:"listview",children:t.jsx(p.Flex,{height:"6x",align:"center",children:t.jsx(v.Skeleton,{height:"4x"})})})}),Y=t.jsx("div",{class:l.LOADMORE_STYLE_CLASS,children:t.jsx(H,{minimumCount:3,children:()=>t.jsx(j.Inset,{variant:"listview",children:t.jsx(p.Flex,{height:"6x",align:"center",children:t.jsx(v.Skeleton,{height:"4x"})})})})}),$=(e,t)=>{if(t){const i=Math.min(t.offset,e.offset+e.totalSize),s=i-e.offset;s>0&&(e={offset:i,data:e.data.slice(s,s+t.count),totalSize:e.totalSize,sizePrecision:e.sizePrecision})}return e};e.List=function({"aria-label":e,"aria-labelledby":a,allowTabbableMode:c=!0,children:u,data:d,gridlines:g,loadingIndicator:m=q,currentItemOverride:b,onPersistCurrentItem:v,onLoadRange:p,onSelectionChange:x,onItemAction:S,rangeExtractor:j,role:A="grid",selectedKeys:M=U,selectionMode:H="none",viewportConfig:z,currentItemVariant:J="none",promotedSection:Q,isVirtualized:W=!1,customItemRenderer:X,scrollToVisibleOffset:Z,testId:ee,scrollerRef:te,reorderProps:ie,contextMenuTriggerProps:se,...re}){const ne=i.useRef(null),le=i.useRef(),[oe,ae]=i.useState(!1),ce="none"===H?void 0:"multiple"===H,ue=null===d?void 0:"exact"===d.sizePrecision?d.totalSize:-1,de=s.classNames([f.listStyles.base]),ge=i.useCallback(((e,t)=>{d&&(le.current={detail:e,range:{offset:d.offset,count:d.data.length}},p(t))}),[d,p]),{currentKey:me,onCurrentKeyChange:be,isCurrentItemOverridden:fe}=((e,t)=>{const[s,r]=i.useState(),n=i.useRef(),l=i.useRef(!1),o=V.useReorderableContext(),a=i.useMemo((()=>e=>{r(e.value),t?.(e),null!=o?.currentItemKey&&(o.currentItemKey.current=e.value?.rowKey)}),[t,o?.currentItemKey]);return n.current!==e&&(n.current=e,s?.rowKey!==e?.rowKey&&(l.current=!0,a({value:e}))),i.useEffect((()=>{l.current=!1})),{currentKey:s?.rowKey,onCurrentKeyChange:e=>{a({value:{rowKey:e.value}})},isCurrentItemOverridden:l.current}})(b,v),{eventProps:ye,showFocusRing:ve,handleSelectionChange:pe}=((e,t,s="none",n,l,o,a,c,u="grid",d,g,m,b)=>{const f=i.useMemo((()=>P(u)),[u]),v=i.useRef(),p=K.useCollectionInteractionContext(),{currentKeyProps:h}=I.useCurrentKey((e=>y.keyExtractor(e,E)),"multiple"!==s,y.getPrevNextKey(g.current,e,!0,E),y.getPrevNextKey(g.current,e,!1,E),void 0,void 0,e,n),[x,S]=w.useCollectionFocusRing(g,["ArrowUp","ArrowDown"]);i.useEffect((()=>{if(null!=e&&g.current){const t=y.findElementByKey(g.current,e,E);if(t){const e=g.current.getAttribute("aria-activedescendant"),i=t.querySelector(`[role=${f.cell}]`);if(i&&e!==i.id&&(g.current.setAttribute("aria-activedescendant",i.id),!b||"embedded"===p)){const e=c?.scroller(),i=d?d(g.current):0;O(t,null!=e?e:g.current,i)}}}}),[e,a,f.cell,c,d,g,b]);const k=i.useCallback((e=>{l&&(!1===e.value.all&&e.value.keys.size>0&&(v.current=Array.from(e.value.keys.values()).pop()),l(e))}),[v,l]),R=i.useCallback((e=>{if(a&&l){const t=G(e,a);Array.isArray(t)?("shiftSpace"===e.eventType?v.current=e.value.start:v.current=e.value.end,l({value:{all:!1,keys:new Set(t)},target:null})):m(e,t)}}),[a,l,m]),{selectionProps:V}=C.useSelection((t=>t===g.current?void 0===e?null:e:y.keyExtractor(t,E)),t,s,!1,"replace","embedded"===p,k,v.current,e,((e,t)=>y.getPrevNextKey(g.current,e,t,E)),void 0,(e=>{if(g.current){const t=y.findElementByKey(g.current,e,E);if(t){const e=c?.scroller(),i=d?d(g.current):0;O(t,null!=e?e:g.current,i)}}}),R),j=T.useItemAction(e,a,o,E,"embedded"===p);return{eventProps:r.mergeProps(h,S,V,j),showFocusRing:x,handleSelectionChange:k}})(me,M,H,be,x,S,d,z,A,Z,ne,ge,fe),{eventProps:he,isCurrentTabbableKey:xe}=((e,t,s,l,o,a)=>{const c=i.useRef(),[u,d]=R.useTabbableModeSet(l,(e=>B(e)?null:y.keyExtractor(e,E)),e,t),g=i.useCallback((()=>{if(l.current&&t&&(!s||u(void 0))){const e=c.current||y.getFirstVisibleKey(l.current,E);n.isKeyDefined(e)&&t({value:e})}}),[l,t,s,u]),m=i.useCallback((i=>{if(B(i.target)){l.current?.focus();const e=y.keyExtractor(i.target,E);t&&n.isKeyDefined(e)&&t({value:e})}else if(n.isKeyDefined(e)){if(l.current){const i=y.findElementByKey(l.current,e,E);if(i){const e=o?.scroller(),t=a?a(l.current):0;O(i,null!=e?e:l.current,t)}else t&&g()}}else t&&g()}),[e,g,t,l]),b=i.useCallback((e=>{const t=y.keyExtractor(e.target,E);n.isKeyDefined(t)&&(c.current=t)}),[]);return{eventProps:r.mergeProps(s?d:{},{onFocus:m,onPointerDown:b}),isCurrentTabbableKey:u}})(me,be,c,ne,z,Z);if(d&&void 0!==le.current&&x){const e=G(le.current.detail,d);Array.isArray(e)&&x({value:{all:!1,keys:new Set(e)},target:null});const t=le.current?le.current.range:{offset:d.offset,count:d.data.length};d=$(d,t),le.current=void 0,p(t)}const{sparkleHeight:Se,suggestions:ke}=((e,t,s)=>{const[r,n]=i.useState(0),l=i.useMemo((()=>e&&t&&N(e.data,t.count)),[e,t]);return i.useEffect((()=>{if(l){const e=s.current?.querySelector("."+o.PLACEHOLDER_STYLE_CLASS);let t=e?.offsetHeight||0;const i=s.current?.querySelectorAll("[data-oj-suggestion]");i?.forEach((e=>t+=e.offsetHeight)),n(t)}}),[s,l]),{sparkleHeight:r,suggestions:l}})(d,Q,ne),Ce=t.jsx(D,{sparkleHeight:Se}),Ie=i.useCallback((e=>{const i=e.data,s="multiple"===H?()=>t.jsx(h.Selector,{onChange:pe,rowKey:i.metadata.key,selectedKeys:M}):void 0;return{index:e.index,data:i.data,metadata:i.metadata,selector:s}}),[H,M,pe]),we=W?F:L,Ke=e=>{const i=Ie(e),s=ke?.get(i.metadata.key),r=c&&xe(i.metadata.key),l=me===i.metadata.key&&!r,o=l&&oe,a=n.containsKey(M,i.metadata.key),m=l&&ve,b=(e,r)=>{return t.jsx(we,{context:e,isFocused:l,isFocusRingVisible:m,isActive:o,isGridlineVisible:(n=i.index,"visible"===g?.item&&(n+1!==d?.totalSize||"visible"===g?.bottom)),isSelected:a,isTabbable:c&&xe(i.metadata.key),role:A,selectionMode:H,currentItemVariant:J,...s&&{suggestion:s},...0===i.index&&{isTopGridlineVisible:"visible"===g?.item&&"visible"===g?.top},...r,children:u},i.metadata.key);var n};if(X){return X({listItemContext:i,isFocused:l,isFocusRingVisible:m,isSelected:a,isTabbable:r,isActive:o,defaultListItem:b})}return b(i)};z=_(ne,z);const Te=i.useCallback((e=>{" "===e.key&&n.isKeyDefined(me)&&"none"!==H&&ae(!0)}),[me,H,ae]),Re=i.useCallback((()=>{ae(!1)}),[ae]);i.useImperativeHandle(te,(()=>ne.current));const Ve=k.useTestId(ee);return t.jsx("div",{...r.mergeProps(ye,he,se||{},ie||{},{onKeyDown:Te,onKeyUp:Re},re),...Ve,role:A,"aria-rowcount":"grid"===A?ue:void 0,"aria-colcount":"grid"===A?1:void 0,ref:ne,class:de,tabIndex:0,"aria-label":e,"aria-labelledby":a,"aria-multiselectable":ce,children:null==d?m:W?t.jsx(o.VirtualizedCollection,{data:d,itemSelector:E,loadMoreIndicator:Y,onLoadRange:p,rangeExtractor:j,suggestions:Ce,viewportConfig:z,children:Ke}):t.jsx(l.LoadMoreCollection,{data:d.data,loadMoreIndicator:Y,hasMore:"atLeast"===d.sizePrecision&&d.data.length<=d.totalSize,onLoadMore:()=>{d&&p({offset:0,count:d.data.length+25})},suggestions:Ce,viewportConfig:z,children:Ke})})},e.SkeletonContainer=H,e.excludeGroup=(e,t)=>{if(!t.all){const i=e.data.filter((e=>!e.metadata.isLeaf)).map((e=>e.metadata.key)),s=Array.from(t.keys.values()).filter((e=>!i.includes(e)));return{...t,keys:new Set(s)}}return t},e.scrollToVisible=O}));
2
+ //# sourceMappingURL=List-3ebac3fc.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"List-61d64cd6.js","sources":["../../src/PRIVATE_List/ListRoles.ts","../../src/PRIVATE_List/ListItem.tsx","../../src/PRIVATE_List/SkeletonContainer.tsx","../../src/PRIVATE_List/Sparkle.tsx","../../src/PRIVATE_List/usePromotedSection.ts","../../src/PRIVATE_List/ListUtils.ts","../../src/PRIVATE_List/useSelectionAndNavigation.ts","../../src/PRIVATE_List/useFocusTabbableMode.ts","../../src/PRIVATE_List/List.tsx","../../src/PRIVATE_List/useCurrentItemOverride.ts"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Roles } from '../UNSAFE_ListView';\nimport { HTMLAttributesSignalExcluded } from '../utils/UNSAFE_attributeUtils';\n\n/**\n * List Roles need to be kept in matching sets, this module encapsulates the sets\n *\n * @param ariaRole\n * @returns matching, valid set of roles\n */\n\nconst getListViewRoles = (\n ariaRole: Roles\n): {\n list: HTMLAttributesSignalExcluded['role'];\n item: HTMLAttributesSignalExcluded['role'];\n cell: HTMLAttributesSignalExcluded['role'];\n} => {\n switch (ariaRole) {\n case 'listbox':\n return { list: 'listbox', item: 'presentation', cell: 'option' };\n case 'treegrid':\n return { list: 'treegrid', item: 'row', cell: 'gridcell' };\n default:\n return { list: 'grid', item: 'row', cell: 'gridcell' };\n }\n};\n\nexport { getListViewRoles };\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren } from 'preact';\nimport { useRef, useMemo } from 'preact/hooks';\nimport { memo } from 'preact/compat';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { TabbableModeContext } from '../hooks/UNSAFE_useTabbableMode';\nimport { SelectionMode, CurrentItemVariant, ListItemRendererContext } from '../UNSAFE_Collection';\nimport { FocusTrap } from '../UNSAFE_FocusTrap';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { Roles } from '../UNSAFE_ListView';\nimport { getListViewRoles } from './ListRoles';\nimport { useInteractionStyle } from '../hooks/UNSAFE_useInteractionStyle';\nimport { mergeInterpolations } from '../utils/UNSAFE_mergeInterpolations';\nimport { flexitemInterpolations } from '../utils/UNSAFE_interpolations/flexitem';\nimport type { FlexitemProps } from '../utils/UNSAFE_interpolations/flexitem';\nimport { listItemStyles, listItemMultiVariantStyles } from './themes/ListStyles.css';\nimport { compareListItemContext } from '../utils/PRIVATE_collectionUtils';\n\nexport const ITEM_SELECTOR = '[data-oj-key]';\n\n/**\n * Props for the ListViewItem Component\n */\nexport type Props<K, D> = {\n children: (context: ListItemRendererContext<K, D>) => ComponentChildren;\n context: ListItemRendererContext<K, D>;\n itemDepth?: number;\n isFocused: boolean;\n isFocusRingVisible: boolean;\n isActive: boolean;\n isGridlineVisible: boolean;\n isSelected: boolean;\n isTopGridlineVisible?: boolean;\n isTabbable?: boolean;\n role: Roles;\n selectionMode: SelectionMode;\n suggestion?: 'end' | true;\n currentItemVariant?: CurrentItemVariant;\n};\n\n/**\n * The internal component used to render a single item in ListView.\n */\nexport function ListViewItem<K extends string | number, D>({\n children,\n context,\n itemDepth,\n isFocused,\n isFocusRingVisible,\n isActive,\n isGridlineVisible,\n isSelected,\n isTopGridlineVisible = false,\n isTabbable = false,\n role,\n selectionMode,\n suggestion,\n currentItemVariant\n}: Props<K, D>) {\n const rootRef = useRef<HTMLDivElement>(null);\n const roles = useMemo(() => getListViewRoles(role), [role]);\n const itemKey = context.metadata.key;\n const itemIndex = context.index;\n\n // some roles come with related aria attributes which need to be set\n const cellRoleAttributes =\n roles.cell === 'option'\n ? {\n role: roles.cell,\n 'aria-posinset': itemIndex + 1,\n 'aria-setsize': -1\n }\n : {\n role: roles.cell\n };\n\n // don't bubble Arrow Up and Down events to parent when in isTabbable mode\n // this bubbling causes the outer CollectionFocus ring to change index while in the isTabbable mode.\n const handleKeyDown = (event: KeyboardEvent) => {\n if (isTabbable && (event.key === 'ArrowDown' || event.key === 'ArrowUp')) {\n event.stopPropagation();\n }\n };\n\n const { interactionProps, applyActiveStyle, applyHoverStyle, applyPseudoHoverStyle } =\n useInteractionStyle();\n\n const variantClasses = listItemMultiVariantStyles({\n selectable: isSelectable(selectionMode, isSelected) ? 'isSelectable' : 'notSelectable',\n selected: isSelected ? 'isSelected' : 'notSelected',\n selectedSingle:\n isSelected && selectionMode === 'single' ? 'isSelectedSingle' : 'notSelectedSingle',\n needsEventsHover: applyHoverStyle ? 'isNeedsEventsHover' : 'notNeedsEventsHover',\n pseudoHover: applyPseudoHoverStyle ? 'isPseudoHover' : 'notPseudoHover',\n active: applyActiveStyle || isActive ? 'isActive' : 'notActive',\n focusHighlight:\n currentItemVariant === 'highlight' && isFocused ? 'isFocusHighlight' : 'notFocusHighlight',\n focusRingVisible:\n isFocusRingVisible && isFocused ? 'isFocusRingVisible' : 'notFocusRingVisible',\n gridlineTop: isTopGridlineVisible ? 'visible' : 'hidden',\n gridlineBottom:\n isGridlineVisible ||\n (suggestion === 'end' && !isGridlineVisible && (!isSelected || selectionMode !== 'single'))\n ? 'visible'\n : 'hidden'\n });\n const classes = classNames([variantClasses]);\n const styleInterpolations = mergeInterpolations<FlexitemProps>([\n ...Object.values(flexitemInterpolations)\n ]);\n const { class: cls, ...cellStyles } = styleInterpolations({\n flex: '1 1 auto',\n alignSelf: 'center'\n });\n const cellClasses = classNames([\n cls,\n selectionMode === 'multiple' && listItemStyles.checkboxContainer\n ]);\n\n // todo: use translated text for selector\n // note cannot put focus on gridcell div since JAWS will not read the aria-rowindex\n // correctly, so unfortunately needed another div\n return (\n <div\n aria-rowindex={role === 'grid' ? itemIndex + 1 : undefined}\n aria-level={itemDepth}\n data-oj-key={itemKey}\n class={classes}\n ref={rootRef}\n role={roles.item}\n {...(suggestion && { 'data-oj-suggestion': true })}\n {...(typeof itemKey === 'number' && { 'data-oj-key-type': 'number' })}\n {...interactionProps}>\n <div\n id={useId()}\n style={cellStyles}\n class={cellClasses}\n aria-posinset={role === 'grid' ? undefined : itemIndex + 1}\n aria-setsize={role === 'grid' ? undefined : -1}\n onKeyDown={handleKeyDown}\n aria-colindex={role === 'grid' ? 1 : undefined}\n aria-selected={selectionMode !== 'none' ? isSelected : undefined}\n {...cellRoleAttributes}>\n <TabbableModeContext.Provider value={{ isTabbable }}>\n <FocusTrap isDisabled={!isTabbable} restoreFocusRef={false}>\n {children(context)}\n </FocusTrap>\n </TabbableModeContext.Provider>\n </div>\n </div>\n );\n}\n\n/**\n * Helper method to determine whether item is selectable\n * @returns true if item is selectable (show hover effect), false otherwise\n */\nconst isSelectable = (selectionMode: SelectionMode, isItemSelected: boolean) => {\n return selectionMode !== 'none' && (selectionMode === 'multiple' || !isItemSelected);\n};\n\nexport const MemoizeListViewItem = memo(ListViewItem, (prev: any, next: any) => {\n if (prev && next) {\n return (\n prev.children === next.children &&\n prev.isFocused === next.isFocused &&\n prev.isFocusRingVisible === next.isFocusRingVisible &&\n prev.isSelected === next.isSelected &&\n prev.isTabbable === next.isTabbable &&\n prev.isActive === next.isActive &&\n prev.suggestion === next.suggestion &&\n prev.isGridlineVisible === next.isGridlineVisible &&\n prev.isTopGridlineVisible === next.isTopGridlineVisible &&\n compareListItemContext(prev.context, next.context)\n );\n }\n return false;\n});\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren } from 'preact';\nimport { useState, useEffect } from 'preact/hooks';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { skeletonStyles } from './themes/ListStyles.css';\n\ntype Props = {\n /**\n * Allows to pass and access the properties from child elements\n **/\n children?: (index: number) => ComponentChildren;\n /**\n * Allows to specify number of skeletons to be rendered on initial load\n **/\n minimumCount?: number;\n};\n\n/**\n * Allows to specify the time delay for rendering the component\n **/\nconst timerValue = 50;\n\n/**\n * SkeletonContainer renders 'minimumCount' number of skeletons\n * of the variant specified from its child element - Skeleton's prop after\n * 'timerValue' ms delay\n **/\nexport function SkeletonContainer({ children, minimumCount = 1 }: Props) {\n const [isVisible, setIsVisible] = useState(false);\n\n useEffect(() => {\n setTimeout(() => {\n setIsVisible(true);\n }, timerValue);\n }, []);\n\n const containerClasses = classNames([skeletonStyles.container]);\n return isVisible && children ? (\n <div class={containerClasses} role=\"presentation\">\n {[...Array(minimumCount)].map((_element, index) => children(index))}\n </div>\n ) : null;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { globalImages } from '#/ImageVars.css';\nimport { sparkleStyles } from './themes/ListStyles.css';\nimport { useTheme } from '#/hooks/UNSAFE_useTheme';\n\nconst SPARKLE_STYLE_CLASS = 'oj-collection-sparkle';\n\n/**\n * A sparkle component for smart suggestion indicator in ListView\n * @param sparkleHeight the height of sparkle\n */\nexport function Sparkle({ sparkleHeight }: { sparkleHeight: number }) {\n const { name } = useTheme();\n if (sparkleHeight <= 0) {\n return null;\n }\n\n const height = sparkleHeight + 'px';\n const sparkleClasses = classNames([sparkleStyles.base]);\n const containerClasses = classNames([\n sparkleStyles.container,\n SPARKLE_STYLE_CLASS,\n // TODO: this component should create separate theme definitions to only show the image in redwood\n name === 'redwood' && globalImages\n ]);\n\n return (\n <div key=\"sparkle\" class={containerClasses}>\n <div class={sparkleClasses} style={{ height }}></div>\n </div>\n );\n}\n","import { RefObject } from 'preact';\nimport { useState, useEffect, useMemo } from 'preact/hooks';\nimport { Props as ListViewProps } from '../UNSAFE_ListView';\nimport { PLACEHOLDER_STYLE_CLASS } from '../PRIVATE_VirtualizedCollection';\nimport { Metadata } from '../UNSAFE_Collection';\n\nexport const usePromotedSection = <K extends string | number, D>(\n data: ListViewProps<K, D>['data'],\n promotedSection: ListViewProps<K, D>['promotedSection'],\n rootRef: RefObject<HTMLDivElement>\n) => {\n // tracking sparkle height\n const [sparkleHeight, setSparkleHeight] = useState<number>(0);\n\n const suggestions = useMemo(\n () => data && promotedSection && findSuggestions(data.data, promotedSection.count),\n [data, promotedSection]\n );\n\n useEffect(() => {\n // update sparkleHeight only when we have suggestions\n // avoid unnecessary iterating through elements\n if (suggestions) {\n const placeholder = rootRef.current?.querySelector(\n '.' + PLACEHOLDER_STYLE_CLASS\n ) as HTMLElement;\n let height = placeholder?.offsetHeight || 0;\n const suggestionItems = rootRef.current?.querySelectorAll('[data-oj-suggestion]');\n suggestionItems?.forEach((item) => (height += (item as HTMLElement).offsetHeight));\n setSparkleHeight(height);\n }\n }, [rootRef, suggestions]);\n\n return { sparkleHeight, suggestions };\n};\n\n/**\n * A helper function that finds the data with suggestions, and\n * returns the corresponding keys\n * @param dataState\n */\nconst findSuggestions = <K, D>(data: { data: D; metadata: Metadata<K> }[], count: number) => {\n if (count === 0) {\n return null;\n }\n\n const suggestionsData = data.slice(0, count);\n return suggestionsData.reduce((suggestions, value, index) => {\n const key = value.metadata.key;\n\n if (index === count - 1) {\n suggestions.set(key, 'end');\n } else {\n suggestions.set(key, true);\n }\n\n return suggestions;\n }, new Map<K, 'end' | true>());\n};\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { FlattenedDataState } from '../UNSAFE_Collection';\nimport { Keys } from '../utils/UNSAFE_keys';\n\n/**\n * Helper function to only include keys of leaf items.\n */\nexport const excludeGroup = <K, D>(data: FlattenedDataState<K, D>, keys: Keys<K>) => {\n if (!keys.all) {\n const groups = data.data\n .filter((dataMetadata) => {\n return !dataMetadata.metadata.isLeaf;\n })\n .map((dataMetadata) => {\n return dataMetadata.metadata.key;\n });\n const leafOnly = Array.from(keys.keys.values()).filter((key: K) => {\n return !groups.includes(key);\n });\n return { ...keys, keys: new Set(leafOnly) };\n }\n return keys;\n};\n\n/**\n * A helper function to make sure specified elem is visible in the specified container\n */\nexport const scrollToVisible = (elem: Element, scroller: Element, offset: number) => {\n if (elem && scroller) {\n if ((elem as any).scrollIntoViewIfNeeded) {\n // for Safari, we'll need the non-standard scrollIntoViewIfNeeded\n (elem as any).scrollIntoViewIfNeeded();\n } else {\n elem.scrollIntoView({ block: 'nearest' });\n }\n if (offset > 0) {\n const scrollerBounds = scroller.getBoundingClientRect();\n const elemBounds = elem.getBoundingClientRect();\n const diff = scrollerBounds.top + offset - elemBounds.top;\n if (diff > 0) {\n scroller.scrollTop = scroller.scrollTop - diff;\n }\n }\n }\n};\n","import { RefObject } from 'preact';\nimport { useEffect, useCallback, useRef, useMemo } from 'preact/hooks';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { Keys } from '../utils/UNSAFE_keys';\nimport {\n DataState,\n Metadata,\n Range,\n SelectionDetail,\n CurrentKeyDetail\n} from '../UNSAFE_Collection';\nimport { getListViewRoles } from './ListRoles';\nimport { SelectionRangeDetail, useSelection } from '../hooks/PRIVATE_useSelection';\nimport { useCurrentKey } from '../hooks/PRIVATE_useCurrentKey';\nimport { useCollectionFocusRing } from '../hooks/PRIVATE_useCollectionFocusRing';\nimport { useCollectionInteractionContext } from '../hooks/UNSAFE_useCollectionInteractionContext';\nimport { useItemAction } from '../hooks/PRIVATE_useItemAction';\nimport { Props as ListViewProps } from '../UNSAFE_ListView';\nimport { getPrevNextKey, findElementByKey, keyExtractor } from '../utils/PRIVATE_collectionUtils';\nimport { ITEM_SELECTOR } from './ListItem';\nimport { scrollToVisible } from './ListUtils';\n\nexport const useSelectionAndNavigation = <K extends string | number, D>(\n currentKey: K | undefined,\n selectedKeys: Keys<K>,\n selectionMode: ListViewProps<K, D>['selectionMode'] = 'none',\n onCurrentKeyChange: ((detail: CurrentKeyDetail<K>) => void) | undefined,\n onSelectionChange: ListViewProps<K, D>['onSelectionChange'],\n onItemAction: ListViewProps<K, D>['onItemAction'],\n data: ListViewProps<K, D>['data'],\n viewportConfig: ListViewProps<K, D>['viewportConfig'],\n role: ListViewProps<K, D>['role'] = 'grid',\n scrollToVisibleOffset: ListViewProps<K, D>['scrollToVisibleOffset'],\n rootRef: RefObject<HTMLDivElement>,\n pendingSelectionCallback: (detail: SelectionRangeDetail<K>, value: Range) => void,\n isCurrentItemOverridden: boolean\n) => {\n const listRoles = useMemo(() => getListViewRoles(role), [role]);\n\n // tracking the anchor key which is used for shift+click selection\n const anchorKey = useRef<K | undefined>();\n\n const collectionInteraction = useCollectionInteractionContext();\n\n const { currentKeyProps } = useCurrentKey(\n (element) => keyExtractor(element, ITEM_SELECTOR),\n selectionMode !== 'multiple',\n getPrevNextKey(rootRef.current, currentKey, true, ITEM_SELECTOR),\n getPrevNextKey(rootRef.current, currentKey, false, ITEM_SELECTOR),\n undefined,\n undefined,\n currentKey,\n onCurrentKeyChange\n );\n\n const [showFocusRing, focusRingProps] = useCollectionFocusRing(rootRef, ['ArrowUp', 'ArrowDown']);\n\n useEffect(() => {\n if (currentKey != null && rootRef.current) {\n const elem = findElementByKey(rootRef.current, currentKey, ITEM_SELECTOR);\n if (elem) {\n const activeDescendant = rootRef.current.getAttribute('aria-activedescendant');\n const cell = elem.querySelector(`[role=${listRoles.cell}]`);\n if (cell && activeDescendant !== cell.id) {\n // update aria-activedescendant for screenreader\n rootRef.current.setAttribute('aria-activedescendant', cell.id);\n\n // scroll the current item into view only when the current item is updated internally\n // or when the collection interaction is 'embedded' if the current item is updated by the app\n if (!isCurrentItemOverridden || collectionInteraction === 'embedded') {\n const scroller = viewportConfig?.scroller();\n const offset = scrollToVisibleOffset ? scrollToVisibleOffset(rootRef.current) : 0;\n // make sure item is visible\n scrollToVisible(elem, scroller != null ? scroller : rootRef.current, offset);\n }\n }\n }\n }\n // listen to data because the current item would re-render when the virtualizer\n // is fetching data or updating the data, i.e. the id of current item would be updated,\n // so the currentKey itself couldn't guarantee the root has latest aria-activedescendant\n }, [\n currentKey,\n data,\n listRoles.cell,\n viewportConfig,\n scrollToVisibleOffset,\n rootRef,\n isCurrentItemOverridden\n ]);\n\n const handleSelectionChange = useCallback(\n (detail: SelectionDetail<K>) => {\n if (onSelectionChange) {\n if (detail.value.all === false && detail.value.keys.size > 0) {\n // during regular selection, the last key selected by a user gesture is the anchor key\n anchorKey.current = Array.from(detail.value.keys.values()).pop();\n }\n onSelectionChange(detail);\n }\n },\n [anchorKey, onSelectionChange]\n );\n\n const handleSelectionRangeChange = useCallback(\n (detail: SelectionRangeDetail<K>) => {\n if (data && onSelectionChange) {\n const value = handleSelectionRange(detail, data);\n if (Array.isArray(value)) {\n if (detail.eventType === 'shiftSpace') {\n // during range selection by shift+space, the first key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.start;\n } else {\n // during range selection by shift+click/arrow keys, the last key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.end;\n }\n onSelectionChange({ value: { all: false, keys: new Set(value) }, target: null });\n } else {\n pendingSelectionCallback(detail, value);\n }\n }\n },\n [data, onSelectionChange, pendingSelectionCallback]\n );\n\n const { selectionProps } = useSelection(\n (element: HTMLElement) => {\n if (element === rootRef.current) {\n return currentKey === undefined ? null : currentKey;\n }\n return keyExtractor(element, ITEM_SELECTOR) as K;\n },\n selectedKeys,\n selectionMode,\n false,\n 'replace',\n collectionInteraction === 'embedded',\n handleSelectionChange,\n anchorKey.current,\n currentKey,\n (currentKey: K | undefined, isPrev: boolean) =>\n getPrevNextKey(rootRef.current, currentKey, isPrev, ITEM_SELECTOR),\n undefined,\n (key: K) => {\n if (rootRef.current) {\n const elem = findElementByKey(rootRef.current, key, ITEM_SELECTOR);\n if (elem) {\n const scroller = viewportConfig?.scroller();\n const offset = scrollToVisibleOffset ? scrollToVisibleOffset(rootRef.current) : 0;\n scrollToVisible(elem, scroller != null ? scroller : rootRef.current, offset);\n }\n }\n },\n handleSelectionRangeChange\n );\n\n const itemActionProps = useItemAction(\n currentKey,\n data,\n onItemAction,\n ITEM_SELECTOR,\n collectionInteraction === 'embedded'\n );\n\n return {\n eventProps: mergeProps(currentKeyProps, focusRingProps, selectionProps, itemActionProps),\n showFocusRing,\n handleSelectionChange\n };\n};\n\nexport const handleSelectionRange = <K, D>(\n detail: SelectionRangeDetail<K>,\n dataState: DataState<K, D>\n) => {\n const keys = dataState.data.map((value: { data: D; metadata: Metadata<K> }) => {\n return value.metadata.key;\n });\n const startIndex = keys.indexOf(detail.value.start);\n const endIndex = keys.indexOf(detail.value.end);\n const minIndex = Math.min(startIndex, endIndex);\n const maxIndex = Math.max(startIndex, endIndex);\n if (minIndex === -1) {\n // return a range to fetch so we can find all the keys, maxIndex should not be -1\n return { offset: 0, count: dataState.totalSize };\n } else {\n // range of keys are in the current viewport, return them\n return keys.slice(minIndex, maxIndex + 1);\n }\n};\n","import { RefObject } from 'preact';\nimport { useCallback, useRef } from 'preact/hooks';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { Props as ListViewProps } from '../UNSAFE_ListView';\nimport { CurrentKeyDetail } from '../UNSAFE_Collection';\nimport { getFirstVisibleKey, keyExtractor } from '../utils/PRIVATE_collectionUtils';\nimport { isKeyDefined } from '../utils/UNSAFE_keys';\nimport { ITEM_SELECTOR } from './ListItem';\nimport { useTabbableModeSet } from '../hooks/PRIVATE_useTabbableModeSet';\nimport { findElementByKey } from '../utils/PRIVATE_collectionUtils';\nimport { scrollToVisible } from './ListUtils';\n\nexport const useFocusTabbableMode = <K extends string | number, D>(\n currentKey: K | undefined,\n onCurrentKeyChange: ((detail: CurrentKeyDetail<K>) => void) | undefined,\n allowTabbableMode: ListViewProps<K, D>['allowTabbableMode'],\n rootRef: RefObject<HTMLDivElement>,\n viewportConfig: ListViewProps<K, D>['viewportConfig'],\n scrollToVisibleOffset: ListViewProps<K, D>['scrollToVisibleOffset']\n) => {\n const pendingCurrentKey = useRef<K>();\n\n const [isCurrentTabbableKey, tabbableModeProps] = useTabbableModeSet(\n rootRef,\n (element) => {\n // we don't want List to go into Tabbable mode when user clicks on expander\n return isExpander(element) ? null : (keyExtractor(element, ITEM_SELECTOR) as K);\n },\n currentKey,\n onCurrentKeyChange\n );\n\n const handleInitialFocus = useCallback(() => {\n if (\n rootRef.current &&\n onCurrentKeyChange &&\n (!allowTabbableMode || isCurrentTabbableKey(undefined))\n ) {\n const firstKey =\n pendingCurrentKey.current || (getFirstVisibleKey(rootRef.current, ITEM_SELECTOR) as K);\n if (isKeyDefined(firstKey)) {\n onCurrentKeyChange({ value: firstKey });\n }\n }\n }, [rootRef, onCurrentKeyChange, allowTabbableMode, isCurrentTabbableKey]);\n\n const handleFocus = useCallback(\n (event: FocusEvent) => {\n if (isExpander(event.target as HTMLElement)) {\n rootRef.current?.focus();\n const key = keyExtractor(event.target as HTMLElement, ITEM_SELECTOR);\n if (onCurrentKeyChange && isKeyDefined(key)) {\n onCurrentKeyChange({ value: key as K });\n }\n return;\n }\n if (!isKeyDefined(currentKey)) {\n onCurrentKeyChange && handleInitialFocus();\n } else if (rootRef.current) {\n // if currentKey is defined, make sure scroll the current item into view when listview regains focus\n const elem = findElementByKey(rootRef.current, currentKey as K, ITEM_SELECTOR);\n if (elem) {\n const scroller = viewportConfig?.scroller();\n const offset = scrollToVisibleOffset ? scrollToVisibleOffset(rootRef.current) : 0;\n scrollToVisible(elem, scroller != null ? scroller : rootRef.current, offset);\n } else {\n // if elem is not found, meaning the currentKey is not valid, we should pick the first item as current item\n onCurrentKeyChange && handleInitialFocus();\n }\n }\n },\n [currentKey, handleInitialFocus, onCurrentKeyChange, rootRef]\n );\n\n /**\n * Need to track pointer down element to set currentItem when initial focus happens\n */\n const handlePointerDown = useCallback((event: PointerEvent) => {\n const key = keyExtractor(event.target as HTMLElement, ITEM_SELECTOR);\n if (isKeyDefined(key)) {\n pendingCurrentKey.current = key as K;\n }\n }, []);\n\n return {\n eventProps: mergeProps(allowTabbableMode ? tabbableModeProps : {}, {\n onFocus: handleFocus,\n onPointerDown: handlePointerDown\n }),\n isCurrentTabbableKey\n };\n};\n\nconst isExpander = (elem: HTMLElement) => {\n if (elem.parentElement && elem.parentElement.classList.contains('oj-listview-expander')) {\n return true;\n }\n return false;\n};\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { RefObject } from 'preact';\nimport { useRef, useCallback, useState, useImperativeHandle } from 'preact/hooks';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { containsKey, Keys, isKeyDefined } from '../utils/UNSAFE_keys';\nimport { DataState, ItemContext, ListItemRendererContext, Range } from '../UNSAFE_Collection';\nimport { LoadMoreCollection, LOADMORE_STYLE_CLASS } from '../PRIVATE_LoadMoreCollection';\nimport { VirtualizedCollection } from '../PRIVATE_VirtualizedCollection';\nimport { ViewportConfig } from '../hooks/UNSAFE_useViewportIntersect';\nimport { ListViewItem, ITEM_SELECTOR, MemoizeListViewItem } from './ListItem';\n\nimport { SelectionRangeDetail } from '../hooks/PRIVATE_useSelection';\nimport { SkeletonContainer } from './SkeletonContainer';\nimport { Skeleton } from '../UNSAFE_Skeleton';\nimport { Flex } from '../UNSAFE_Flex';\nimport { Selector } from '../UNSAFE_Selector';\nimport { Props } from '../UNSAFE_ListView';\nimport { Sparkle } from './Sparkle';\nimport { listStyles } from './themes/ListStyles.css';\nimport { useTestId } from '../hooks/UNSAFE_useTestId';\nimport { usePromotedSection } from './usePromotedSection';\nimport { useSelectionAndNavigation, handleSelectionRange } from './useSelectionAndNavigation';\nimport { useFocusTabbableMode } from './useFocusTabbableMode';\nimport { useCurrentItemOverride } from './useCurrentItemOverride';\nimport { Inset } from '../UNSAFE_Inset';\n// TODO: add this import due to issue JET-67485, need to update once Stable is introduced\nimport './themes/redwood/ListBaseTheme.css';\n\n/**\n * Component that renders items as a flat list.\n * In order to maximize performance, only items that are visible in the viewport are rendered.\n */\nexport function List<K extends string | number, D>({\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n allowTabbableMode = true,\n children,\n data,\n gridlines,\n loadingIndicator = defaultLoadingIndicator,\n currentItemOverride,\n onPersistCurrentItem,\n onLoadRange,\n onSelectionChange,\n onItemAction,\n rangeExtractor,\n role = 'grid',\n selectedKeys = emptyKeys as Keys<K>,\n selectionMode = 'none',\n viewportConfig,\n currentItemVariant = 'none',\n promotedSection,\n isVirtualized = false,\n customItemRenderer,\n scrollToVisibleOffset,\n testId,\n scrollerRef,\n reorderProps,\n contextMenuTriggerProps,\n ...props\n}: Props<K, D>) {\n const rootRef = useRef<HTMLDivElement>(null);\n\n // tracking pending selection key that is not in current data\n const pendingSelection = useRef<{ detail: SelectionRangeDetail<K>; range: Range }>();\n\n const [active, setActive] = useState<boolean>(false);\n\n const showGridline = (index: number) => {\n // show bottom gridlines for each item, and for the last item if specified\n return (\n gridlines?.item === 'visible' &&\n (index + 1 !== data?.totalSize || gridlines?.bottom === 'visible')\n );\n };\n\n const showGridlineTop = () => {\n // show the top gridline for the first item\n return gridlines?.item === 'visible' && gridlines?.top === 'visible';\n };\n\n const ariaMultiSelectable = selectionMode === 'none' ? undefined : selectionMode === 'multiple';\n const ariaRowCount =\n data === null ? undefined : data.sizePrecision === 'exact' ? data.totalSize : -1;\n\n const classes = classNames([listStyles.base]);\n\n const pendingSelectionCallback = useCallback(\n (detail: SelectionRangeDetail<K>, value: Range) => {\n if (data) {\n pendingSelection.current = {\n detail: detail,\n range: { offset: data.offset, count: data.data.length }\n };\n onLoadRange(value);\n }\n },\n [data, onLoadRange]\n );\n\n const { currentKey, onCurrentKeyChange, isCurrentItemOverridden } = useCurrentItemOverride(\n currentItemOverride,\n onPersistCurrentItem\n );\n\n const { eventProps, showFocusRing, handleSelectionChange } = useSelectionAndNavigation(\n currentKey,\n selectedKeys,\n selectionMode,\n onCurrentKeyChange,\n onSelectionChange,\n onItemAction,\n data,\n viewportConfig,\n role,\n scrollToVisibleOffset,\n rootRef,\n pendingSelectionCallback,\n isCurrentItemOverridden\n );\n\n const { eventProps: focusTabbableProps, isCurrentTabbableKey } = useFocusTabbableMode(\n currentKey,\n onCurrentKeyChange,\n allowTabbableMode,\n rootRef,\n viewportConfig,\n scrollToVisibleOffset\n );\n\n if (data && pendingSelection.current !== undefined && onSelectionChange) {\n const keys = handleSelectionRange(pendingSelection.current.detail, data);\n if (Array.isArray(keys)) {\n onSelectionChange({ value: { all: false, keys: new Set(keys) }, target: null });\n }\n const range = pendingSelection.current\n ? pendingSelection.current.range\n : { offset: data.offset, count: data.data.length };\n data = adjustDataState(data, range);\n pendingSelection.current = undefined;\n onLoadRange(range);\n }\n\n const { sparkleHeight, suggestions } = usePromotedSection(data, promotedSection, rootRef);\n\n // TODO: check suggestions before Sparkle would cause a scrolling issue\n const sparkleIndicator = <Sparkle sparkleHeight={sparkleHeight}></Sparkle>;\n\n // Collection generic is of this type\n type DataStateData = DataState<K, D>['data'][number];\n\n // returns an ListItemContext based on ItemContext (added metadata and selector)\n // note the type for ItemContext, this is the context coming from Collection\n const getItemContext = useCallback(\n (context: ItemContext<DataStateData>) => {\n const dataStateData = context.data;\n const selectorRenderer =\n selectionMode === 'multiple'\n ? () => (\n <Selector\n onChange={handleSelectionChange}\n rowKey={dataStateData.metadata.key}\n selectedKeys={selectedKeys}></Selector>\n )\n : undefined;\n\n return {\n index: context.index,\n data: dataStateData.data,\n metadata: dataStateData.metadata,\n selector: selectorRenderer\n };\n },\n [selectionMode, selectedKeys, handleSelectionChange]\n );\n\n const ItemComponent = isVirtualized ? ListViewItem : MemoizeListViewItem;\n\n const childrenComponent = (context: ItemContext<DataStateData>) => {\n const listItemContext = getItemContext(context);\n const suggestion = suggestions?.get(listItemContext.metadata.key);\n const isTabbable = allowTabbableMode && isCurrentTabbableKey(listItemContext.metadata.key);\n const isFocused = currentKey === listItemContext.metadata.key && !isTabbable;\n const isActive = isFocused && active;\n const isSelected = containsKey(selectedKeys, listItemContext.metadata.key);\n const isFocusRingVisible = isFocused && showFocusRing;\n const listItemFunc = (ctx: ListItemRendererContext<K, D>, otherProps?: any) => (\n <ItemComponent\n key={listItemContext.metadata.key}\n context={ctx}\n isFocused={isFocused}\n isFocusRingVisible={isFocusRingVisible}\n isActive={isActive}\n isGridlineVisible={showGridline(listItemContext.index)}\n isSelected={isSelected}\n isTabbable={allowTabbableMode && isCurrentTabbableKey(listItemContext.metadata.key)}\n role={role}\n selectionMode={selectionMode}\n currentItemVariant={currentItemVariant}\n {...(suggestion && { suggestion })}\n {...(listItemContext.index === 0 && { isTopGridlineVisible: showGridlineTop() })}\n {...otherProps}>\n {children}\n </ItemComponent>\n );\n\n // if customItemRenderer is specified (ExpandableList and GroupedList)\n // create a custom context with additional info including a function\n // that helps create the default item component\n if (customItemRenderer) {\n const customRendererContext = {\n listItemContext,\n isFocused,\n isFocusRingVisible,\n isSelected,\n isTabbable,\n isActive,\n defaultListItem: listItemFunc\n };\n return customItemRenderer(customRendererContext);\n }\n return listItemFunc(listItemContext);\n };\n\n viewportConfig = getViewportConfig(rootRef, viewportConfig);\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === ' ' && isKeyDefined(currentKey) && selectionMode !== 'none') {\n setActive(true);\n }\n },\n [currentKey, selectionMode, setActive]\n );\n\n const handleKeyUp = useCallback(() => {\n setActive(false);\n }, [setActive]);\n\n useImperativeHandle(scrollerRef!, () => rootRef.current);\n\n // if data is not specified, listview should show loading indicator\n // todo: replace placeholder with actual SkeletonContainer component (Ash is working on)\n const testIdProps = useTestId(testId);\n return (\n <div\n {...mergeProps(\n eventProps,\n focusTabbableProps,\n contextMenuTriggerProps || {},\n reorderProps || {},\n {\n onKeyDown: handleKeyDown,\n onKeyUp: handleKeyUp\n },\n props\n )}\n {...testIdProps}\n role={role}\n aria-rowcount={role === 'grid' ? ariaRowCount : undefined}\n aria-colcount={role === 'grid' ? 1 : undefined}\n ref={rootRef}\n class={classes}\n tabIndex={0}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-multiselectable={ariaMultiSelectable}>\n {data == null ? (\n loadingIndicator\n ) : isVirtualized ? (\n <VirtualizedCollection\n data={data}\n itemSelector={ITEM_SELECTOR}\n loadMoreIndicator={defaultLoadMoreIndicator}\n onLoadRange={onLoadRange}\n rangeExtractor={rangeExtractor}\n suggestions={sparkleIndicator}\n viewportConfig={viewportConfig}>\n {childrenComponent}\n </VirtualizedCollection>\n ) : (\n <LoadMoreCollection\n data={data.data}\n loadMoreIndicator={defaultLoadMoreIndicator}\n hasMore={data.sizePrecision === 'atLeast' && data.data.length <= data.totalSize}\n onLoadMore={() => {\n data && onLoadRange({ offset: 0, count: data.data.length + 25 });\n }}\n suggestions={sparkleIndicator}\n viewportConfig={viewportConfig}>\n {childrenComponent}\n </LoadMoreCollection>\n )}\n </div>\n );\n}\n\nconst getViewportConfig = (rootRef: RefObject<HTMLElement>, config?: ViewportConfig) => {\n return (\n config ?? {\n scroller: () => {\n return rootRef.current;\n }\n }\n );\n};\n\nconst emptyKeys = { all: false, keys: new Set() };\n\nconst defaultLoadingIndicator = (\n <SkeletonContainer minimumCount={25}>\n {() => {\n return (\n <Inset variant=\"listview\">\n <Flex height=\"6x\" align=\"center\">\n <Skeleton height=\"4x\" />\n </Flex>\n </Inset>\n );\n }}\n </SkeletonContainer>\n);\n\nconst defaultLoadMoreIndicator = (\n <div class={LOADMORE_STYLE_CLASS}>\n <SkeletonContainer minimumCount={3}>\n {() => {\n return (\n <Inset variant=\"listview\">\n <Flex height=\"6x\" align=\"center\">\n <Skeleton height=\"4x\" />\n </Flex>\n </Inset>\n );\n }}\n </SkeletonContainer>\n </div>\n);\n\n/**\n * Adjust the DataState as needed if it contains more than needed for the specified range\n */\nconst adjustDataState = <K, D>(dataState: DataState<K, D>, range: Range | null) => {\n if (range) {\n // prevent range offset from being larger than the data state\n const safeRangeOffset = Math.min(range.offset, dataState.offset + dataState.totalSize);\n const diff = safeRangeOffset - dataState.offset;\n if (diff > 0) {\n dataState = {\n offset: safeRangeOffset,\n data: dataState.data.slice(diff, diff + range.count),\n totalSize: dataState.totalSize,\n sizePrecision: dataState.sizePrecision\n };\n }\n }\n return dataState;\n};\n","import { useRef, useMemo, useState, useEffect } from 'preact/hooks';\nimport { Props as ListProps } from '../UNSAFE_ListView';\nimport { CurrentKeyDetail, Item, CurrentItemDetail } from '../UNSAFE_Collection';\nimport { useReorderableContext } from '#hooks/PRIVATE_useReorderable/useReorderableContext';\n\n/**\n * This hook converts the new API (i.e. currentItemOverride and onPersistCurrentItem) back to\n * the old API (i.e. currentKey and onCurrentKeyChange), keeps the internal current item, and\n * also triggers an update when a new currentItemOverride is passed by the app\n *\n * @param currentItemOverride\n * @param onPersistCurrentItem\n */\nexport const useCurrentItemOverride = <K extends string | number, D>(\n currentItemOverride: ListProps<K, D>['currentItemOverride'],\n onPersistCurrentItem: ListProps<K, D>['onPersistCurrentItem']\n) => {\n // the internal state of current item\n const [currentItem, setCurrentItem] = useState<Item<K>>();\n // track the currentItemOverride props\n const currentItemOverrideRef = useRef<Item<K>>();\n // whether the current item is overridden by the app\n const isCurrentItemOverridden = useRef(false);\n // update current item key for reorderable list\n const reorderContext = useReorderableContext();\n\n // intercept onPersistCurrentItem calls to ensure internal state is updated appropriately\n const handleCurrentItemChanged = useMemo(() => {\n return (detail: CurrentItemDetail<K>) => {\n setCurrentItem(detail.value);\n onPersistCurrentItem?.(detail);\n if (reorderContext?.currentItemKey != null) {\n reorderContext.currentItemKey.current = detail.value?.rowKey;\n }\n };\n }, [onPersistCurrentItem, reorderContext?.currentItemKey]);\n\n // ensure any new currentItemOverride settings are applied only on that render\n // (same as how Table handles the changes)\n if (currentItemOverrideRef.current !== currentItemOverride) {\n currentItemOverrideRef.current = currentItemOverride;\n if (currentItem?.rowKey !== currentItemOverride?.rowKey) {\n isCurrentItemOverridden.current = true;\n handleCurrentItemChanged({ value: currentItemOverride });\n }\n }\n\n useEffect(() => {\n isCurrentItemOverridden.current = false;\n });\n\n return {\n currentKey: currentItem?.rowKey,\n onCurrentKeyChange: (detail: CurrentKeyDetail<K>) => {\n handleCurrentItemChanged({ value: { rowKey: detail.value } });\n },\n isCurrentItemOverridden: isCurrentItemOverridden.current\n };\n};\n"],"names":["getListViewRoles","ariaRole","list","item","cell","ITEM_SELECTOR","ListViewItem","children","context","itemDepth","isFocused","isFocusRingVisible","isActive","isGridlineVisible","isSelected","isTopGridlineVisible","isTabbable","role","selectionMode","suggestion","currentItemVariant","rootRef","useRef","roles","useMemo","itemKey","metadata","key","itemIndex","index","cellRoleAttributes","interactionProps","applyActiveStyle","applyHoverStyle","applyPseudoHoverStyle","useInteractionStyle","variantClasses","listItemMultiVariantStyles","selectable","isSelectable","selected","selectedSingle","needsEventsHover","pseudoHover","active","focusHighlight","focusRingVisible","gridlineTop","gridlineBottom","classes","classNames","styleInterpolations","mergeInterpolations","Object","values","flexitemInterpolations","class","cls","cellStyles","flex","alignSelf","cellClasses","listItemStyles","checkboxContainer","_jsx","jsx","undefined","ref","id","useId","style","onKeyDown","event","stopPropagation","TabbableModeContext","Provider","value","FocusTrap","isDisabled","restoreFocusRef","isItemSelected","MemoizeListViewItem","memo","prev","next","compareListItemContext","SkeletonContainer","minimumCount","isVisible","setIsVisible","useState","useEffect","setTimeout","containerClasses","skeletonStyles","container","Array","map","_element","SPARKLE_STYLE_CLASS","Sparkle","sparkleHeight","name","useTheme","height","sparkleClasses","sparkleStyles","base","globalImages","findSuggestions","data","count","slice","reduce","suggestions","set","Map","scrollToVisible","elem","scroller","offset","scrollIntoViewIfNeeded","scrollIntoView","block","scrollerBounds","getBoundingClientRect","elemBounds","diff","top","scrollTop","handleSelectionRange","detail","dataState","keys","startIndex","indexOf","start","endIndex","end","minIndex","Math","min","maxIndex","max","totalSize","isExpander","parentElement","classList","contains","getViewportConfig","config","current","emptyKeys","all","Set","defaultLoadingIndicator","Inset","variant","Flex","align","Skeleton","defaultLoadMoreIndicator","LOADMORE_STYLE_CLASS","adjustDataState","range","safeRangeOffset","sizePrecision","ariaLabel","ariaLabelledBy","allowTabbableMode","gridlines","loadingIndicator","currentItemOverride","onPersistCurrentItem","onLoadRange","onSelectionChange","onItemAction","rangeExtractor","selectedKeys","viewportConfig","promotedSection","isVirtualized","customItemRenderer","scrollToVisibleOffset","testId","scrollerRef","reorderProps","contextMenuTriggerProps","props","pendingSelection","setActive","ariaMultiSelectable","ariaRowCount","listStyles","pendingSelectionCallback","useCallback","length","currentKey","onCurrentKeyChange","isCurrentItemOverridden","currentItem","setCurrentItem","currentItemOverrideRef","reorderContext","useReorderableContext","handleCurrentItemChanged","currentItemKey","rowKey","useCurrentItemOverride","eventProps","showFocusRing","handleSelectionChange","listRoles","anchorKey","collectionInteraction","useCollectionInteractionContext","currentKeyProps","useCurrentKey","element","keyExtractor","getPrevNextKey","focusRingProps","useCollectionFocusRing","findElementByKey","activeDescendant","getAttribute","querySelector","setAttribute","size","from","pop","handleSelectionRangeChange","isArray","eventType","target","selectionProps","useSelection","isPrev","itemActionProps","useItemAction","mergeProps","useSelectionAndNavigation","focusTabbableProps","isCurrentTabbableKey","pendingCurrentKey","tabbableModeProps","useTabbableModeSet","handleInitialFocus","firstKey","getFirstVisibleKey","isKeyDefined","handleFocus","focus","handlePointerDown","onFocus","onPointerDown","useFocusTabbableMode","setSparkleHeight","placeholder","PLACEHOLDER_STYLE_CLASS","offsetHeight","suggestionItems","querySelectorAll","forEach","usePromotedSection","sparkleIndicator","getItemContext","dataStateData","selectorRenderer","Selector","onChange","selector","ItemComponent","childrenComponent","listItemContext","get","containsKey","listItemFunc","ctx","otherProps","bottom","defaultListItem","handleKeyDown","handleKeyUp","useImperativeHandle","testIdProps","useTestId","onKeyUp","tabIndex","VirtualizedCollection","itemSelector","loadMoreIndicator","LoadMoreCollection","hasMore","onLoadMore","groups","filter","dataMetadata","isLeaf","leafOnly","includes"],"mappings":"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"}
1
+ {"version":3,"file":"List-3ebac3fc.js","sources":["../../src/PRIVATE_List/ListRoles.ts","../../src/PRIVATE_List/ListItem.tsx","../../src/PRIVATE_List/SkeletonContainer.tsx","../../src/PRIVATE_List/Sparkle.tsx","../../src/PRIVATE_List/usePromotedSection.ts","../../src/PRIVATE_List/ListUtils.ts","../../src/PRIVATE_List/useSelectionAndNavigation.ts","../../src/PRIVATE_List/useFocusTabbableMode.ts","../../src/PRIVATE_List/List.tsx","../../src/PRIVATE_List/useCurrentItemOverride.ts"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Roles } from '../UNSAFE_ListView';\nimport { HTMLAttributesSignalExcluded } from '../utils/UNSAFE_attributeUtils';\n\n/**\n * List Roles need to be kept in matching sets, this module encapsulates the sets\n *\n * @param ariaRole\n * @returns matching, valid set of roles\n */\n\nconst getListViewRoles = (\n ariaRole: Roles\n): {\n list: HTMLAttributesSignalExcluded['role'];\n item: HTMLAttributesSignalExcluded['role'];\n cell: HTMLAttributesSignalExcluded['role'];\n} => {\n switch (ariaRole) {\n case 'listbox':\n return { list: 'listbox', item: 'presentation', cell: 'option' };\n case 'treegrid':\n return { list: 'treegrid', item: 'row', cell: 'gridcell' };\n default:\n return { list: 'grid', item: 'row', cell: 'gridcell' };\n }\n};\n\nexport { getListViewRoles };\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren } from 'preact';\nimport { useRef, useMemo } from 'preact/hooks';\nimport { memo } from 'preact/compat';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { TabbableModeContext } from '../hooks/UNSAFE_useTabbableMode';\nimport { SelectionMode, CurrentItemVariant, ListItemRendererContext } from '../UNSAFE_Collection';\nimport { FocusTrap } from '../UNSAFE_FocusTrap';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { Roles } from '../UNSAFE_ListView';\nimport { getListViewRoles } from './ListRoles';\nimport { useInteractionStyle } from '../hooks/UNSAFE_useInteractionStyle';\nimport { mergeInterpolations } from '../utils/UNSAFE_mergeInterpolations';\nimport { flexitemInterpolations } from '../utils/UNSAFE_interpolations/flexitem';\nimport type { FlexitemProps } from '../utils/UNSAFE_interpolations/flexitem';\nimport { listItemStyles, listItemMultiVariantStyles } from './themes/ListStyles.css';\nimport { compareListItemContext } from '../utils/PRIVATE_collectionUtils';\n\nexport const ITEM_SELECTOR = '[data-oj-key]';\n\n/**\n * Props for the ListViewItem Component\n */\nexport type Props<K, D> = {\n children: (context: ListItemRendererContext<K, D>) => ComponentChildren;\n context: ListItemRendererContext<K, D>;\n itemDepth?: number;\n isFocused: boolean;\n isFocusRingVisible: boolean;\n isActive: boolean;\n isGridlineVisible: boolean;\n isSelected: boolean;\n isTopGridlineVisible?: boolean;\n isTabbable?: boolean;\n role: Roles;\n selectionMode: SelectionMode;\n suggestion?: 'end' | true;\n currentItemVariant?: CurrentItemVariant;\n};\n\n/**\n * The internal component used to render a single item in ListView.\n */\nexport function ListViewItem<K extends string | number, D>({\n children,\n context,\n itemDepth,\n isFocused,\n isFocusRingVisible,\n isActive,\n isGridlineVisible,\n isSelected,\n isTopGridlineVisible = false,\n isTabbable = false,\n role,\n selectionMode,\n suggestion,\n currentItemVariant\n}: Props<K, D>) {\n const rootRef = useRef<HTMLDivElement>(null);\n const roles = useMemo(() => getListViewRoles(role), [role]);\n const itemKey = context.metadata.key;\n const itemIndex = context.index;\n\n // some roles come with related aria attributes which need to be set\n const cellRoleAttributes =\n roles.cell === 'option'\n ? {\n role: roles.cell,\n 'aria-posinset': itemIndex + 1,\n 'aria-setsize': -1\n }\n : {\n role: roles.cell\n };\n\n // don't bubble Arrow Up and Down events to parent when in isTabbable mode\n // this bubbling causes the outer CollectionFocus ring to change index while in the isTabbable mode.\n const handleKeyDown = (event: KeyboardEvent) => {\n if (isTabbable && (event.key === 'ArrowDown' || event.key === 'ArrowUp')) {\n event.stopPropagation();\n }\n };\n\n const { interactionProps, applyActiveStyle, applyHoverStyle, applyPseudoHoverStyle } =\n useInteractionStyle();\n\n const variantClasses = listItemMultiVariantStyles({\n selectable: isSelectable(selectionMode, isSelected) ? 'isSelectable' : 'notSelectable',\n selected: isSelected ? 'isSelected' : 'notSelected',\n selectedSingle:\n isSelected && selectionMode === 'single' ? 'isSelectedSingle' : 'notSelectedSingle',\n needsEventsHover: applyHoverStyle ? 'isNeedsEventsHover' : 'notNeedsEventsHover',\n pseudoHover: applyPseudoHoverStyle ? 'isPseudoHover' : 'notPseudoHover',\n active: applyActiveStyle || isActive ? 'isActive' : 'notActive',\n focusHighlight:\n currentItemVariant === 'highlight' && isFocused ? 'isFocusHighlight' : 'notFocusHighlight',\n focusRingVisible:\n isFocusRingVisible && isFocused ? 'isFocusRingVisible' : 'notFocusRingVisible',\n gridlineTop: isTopGridlineVisible ? 'visible' : 'hidden',\n gridlineBottom:\n isGridlineVisible ||\n (suggestion === 'end' && !isGridlineVisible && (!isSelected || selectionMode !== 'single'))\n ? 'visible'\n : 'hidden'\n });\n const classes = classNames([variantClasses]);\n const styleInterpolations = mergeInterpolations<FlexitemProps>([\n ...Object.values(flexitemInterpolations)\n ]);\n const { class: cls, ...cellStyles } = styleInterpolations({\n flex: '1 1 auto',\n alignSelf: 'center'\n });\n const cellClasses = classNames([\n cls,\n selectionMode === 'multiple' && listItemStyles.checkboxContainer\n ]);\n\n // todo: use translated text for selector\n // note cannot put focus on gridcell div since JAWS will not read the aria-rowindex\n // correctly, so unfortunately needed another div\n return (\n <div\n aria-rowindex={role === 'grid' ? itemIndex + 1 : undefined}\n aria-level={itemDepth}\n data-oj-key={itemKey}\n class={classes}\n ref={rootRef}\n role={roles.item}\n {...(suggestion && { 'data-oj-suggestion': true })}\n {...(typeof itemKey === 'number' && { 'data-oj-key-type': 'number' })}\n {...interactionProps}>\n <div\n id={useId()}\n style={cellStyles}\n class={cellClasses}\n aria-posinset={role === 'grid' ? undefined : itemIndex + 1}\n aria-setsize={role === 'grid' ? undefined : -1}\n onKeyDown={handleKeyDown}\n aria-colindex={role === 'grid' ? 1 : undefined}\n aria-selected={selectionMode !== 'none' ? isSelected : undefined}\n {...cellRoleAttributes}>\n <TabbableModeContext.Provider value={{ isTabbable }}>\n <FocusTrap isDisabled={!isTabbable} restoreFocusRef={false}>\n {children(context)}\n </FocusTrap>\n </TabbableModeContext.Provider>\n </div>\n </div>\n );\n}\n\n/**\n * Helper method to determine whether item is selectable\n * @returns true if item is selectable (show hover effect), false otherwise\n */\nconst isSelectable = (selectionMode: SelectionMode, isItemSelected: boolean) => {\n return selectionMode !== 'none' && (selectionMode === 'multiple' || !isItemSelected);\n};\n\nexport const MemoizeListViewItem = memo(ListViewItem, (prev: any, next: any) => {\n if (prev && next) {\n return (\n prev.children === next.children &&\n prev.isFocused === next.isFocused &&\n prev.isFocusRingVisible === next.isFocusRingVisible &&\n prev.isSelected === next.isSelected &&\n prev.isTabbable === next.isTabbable &&\n prev.isActive === next.isActive &&\n prev.suggestion === next.suggestion &&\n prev.isGridlineVisible === next.isGridlineVisible &&\n prev.isTopGridlineVisible === next.isTopGridlineVisible &&\n compareListItemContext(prev.context, next.context)\n );\n }\n return false;\n});\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren } from 'preact';\nimport { useState, useEffect } from 'preact/hooks';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { skeletonStyles } from './themes/ListStyles.css';\n\ntype Props = {\n /**\n * Allows to pass and access the properties from child elements\n **/\n children?: (index: number) => ComponentChildren;\n /**\n * Allows to specify number of skeletons to be rendered on initial load\n **/\n minimumCount?: number;\n};\n\n/**\n * Allows to specify the time delay for rendering the component\n **/\nconst timerValue = 50;\n\n/**\n * SkeletonContainer renders 'minimumCount' number of skeletons\n * of the variant specified from its child element - Skeleton's prop after\n * 'timerValue' ms delay\n **/\nexport function SkeletonContainer({ children, minimumCount = 1 }: Props) {\n const [isVisible, setIsVisible] = useState(false);\n\n useEffect(() => {\n setTimeout(() => {\n setIsVisible(true);\n }, timerValue);\n }, []);\n\n const containerClasses = classNames([skeletonStyles.container]);\n return isVisible && children ? (\n <div class={containerClasses} role=\"presentation\">\n {[...Array(minimumCount)].map((_element, index) => children(index))}\n </div>\n ) : null;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { globalImages } from '#/ImageVars.css';\nimport { sparkleStyles } from './themes/ListStyles.css';\nimport { useTheme } from '#/hooks/UNSAFE_useTheme';\n\nconst SPARKLE_STYLE_CLASS = 'oj-collection-sparkle';\n\n/**\n * A sparkle component for smart suggestion indicator in ListView\n * @param sparkleHeight the height of sparkle\n */\nexport function Sparkle({ sparkleHeight }: { sparkleHeight: number }) {\n const { name } = useTheme();\n if (sparkleHeight <= 0) {\n return null;\n }\n\n const height = sparkleHeight + 'px';\n const sparkleClasses = classNames([sparkleStyles.base]);\n const containerClasses = classNames([\n sparkleStyles.container,\n SPARKLE_STYLE_CLASS,\n // TODO: this component should create separate theme definitions to only show the image in redwood\n name === 'redwood' && globalImages\n ]);\n\n return (\n <div key=\"sparkle\" class={containerClasses}>\n <div class={sparkleClasses} style={{ height }}></div>\n </div>\n );\n}\n","import { RefObject } from 'preact';\nimport { useState, useEffect, useMemo } from 'preact/hooks';\nimport { Props as ListViewProps } from '../UNSAFE_ListView';\nimport { PLACEHOLDER_STYLE_CLASS } from '../PRIVATE_VirtualizedCollection';\nimport { Metadata } from '../UNSAFE_Collection';\n\nexport const usePromotedSection = <K extends string | number, D>(\n data: ListViewProps<K, D>['data'],\n promotedSection: ListViewProps<K, D>['promotedSection'],\n rootRef: RefObject<HTMLDivElement>\n) => {\n // tracking sparkle height\n const [sparkleHeight, setSparkleHeight] = useState<number>(0);\n\n const suggestions = useMemo(\n () => data && promotedSection && findSuggestions(data.data, promotedSection.count),\n [data, promotedSection]\n );\n\n useEffect(() => {\n // update sparkleHeight only when we have suggestions\n // avoid unnecessary iterating through elements\n if (suggestions) {\n const placeholder = rootRef.current?.querySelector(\n '.' + PLACEHOLDER_STYLE_CLASS\n ) as HTMLElement;\n let height = placeholder?.offsetHeight || 0;\n const suggestionItems = rootRef.current?.querySelectorAll('[data-oj-suggestion]');\n suggestionItems?.forEach((item) => (height += (item as HTMLElement).offsetHeight));\n setSparkleHeight(height);\n }\n }, [rootRef, suggestions]);\n\n return { sparkleHeight, suggestions };\n};\n\n/**\n * A helper function that finds the data with suggestions, and\n * returns the corresponding keys\n * @param dataState\n */\nconst findSuggestions = <K, D>(data: { data: D; metadata: Metadata<K> }[], count: number) => {\n if (count === 0) {\n return null;\n }\n\n const suggestionsData = data.slice(0, count);\n return suggestionsData.reduce((suggestions, value, index) => {\n const key = value.metadata.key;\n\n if (index === count - 1) {\n suggestions.set(key, 'end');\n } else {\n suggestions.set(key, true);\n }\n\n return suggestions;\n }, new Map<K, 'end' | true>());\n};\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { FlattenedDataState } from '../UNSAFE_Collection';\nimport { Keys } from '../utils/UNSAFE_keys';\n\n/**\n * Helper function to only include keys of leaf items.\n */\nexport const excludeGroup = <K, D>(data: FlattenedDataState<K, D>, keys: Keys<K>) => {\n if (!keys.all) {\n const groups = data.data\n .filter((dataMetadata) => {\n return !dataMetadata.metadata.isLeaf;\n })\n .map((dataMetadata) => {\n return dataMetadata.metadata.key;\n });\n const leafOnly = Array.from(keys.keys.values()).filter((key: K) => {\n return !groups.includes(key);\n });\n return { ...keys, keys: new Set(leafOnly) };\n }\n return keys;\n};\n\n/**\n * A helper function to make sure specified elem is visible in the specified container\n */\nexport const scrollToVisible = (elem: Element, scroller: Element, offset: number) => {\n if (elem && scroller) {\n if ((elem as any).scrollIntoViewIfNeeded) {\n // for Safari, we'll need the non-standard scrollIntoViewIfNeeded\n (elem as any).scrollIntoViewIfNeeded();\n } else {\n elem.scrollIntoView({ block: 'nearest' });\n }\n if (offset > 0) {\n const scrollerBounds = scroller.getBoundingClientRect();\n const elemBounds = elem.getBoundingClientRect();\n const diff = scrollerBounds.top + offset - elemBounds.top;\n if (diff > 0) {\n scroller.scrollTop = scroller.scrollTop - diff;\n }\n }\n }\n};\n","import { RefObject } from 'preact';\nimport { useEffect, useCallback, useRef, useMemo } from 'preact/hooks';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { Keys } from '../utils/UNSAFE_keys';\nimport {\n DataState,\n Metadata,\n Range,\n SelectionDetail,\n CurrentKeyDetail\n} from '../UNSAFE_Collection';\nimport { getListViewRoles } from './ListRoles';\nimport { SelectionRangeDetail, useSelection } from '../hooks/PRIVATE_useSelection';\nimport { useCurrentKey } from '../hooks/PRIVATE_useCurrentKey';\nimport { useCollectionFocusRing } from '../hooks/PRIVATE_useCollectionFocusRing';\nimport { useCollectionInteractionContext } from '../hooks/UNSAFE_useCollectionInteractionContext';\nimport { useItemAction } from '../hooks/PRIVATE_useItemAction';\nimport { Props as ListViewProps } from '../UNSAFE_ListView';\nimport { getPrevNextKey, findElementByKey, keyExtractor } from '../utils/PRIVATE_collectionUtils';\nimport { ITEM_SELECTOR } from './ListItem';\nimport { scrollToVisible } from './ListUtils';\n\nexport const useSelectionAndNavigation = <K extends string | number, D>(\n currentKey: K | undefined,\n selectedKeys: Keys<K>,\n selectionMode: ListViewProps<K, D>['selectionMode'] = 'none',\n onCurrentKeyChange: ((detail: CurrentKeyDetail<K>) => void) | undefined,\n onSelectionChange: ListViewProps<K, D>['onSelectionChange'],\n onItemAction: ListViewProps<K, D>['onItemAction'],\n data: ListViewProps<K, D>['data'],\n viewportConfig: ListViewProps<K, D>['viewportConfig'],\n role: ListViewProps<K, D>['role'] = 'grid',\n scrollToVisibleOffset: ListViewProps<K, D>['scrollToVisibleOffset'],\n rootRef: RefObject<HTMLDivElement>,\n pendingSelectionCallback: (detail: SelectionRangeDetail<K>, value: Range) => void,\n isCurrentItemOverridden: boolean\n) => {\n const listRoles = useMemo(() => getListViewRoles(role), [role]);\n\n // tracking the anchor key which is used for shift+click selection\n const anchorKey = useRef<K | undefined>();\n\n const collectionInteraction = useCollectionInteractionContext();\n\n const { currentKeyProps } = useCurrentKey(\n (element) => keyExtractor(element, ITEM_SELECTOR),\n selectionMode !== 'multiple',\n getPrevNextKey(rootRef.current, currentKey, true, ITEM_SELECTOR),\n getPrevNextKey(rootRef.current, currentKey, false, ITEM_SELECTOR),\n undefined,\n undefined,\n currentKey,\n onCurrentKeyChange\n );\n\n const [showFocusRing, focusRingProps] = useCollectionFocusRing(rootRef, ['ArrowUp', 'ArrowDown']);\n\n useEffect(() => {\n if (currentKey != null && rootRef.current) {\n const elem = findElementByKey(rootRef.current, currentKey, ITEM_SELECTOR);\n if (elem) {\n const activeDescendant = rootRef.current.getAttribute('aria-activedescendant');\n const cell = elem.querySelector(`[role=${listRoles.cell}]`);\n if (cell && activeDescendant !== cell.id) {\n // update aria-activedescendant for screenreader\n rootRef.current.setAttribute('aria-activedescendant', cell.id);\n\n // scroll the current item into view only when the current item is updated internally\n // or when the collection interaction is 'embedded' if the current item is updated by the app\n if (!isCurrentItemOverridden || collectionInteraction === 'embedded') {\n const scroller = viewportConfig?.scroller();\n const offset = scrollToVisibleOffset ? scrollToVisibleOffset(rootRef.current) : 0;\n // make sure item is visible\n scrollToVisible(elem, scroller != null ? scroller : rootRef.current, offset);\n }\n }\n }\n }\n // listen to data because the current item would re-render when the virtualizer\n // is fetching data or updating the data, i.e. the id of current item would be updated,\n // so the currentKey itself couldn't guarantee the root has latest aria-activedescendant\n }, [\n currentKey,\n data,\n listRoles.cell,\n viewportConfig,\n scrollToVisibleOffset,\n rootRef,\n isCurrentItemOverridden\n ]);\n\n const handleSelectionChange = useCallback(\n (detail: SelectionDetail<K>) => {\n if (onSelectionChange) {\n if (detail.value.all === false && detail.value.keys.size > 0) {\n // during regular selection, the last key selected by a user gesture is the anchor key\n anchorKey.current = Array.from(detail.value.keys.values()).pop();\n }\n onSelectionChange(detail);\n }\n },\n [anchorKey, onSelectionChange]\n );\n\n const handleSelectionRangeChange = useCallback(\n (detail: SelectionRangeDetail<K>) => {\n if (data && onSelectionChange) {\n const value = handleSelectionRange(detail, data);\n if (Array.isArray(value)) {\n if (detail.eventType === 'shiftSpace') {\n // during range selection by shift+space, the first key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.start;\n } else {\n // during range selection by shift+click/arrow keys, the last key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.end;\n }\n onSelectionChange({ value: { all: false, keys: new Set(value) }, target: null });\n } else {\n pendingSelectionCallback(detail, value);\n }\n }\n },\n [data, onSelectionChange, pendingSelectionCallback]\n );\n\n const { selectionProps } = useSelection(\n (element: HTMLElement) => {\n if (element === rootRef.current) {\n return currentKey === undefined ? null : currentKey;\n }\n return keyExtractor(element, ITEM_SELECTOR) as K;\n },\n selectedKeys,\n selectionMode,\n false,\n 'replace',\n collectionInteraction === 'embedded',\n handleSelectionChange,\n anchorKey.current,\n currentKey,\n (currentKey: K | undefined, isPrev: boolean) =>\n getPrevNextKey(rootRef.current, currentKey, isPrev, ITEM_SELECTOR),\n undefined,\n (key: K) => {\n if (rootRef.current) {\n const elem = findElementByKey(rootRef.current, key, ITEM_SELECTOR);\n if (elem) {\n const scroller = viewportConfig?.scroller();\n const offset = scrollToVisibleOffset ? scrollToVisibleOffset(rootRef.current) : 0;\n scrollToVisible(elem, scroller != null ? scroller : rootRef.current, offset);\n }\n }\n },\n handleSelectionRangeChange\n );\n\n const itemActionProps = useItemAction(\n currentKey,\n data,\n onItemAction,\n ITEM_SELECTOR,\n collectionInteraction === 'embedded'\n );\n\n return {\n eventProps: mergeProps(currentKeyProps, focusRingProps, selectionProps, itemActionProps),\n showFocusRing,\n handleSelectionChange\n };\n};\n\nexport const handleSelectionRange = <K, D>(\n detail: SelectionRangeDetail<K>,\n dataState: DataState<K, D>\n) => {\n const keys = dataState.data.map((value: { data: D; metadata: Metadata<K> }) => {\n return value.metadata.key;\n });\n const startIndex = keys.indexOf(detail.value.start);\n const endIndex = keys.indexOf(detail.value.end);\n const minIndex = Math.min(startIndex, endIndex);\n const maxIndex = Math.max(startIndex, endIndex);\n if (minIndex === -1) {\n // return a range to fetch so we can find all the keys, maxIndex should not be -1\n return { offset: 0, count: dataState.totalSize };\n } else {\n // range of keys are in the current viewport, return them\n return keys.slice(minIndex, maxIndex + 1);\n }\n};\n","import { RefObject } from 'preact';\nimport { useCallback, useRef } from 'preact/hooks';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { Props as ListViewProps } from '../UNSAFE_ListView';\nimport { CurrentKeyDetail } from '../UNSAFE_Collection';\nimport { getFirstVisibleKey, keyExtractor } from '../utils/PRIVATE_collectionUtils';\nimport { isKeyDefined } from '../utils/UNSAFE_keys';\nimport { ITEM_SELECTOR } from './ListItem';\nimport { useTabbableModeSet } from '../hooks/PRIVATE_useTabbableModeSet';\nimport { findElementByKey } from '../utils/PRIVATE_collectionUtils';\nimport { scrollToVisible } from './ListUtils';\n\nexport const useFocusTabbableMode = <K extends string | number, D>(\n currentKey: K | undefined,\n onCurrentKeyChange: ((detail: CurrentKeyDetail<K>) => void) | undefined,\n allowTabbableMode: ListViewProps<K, D>['allowTabbableMode'],\n rootRef: RefObject<HTMLDivElement>,\n viewportConfig: ListViewProps<K, D>['viewportConfig'],\n scrollToVisibleOffset: ListViewProps<K, D>['scrollToVisibleOffset']\n) => {\n const pendingCurrentKey = useRef<K>();\n\n const [isCurrentTabbableKey, tabbableModeProps] = useTabbableModeSet(\n rootRef,\n (element) => {\n // we don't want List to go into Tabbable mode when user clicks on expander\n return isExpander(element) ? null : (keyExtractor(element, ITEM_SELECTOR) as K);\n },\n currentKey,\n onCurrentKeyChange\n );\n\n const handleInitialFocus = useCallback(() => {\n if (\n rootRef.current &&\n onCurrentKeyChange &&\n (!allowTabbableMode || isCurrentTabbableKey(undefined))\n ) {\n const firstKey =\n pendingCurrentKey.current || (getFirstVisibleKey(rootRef.current, ITEM_SELECTOR) as K);\n if (isKeyDefined(firstKey)) {\n onCurrentKeyChange({ value: firstKey });\n }\n }\n }, [rootRef, onCurrentKeyChange, allowTabbableMode, isCurrentTabbableKey]);\n\n const handleFocus = useCallback(\n (event: FocusEvent) => {\n if (isExpander(event.target as HTMLElement)) {\n rootRef.current?.focus();\n const key = keyExtractor(event.target as HTMLElement, ITEM_SELECTOR);\n if (onCurrentKeyChange && isKeyDefined(key)) {\n onCurrentKeyChange({ value: key as K });\n }\n return;\n }\n if (!isKeyDefined(currentKey)) {\n onCurrentKeyChange && handleInitialFocus();\n } else if (rootRef.current) {\n // if currentKey is defined, make sure scroll the current item into view when listview regains focus\n const elem = findElementByKey(rootRef.current, currentKey as K, ITEM_SELECTOR);\n if (elem) {\n const scroller = viewportConfig?.scroller();\n const offset = scrollToVisibleOffset ? scrollToVisibleOffset(rootRef.current) : 0;\n scrollToVisible(elem, scroller != null ? scroller : rootRef.current, offset);\n } else {\n // if elem is not found, meaning the currentKey is not valid, we should pick the first item as current item\n onCurrentKeyChange && handleInitialFocus();\n }\n }\n },\n [currentKey, handleInitialFocus, onCurrentKeyChange, rootRef]\n );\n\n /**\n * Need to track pointer down element to set currentItem when initial focus happens\n */\n const handlePointerDown = useCallback((event: PointerEvent) => {\n const key = keyExtractor(event.target as HTMLElement, ITEM_SELECTOR);\n if (isKeyDefined(key)) {\n pendingCurrentKey.current = key as K;\n }\n }, []);\n\n return {\n eventProps: mergeProps(allowTabbableMode ? tabbableModeProps : {}, {\n onFocus: handleFocus,\n onPointerDown: handlePointerDown\n }),\n isCurrentTabbableKey\n };\n};\n\nconst isExpander = (elem: HTMLElement) => {\n if (elem.parentElement && elem.parentElement.classList.contains('oj-listview-expander')) {\n return true;\n }\n return false;\n};\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { RefObject } from 'preact';\nimport { useRef, useCallback, useState, useImperativeHandle } from 'preact/hooks';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { containsKey, Keys, isKeyDefined } from '../utils/UNSAFE_keys';\nimport { DataState, ItemContext, ListItemRendererContext, Range } from '../UNSAFE_Collection';\nimport { LoadMoreCollection, LOADMORE_STYLE_CLASS } from '../PRIVATE_LoadMoreCollection';\nimport { VirtualizedCollection } from '../PRIVATE_VirtualizedCollection';\nimport { ViewportConfig } from '../hooks/UNSAFE_useViewportIntersect';\nimport { ListViewItem, ITEM_SELECTOR, MemoizeListViewItem } from './ListItem';\n\nimport { SelectionRangeDetail } from '../hooks/PRIVATE_useSelection';\nimport { SkeletonContainer } from './SkeletonContainer';\nimport { Skeleton } from '../UNSAFE_Skeleton';\nimport { Flex } from '../UNSAFE_Flex';\nimport { Selector } from '../UNSAFE_Selector';\nimport { Props } from '../UNSAFE_ListView';\nimport { Sparkle } from './Sparkle';\nimport { listStyles } from './themes/ListStyles.css';\nimport { useTestId } from '../hooks/UNSAFE_useTestId';\nimport { usePromotedSection } from './usePromotedSection';\nimport { useSelectionAndNavigation, handleSelectionRange } from './useSelectionAndNavigation';\nimport { useFocusTabbableMode } from './useFocusTabbableMode';\nimport { useCurrentItemOverride } from './useCurrentItemOverride';\nimport { Inset } from '../UNSAFE_Inset';\n// TODO: add this import due to issue JET-67485, need to update once Stable is introduced\nimport './themes/redwood/ListBaseTheme.css';\n\n/**\n * Component that renders items as a flat list.\n * In order to maximize performance, only items that are visible in the viewport are rendered.\n */\nexport function List<K extends string | number, D>({\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n allowTabbableMode = true,\n children,\n data,\n gridlines,\n loadingIndicator = defaultLoadingIndicator,\n currentItemOverride,\n onPersistCurrentItem,\n onLoadRange,\n onSelectionChange,\n onItemAction,\n rangeExtractor,\n role = 'grid',\n selectedKeys = emptyKeys as Keys<K>,\n selectionMode = 'none',\n viewportConfig,\n currentItemVariant = 'none',\n promotedSection,\n isVirtualized = false,\n customItemRenderer,\n scrollToVisibleOffset,\n testId,\n scrollerRef,\n reorderProps,\n contextMenuTriggerProps,\n ...props\n}: Props<K, D>) {\n const rootRef = useRef<HTMLDivElement>(null);\n\n // tracking pending selection key that is not in current data\n const pendingSelection = useRef<{ detail: SelectionRangeDetail<K>; range: Range }>();\n\n const [active, setActive] = useState<boolean>(false);\n\n const showGridline = (index: number) => {\n // show bottom gridlines for each item, and for the last item if specified\n return (\n gridlines?.item === 'visible' &&\n (index + 1 !== data?.totalSize || gridlines?.bottom === 'visible')\n );\n };\n\n const showGridlineTop = () => {\n // show the top gridline for the first item\n return gridlines?.item === 'visible' && gridlines?.top === 'visible';\n };\n\n const ariaMultiSelectable = selectionMode === 'none' ? undefined : selectionMode === 'multiple';\n const ariaRowCount =\n data === null ? undefined : data.sizePrecision === 'exact' ? data.totalSize : -1;\n\n const classes = classNames([listStyles.base]);\n\n const pendingSelectionCallback = useCallback(\n (detail: SelectionRangeDetail<K>, value: Range) => {\n if (data) {\n pendingSelection.current = {\n detail: detail,\n range: { offset: data.offset, count: data.data.length }\n };\n onLoadRange(value);\n }\n },\n [data, onLoadRange]\n );\n\n const { currentKey, onCurrentKeyChange, isCurrentItemOverridden } = useCurrentItemOverride(\n currentItemOverride,\n onPersistCurrentItem\n );\n\n const { eventProps, showFocusRing, handleSelectionChange } = useSelectionAndNavigation(\n currentKey,\n selectedKeys,\n selectionMode,\n onCurrentKeyChange,\n onSelectionChange,\n onItemAction,\n data,\n viewportConfig,\n role,\n scrollToVisibleOffset,\n rootRef,\n pendingSelectionCallback,\n isCurrentItemOverridden\n );\n\n const { eventProps: focusTabbableProps, isCurrentTabbableKey } = useFocusTabbableMode(\n currentKey,\n onCurrentKeyChange,\n allowTabbableMode,\n rootRef,\n viewportConfig,\n scrollToVisibleOffset\n );\n\n if (data && pendingSelection.current !== undefined && onSelectionChange) {\n const keys = handleSelectionRange(pendingSelection.current.detail, data);\n if (Array.isArray(keys)) {\n onSelectionChange({ value: { all: false, keys: new Set(keys) }, target: null });\n }\n const range = pendingSelection.current\n ? pendingSelection.current.range\n : { offset: data.offset, count: data.data.length };\n data = adjustDataState(data, range);\n pendingSelection.current = undefined;\n onLoadRange(range);\n }\n\n const { sparkleHeight, suggestions } = usePromotedSection(data, promotedSection, rootRef);\n\n // TODO: check suggestions before Sparkle would cause a scrolling issue\n const sparkleIndicator = <Sparkle sparkleHeight={sparkleHeight}></Sparkle>;\n\n // Collection generic is of this type\n type DataStateData = DataState<K, D>['data'][number];\n\n // returns an ListItemContext based on ItemContext (added metadata and selector)\n // note the type for ItemContext, this is the context coming from Collection\n const getItemContext = useCallback(\n (context: ItemContext<DataStateData>) => {\n const dataStateData = context.data;\n const selectorRenderer =\n selectionMode === 'multiple'\n ? () => (\n <Selector\n onChange={handleSelectionChange}\n rowKey={dataStateData.metadata.key}\n selectedKeys={selectedKeys}></Selector>\n )\n : undefined;\n\n return {\n index: context.index,\n data: dataStateData.data,\n metadata: dataStateData.metadata,\n selector: selectorRenderer\n };\n },\n [selectionMode, selectedKeys, handleSelectionChange]\n );\n\n const ItemComponent = isVirtualized ? ListViewItem : MemoizeListViewItem;\n\n const childrenComponent = (context: ItemContext<DataStateData>) => {\n const listItemContext = getItemContext(context);\n const suggestion = suggestions?.get(listItemContext.metadata.key);\n const isTabbable = allowTabbableMode && isCurrentTabbableKey(listItemContext.metadata.key);\n const isFocused = currentKey === listItemContext.metadata.key && !isTabbable;\n const isActive = isFocused && active;\n const isSelected = containsKey(selectedKeys, listItemContext.metadata.key);\n const isFocusRingVisible = isFocused && showFocusRing;\n const listItemFunc = (ctx: ListItemRendererContext<K, D>, otherProps?: any) => (\n <ItemComponent\n key={listItemContext.metadata.key}\n context={ctx}\n isFocused={isFocused}\n isFocusRingVisible={isFocusRingVisible}\n isActive={isActive}\n isGridlineVisible={showGridline(listItemContext.index)}\n isSelected={isSelected}\n isTabbable={allowTabbableMode && isCurrentTabbableKey(listItemContext.metadata.key)}\n role={role}\n selectionMode={selectionMode}\n currentItemVariant={currentItemVariant}\n {...(suggestion && { suggestion })}\n {...(listItemContext.index === 0 && { isTopGridlineVisible: showGridlineTop() })}\n {...otherProps}>\n {children}\n </ItemComponent>\n );\n\n // if customItemRenderer is specified (ExpandableList and GroupedList)\n // create a custom context with additional info including a function\n // that helps create the default item component\n if (customItemRenderer) {\n const customRendererContext = {\n listItemContext,\n isFocused,\n isFocusRingVisible,\n isSelected,\n isTabbable,\n isActive,\n defaultListItem: listItemFunc\n };\n return customItemRenderer(customRendererContext);\n }\n return listItemFunc(listItemContext);\n };\n\n viewportConfig = getViewportConfig(rootRef, viewportConfig);\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === ' ' && isKeyDefined(currentKey) && selectionMode !== 'none') {\n setActive(true);\n }\n },\n [currentKey, selectionMode, setActive]\n );\n\n const handleKeyUp = useCallback(() => {\n setActive(false);\n }, [setActive]);\n\n useImperativeHandle(scrollerRef!, () => rootRef.current);\n\n // if data is not specified, listview should show loading indicator\n // todo: replace placeholder with actual SkeletonContainer component (Ash is working on)\n const testIdProps = useTestId(testId);\n return (\n <div\n {...mergeProps(\n eventProps,\n focusTabbableProps,\n contextMenuTriggerProps || {},\n reorderProps || {},\n {\n onKeyDown: handleKeyDown,\n onKeyUp: handleKeyUp\n },\n props\n )}\n {...testIdProps}\n role={role}\n aria-rowcount={role === 'grid' ? ariaRowCount : undefined}\n aria-colcount={role === 'grid' ? 1 : undefined}\n ref={rootRef}\n class={classes}\n tabIndex={0}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-multiselectable={ariaMultiSelectable}>\n {data == null ? (\n loadingIndicator\n ) : isVirtualized ? (\n <VirtualizedCollection\n data={data}\n itemSelector={ITEM_SELECTOR}\n loadMoreIndicator={defaultLoadMoreIndicator}\n onLoadRange={onLoadRange}\n rangeExtractor={rangeExtractor}\n suggestions={sparkleIndicator}\n viewportConfig={viewportConfig}>\n {childrenComponent}\n </VirtualizedCollection>\n ) : (\n <LoadMoreCollection\n data={data.data}\n loadMoreIndicator={defaultLoadMoreIndicator}\n hasMore={data.sizePrecision === 'atLeast' && data.data.length <= data.totalSize}\n onLoadMore={() => {\n data && onLoadRange({ offset: 0, count: data.data.length + 25 });\n }}\n suggestions={sparkleIndicator}\n viewportConfig={viewportConfig}>\n {childrenComponent}\n </LoadMoreCollection>\n )}\n </div>\n );\n}\n\nconst getViewportConfig = (rootRef: RefObject<HTMLElement>, config?: ViewportConfig) => {\n return (\n config ?? {\n scroller: () => {\n return rootRef.current;\n }\n }\n );\n};\n\nconst emptyKeys = { all: false, keys: new Set() };\n\nconst defaultLoadingIndicator = (\n <SkeletonContainer minimumCount={25}>\n {() => {\n return (\n <Inset variant=\"listview\">\n <Flex height=\"6x\" align=\"center\">\n <Skeleton height=\"4x\" />\n </Flex>\n </Inset>\n );\n }}\n </SkeletonContainer>\n);\n\nconst defaultLoadMoreIndicator = (\n <div class={LOADMORE_STYLE_CLASS}>\n <SkeletonContainer minimumCount={3}>\n {() => {\n return (\n <Inset variant=\"listview\">\n <Flex height=\"6x\" align=\"center\">\n <Skeleton height=\"4x\" />\n </Flex>\n </Inset>\n );\n }}\n </SkeletonContainer>\n </div>\n);\n\n/**\n * Adjust the DataState as needed if it contains more than needed for the specified range\n */\nconst adjustDataState = <K, D>(dataState: DataState<K, D>, range: Range | null) => {\n if (range) {\n // prevent range offset from being larger than the data state\n const safeRangeOffset = Math.min(range.offset, dataState.offset + dataState.totalSize);\n const diff = safeRangeOffset - dataState.offset;\n if (diff > 0) {\n dataState = {\n offset: safeRangeOffset,\n data: dataState.data.slice(diff, diff + range.count),\n totalSize: dataState.totalSize,\n sizePrecision: dataState.sizePrecision\n };\n }\n }\n return dataState;\n};\n","import { useRef, useMemo, useState, useEffect } from 'preact/hooks';\nimport { Props as ListProps } from '../UNSAFE_ListView';\nimport { CurrentKeyDetail, Item, CurrentItemDetail } from '../UNSAFE_Collection';\nimport { useReorderableContext } from '#hooks/PRIVATE_useReorderable/useReorderableContext';\n\n/**\n * This hook converts the new API (i.e. currentItemOverride and onPersistCurrentItem) back to\n * the old API (i.e. currentKey and onCurrentKeyChange), keeps the internal current item, and\n * also triggers an update when a new currentItemOverride is passed by the app\n *\n * @param currentItemOverride\n * @param onPersistCurrentItem\n */\nexport const useCurrentItemOverride = <K extends string | number, D>(\n currentItemOverride: ListProps<K, D>['currentItemOverride'],\n onPersistCurrentItem: ListProps<K, D>['onPersistCurrentItem']\n) => {\n // the internal state of current item\n const [currentItem, setCurrentItem] = useState<Item<K>>();\n // track the currentItemOverride props\n const currentItemOverrideRef = useRef<Item<K>>();\n // whether the current item is overridden by the app\n const isCurrentItemOverridden = useRef(false);\n // update current item key for reorderable list\n const reorderContext = useReorderableContext();\n\n // intercept onPersistCurrentItem calls to ensure internal state is updated appropriately\n const handleCurrentItemChanged = useMemo(() => {\n return (detail: CurrentItemDetail<K>) => {\n setCurrentItem(detail.value);\n onPersistCurrentItem?.(detail);\n if (reorderContext?.currentItemKey != null) {\n reorderContext.currentItemKey.current = detail.value?.rowKey;\n }\n };\n }, [onPersistCurrentItem, reorderContext?.currentItemKey]);\n\n // ensure any new currentItemOverride settings are applied only on that render\n // (same as how Table handles the changes)\n if (currentItemOverrideRef.current !== currentItemOverride) {\n currentItemOverrideRef.current = currentItemOverride;\n if (currentItem?.rowKey !== currentItemOverride?.rowKey) {\n isCurrentItemOverridden.current = true;\n handleCurrentItemChanged({ value: currentItemOverride });\n }\n }\n\n useEffect(() => {\n isCurrentItemOverridden.current = false;\n });\n\n return {\n currentKey: currentItem?.rowKey,\n onCurrentKeyChange: (detail: CurrentKeyDetail<K>) => {\n handleCurrentItemChanged({ value: { rowKey: detail.value } });\n },\n isCurrentItemOverridden: isCurrentItemOverridden.current\n };\n};\n"],"names":["getListViewRoles","ariaRole","list","item","cell","ITEM_SELECTOR","ListViewItem","children","context","itemDepth","isFocused","isFocusRingVisible","isActive","isGridlineVisible","isSelected","isTopGridlineVisible","isTabbable","role","selectionMode","suggestion","currentItemVariant","rootRef","useRef","roles","useMemo","itemKey","metadata","key","itemIndex","index","cellRoleAttributes","interactionProps","applyActiveStyle","applyHoverStyle","applyPseudoHoverStyle","useInteractionStyle","variantClasses","listItemMultiVariantStyles","selectable","isSelectable","selected","selectedSingle","needsEventsHover","pseudoHover","active","focusHighlight","focusRingVisible","gridlineTop","gridlineBottom","classes","classNames","styleInterpolations","mergeInterpolations","Object","values","flexitemInterpolations","class","cls","cellStyles","flex","alignSelf","cellClasses","listItemStyles","checkboxContainer","_jsx","jsx","undefined","ref","id","useId","style","onKeyDown","event","stopPropagation","TabbableModeContext","Provider","value","FocusTrap","isDisabled","restoreFocusRef","isItemSelected","MemoizeListViewItem","memo","prev","next","compareListItemContext","SkeletonContainer","minimumCount","isVisible","setIsVisible","useState","useEffect","setTimeout","containerClasses","skeletonStyles","container","Array","map","_element","SPARKLE_STYLE_CLASS","Sparkle","sparkleHeight","name","useTheme","height","sparkleClasses","sparkleStyles","base","globalImages","findSuggestions","data","count","slice","reduce","suggestions","set","Map","scrollToVisible","elem","scroller","offset","scrollIntoViewIfNeeded","scrollIntoView","block","scrollerBounds","getBoundingClientRect","elemBounds","diff","top","scrollTop","handleSelectionRange","detail","dataState","keys","startIndex","indexOf","start","endIndex","end","minIndex","Math","min","maxIndex","max","totalSize","isExpander","parentElement","classList","contains","getViewportConfig","config","current","emptyKeys","all","Set","defaultLoadingIndicator","Inset","variant","Flex","align","Skeleton","defaultLoadMoreIndicator","LOADMORE_STYLE_CLASS","adjustDataState","range","safeRangeOffset","sizePrecision","ariaLabel","ariaLabelledBy","allowTabbableMode","gridlines","loadingIndicator","currentItemOverride","onPersistCurrentItem","onLoadRange","onSelectionChange","onItemAction","rangeExtractor","selectedKeys","viewportConfig","promotedSection","isVirtualized","customItemRenderer","scrollToVisibleOffset","testId","scrollerRef","reorderProps","contextMenuTriggerProps","props","pendingSelection","setActive","ariaMultiSelectable","ariaRowCount","listStyles","pendingSelectionCallback","useCallback","length","currentKey","onCurrentKeyChange","isCurrentItemOverridden","currentItem","setCurrentItem","currentItemOverrideRef","reorderContext","useReorderableContext","handleCurrentItemChanged","currentItemKey","rowKey","useCurrentItemOverride","eventProps","showFocusRing","handleSelectionChange","listRoles","anchorKey","collectionInteraction","useCollectionInteractionContext","currentKeyProps","useCurrentKey","element","keyExtractor","getPrevNextKey","focusRingProps","useCollectionFocusRing","findElementByKey","activeDescendant","getAttribute","querySelector","setAttribute","size","from","pop","handleSelectionRangeChange","isArray","eventType","target","selectionProps","useSelection","isPrev","itemActionProps","useItemAction","mergeProps","useSelectionAndNavigation","focusTabbableProps","isCurrentTabbableKey","pendingCurrentKey","tabbableModeProps","useTabbableModeSet","handleInitialFocus","firstKey","getFirstVisibleKey","isKeyDefined","handleFocus","focus","handlePointerDown","onFocus","onPointerDown","useFocusTabbableMode","setSparkleHeight","placeholder","PLACEHOLDER_STYLE_CLASS","offsetHeight","suggestionItems","querySelectorAll","forEach","usePromotedSection","sparkleIndicator","getItemContext","dataStateData","selectorRenderer","Selector","onChange","selector","ItemComponent","childrenComponent","listItemContext","get","containsKey","listItemFunc","ctx","otherProps","bottom","defaultListItem","handleKeyDown","handleKeyUp","useImperativeHandle","testIdProps","useTestId","onKeyUp","tabIndex","VirtualizedCollection","itemSelector","loadMoreIndicator","LoadMoreCollection","hasMore","onLoadMore","groups","filter","dataMetadata","isLeaf","leafOnly","includes"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- define(['exports', 'preact/jsx-runtime', 'preact/compat', 'preact/hooks', './LayerHost-e95c5f30', 'css!./DragAndDropStyles.styles.css', './useReorderableContext-652356ad', 'css!./ReorderableItemStyles.styles.css', './HiddenAccessible-037ef42d', './collectionUtils-6740111c', './useReorderableItem-7fd4d629', './classNames-08d99695', './UNSAFE_ListView/themes/ListViewStyles.css', './mergeProps-bcfa6a92', './List-61d64cd6', './Menu-8f3a1e8c', './MenuItem-44b2547b', 'preact', './logger-0f873e29', 'css!./TooltipContentStyles.styles.css', 'module', './hooks/UNSAFE_useTooltip/themes/redwood/TooltipContentVariants.css', './tooltipUtils-3b34c2bc', 'css!./IconStyle.styles.css', './SelectMenuGroupContext-67f24a8f', './UNSAFE_Separator/themes/SeparatorStyles.css', 'css!./MenuSeparatorStyles.styles.css', 'module', './UNSAFE_Menu/themes/redwood/MenuSeparatorVariants.css', './useItemAction-66d976c4', './useContextMenuGesture-a2ad99c1'], (function(e,r,t,o,n,s,l,i,c,a,u,d,f,m,y,g,p,x,C,I,h,R,S,b,v,M,E,P,T,O,K){"use strict";const w=(e,r)=>{if(null!=e){const t=e.querySelectorAll("[role='row']");if(t.length>r)return a.getKey(t[r])}return null};function k(e,r){const t=Math.abs(null==r?e.scrollTop:r),o={y:t,key:void 0,offsetY:void 0};let n=0;const s=e.querySelectorAll("[role='row']");if(s.length>0&&0===t)return o.key=w(e,0),o.offsetY=0,o;for(let r=0;r<s.length;r++){const l=s[r].getBoundingClientRect().height;if(n+=l,t<n){o.key=w(e,r),o.offsetY=l+t-n;break}}return o}function L(e,r){const t=function(e,r){if(null!=r){let t,o=!1;if(null!=r.key?(o=!0,t=r.key):null!=r.offsetY&&null==r.y&&(o=!0,t=k(e).key),o){if(null!=t){let o=0;const n=e.querySelectorAll("[role ='row']");for(let e=0;e<n.length;e++){if(t===a.getKey(n[e]))return o+(null!=r.offsetY?r.offsetY:0);o+=n[e].getBoundingClientRect().height}}}else if(null!=r.y)return r.y}return}(e,r);e.scrollTop=null!=t?t:0}const D=t.memo((function({children:e,dragKey:t,setDragKey:n,onReorder:s,rootRef:l,itemKey:i}){const c=o.useRef(null),m={itemOverlayFront:f.styles.reorderableItemOverlayFront,itemOverlayRear:f.styles.reorderableItemOverlayRear,itemDragger:f.styles.reorderableItemDragger},y=o.useCallback((e=>{e.dataTransfer?.setData("text/listview-items-key",JSON.stringify(i))}),[i]),{rootProps:g,isDragged:p,overlayZoneBeforeProps:x,overlayZoneAfterProps:C}=u.useReorderableItem({currentKey:void 0,isDisabled:!s,draggable:!!s,dragKey:t,setDragKey:n,onReorder:s,rootRef:l,ref:c,getItem:()=>c?.current?.closest(a.ITEM_SELECTOR),setTransferData:y,itemStyles:m,itemSelector:a.ITEM_SELECTOR,isVertical:!0}),I=d.classNames([g?.class,f.styles.reorderableItemDnd]);return r.jsxs("div",{...g,draggable:!1,class:I,children:[e,!p&&t&&r.jsxs(r.Fragment,{children:[r.jsx("div",{...x}),r.jsx("div",{...C})]})]})}),((e,r)=>!(!e||!r)&&(e?.children===r?.children&&e?.dragKey===r?.dragKey)));function j({contextMenuConfig:e,contextMenuContext:t,...o}){const n=e.accessibleLabel;return r.jsx(r.Fragment,{children:r.jsx(g.Menu,{...o,...n&&{"aria-label":n},children:o.isOpen&&e.itemsRenderer(t)})})}const A={mouse:{initialFocus:"menu",placement:"bottom-start",offsetValue:0},keyboard:{initialFocus:"firstItem",placement:"bottom-start",offsetValue:0},touch:{initialFocus:"menu",placement:"end",offsetValue:40}},F={isOpen:!1,initialFocus:"menu",placement:"bottom-start",offsetValue:0,anchorRef:{current:null}},_=t.forwardRef(((e,t)=>{const{contextMenuConfig:n}=e,s=o.useRef(),i=o.useRef(null),{currentItemOverride:d,updateCurrentItemOverride:f}=(e=>{const r=o.useRef(),t=o.useRef();t.current!==e&&(t.current=e,r.current=e);const n=o.useCallback((e=>{r.current={rowKey:e}}),[]);return{currentItemOverride:r.current,updateCurrentItemOverride:n}})(e.currentItemOverride),g=e.data?e.data.map((r=>({data:r,metadata:{key:e.getRowKey(r)}}))):null,p=e.onLoadMore?e.onLoadMore:()=>{},x=g?{offset:0,data:g,sizePrecision:e.hasMore?"atLeast":"exact",totalSize:g.length}:null,{triggerProps:C,menuProps:I,contextMenuContext:h,notifyCurrentItemChanged:R}=((e,r,t,n)=>{const[s,l]=o.useState(),[i,c]=o.useState(F),u=o.useRef(),{triggerProps:d}=K.useContextMenuGesture((({gesture:r,anchor:o,target:s})=>{let i=o;if("keyboard"===r){i=a.findElementByKey(t.current,u.current?.rowKey,a.ITEM_SELECTOR)||o;const r=O.findItemContext(u.current?.rowKey,e);l(r)}else{const r=a.keyExtractor(s,a.ITEM_SELECTOR),t=O.findItemContext(r,e);l(t),n(r)}c({...A[r],anchorRef:{current:i},isOpen:!0})}),{isDisabled:!r}),f=o.useCallback((e=>{"dismissed"!==e.reason&&"itemAction"!==e.reason||t.current?.focus({preventScroll:!0}),c({...F})}),[t]);return{menuProps:{...i,onClose:f},onClose:f,contextMenuContext:s,triggerProps:d,notifyCurrentItemChanged:e=>{u.current=e.value}}})(x,n,i,f),S=r=>{e.onPersistCurrentItem?.(r),R(r)};o.useImperativeHandle(t,(()=>({getScrollPosition:()=>i.current?k(i.current):{y:0}}))),o.useLayoutEffect((()=>{i.current&&s.current!==e.scrollPositionOverride&&(L(i.current,e.scrollPositionOverride),s.current=e.scrollPositionOverride)}),[e.scrollPositionOverride]);const b=null!=e.onReorder,{reorderProps:v,reorderItemProps:M,reorderContext:E,reorderInstructionsId:P,reorderInstructions:T}=(({onReorder:e,rootRef:r,viewportConfig:t})=>{const n=null!=e,[s,l]=o.useState(void 0),{reorderProps:i,reorderContext:c,reorderInstructionsId:d,reorderInstructions:f}=u.useReorderable({onReorder:e,rootRef:r,itemSelector:a.ITEM_SELECTOR,isDisabled:!n,columns:1}),g=o.useRef(!1);return o.useEffect((()=>{if(n&&g.current){const e=r.current,o=a.findElementByKey(e,c.currentItemKey.current,a.ITEM_SELECTOR);if(o){const r=t?.scroller()||e;y.scrollToVisible(o,r,0),g.current=!1}}})),n?{reorderProps:m.mergeProps({onKeyDown:e=>{n&&("ArrowUp"===e.key||"ArrowDown"===e.key)&&(e.metaKey||e.ctrlKey)&&e.shiftKey&&(g.current=!0,i.onKeyDown?.(e))},onDragOver:e=>{void 0!==s&&(g.current=!1,a.dragToScroll(e,void 0!==s,r.current))}}),reorderItemProps:{dragKey:s,setDragKey:l,onReorder:e,rootRef:r},reorderContext:c,reorderInstructionsId:d,reorderInstructions:f}:{reorderProps:i,reorderContext:c,reorderInstructionsId:d,reorderInstructions:f}})({onReorder:e.onReorder,rootRef:i,viewportConfig:e.viewportConfig});return b&&M?r.jsxs(r.Fragment,{children:[r.jsxs(l.ReorderableContext.Provider,{value:E,children:[r.jsx(y.List,{...e,contextMenuTriggerProps:C,reorderProps:v,onLoadRange:p,scrollerRef:i,data:x,currentItemOverride:d,onPersistCurrentItem:S,children:t=>r.jsx(D,{...M,itemKey:t.metadata.key,children:e.children(t)})}),r.jsx("span",{id:P,children:r.jsx(c.HiddenAccessible,{children:T})})]}),n&&r.jsx(j,{...I,contextMenuConfig:n,contextMenuContext:h})]}):r.jsxs(r.Fragment,{children:[r.jsx(y.List,{...e,onLoadRange:p,scrollerRef:i,data:x,contextMenuTriggerProps:C,currentItemOverride:d,onPersistCurrentItem:S,children:e.children}),n&&r.jsx(j,{...I,contextMenuConfig:n,contextMenuContext:h})]})}));e.ListView=_}));
2
- //# sourceMappingURL=ListView-a49e52c3.js.map
1
+ define(['exports', 'preact/jsx-runtime', 'preact/compat', 'preact/hooks', './LayerHost-e95c5f30', 'css!./DragAndDropStyles.styles.css', './useReorderableContext-652356ad', 'css!./ReorderableItemStyles.styles.css', './HiddenAccessible-037ef42d', './collectionUtils-6740111c', './useReorderableItem-7fd4d629', './classNames-08d99695', './UNSAFE_ListView/themes/ListViewStyles.css', './mergeProps-bcfa6a92', './List-3ebac3fc', './Menu-8f3a1e8c', './MenuItem-44b2547b', 'preact', './logger-0f873e29', 'css!./TooltipContentStyles.styles.css', 'module', './hooks/UNSAFE_useTooltip/themes/redwood/TooltipContentVariants.css', './tooltipUtils-3b34c2bc', 'css!./IconStyle.styles.css', './SelectMenuGroupContext-67f24a8f', './UNSAFE_Separator/themes/SeparatorStyles.css', 'css!./MenuSeparatorStyles.styles.css', 'module', './UNSAFE_Menu/themes/redwood/MenuSeparatorVariants.css', './useItemAction-66d976c4', './useContextMenuGesture-a2ad99c1'], (function(e,r,t,o,n,s,l,i,c,a,u,d,f,m,y,g,p,x,C,I,h,R,S,b,v,M,E,P,T,O,K){"use strict";const w=(e,r)=>{if(null!=e){const t=e.querySelectorAll("[role='row']");if(t.length>r)return a.getKey(t[r])}return null};function k(e,r){const t=Math.abs(null==r?e.scrollTop:r),o={y:t,key:void 0,offsetY:void 0};let n=0;const s=e.querySelectorAll("[role='row']");if(s.length>0&&0===t)return o.key=w(e,0),o.offsetY=0,o;for(let r=0;r<s.length;r++){const l=s[r].getBoundingClientRect().height;if(n+=l,t<n){o.key=w(e,r),o.offsetY=l+t-n;break}}return o}function L(e,r){const t=function(e,r){if(null!=r){let t,o=!1;if(null!=r.key?(o=!0,t=r.key):null!=r.offsetY&&null==r.y&&(o=!0,t=k(e).key),o){if(null!=t){let o=0;const n=e.querySelectorAll("[role ='row']");for(let e=0;e<n.length;e++){if(t===a.getKey(n[e]))return o+(null!=r.offsetY?r.offsetY:0);o+=n[e].getBoundingClientRect().height}}}else if(null!=r.y)return r.y}return}(e,r);e.scrollTop=null!=t?t:0}const D=t.memo((function({children:e,dragKey:t,setDragKey:n,onReorder:s,rootRef:l,itemKey:i}){const c=o.useRef(null),m={itemOverlayFront:f.styles.reorderableItemOverlayFront,itemOverlayRear:f.styles.reorderableItemOverlayRear,itemDragger:f.styles.reorderableItemDragger},y=o.useCallback((e=>{e.dataTransfer?.setData("text/listview-items-key",JSON.stringify(i))}),[i]),{rootProps:g,isDragged:p,overlayZoneBeforeProps:x,overlayZoneAfterProps:C}=u.useReorderableItem({currentKey:void 0,isDisabled:!s,draggable:!!s,dragKey:t,setDragKey:n,onReorder:s,rootRef:l,ref:c,getItem:()=>c?.current?.closest(a.ITEM_SELECTOR),setTransferData:y,itemStyles:m,itemSelector:a.ITEM_SELECTOR,isVertical:!0}),I=d.classNames([g?.class,f.styles.reorderableItemDnd]);return r.jsxs("div",{...g,draggable:!1,class:I,children:[e,!p&&t&&r.jsxs(r.Fragment,{children:[r.jsx("div",{...x}),r.jsx("div",{...C})]})]})}),((e,r)=>!(!e||!r)&&(e?.children===r?.children&&e?.dragKey===r?.dragKey)));function j({contextMenuConfig:e,contextMenuContext:t,...o}){const n=e.accessibleLabel;return r.jsx(r.Fragment,{children:r.jsx(g.Menu,{...o,...n&&{"aria-label":n},children:o.isOpen&&e.itemsRenderer(t)})})}const A={mouse:{initialFocus:"menu",placement:"bottom-start",offsetValue:0},keyboard:{initialFocus:"firstItem",placement:"bottom-start",offsetValue:0},touch:{initialFocus:"menu",placement:"end",offsetValue:40}},F={isOpen:!1,initialFocus:"menu",placement:"bottom-start",offsetValue:0,anchorRef:{current:null}},_=t.forwardRef(((e,t)=>{const{contextMenuConfig:n}=e,s=o.useRef(),i=o.useRef(null),{currentItemOverride:d,updateCurrentItemOverride:f}=(e=>{const r=o.useRef(),t=o.useRef();t.current!==e&&(t.current=e,r.current=e);const n=o.useCallback((e=>{r.current={rowKey:e}}),[]);return{currentItemOverride:r.current,updateCurrentItemOverride:n}})(e.currentItemOverride),g=e.data?e.data.map((r=>({data:r,metadata:{key:e.getRowKey(r)}}))):null,p=e.onLoadMore?e.onLoadMore:()=>{},x=g?{offset:0,data:g,sizePrecision:e.hasMore?"atLeast":"exact",totalSize:g.length}:null,{triggerProps:C,menuProps:I,contextMenuContext:h,notifyCurrentItemChanged:R}=((e,r,t,n)=>{const[s,l]=o.useState(),[i,c]=o.useState(F),u=o.useRef(),{triggerProps:d}=K.useContextMenuGesture((({gesture:r,anchor:o,target:s})=>{let i=o;if("keyboard"===r){i=a.findElementByKey(t.current,u.current?.rowKey,a.ITEM_SELECTOR)||o;const r=O.findItemContext(u.current?.rowKey,e);l(r)}else{const r=a.keyExtractor(s,a.ITEM_SELECTOR),t=O.findItemContext(r,e);l(t),n(r)}c({...A[r],anchorRef:{current:i},isOpen:!0})}),{isDisabled:!r}),f=o.useCallback((e=>{"dismissed"!==e.reason&&"itemAction"!==e.reason||t.current?.focus({preventScroll:!0}),c({...F})}),[t]);return{menuProps:{...i,onClose:f},onClose:f,contextMenuContext:s,triggerProps:d,notifyCurrentItemChanged:e=>{u.current=e.value}}})(x,n,i,f),S=r=>{e.onPersistCurrentItem?.(r),R(r)};o.useImperativeHandle(t,(()=>({getScrollPosition:()=>i.current?k(i.current):{y:0}}))),o.useLayoutEffect((()=>{i.current&&s.current!==e.scrollPositionOverride&&(L(i.current,e.scrollPositionOverride),s.current=e.scrollPositionOverride)}),[e.scrollPositionOverride]);const b=null!=e.onReorder,{reorderProps:v,reorderItemProps:M,reorderContext:E,reorderInstructionsId:P,reorderInstructions:T}=(({onReorder:e,rootRef:r,viewportConfig:t})=>{const n=null!=e,[s,l]=o.useState(void 0),{reorderProps:i,reorderContext:c,reorderInstructionsId:d,reorderInstructions:f}=u.useReorderable({onReorder:e,rootRef:r,itemSelector:a.ITEM_SELECTOR,isDisabled:!n,columns:1}),g=o.useRef(!1);return o.useEffect((()=>{if(n&&g.current){const e=r.current,o=a.findElementByKey(e,c.currentItemKey.current,a.ITEM_SELECTOR);if(o){const r=t?.scroller()||e;y.scrollToVisible(o,r,0),g.current=!1}}})),n?{reorderProps:m.mergeProps({onKeyDown:e=>{n&&("ArrowUp"===e.key||"ArrowDown"===e.key)&&(e.metaKey||e.ctrlKey)&&e.shiftKey&&(g.current=!0,i.onKeyDown?.(e))},onDragOver:e=>{void 0!==s&&(g.current=!1,a.dragToScroll(e,void 0!==s,r.current))}}),reorderItemProps:{dragKey:s,setDragKey:l,onReorder:e,rootRef:r},reorderContext:c,reorderInstructionsId:d,reorderInstructions:f}:{reorderProps:i,reorderContext:c,reorderInstructionsId:d,reorderInstructions:f}})({onReorder:e.onReorder,rootRef:i,viewportConfig:e.viewportConfig});return b&&M?r.jsxs(r.Fragment,{children:[r.jsxs(l.ReorderableContext.Provider,{value:E,children:[r.jsx(y.List,{...e,contextMenuTriggerProps:C,reorderProps:v,onLoadRange:p,scrollerRef:i,data:x,currentItemOverride:d,onPersistCurrentItem:S,children:t=>r.jsx(D,{...M,itemKey:t.metadata.key,children:e.children(t)})}),r.jsx("span",{id:P,children:r.jsx(c.HiddenAccessible,{children:T})})]}),n&&r.jsx(j,{...I,contextMenuConfig:n,contextMenuContext:h})]}):r.jsxs(r.Fragment,{children:[r.jsx(y.List,{...e,onLoadRange:p,scrollerRef:i,data:x,contextMenuTriggerProps:C,currentItemOverride:d,onPersistCurrentItem:S,children:e.children}),n&&r.jsx(j,{...I,contextMenuConfig:n,contextMenuContext:h})]})}));e.ListView=_}));
2
+ //# sourceMappingURL=ListView-c8082c0c.js.map