@telus-uds/components-base 2.0.0 → 2.0.1

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 (970) hide show
  1. package/CHANGELOG.md +1050 -3
  2. package/README.md +35 -0
  3. package/babel.config.cjs +35 -0
  4. package/{jest.config-android.js → jest.config-android.cjs} +1 -1
  5. package/{jest.config-ios.js → jest.config-ios.cjs} +1 -1
  6. package/{jest.config-web.js → jest.config-web.cjs} +1 -1
  7. package/jest.config.cjs +40 -0
  8. package/jest.setup.js +7 -0
  9. package/lib/A11yInfoProvider/index.js +33 -64
  10. package/lib/A11yText/index.js +29 -40
  11. package/lib/ActionCard/ActionCard.js +342 -0
  12. package/lib/ActionCard/index.js +2 -0
  13. package/lib/ActivityIndicator/Spinner.js +27 -42
  14. package/lib/ActivityIndicator/Spinner.native.js +37 -70
  15. package/lib/ActivityIndicator/index.js +17 -33
  16. package/lib/ActivityIndicator/shared.js +12 -26
  17. package/lib/Autocomplete/Autocomplete.js +478 -0
  18. package/lib/Autocomplete/Loading.js +35 -0
  19. package/lib/Autocomplete/Suggestions.js +64 -0
  20. package/lib/Autocomplete/constants.js +4 -0
  21. package/lib/Autocomplete/dictionary.js +12 -0
  22. package/lib/Autocomplete/index.js +2 -0
  23. package/lib/Badge/Badge.js +102 -0
  24. package/lib/Badge/index.js +2 -0
  25. package/lib/BaseProvider/HydrationContext.js +17 -43
  26. package/lib/BaseProvider/index.js +24 -41
  27. package/lib/Box/Box.js +191 -93
  28. package/lib/Box/backgroundImageStylesMap.js +94 -0
  29. package/lib/Box/index.js +2 -13
  30. package/lib/Button/Button.js +21 -33
  31. package/lib/Button/ButtonBase.js +143 -136
  32. package/lib/Button/ButtonDropdown.js +41 -75
  33. package/lib/Button/ButtonGroup.js +92 -110
  34. package/lib/Button/ButtonLink.js +25 -36
  35. package/lib/Button/index.js +5 -39
  36. package/lib/Button/propTypes.js +16 -40
  37. package/lib/Card/Card.js +266 -45
  38. package/lib/Card/CardBase.js +67 -40
  39. package/lib/Card/PressableCardBase.js +35 -67
  40. package/lib/Card/index.js +4 -40
  41. package/lib/CardGroup/CardGroup.js +210 -0
  42. package/lib/CardGroup/dictionary.js +8 -0
  43. package/lib/CardGroup/index.js +2 -0
  44. package/lib/Carousel/Carousel.js +476 -332
  45. package/lib/Carousel/CarouselContext.js +20 -42
  46. package/lib/Carousel/CarouselFirstFocus/CarouselFirstFocus.js +18 -39
  47. package/lib/Carousel/CarouselItem/CarouselItem.js +106 -58
  48. package/lib/Carousel/CarouselItem/index.js +2 -13
  49. package/lib/Carousel/CarouselStepTracker/CarouselStepTracker.js +21 -32
  50. package/lib/Carousel/CarouselStepTracker/index.js +2 -13
  51. package/lib/Carousel/CarouselTabs/CarouselTabs.js +17 -36
  52. package/lib/Carousel/CarouselTabs/CarouselTabsPanel.js +36 -51
  53. package/lib/Carousel/CarouselTabs/CarouselTabsPanelItem.js +25 -55
  54. package/lib/Carousel/CarouselTabs/index.js +2 -13
  55. package/lib/Carousel/CarouselThumbnail.js +76 -62
  56. package/lib/Carousel/CarouselThumbnailNavigation.js +31 -47
  57. package/lib/Carousel/dictionary.js +13 -16
  58. package/lib/Carousel/index.js +3 -41
  59. package/lib/Checkbox/Checkbox.js +64 -107
  60. package/lib/Checkbox/CheckboxButton.js +163 -0
  61. package/lib/Checkbox/CheckboxGroup.js +64 -90
  62. package/lib/Checkbox/CheckboxInput.js +16 -42
  63. package/lib/Checkbox/CheckboxInput.native.js +1 -10
  64. package/lib/Checkbox/index.js +3 -21
  65. package/{lib-module/RadioCard/RadioCard.js → lib/CheckboxCard/CheckboxCard.js} +43 -88
  66. package/lib/CheckboxCard/index.js +2 -0
  67. package/lib/CheckboxCardGroup/CheckboxCardGroup.js +206 -0
  68. package/lib/CheckboxCardGroup/index.js +2 -0
  69. package/lib/ColourToggle/ColourBubble.js +126 -0
  70. package/lib/ColourToggle/ColourToggle.js +91 -0
  71. package/lib/ColourToggle/index.js +2 -0
  72. package/lib/Divider/Divider.js +37 -54
  73. package/lib/Divider/index.js +2 -13
  74. package/lib/DownloadApp/DownloadApp.js +160 -0
  75. package/lib/DownloadApp/dictionary.js +10 -0
  76. package/lib/DownloadApp/index.js +2 -0
  77. package/lib/ExpandCollapse/Accordion.js +6 -22
  78. package/lib/ExpandCollapse/Control.js +72 -67
  79. package/lib/ExpandCollapse/ExpandCollapse.js +39 -56
  80. package/lib/ExpandCollapse/Panel.js +144 -86
  81. package/lib/ExpandCollapse/dictionary.js +10 -0
  82. package/lib/ExpandCollapse/index.js +7 -25
  83. package/lib/Feedback/Feedback.js +41 -69
  84. package/lib/Feedback/index.js +2 -13
  85. package/lib/Fieldset/Fieldset.js +81 -90
  86. package/lib/Fieldset/FieldsetContainer.js +26 -33
  87. package/lib/Fieldset/FieldsetContainer.native.js +18 -27
  88. package/lib/Fieldset/Legend.js +9 -26
  89. package/lib/Fieldset/Legend.native.js +10 -30
  90. package/lib/Fieldset/cssReset.js +2 -9
  91. package/lib/Fieldset/index.js +2 -13
  92. package/lib/FileUpload/FileUpload.js +328 -0
  93. package/lib/FileUpload/NotificationContent.js +54 -0
  94. package/lib/FileUpload/dictionary.js +40 -0
  95. package/lib/FileUpload/index.js +2 -0
  96. package/lib/FlexGrid/Col/Col.js +104 -148
  97. package/lib/FlexGrid/Col/index.js +2 -13
  98. package/lib/FlexGrid/FlexGrid.js +92 -110
  99. package/lib/FlexGrid/Row/Row.js +82 -108
  100. package/lib/FlexGrid/Row/index.js +2 -13
  101. package/lib/FlexGrid/helpers/index.js +1 -12
  102. package/lib/FlexGrid/index.js +2 -13
  103. package/lib/FlexGrid/providers/GutterContext.js +3 -15
  104. package/lib/Footnote/Footnote.js +316 -0
  105. package/lib/Footnote/FootnoteLink.js +107 -0
  106. package/lib/Footnote/dictionary.js +12 -0
  107. package/lib/Footnote/index.js +4 -0
  108. package/lib/HorizontalScroll/HorizontalScroll.js +48 -87
  109. package/lib/HorizontalScroll/HorizontalScrollButton.js +26 -52
  110. package/lib/HorizontalScroll/ScrollViewEnd.js +17 -38
  111. package/lib/HorizontalScroll/ScrollViewEnd.native.js +8 -26
  112. package/lib/HorizontalScroll/dictionary.js +2 -9
  113. package/lib/HorizontalScroll/index.js +11 -35
  114. package/lib/HorizontalScroll/itemPositions.js +25 -46
  115. package/lib/Icon/Icon.js +59 -48
  116. package/lib/Icon/IconText.js +59 -55
  117. package/lib/Icon/index.js +4 -31
  118. package/lib/IconButton/IconButton.js +127 -85
  119. package/lib/IconButton/index.js +2 -13
  120. package/lib/InputLabel/InputLabel.js +42 -76
  121. package/lib/InputLabel/LabelContent.js +10 -26
  122. package/lib/InputLabel/LabelContent.native.js +8 -27
  123. package/lib/InputLabel/index.js +2 -13
  124. package/lib/InputSupports/InputSupports.js +39 -56
  125. package/lib/InputSupports/index.js +2 -13
  126. package/lib/InputSupports/useInputSupports.js +7 -19
  127. package/lib/Link/ChevronLink.js +35 -38
  128. package/lib/Link/InlinePressable.js +14 -29
  129. package/lib/Link/InlinePressable.native.js +20 -40
  130. package/lib/Link/Link.js +9 -27
  131. package/lib/Link/LinkBase.js +96 -103
  132. package/lib/Link/TextButton.js +19 -29
  133. package/lib/Link/index.js +5 -39
  134. package/lib/List/List.js +39 -50
  135. package/lib/List/ListItem.js +13 -37
  136. package/lib/List/ListItemBase.js +72 -70
  137. package/lib/List/ListItemContent.js +36 -48
  138. package/lib/List/ListItemMark.js +42 -75
  139. package/lib/List/PressableListItemBase.js +35 -69
  140. package/lib/List/index.js +5 -28
  141. package/lib/Listbox/GroupControl.js +105 -0
  142. package/lib/Listbox/Listbox.js +171 -0
  143. package/lib/Listbox/ListboxContext.js +4 -0
  144. package/lib/Listbox/ListboxGroup.js +125 -0
  145. package/lib/Listbox/ListboxItem.js +76 -0
  146. package/lib/Listbox/ListboxOverlay.js +77 -0
  147. package/lib/Listbox/PressableItem.js +139 -0
  148. package/lib/Listbox/index.js +2 -0
  149. package/lib/Modal/Modal.js +212 -96
  150. package/lib/Modal/ModalContent.js +179 -0
  151. package/lib/Modal/WebModal.js +76 -0
  152. package/lib/Modal/dictionary.js +2 -9
  153. package/lib/Modal/index.js +2 -13
  154. package/lib/MultiSelectFilter/ModalOverlay.js +114 -95
  155. package/lib/MultiSelectFilter/MultiSelectFilter.js +380 -170
  156. package/lib/MultiSelectFilter/dictionary.js +2 -9
  157. package/lib/MultiSelectFilter/index.js +2 -13
  158. package/lib/Notification/Notification.js +290 -116
  159. package/lib/Notification/dictionary.js +2 -9
  160. package/lib/Notification/index.js +2 -13
  161. package/lib/OrderedList/Item.js +159 -0
  162. package/lib/OrderedList/ItemBase.js +43 -0
  163. package/lib/OrderedList/OrderedList.js +64 -0
  164. package/lib/OrderedList/OrderedListBase.js +36 -0
  165. package/lib/OrderedList/index.js +2 -0
  166. package/lib/Pagination/PageButton.js +38 -57
  167. package/lib/Pagination/Pagination.js +124 -95
  168. package/lib/Pagination/SideButton.js +25 -58
  169. package/lib/Pagination/constants.js +3 -0
  170. package/lib/Pagination/dictionary.js +5 -12
  171. package/lib/Pagination/index.js +2 -13
  172. package/lib/Pagination/usePagination.js +20 -23
  173. package/lib/Portal/Portal.js +50 -0
  174. package/lib/Portal/Portal.native.js +2 -0
  175. package/lib/Portal/index.js +2 -0
  176. package/lib/PriceLockup/PriceLockup.js +223 -0
  177. package/lib/PriceLockup/index.js +2 -0
  178. package/lib/PriceLockup/utils/renderFootnoteContent.js +85 -0
  179. package/lib/PriceLockup/utils/renderFootnoteLinks.js +28 -0
  180. package/lib/PriceLockup/utils/renderPrice.js +139 -0
  181. package/lib/PriceLockup/utils/renderTypography.js +23 -0
  182. package/lib/ProductCard/ProductCard.js +231 -0
  183. package/lib/ProductCard/dictionary.js +38 -0
  184. package/lib/ProductCard/index.js +2 -0
  185. package/lib/ProductCardGroup/ProductCardGroup.js +70 -0
  186. package/lib/ProductCardGroup/index.js +2 -0
  187. package/lib/Progress/Progress.js +22 -43
  188. package/lib/Progress/ProgressBar.js +31 -60
  189. package/lib/Progress/ProgressBarBackground.js +13 -35
  190. package/lib/Progress/index.js +4 -16
  191. package/lib/QuickLinks/QuickLinks.js +31 -44
  192. package/lib/QuickLinks/QuickLinksCard.js +16 -30
  193. package/lib/QuickLinks/QuickLinksItem.js +22 -44
  194. package/lib/QuickLinks/index.js +4 -16
  195. package/lib/QuickLinksFeature/QuickLinksFeature.js +25 -47
  196. package/lib/QuickLinksFeature/QuickLinksFeatureItem.js +88 -99
  197. package/lib/QuickLinksFeature/index.js +4 -16
  198. package/lib/Radio/Radio.js +63 -95
  199. package/lib/Radio/RadioButton.js +94 -76
  200. package/lib/Radio/RadioGroup.js +70 -94
  201. package/lib/Radio/RadioInput.js +18 -46
  202. package/lib/Radio/RadioInput.native.js +1 -10
  203. package/lib/Radio/index.js +3 -21
  204. package/lib/RadioCard/RadioCard.js +47 -90
  205. package/lib/RadioCard/RadioCardGroup.js +66 -91
  206. package/lib/RadioCard/index.js +3 -21
  207. package/lib/Responsive/Responsive.js +48 -41
  208. package/{lib-module/Responsive/Responsive.js → lib/Responsive/ResponsiveProp.js} +13 -20
  209. package/lib/Responsive/ResponsiveWithMediaQueryStyleSheet.js +68 -0
  210. package/lib/Responsive/index.js +2 -13
  211. package/lib/Search/Search.js +73 -96
  212. package/lib/Search/dictionary.js +2 -9
  213. package/lib/Search/index.js +2 -13
  214. package/lib/Select/Group.js +15 -25
  215. package/lib/Select/Group.native.js +8 -18
  216. package/lib/Select/Item.js +14 -23
  217. package/lib/Select/Item.native.js +1 -10
  218. package/lib/Select/Picker.js +71 -60
  219. package/lib/Select/Picker.native.js +40 -65
  220. package/lib/Select/Select.js +70 -109
  221. package/lib/Select/constants.js +4 -14
  222. package/lib/Select/index.js +6 -19
  223. package/lib/SideNav/Item.js +41 -65
  224. package/lib/SideNav/ItemContent.js +22 -41
  225. package/lib/SideNav/ItemsGroup.js +43 -60
  226. package/lib/SideNav/SideNav.js +42 -68
  227. package/lib/SideNav/index.js +1 -15
  228. package/lib/Skeleton/Skeleton.js +54 -86
  229. package/lib/Skeleton/index.js +2 -13
  230. package/lib/Skeleton/skeleton.constant.js +2 -12
  231. package/lib/Skeleton/skeletonWebAnimation.js +12 -25
  232. package/lib/Skeleton/useSkeletonNativeAnimation.js +22 -33
  233. package/lib/SkipLink/SkipLink.js +48 -75
  234. package/lib/SkipLink/index.js +2 -13
  235. package/lib/Spacer/Spacer.js +17 -41
  236. package/lib/Spacer/index.js +2 -13
  237. package/lib/StackView/StackView.js +34 -59
  238. package/lib/StackView/StackWrap.js +23 -44
  239. package/lib/StackView/StackWrap.native.js +2 -12
  240. package/lib/StackView/StackWrapBox.js +32 -58
  241. package/lib/StackView/StackWrapGap.js +22 -45
  242. package/lib/StackView/common.js +4 -19
  243. package/lib/StackView/getStackedContent.js +21 -41
  244. package/lib/StackView/index.js +5 -29
  245. package/lib/Status/Status.js +165 -0
  246. package/lib/Status/index.js +2 -0
  247. package/lib/StepTracker/Step.js +70 -79
  248. package/lib/StepTracker/StepTracker.js +67 -79
  249. package/lib/StepTracker/dictionary.js +26 -13
  250. package/lib/StepTracker/index.js +2 -13
  251. package/lib/TabBar/TabBar.js +125 -0
  252. package/lib/TabBar/TabBarItem.js +175 -0
  253. package/lib/TabBar/index.js +2 -0
  254. package/lib/Tabs/Tabs.js +75 -71
  255. package/lib/Tabs/TabsItem.js +70 -91
  256. package/lib/Tabs/index.js +2 -13
  257. package/lib/Tags/Tags.js +59 -97
  258. package/lib/Tags/index.js +2 -13
  259. package/lib/TextInput/TextArea.js +27 -46
  260. package/lib/TextInput/TextInput.js +38 -54
  261. package/lib/TextInput/TextInputBase.js +210 -137
  262. package/lib/TextInput/dictionary.js +8 -11
  263. package/lib/TextInput/index.js +3 -23
  264. package/lib/TextInput/propTypes.js +11 -21
  265. package/lib/ThemeProvider/ThemeProvider.js +40 -52
  266. package/lib/ThemeProvider/index.js +7 -61
  267. package/lib/ThemeProvider/useResponsiveThemeTokens.js +81 -0
  268. package/lib/ThemeProvider/useSetTheme.js +10 -20
  269. package/lib/ThemeProvider/useTheme.js +5 -17
  270. package/lib/ThemeProvider/useThemeTokens.js +16 -33
  271. package/lib/ThemeProvider/utils/index.js +2 -31
  272. package/lib/ThemeProvider/utils/styles.js +48 -60
  273. package/lib/ThemeProvider/utils/theme-tokens.js +37 -78
  274. package/lib/Timeline/Timeline.js +39 -63
  275. package/lib/Timeline/index.js +2 -13
  276. package/lib/ToggleSwitch/ToggleSwitch.js +105 -108
  277. package/lib/ToggleSwitch/ToggleSwitchGroup.js +47 -91
  278. package/lib/ToggleSwitch/index.js +3 -23
  279. package/lib/Tooltip/Backdrop.js +22 -29
  280. package/lib/Tooltip/Backdrop.native.js +14 -33
  281. package/lib/Tooltip/Tooltip.js +65 -92
  282. package/lib/Tooltip/Tooltip.native.js +107 -110
  283. package/lib/Tooltip/dictionary.js +2 -9
  284. package/lib/Tooltip/getTooltipPosition.js +35 -49
  285. package/lib/Tooltip/index.js +5 -18
  286. package/lib/Tooltip/shared.js +26 -24
  287. package/lib/TooltipButton/TooltipButton.js +48 -53
  288. package/lib/TooltipButton/index.js +2 -13
  289. package/lib/Typography/Typography.js +164 -87
  290. package/lib/Typography/index.js +2 -13
  291. package/lib/Validator/Validator.js +222 -0
  292. package/lib/Validator/index.js +2 -0
  293. package/lib/ViewportProvider/ViewportProvider.js +11 -31
  294. package/lib/ViewportProvider/index.js +3 -28
  295. package/lib/ViewportProvider/useViewport.js +3 -15
  296. package/lib/ViewportProvider/useViewportListener.js +13 -29
  297. package/lib/index.js +71 -681
  298. package/lib/server.js +4 -0
  299. package/lib/utils/BaseView/BaseView.js +14 -36
  300. package/lib/utils/BaseView/BaseView.native.js +2 -13
  301. package/lib/utils/BaseView/index.js +2 -13
  302. package/lib/utils/a11y/index.js +2 -31
  303. package/lib/utils/a11y/semantics.js +18 -60
  304. package/lib/utils/a11y/textSize.js +8 -24
  305. package/lib/utils/animation/index.js +2 -15
  306. package/lib/utils/animation/useVerticalExpandAnimation.js +27 -47
  307. package/lib/utils/children.js +25 -47
  308. package/lib/utils/containUniqueFields.js +3 -13
  309. package/lib/utils/convertFromMegaByteToByte.js +10 -0
  310. package/lib/utils/floating-ui/index.js +1 -43
  311. package/lib/utils/floating-ui/index.native.js +1 -43
  312. package/lib/utils/formatImageSource.js +27 -0
  313. package/lib/utils/hasOwnProperty.js +1 -8
  314. package/lib/utils/htmlAttrs.js +23 -0
  315. package/lib/utils/index.js +25 -222
  316. package/lib/utils/info/index.js +6 -17
  317. package/lib/utils/info/platform/index.js +8 -17
  318. package/lib/utils/info/platform/platform.android.js +1 -8
  319. package/lib/utils/info/platform/platform.ios.js +1 -8
  320. package/lib/utils/info/platform/platform.js +1 -8
  321. package/lib/utils/info/platform/platform.native.js +1 -8
  322. package/lib/utils/info/versions.js +4 -14
  323. package/lib/utils/input.js +38 -52
  324. package/lib/utils/pressability.js +18 -40
  325. package/lib/utils/props/a11yProps.js +105 -119
  326. package/lib/utils/props/clickProps.js +4 -16
  327. package/lib/utils/props/componentPropType.js +4 -24
  328. package/lib/utils/props/copyPropTypes.js +2 -14
  329. package/lib/utils/props/getPropSelector.js +15 -21
  330. package/lib/utils/props/handlerProps.js +28 -52
  331. package/lib/utils/props/hrefAttrsProp.js +6 -17
  332. package/lib/utils/props/index.js +19 -190
  333. package/lib/utils/props/inputSupportsProps.js +22 -27
  334. package/lib/utils/props/linkProps.js +17 -35
  335. package/lib/utils/props/paddingProp.js +8 -19
  336. package/lib/utils/props/pressProps.js +23 -38
  337. package/lib/utils/props/rectProp.js +8 -19
  338. package/lib/utils/props/responsiveProps.js +6 -18
  339. package/lib/utils/props/selectSystemProps.js +7 -15
  340. package/lib/utils/props/spacingProps.js +13 -27
  341. package/lib/utils/props/textInputProps.js +64 -90
  342. package/lib/utils/props/textProps.js +23 -34
  343. package/lib/utils/props/tokens.js +26 -55
  344. package/lib/utils/props/variantProp.js +4 -14
  345. package/lib/utils/props/viewProps.js +10 -23
  346. package/lib/utils/ssr-media-query/create-stylesheet/create-stylesheet-mobile.js +48 -0
  347. package/lib/utils/ssr-media-query/create-stylesheet/index.android.js +2 -0
  348. package/lib/utils/ssr-media-query/create-stylesheet/index.ios.js +2 -0
  349. package/lib/utils/ssr-media-query/create-stylesheet/index.js +36 -0
  350. package/lib/utils/ssr-media-query/hash.js +13 -0
  351. package/lib/utils/ssr-media-query/index.js +6 -0
  352. package/lib/utils/ssr-media-query/utils/common.js +33 -0
  353. package/lib/utils/ssr-media-query/utils/create-declaration-block.js +16 -0
  354. package/lib/utils/ssr-media-query/utils/create-media-query-styles.js +60 -0
  355. package/lib/utils/ssr-media-query/utils/hyphenate-style-name.js +12 -0
  356. package/lib/utils/ssr-media-query/utils/inject.js +39 -0
  357. package/lib/utils/ssr.js +27 -55
  358. package/lib/utils/transformGradient.js +15 -0
  359. package/lib/utils/useCopy.js +4 -15
  360. package/lib/utils/useHash.js +11 -23
  361. package/lib/utils/useHash.native.js +1 -10
  362. package/lib/utils/useOverlaidPosition.js +214 -0
  363. package/lib/utils/useResponsiveProp.js +13 -29
  364. package/lib/utils/useSafeLayoutEffect.js +10 -22
  365. package/lib/utils/useScrollBlocking.js +13 -28
  366. package/lib/utils/useScrollBlocking.native.js +1 -10
  367. package/lib/utils/useSpacingScale.js +12 -24
  368. package/lib/utils/useUniqueId.js +4 -15
  369. package/lib/utils/withLinkRouter.js +23 -36
  370. package/package.json +32 -22
  371. package/src/A11yInfoProvider/index.jsx +13 -20
  372. package/src/A11yText/index.jsx +14 -4
  373. package/src/ActionCard/ActionCard.jsx +306 -0
  374. package/src/ActionCard/index.js +3 -0
  375. package/src/ActivityIndicator/Spinner.jsx +3 -2
  376. package/src/ActivityIndicator/Spinner.native.jsx +2 -2
  377. package/src/ActivityIndicator/index.jsx +12 -3
  378. package/src/Autocomplete/Autocomplete.jsx +486 -0
  379. package/src/Autocomplete/Loading.jsx +21 -0
  380. package/src/Autocomplete/Suggestions.jsx +54 -0
  381. package/src/Autocomplete/constants.js +4 -0
  382. package/src/Autocomplete/dictionary.js +12 -0
  383. package/src/Autocomplete/index.js +3 -0
  384. package/src/Badge/Badge.jsx +76 -0
  385. package/src/Badge/index.js +3 -0
  386. package/src/BaseProvider/HydrationContext.jsx +5 -5
  387. package/src/BaseProvider/index.jsx +5 -2
  388. package/src/Box/Box.jsx +162 -20
  389. package/src/Box/backgroundImageStylesMap.js +21 -0
  390. package/src/Button/Button.jsx +12 -7
  391. package/src/Button/ButtonBase.jsx +76 -35
  392. package/src/Button/ButtonDropdown.jsx +5 -2
  393. package/src/Button/ButtonGroup.jsx +20 -3
  394. package/src/Button/ButtonLink.jsx +10 -4
  395. package/src/Card/Card.jsx +269 -17
  396. package/src/Card/CardBase.jsx +79 -28
  397. package/src/Card/PressableCardBase.jsx +21 -5
  398. package/src/CardGroup/CardGroup.jsx +249 -0
  399. package/src/CardGroup/dictionary.js +8 -0
  400. package/src/CardGroup/index.js +3 -0
  401. package/src/Carousel/Carousel.jsx +406 -117
  402. package/src/Carousel/CarouselFirstFocus/CarouselFirstFocus.jsx +2 -2
  403. package/src/Carousel/CarouselItem/CarouselItem.jsx +99 -18
  404. package/src/Carousel/CarouselStepTracker/CarouselStepTracker.jsx +15 -5
  405. package/src/Carousel/CarouselTabs/CarouselTabs.jsx +2 -2
  406. package/src/Carousel/CarouselTabs/CarouselTabsPanel.jsx +22 -12
  407. package/src/Carousel/CarouselTabs/CarouselTabsPanelItem.jsx +3 -3
  408. package/src/Carousel/CarouselThumbnail.jsx +45 -27
  409. package/src/Carousel/CarouselThumbnailNavigation.jsx +11 -7
  410. package/src/Carousel/dictionary.js +11 -7
  411. package/src/Checkbox/Checkbox.jsx +8 -4
  412. package/src/Checkbox/CheckboxButton.jsx +178 -0
  413. package/src/Checkbox/CheckboxGroup.jsx +24 -4
  414. package/src/Checkbox/CheckboxInput.jsx +15 -12
  415. package/src/CheckboxCard/CheckboxCard.jsx +190 -0
  416. package/src/CheckboxCard/index.js +3 -0
  417. package/src/CheckboxCardGroup/CheckboxCardGroup.jsx +231 -0
  418. package/src/CheckboxCardGroup/index.js +3 -0
  419. package/src/ColourToggle/ColourBubble.jsx +112 -0
  420. package/src/ColourToggle/ColourToggle.jsx +83 -0
  421. package/src/ColourToggle/index.js +3 -0
  422. package/src/Divider/Divider.jsx +5 -2
  423. package/src/DownloadApp/DownloadApp.jsx +165 -0
  424. package/src/DownloadApp/dictionary.js +10 -0
  425. package/src/DownloadApp/index.js +3 -0
  426. package/src/ExpandCollapse/Accordion.jsx +4 -2
  427. package/src/ExpandCollapse/Control.jsx +44 -14
  428. package/src/ExpandCollapse/ExpandCollapse.jsx +15 -7
  429. package/src/ExpandCollapse/Panel.jsx +119 -24
  430. package/src/ExpandCollapse/dictionary.js +10 -0
  431. package/src/Feedback/Feedback.jsx +3 -4
  432. package/src/Fieldset/Fieldset.jsx +47 -23
  433. package/src/Fieldset/FieldsetContainer.jsx +15 -7
  434. package/src/Fieldset/FieldsetContainer.native.jsx +15 -7
  435. package/src/Fieldset/Legend.jsx +2 -2
  436. package/src/Fieldset/Legend.native.jsx +2 -2
  437. package/src/FileUpload/FileUpload.jsx +396 -0
  438. package/src/FileUpload/NotificationContent.jsx +44 -0
  439. package/src/FileUpload/dictionary.js +40 -0
  440. package/src/FileUpload/index.js +3 -0
  441. package/src/FlexGrid/Col/Col.jsx +76 -79
  442. package/src/FlexGrid/FlexGrid.jsx +62 -43
  443. package/src/FlexGrid/Row/Row.jsx +60 -54
  444. package/src/Footnote/Footnote.jsx +326 -0
  445. package/src/Footnote/FootnoteLink.jsx +110 -0
  446. package/src/Footnote/dictionary.js +12 -0
  447. package/src/Footnote/index.js +6 -0
  448. package/src/HorizontalScroll/HorizontalScroll.jsx +8 -8
  449. package/src/HorizontalScroll/HorizontalScrollButton.jsx +2 -2
  450. package/src/HorizontalScroll/ScrollViewEnd.jsx +4 -8
  451. package/src/HorizontalScroll/ScrollViewEnd.native.jsx +2 -2
  452. package/src/Icon/Icon.jsx +53 -6
  453. package/src/Icon/IconText.jsx +46 -14
  454. package/src/IconButton/IconButton.jsx +116 -20
  455. package/src/InputLabel/InputLabel.jsx +8 -6
  456. package/src/InputLabel/LabelContent.jsx +2 -2
  457. package/src/InputLabel/LabelContent.native.jsx +2 -2
  458. package/src/InputSupports/InputSupports.jsx +22 -3
  459. package/src/Link/ChevronLink.jsx +24 -7
  460. package/src/Link/InlinePressable.jsx +23 -15
  461. package/src/Link/InlinePressable.native.jsx +12 -6
  462. package/src/Link/Link.jsx +2 -2
  463. package/src/Link/LinkBase.jsx +75 -31
  464. package/src/Link/TextButton.jsx +11 -4
  465. package/src/List/List.jsx +26 -8
  466. package/src/List/ListItem.jsx +3 -5
  467. package/src/List/ListItemBase.jsx +38 -9
  468. package/src/List/ListItemContent.jsx +24 -6
  469. package/src/List/ListItemMark.jsx +14 -13
  470. package/src/List/PressableListItemBase.jsx +4 -2
  471. package/src/Listbox/GroupControl.jsx +101 -0
  472. package/src/Listbox/Listbox.jsx +177 -0
  473. package/src/Listbox/ListboxContext.js +6 -0
  474. package/src/Listbox/ListboxGroup.jsx +127 -0
  475. package/src/Listbox/ListboxItem.jsx +87 -0
  476. package/src/Listbox/ListboxOverlay.jsx +81 -0
  477. package/src/Listbox/PressableItem.jsx +138 -0
  478. package/src/Listbox/index.js +3 -0
  479. package/src/Modal/Modal.jsx +190 -16
  480. package/src/Modal/ModalContent.jsx +180 -0
  481. package/src/Modal/WebModal.jsx +70 -0
  482. package/src/MultiSelectFilter/ModalOverlay.jsx +103 -30
  483. package/src/MultiSelectFilter/MultiSelectFilter.jsx +326 -68
  484. package/src/Notification/Notification.jsx +273 -49
  485. package/src/OrderedList/Item.jsx +147 -0
  486. package/src/OrderedList/ItemBase.jsx +43 -0
  487. package/src/OrderedList/OrderedList.jsx +64 -0
  488. package/src/OrderedList/OrderedListBase.jsx +33 -0
  489. package/src/OrderedList/index.js +3 -0
  490. package/src/Pagination/PageButton.jsx +14 -5
  491. package/src/Pagination/Pagination.jsx +83 -17
  492. package/src/Pagination/SideButton.jsx +2 -2
  493. package/src/Pagination/constants.js +3 -0
  494. package/src/Pagination/dictionary.js +3 -3
  495. package/src/Pagination/usePagination.js +14 -3
  496. package/src/Portal/Portal.jsx +52 -0
  497. package/src/Portal/Portal.native.jsx +3 -0
  498. package/src/Portal/index.js +3 -0
  499. package/src/PriceLockup/PriceLockup.jsx +237 -0
  500. package/src/PriceLockup/index.js +3 -0
  501. package/src/PriceLockup/utils/renderFootnoteContent.jsx +77 -0
  502. package/src/PriceLockup/utils/renderFootnoteLinks.jsx +38 -0
  503. package/src/PriceLockup/utils/renderPrice.jsx +201 -0
  504. package/src/PriceLockup/utils/renderTypography.jsx +13 -0
  505. package/src/ProductCard/ProductCard.jsx +199 -0
  506. package/src/ProductCard/dictionary.js +38 -0
  507. package/src/ProductCard/index.js +3 -0
  508. package/src/ProductCardGroup/ProductCardGroup.jsx +75 -0
  509. package/src/ProductCardGroup/index.js +3 -0
  510. package/src/Progress/Progress.jsx +8 -5
  511. package/src/Progress/ProgressBar.jsx +6 -4
  512. package/src/Progress/ProgressBarBackground.jsx +6 -4
  513. package/src/QuickLinks/QuickLinks.jsx +11 -2
  514. package/src/QuickLinks/QuickLinksCard.jsx +9 -3
  515. package/src/QuickLinks/QuickLinksItem.jsx +2 -2
  516. package/src/QuickLinksFeature/QuickLinksFeature.jsx +31 -27
  517. package/src/QuickLinksFeature/QuickLinksFeatureItem.jsx +43 -36
  518. package/src/Radio/Radio.jsx +24 -6
  519. package/src/Radio/RadioButton.jsx +58 -6
  520. package/src/Radio/RadioGroup.jsx +27 -5
  521. package/src/Radio/RadioInput.jsx +15 -14
  522. package/src/RadioCard/RadioCard.jsx +2 -2
  523. package/src/RadioCard/RadioCardGroup.jsx +25 -4
  524. package/src/Responsive/Responsive.jsx +43 -13
  525. package/src/Responsive/ResponsiveProp.jsx +33 -0
  526. package/src/Responsive/ResponsiveWithMediaQueryStyleSheet.jsx +67 -0
  527. package/src/Search/Search.jsx +10 -5
  528. package/src/Select/Group.jsx +12 -3
  529. package/src/Select/Group.native.jsx +3 -0
  530. package/src/Select/Item.jsx +10 -1
  531. package/src/Select/Picker.jsx +32 -5
  532. package/src/Select/Picker.native.jsx +3 -3
  533. package/src/Select/Select.jsx +27 -10
  534. package/src/SideNav/Item.jsx +12 -7
  535. package/src/SideNav/ItemContent.jsx +14 -6
  536. package/src/SideNav/ItemsGroup.jsx +15 -4
  537. package/src/SideNav/SideNav.jsx +11 -3
  538. package/src/Skeleton/Skeleton.jsx +19 -7
  539. package/src/Skeleton/skeleton.constant.js +0 -1
  540. package/src/Skeleton/skeletonWebAnimation.js +11 -11
  541. package/src/Skeleton/useSkeletonNativeAnimation.js +5 -4
  542. package/src/SkipLink/SkipLink.jsx +14 -14
  543. package/src/Spacer/Spacer.jsx +2 -2
  544. package/src/StackView/StackView.jsx +5 -4
  545. package/src/StackView/StackWrap.jsx +3 -3
  546. package/src/StackView/StackWrapBox.jsx +2 -2
  547. package/src/StackView/StackWrapGap.jsx +2 -2
  548. package/src/StackView/getStackedContent.jsx +16 -7
  549. package/src/Status/Status.jsx +153 -0
  550. package/src/Status/index.js +3 -0
  551. package/src/StepTracker/Step.jsx +102 -70
  552. package/src/StepTracker/StepTracker.jsx +28 -6
  553. package/src/StepTracker/dictionary.js +24 -4
  554. package/src/TabBar/TabBar.jsx +123 -0
  555. package/src/TabBar/TabBarItem.jsx +149 -0
  556. package/src/TabBar/index.js +3 -0
  557. package/src/Tabs/Tabs.jsx +37 -5
  558. package/src/Tabs/TabsItem.jsx +19 -7
  559. package/src/Tags/Tags.jsx +7 -3
  560. package/src/TextInput/TextArea.jsx +3 -3
  561. package/src/TextInput/TextInput.jsx +11 -7
  562. package/src/TextInput/TextInputBase.jsx +145 -29
  563. package/src/TextInput/dictionary.js +6 -2
  564. package/src/TextInput/propTypes.js +4 -0
  565. package/src/ThemeProvider/ThemeProvider.jsx +17 -7
  566. package/src/ThemeProvider/index.js +1 -0
  567. package/src/ThemeProvider/useResponsiveThemeTokens.js +85 -0
  568. package/src/ThemeProvider/utils/styles.js +34 -2
  569. package/src/Timeline/Timeline.jsx +10 -6
  570. package/src/ToggleSwitch/ToggleSwitch.jsx +28 -11
  571. package/src/ToggleSwitch/ToggleSwitchGroup.jsx +2 -2
  572. package/src/Tooltip/Tooltip.jsx +38 -9
  573. package/src/Tooltip/Tooltip.native.jsx +82 -20
  574. package/src/Tooltip/getTooltipPosition.js +12 -13
  575. package/src/Tooltip/shared.js +17 -0
  576. package/src/TooltipButton/TooltipButton.jsx +34 -8
  577. package/src/Typography/Typography.jsx +173 -29
  578. package/src/Validator/Validator.jsx +230 -0
  579. package/src/Validator/index.js +3 -0
  580. package/src/ViewportProvider/ViewportProvider.jsx +2 -2
  581. package/src/index.js +31 -12
  582. package/src/server.js +4 -0
  583. package/src/utils/BaseView/BaseView.jsx +2 -2
  584. package/src/utils/a11y/semantics.js +7 -14
  585. package/src/utils/animation/useVerticalExpandAnimation.js +3 -3
  586. package/src/utils/children.jsx +4 -4
  587. package/src/utils/convertFromMegaByteToByte.js +11 -0
  588. package/src/utils/formatImageSource.js +29 -0
  589. package/src/utils/htmlAttrs.js +29 -0
  590. package/src/utils/index.js +6 -1
  591. package/src/utils/props/handlerProps.js +5 -1
  592. package/src/utils/props/inputSupportsProps.js +21 -1
  593. package/src/utils/props/textInputProps.js +1 -0
  594. package/src/utils/props/tokens.js +4 -2
  595. package/src/utils/ssr-media-query/create-stylesheet/create-stylesheet-mobile.js +41 -0
  596. package/src/utils/ssr-media-query/create-stylesheet/index.android.js +3 -0
  597. package/src/utils/ssr-media-query/create-stylesheet/index.ios.js +3 -0
  598. package/src/utils/ssr-media-query/create-stylesheet/index.js +35 -0
  599. package/src/utils/ssr-media-query/hash.js +16 -0
  600. package/src/utils/ssr-media-query/index.js +8 -0
  601. package/src/utils/ssr-media-query/utils/common.js +38 -0
  602. package/src/utils/ssr-media-query/utils/create-declaration-block.js +21 -0
  603. package/src/utils/ssr-media-query/utils/create-media-query-styles.js +46 -0
  604. package/src/utils/ssr-media-query/utils/hyphenate-style-name.js +15 -0
  605. package/src/utils/ssr-media-query/utils/inject.js +43 -0
  606. package/src/utils/ssr.jsx +3 -1
  607. package/src/utils/transformGradient.js +17 -0
  608. package/src/utils/useOverlaidPosition.js +224 -0
  609. package/src/utils/withLinkRouter.jsx +3 -3
  610. package/types/Badge.d.ts +28 -0
  611. package/types/Box.d.ts +52 -0
  612. package/types/Checkbox.d.ts +47 -0
  613. package/types/CheckboxCardGroup.d.ts +72 -0
  614. package/types/ChevronLink.d.ts +47 -0
  615. package/types/Common.d.ts +106 -0
  616. package/types/Divider.d.ts +19 -0
  617. package/types/ExpandCollapse.d.ts +65 -0
  618. package/types/FileUpload.d.ts +40 -0
  619. package/types/HorizontalScrollButton.d.ts +16 -0
  620. package/types/Icon.d.ts +21 -0
  621. package/types/Link.d.ts +48 -0
  622. package/types/List.d.ts +48 -0
  623. package/types/Portal.d.ts +5 -0
  624. package/types/Search.d.ts +38 -0
  625. package/types/Select.d.ts +57 -0
  626. package/types/Spacer.d.ts +5 -0
  627. package/types/StackView.d.ts +28 -0
  628. package/types/Tabs.d.ts +46 -0
  629. package/types/TextButton.d.ts +11 -0
  630. package/types/ToggleSwitch.d.ts +54 -0
  631. package/types/ToolTip.d.ts +40 -0
  632. package/types/Typography.d.ts +40 -0
  633. package/types/index.d.ts +78 -0
  634. package/.eslintrc.js +0 -9
  635. package/__tests17__/A11yText/A11yText.test.jsx +0 -34
  636. package/__tests17__/ActivityIndicator/ActivityIndicator.test.jsx +0 -68
  637. package/__tests17__/ActivityIndicator/__snapshots__/ActivityIndicator.test.jsx.snap +0 -299
  638. package/__tests17__/Box/Box.test.jsx +0 -111
  639. package/__tests17__/Button/Button.test.jsx +0 -86
  640. package/__tests17__/Button/ButtonBase.test.jsx +0 -82
  641. package/__tests17__/Button/ButtonGroup.test.jsx +0 -347
  642. package/__tests17__/Button/ButtonLink.test.jsx +0 -61
  643. package/__tests17__/Card/Card.test.jsx +0 -63
  644. package/__tests17__/Carousel/Carousel.test.jsx +0 -128
  645. package/__tests17__/Carousel/CarouselTabs.test.jsx +0 -142
  646. package/__tests17__/Checkbox/Checkbox.test.jsx +0 -94
  647. package/__tests17__/Checkbox/CheckboxGroup.test.jsx +0 -246
  648. package/__tests17__/Divider/Divider.test.jsx +0 -91
  649. package/__tests17__/ExpandCollapse/ExpandCollapse.test.jsx +0 -109
  650. package/__tests17__/Feedback/Feedback.test.jsx +0 -42
  651. package/__tests17__/FlexGrid/Col.test.jsx +0 -261
  652. package/__tests17__/FlexGrid/FlexGrid.test.jsx +0 -136
  653. package/__tests17__/FlexGrid/Row.test.jsx +0 -273
  654. package/__tests17__/HorizontalScroll/HorizontalScroll.test.jsx +0 -165
  655. package/__tests17__/Icon/Icon.test.jsx +0 -61
  656. package/__tests17__/IconButton/IconButton.test.jsx +0 -52
  657. package/__tests17__/InputLabel/InputLabel.test.jsx +0 -28
  658. package/__tests17__/InputLabel/__snapshots__/InputLabel.test.jsx.snap +0 -3
  659. package/__tests17__/InputSupports/InputSupports.test.jsx +0 -60
  660. package/__tests17__/Link/Link.test.jsx +0 -63
  661. package/__tests17__/Link/TextButton.test.jsx +0 -35
  662. package/__tests17__/List/List.test.jsx +0 -82
  663. package/__tests17__/Modal/Modal.test.jsx +0 -47
  664. package/__tests17__/Notification/Notification.test.jsx +0 -20
  665. package/__tests17__/Pagination/Pagination.test.jsx +0 -160
  666. package/__tests17__/Progress/Progress.test.jsx +0 -79
  667. package/__tests17__/Radio/Radio.test.jsx +0 -87
  668. package/__tests17__/Radio/RadioGroup.test.jsx +0 -220
  669. package/__tests17__/RadioCard/RadioCard.test.jsx +0 -87
  670. package/__tests17__/RadioCard/RadioCardGroup.test.jsx +0 -246
  671. package/__tests17__/Search/Search.test.jsx +0 -87
  672. package/__tests17__/Select/Select.test.jsx +0 -94
  673. package/__tests17__/SideNav/SideNav.test.jsx +0 -110
  674. package/__tests17__/Skeleton/Skeleton.test.jsx +0 -61
  675. package/__tests17__/SkipLink/SkipLink.test.jsx +0 -61
  676. package/__tests17__/Spacer/Spacer.test.jsx +0 -63
  677. package/__tests17__/StackView/StackView.test.jsx +0 -211
  678. package/__tests17__/StackView/StackWrap.test.jsx +0 -47
  679. package/__tests17__/StackView/getStackedContent.test.jsx +0 -295
  680. package/__tests17__/StepTracker/StepTracker.test.jsx +0 -108
  681. package/__tests17__/Tabs/Tabs.test.jsx +0 -49
  682. package/__tests17__/Tags/Tags.test.jsx +0 -327
  683. package/__tests17__/TextInput/TextArea.test.jsx +0 -35
  684. package/__tests17__/TextInput/TextInputBase.test.jsx +0 -125
  685. package/__tests17__/ThemeProvider/ThemeProvider.test.jsx +0 -82
  686. package/__tests17__/ThemeProvider/useThemeTokens.test.jsx +0 -514
  687. package/__tests17__/ThemeProvider/utils/theme-tokens.test.js +0 -41
  688. package/__tests17__/ToggleSwitch/ToggleSwitch.test.jsx +0 -82
  689. package/__tests17__/ToggleSwitch/ToggleSwitchGroup.test.jsx +0 -192
  690. package/__tests17__/Tooltip/Tooltip.test.jsx +0 -65
  691. package/__tests17__/Tooltip/getTooltipPosition.test.js +0 -79
  692. package/__tests17__/Typography/typography.test.jsx +0 -90
  693. package/__tests17__/utils/children.test.jsx +0 -128
  694. package/__tests17__/utils/containUniqueFields.test.js +0 -25
  695. package/__tests17__/utils/input.test.js +0 -375
  696. package/__tests17__/utils/props.test.js +0 -36
  697. package/__tests17__/utils/semantics.test.jsx +0 -34
  698. package/__tests17__/utils/useCopy.test.js +0 -42
  699. package/__tests17__/utils/useResponsiveProp.test.jsx +0 -202
  700. package/__tests17__/utils/useSpacingScale.test.jsx +0 -273
  701. package/__tests17__/utils/useUniqueId.test.js +0 -31
  702. package/component-docs.json +0 -13646
  703. package/lib-module/A11yInfoProvider/index.js +0 -73
  704. package/lib-module/A11yText/index.js +0 -56
  705. package/lib-module/ActivityIndicator/Spinner.js +0 -79
  706. package/lib-module/ActivityIndicator/Spinner.native.js +0 -146
  707. package/lib-module/ActivityIndicator/index.js +0 -48
  708. package/lib-module/ActivityIndicator/shared.js +0 -13
  709. package/lib-module/BaseProvider/HydrationContext.js +0 -51
  710. package/lib-module/BaseProvider/index.js +0 -41
  711. package/lib-module/Box/Box.js +0 -259
  712. package/lib-module/Box/index.js +0 -2
  713. package/lib-module/Button/Button.js +0 -26
  714. package/lib-module/Button/ButtonBase.js +0 -309
  715. package/lib-module/Button/ButtonDropdown.js +0 -181
  716. package/lib-module/Button/ButtonGroup.js +0 -264
  717. package/lib-module/Button/ButtonLink.js +0 -40
  718. package/lib-module/Button/index.js +0 -5
  719. package/lib-module/Button/propTypes.js +0 -53
  720. package/lib-module/Card/Card.js +0 -85
  721. package/lib-module/Card/CardBase.js +0 -66
  722. package/lib-module/Card/PressableCardBase.js +0 -114
  723. package/lib-module/Card/index.js +0 -4
  724. package/lib-module/Carousel/Carousel.js +0 -690
  725. package/lib-module/Carousel/CarouselContext.js +0 -56
  726. package/lib-module/Carousel/CarouselFirstFocus/CarouselFirstFocus.js +0 -51
  727. package/lib-module/Carousel/CarouselItem/CarouselItem.js +0 -81
  728. package/lib-module/Carousel/CarouselItem/index.js +0 -2
  729. package/lib-module/Carousel/CarouselStepTracker/CarouselStepTracker.js +0 -50
  730. package/lib-module/Carousel/CarouselStepTracker/index.js +0 -2
  731. package/lib-module/Carousel/CarouselTabs/CarouselTabs.js +0 -51
  732. package/lib-module/Carousel/CarouselTabs/CarouselTabsPanel.js +0 -84
  733. package/lib-module/Carousel/CarouselTabs/CarouselTabsPanelItem.js +0 -126
  734. package/lib-module/Carousel/CarouselTabs/index.js +0 -2
  735. package/lib-module/Carousel/CarouselThumbnail.js +0 -85
  736. package/lib-module/Carousel/CarouselThumbnailNavigation.js +0 -66
  737. package/lib-module/Carousel/dictionary.js +0 -18
  738. package/lib-module/Carousel/index.js +0 -3
  739. package/lib-module/Checkbox/Checkbox.js +0 -355
  740. package/lib-module/Checkbox/CheckboxGroup.js +0 -242
  741. package/lib-module/Checkbox/CheckboxInput.js +0 -60
  742. package/lib-module/Checkbox/CheckboxInput.native.js +0 -6
  743. package/lib-module/Checkbox/index.js +0 -3
  744. package/lib-module/Divider/Divider.js +0 -127
  745. package/lib-module/Divider/index.js +0 -2
  746. package/lib-module/ExpandCollapse/Accordion.js +0 -15
  747. package/lib-module/ExpandCollapse/Control.js +0 -139
  748. package/lib-module/ExpandCollapse/ExpandCollapse.js +0 -95
  749. package/lib-module/ExpandCollapse/Panel.js +0 -160
  750. package/lib-module/ExpandCollapse/index.js +0 -7
  751. package/lib-module/Feedback/Feedback.js +0 -165
  752. package/lib-module/Feedback/index.js +0 -2
  753. package/lib-module/Fieldset/Fieldset.js +0 -182
  754. package/lib-module/Fieldset/FieldsetContainer.js +0 -38
  755. package/lib-module/Fieldset/FieldsetContainer.native.js +0 -23
  756. package/lib-module/Fieldset/Legend.js +0 -24
  757. package/lib-module/Fieldset/Legend.native.js +0 -31
  758. package/lib-module/Fieldset/cssReset.js +0 -14
  759. package/lib-module/Fieldset/index.js +0 -2
  760. package/lib-module/FlexGrid/Col/Col.js +0 -275
  761. package/lib-module/FlexGrid/Col/index.js +0 -2
  762. package/lib-module/FlexGrid/FlexGrid.js +0 -149
  763. package/lib-module/FlexGrid/Row/Row.js +0 -184
  764. package/lib-module/FlexGrid/Row/index.js +0 -2
  765. package/lib-module/FlexGrid/helpers/index.js +0 -18
  766. package/lib-module/FlexGrid/index.js +0 -2
  767. package/lib-module/FlexGrid/providers/GutterContext.js +0 -3
  768. package/lib-module/HorizontalScroll/HorizontalScroll.js +0 -175
  769. package/lib-module/HorizontalScroll/HorizontalScrollButton.js +0 -81
  770. package/lib-module/HorizontalScroll/ScrollViewEnd.js +0 -48
  771. package/lib-module/HorizontalScroll/ScrollViewEnd.native.js +0 -27
  772. package/lib-module/HorizontalScroll/dictionary.js +0 -11
  773. package/lib-module/HorizontalScroll/index.js +0 -11
  774. package/lib-module/HorizontalScroll/itemPositions.js +0 -112
  775. package/lib-module/Icon/Icon.js +0 -62
  776. package/lib-module/Icon/IconText.js +0 -88
  777. package/lib-module/Icon/index.js +0 -4
  778. package/lib-module/IconButton/IconButton.js +0 -132
  779. package/lib-module/IconButton/index.js +0 -2
  780. package/lib-module/InputLabel/InputLabel.js +0 -154
  781. package/lib-module/InputLabel/LabelContent.js +0 -27
  782. package/lib-module/InputLabel/LabelContent.native.js +0 -19
  783. package/lib-module/InputLabel/index.js +0 -2
  784. package/lib-module/InputSupports/InputSupports.js +0 -103
  785. package/lib-module/InputSupports/index.js +0 -2
  786. package/lib-module/InputSupports/useInputSupports.js +0 -33
  787. package/lib-module/Link/ChevronLink.js +0 -52
  788. package/lib-module/Link/InlinePressable.js +0 -44
  789. package/lib-module/Link/InlinePressable.native.js +0 -89
  790. package/lib-module/Link/Link.js +0 -28
  791. package/lib-module/Link/LinkBase.js +0 -244
  792. package/lib-module/Link/TextButton.js +0 -35
  793. package/lib-module/Link/index.js +0 -5
  794. package/lib-module/List/List.js +0 -66
  795. package/lib-module/List/ListItem.js +0 -38
  796. package/lib-module/List/ListItemBase.js +0 -139
  797. package/lib-module/List/ListItemContent.js +0 -66
  798. package/lib-module/List/ListItemMark.js +0 -143
  799. package/lib-module/List/PressableListItemBase.js +0 -114
  800. package/lib-module/List/index.js +0 -5
  801. package/lib-module/Modal/Modal.js +0 -225
  802. package/lib-module/Modal/dictionary.js +0 -9
  803. package/lib-module/Modal/index.js +0 -2
  804. package/lib-module/MultiSelectFilter/ModalOverlay.js +0 -112
  805. package/lib-module/MultiSelectFilter/MultiSelectFilter.js +0 -286
  806. package/lib-module/MultiSelectFilter/dictionary.js +0 -12
  807. package/lib-module/MultiSelectFilter/index.js +0 -2
  808. package/lib-module/Notification/Notification.js +0 -230
  809. package/lib-module/Notification/dictionary.js +0 -8
  810. package/lib-module/Notification/index.js +0 -2
  811. package/lib-module/Pagination/PageButton.js +0 -66
  812. package/lib-module/Pagination/Pagination.js +0 -159
  813. package/lib-module/Pagination/SideButton.js +0 -118
  814. package/lib-module/Pagination/dictionary.js +0 -18
  815. package/lib-module/Pagination/index.js +0 -2
  816. package/lib-module/Pagination/usePagination.js +0 -73
  817. package/lib-module/Progress/Progress.js +0 -89
  818. package/lib-module/Progress/ProgressBar.js +0 -138
  819. package/lib-module/Progress/ProgressBarBackground.js +0 -42
  820. package/lib-module/Progress/index.js +0 -4
  821. package/lib-module/QuickLinks/QuickLinks.js +0 -71
  822. package/lib-module/QuickLinks/QuickLinksCard.js +0 -33
  823. package/lib-module/QuickLinks/QuickLinksItem.js +0 -50
  824. package/lib-module/QuickLinks/index.js +0 -4
  825. package/lib-module/QuickLinksFeature/QuickLinksFeature.js +0 -69
  826. package/lib-module/QuickLinksFeature/QuickLinksFeatureItem.js +0 -130
  827. package/lib-module/QuickLinksFeature/index.js +0 -4
  828. package/lib-module/Radio/Radio.js +0 -288
  829. package/lib-module/Radio/RadioButton.js +0 -138
  830. package/lib-module/Radio/RadioGroup.js +0 -255
  831. package/lib-module/Radio/RadioInput.js +0 -62
  832. package/lib-module/Radio/RadioInput.native.js +0 -6
  833. package/lib-module/Radio/index.js +0 -3
  834. package/lib-module/RadioCard/RadioCardGroup.js +0 -259
  835. package/lib-module/RadioCard/index.js +0 -3
  836. package/lib-module/Responsive/index.js +0 -2
  837. package/lib-module/Search/Search.js +0 -241
  838. package/lib-module/Search/dictionary.js +0 -12
  839. package/lib-module/Search/index.js +0 -2
  840. package/lib-module/Select/Group.js +0 -21
  841. package/lib-module/Select/Group.native.js +0 -15
  842. package/lib-module/Select/Item.js +0 -20
  843. package/lib-module/Select/Item.native.js +0 -3
  844. package/lib-module/Select/Picker.js +0 -68
  845. package/lib-module/Select/Picker.native.js +0 -122
  846. package/lib-module/Select/Select.js +0 -347
  847. package/lib-module/Select/constants.js +0 -5
  848. package/lib-module/Select/index.js +0 -6
  849. package/lib-module/SideNav/Item.js +0 -145
  850. package/lib-module/SideNav/ItemContent.js +0 -48
  851. package/lib-module/SideNav/ItemsGroup.js +0 -117
  852. package/lib-module/SideNav/SideNav.js +0 -136
  853. package/lib-module/SideNav/index.js +0 -1
  854. package/lib-module/Skeleton/Skeleton.js +0 -182
  855. package/lib-module/Skeleton/index.js +0 -2
  856. package/lib-module/Skeleton/skeleton.constant.js +0 -3
  857. package/lib-module/Skeleton/skeletonWebAnimation.js +0 -18
  858. package/lib-module/Skeleton/useSkeletonNativeAnimation.js +0 -25
  859. package/lib-module/SkipLink/SkipLink.js +0 -188
  860. package/lib-module/SkipLink/index.js +0 -2
  861. package/lib-module/Spacer/Spacer.js +0 -98
  862. package/lib-module/Spacer/index.js +0 -2
  863. package/lib-module/StackView/StackView.js +0 -127
  864. package/lib-module/StackView/StackWrap.js +0 -53
  865. package/lib-module/StackView/StackWrap.native.js +0 -3
  866. package/lib-module/StackView/StackWrapBox.js +0 -117
  867. package/lib-module/StackView/StackWrapGap.js +0 -61
  868. package/lib-module/StackView/common.js +0 -35
  869. package/lib-module/StackView/getStackedContent.js +0 -124
  870. package/lib-module/StackView/index.js +0 -5
  871. package/lib-module/StepTracker/Step.js +0 -253
  872. package/lib-module/StepTracker/StepTracker.js +0 -191
  873. package/lib-module/StepTracker/dictionary.js +0 -10
  874. package/lib-module/StepTracker/index.js +0 -2
  875. package/lib-module/Tabs/Tabs.js +0 -152
  876. package/lib-module/Tabs/TabsItem.js +0 -228
  877. package/lib-module/Tabs/index.js +0 -2
  878. package/lib-module/Tags/Tags.js +0 -257
  879. package/lib-module/Tags/index.js +0 -2
  880. package/lib-module/TextInput/TextArea.js +0 -94
  881. package/lib-module/TextInput/TextInput.js +0 -73
  882. package/lib-module/TextInput/TextInputBase.js +0 -333
  883. package/lib-module/TextInput/dictionary.js +0 -8
  884. package/lib-module/TextInput/index.js +0 -3
  885. package/lib-module/TextInput/propTypes.js +0 -33
  886. package/lib-module/ThemeProvider/ThemeProvider.js +0 -74
  887. package/lib-module/ThemeProvider/index.js +0 -6
  888. package/lib-module/ThemeProvider/useSetTheme.js +0 -25
  889. package/lib-module/ThemeProvider/useTheme.js +0 -14
  890. package/lib-module/ThemeProvider/useThemeTokens.js +0 -110
  891. package/lib-module/ThemeProvider/utils/index.js +0 -2
  892. package/lib-module/ThemeProvider/utils/styles.js +0 -188
  893. package/lib-module/ThemeProvider/utils/theme-tokens.js +0 -163
  894. package/lib-module/Timeline/Timeline.js +0 -174
  895. package/lib-module/Timeline/index.js +0 -2
  896. package/lib-module/ToggleSwitch/ToggleSwitch.js +0 -255
  897. package/lib-module/ToggleSwitch/ToggleSwitchGroup.js +0 -227
  898. package/lib-module/ToggleSwitch/index.js +0 -3
  899. package/lib-module/Tooltip/Backdrop.js +0 -45
  900. package/lib-module/Tooltip/Backdrop.native.js +0 -44
  901. package/lib-module/Tooltip/Tooltip.js +0 -278
  902. package/lib-module/Tooltip/Tooltip.native.js +0 -326
  903. package/lib-module/Tooltip/dictionary.js +0 -8
  904. package/lib-module/Tooltip/getTooltipPosition.js +0 -175
  905. package/lib-module/Tooltip/index.js +0 -5
  906. package/lib-module/Tooltip/shared.js +0 -27
  907. package/lib-module/TooltipButton/TooltipButton.js +0 -78
  908. package/lib-module/TooltipButton/index.js +0 -2
  909. package/lib-module/Typography/Typography.js +0 -154
  910. package/lib-module/Typography/index.js +0 -2
  911. package/lib-module/ViewportProvider/ViewportProvider.js +0 -29
  912. package/lib-module/ViewportProvider/index.js +0 -3
  913. package/lib-module/ViewportProvider/useViewport.js +0 -3
  914. package/lib-module/ViewportProvider/useViewportListener.js +0 -39
  915. package/lib-module/index.js +0 -58
  916. package/lib-module/utils/BaseView/BaseView.js +0 -43
  917. package/lib-module/utils/BaseView/BaseView.native.js +0 -6
  918. package/lib-module/utils/BaseView/index.js +0 -2
  919. package/lib-module/utils/a11y/index.js +0 -2
  920. package/lib-module/utils/a11y/semantics.js +0 -157
  921. package/lib-module/utils/a11y/textSize.js +0 -36
  922. package/lib-module/utils/animation/index.js +0 -2
  923. package/lib-module/utils/animation/useVerticalExpandAnimation.js +0 -89
  924. package/lib-module/utils/children.js +0 -119
  925. package/lib-module/utils/containUniqueFields.js +0 -26
  926. package/lib-module/utils/floating-ui/index.js +0 -1
  927. package/lib-module/utils/floating-ui/index.native.js +0 -1
  928. package/lib-module/utils/hasOwnProperty.js +0 -11
  929. package/lib-module/utils/index.js +0 -19
  930. package/lib-module/utils/info/index.js +0 -7
  931. package/lib-module/utils/info/platform/index.js +0 -11
  932. package/lib-module/utils/info/platform/platform.android.js +0 -1
  933. package/lib-module/utils/info/platform/platform.ios.js +0 -1
  934. package/lib-module/utils/info/platform/platform.js +0 -1
  935. package/lib-module/utils/info/platform/platform.native.js +0 -4
  936. package/lib-module/utils/info/versions.js +0 -5
  937. package/lib-module/utils/input.js +0 -187
  938. package/lib-module/utils/pressability.js +0 -111
  939. package/lib-module/utils/props/a11yProps.js +0 -308
  940. package/lib-module/utils/props/clickProps.js +0 -26
  941. package/lib-module/utils/props/componentPropType.js +0 -63
  942. package/lib-module/utils/props/copyPropTypes.js +0 -2
  943. package/lib-module/utils/props/getPropSelector.js +0 -48
  944. package/lib-module/utils/props/handlerProps.js +0 -117
  945. package/lib-module/utils/props/hrefAttrsProp.js +0 -33
  946. package/lib-module/utils/props/index.js +0 -19
  947. package/lib-module/utils/props/inputSupportsProps.js +0 -62
  948. package/lib-module/utils/props/linkProps.js +0 -44
  949. package/lib-module/utils/props/paddingProp.js +0 -9
  950. package/lib-module/utils/props/pressProps.js +0 -42
  951. package/lib-module/utils/props/rectProp.js +0 -9
  952. package/lib-module/utils/props/responsiveProps.js +0 -30
  953. package/lib-module/utils/props/selectSystemProps.js +0 -24
  954. package/lib-module/utils/props/spacingProps.js +0 -56
  955. package/lib-module/utils/props/textInputProps.js +0 -201
  956. package/lib-module/utils/props/textProps.js +0 -59
  957. package/lib-module/utils/props/tokens.js +0 -133
  958. package/lib-module/utils/props/variantProp.js +0 -18
  959. package/lib-module/utils/props/viewProps.js +0 -22
  960. package/lib-module/utils/ssr.js +0 -144
  961. package/lib-module/utils/useCopy.js +0 -44
  962. package/lib-module/utils/useHash.js +0 -45
  963. package/lib-module/utils/useHash.native.js +0 -7
  964. package/lib-module/utils/useResponsiveProp.js +0 -46
  965. package/lib-module/utils/useSafeLayoutEffect.js +0 -30
  966. package/lib-module/utils/useScrollBlocking.js +0 -58
  967. package/lib-module/utils/useScrollBlocking.native.js +0 -2
  968. package/lib-module/utils/useSpacingScale.js +0 -125
  969. package/lib-module/utils/useUniqueId.js +0 -13
  970. package/lib-module/utils/withLinkRouter.js +0 -81
@@ -0,0 +1,43 @@
1
+ import React from 'react'
2
+ import { Platform } from 'react-native'
3
+
4
+ const rules = {}
5
+ let styleSheet
6
+
7
+ if (typeof window !== 'undefined' && typeof document !== 'undefined') {
8
+ styleSheet = (() => {
9
+ const style = document.createElement('style')
10
+ style.id = 'RNMQCSS'
11
+ style.appendChild(document.createTextNode(''))
12
+ document.head.appendChild(style)
13
+ return style.sheet
14
+ })()
15
+ }
16
+ export const hasCss = (id, text) => {
17
+ return !!rules[id] && !!rules[id].text?.includes?.(text)
18
+ }
19
+
20
+ export const addCss = (id, text) => {
21
+ if (!hasCss(id, text)) {
22
+ rules[id] = rules?.[id] || {}
23
+ rules[id].text = (rules[id]?.text || '') + text
24
+ if (styleSheet) {
25
+ styleSheet.insertRule(text, Object.keys(rules).length - 1)
26
+ }
27
+ }
28
+ }
29
+
30
+ export const flush = () => {
31
+ if (Platform.OS === 'web') {
32
+ return React.createElement('style', {
33
+ id: 'rnmq',
34
+ key: 'rnmq',
35
+ dangerouslySetInnerHTML: {
36
+ __html: Object.keys(rules)
37
+ .map((key) => rules[key].text)
38
+ .join('\n')
39
+ }
40
+ })
41
+ }
42
+ return {}
43
+ }
package/src/utils/ssr.jsx CHANGED
@@ -1,5 +1,6 @@
1
1
  import React from 'react'
2
2
  import { AppRegistry } from 'react-native'
3
+ import { flush } from './ssr-media-query/utils/inject'
3
4
  /** @typedef {import('react').ComponentType} ReactComponent */
4
5
  /** @typedef {import('react').ReactElement} ReactElement */
5
6
 
@@ -80,7 +81,8 @@ export const ssrStyles = (appName = 'UDS app', { styleGetters = [], collectStyle
80
81
  */
81
82
  getStyles: (...existingStyles) => {
82
83
  if (!hasAppRendered) throw new Error('Called getStyles before renderApp in ssrStyles')
83
- return [...existingStyles, ...styleGetters.flatMap((getter) => getter())]
84
+
85
+ return [...existingStyles, ...styleGetters.flatMap((getter) => getter()), flush()]
84
86
  }
85
87
  }
86
88
  }
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Transforms a gradient object into a CSS gradient string.
3
+ *
4
+ * @param {Object} gradient - The gradient object to transform.
5
+ * @param {string} gradient.type - The type of gradient (linear or radial).
6
+ * @param {number} gradient.angle - The angle of the linear gradient in degrees.
7
+ * @param {Array} gradient.stops - An array of gradient stops.
8
+ * @param {string} gradient.stops[].color - The color of the gradient stop.
9
+ * @param {number} gradient.stops[].stop - The position of the gradient stop as a percentage.
10
+ * @returns {string} The CSS gradient string.
11
+ */
12
+ export const transformGradient = (gradient) =>
13
+ `${gradient.type}-gradient(${gradient.angle}deg, ${gradient.stops[0].color} ${
14
+ gradient.stops[0].stop * 100
15
+ }%, ${gradient.stops[1].color} ${gradient.stops[1].stop * 100}%)`
16
+
17
+ export default { transformGradient }
@@ -0,0 +1,224 @@
1
+ import { useCallback, useEffect, useRef, useState } from 'react'
2
+ import { Dimensions, Platform } from 'react-native'
3
+
4
+ const adjustHorizontalToFit = (initialOffset, windowWidth, sourceWidth) => {
5
+ const offset = Math.max(0, initialOffset)
6
+ const otherEdgeOverflow = Math.max(0, offset + sourceWidth - windowWidth)
7
+ const tooWideBy = Math.max(0, otherEdgeOverflow - offset)
8
+
9
+ const adjusted = {
10
+ offset: Math.max(0, offset - otherEdgeOverflow)
11
+ }
12
+ if (tooWideBy) adjusted.width = Math.max(0, sourceWidth - tooWideBy)
13
+
14
+ return adjusted
15
+ }
16
+
17
+ const getPosition = ({ edge, fromEdge, sourceSize }) => {
18
+ switch (edge) {
19
+ case 'near':
20
+ return fromEdge
21
+ case 'mid':
22
+ return fromEdge + sourceSize / 2
23
+ case 'far':
24
+ return fromEdge + sourceSize
25
+ default:
26
+ return 0
27
+ }
28
+ }
29
+
30
+ const getEdgeType = (align, alignSide) => {
31
+ const alignTo = align[alignSide]
32
+ const edge =
33
+ (['center', 'middle'].includes(alignTo) && 'mid') || (alignSide === alignTo ? 'near' : 'far')
34
+ return edge
35
+ }
36
+
37
+ /**
38
+ * Based on UDS's private getTooltipPosition but generalised.
39
+ *
40
+ * Used for absolute positioning of the tooltip. Since the tooltip is always centered relatively
41
+ * to the source (button) and we have a limited set of positions, an easy and consistent way
42
+ * of positioning it is to check all of the possible positions and pick one that will be rendered
43
+ * within the window bounds. This way we can also rely on the tooltip being actually rendered
44
+ * before it is shown, which makes it account for the width being limiting in styles, custom font
45
+ * rendering, etc.
46
+ */
47
+ function getOverlaidPosition({
48
+ sourceLayout,
49
+ targetDimensions,
50
+ windowDimensions,
51
+ offsets = {},
52
+ align
53
+ }) {
54
+ // Web-only: this will be difficult to mimic on native because there's no global scroll position.
55
+ // TODO: wire something in e.g. a scroll ref accessible from a provider included in Allium provider
56
+ // that can be passed to the appropriate ScrollView?
57
+ const { scrollX = 0, scrollY = 0 } = typeof window === 'object' ? window : {}
58
+
59
+ // Will have top, bottom, left and/or right offsets depending on `align`
60
+ const positioning = {}
61
+
62
+ if (align.top)
63
+ positioning.top = getPosition({
64
+ edge: getEdgeType(align, 'top'),
65
+ fromEdge: sourceLayout.y + scrollY + (offsets.vertical ?? 0),
66
+ sourceSize: sourceLayout.height
67
+ })
68
+ if (align.middle)
69
+ positioning.top = getPosition({
70
+ edge: getEdgeType(align, 'middle'),
71
+ fromEdge: sourceLayout.y + scrollY + (offsets.vertical ?? 0) - targetDimensions.height / 2,
72
+ sourceSize: sourceLayout.height
73
+ })
74
+ if (align.bottom)
75
+ positioning.bottom = getPosition({
76
+ edge: getEdgeType(align, 'bottom'),
77
+ fromEdge:
78
+ windowDimensions.height -
79
+ (sourceLayout.y + scrollY + sourceLayout.height - (offsets.vertical ?? 0)),
80
+ sourceSize: sourceLayout.height
81
+ })
82
+
83
+ if (align.left)
84
+ positioning.left = getPosition({
85
+ edge: getEdgeType(align, 'left'),
86
+ fromEdge: sourceLayout.x + scrollX + (offsets.horizontal ?? 0),
87
+ sourceSize: sourceLayout.width
88
+ })
89
+ if (align.center)
90
+ positioning.left = getPosition({
91
+ edge: getEdgeType(align, 'center'),
92
+ fromEdge: sourceLayout.x + scrollX + (offsets.horizontal ?? 0) - targetDimensions.width / 2,
93
+ sourceSize: sourceLayout.width
94
+ })
95
+ if (align.right)
96
+ positioning.right = getPosition({
97
+ edge: getEdgeType(align, 'right'),
98
+ fromEdge:
99
+ windowDimensions.width -
100
+ (sourceLayout.x + scrollX + sourceLayout.width - (offsets.horizontal ?? 0)),
101
+ sourceSize: sourceLayout.width
102
+ })
103
+
104
+ if (!(align.left && align.right)) {
105
+ // Check if the position and/or width need adjusting to fit on the screen
106
+ const side = align.right ? 'right' : 'left'
107
+ const adjusted = adjustHorizontalToFit(
108
+ positioning[side],
109
+ windowDimensions.width,
110
+ sourceLayout.width
111
+ )
112
+ if (typeof adjusted.width === 'number') positioning.width = adjusted.width
113
+ if (typeof adjusted.offset === 'number') {
114
+ positioning[side] = adjusted.offset
115
+ }
116
+ }
117
+
118
+ return positioning
119
+ }
120
+
121
+ /**
122
+ * Positions an element in a modal or portal so that it appears tooltip-like below the
123
+ * target element.
124
+ *
125
+ * @TODO - add support for positioning other than 'below' like UDS's tooltip (this is not
126
+ * a small task because UDS's tooltip logic only really works for short text - it might be
127
+ * better to use a third-party library).
128
+ */
129
+ const useOverlaidPosition = ({
130
+ isShown = false,
131
+ offsets,
132
+ // By default, align the overlaid target's `top` to the bottom of the source, and center horizontally.
133
+ align = {
134
+ center: 'center',
135
+ top: 'bottom'
136
+ }
137
+ }) => {
138
+ // Element in main document flow that the targetRef element is positioned around
139
+ const sourceRef = useRef(null)
140
+ const [sourceLayout, setSourceLayout] = useState(null)
141
+
142
+ // Element in a modal or portal overlay positioned to appear adjacent to sourceRef
143
+ const targetRef = useRef(null)
144
+ const [targetDimensions, setTargetDimensions] = useState(null)
145
+
146
+ const [windowDimensions, setWindowDimensions] = useState(null)
147
+
148
+ const onTargetLayout = useCallback(
149
+ ({
150
+ nativeEvent: {
151
+ layout: { width, height }
152
+ }
153
+ }) => {
154
+ // NOTE: UDS's Tooltip logic injects some additional width to allow for antialiasing etc of text,
155
+ // avoiding adding unnecessary line breaks to text that is slightly wider than it thinks it is.
156
+ // That is probably something specific to text tooltips that doesn't belong in a generic hook.
157
+ setTargetDimensions((previousDimensions) => {
158
+ // Re-render on first non-zero width / height: avoid infinite loops on changes, or mispositioning
159
+ // if user scrolls while a slidedown animation is changing the height and recalculating position.
160
+ if (!previousDimensions && width && height) {
161
+ return { width, height }
162
+ }
163
+ return previousDimensions
164
+ })
165
+ },
166
+ []
167
+ )
168
+
169
+ const readyToShow = Boolean(isShown && sourceRef.current)
170
+ useEffect(() => {
171
+ const handleDimensionsChange = ({ window }) => {
172
+ const measurementFunction = Platform.OS === 'web' ? 'measureInWindow' : 'measure'
173
+
174
+ sourceRef.current?.[measurementFunction]((x, y, width, height) => {
175
+ setWindowDimensions(window)
176
+ setSourceLayout({ x, y, width, height })
177
+ })
178
+ }
179
+
180
+ let subscription
181
+ const unsubscribe = () => {
182
+ if (typeof subscription?.remove === 'function') {
183
+ // React Native >=0.65.0
184
+ subscription.remove()
185
+ } else if (typeof Dimensions.remove === 'function') {
186
+ // React Native <0.65.0
187
+ Dimensions.remove('change', handleDimensionsChange)
188
+ }
189
+ setSourceLayout(null)
190
+ setTargetDimensions(null)
191
+ }
192
+
193
+ if (readyToShow) {
194
+ subscription = Dimensions.addEventListener('change', handleDimensionsChange)
195
+ handleDimensionsChange({ window: Dimensions.get('window') })
196
+ } else {
197
+ unsubscribe()
198
+ }
199
+
200
+ return unsubscribe
201
+ }, [readyToShow])
202
+
203
+ const isReady = Boolean(isShown && sourceLayout && windowDimensions && targetDimensions)
204
+
205
+ const overlaidPosition = isReady
206
+ ? getOverlaidPosition({
207
+ sourceLayout,
208
+ targetDimensions,
209
+ windowDimensions,
210
+ offsets,
211
+ align
212
+ })
213
+ : {}
214
+
215
+ return {
216
+ overlaidPosition,
217
+ sourceRef,
218
+ targetRef,
219
+ onTargetLayout,
220
+ isReady
221
+ }
222
+ }
223
+
224
+ export default useOverlaidPosition
@@ -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 hasOwnProperty from './hasOwnProperty'
4
4
 
@@ -17,7 +17,7 @@ import hasOwnProperty from './hasOwnProperty'
17
17
  * @example A LinkRouter component to be used with link-like components might look like:
18
18
  *
19
19
  * ```jsx
20
- * const LinkLinkRouter = forwardRef(({ Component, linkRouterProps: { to, options }, href, ...rest }, ref) => {
20
+ * const LinkLinkRouter = React.forwardRef(({ Component, linkRouterProps: { to, options }, href, ...rest }, ref) => {
21
21
  * const { href: resolvedHref, onClick } = useSomeRouterHook({ to, href, options })
22
22
  * return <Component href={resolvedHref} onPress={onClick} {...rest} />
23
23
  * })
@@ -31,7 +31,7 @@ import hasOwnProperty from './hasOwnProperty'
31
31
  * ```
32
32
  */
33
33
  const withLinkRouter = (Component) => {
34
- const wrappedComponent = forwardRef(({ LinkRouter, linkRouterProps, ...props }, ref) => {
34
+ const wrappedComponent = React.forwardRef(({ LinkRouter, linkRouterProps, ...props }, ref) => {
35
35
  if (!LinkRouter) return <Component {...props} ref={ref} />
36
36
  return (
37
37
  <LinkRouter linkRouterProps={linkRouterProps} Component={Component} ref={ref} {...props} />
@@ -0,0 +1,28 @@
1
+ export interface BadgeProps {
2
+ text: string
3
+ borderColor?: string
4
+ textColor?: string
5
+ }
6
+
7
+ type BadgeVariants = {
8
+ alternative?: boolean
9
+ inverse?: boolean
10
+ outline?: boolean
11
+ purpose?: 'offer' | 'editorial'
12
+ }
13
+
14
+ export type BadgeTokens = {
15
+ backgroundColor?: string
16
+ borderColor?: string
17
+ borderRadius?: number
18
+ borderWidth?: number
19
+ color?: string
20
+ fontName?: string
21
+ fontSize?: number
22
+ fontWeight?: number
23
+ gradient?: string
24
+ paddingBottom?: number
25
+ paddingLeft?: number
26
+ paddingRight?: number
27
+ paddingTop?: number
28
+ }
package/types/Box.d.ts ADDED
@@ -0,0 +1,52 @@
1
+ import { ReactNode, ReactElement } from 'react'
2
+ import { ScrollViewProps } from 'react-native'
3
+ import { ResponsiveSpacing, SemanticTag } from './Common'
4
+
5
+ type BoxVariants = {
6
+ background?:
7
+ | 'lightest'
8
+ | 'lighter'
9
+ | 'light'
10
+ | 'dark'
11
+ | 'darker'
12
+ | 'darkest'
13
+ | 'critical'
14
+ | 'danger'
15
+ | 'warning'
16
+ | 'positive'
17
+ | 'black'
18
+ | 'featurePrimary'
19
+ | 'featureSecondary'
20
+ | 'featureNeutral'
21
+ | 'featureBrand'
22
+ }
23
+
24
+ type BoxTokens = {
25
+ backgroundColor?: string
26
+ gradient?: string
27
+ borderWidth?: number
28
+ borderColor?: string
29
+ borderTopLeftRadius?: number
30
+ borderTopRightRadius?: number
31
+ borderBottomLeftRadius?: number
32
+ borderBottomRightRadius?: number
33
+ }
34
+
35
+ export interface BoxProps {
36
+ children: ReactNode | ReactElement
37
+ horizontal?: ResponsiveSpacing | number
38
+ vertical?: ResponsiveSpacing | number
39
+ top?: ResponsiveSpacing | number
40
+ bottom?: ResponsiveSpacing | number
41
+ left?: ResponsiveSpacing | number
42
+ right?: ResponsiveSpacing | number
43
+ variant?: BoxVariants
44
+ tokens?: BoxTokens
45
+ space?: ResponsiveSpacing | number
46
+ flex?: number
47
+ scroll?: boolean | ScrollViewProps
48
+ tag?: SemanticTag
49
+ testID?: string
50
+ accessibilityLabel?: string
51
+ accessible?: boolean
52
+ }
@@ -0,0 +1,47 @@
1
+ import { StyleProp, ViewStyle, TextStyle } from 'react-native'
2
+ import { Tokens, Variant } from '../ThemeProvider'
3
+
4
+ type CheckboxProps = {
5
+ checked?: boolean
6
+ defaultChecked?: boolean
7
+ error?: boolean
8
+ feedback?: string
9
+ id?: string
10
+ inactive?: boolean
11
+ label?: string
12
+ name?: string
13
+ onChange?: (value: boolean, event: any) => void
14
+ tokens?: Tokens
15
+ value?: string | number | boolean
16
+ variant?: Variant
17
+ style?: StyleProp<ViewStyle>
18
+ labelStyle?: StyleProp<TextStyle>
19
+ containerStyle?: StyleProp<ViewStyle>
20
+ }
21
+
22
+ type CheckboxTokens = {
23
+ containerBackgroundColor?: string
24
+ feedbackMarginBottom?: number
25
+ feedbackMarginTop?: number
26
+ feedbackPosition?: string
27
+ icon?: string
28
+ iconBackgroundColor?: string
29
+ iconColor?: string
30
+ iconSize?: number
31
+ inputBackgroundColor?: string
32
+ inputBorderColor?: string
33
+ inputBorderRadius?: number | string
34
+ inputBorderWidth?: number | string
35
+ inputHeight?: number
36
+ inputOutlineColor?: string
37
+ inputOutlineOffset?: number
38
+ inputOutlineWidth?: number | string
39
+ inputShadow?: string
40
+ inputWidth?: number
41
+ labelColor?: string
42
+ labelFontName?: string
43
+ labelFontSize?: number
44
+ labelFontWeight?: number
45
+ labelLineHeight?: number
46
+ labelMarginLeft?: number
47
+ }
@@ -0,0 +1,72 @@
1
+ import * as React from 'react'
2
+ import { Direction, ResponsiveDirection } from './Common'
3
+
4
+ type CheckboxCardGroupProps = {
5
+ copy?: 'en' | 'fr'
6
+ variant?: 'fullWidth'
7
+ legend?: string
8
+ tooltip?: string
9
+ hint?: string
10
+ hintPosition?: 'inline' | 'below'
11
+ validation?: 'error' | 'success'
12
+ feedback?: string
13
+ initialCheckedIds?: string[]
14
+ checkedIds?: string[]
15
+ onChange?: (checkedIds: string[]) => void
16
+ readOnly?: boolean
17
+ inactive?: boolean
18
+ }
19
+
20
+ type CheckboxCardGroupTokens = {
21
+ borderBottomLeftRadius?: number
22
+ borderBottomRightRadius?: number
23
+ borderTopLeftRadius?: number
24
+ borderTopRightRadius?: number
25
+ direction?: Direction | ResponsiveDirection
26
+ fieldSpace?: number
27
+ outlineOffset?: number
28
+ outlineWidth?: number
29
+ showIcon?: boolean
30
+ space?: number
31
+ }
32
+
33
+ type checkboxCardTokens = {
34
+ outerBorderColer?: string
35
+ outerBorderWidth?: number
36
+ outerBorderGap?: number
37
+ flex?: number
38
+ backgroundColor?: string
39
+ borderColor?: string
40
+ borderRadius?: number
41
+ borderWidth?: number
42
+ paddingBottom?: number
43
+ paddingLeft?: number
44
+ paddingRight?: number
45
+ paddingTop?: number
46
+ minWidth?: number
47
+ shadow?: string
48
+ contentAlignItems?: string
49
+ contentJustifyContent?: string
50
+ contentFlexGrow?: number
51
+ contentFlexShrink?: number
52
+ checkboxCheckedBackgroundColor?: string
53
+ checkboxCheckedSize?: number
54
+ checkboxInputBackgroundColor?: string
55
+ checkboxInputBorderColor?: string
56
+ checkboxInputBorderWidth?: number
57
+ checkboxInputOutlineColor?: string
58
+ checkboxInputOutlineWidth?: number
59
+ checkboxInputSize?: number
60
+ checkboxOuterBorderColor?: string
61
+ checkboxOuterBorderWidth?: number
62
+ checkboxOuterBorderGap?: number
63
+ fontSize?: number
64
+ fontName?: string
65
+ lineHeight?: number
66
+ color?: string
67
+ letterSpacing?: string
68
+ textTransform?: string
69
+ fontWeight?: number
70
+ checkboxSpace?: number
71
+ contentSpace?: number
72
+ }
@@ -0,0 +1,47 @@
1
+ import { IconProps, IconPositionLeftRight } from './Icon'
2
+ import { LinkAndTextButtonVariants } from './Link'
3
+
4
+ type ChevronLinkTokens = {
5
+ fontSize?: number
6
+ color?: string
7
+ outerBorderColor?: string
8
+ leftIcon?: IconProps
9
+ rightIcon?: IconProps
10
+ iconDisplace?: number
11
+ iconSize?: number
12
+ iconSpace?: number
13
+ textLine?: string
14
+ textLineStyle?: string
15
+ outerBorderWidth?: number
16
+ outerBorderOutline?: string
17
+ borderRadius?: number
18
+ blockFontName?: string
19
+ blockFontWeight?: number
20
+ blockFontSize?: number
21
+ blockLineHeight?: number
22
+ icon?: IconProps
23
+ iconTranslateX?: number
24
+ iconTranslateY?: number
25
+ alignSelf?: 'auto' | 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'baseline'
26
+ }
27
+ export interface ChevronLinkProps {
28
+ testID?: string
29
+ children?: React.ReactNode
30
+ onPress?: () => void
31
+ onPressIn?: () => void
32
+ onPressOut?: () => void
33
+ disabled?: boolean
34
+ href?: string
35
+ hrefAttrs?: HrefProps
36
+ accessibilityRole?: string
37
+ accessibilityLabel?: string
38
+ tokens?: ChevronLinkTokens
39
+ direction?: IconPositionLeftRight
40
+ variant?: LinkAndTextButtonVariants
41
+ }
42
+
43
+ export interface HrefProps {
44
+ download: string
45
+ rel: string
46
+ target: string
47
+ }
@@ -0,0 +1,106 @@
1
+ import React from 'react'
2
+
3
+ export type TextTransform = {
4
+ CAPITALIZE: 'capitalize'
5
+ LOWERCASE: 'lowercase'
6
+ UPPERCASE: 'uppercase'
7
+ NONE: 'none'
8
+ }
9
+
10
+ export type LetterSpacing = {
11
+ NORMAL: 'normal'
12
+ LENGTH: number
13
+ }
14
+
15
+ export type CopyType = {
16
+ EN: 'en'
17
+ FR: 'fr'
18
+ }
19
+
20
+ export type Size = {
21
+ margin?: number
22
+ padding?: number
23
+ height?: number | string
24
+ width?: number | string
25
+ }
26
+
27
+ export type Position = 'auto' | 'above' | 'below' | 'right' | 'left'
28
+
29
+ export type DisplaySize = {
30
+ LARGE: 'large'
31
+ MEDIUM: 'medium'
32
+ SMALL: 'small'
33
+ MICRO: 'micro'
34
+ }
35
+
36
+ export enum Sizes {
37
+ xs = 'xs',
38
+ sm = 'sm',
39
+ md = 'md',
40
+ lg = 'lg',
41
+ xl = 'xl'
42
+ }
43
+
44
+ export type ResponsiveSpacing = {
45
+ [key in Sizes]?: 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11
46
+ }
47
+
48
+ export type Direction = 'column' | 'row' | 'column-reverse' | 'row-reverse'
49
+
50
+ export type ResponsiveDirection = {
51
+ [key in Sizes]?: Direction
52
+ }
53
+
54
+ export type SemanticTag =
55
+ | 'h1'
56
+ | 'h2'
57
+ | 'h3'
58
+ | 'h4'
59
+ | 'h5'
60
+ | 'h6'
61
+ | 'article'
62
+ | 'aside'
63
+ | 'blockquote'
64
+ | 'footer'
65
+ | 'figure'
66
+ | 'form'
67
+ | 'header'
68
+ | 'ul'
69
+ | 'li'
70
+ | 'main'
71
+ | 'nav'
72
+ | 'section'
73
+ | 'label'
74
+
75
+ type headingType = {
76
+ H1: 'h1'
77
+ H2: 'h2'
78
+ H3: 'h1'
79
+ H4: 'h2'
80
+ H5: 'h1'
81
+ H6: 'h2'
82
+ }
83
+
84
+ type tagType = {
85
+ HEADING: headingType
86
+ BLOCKQUOTE: 'blockquote'
87
+ CODE: 'code'
88
+ DEL: 'del'
89
+ EM: 'em'
90
+ INS: 'ins'
91
+ LI: 'li'
92
+ STRONG: 'strong'
93
+ LABEL: 'label'
94
+ }
95
+
96
+ type alignType = {
97
+ AUTO: 'auto'
98
+ LEFT: 'left'
99
+ RIGHT: 'right'
100
+ CENTER: 'center'
101
+ JUSTIFY: 'justify'
102
+ }
103
+
104
+ export type FlexAlign = 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'baseline'
105
+
106
+ export type FlexJustify = 'flex-start' | 'flex-end' | 'center' | 'space-between' | 'space-around'
@@ -0,0 +1,19 @@
1
+ import { ResponsiveSpacing, Size } from './Common'
2
+ type DividerVariants = {
3
+ weight?: 'regular' | 'thick'
4
+ decorative?: boolean
5
+ inverse?: boolean
6
+ }
7
+
8
+ export interface DividerProps {
9
+ testID?: string
10
+ vertical?: boolean
11
+ space?: number | ResponsiveSpacing
12
+ tokens?: DividerTokens
13
+ variant?: DividerVariants
14
+ }
15
+
16
+ export interface DividerTokens {
17
+ width?: Size
18
+ color?: string
19
+ }