@conveyorhq/arrow-ds 2.0.0-beta.5 → 2.0.0-beta.9

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 (617) hide show
  1. package/package.json +31 -23
  2. package/public/components/Accordion/Accordion.d.ts +29 -17
  3. package/public/components/Accordion/Accordion.js +73 -53
  4. package/public/components/Accordion/context.d.ts +12 -0
  5. package/public/components/Accordion/context.js +30 -0
  6. package/public/components/Accordion/index.d.ts +1 -0
  7. package/public/components/Accordion/index.js +1 -0
  8. package/public/components/Accordion/types.d.ts +17 -0
  9. package/public/components/Accordion/types.js +2 -0
  10. package/public/components/Avatar/Avatar.d.ts +1 -1
  11. package/public/components/Avatar/Avatar.js +20 -19
  12. package/public/components/Avatar/AvatarGroup.d.ts +1 -1
  13. package/public/components/Avatar/AvatarGroup.js +11 -1
  14. package/public/components/Button/Button.d.ts +3 -2
  15. package/public/components/Button/Button.js +5 -2
  16. package/public/components/CloseButton/CloseButton.d.ts +1 -2
  17. package/public/components/ConveyorLogo/ConveyorLogo.js +7 -7
  18. package/public/components/Divider/Divider.d.ts +1 -9
  19. package/public/components/Divider/Divider.js +13 -24
  20. package/public/components/Drawer/Drawer.js +4 -2
  21. package/public/components/Flex/Flex.js +3 -4
  22. package/public/components/Frame/Frame.d.ts +1 -1
  23. package/public/components/Grid/Grid.d.ts +2 -2
  24. package/public/components/Grid/Grid.js +9 -3
  25. package/public/components/Icon/Icon.d.ts +15 -0
  26. package/public/components/Icon/Icon.js +34 -2
  27. package/public/components/Icon/svg/ArrowToBottom.d.ts +2 -0
  28. package/public/components/Icon/svg/ArrowToBottom.js +14 -0
  29. package/public/components/Icon/svg/CommentAltCheck.d.ts +2 -0
  30. package/public/components/Icon/svg/CommentAltCheck.js +13 -0
  31. package/public/components/Icon/svg/index.d.ts +2 -0
  32. package/public/components/Icon/svg/index.js +2 -0
  33. package/public/components/Input/Input.d.ts +3 -2
  34. package/public/components/Input/Input.js +7 -6
  35. package/public/components/Loading/Loading.d.ts +3 -2
  36. package/public/components/Loading/Loading.js +4 -7
  37. package/public/components/Markdown/Markdown.d.ts +1 -1
  38. package/public/components/Markdown/Markdown.js +3 -3
  39. package/public/components/MarkdownEditor/MarkdownEditor.js +1 -2
  40. package/public/components/MarkdownEditor/MarkdownHelp.js +4 -7
  41. package/public/components/Modal/Modal.d.ts +6 -0
  42. package/public/components/Modal/Modal.js +30 -20
  43. package/public/components/Modal/context.d.ts +6 -0
  44. package/public/components/Modal/context.js +15 -0
  45. package/public/components/Modal/index.d.ts +1 -0
  46. package/public/components/Modal/index.js +1 -0
  47. package/public/components/OptionButton/OptionButton.d.ts +28 -1
  48. package/public/components/OptionButton/OptionButton.js +65 -13
  49. package/public/components/OptionButton/context.d.ts +11 -0
  50. package/public/components/OptionButton/context.js +16 -0
  51. package/public/components/Overlay/Overlay.js +2 -2
  52. package/public/components/Paragraph/Paragraph.js +3 -7
  53. package/public/components/Reference/Reference.d.ts +2 -2
  54. package/public/components/Select/Select.d.ts +1 -0
  55. package/public/components/Select/Select.js +15 -10
  56. package/public/components/Select/SelectPopover.js +6 -6
  57. package/public/components/Select/index.d.ts +2 -0
  58. package/public/components/Select/index.js +3 -0
  59. package/public/components/Select/theme.js +22 -22
  60. package/public/components/Snackbar/Snackbar.d.ts +14 -22
  61. package/public/components/Snackbar/Snackbar.js +28 -85
  62. package/public/components/Snackbar/SnackbarProvider.d.ts +2 -0
  63. package/public/components/Snackbar/SnackbarProvider.js +21 -0
  64. package/public/components/Snackbar/constants.d.ts +2 -0
  65. package/public/components/Snackbar/constants.js +5 -0
  66. package/public/components/Snackbar/context.d.ts +4 -0
  67. package/public/components/Snackbar/context.js +17 -0
  68. package/public/components/Snackbar/helpers.d.ts +3 -0
  69. package/public/components/Snackbar/helpers.js +31 -0
  70. package/public/components/Snackbar/hooks.d.ts +2 -0
  71. package/public/components/Snackbar/hooks.js +47 -0
  72. package/public/components/Snackbar/index.d.ts +6 -0
  73. package/public/components/Snackbar/index.js +6 -0
  74. package/public/components/Snackbar/types.d.ts +43 -0
  75. package/public/components/Snackbar/types.js +2 -0
  76. package/public/components/SpeechBubble/SpeechBubble.d.ts +1 -0
  77. package/public/components/SpeechBubble/SpeechBubble.js +9 -2
  78. package/public/components/Svg/Svg.d.ts +3 -3
  79. package/public/components/Svg/Svg.js +1 -2
  80. package/public/components/Table/Table.d.ts +5 -2
  81. package/public/components/Table/Table.js +11 -4
  82. package/public/components/Table/TableCell.d.ts +1 -0
  83. package/public/components/Table/TableCell.js +4 -2
  84. package/public/components/Table/TableHeaderCell.d.ts +2 -1
  85. package/public/components/Table/TableHeaderCell.js +24 -7
  86. package/public/components/Table/index.d.ts +3 -0
  87. package/public/components/Tag/Tag.d.ts +2 -2
  88. package/public/components/Toast/Toast.d.ts +3 -3
  89. package/public/components/Toast/Toast.js +6 -2
  90. package/public/components/Tooltip/Tooltip.js +24 -31
  91. package/public/components/VisuallyHidden/VisuallyHidden.d.ts +2 -1
  92. package/public/components/VisuallyHidden/VisuallyHidden.js +3 -5
  93. package/public/css/styles.css +4542 -33010
  94. package/public/css/styles.min.css +1 -1
  95. package/public/css/styles.min.css.map +1 -1
  96. package/public/hooks/index.d.ts +3 -0
  97. package/public/hooks/index.js +7 -1
  98. package/public/hooks/useMatchMedia.d.ts +1 -0
  99. package/public/hooks/useMatchMedia.js +27 -0
  100. package/public/hooks/usePrefersReducedMotion.d.ts +1 -0
  101. package/public/hooks/usePrefersReducedMotion.js +9 -0
  102. package/public/hooks/useScreenOrientation.d.ts +1 -0
  103. package/public/hooks/useScreenOrientation.js +24 -0
  104. package/public/index.d.ts +0 -15
  105. package/public/index.js +0 -15
  106. package/public/src/style-dictionary/dist/tokens.css +378 -0
  107. package/public/src/style-dictionary/dist/tokens.d.ts +428 -0
  108. package/public/src/style-dictionary/dist/tokens.js +428 -0
  109. package/public/src/style-dictionary/dist/tokens.module.js +428 -0
  110. package/public/src/style-dictionary/tailwind.config.js +87 -0
  111. package/public/storybook-components/ComponentHeading.js +3 -5
  112. package/public/storybook-components/ComponentStatus.d.ts +1 -0
  113. package/public/storybook-components/ComponentStatus.js +4 -0
  114. package/public/storybook-components/EnumTable.js +2 -1
  115. package/public/storybook-components/Story.d.ts +2 -1
  116. package/public/storybook-components/Story.js +4 -1
  117. package/public/storybook-components/index.d.ts +1 -1
  118. package/public/storybook-components/index.js +1 -1
  119. package/public/style-dictionary/dist/tokens.d.ts +433 -0
  120. package/public/style-dictionary/dist/tokens.js +426 -0
  121. package/public/style-dictionary/dist/tokens.module.d.ts +431 -0
  122. package/public/style-dictionary/dist/tokens.module.js +424 -0
  123. package/public/style-dictionary/src/border-radius.d.ts +31 -0
  124. package/public/style-dictionary/src/border-radius.js +12 -0
  125. package/public/style-dictionary/src/border-width.d.ts +21 -0
  126. package/public/style-dictionary/src/border-width.js +11 -0
  127. package/public/style-dictionary/src/color.d.ts +249 -0
  128. package/public/style-dictionary/src/color.js +99 -0
  129. package/public/style-dictionary/src/font-size.d.ts +45 -0
  130. package/public/style-dictionary/src/font-size.js +16 -0
  131. package/public/style-dictionary/src/font-weight.d.ts +13 -0
  132. package/public/style-dictionary/src/font-weight.js +8 -0
  133. package/public/style-dictionary/src/height.d.ts +215 -0
  134. package/public/style-dictionary/src/height.js +13 -0
  135. package/public/style-dictionary/src/leading.d.ts +17 -0
  136. package/public/style-dictionary/src/leading.js +9 -0
  137. package/public/style-dictionary/src/screen-width.d.ts +17 -0
  138. package/public/style-dictionary/src/screen-width.js +9 -0
  139. package/public/style-dictionary/src/shadow.d.ts +63 -0
  140. package/public/style-dictionary/src/shadow.js +20 -0
  141. package/public/style-dictionary/src/spacing.d.ts +197 -0
  142. package/public/style-dictionary/src/spacing.js +70 -0
  143. package/public/style-dictionary/src/tracking.d.ts +13 -0
  144. package/public/style-dictionary/src/tracking.js +8 -0
  145. package/public/style-dictionary/src/type.d.ts +13 -0
  146. package/public/style-dictionary/src/type.js +35 -0
  147. package/public/style-dictionary/src/width.d.ts +287 -0
  148. package/public/style-dictionary/src/width.js +32 -0
  149. package/public/style-dictionary/src/z-index.d.ts +53 -0
  150. package/public/style-dictionary/src/z-index.js +22 -0
  151. package/public/style-dictionary/tailwind.config.d.ts +392 -0
  152. package/public/style-dictionary/tailwind.config.js +66 -0
  153. package/public/tokens/box-shadow.d.ts +1 -0
  154. package/public/tokens/box-shadow.js +1 -0
  155. package/public/tokens/font-family.js +1 -1
  156. package/public/tokens/height.d.ts +65 -43
  157. package/public/tokens/height.js +3 -44
  158. package/public/tokens/index.d.ts +526 -173
  159. package/public/tokens/index.js +1 -1
  160. package/public/tokens/margin.d.ts +129 -47
  161. package/public/tokens/margin.js +3 -47
  162. package/public/tokens/padding.d.ts +65 -24
  163. package/public/tokens/padding.js +2 -24
  164. package/public/tokens/sizing-scale.d.ts +133 -0
  165. package/public/tokens/sizing-scale.js +136 -0
  166. package/public/tokens/width.d.ts +197 -63
  167. package/public/tokens/width.js +6 -63
  168. package/public/types/index.d.ts +14 -6
  169. package/public/types/index.js +3 -10
  170. package/public/utilities/index.d.ts +1 -0
  171. package/public/utilities/index.js +3 -1
  172. package/public/utilities/mergeEventHandlers.d.ts +3 -0
  173. package/public/utilities/mergeEventHandlers.js +13 -0
  174. package/src/components/Accordion/Accordion.story.mdx +232 -22
  175. package/src/components/Accordion/Accordion.tsx +237 -114
  176. package/src/components/Accordion/context.ts +60 -0
  177. package/src/components/Accordion/index.css +0 -5
  178. package/src/components/Accordion/index.ts +1 -0
  179. package/src/components/Accordion/types.ts +55 -0
  180. package/src/components/Avatar/Avatar.story.mdx +60 -0
  181. package/src/components/Avatar/Avatar.tsx +20 -19
  182. package/src/components/Avatar/AvatarGroup.tsx +11 -9
  183. package/src/components/Avatar/index.css +8 -0
  184. package/src/components/Button/Button.story.mdx +116 -1
  185. package/src/components/Button/Button.tsx +13 -7
  186. package/src/components/Button/index.css +12 -1
  187. package/src/components/Button/product.css +12 -0
  188. package/src/components/Card/Card.story.mdx +56 -73
  189. package/src/components/CloseButton/CloseButton.tsx +1 -1
  190. package/src/components/ConveyorLogo/ConveyorLogo.tsx +7 -6
  191. package/src/components/Divider/Divider.tsx +26 -40
  192. package/src/components/Divider/index.css +16 -0
  193. package/src/components/Drawer/Drawer.story.mdx +68 -70
  194. package/src/components/Drawer/Drawer.tsx +9 -8
  195. package/src/components/Drawer/index.css +26 -1
  196. package/src/components/Flex/Flex.story.mdx +130 -0
  197. package/src/components/Flex/Flex.tsx +7 -6
  198. package/src/components/Flex/index.css +3 -0
  199. package/src/components/Frame/Frame.story.mdx +146 -6
  200. package/src/components/Frame/Frame.tsx +1 -1
  201. package/src/components/Frame/index.css +8 -13
  202. package/src/components/Grid/Grid.story.mdx +205 -3
  203. package/src/components/Grid/Grid.tsx +44 -5
  204. package/src/components/Grid/index.css +3 -0
  205. package/src/components/Icon/Icon.tsx +63 -5
  206. package/src/components/Icon/svg/ArrowToBottom.tsx +17 -0
  207. package/src/components/Icon/svg/CommentAltCheck.tsx +13 -0
  208. package/src/components/Icon/svg/index.ts +2 -0
  209. package/src/components/Input/Input.story.mdx +199 -13
  210. package/src/components/Input/Input.tsx +39 -6
  211. package/src/components/Input/brand.css +7 -7
  212. package/src/components/Input/index.css +30 -0
  213. package/src/components/Input/product.css +12 -48
  214. package/src/components/Loading/Loading.story.mdx +16 -9
  215. package/src/components/Loading/Loading.tsx +17 -8
  216. package/src/components/Loading/index.css +1 -67
  217. package/src/components/Markdown/Markdown.story.mdx +67 -0
  218. package/src/components/Markdown/Markdown.tsx +3 -2
  219. package/src/components/MarkdownEditor/MarkdownEditor.tsx +2 -3
  220. package/src/components/MarkdownEditor/MarkdownHelp.tsx +7 -10
  221. package/src/components/MarkdownEditor/index.css +5 -1
  222. package/src/components/Modal/Modal.story.mdx +26 -0
  223. package/src/components/Modal/Modal.tsx +61 -43
  224. package/src/components/Modal/context.ts +20 -0
  225. package/src/components/Modal/index.css +8 -3
  226. package/src/components/Modal/index.ts +1 -0
  227. package/src/components/OptionButton/OptionButton.story.mdx +175 -21
  228. package/src/components/OptionButton/OptionButton.tsx +215 -26
  229. package/src/components/OptionButton/context.ts +22 -0
  230. package/src/components/OptionButton/index.css +14 -2
  231. package/src/components/Overlay/Overlay.story.mdx +26 -0
  232. package/src/components/Overlay/Overlay.tsx +2 -3
  233. package/src/components/Overlay/index.css +1 -0
  234. package/src/components/Paragraph/Paragraph.story.mdx +16 -2
  235. package/src/components/Paragraph/Paragraph.tsx +5 -13
  236. package/src/components/Paragraph/index.css +6 -0
  237. package/src/components/Popover/index.css +5 -6
  238. package/src/components/Reference/Reference.tsx +2 -2
  239. package/src/components/Select/Select.story.mdx +23 -10
  240. package/src/components/Select/Select.tsx +35 -10
  241. package/src/components/Select/SelectPopover.tsx +6 -6
  242. package/src/components/Select/index.ts +14 -0
  243. package/src/components/Select/theme.ts +22 -22
  244. package/src/components/Snackbar/Snackbar.story.mdx +96 -9
  245. package/src/components/Snackbar/Snackbar.tsx +56 -145
  246. package/src/components/Snackbar/SnackbarProvider.tsx +31 -0
  247. package/src/components/Snackbar/constants.ts +2 -0
  248. package/src/components/Snackbar/context.ts +20 -0
  249. package/src/components/Snackbar/helpers.tsx +52 -0
  250. package/src/components/Snackbar/hooks.ts +57 -0
  251. package/src/components/Snackbar/index.ts +6 -0
  252. package/src/components/Snackbar/types.ts +180 -0
  253. package/src/components/SpeechBubble/SpeechBubble.story.mdx +76 -0
  254. package/src/components/SpeechBubble/SpeechBubble.tsx +22 -1
  255. package/src/components/SpeechBubble/index.css +7 -4
  256. package/src/components/Svg/Svg.story.mdx +36 -0
  257. package/src/components/Svg/Svg.tsx +6 -4
  258. package/src/components/Table/Table.story.mdx +243 -0
  259. package/src/components/Table/Table.tsx +36 -1
  260. package/src/components/Table/TableCell.tsx +24 -1
  261. package/src/components/Table/TableHeaderCell.tsx +64 -11
  262. package/src/components/Table/index.css +138 -10
  263. package/src/components/Table/index.ts +3 -0
  264. package/src/components/Tag/Tag.tsx +2 -2
  265. package/src/components/Text/Text.story.mdx +34 -0
  266. package/src/components/Toast/Toast.story.mdx +1 -1
  267. package/src/components/Toast/Toast.tsx +14 -10
  268. package/src/components/Toast/index.css +4 -2
  269. package/src/components/Toggle/index.css +2 -3
  270. package/src/components/Tooltip/Tooltip.story.mdx +71 -1
  271. package/src/components/Tooltip/Tooltip.tsx +40 -35
  272. package/src/components/Tooltip/index.css +31 -0
  273. package/src/components/VisuallyHidden/VisuallyHidden.story.mdx +54 -0
  274. package/src/components/VisuallyHidden/VisuallyHidden.tsx +10 -5
  275. package/src/components/VisuallyHidden/index.css +3 -0
  276. package/src/css/base.css +6 -561
  277. package/src/css/components.css +6 -9
  278. package/src/css/fonts.css +13 -10
  279. package/src/css/styles.css +0 -1
  280. package/src/css/utilities/animations.css +13 -0
  281. package/src/docs/Colors.story.mdx +13 -13
  282. package/src/docs/Spacing.story.mdx +4 -20
  283. package/src/docs/Tokens.story.mdx +230 -0
  284. package/src/docs/Typography.story.mdx +27 -101
  285. package/src/docs/hooks/useDisclosureHook.story.mdx +58 -0
  286. package/src/docs/hooks/useKeyPressHook.story.mdx +54 -0
  287. package/src/docs/hooks/useMatchMediaHook.story.mdx +42 -0
  288. package/src/docs/hooks/useOutsideClickHook.story.mdx +56 -0
  289. package/src/docs/hooks/usePrefersReducedMotion.story.mdx +61 -0
  290. package/src/docs/hooks/useScreenOrientationHook.story.mdx +56 -0
  291. package/src/docs/hooks/useStepHook.story.mdx +102 -0
  292. package/src/hooks/index.ts +3 -0
  293. package/src/hooks/useMatchMedia.ts +40 -0
  294. package/src/hooks/usePrefersReducedMotion.ts +9 -0
  295. package/src/hooks/useScreenOrientation.ts +27 -0
  296. package/src/index.ts +0 -15
  297. package/src/storybook-components/ComponentHeading.tsx +4 -19
  298. package/src/storybook-components/ComponentStatus.tsx +4 -0
  299. package/src/storybook-components/EnumTable.tsx +3 -2
  300. package/src/storybook-components/Story.tsx +13 -1
  301. package/src/storybook-components/index.tsx +1 -1
  302. package/src/style-dictionary/dist/tokens.css +378 -0
  303. package/src/style-dictionary/dist/tokens.d.ts +428 -0
  304. package/src/style-dictionary/dist/tokens.js +428 -0
  305. package/src/style-dictionary/dist/tokens.module.js +428 -0
  306. package/src/style-dictionary/src/border-radius.js +11 -0
  307. package/src/style-dictionary/src/border-width.js +10 -0
  308. package/src/style-dictionary/src/color.js +98 -0
  309. package/src/style-dictionary/src/font-size.js +15 -0
  310. package/src/style-dictionary/src/font-weight.js +7 -0
  311. package/src/style-dictionary/src/height.js +13 -0
  312. package/src/style-dictionary/src/leading.js +8 -0
  313. package/src/style-dictionary/src/screen-width.js +8 -0
  314. package/src/style-dictionary/src/shadow.js +19 -0
  315. package/src/style-dictionary/src/spacing.js +69 -0
  316. package/src/style-dictionary/src/tracking.js +7 -0
  317. package/src/style-dictionary/src/type.js +34 -0
  318. package/src/style-dictionary/src/width.js +32 -0
  319. package/src/style-dictionary/src/z-index.js +21 -0
  320. package/src/style-dictionary/tailwind.config.js +87 -0
  321. package/src/tokens/borders.ts +6 -0
  322. package/src/tokens/box-shadow.ts +4 -0
  323. package/src/tokens/colors.ts +6 -0
  324. package/src/tokens/font-family.ts +4 -1
  325. package/src/tokens/font-size.ts +3 -0
  326. package/src/tokens/font-weight.ts +3 -0
  327. package/src/tokens/height.ts +6 -44
  328. package/src/tokens/index.ts +5 -4
  329. package/src/tokens/letter-spacing.ts +3 -0
  330. package/src/tokens/line-height.ts +3 -0
  331. package/src/tokens/margin.ts +7 -47
  332. package/src/tokens/padding.ts +6 -24
  333. package/src/tokens/screens.ts +3 -0
  334. package/src/tokens/sizing-scale.ts +140 -0
  335. package/src/tokens/width.ts +16 -63
  336. package/src/tokens/will-change.ts +3 -0
  337. package/src/tokens/z-index.ts +3 -0
  338. package/src/types/index.ts +37 -10
  339. package/src/utilities/index.ts +1 -0
  340. package/src/utilities/mergeEventHandlers.ts +20 -0
  341. package/public/components/Absolute/Absolute.d.ts +0 -2
  342. package/public/components/Absolute/Absolute.js +0 -14
  343. package/public/components/Absolute/index.d.ts +0 -1
  344. package/public/components/Absolute/index.js +0 -5
  345. package/public/components/Appbar/Appbar.d.ts +0 -60
  346. package/public/components/Appbar/Appbar.js +0 -42
  347. package/public/components/Appbar/AppbarClaimProfileButton.d.ts +0 -2
  348. package/public/components/Appbar/AppbarClaimProfileButton.js +0 -10
  349. package/public/components/Appbar/AppbarDropdownIcon.d.ts +0 -1
  350. package/public/components/Appbar/AppbarDropdownIcon.js +0 -10
  351. package/public/components/Appbar/AppbarLogInButton.d.ts +0 -2
  352. package/public/components/Appbar/AppbarLogInButton.js +0 -26
  353. package/public/components/Appbar/AppbarLogo.d.ts +0 -2
  354. package/public/components/Appbar/AppbarLogo.js +0 -19
  355. package/public/components/Appbar/AppbarOrganization.d.ts +0 -17
  356. package/public/components/Appbar/AppbarOrganization.js +0 -35
  357. package/public/components/Appbar/AppbarTabMarker.d.ts +0 -1
  358. package/public/components/Appbar/AppbarTabMarker.js +0 -11
  359. package/public/components/Appbar/AppbarTabs.d.ts +0 -10
  360. package/public/components/Appbar/AppbarTabs.js +0 -42
  361. package/public/components/Appbar/AppbarUser.d.ts +0 -27
  362. package/public/components/Appbar/AppbarUser.js +0 -76
  363. package/public/components/Appbar/config.d.ts +0 -7
  364. package/public/components/Appbar/config.js +0 -13
  365. package/public/components/Appbar/context.d.ts +0 -10
  366. package/public/components/Appbar/context.js +0 -16
  367. package/public/components/Appbar/index.d.ts +0 -1
  368. package/public/components/Appbar/index.js +0 -13
  369. package/public/components/ArrowButton/ArrowButton.d.ts +0 -9
  370. package/public/components/ArrowButton/ArrowButton.js +0 -22
  371. package/public/components/ArrowButton/index.d.ts +0 -1
  372. package/public/components/ArrowButton/index.js +0 -13
  373. package/public/components/ArrowLink/ArrowLink.d.ts +0 -9
  374. package/public/components/ArrowLink/ArrowLink.js +0 -21
  375. package/public/components/ArrowLink/index.d.ts +0 -1
  376. package/public/components/ArrowLink/index.js +0 -13
  377. package/public/components/Aside/Aside.d.ts +0 -14
  378. package/public/components/Aside/Aside.js +0 -28
  379. package/public/components/Aside/index.d.ts +0 -1
  380. package/public/components/Aside/index.js +0 -13
  381. package/public/components/Fixed/Fixed.d.ts +0 -2
  382. package/public/components/Fixed/Fixed.js +0 -14
  383. package/public/components/Fixed/Fixed.story.d.ts +0 -1
  384. package/public/components/Fixed/Fixed.story.js +0 -12
  385. package/public/components/Fixed/index.d.ts +0 -1
  386. package/public/components/Fixed/index.js +0 -5
  387. package/public/components/Flex/Flex.story.d.ts +0 -1
  388. package/public/components/Flex/Flex.story.js +0 -12
  389. package/public/components/IntegrationLogo/IntegrationLogo.d.ts +0 -10
  390. package/public/components/IntegrationLogo/IntegrationLogo.js +0 -33
  391. package/public/components/IntegrationLogo/IntegrationLogoSvg.d.ts +0 -9
  392. package/public/components/IntegrationLogo/IntegrationLogoSvg.js +0 -52
  393. package/public/components/IntegrationLogo/index.d.ts +0 -1
  394. package/public/components/IntegrationLogo/index.js +0 -13
  395. package/public/components/IntegrationLogo/svg/addigy.d.ts +0 -2
  396. package/public/components/IntegrationLogo/svg/addigy.js +0 -17
  397. package/public/components/IntegrationLogo/svg/aws.d.ts +0 -2
  398. package/public/components/IntegrationLogo/svg/aws.js +0 -22
  399. package/public/components/IntegrationLogo/svg/bamboohr.d.ts +0 -2
  400. package/public/components/IntegrationLogo/svg/bamboohr.js +0 -18
  401. package/public/components/IntegrationLogo/svg/bitbucket.d.ts +0 -2
  402. package/public/components/IntegrationLogo/svg/bitbucket.js +0 -18
  403. package/public/components/IntegrationLogo/svg/conveyor.d.ts +0 -2
  404. package/public/components/IntegrationLogo/svg/conveyor.js +0 -20
  405. package/public/components/IntegrationLogo/svg/default.d.ts +0 -2
  406. package/public/components/IntegrationLogo/svg/default.js +0 -13
  407. package/public/components/IntegrationLogo/svg/deploy.d.ts +0 -2
  408. package/public/components/IntegrationLogo/svg/deploy.js +0 -17
  409. package/public/components/IntegrationLogo/svg/events-api.d.ts +0 -2
  410. package/public/components/IntegrationLogo/svg/events-api.js +0 -26
  411. package/public/components/IntegrationLogo/svg/gcp.d.ts +0 -3
  412. package/public/components/IntegrationLogo/svg/gcp.js +0 -15
  413. package/public/components/IntegrationLogo/svg/github.d.ts +0 -3
  414. package/public/components/IntegrationLogo/svg/github.js +0 -12
  415. package/public/components/IntegrationLogo/svg/gitlab.d.ts +0 -2
  416. package/public/components/IntegrationLogo/svg/gitlab.js +0 -19
  417. package/public/components/IntegrationLogo/svg/gsuite.d.ts +0 -2
  418. package/public/components/IntegrationLogo/svg/gsuite.js +0 -15
  419. package/public/components/IntegrationLogo/svg/index.d.ts +0 -21
  420. package/public/components/IntegrationLogo/svg/index.js +0 -54
  421. package/public/components/IntegrationLogo/svg/jamf.d.ts +0 -2
  422. package/public/components/IntegrationLogo/svg/jamf.js +0 -20
  423. package/public/components/IntegrationLogo/svg/jira.d.ts +0 -2
  424. package/public/components/IntegrationLogo/svg/jira.js +0 -21
  425. package/public/components/IntegrationLogo/svg/jumpcloud.d.ts +0 -2
  426. package/public/components/IntegrationLogo/svg/jumpcloud.js +0 -28
  427. package/public/components/IntegrationLogo/svg/okta.d.ts +0 -2
  428. package/public/components/IntegrationLogo/svg/okta.js +0 -16
  429. package/public/components/IntegrationLogo/svg/onelogin.d.ts +0 -2
  430. package/public/components/IntegrationLogo/svg/onelogin.js +0 -18
  431. package/public/components/IntegrationLogo/svg/salesforce.d.ts +0 -2
  432. package/public/components/IntegrationLogo/svg/salesforce.js +0 -20
  433. package/public/components/IntegrationLogo/svg/slack.d.ts +0 -2
  434. package/public/components/IntegrationLogo/svg/slack.js +0 -19
  435. package/public/components/IntegrationLogo/svg/wrapper.d.ts +0 -11
  436. package/public/components/IntegrationLogo/svg/wrapper.js +0 -13
  437. package/public/components/IntegrationLogo/svg/zoom.d.ts +0 -2
  438. package/public/components/IntegrationLogo/svg/zoom.js +0 -23
  439. package/public/components/Meta/Meta.d.ts +0 -6
  440. package/public/components/Meta/Meta.js +0 -21
  441. package/public/components/Meta/Meta.story.d.ts +0 -1
  442. package/public/components/Meta/Meta.story.js +0 -39
  443. package/public/components/Meta/index.d.ts +0 -1
  444. package/public/components/Meta/index.js +0 -5
  445. package/public/components/Overlay/Overlay.story.d.ts +0 -1
  446. package/public/components/Overlay/Overlay.story.js +0 -12
  447. package/public/components/PropertyDiff/PropertyDiff.d.ts +0 -7
  448. package/public/components/PropertyDiff/PropertyDiff.js +0 -22
  449. package/public/components/PropertyDiff/index.d.ts +0 -1
  450. package/public/components/PropertyDiff/index.js +0 -13
  451. package/public/components/Relative/Relative.d.ts +0 -2
  452. package/public/components/Relative/Relative.js +0 -14
  453. package/public/components/Relative/Relative.story.d.ts +0 -1
  454. package/public/components/Relative/Relative.story.js +0 -12
  455. package/public/components/Relative/index.d.ts +0 -1
  456. package/public/components/Relative/index.js +0 -5
  457. package/public/components/SpeechBubble/SpeechBubble.story.d.ts +0 -1
  458. package/public/components/SpeechBubble/SpeechBubble.story.js +0 -19
  459. package/public/components/StatusLabel/StatusLabel.d.ts +0 -16
  460. package/public/components/StatusLabel/StatusLabel.js +0 -40
  461. package/public/components/StatusLabel/index.d.ts +0 -1
  462. package/public/components/StatusLabel/index.js +0 -13
  463. package/public/components/StatusPanel/StatusPanel.d.ts +0 -11
  464. package/public/components/StatusPanel/StatusPanel.js +0 -24
  465. package/public/components/StatusPanel/index.d.ts +0 -1
  466. package/public/components/StatusPanel/index.js +0 -13
  467. package/public/components/Sticky/Sticky.d.ts +0 -2
  468. package/public/components/Sticky/Sticky.js +0 -14
  469. package/public/components/Sticky/Sticky.story.d.ts +0 -1
  470. package/public/components/Sticky/Sticky.story.js +0 -12
  471. package/public/components/Sticky/index.d.ts +0 -1
  472. package/public/components/Sticky/index.js +0 -5
  473. package/public/components/Svg/Svg.story.d.ts +0 -1
  474. package/public/components/Svg/Svg.story.js +0 -14
  475. package/public/components/Text/Text.story.d.ts +0 -1
  476. package/public/components/Text/Text.story.js +0 -31
  477. package/public/components/TopBar/TopBar.d.ts +0 -14
  478. package/public/components/TopBar/TopBar.js +0 -24
  479. package/public/components/TopBar/TopBarBreadcrumbs.d.ts +0 -10
  480. package/public/components/TopBar/TopBarBreadcrumbs.js +0 -34
  481. package/public/components/TopBar/TopBarSubNav.d.ts +0 -2
  482. package/public/components/TopBar/TopBarSubNav.js +0 -16
  483. package/public/components/TopBar/TopBarSubNavItem.d.ts +0 -5
  484. package/public/components/TopBar/TopBarSubNavItem.js +0 -17
  485. package/public/components/TopBar/index.d.ts +0 -1
  486. package/public/components/TopBar/index.js +0 -13
  487. package/public/components/VendorLogo/VendorLogo.d.ts +0 -20
  488. package/public/components/VendorLogo/VendorLogo.js +0 -57
  489. package/public/components/VendorLogo/index.d.ts +0 -1
  490. package/public/components/VendorLogo/index.js +0 -13
  491. package/public/components/VisuallyHidden/VisuallyHidden.story.d.ts +0 -1
  492. package/public/components/VisuallyHidden/VisuallyHidden.story.js +0 -36
  493. package/public/components/useStep/ExampleSetupWizard.d.ts +0 -4
  494. package/public/components/useStep/ExampleSetupWizard.js +0 -33
  495. package/public/storybook-components/TailwindPropertyClasses.d.ts +0 -9
  496. package/public/storybook-components/TailwindPropertyClasses.js +0 -194
  497. package/public/tailwind.config.d.ts +0 -1
  498. package/public/tailwind.config.js +0 -4
  499. package/public/tokens/_tailwind-config.d.ts +0 -810
  500. package/public/tokens/_tailwind-config.js +0 -50
  501. package/src/components/Absolute/Absolute.story.mdx +0 -26
  502. package/src/components/Absolute/Absolute.tsx +0 -9
  503. package/src/components/Absolute/index.ts +0 -1
  504. package/src/components/Appbar/Appbar.story.mdx +0 -185
  505. package/src/components/Appbar/Appbar.tsx +0 -108
  506. package/src/components/Appbar/AppbarClaimProfileButton.tsx +0 -13
  507. package/src/components/Appbar/AppbarDropdownIcon.tsx +0 -6
  508. package/src/components/Appbar/AppbarLogInButton.tsx +0 -28
  509. package/src/components/Appbar/AppbarLogo.tsx +0 -29
  510. package/src/components/Appbar/AppbarOrganization.tsx +0 -96
  511. package/src/components/Appbar/AppbarTabMarker.tsx +0 -5
  512. package/src/components/Appbar/AppbarTabs.tsx +0 -46
  513. package/src/components/Appbar/AppbarUser.tsx +0 -179
  514. package/src/components/Appbar/config.ts +0 -12
  515. package/src/components/Appbar/context.ts +0 -20
  516. package/src/components/Appbar/index.css +0 -324
  517. package/src/components/Appbar/index.ts +0 -1
  518. package/src/components/ArrowButton/ArrowButton.story.mdx +0 -110
  519. package/src/components/ArrowButton/ArrowButton.tsx +0 -54
  520. package/src/components/ArrowButton/index.css +0 -42
  521. package/src/components/ArrowButton/index.ts +0 -1
  522. package/src/components/ArrowLink/ArrowLink.story.mdx +0 -65
  523. package/src/components/ArrowLink/ArrowLink.tsx +0 -42
  524. package/src/components/ArrowLink/index.ts +0 -1
  525. package/src/components/Aside/Aside.story.mdx +0 -65
  526. package/src/components/Aside/Aside.tsx +0 -59
  527. package/src/components/Aside/index.css +0 -11
  528. package/src/components/Aside/index.ts +0 -1
  529. package/src/components/Fixed/Fixed.md +0 -16
  530. package/src/components/Fixed/Fixed.story.tsx +0 -12
  531. package/src/components/Fixed/Fixed.tsx +0 -9
  532. package/src/components/Fixed/index.ts +0 -1
  533. package/src/components/Flex/Flex.md +0 -14
  534. package/src/components/Flex/Flex.story.tsx +0 -12
  535. package/src/components/IntegrationLogo/IntegrationLogo.story.mdx +0 -159
  536. package/src/components/IntegrationLogo/IntegrationLogo.tsx +0 -54
  537. package/src/components/IntegrationLogo/IntegrationLogoSvg.tsx +0 -79
  538. package/src/components/IntegrationLogo/index.ts +0 -1
  539. package/src/components/IntegrationLogo/svg/addigy.tsx +0 -23
  540. package/src/components/IntegrationLogo/svg/aws.tsx +0 -52
  541. package/src/components/IntegrationLogo/svg/bamboohr.tsx +0 -34
  542. package/src/components/IntegrationLogo/svg/bitbucket.tsx +0 -37
  543. package/src/components/IntegrationLogo/svg/conveyor.tsx +0 -41
  544. package/src/components/IntegrationLogo/svg/default.tsx +0 -11
  545. package/src/components/IntegrationLogo/svg/deploy.tsx +0 -29
  546. package/src/components/IntegrationLogo/svg/events-api.tsx +0 -75
  547. package/src/components/IntegrationLogo/svg/gcp.tsx +0 -26
  548. package/src/components/IntegrationLogo/svg/github.tsx +0 -14
  549. package/src/components/IntegrationLogo/svg/gitlab.tsx +0 -40
  550. package/src/components/IntegrationLogo/svg/gsuite.tsx +0 -24
  551. package/src/components/IntegrationLogo/svg/index.ts +0 -21
  552. package/src/components/IntegrationLogo/svg/jamf.tsx +0 -36
  553. package/src/components/IntegrationLogo/svg/jira.tsx +0 -44
  554. package/src/components/IntegrationLogo/svg/jumpcloud.tsx +0 -86
  555. package/src/components/IntegrationLogo/svg/okta.tsx +0 -28
  556. package/src/components/IntegrationLogo/svg/onelogin.tsx +0 -34
  557. package/src/components/IntegrationLogo/svg/salesforce.tsx +0 -39
  558. package/src/components/IntegrationLogo/svg/slack.tsx +0 -40
  559. package/src/components/IntegrationLogo/svg/wrapper.tsx +0 -35
  560. package/src/components/IntegrationLogo/svg/zoom.tsx +0 -51
  561. package/src/components/Meta/Meta.md +0 -14
  562. package/src/components/Meta/Meta.story.tsx +0 -24
  563. package/src/components/Meta/Meta.tsx +0 -26
  564. package/src/components/Meta/index.ts +0 -1
  565. package/src/components/Overlay/Overlay.md +0 -14
  566. package/src/components/Overlay/Overlay.story.tsx +0 -12
  567. package/src/components/PropertyDiff/PropertDiff.story.mdx +0 -46
  568. package/src/components/PropertyDiff/PropertyDiff.tsx +0 -48
  569. package/src/components/PropertyDiff/index.css +0 -33
  570. package/src/components/PropertyDiff/index.ts +0 -1
  571. package/src/components/Relative/Relative.md +0 -16
  572. package/src/components/Relative/Relative.story.tsx +0 -12
  573. package/src/components/Relative/Relative.tsx +0 -9
  574. package/src/components/Relative/index.ts +0 -1
  575. package/src/components/SpeechBubble/SpeechBubble.md +0 -14
  576. package/src/components/SpeechBubble/SpeechBubble.story.tsx +0 -26
  577. package/src/components/StatusLabel/StatusLabel.story.mdx +0 -316
  578. package/src/components/StatusLabel/StatusLabel.tsx +0 -112
  579. package/src/components/StatusLabel/index.css +0 -23
  580. package/src/components/StatusLabel/index.ts +0 -1
  581. package/src/components/StatusPanel/StatusPanel.story.mdx +0 -109
  582. package/src/components/StatusPanel/StatusPanel.tsx +0 -51
  583. package/src/components/StatusPanel/index.css +0 -52
  584. package/src/components/StatusPanel/index.ts +0 -1
  585. package/src/components/Sticky/Sticky.md +0 -16
  586. package/src/components/Sticky/Sticky.story.tsx +0 -12
  587. package/src/components/Sticky/Sticky.tsx +0 -9
  588. package/src/components/Sticky/index.ts +0 -1
  589. package/src/components/Svg/Svg.md +0 -14
  590. package/src/components/Svg/Svg.story.tsx +0 -15
  591. package/src/components/Text/Text.md +0 -14
  592. package/src/components/Text/Text.story.tsx +0 -12
  593. package/src/components/TopBar/TopBar.story.mdx +0 -154
  594. package/src/components/TopBar/TopBar.tsx +0 -40
  595. package/src/components/TopBar/TopBarBreadcrumbs.tsx +0 -79
  596. package/src/components/TopBar/TopBarSubNav.tsx +0 -19
  597. package/src/components/TopBar/TopBarSubNavItem.tsx +0 -21
  598. package/src/components/TopBar/index.css +0 -102
  599. package/src/components/TopBar/index.ts +0 -1
  600. package/src/components/VendorLogo/VendorLogo.story.mdx +0 -209
  601. package/src/components/VendorLogo/VendorLogo.tsx +0 -110
  602. package/src/components/VendorLogo/index.css +0 -46
  603. package/src/components/VendorLogo/index.ts +0 -1
  604. package/src/components/VisuallyHidden/VisuallyHidden.md +0 -23
  605. package/src/components/VisuallyHidden/VisuallyHidden.story.tsx +0 -19
  606. package/src/components/useStep/ExampleSetupWizard.tsx +0 -63
  607. package/src/components/useStep/useStep.story.mdx +0 -76
  608. package/src/docs/TailwindClasses.story.mdx +0 -15
  609. package/src/docs/brand-components/BrandButton.story.mdx +0 -103
  610. package/src/docs/brand-components/BrandCheckbox.story.mdx +0 -63
  611. package/src/docs/brand-components/BrandFormGroup.story.mdx +0 -76
  612. package/src/docs/brand-components/BrandInput.story.mdx +0 -41
  613. package/src/docs/brand-components/BrandRadio.story.mdx +0 -45
  614. package/src/docs/brand-components/BrandTextArea.story.mdx +0 -41
  615. package/src/storybook-components/TailwindPropertyClasses.tsx +0 -285
  616. package/src/tailwind.config.ts +0 -6
  617. package/src/tokens/_tailwind-config.ts +0 -69
@@ -1,82 +1,190 @@
1
- import React, { ReactNode, useCallback, useRef, useState } from "react";
1
+ import React from "react";
2
2
  import classNames from "classnames";
3
3
  import { Transition } from "react-spring/renderprops";
4
4
  import useComponentSize from "@rehooks/component-size";
5
5
  import { useId } from "@reach/auto-id";
6
+ import mergeRefs from "react-merge-refs";
7
+
8
+ import { bemHOF } from "../../utilities";
9
+ import { useDisclosure } from "../../hooks";
10
+ import { ORIENTATION } from "../../types";
6
11
 
7
12
  import { BoxProps, Box } from "../Box";
8
13
  import { Flex } from "../Flex";
14
+ import { Stack, StackProps } from "../Stack";
9
15
  import { Heading } from "../Heading";
10
16
  import { Icon, ICON_TYPE } from "../Icon";
11
- import { bemHOF } from "../../utilities/bem";
12
- import { useDisclosure } from "../../hooks";
17
+
18
+ import type {
19
+ AccordionOwnProps,
20
+ AccordionItemOwnProps,
21
+ AccordionDisclosureProps,
22
+ AccordionGroupOwnProps,
23
+ } from "./types";
24
+ import {
25
+ AccordionItemContext,
26
+ useAccordionItemContext,
27
+ AccordionGroupContext,
28
+ useAccordionGroupContext,
29
+ } from "./context";
13
30
 
14
31
  const cn = bemHOF("Accordion");
15
32
 
16
- export interface AccordionProps extends BoxProps {
17
- /**
18
- * The displayed text of the `Accordion` when closed
19
- */
20
- title: string;
33
+ /**
34
+ * Accordion.Group
35
+ * =============================================================================
36
+ */
37
+ export type AccordionGroupProps = AccordionGroupOwnProps &
38
+ Pick<StackProps, "children" | "spacing">;
21
39
 
22
- /**
23
- * If true, this shows a green indicator next to the title
24
- */
25
- isActive?: boolean;
40
+ export const AccordionGroup = ({
41
+ children,
42
+ spacing = 0,
43
+ defaultValue,
44
+ ...rest
45
+ }: AccordionGroupProps) => {
46
+ return (
47
+ <AccordionGroupContext.Provider value={{ defaultValue }}>
48
+ <Stack orientation={ORIENTATION.VERTICAL} spacing={spacing} {...rest}>
49
+ {children}
50
+ </Stack>
51
+ </AccordionGroupContext.Provider>
52
+ );
53
+ };
26
54
 
27
- /**
28
- * CSS value to define a max height of the opened Accordion content.
29
- * If the children exceed the height of the container, it will scroll.
30
- */
31
- maxHeight?: string;
55
+ /**
56
+ * Accordion.Item
57
+ * =============================================================================
58
+ */
59
+ export type AccordionItemProps = AccordionItemOwnProps & BoxProps;
32
60
 
33
- /**
34
- * Whether or not the accordion item is open / visible.
35
- */
36
- defaultIsOpen?: boolean;
61
+ export const AccordionItem = ({
62
+ value,
63
+ defaultIsOpen: defaultIsOpenProp,
64
+ children,
65
+ className,
66
+ ...rest
67
+ }: AccordionItemProps) => {
68
+ const { defaultValue } = useAccordionGroupContext();
37
69
 
38
70
  /**
39
- * Add an icon or integration logo to the left of the header title
71
+ * To remain backwards compatible with the `defaultIsOpen` prop, we need to
72
+ * perform an extra conditional check to determine if `defaultIsOpenProp`
73
+ * has been defined.
40
74
  */
41
- iconSlot?: ReactNode;
75
+ const hasDefaultValue =
76
+ typeof defaultValue === "undefined" ? false : defaultValue === value;
77
+ const defaultIsOpen =
78
+ typeof defaultIsOpenProp === "undefined"
79
+ ? hasDefaultValue
80
+ : defaultIsOpenProp;
42
81
 
43
- /**
44
- * Removes padding from the Accordion's content
45
- */
46
- removePadding?: ReactNode;
47
- }
82
+ const { isOpen, onToggle } = useDisclosure(defaultIsOpen);
83
+ const id = `accordion-${useId()}`;
84
+ const buttonId = `${id}-button`;
85
+ const contentId = `${id}-content`;
48
86
 
49
- export const AccordionGroup = ({
50
- children,
51
- className,
52
- ...rest
53
- }: {
54
- children: ReactNode;
87
+ return (
88
+ <AccordionItemContext.Provider
89
+ value={{
90
+ defaultIsOpen,
91
+ isOpen,
92
+ onToggle,
93
+ buttonId,
94
+ contentId,
95
+ }}
96
+ >
97
+ <Box
98
+ data-component="accordion"
99
+ className={classNames(cn(), className, {
100
+ [cn({ m: "isOpen" })]: isOpen,
101
+ })}
102
+ {...rest}
103
+ >
104
+ {children}
105
+ </Box>
106
+ </AccordionItemContext.Provider>
107
+ );
108
+ };
109
+
110
+ /**
111
+ * Accordion.Button
112
+ * =============================================================================
113
+ */
114
+ type AccordionButtonChildProps = Omit<AccordionDisclosureProps, "onToggle">;
115
+ type AccordionButtonChildFunction = {
116
+ children(props: AccordionButtonChildProps): React.ReactNode;
117
+ };
118
+ type AccordionButtonOwnProps =
119
+ | AccordionButtonChildFunction
120
+ | { children: React.ReactNode };
121
+
122
+ export type AccordionButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement> &
123
+ AccordionButtonOwnProps;
124
+
125
+ export const AccordionButton = React.forwardRef<
126
+ HTMLButtonElement,
127
+ AccordionButtonProps
128
+ >((props, forwardedRef) => {
129
+ const { children, className, onClick, disabled = false, ...rest } = props;
130
+ const { buttonId, contentId, isOpen, onToggle } = useAccordionItemContext();
131
+ const buttonRef = React.useRef<HTMLButtonElement>(null);
132
+ const ref = mergeRefs<HTMLButtonElement>([forwardedRef, buttonRef]);
133
+
134
+ return (
135
+ <button
136
+ ref={ref}
137
+ type="button"
138
+ className={className}
139
+ id={buttonId}
140
+ aria-controls={contentId}
141
+ aria-expanded={isOpen}
142
+ aria-disabled={disabled}
143
+ disabled={disabled}
144
+ onClick={(event: React.MouseEvent<HTMLButtonElement>) => {
145
+ if (onClick) {
146
+ onClick(event);
147
+ }
148
+ if (onToggle) {
149
+ onToggle();
150
+ }
151
+ }}
152
+ {...rest}
153
+ >
154
+ {typeof children === "function" ? children({ isOpen }) : children}
155
+ </button>
156
+ );
157
+ });
158
+
159
+ /**
160
+ * Accordion.Content
161
+ * =============================================================================
162
+ */
163
+ export type AccordionContentProps = {
164
+ children: React.ReactNode;
165
+ maxHeight?: string;
166
+ style?: React.CSSProperties;
55
167
  className?: string;
56
- }) => (
57
- <Flex className={classNames("flex-col", className)} {...rest}>
58
- {children}
59
- </Flex>
60
- );
61
-
62
- export const Accordion = ({
63
- title,
64
- isActive,
65
- maxHeight,
168
+ };
169
+
170
+ export const AccordionContent = ({
66
171
  children,
67
- defaultIsOpen = false,
68
- iconSlot,
172
+ maxHeight,
173
+ style,
69
174
  className,
70
- removePadding,
71
175
  ...rest
72
- }: AccordionProps) => {
73
- const { isOpen, onToggle } = useDisclosure(defaultIsOpen);
74
- const buttonRef = useRef<HTMLButtonElement>(null);
75
-
76
- const [childrenRef, setChildrenRef] = useState<
176
+ }: AccordionContentProps) => {
177
+ const {
178
+ buttonId,
179
+ contentId,
180
+ defaultIsOpen,
181
+ isOpen,
182
+ } = useAccordionItemContext();
183
+ const [childrenRef, setChildrenRef] = React.useState<
77
184
  React.MutableRefObject<null | HTMLDivElement>
78
185
  >({ current: null });
79
- const onRefChange = useCallback((node) => {
186
+
187
+ const onRefChange = React.useCallback((node) => {
80
188
  if (node !== null) {
81
189
  setChildrenRef({ current: node });
82
190
  }
@@ -85,38 +193,75 @@ export const Accordion = ({
85
193
  const { height } = useComponentSize(childrenRef);
86
194
  const heightObj = { height };
87
195
 
88
- const id = `accordion:${useId()}`;
89
- const buttonId = `${id}-button`;
90
- const contentId = `${id}-content`;
196
+ const [enableTransition, setEnableTransition] = React.useState(
197
+ !defaultIsOpen,
198
+ );
199
+
200
+ return (
201
+ <Transition
202
+ items={isOpen}
203
+ from={{ height: 0 }}
204
+ enter={{ height }}
205
+ leave={{ height: 0 }}
206
+ update={heightObj}
207
+ onRest={() => {
208
+ if (defaultIsOpen && isOpen) {
209
+ setEnableTransition(true);
210
+ }
211
+ }}
212
+ immediate={!enableTransition}
213
+ >
214
+ {(show) =>
215
+ show
216
+ ? (styles: React.CSSProperties) => (
217
+ <Box
218
+ className={classNames("overflow-hidden box-content", className)}
219
+ style={{ ...styles, ...style }}
220
+ aria-labelledby={buttonId}
221
+ id={contentId}
222
+ role="region"
223
+ {...rest}
224
+ >
225
+ <Box
226
+ ref={onRefChange}
227
+ className={classNames(maxHeight && "overflow-y-auto")}
228
+ style={maxHeight ? { maxHeight } : undefined}
229
+ >
230
+ {children}
231
+ </Box>
232
+ </Box>
233
+ )
234
+ : null
235
+ }
236
+ </Transition>
237
+ );
238
+ };
91
239
 
92
- const [enableTransition, setEnableTransition] = useState(!defaultIsOpen);
240
+ /**
241
+ * Accordion
242
+ * =============================================================================
243
+ */
244
+ export type AccordionProps = AccordionOwnProps & BoxProps;
93
245
 
94
- const handleItemClick = () => {
95
- if (isOpen && buttonRef.current !== null) {
96
- buttonRef.current.blur();
97
- }
98
- onToggle();
99
- };
246
+ export const Accordion = (props: AccordionProps) => {
247
+ const {
248
+ title,
249
+ isActive,
250
+ maxHeight,
251
+ children,
252
+ iconSlot,
253
+ className,
254
+ removePadding,
255
+ ...rest
256
+ } = props;
100
257
 
101
258
  return (
102
- <Box
103
- className={classNames(cn(), className, {
104
- [cn({ m: "isOpen" })]: isOpen,
105
- })}
106
- {...rest}
107
- >
259
+ <AccordionItem className={className} {...rest}>
108
260
  <Heading.H5>
109
- <button
110
- type="button"
111
- onClick={handleItemClick}
261
+ <AccordionButton
112
262
  className={classNames(cn({ e: "button" }), {
113
263
  [cn({ e: "button", m: "isActive" })]: isActive,
114
264
  })}
115
- ref={buttonRef}
116
- id={buttonId}
117
- aria-controls={contentId}
118
- aria-expanded={isOpen}
119
- aria-disabled="false"
120
265
  >
121
266
  <Flex className="items-center" as="span">
122
267
  {iconSlot && (
@@ -130,45 +275,23 @@ export const Accordion = ({
130
275
  icon={ICON_TYPE.CHEVRON_DOWN}
131
276
  className={cn({ e: "chevronIcon" })}
132
277
  />
133
- </button>
278
+ </AccordionButton>
134
279
  </Heading.H5>
135
- <Transition
136
- items={isOpen}
137
- from={{ height: 0 }}
138
- enter={{ height }}
139
- leave={{ height: 0 }}
140
- update={heightObj}
141
- onRest={() => {
142
- if (defaultIsOpen && isOpen) {
143
- setEnableTransition(true);
144
- }
145
- }}
146
- immediate={!enableTransition}
147
- >
148
- {(show) => {
149
- return (
150
- show &&
151
- ((props) => (
152
- <div style={props} className={cn({ e: "content" })}>
153
- <Box
154
- ref={onRefChange}
155
- className={classNames(
156
- cn({ e: "children" }),
157
- !removePadding && cn({ e: "children", m: "padded" }),
158
- )}
159
- style={maxHeight ? { maxHeight } : undefined}
160
- id={contentId}
161
- aria-labelledby={buttonId}
162
- >
163
- {children}
164
- </Box>
165
- </div>
166
- ))
167
- );
168
- }}
169
- </Transition>
170
- </Box>
280
+ <AccordionContent className={cn({ e: "content" })} maxHeight={maxHeight}>
281
+ <Box
282
+ className={classNames(
283
+ cn({ e: "children" }),
284
+ !removePadding && cn({ e: "children", m: "padded" }),
285
+ )}
286
+ >
287
+ {children}
288
+ </Box>
289
+ </AccordionContent>
290
+ </AccordionItem>
171
291
  );
172
292
  };
173
293
 
174
294
  Accordion.Group = AccordionGroup;
295
+ Accordion.Item = AccordionItem;
296
+ Accordion.Button = AccordionButton;
297
+ Accordion.Content = AccordionContent;
@@ -0,0 +1,60 @@
1
+ import { Context, createContext, useContext } from "react";
2
+ import type {
3
+ AccordionGroupOwnProps,
4
+ AccordionItemOwnProps,
5
+ AccordionDisclosureProps,
6
+ } from "./types";
7
+
8
+ /**
9
+ * Accordion.Group context
10
+ * =============================================================================
11
+ */
12
+ type AccordionGroupContextType = AccordionGroupOwnProps;
13
+
14
+ const defaultGroupContext: AccordionGroupContextType = {
15
+ defaultValue: undefined,
16
+ };
17
+
18
+ export const AccordionGroupContext: Context<AccordionGroupContextType> = createContext<AccordionGroupContextType>(
19
+ defaultGroupContext,
20
+ );
21
+
22
+ export function useAccordionGroupContext() {
23
+ const context = useContext<typeof defaultGroupContext>(
24
+ AccordionGroupContext,
25
+ ) || {
26
+ ...defaultGroupContext,
27
+ };
28
+
29
+ return context;
30
+ }
31
+
32
+ /**
33
+ * Accordion.Item context
34
+ * =============================================================================
35
+ */
36
+ type AccordionItemContextType = AccordionItemOwnProps &
37
+ AccordionDisclosureProps & {
38
+ buttonId: string;
39
+ contentId: string;
40
+ };
41
+
42
+ const defaultContext: AccordionItemContextType = {
43
+ defaultIsOpen: false,
44
+ isOpen: false,
45
+ onToggle: () => {},
46
+ buttonId: "accordion-0-button",
47
+ contentId: "accordion-0-content",
48
+ };
49
+
50
+ export const AccordionItemContext: Context<AccordionItemContextType> = createContext<AccordionItemContextType>(
51
+ defaultContext,
52
+ );
53
+
54
+ export function useAccordionItemContext() {
55
+ const context = useContext<typeof defaultContext>(AccordionItemContext) || {
56
+ ...defaultContext,
57
+ };
58
+
59
+ return context;
60
+ }
@@ -60,7 +60,6 @@
60
60
  border-l-4
61
61
  duration-200
62
62
  border-transparent
63
- overflow-hidden
64
63
  transition
65
64
  text-bodySm;
66
65
  }
@@ -94,10 +93,6 @@
94
93
  @apply border-gray-500;
95
94
  }
96
95
 
97
- .ads-Accordion-children {
98
- @apply overflow-y-auto;
99
- }
100
-
101
96
  .ads-Accordion-children--padded {
102
97
  @apply py-4
103
98
  pl-7
@@ -1 +1,2 @@
1
1
  export * from "./Accordion";
2
+ export * from "./context";
@@ -0,0 +1,55 @@
1
+ import type { ReactNode } from "react";
2
+ import type { DisclosureProps } from "../../types";
3
+
4
+ export type AccordionGroupOwnProps = {
5
+ /**
6
+ * The value of the item to expand when initially rendered.
7
+ */
8
+ defaultValue?: string;
9
+ };
10
+
11
+ export type AccordionItemOwnProps = {
12
+ /**
13
+ * Whether or not the accordion item is open / visible.
14
+ *
15
+ * ⚠️ **Deprecation notice** ⚠️
16
+ *
17
+ * This prop is deprecated and will be removed in the next major version. Use
18
+ * `defaultValue`/`value` combo instead to expand an item when initially
19
+ * rendered.
20
+ */
21
+ defaultIsOpen?: boolean;
22
+ /**
23
+ * A unique value for the item.
24
+ */
25
+ value?: string;
26
+ };
27
+
28
+ export type AccordionOwnProps = Pick<AccordionItemOwnProps, "defaultIsOpen"> & {
29
+ /**
30
+ * The displayed text of the `Accordion` when closed.
31
+ */
32
+ title: string;
33
+ /**
34
+ * If true, this shows a green indicator next to the title.
35
+ */
36
+ isActive?: boolean;
37
+ /**
38
+ * CSS value to define a max height of the opened Accordion content.
39
+ * If the children exceed the height of the container, it will scroll.
40
+ */
41
+ maxHeight?: string;
42
+ /**
43
+ * Add an icon or integration logo to the left of the header title.
44
+ */
45
+ iconSlot?: ReactNode;
46
+ /**
47
+ * Removes padding from the Accordion's content.
48
+ */
49
+ removePadding?: ReactNode;
50
+ };
51
+
52
+ export type AccordionDisclosureProps = Pick<
53
+ DisclosureProps,
54
+ "isOpen" | "onToggle"
55
+ >;
@@ -607,3 +607,63 @@ For best results, use the round bordered variant of the avatar.
607
607
  </Stack>
608
608
  </Story>
609
609
  </Preview>
610
+
611
+ ### Reverse direction of the group overlap stack
612
+
613
+ Pass in the `overlap-reverse` value to the `spacing` prop on the Avatar.Group to
614
+ reverse the stack direction.
615
+
616
+ <Preview>
617
+ <Story name="Avatars reverse overlapping">
618
+ <Stack orientation={ORIENTATION.VERTICAL} spacing={8}>
619
+ <Avatar.Group size="small" spacing="overlap-reverse">
620
+ {people.map((person) => (
621
+ <Avatar
622
+ key={person.email}
623
+ type={AVATAR_TYPE.USER}
624
+ email={person.email}
625
+ name={person.name}
626
+ bordered
627
+ enableTooltip
628
+ />
629
+ ))}
630
+ </Avatar.Group>
631
+ <Avatar.Group size="medium" spacing="overlap-reverse">
632
+ {people.map((person) => (
633
+ <Avatar
634
+ key={person.email}
635
+ type={AVATAR_TYPE.USER}
636
+ email={person.email}
637
+ name={person.name}
638
+ bordered
639
+ enableTooltip
640
+ />
641
+ ))}
642
+ </Avatar.Group>
643
+ <Avatar.Group size="large" spacing="overlap-reverse">
644
+ {people.map((person) => (
645
+ <Avatar
646
+ key={person.email}
647
+ type={AVATAR_TYPE.USER}
648
+ email={person.email}
649
+ name={person.name}
650
+ bordered
651
+ enableTooltip
652
+ />
653
+ ))}
654
+ </Avatar.Group>
655
+ <Avatar.Group size="xlarge" spacing="overlap-reverse">
656
+ {people.map((person) => (
657
+ <Avatar
658
+ key={person.email}
659
+ type={AVATAR_TYPE.USER}
660
+ email={person.email}
661
+ name={person.name}
662
+ bordered
663
+ enableTooltip
664
+ />
665
+ ))}
666
+ </Avatar.Group>
667
+ </Stack>
668
+ </Story>
669
+ </Preview>