@telus-uds/components-base 1.83.0 → 1.85.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (474) hide show
  1. package/CHANGELOG.md +36 -2
  2. package/lib/A11yInfoProvider/index.js +8 -10
  3. package/lib/A11yText/index.js +2 -4
  4. package/lib/ActivityIndicator/Spinner.js +3 -4
  5. package/lib/ActivityIndicator/Spinner.native.js +2 -4
  6. package/lib/Autocomplete/Autocomplete.js +13 -17
  7. package/lib/Autocomplete/Loading.js +4 -2
  8. package/lib/Autocomplete/Suggestions.js +2 -4
  9. package/lib/Badge/Badge.js +2 -4
  10. package/lib/BaseProvider/HydrationContext.js +5 -7
  11. package/lib/Box/Box.js +5 -7
  12. package/lib/Button/Button.js +3 -3
  13. package/lib/Button/ButtonBase.js +2 -7
  14. package/lib/Button/ButtonDropdown.js +3 -3
  15. package/lib/Button/ButtonGroup.js +11 -4
  16. package/lib/Button/ButtonLink.js +3 -3
  17. package/lib/Card/Card.js +159 -16
  18. package/lib/Card/CardBase.js +2 -4
  19. package/lib/Card/PressableCardBase.js +3 -5
  20. package/lib/CardGroup/CardGroup.js +220 -0
  21. package/lib/CardGroup/dictionary.js +15 -0
  22. package/lib/CardGroup/index.js +10 -0
  23. package/lib/Carousel/Carousel.js +308 -129
  24. package/lib/Carousel/CarouselFirstFocus/CarouselFirstFocus.js +2 -4
  25. package/lib/Carousel/CarouselItem/CarouselItem.js +3 -2
  26. package/lib/Carousel/CarouselStepTracker/CarouselStepTracker.js +4 -2
  27. package/lib/Carousel/CarouselTabs/CarouselTabs.js +2 -4
  28. package/lib/Carousel/CarouselTabs/CarouselTabsPanel.js +6 -8
  29. package/lib/Carousel/CarouselTabs/CarouselTabsPanelItem.js +3 -5
  30. package/lib/Carousel/CarouselThumbnail.js +4 -2
  31. package/lib/Carousel/CarouselThumbnailNavigation.js +2 -4
  32. package/lib/Checkbox/Checkbox.js +2 -4
  33. package/lib/Checkbox/CheckboxButton.js +3 -5
  34. package/lib/Checkbox/CheckboxGroup.js +2 -4
  35. package/lib/Checkbox/CheckboxInput.js +4 -14
  36. package/lib/CheckboxCard/CheckboxCard.js +3 -3
  37. package/lib/CheckboxCardGroup/CheckboxCardGroup.js +3 -3
  38. package/lib/ColourToggle/ColourBubble.js +5 -6
  39. package/lib/ColourToggle/ColourToggle.js +3 -5
  40. package/lib/Divider/Divider.js +2 -4
  41. package/lib/ExpandCollapse/Accordion.js +2 -4
  42. package/lib/ExpandCollapse/Control.js +2 -4
  43. package/lib/ExpandCollapse/ExpandCollapse.js +20 -13
  44. package/lib/ExpandCollapse/Panel.js +15 -5
  45. package/lib/ExpandCollapse/dictionary.js +17 -0
  46. package/lib/Feedback/Feedback.js +2 -4
  47. package/lib/Fieldset/Fieldset.js +2 -4
  48. package/lib/Fieldset/FieldsetContainer.js +2 -4
  49. package/lib/Fieldset/FieldsetContainer.native.js +2 -4
  50. package/lib/Fieldset/Legend.js +2 -4
  51. package/lib/Fieldset/Legend.native.js +2 -4
  52. package/lib/FlexGrid/Col/Col.js +3 -5
  53. package/lib/FlexGrid/FlexGrid.js +2 -4
  54. package/lib/FlexGrid/Row/Row.js +2 -4
  55. package/lib/Footnote/Footnote.js +9 -9
  56. package/lib/Footnote/FootnoteLink.js +5 -3
  57. package/lib/HorizontalScroll/HorizontalScroll.js +8 -10
  58. package/lib/HorizontalScroll/HorizontalScrollButton.js +2 -4
  59. package/lib/HorizontalScroll/ScrollViewEnd.js +5 -10
  60. package/lib/HorizontalScroll/ScrollViewEnd.native.js +2 -4
  61. package/lib/Icon/Icon.js +2 -4
  62. package/lib/Icon/IconText.js +6 -6
  63. package/lib/IconButton/IconButton.js +2 -4
  64. package/lib/InputLabel/InputLabel.js +2 -4
  65. package/lib/InputLabel/LabelContent.js +2 -4
  66. package/lib/InputLabel/LabelContent.native.js +2 -4
  67. package/lib/InputSupports/InputSupports.js +4 -5
  68. package/lib/Link/ChevronLink.js +2 -4
  69. package/lib/Link/InlinePressable.js +8 -7
  70. package/lib/Link/InlinePressable.native.js +10 -8
  71. package/lib/Link/Link.js +2 -4
  72. package/lib/Link/LinkBase.js +2 -4
  73. package/lib/Link/TextButton.js +2 -4
  74. package/lib/List/List.js +13 -11
  75. package/lib/List/ListItem.js +2 -4
  76. package/lib/List/ListItemBase.js +6 -10
  77. package/lib/List/ListItemContent.js +4 -2
  78. package/lib/List/ListItemMark.js +4 -2
  79. package/lib/List/PressableListItemBase.js +2 -4
  80. package/lib/Listbox/GroupControl.js +4 -2
  81. package/lib/Listbox/Listbox.js +6 -6
  82. package/lib/Listbox/ListboxContext.js +3 -4
  83. package/lib/Listbox/ListboxGroup.js +2 -4
  84. package/lib/Listbox/ListboxItem.js +2 -6
  85. package/lib/Listbox/ListboxOverlay.js +2 -6
  86. package/lib/Listbox/PressableItem.js +2 -6
  87. package/lib/Modal/Modal.js +5 -7
  88. package/lib/Modal/ModalContent.js +7 -7
  89. package/lib/Modal/WebModal.js +19 -10
  90. package/lib/MultiSelectFilter/ModalOverlay.js +2 -4
  91. package/lib/MultiSelectFilter/MultiSelectFilter.js +10 -10
  92. package/lib/Notification/Notification.js +5 -7
  93. package/lib/OrderedList/Item.js +4 -10
  94. package/lib/OrderedList/ItemBase.js +2 -4
  95. package/lib/OrderedList/OrderedList.js +5 -13
  96. package/lib/OrderedList/OrderedListBase.js +2 -4
  97. package/lib/Pagination/PageButton.js +1 -1
  98. package/lib/Pagination/Pagination.js +1 -1
  99. package/lib/Pagination/SideButton.js +2 -4
  100. package/lib/PriceLockup/PriceLockup.js +5 -5
  101. package/lib/ProductCard/ProductCard.js +3 -2
  102. package/lib/ProductCardGroup/ProductCardGroup.js +5 -6
  103. package/lib/Progress/Progress.js +2 -4
  104. package/lib/Progress/ProgressBar.js +2 -4
  105. package/lib/Progress/ProgressBarBackground.js +2 -4
  106. package/lib/QuickLinks/QuickLinks.js +2 -4
  107. package/lib/QuickLinks/QuickLinksCard.js +4 -2
  108. package/lib/QuickLinks/QuickLinksItem.js +2 -4
  109. package/lib/QuickLinksFeature/QuickLinksFeature.js +9 -7
  110. package/lib/QuickLinksFeature/QuickLinksFeatureItem.js +10 -12
  111. package/lib/Radio/Radio.js +3 -3
  112. package/lib/Radio/RadioButton.js +61 -15
  113. package/lib/Radio/RadioGroup.js +2 -4
  114. package/lib/Radio/RadioInput.js +6 -18
  115. package/lib/RadioCard/RadioCard.js +3 -3
  116. package/lib/RadioCard/RadioCardGroup.js +3 -3
  117. package/lib/Responsive/Responsive.js +3 -2
  118. package/lib/Responsive/ResponsiveWithMediaQueryStyleSheet.js +3 -2
  119. package/lib/Search/Search.js +2 -4
  120. package/lib/Select/Group.js +4 -2
  121. package/lib/Select/Item.js +4 -2
  122. package/lib/Select/Picker.js +2 -4
  123. package/lib/Select/Picker.native.js +3 -5
  124. package/lib/Select/Select.js +4 -6
  125. package/lib/SideNav/Item.js +2 -4
  126. package/lib/SideNav/ItemContent.js +4 -2
  127. package/lib/SideNav/ItemsGroup.js +2 -4
  128. package/lib/SideNav/SideNav.js +2 -2
  129. package/lib/Skeleton/Skeleton.js +2 -4
  130. package/lib/SkipLink/SkipLink.js +2 -4
  131. package/lib/Spacer/Spacer.js +2 -4
  132. package/lib/StackView/StackView.js +2 -4
  133. package/lib/StackView/StackWrap.js +3 -5
  134. package/lib/StackView/StackWrapBox.js +2 -4
  135. package/lib/StackView/StackWrapGap.js +2 -4
  136. package/lib/StackView/getStackedContent.js +3 -3
  137. package/lib/StepTracker/Step.js +4 -2
  138. package/lib/StepTracker/StepTracker.js +2 -4
  139. package/lib/Tabs/Tabs.js +4 -4
  140. package/lib/Tabs/TabsItem.js +3 -5
  141. package/lib/Tags/Tags.js +2 -4
  142. package/lib/TextInput/TextArea.js +3 -5
  143. package/lib/TextInput/TextInput.js +2 -4
  144. package/lib/TextInput/TextInputBase.js +7 -9
  145. package/lib/ThemeProvider/ThemeProvider.js +5 -7
  146. package/lib/Timeline/Timeline.js +2 -4
  147. package/lib/ToggleSwitch/ToggleSwitch.js +2 -4
  148. package/lib/ToggleSwitch/ToggleSwitchGroup.js +2 -4
  149. package/lib/Tooltip/Tooltip.js +6 -8
  150. package/lib/Tooltip/Tooltip.native.js +12 -14
  151. package/lib/TooltipButton/TooltipButton.js +4 -2
  152. package/lib/Typography/Typography.js +2 -4
  153. package/lib/Validator/Validator.js +11 -13
  154. package/lib/ViewportProvider/ViewportProvider.js +2 -4
  155. package/lib/index.js +8 -0
  156. package/lib/utils/BaseView/BaseView.js +2 -4
  157. package/lib/utils/children.js +4 -6
  158. package/lib/utils/withLinkRouter.js +3 -5
  159. package/lib-module/A11yInfoProvider/index.js +8 -8
  160. package/lib-module/A11yText/index.js +2 -2
  161. package/lib-module/ActivityIndicator/Spinner.js +2 -2
  162. package/lib-module/ActivityIndicator/Spinner.native.js +2 -2
  163. package/lib-module/Autocomplete/Autocomplete.js +13 -14
  164. package/lib-module/Autocomplete/Loading.js +4 -2
  165. package/lib-module/Autocomplete/Suggestions.js +2 -2
  166. package/lib-module/Badge/Badge.js +2 -2
  167. package/lib-module/BaseProvider/HydrationContext.js +5 -5
  168. package/lib-module/Box/Box.js +5 -5
  169. package/lib-module/Button/Button.js +2 -2
  170. package/lib-module/Button/ButtonBase.js +2 -5
  171. package/lib-module/Button/ButtonDropdown.js +2 -2
  172. package/lib-module/Button/ButtonGroup.js +11 -2
  173. package/lib-module/Button/ButtonLink.js +2 -2
  174. package/lib-module/Card/Card.js +159 -14
  175. package/lib-module/Card/CardBase.js +2 -2
  176. package/lib-module/Card/PressableCardBase.js +4 -4
  177. package/lib-module/CardGroup/CardGroup.js +210 -0
  178. package/lib-module/CardGroup/dictionary.js +8 -0
  179. package/lib-module/CardGroup/index.js +2 -0
  180. package/lib-module/Carousel/Carousel.js +308 -129
  181. package/lib-module/Carousel/CarouselFirstFocus/CarouselFirstFocus.js +2 -2
  182. package/lib-module/Carousel/CarouselItem/CarouselItem.js +3 -2
  183. package/lib-module/Carousel/CarouselStepTracker/CarouselStepTracker.js +4 -2
  184. package/lib-module/Carousel/CarouselTabs/CarouselTabs.js +2 -2
  185. package/lib-module/Carousel/CarouselTabs/CarouselTabsPanel.js +6 -6
  186. package/lib-module/Carousel/CarouselTabs/CarouselTabsPanelItem.js +3 -3
  187. package/lib-module/Carousel/CarouselThumbnail.js +4 -2
  188. package/lib-module/Carousel/CarouselThumbnailNavigation.js +2 -2
  189. package/lib-module/Checkbox/Checkbox.js +2 -2
  190. package/lib-module/Checkbox/CheckboxButton.js +3 -3
  191. package/lib-module/Checkbox/CheckboxGroup.js +2 -2
  192. package/lib-module/Checkbox/CheckboxInput.js +4 -12
  193. package/lib-module/CheckboxCard/CheckboxCard.js +2 -2
  194. package/lib-module/CheckboxCardGroup/CheckboxCardGroup.js +2 -2
  195. package/lib-module/ColourToggle/ColourBubble.js +5 -4
  196. package/lib-module/ColourToggle/ColourToggle.js +3 -3
  197. package/lib-module/Divider/Divider.js +2 -2
  198. package/lib-module/ExpandCollapse/Accordion.js +2 -2
  199. package/lib-module/ExpandCollapse/Control.js +2 -2
  200. package/lib-module/ExpandCollapse/ExpandCollapse.js +20 -11
  201. package/lib-module/ExpandCollapse/Panel.js +16 -4
  202. package/lib-module/ExpandCollapse/dictionary.js +10 -0
  203. package/lib-module/Feedback/Feedback.js +2 -2
  204. package/lib-module/Fieldset/Fieldset.js +2 -2
  205. package/lib-module/Fieldset/FieldsetContainer.js +2 -2
  206. package/lib-module/Fieldset/FieldsetContainer.native.js +2 -2
  207. package/lib-module/Fieldset/Legend.js +2 -2
  208. package/lib-module/Fieldset/Legend.native.js +2 -2
  209. package/lib-module/FlexGrid/Col/Col.js +3 -3
  210. package/lib-module/FlexGrid/FlexGrid.js +2 -2
  211. package/lib-module/FlexGrid/Row/Row.js +2 -2
  212. package/lib-module/Footnote/Footnote.js +9 -7
  213. package/lib-module/Footnote/FootnoteLink.js +5 -4
  214. package/lib-module/HorizontalScroll/HorizontalScroll.js +8 -8
  215. package/lib-module/HorizontalScroll/HorizontalScrollButton.js +2 -2
  216. package/lib-module/HorizontalScroll/ScrollViewEnd.js +5 -8
  217. package/lib-module/HorizontalScroll/ScrollViewEnd.native.js +2 -2
  218. package/lib-module/Icon/Icon.js +2 -2
  219. package/lib-module/Icon/IconText.js +5 -5
  220. package/lib-module/IconButton/IconButton.js +2 -2
  221. package/lib-module/InputLabel/InputLabel.js +2 -2
  222. package/lib-module/InputLabel/LabelContent.js +2 -2
  223. package/lib-module/InputLabel/LabelContent.native.js +2 -2
  224. package/lib-module/InputSupports/InputSupports.js +4 -3
  225. package/lib-module/Link/ChevronLink.js +2 -2
  226. package/lib-module/Link/InlinePressable.js +10 -4
  227. package/lib-module/Link/InlinePressable.native.js +12 -6
  228. package/lib-module/Link/Link.js +2 -2
  229. package/lib-module/Link/LinkBase.js +2 -2
  230. package/lib-module/Link/TextButton.js +2 -2
  231. package/lib-module/List/List.js +13 -9
  232. package/lib-module/List/ListItem.js +2 -2
  233. package/lib-module/List/ListItemBase.js +6 -8
  234. package/lib-module/List/ListItemContent.js +4 -2
  235. package/lib-module/List/ListItemMark.js +4 -2
  236. package/lib-module/List/PressableListItemBase.js +2 -2
  237. package/lib-module/Listbox/GroupControl.js +4 -2
  238. package/lib-module/Listbox/Listbox.js +7 -7
  239. package/lib-module/Listbox/ListboxContext.js +2 -2
  240. package/lib-module/Listbox/ListboxGroup.js +2 -2
  241. package/lib-module/Listbox/ListboxItem.js +2 -3
  242. package/lib-module/Listbox/ListboxOverlay.js +2 -3
  243. package/lib-module/Listbox/PressableItem.js +2 -3
  244. package/lib-module/Modal/Modal.js +5 -5
  245. package/lib-module/Modal/ModalContent.js +7 -5
  246. package/lib-module/Modal/WebModal.js +19 -10
  247. package/lib-module/MultiSelectFilter/ModalOverlay.js +2 -2
  248. package/lib-module/MultiSelectFilter/MultiSelectFilter.js +10 -8
  249. package/lib-module/Notification/Notification.js +5 -5
  250. package/lib-module/OrderedList/Item.js +4 -8
  251. package/lib-module/OrderedList/ItemBase.js +2 -2
  252. package/lib-module/OrderedList/OrderedList.js +6 -12
  253. package/lib-module/OrderedList/OrderedListBase.js +2 -2
  254. package/lib-module/Pagination/PageButton.js +2 -2
  255. package/lib-module/Pagination/Pagination.js +2 -2
  256. package/lib-module/Pagination/SideButton.js +2 -2
  257. package/lib-module/PriceLockup/PriceLockup.js +5 -5
  258. package/lib-module/ProductCard/ProductCard.js +3 -2
  259. package/lib-module/ProductCardGroup/ProductCardGroup.js +5 -4
  260. package/lib-module/Progress/Progress.js +2 -2
  261. package/lib-module/Progress/ProgressBar.js +2 -2
  262. package/lib-module/Progress/ProgressBarBackground.js +2 -2
  263. package/lib-module/QuickLinks/QuickLinks.js +2 -2
  264. package/lib-module/QuickLinks/QuickLinksCard.js +4 -2
  265. package/lib-module/QuickLinks/QuickLinksItem.js +2 -2
  266. package/lib-module/QuickLinksFeature/QuickLinksFeature.js +9 -5
  267. package/lib-module/QuickLinksFeature/QuickLinksFeatureItem.js +10 -10
  268. package/lib-module/Radio/Radio.js +2 -2
  269. package/lib-module/Radio/RadioButton.js +62 -14
  270. package/lib-module/Radio/RadioGroup.js +2 -2
  271. package/lib-module/Radio/RadioInput.js +6 -16
  272. package/lib-module/RadioCard/RadioCard.js +2 -2
  273. package/lib-module/RadioCard/RadioCardGroup.js +2 -2
  274. package/lib-module/Responsive/Responsive.js +3 -2
  275. package/lib-module/Responsive/ResponsiveWithMediaQueryStyleSheet.js +3 -2
  276. package/lib-module/Search/Search.js +2 -2
  277. package/lib-module/Select/Group.js +4 -2
  278. package/lib-module/Select/Item.js +4 -2
  279. package/lib-module/Select/Picker.js +2 -2
  280. package/lib-module/Select/Picker.native.js +3 -3
  281. package/lib-module/Select/Select.js +4 -4
  282. package/lib-module/SideNav/Item.js +2 -2
  283. package/lib-module/SideNav/ItemContent.js +4 -2
  284. package/lib-module/SideNav/ItemsGroup.js +2 -2
  285. package/lib-module/SideNav/SideNav.js +3 -3
  286. package/lib-module/Skeleton/Skeleton.js +2 -2
  287. package/lib-module/SkipLink/SkipLink.js +2 -2
  288. package/lib-module/Spacer/Spacer.js +2 -2
  289. package/lib-module/StackView/StackView.js +2 -2
  290. package/lib-module/StackView/StackWrap.js +3 -3
  291. package/lib-module/StackView/StackWrapBox.js +2 -2
  292. package/lib-module/StackView/StackWrapGap.js +2 -2
  293. package/lib-module/StackView/getStackedContent.js +4 -4
  294. package/lib-module/StepTracker/Step.js +4 -2
  295. package/lib-module/StepTracker/StepTracker.js +2 -2
  296. package/lib-module/Tabs/Tabs.js +3 -3
  297. package/lib-module/Tabs/TabsItem.js +3 -3
  298. package/lib-module/Tags/Tags.js +2 -2
  299. package/lib-module/TextInput/TextArea.js +3 -3
  300. package/lib-module/TextInput/TextInput.js +2 -2
  301. package/lib-module/TextInput/TextInputBase.js +7 -7
  302. package/lib-module/ThemeProvider/ThemeProvider.js +5 -5
  303. package/lib-module/Timeline/Timeline.js +2 -2
  304. package/lib-module/ToggleSwitch/ToggleSwitch.js +2 -2
  305. package/lib-module/ToggleSwitch/ToggleSwitchGroup.js +2 -2
  306. package/lib-module/Tooltip/Tooltip.js +6 -6
  307. package/lib-module/Tooltip/Tooltip.native.js +12 -12
  308. package/lib-module/TooltipButton/TooltipButton.js +4 -2
  309. package/lib-module/Typography/Typography.js +2 -2
  310. package/lib-module/Validator/Validator.js +11 -11
  311. package/lib-module/ViewportProvider/ViewportProvider.js +2 -2
  312. package/lib-module/index.js +1 -0
  313. package/lib-module/utils/BaseView/BaseView.js +2 -2
  314. package/lib-module/utils/children.js +4 -4
  315. package/lib-module/utils/withLinkRouter.js +3 -3
  316. package/package.json +2 -2
  317. package/src/A11yInfoProvider/index.jsx +8 -8
  318. package/src/A11yText/index.jsx +2 -2
  319. package/src/ActivityIndicator/Spinner.jsx +2 -2
  320. package/src/ActivityIndicator/Spinner.native.jsx +2 -2
  321. package/src/Autocomplete/Autocomplete.jsx +15 -14
  322. package/src/Autocomplete/Loading.jsx +6 -3
  323. package/src/Autocomplete/Suggestions.jsx +2 -2
  324. package/src/Badge/Badge.jsx +2 -2
  325. package/src/BaseProvider/HydrationContext.jsx +5 -5
  326. package/src/Box/Box.jsx +5 -5
  327. package/src/Button/Button.jsx +11 -9
  328. package/src/Button/ButtonBase.jsx +2 -3
  329. package/src/Button/ButtonDropdown.jsx +2 -2
  330. package/src/Button/ButtonGroup.jsx +11 -2
  331. package/src/Button/ButtonLink.jsx +2 -2
  332. package/src/Card/Card.jsx +151 -11
  333. package/src/Card/CardBase.jsx +2 -2
  334. package/src/Card/PressableCardBase.jsx +18 -4
  335. package/src/CardGroup/CardGroup.jsx +249 -0
  336. package/src/CardGroup/dictionary.js +8 -0
  337. package/src/CardGroup/index.js +3 -0
  338. package/src/Carousel/Carousel.jsx +338 -117
  339. package/src/Carousel/CarouselFirstFocus/CarouselFirstFocus.jsx +2 -2
  340. package/src/Carousel/CarouselItem/CarouselItem.jsx +19 -17
  341. package/src/Carousel/CarouselStepTracker/CarouselStepTracker.jsx +5 -3
  342. package/src/Carousel/CarouselTabs/CarouselTabs.jsx +2 -2
  343. package/src/Carousel/CarouselTabs/CarouselTabsPanel.jsx +6 -6
  344. package/src/Carousel/CarouselTabs/CarouselTabsPanelItem.jsx +3 -3
  345. package/src/Carousel/CarouselThumbnail.jsx +6 -2
  346. package/src/Carousel/CarouselThumbnailNavigation.jsx +2 -2
  347. package/src/Checkbox/Checkbox.jsx +2 -2
  348. package/src/Checkbox/CheckboxButton.jsx +5 -7
  349. package/src/Checkbox/CheckboxGroup.jsx +2 -2
  350. package/src/Checkbox/CheckboxInput.jsx +15 -12
  351. package/src/CheckboxCard/CheckboxCard.jsx +2 -2
  352. package/src/CheckboxCardGroup/CheckboxCardGroup.jsx +2 -2
  353. package/src/ColourToggle/ColourBubble.jsx +5 -4
  354. package/src/ColourToggle/ColourToggle.jsx +3 -3
  355. package/src/Divider/Divider.jsx +2 -2
  356. package/src/ExpandCollapse/Accordion.jsx +4 -2
  357. package/src/ExpandCollapse/Control.jsx +2 -2
  358. package/src/ExpandCollapse/ExpandCollapse.jsx +15 -7
  359. package/src/ExpandCollapse/Panel.jsx +30 -8
  360. package/src/ExpandCollapse/dictionary.js +10 -0
  361. package/src/Feedback/Feedback.jsx +2 -2
  362. package/src/Fieldset/Fieldset.jsx +2 -2
  363. package/src/Fieldset/FieldsetContainer.jsx +2 -2
  364. package/src/Fieldset/FieldsetContainer.native.jsx +2 -2
  365. package/src/Fieldset/Legend.jsx +2 -2
  366. package/src/Fieldset/Legend.native.jsx +2 -2
  367. package/src/FlexGrid/Col/Col.jsx +3 -3
  368. package/src/FlexGrid/FlexGrid.jsx +2 -2
  369. package/src/FlexGrid/Row/Row.jsx +2 -2
  370. package/src/Footnote/Footnote.jsx +111 -98
  371. package/src/Footnote/FootnoteLink.jsx +35 -31
  372. package/src/HorizontalScroll/HorizontalScroll.jsx +8 -8
  373. package/src/HorizontalScroll/HorizontalScrollButton.jsx +2 -2
  374. package/src/HorizontalScroll/ScrollViewEnd.jsx +4 -8
  375. package/src/HorizontalScroll/ScrollViewEnd.native.jsx +2 -2
  376. package/src/Icon/Icon.jsx +2 -2
  377. package/src/Icon/IconText.jsx +7 -5
  378. package/src/IconButton/IconButton.jsx +2 -2
  379. package/src/InputLabel/InputLabel.jsx +2 -2
  380. package/src/InputLabel/LabelContent.jsx +2 -2
  381. package/src/InputLabel/LabelContent.native.jsx +2 -2
  382. package/src/InputSupports/InputSupports.jsx +4 -3
  383. package/src/Link/ChevronLink.jsx +2 -2
  384. package/src/Link/InlinePressable.jsx +22 -15
  385. package/src/Link/InlinePressable.native.jsx +12 -6
  386. package/src/Link/Link.jsx +2 -2
  387. package/src/Link/LinkBase.jsx +2 -2
  388. package/src/Link/TextButton.jsx +2 -2
  389. package/src/List/List.jsx +15 -7
  390. package/src/List/ListItem.jsx +2 -2
  391. package/src/List/ListItemBase.jsx +6 -12
  392. package/src/List/ListItemContent.jsx +5 -2
  393. package/src/List/ListItemMark.jsx +5 -3
  394. package/src/List/PressableListItemBase.jsx +2 -2
  395. package/src/Listbox/GroupControl.jsx +5 -2
  396. package/src/Listbox/Listbox.jsx +7 -7
  397. package/src/Listbox/ListboxContext.js +2 -2
  398. package/src/Listbox/ListboxGroup.jsx +2 -2
  399. package/src/Listbox/ListboxItem.jsx +2 -3
  400. package/src/Listbox/ListboxOverlay.jsx +2 -3
  401. package/src/Listbox/PressableItem.jsx +2 -3
  402. package/src/Modal/Modal.jsx +5 -5
  403. package/src/Modal/ModalContent.jsx +132 -125
  404. package/src/Modal/WebModal.jsx +17 -8
  405. package/src/MultiSelectFilter/ModalOverlay.jsx +2 -2
  406. package/src/MultiSelectFilter/MultiSelectFilter.jsx +263 -252
  407. package/src/Notification/Notification.jsx +5 -5
  408. package/src/OrderedList/Item.jsx +4 -6
  409. package/src/OrderedList/ItemBase.jsx +2 -2
  410. package/src/OrderedList/OrderedList.jsx +4 -7
  411. package/src/OrderedList/OrderedListBase.jsx +2 -2
  412. package/src/Pagination/PageButton.jsx +2 -2
  413. package/src/Pagination/Pagination.jsx +2 -2
  414. package/src/Pagination/SideButton.jsx +2 -2
  415. package/src/PriceLockup/PriceLockup.jsx +93 -88
  416. package/src/ProductCard/ProductCard.jsx +90 -84
  417. package/src/ProductCardGroup/ProductCardGroup.jsx +5 -5
  418. package/src/Progress/Progress.jsx +2 -2
  419. package/src/Progress/ProgressBar.jsx +2 -2
  420. package/src/Progress/ProgressBarBackground.jsx +4 -2
  421. package/src/QuickLinks/QuickLinks.jsx +2 -2
  422. package/src/QuickLinks/QuickLinksCard.jsx +9 -3
  423. package/src/QuickLinks/QuickLinksItem.jsx +2 -2
  424. package/src/QuickLinksFeature/QuickLinksFeature.jsx +31 -27
  425. package/src/QuickLinksFeature/QuickLinksFeatureItem.jsx +3 -3
  426. package/src/Radio/Radio.jsx +2 -2
  427. package/src/Radio/RadioButton.jsx +58 -6
  428. package/src/Radio/RadioGroup.jsx +2 -2
  429. package/src/Radio/RadioInput.jsx +15 -14
  430. package/src/RadioCard/RadioCard.jsx +2 -2
  431. package/src/RadioCard/RadioCardGroup.jsx +2 -2
  432. package/src/Responsive/Responsive.jsx +8 -3
  433. package/src/Responsive/ResponsiveWithMediaQueryStyleSheet.jsx +23 -16
  434. package/src/Search/Search.jsx +2 -2
  435. package/src/Select/Group.jsx +9 -3
  436. package/src/Select/Item.jsx +7 -1
  437. package/src/Select/Picker.jsx +2 -2
  438. package/src/Select/Picker.native.jsx +3 -3
  439. package/src/Select/Select.jsx +4 -4
  440. package/src/SideNav/Item.jsx +2 -2
  441. package/src/SideNav/ItemContent.jsx +7 -3
  442. package/src/SideNav/ItemsGroup.jsx +2 -2
  443. package/src/SideNav/SideNav.jsx +3 -3
  444. package/src/Skeleton/Skeleton.jsx +2 -2
  445. package/src/SkipLink/SkipLink.jsx +2 -2
  446. package/src/Spacer/Spacer.jsx +2 -2
  447. package/src/StackView/StackView.jsx +2 -2
  448. package/src/StackView/StackWrap.jsx +3 -3
  449. package/src/StackView/StackWrapBox.jsx +2 -2
  450. package/src/StackView/StackWrapGap.jsx +2 -2
  451. package/src/StackView/getStackedContent.jsx +4 -4
  452. package/src/StepTracker/Step.jsx +75 -67
  453. package/src/StepTracker/StepTracker.jsx +2 -2
  454. package/src/Tabs/Tabs.jsx +3 -3
  455. package/src/Tabs/TabsItem.jsx +3 -3
  456. package/src/Tags/Tags.jsx +2 -2
  457. package/src/TextInput/TextArea.jsx +3 -3
  458. package/src/TextInput/TextInput.jsx +2 -2
  459. package/src/TextInput/TextInputBase.jsx +7 -7
  460. package/src/ThemeProvider/ThemeProvider.jsx +5 -5
  461. package/src/Timeline/Timeline.jsx +2 -2
  462. package/src/ToggleSwitch/ToggleSwitch.jsx +2 -2
  463. package/src/ToggleSwitch/ToggleSwitchGroup.jsx +2 -2
  464. package/src/Tooltip/Tooltip.jsx +6 -6
  465. package/src/Tooltip/Tooltip.native.jsx +12 -12
  466. package/src/TooltipButton/TooltipButton.jsx +5 -2
  467. package/src/Typography/Typography.jsx +2 -2
  468. package/src/Validator/Validator.jsx +11 -11
  469. package/src/ViewportProvider/ViewportProvider.jsx +2 -2
  470. package/src/index.js +1 -0
  471. package/src/utils/BaseView/BaseView.jsx +2 -2
  472. package/src/utils/children.jsx +4 -4
  473. package/src/utils/withLinkRouter.jsx +3 -3
  474. package/types/ExpandCollapse.d.ts +1 -1
@@ -1,11 +1,11 @@
1
1
  /* eslint-disable react-native-a11y/has-valid-accessibility-role */
2
- import React, { forwardRef } from 'react'
2
+ import React from 'react'
3
3
  import PropTypes from 'prop-types'
4
4
  import { View, StyleSheet } from 'react-native'
5
5
 
6
6
  import ItemBase from './ItemBase'
7
7
 
8
- const OrderedListBase = forwardRef(({ children, ...rest }, ref) => (
8
+ const OrderedListBase = React.forwardRef(({ children, ...rest }, ref) => (
9
9
  <View accessibilityRole="list" ref={ref} style={staticStyles.container} {...rest}>
10
10
  {children}
11
11
  </View>
@@ -1,4 +1,4 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
 
4
4
  import ButtonBase from '../Button/ButtonBase'
@@ -17,7 +17,7 @@ import {
17
17
  import useCopy from '../utils/useCopy'
18
18
  import dictionary from './dictionary'
19
19
 
20
- const PageButton = forwardRef(
20
+ const PageButton = React.forwardRef(
21
21
  ({ label, onPress, href, isActive, copy, variant, tokens, ...props }, ref) => {
22
22
  const getTokens = useThemeTokensCallback('PaginationPageButton', tokens, variant)
23
23
 
@@ -1,4 +1,4 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import { View, Text, StyleSheet } from 'react-native'
3
3
 
4
4
  import {
@@ -31,7 +31,7 @@ const selectTextStyles = ({ color, fontName, fontSize, fontWeight, lineHeight },
31
31
  themeOptions
32
32
  })
33
33
 
34
- const Pagination = forwardRef(
34
+ const Pagination = React.forwardRef(
35
35
  (
36
36
  {
37
37
  children,
@@ -1,4 +1,4 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import { Text } from 'react-native'
3
3
 
4
4
  import PropTypes from 'prop-types'
@@ -29,7 +29,7 @@ const directionToSide = {
29
29
  next: 'right'
30
30
  }
31
31
 
32
- const SideButton = forwardRef(
32
+ const SideButton = React.forwardRef(
33
33
  ({ direction = 'previous', onPress, href, copy, variant, tokens, ...props }, ref) => {
34
34
  const viewport = useViewport()
35
35
  const buttonVariant = { direction, viewport, ...variant }
@@ -61,95 +61,100 @@ const selectBottomTextTypographyTokens = ({ bottomTextFontSize, bottomTextLineHe
61
61
  lineHeight: bottomTextLineHeight
62
62
  })
63
63
 
64
- const PriceLockup = ({
65
- size = 'medium',
66
- signDirection = 'left',
67
- footnoteLinks,
68
- topText,
69
- price,
70
- currencySymbol = '$',
71
- rateText,
72
- ratePosition = 'right',
73
- bottomText,
74
- onClickFootnote,
75
- strikeThrough,
76
- a11yText,
77
- tokens: priceLockupTokens,
78
- variant = {},
79
- ...rest
80
- }) => {
81
- const viewport = useViewport()
82
- const {
83
- footnoteMarginTop,
84
- footnoteGap,
85
- bottomTextMarginTop,
86
- priceMarginBottom,
87
- bottomLinksMarginLeft,
88
- fontColor,
89
- dividerColor,
90
- ...themeTokens
91
- } = useThemeTokens(
92
- 'PriceLockup',
93
- priceLockupTokens,
94
- { ...variant, size },
95
- { viewport, strikeThrough }
96
- )
97
- const currencySymbolTypographyTokens = selectCurrencySymbolTypographyTokens(themeTokens)
98
- const amountTypographyTokens = selectAmountTypographyTokens(themeTokens)
99
- const centsTypographyTokens = selectCentsTypographyTokens(themeTokens)
100
- const rateTypographyTokens = selectRateTypographyTokens(themeTokens)
101
- const topTextTypographyTokens = selectTopTextTypographyTokens(themeTokens)
102
- const bottomTextTypographyTokens = selectBottomTextTypographyTokens(themeTokens)
64
+ const PriceLockup = React.forwardRef(
65
+ (
66
+ {
67
+ size = 'medium',
68
+ signDirection = 'left',
69
+ footnoteLinks,
70
+ topText,
71
+ price,
72
+ currencySymbol = '$',
73
+ rateText,
74
+ ratePosition = 'right',
75
+ bottomText,
76
+ onClickFootnote,
77
+ strikeThrough,
78
+ a11yText,
79
+ tokens: priceLockupTokens,
80
+ variant = {},
81
+ ...rest
82
+ },
83
+ ref
84
+ ) => {
85
+ const viewport = useViewport()
86
+ const {
87
+ footnoteMarginTop,
88
+ footnoteGap,
89
+ bottomTextMarginTop,
90
+ priceMarginBottom,
91
+ bottomLinksMarginLeft,
92
+ fontColor,
93
+ dividerColor,
94
+ ...themeTokens
95
+ } = useThemeTokens(
96
+ 'PriceLockup',
97
+ priceLockupTokens,
98
+ { ...variant, size },
99
+ { viewport, strikeThrough }
100
+ )
101
+ const currencySymbolTypographyTokens = selectCurrencySymbolTypographyTokens(themeTokens)
102
+ const amountTypographyTokens = selectAmountTypographyTokens(themeTokens)
103
+ const centsTypographyTokens = selectCentsTypographyTokens(themeTokens)
104
+ const rateTypographyTokens = selectRateTypographyTokens(themeTokens)
105
+ const topTextTypographyTokens = selectTopTextTypographyTokens(themeTokens)
106
+ const bottomTextTypographyTokens = selectBottomTextTypographyTokens(themeTokens)
103
107
 
104
- return (
105
- <View style={[staticStyles.priceLockupContainer, { ...selectProps(rest) }]}>
106
- {topText ? (
107
- <View style={staticStyles.topText}>
108
- {renderTypography(topText, topTextTypographyTokens)}
109
- </View>
110
- ) : null}
111
- {renderPrice(
112
- price,
113
- rateText,
114
- ratePosition,
115
- signDirection,
116
- currencySymbol,
117
- currencySymbolTypographyTokens,
118
- amountTypographyTokens,
119
- centsTypographyTokens,
120
- rateTypographyTokens,
121
- fontColor,
122
- strikeThrough,
123
- a11yText,
124
- bottomText,
125
- bottomLinksMarginLeft,
126
- footnoteLinks,
127
- onClickFootnote,
128
- themeTokens
129
- )}
130
- {bottomText ? (
131
- <>
132
- <Divider
133
- testID="price-lockup-divider"
134
- role="separator"
135
- tokens={{ color: dividerColor }}
136
- />
137
- {renderFootnoteContent(
138
- footnoteMarginTop,
139
- bottomTextMarginTop,
140
- bottomText,
141
- bottomTextTypographyTokens,
142
- fontColor,
143
- footnoteLinks,
144
- bottomLinksMarginLeft,
145
- onClickFootnote,
146
- themeTokens
147
- )}
148
- </>
149
- ) : null}
150
- </View>
151
- )
152
- }
108
+ return (
109
+ <View style={[staticStyles.priceLockupContainer]} ref={ref} {...selectProps(rest)}>
110
+ {topText ? (
111
+ <View style={staticStyles.topText}>
112
+ {renderTypography(topText, topTextTypographyTokens)}
113
+ </View>
114
+ ) : null}
115
+ {renderPrice(
116
+ price,
117
+ rateText,
118
+ ratePosition,
119
+ signDirection,
120
+ currencySymbol,
121
+ currencySymbolTypographyTokens,
122
+ amountTypographyTokens,
123
+ centsTypographyTokens,
124
+ rateTypographyTokens,
125
+ fontColor,
126
+ strikeThrough,
127
+ a11yText,
128
+ bottomText,
129
+ bottomLinksMarginLeft,
130
+ footnoteLinks,
131
+ onClickFootnote,
132
+ themeTokens
133
+ )}
134
+ {bottomText ? (
135
+ <>
136
+ <Divider
137
+ testID="price-lockup-divider"
138
+ role="separator"
139
+ tokens={{ color: dividerColor }}
140
+ />
141
+ {renderFootnoteContent(
142
+ footnoteMarginTop,
143
+ bottomTextMarginTop,
144
+ bottomText,
145
+ bottomTextTypographyTokens,
146
+ fontColor,
147
+ footnoteLinks,
148
+ bottomLinksMarginLeft,
149
+ onClickFootnote,
150
+ themeTokens
151
+ )}
152
+ </>
153
+ ) : null}
154
+ </View>
155
+ )
156
+ }
157
+ )
153
158
 
154
159
  PriceLockup.displayName = 'PriceLockup'
155
160
  PriceLockup.propTypes = {
@@ -40,100 +40,106 @@ const selectProductCardTokens = ({
40
40
  paddingVertical
41
41
  })
42
42
 
43
- const ProductCard = ({
44
- copy = 'en',
45
- dictionary = defaultDictionary,
46
- image = {
47
- src: '',
48
- alt: ''
49
- },
50
- cardId,
51
- isSelected,
52
- onSelect,
53
- tokens,
54
- ...rest
55
- }) => {
56
- const viewport = useViewport()
57
- const themeTokens = useThemeTokens('ProductCard', tokens, { viewport })
43
+ const ProductCard = React.forwardRef(
44
+ (
45
+ {
46
+ copy = 'en',
47
+ dictionary = defaultDictionary,
48
+ image = {
49
+ src: '',
50
+ alt: ''
51
+ },
52
+ cardId,
53
+ isSelected,
54
+ onSelect,
55
+ tokens,
56
+ ...rest
57
+ },
58
+ ref
59
+ ) => {
60
+ const viewport = useViewport()
61
+ const themeTokens = useThemeTokens('ProductCard', tokens, { viewport })
58
62
 
59
- const getCopy = useCopy({ copy, dictionary })
63
+ const getCopy = useCopy({ copy, dictionary })
60
64
 
61
- const { currentValue, setValue } = useInputValue()
62
- const hasClicked = isSelected || currentValue
65
+ const { currentValue, setValue } = useInputValue()
66
+ const hasClicked = isSelected || currentValue
63
67
 
64
- const handlePress = (event) => {
65
- if (cardId) {
66
- onSelect(cardId)
67
- } else {
68
- setValue(!currentValue, event)
68
+ const handlePress = (event) => {
69
+ if (cardId) {
70
+ onSelect(cardId)
71
+ } else {
72
+ setValue(!currentValue, event)
73
+ }
69
74
  }
70
- }
71
75
 
72
- const renderButton = hasClicked ? (
73
- <Box vertical={1}>
74
- <StackView space={2} direction="row">
75
- <Icon icon={themeTokens.selectedButtonIcon} variant={{ color: 'success' }} />
76
- <Typography variant={{ size: 'h4' }} tokens={{ fontWeight: 400 }}>
77
- {getCopy('selectedButtonLabel')}
78
- </Typography>
79
- </StackView>
80
- </Box>
81
- ) : (
82
- <Button onPress={handlePress} variant={{ purpose: 'primary', size: 'small', width: 'full' }}>
83
- {getCopy('buttonLabel')}
84
- </Button>
85
- )
76
+ const renderButton = hasClicked ? (
77
+ <Box vertical={1}>
78
+ <StackView space={2} direction="row">
79
+ <Icon icon={themeTokens.selectedButtonIcon} variant={{ color: 'success' }} />
80
+ <Typography variant={{ size: 'h4' }} tokens={{ fontWeight: 400 }}>
81
+ {getCopy('selectedButtonLabel')}
82
+ </Typography>
83
+ </StackView>
84
+ </Box>
85
+ ) : (
86
+ <Button onPress={handlePress} variant={{ purpose: 'primary', size: 'small', width: 'full' }}>
87
+ {getCopy('buttonLabel')}
88
+ </Button>
89
+ )
86
90
 
87
- return (
88
- <View
89
- {...selectProps(rest)}
90
- style={[selectProductCardTokens(themeTokens), staticStyles.container]}
91
- >
92
- {image?.src ? (
93
- <View style={staticStyles.imageContainer}>
94
- <Image
95
- source={image.src}
96
- style={staticStyles.image}
97
- alt={image.alt}
98
- accessibilityLabel={image.alt}
99
- resizeMethod="resize"
100
- accessibilityIgnoresInvertColors
101
- />
102
- </View>
103
- ) : null}
91
+ return (
92
+ <View
93
+ {...selectProps(rest)}
94
+ style={[selectProductCardTokens(themeTokens), staticStyles.container]}
95
+ ref={ref}
96
+ >
97
+ {image?.src ? (
98
+ <View style={staticStyles.imageContainer}>
99
+ <Image
100
+ source={image.src}
101
+ style={staticStyles.image}
102
+ alt={image.alt}
103
+ accessibilityLabel={image.alt}
104
+ resizeMethod="resize"
105
+ accessibilityIgnoresInvertColors
106
+ />
107
+ </View>
108
+ ) : null}
104
109
 
105
- <View style={staticStyles.textContainer}>
106
- <Box left={3}>
107
- <StackView space={1}>
108
- {getCopy('badgeText') ? (
109
- <Badge variant={{ outline: true, purpose: 'editorial' }}>
110
- {getCopy('badgeText')}
111
- </Badge>
112
- ) : null}
113
- <Typography variant={{ size: 'h6' }}>{getCopy('brandName')}</Typography>
114
- <Typography variant={{ size: 'h4', colour: 'brand' }} tokens={{ fontWeight: 400 }}>
115
- {getCopy('productName')}
116
- </Typography>
117
- <StackView space={3} divider direction="row">
118
- <PriceLockup {...getCopy('primaryPrice')} size="small" ratePosition="bottom" />
119
- {getCopy('secondaryPrice')?.price ? (
120
- <PriceLockup {...getCopy('secondaryPrice')} size="small" ratePosition="bottom" />
110
+ <View style={staticStyles.textContainer}>
111
+ <Box left={3}>
112
+ <StackView space={1}>
113
+ {getCopy('badgeText') ? (
114
+ <Badge variant={{ outline: true, purpose: 'editorial' }}>
115
+ {getCopy('badgeText')}
116
+ </Badge>
121
117
  ) : null}
122
- </StackView>
123
- <Box top={2}>
124
- <StackView space={2}>
125
- <Typography variant={{ size: 'h6' }} tokens={{ fontWeight: 500 }}>
126
- {getCopy('term')}
127
- </Typography>
128
- {getCopy('buttonLabel') ? <Box top={1}>{renderButton}</Box> : null}
118
+ <Typography variant={{ size: 'h6' }}>{getCopy('brandName')}</Typography>
119
+ <Typography variant={{ size: 'h4', colour: 'brand' }} tokens={{ fontWeight: 400 }}>
120
+ {getCopy('productName')}
121
+ </Typography>
122
+ <StackView space={3} divider direction="row">
123
+ <PriceLockup {...getCopy('primaryPrice')} size="small" ratePosition="bottom" />
124
+ {getCopy('secondaryPrice')?.price ? (
125
+ <PriceLockup {...getCopy('secondaryPrice')} size="small" ratePosition="bottom" />
126
+ ) : null}
129
127
  </StackView>
130
- </Box>
131
- </StackView>
132
- </Box>
128
+ <Box top={2}>
129
+ <StackView space={2}>
130
+ <Typography variant={{ size: 'h6' }} tokens={{ fontWeight: 500 }}>
131
+ {getCopy('term')}
132
+ </Typography>
133
+ {getCopy('buttonLabel') ? <Box top={1}>{renderButton}</Box> : null}
134
+ </StackView>
135
+ </Box>
136
+ </StackView>
137
+ </Box>
138
+ </View>
133
139
  </View>
134
- </View>
135
- )
136
- }
140
+ )
141
+ }
142
+ )
137
143
 
138
144
  ProductCard.displayName = 'ProductCard'
139
145
 
@@ -1,4 +1,4 @@
1
- import React, { useState } from 'react'
1
+ import React from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
  import { View } from 'react-native'
4
4
  import { selectSystemProps, htmlAttrs, viewProps, a11yProps } from '../utils'
@@ -8,8 +8,8 @@ import { StackWrap } from '../StackView'
8
8
 
9
9
  const [selectProps, selectedSystemPropTypes] = selectSystemProps([htmlAttrs, viewProps, a11yProps])
10
10
 
11
- const ProductCardGroup = ({ productCards, maxSelection = 1, ...rest }) => {
12
- const [selectedCardIds, setSelectedCardIds] = useState([])
11
+ const ProductCardGroup = React.forwardRef(({ productCards, maxSelection = 1, ...rest }, ref) => {
12
+ const [selectedCardIds, setSelectedCardIds] = React.useState([])
13
13
 
14
14
  const handleSelect = (id) => {
15
15
  const isAlreadySelected = selectedCardIds.includes(id)
@@ -27,7 +27,7 @@ const ProductCardGroup = ({ productCards, maxSelection = 1, ...rest }) => {
27
27
  }
28
28
 
29
29
  return (
30
- <View {...selectProps(rest)}>
30
+ <View {...selectProps(rest)} ref={ref}>
31
31
  <StackWrap direction={{ xs: 'column', lg: 'row' }} space={4}>
32
32
  {productCards.map((cardProperties, index) => {
33
33
  const cardId = cardProperties.id || index
@@ -47,7 +47,7 @@ const ProductCardGroup = ({ productCards, maxSelection = 1, ...rest }) => {
47
47
  </StackWrap>
48
48
  </View>
49
49
  )
50
- }
50
+ })
51
51
 
52
52
  ProductCardGroup.displayName = 'ProductCardGroup'
53
53
 
@@ -1,4 +1,4 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
  import { View } from 'react-native'
4
4
 
@@ -50,7 +50,7 @@ const selectProgressStyles = ({
50
50
  * role.
51
51
  *
52
52
  */
53
- const Progress = forwardRef(({ children, tokens, variant, ...rest }, ref) => {
53
+ const Progress = React.forwardRef(({ children, tokens, variant, ...rest }, ref) => {
54
54
  const themeTokens = useThemeTokens('Progress', tokens, variant)
55
55
 
56
56
  return (
@@ -1,4 +1,4 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
  import { Platform, StyleSheet, View } from 'react-native'
4
4
 
@@ -53,7 +53,7 @@ const selectBarStyles = (
53
53
  * - `accessibilityValue.text` (`aria-valuetext`): `%{percentage}%`,
54
54
  *
55
55
  */
56
- const ProgressBar = forwardRef(
56
+ const ProgressBar = React.forwardRef(
57
57
  ({ children = null, percentage = 0, tokens, variant, ...rest }, ref) => {
58
58
  const themeTokens = useThemeTokens('ProgressBar', tokens, variant)
59
59
  if (percentage < 0) {
@@ -1,11 +1,12 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import { ImageBackground, StyleSheet } from 'react-native'
3
3
 
4
4
  import { variantProp } from '../utils'
5
5
 
6
6
  const inactiveBackground = `%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='24'%3E%3Cdefs%3E%3Cpattern id='inactive' patternUnits='userSpaceOnUse' width='8' height='8'%3E%3Crect width='8' height='8' fill='rgba(255, 255, 255, 0)'%3E%3C/rect%3E%3Ccircle cx='4' cy='4' r='2' fill='rgba(0, 0, 0, 0.4)' stroke='rgba(0, 0, 0, 0.4)' stroke-width='0'%3E%3C/circle%3E%3Ccircle cx='0' cy='0' r='2' fill='rgba(0, 0, 0, 0.4)' stroke='rgba(0, 0, 0, 0.4)' stroke-width='0'%3E%3C/circle%3E%3Ccircle cx='0' cy='8' r='2' fill='rgba(0, 0, 0, 0.4)' stroke='rgba(0, 0, 0, 0.4)' stroke-width='0'%3E%3C/circle%3E%3Ccircle cx='8' cy='0' r='2' fill='rgba(0, 0, 0, 0.4)' stroke='rgba(0, 0, 0, 0.4)' stroke-width='0'%3E%3C/circle%3E%3Ccircle cx='8' cy='8' r='2' fill='rgba(0, 0, 0, 0.4)' stroke='rgba(0, 0, 0, 0.4)' stroke-width='0'%3E%3C/circle%3E%3C/pattern%3E%3C/defs%3E%3Cpath d='M 0 0 L 0 140 L 2000 2000 L 2000 0 Z' style='fill: url(&quot;%23inactive&quot;);'%3E%3C/path%3E%3C/svg%3E`
7
7
  const negativeBackground = `%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='24'%3E%3Cdefs%3E%3Cpattern id='negative' patternUnits='userSpaceOnUse' width='8' height='8'%3E%3Crect width='8' height='8' fill='rgba(255, 255, 255, 0)'%3E%3C/rect%3E%3Cpath d='M 0,8 l 8,-8 M -2,2 l 4,-4 M 6,10 l 4,-4' stroke-width='1' shape-rendering='auto' stroke='rgba(255, 255, 255, 0.4)' stroke-linecap='square'%3E%3C/path%3E%3C/pattern%3E%3C/defs%3E%3Cpath d='M 0 0 L 0 140 L 2000 2000 L 2000 0 Z' style='fill: url(&quot;%23negative&quot;);'%3E%3C/path%3E%3C/svg%3E`
8
- const ProgressBarBackground = forwardRef(({ variant }, ref) => {
8
+
9
+ const ProgressBarBackground = React.forwardRef(({ variant }, ref) => {
9
10
  let source = null
10
11
  if (variant?.inactive) {
11
12
  source = inactiveBackground
@@ -22,6 +23,7 @@ const ProgressBarBackground = forwardRef(({ variant }, ref) => {
22
23
  />
23
24
  )
24
25
  })
26
+
25
27
  ProgressBarBackground.displayName = 'ProgressBarBackground'
26
28
 
27
29
  ProgressBarBackground.propTypes = {
@@ -1,4 +1,4 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
 
4
4
  import { useThemeTokens } from '../ThemeProvider'
@@ -15,7 +15,7 @@ import QuickLinksCard from './QuickLinksCard'
15
15
  * - If the theme returns `button` token as true and `list` as false, it renders a wrapping horizontal bar of buttons
16
16
  * - If the theme returns `card` token as true, it wraps the above with a `Card`.
17
17
  */
18
- const QuickLinks = forwardRef(
18
+ const QuickLinks = React.forwardRef(
19
19
  ({ tokens, variant, listTokens, cardTokens, children, tag = 'ul', ...rest }, ref) => {
20
20
  const viewport = useViewport()
21
21
  const { dividers, list, card, stackSpace, stackGap, stackJustify } = useThemeTokens(
@@ -11,11 +11,17 @@ import CardBase from '../Card/CardBase'
11
11
  * Restyled Card with identical behaviour to Card, but themed according to the
12
12
  * QuickLinksCard theme rather than the Card theme.
13
13
  */
14
- const QuickLinksList = ({ tokens, variant, children }) => {
14
+ const QuickLinksList = React.forwardRef(({ tokens, variant, children }, ref) => {
15
15
  const themeTokens = useThemeTokens('QuickLinksCard', tokens, variant)
16
16
 
17
- return <CardBase tokens={themeTokens}>{children}</CardBase>
18
- }
17
+ return (
18
+ <CardBase tokens={themeTokens} ref={ref}>
19
+ {children}
20
+ </CardBase>
21
+ )
22
+ })
23
+
24
+ QuickLinksList.displayName = 'QuickLinksList'
19
25
 
20
26
  QuickLinksList.propTypes = {
21
27
  tokens: getTokensPropType('QuickLinksCard'),
@@ -1,4 +1,4 @@
1
- import React, { forwardRef } from 'react'
1
+ import React from 'react'
2
2
  import PropTypes from 'prop-types'
3
3
 
4
4
  import { getTokensPropType, variantProp, withLinkRouter } from '../utils'
@@ -13,7 +13,7 @@ import ButtonBase from '../Button/ButtonBase'
13
13
  *
14
14
  * Receives props injected by QuickLinks and renders the appropriate child component.
15
15
  */
16
- const QuickLinksItem = forwardRef(({ tokens, variant, children, ...rest }, ref) => {
16
+ const QuickLinksItem = React.forwardRef(({ tokens, variant, children, ...rest }, ref) => {
17
17
  const viewport = useViewport()
18
18
  const { list } = useThemeTokens('QuickLinks', tokens, variant, { viewport })
19
19