@primer/components 31.2.0-rc.6afeaa37 → 31.2.0-rc.76ed571d

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 (375) hide show
  1. package/.github/workflows/ci.yml +5 -2
  2. package/.github/workflows/release.yml +1 -0
  3. package/.github/workflows/release_canary.yml +1 -0
  4. package/CHANGELOG.md +4 -0
  5. package/dist/browser.esm.js +209 -209
  6. package/dist/browser.esm.js.map +1 -1
  7. package/dist/browser.umd.js +195 -195
  8. package/dist/browser.umd.js.map +1 -1
  9. package/docs/content/ActionList2.mdx +14 -8
  10. package/docs/content/StateLabel.md +5 -4
  11. package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +2 -2
  12. package/lib/ActionList/Divider.jsx +29 -0
  13. package/lib/ActionList/Group.jsx +23 -0
  14. package/lib/ActionList/Header.jsx +66 -0
  15. package/lib/ActionList/Item.jsx +301 -0
  16. package/lib/ActionList/List.jsx +138 -0
  17. package/lib/ActionList/index.js +12 -23
  18. package/lib/ActionList2/Description.jsx +30 -0
  19. package/lib/ActionList2/Divider.jsx +22 -0
  20. package/lib/ActionList2/Group.jsx +25 -0
  21. package/lib/ActionList2/Header.jsx +36 -0
  22. package/lib/ActionList2/Item.jsx +174 -0
  23. package/lib/ActionList2/LinkItem.jsx +28 -0
  24. package/lib/ActionList2/List.jsx +41 -0
  25. package/lib/ActionList2/Selection.jsx +36 -0
  26. package/lib/ActionList2/Visuals.jsx +48 -0
  27. package/lib/ActionList2/index.js +23 -41
  28. package/lib/ActionMenu.jsx +73 -0
  29. package/lib/AnchoredOverlay/AnchoredOverlay.jsx +100 -0
  30. package/lib/AnchoredOverlay/index.js +4 -12
  31. package/lib/Autocomplete/Autocomplete.d.ts +28 -28
  32. package/lib/Autocomplete/Autocomplete.jsx +100 -0
  33. package/lib/Autocomplete/AutocompleteContext.jsx +5 -0
  34. package/lib/Autocomplete/AutocompleteInput.d.ts +28 -28
  35. package/lib/Autocomplete/AutocompleteInput.jsx +113 -0
  36. package/lib/Autocomplete/AutocompleteMenu.jsx +190 -0
  37. package/lib/Autocomplete/AutocompleteOverlay.jsx +55 -0
  38. package/lib/Autocomplete/index.js +7 -14
  39. package/lib/Avatar.jsx +34 -0
  40. package/lib/AvatarPair.jsx +29 -0
  41. package/lib/AvatarStack.jsx +151 -0
  42. package/lib/BaseStyles.jsx +65 -0
  43. package/lib/BorderBox.jsx +18 -0
  44. package/lib/Box.jsx +10 -0
  45. package/lib/BranchName.jsx +20 -0
  46. package/lib/Breadcrumbs.jsx +74 -0
  47. package/lib/Button/Button.d.ts +25 -25
  48. package/lib/Button/Button.jsx +60 -0
  49. package/lib/Button/ButtonBase.jsx +36 -0
  50. package/lib/Button/ButtonClose.d.ts +45 -45
  51. package/lib/Button/ButtonClose.jsx +55 -0
  52. package/lib/Button/ButtonDanger.d.ts +25 -25
  53. package/lib/Button/ButtonDanger.jsx +63 -0
  54. package/lib/Button/ButtonGroup.jsx +55 -0
  55. package/lib/Button/ButtonInvisible.d.ts +25 -25
  56. package/lib/Button/ButtonInvisible.jsx +52 -0
  57. package/lib/Button/ButtonOutline.d.ts +25 -25
  58. package/lib/Button/ButtonOutline.jsx +63 -0
  59. package/lib/Button/ButtonPrimary.d.ts +25 -25
  60. package/lib/Button/ButtonPrimary.jsx +62 -0
  61. package/lib/Button/ButtonStyles.jsx +37 -0
  62. package/lib/Button/ButtonTableList.jsx +49 -0
  63. package/lib/Button/index.js +21 -70
  64. package/lib/Caret.jsx +93 -0
  65. package/lib/CircleBadge.jsx +43 -0
  66. package/lib/CircleOcticon.d.ts +42 -42
  67. package/lib/CircleOcticon.jsx +21 -0
  68. package/lib/CounterLabel.jsx +44 -0
  69. package/lib/Details.jsx +21 -0
  70. package/lib/Dialog/ConfirmationDialog.jsx +146 -0
  71. package/lib/Dialog/Dialog.js +1 -0
  72. package/lib/Dialog/Dialog.jsx +273 -0
  73. package/lib/Dialog.d.ts +45 -45
  74. package/lib/Dialog.jsx +131 -0
  75. package/lib/Dropdown.d.ts +176 -176
  76. package/lib/Dropdown.jsx +134 -0
  77. package/lib/DropdownMenu/DropdownButton.d.ts +46 -46
  78. package/lib/DropdownMenu/DropdownButton.jsx +14 -0
  79. package/lib/DropdownMenu/DropdownMenu.jsx +70 -0
  80. package/lib/DropdownMenu/index.js +6 -20
  81. package/lib/DropdownStyles.js +18 -26
  82. package/lib/FilterList.d.ts +42 -42
  83. package/lib/FilterList.jsx +63 -0
  84. package/lib/FilteredActionList/FilteredActionList.jsx +100 -0
  85. package/lib/FilteredActionList/index.js +4 -12
  86. package/lib/FilteredSearch.jsx +29 -0
  87. package/lib/Flash.jsx +70 -0
  88. package/lib/Flex.jsx +15 -0
  89. package/lib/FormGroup.jsx +25 -0
  90. package/lib/Grid.jsx +15 -0
  91. package/lib/Header.jsx +90 -0
  92. package/lib/Heading.jsx +21 -0
  93. package/lib/Label.jsx +84 -0
  94. package/lib/LabelGroup.jsx +19 -0
  95. package/lib/Link.jsx +38 -0
  96. package/lib/NewButton/button-counter.d.ts +6 -0
  97. package/lib/NewButton/button-counter.js +31 -0
  98. package/lib/NewButton/button-counter.jsx +14 -0
  99. package/lib/NewButton/button.d.ts +13 -0
  100. package/lib/NewButton/button.js +316 -0
  101. package/lib/NewButton/button.jsx +278 -0
  102. package/lib/NewButton/index.d.ts +14 -0
  103. package/lib/NewButton/index.js +8 -0
  104. package/lib/NewButton/types.d.ts +32 -0
  105. package/lib/NewButton/types.js +2 -0
  106. package/lib/Overlay.jsx +156 -0
  107. package/lib/Pagehead.jsx +18 -0
  108. package/lib/Pagination/Pagination.jsx +163 -0
  109. package/lib/Pagination/index.js +6 -12
  110. package/lib/Pagination/model.jsx +174 -0
  111. package/lib/PointerBox.jsx +25 -0
  112. package/lib/Popover.jsx +210 -0
  113. package/lib/Portal/Portal.jsx +79 -0
  114. package/lib/Portal/index.js +5 -16
  115. package/lib/Position.d.ts +4 -4
  116. package/lib/Position.jsx +46 -0
  117. package/lib/ProgressBar.jsx +39 -0
  118. package/lib/SelectMenu/SelectMenu.d.ts +246 -246
  119. package/lib/SelectMenu/SelectMenu.jsx +114 -0
  120. package/lib/SelectMenu/SelectMenuContext.jsx +5 -0
  121. package/lib/SelectMenu/SelectMenuDivider.jsx +43 -0
  122. package/lib/SelectMenu/SelectMenuFilter.jsx +59 -0
  123. package/lib/SelectMenu/SelectMenuFooter.jsx +46 -0
  124. package/lib/SelectMenu/SelectMenuHeader.jsx +44 -0
  125. package/lib/SelectMenu/SelectMenuItem.d.ts +1 -1
  126. package/lib/SelectMenu/SelectMenuItem.jsx +143 -0
  127. package/lib/SelectMenu/SelectMenuList.jsx +60 -0
  128. package/lib/SelectMenu/SelectMenuLoadingAnimation.jsx +21 -0
  129. package/lib/SelectMenu/SelectMenuModal.d.ts +1 -1
  130. package/lib/SelectMenu/SelectMenuModal.jsx +119 -0
  131. package/lib/SelectMenu/SelectMenuTab.jsx +93 -0
  132. package/lib/SelectMenu/SelectMenuTabPanel.jsx +43 -0
  133. package/lib/SelectMenu/SelectMenuTabs.jsx +58 -0
  134. package/lib/SelectMenu/hooks/useKeyboardNav.js +80 -96
  135. package/lib/SelectMenu/index.js +7 -14
  136. package/lib/SelectPanel/SelectPanel.jsx +105 -0
  137. package/lib/SelectPanel/index.js +4 -12
  138. package/lib/SideNav.jsx +177 -0
  139. package/lib/Spinner.jsx +35 -0
  140. package/lib/StateLabel.d.ts +1 -1
  141. package/lib/StateLabel.js +6 -1
  142. package/lib/StateLabel.jsx +94 -0
  143. package/lib/StyledOcticon.jsx +20 -0
  144. package/lib/SubNav.jsx +104 -0
  145. package/lib/TabNav.jsx +60 -0
  146. package/lib/Text.jsx +14 -0
  147. package/lib/TextInput.jsx +23 -0
  148. package/lib/TextInputWithTokens.d.ts +28 -28
  149. package/lib/TextInputWithTokens.jsx +218 -0
  150. package/lib/ThemeProvider.jsx +130 -0
  151. package/lib/Timeline.d.ts +43 -43
  152. package/lib/Timeline.jsx +124 -0
  153. package/lib/Token/AvatarToken.d.ts +1 -1
  154. package/lib/Token/AvatarToken.jsx +54 -0
  155. package/lib/Token/IssueLabelToken.d.ts +1 -1
  156. package/lib/Token/IssueLabelToken.jsx +125 -0
  157. package/lib/Token/Token.d.ts +1 -1
  158. package/lib/Token/Token.jsx +103 -0
  159. package/lib/Token/TokenBase.jsx +88 -0
  160. package/lib/Token/_RemoveTokenButton.jsx +108 -0
  161. package/lib/Token/_TokenTextContainer.jsx +49 -0
  162. package/lib/Token/index.js +11 -30
  163. package/lib/Tooltip.jsx +246 -0
  164. package/lib/Truncate.jsx +27 -0
  165. package/lib/UnderlineNav.jsx +90 -0
  166. package/lib/_TextInputWrapper.jsx +120 -0
  167. package/lib/_UnstyledTextInput.jsx +22 -0
  168. package/lib/__tests__/ActionList.test.jsx +49 -0
  169. package/lib/__tests__/ActionList.types.test.jsx +45 -0
  170. package/lib/__tests__/ActionList2.test.jsx +46 -0
  171. package/lib/__tests__/ActionMenu.test.jsx +124 -0
  172. package/lib/__tests__/AnchoredOverlay.test.jsx +121 -0
  173. package/lib/__tests__/Autocomplete.test.jsx +299 -0
  174. package/lib/__tests__/Avatar.test.jsx +42 -0
  175. package/lib/__tests__/AvatarStack.test.jsx +43 -0
  176. package/lib/__tests__/BorderBox.test.jsx +36 -0
  177. package/lib/__tests__/Box.test.jsx +41 -0
  178. package/lib/__tests__/BranchName.test.jsx +27 -0
  179. package/lib/__tests__/Breadcrumbs.test.jsx +28 -0
  180. package/lib/__tests__/BreadcrumbsItem.test.jsx +31 -0
  181. package/lib/__tests__/Button.test.jsx +100 -0
  182. package/lib/__tests__/Caret.test.jsx +37 -0
  183. package/lib/__tests__/CircleBadge.test.jsx +55 -0
  184. package/lib/__tests__/CircleOcticon.test.jsx +45 -0
  185. package/lib/__tests__/ConfirmationDialog.test.jsx +119 -0
  186. package/lib/__tests__/CounterLabel.test.jsx +36 -0
  187. package/lib/__tests__/Details.test.jsx +85 -0
  188. package/lib/__tests__/Dialog.test.jsx +139 -0
  189. package/lib/__tests__/Dropdown.test.jsx +49 -0
  190. package/lib/__tests__/DropdownMenu.test.jsx +119 -0
  191. package/lib/__tests__/FilterList.test.jsx +27 -0
  192. package/lib/__tests__/FilterListItem.test.jsx +31 -0
  193. package/lib/__tests__/FilteredSearch.test.jsx +27 -0
  194. package/lib/__tests__/Flash.test.jsx +36 -0
  195. package/lib/__tests__/Flex.test.jsx +51 -0
  196. package/lib/__tests__/FormGroup.test.jsx +36 -0
  197. package/lib/__tests__/Grid.test.jsx +69 -0
  198. package/lib/__tests__/Header.test.jsx +45 -0
  199. package/lib/__tests__/Heading.test.jsx +71 -0
  200. package/lib/__tests__/KeyPaths.types.test.js +5 -8
  201. package/lib/__tests__/Label.test.jsx +33 -0
  202. package/lib/__tests__/LabelGroup.test.jsx +29 -0
  203. package/lib/__tests__/Link.test.jsx +43 -0
  204. package/lib/__tests__/Merge.types.test.js +13 -19
  205. package/lib/__tests__/NewButton.test.d.ts +1 -0
  206. package/lib/__tests__/NewButton.test.js +86 -0
  207. package/lib/__tests__/NewButton.test.jsx +55 -0
  208. package/lib/__tests__/Overlay.test.jsx +105 -0
  209. package/lib/__tests__/Pagehead.test.jsx +25 -0
  210. package/lib/__tests__/Pagination/Pagination.test.jsx +32 -0
  211. package/lib/__tests__/Pagination/PaginationModel.test.jsx +118 -0
  212. package/lib/__tests__/PointerBox.test.jsx +33 -0
  213. package/lib/__tests__/Popover.test.jsx +58 -0
  214. package/lib/__tests__/Portal.test.jsx +102 -0
  215. package/lib/__tests__/Position.test.jsx +96 -0
  216. package/lib/__tests__/ProgressBar.test.jsx +38 -0
  217. package/lib/__tests__/SelectMenu.test.jsx +120 -0
  218. package/lib/__tests__/SelectPanel.test.jsx +48 -0
  219. package/lib/__tests__/SideNav.test.jsx +55 -0
  220. package/lib/__tests__/Spinner.test.jsx +41 -0
  221. package/lib/__tests__/StateLabel.test.jsx +46 -0
  222. package/lib/__tests__/StyledOcticon.test.jsx +28 -0
  223. package/lib/__tests__/SubNav.test.jsx +47 -0
  224. package/lib/__tests__/SubNavLink.test.jsx +31 -0
  225. package/lib/__tests__/TabNav.test.jsx +32 -0
  226. package/lib/__tests__/Text.test.jsx +71 -0
  227. package/lib/__tests__/TextInput.test.jsx +45 -0
  228. package/lib/__tests__/TextInputWithTokens.test.jsx +302 -0
  229. package/lib/__tests__/ThemeProvider.test.jsx +314 -0
  230. package/lib/__tests__/Timeline.test.jsx +51 -0
  231. package/lib/__tests__/Token.test.jsx +93 -0
  232. package/lib/__tests__/Tooltip.test.jsx +46 -0
  233. package/lib/__tests__/Truncate.test.jsx +41 -0
  234. package/lib/__tests__/UnderlineNav.test.jsx +53 -0
  235. package/lib/__tests__/UnderlineNavLink.test.jsx +31 -0
  236. package/lib/__tests__/behaviors/anchoredPosition.test.js +229 -376
  237. package/lib/__tests__/behaviors/focusTrap.test.jsx +184 -0
  238. package/lib/__tests__/behaviors/focusZone.test.jsx +406 -0
  239. package/lib/__tests__/behaviors/iterateFocusableElements.test.jsx +58 -0
  240. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.js +145 -216
  241. package/lib/__tests__/filterObject.test.js +48 -27
  242. package/lib/__tests__/hooks/useAnchoredPosition.test.jsx +29 -0
  243. package/lib/__tests__/hooks/useOnEscapePress.test.jsx +19 -0
  244. package/lib/__tests__/hooks/useOnOutsideClick.test.jsx +63 -0
  245. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.jsx +61 -0
  246. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.jsx +56 -0
  247. package/lib/__tests__/theme.test.js +33 -34
  248. package/lib/__tests__/themeGet.test.js +12 -23
  249. package/lib/__tests__/useSafeTimeout.test.jsx +36 -0
  250. package/lib/__tests__/utils/createSlots.test.jsx +57 -0
  251. package/lib/behaviors/anchoredPosition.js +205 -234
  252. package/lib/behaviors/focusTrap.js +121 -157
  253. package/lib/behaviors/focusZone.js +434 -509
  254. package/lib/behaviors/scrollIntoViewingArea.js +18 -35
  255. package/lib/constants.js +39 -43
  256. package/lib/{unreleased.d.ts → drafts.d.ts} +2 -1
  257. package/lib/drafts.js +21 -0
  258. package/lib/hooks/index.js +16 -60
  259. package/lib/hooks/useAnchoredPosition.js +32 -40
  260. package/lib/hooks/useCombinedRefs.js +32 -36
  261. package/lib/hooks/useDetails.jsx +39 -0
  262. package/lib/hooks/useDialog.js +72 -96
  263. package/lib/hooks/useFocusTrap.js +43 -60
  264. package/lib/hooks/useFocusZone.js +54 -50
  265. package/lib/hooks/useOnEscapePress.js +25 -36
  266. package/lib/hooks/useOnOutsideClick.jsx +61 -0
  267. package/lib/hooks/useOpenAndCloseFocus.js +22 -34
  268. package/lib/hooks/useOverlay.jsx +15 -0
  269. package/lib/hooks/useProvidedRefOrCreate.js +10 -14
  270. package/lib/hooks/useProvidedStateOrCreate.js +13 -16
  271. package/lib/hooks/useRenderForcingRef.js +13 -17
  272. package/lib/hooks/useResizeObserver.js +15 -18
  273. package/lib/hooks/useSafeTimeout.js +22 -30
  274. package/lib/hooks/useScrollFlash.js +16 -23
  275. package/lib/index.d.ts +2 -0
  276. package/lib/index.js +163 -636
  277. package/lib/polyfills/eventListenerSignal.js +37 -45
  278. package/lib/stories/ActionList2.stories.js +3 -2
  279. package/lib/stories/NewButton.stories.js +230 -0
  280. package/lib/sx.js +10 -22
  281. package/lib/theme-preval.js +64 -3023
  282. package/lib/theme.js +3 -12
  283. package/lib/utils/create-slots.jsx +65 -0
  284. package/lib/utils/deprecate.jsx +59 -0
  285. package/lib/utils/isNumeric.jsx +7 -0
  286. package/lib/utils/iterateFocusableElements.js +63 -85
  287. package/lib/utils/ssr.jsx +6 -0
  288. package/lib/utils/test-deprecations.jsx +20 -0
  289. package/lib/utils/test-helpers.jsx +8 -0
  290. package/lib/utils/test-matchers.jsx +100 -0
  291. package/lib/utils/testing.jsx +206 -0
  292. package/lib/utils/theme.js +33 -47
  293. package/lib/utils/types/AriaRole.js +2 -1
  294. package/lib/utils/types/ComponentProps.js +2 -1
  295. package/lib/utils/types/Flatten.js +2 -1
  296. package/lib/utils/types/KeyPaths.js +2 -1
  297. package/lib/utils/types/MandateProps.js +16 -1
  298. package/lib/utils/types/Merge.js +2 -1
  299. package/lib/utils/types/index.js +16 -69
  300. package/lib/utils/uniqueId.js +5 -8
  301. package/lib/utils/use-force-update.js +8 -14
  302. package/lib/utils/useIsomorphicLayoutEffect.js +8 -11
  303. package/lib/utils/userAgent.js +8 -12
  304. package/lib-esm/Autocomplete/Autocomplete.d.ts +28 -28
  305. package/lib-esm/Autocomplete/AutocompleteInput.d.ts +28 -28
  306. package/lib-esm/Button/Button.d.ts +25 -25
  307. package/lib-esm/Button/ButtonClose.d.ts +45 -45
  308. package/lib-esm/Button/ButtonDanger.d.ts +25 -25
  309. package/lib-esm/Button/ButtonInvisible.d.ts +25 -25
  310. package/lib-esm/Button/ButtonOutline.d.ts +25 -25
  311. package/lib-esm/Button/ButtonPrimary.d.ts +25 -25
  312. package/lib-esm/CircleOcticon.d.ts +42 -42
  313. package/lib-esm/Dialog/Dialog.js +1 -0
  314. package/lib-esm/Dialog.d.ts +45 -45
  315. package/lib-esm/Dropdown.d.ts +176 -176
  316. package/lib-esm/DropdownMenu/DropdownButton.d.ts +46 -46
  317. package/lib-esm/FilterList.d.ts +42 -42
  318. package/lib-esm/NewButton/button-counter.d.ts +6 -0
  319. package/lib-esm/NewButton/button-counter.js +18 -0
  320. package/lib-esm/NewButton/button.d.ts +13 -0
  321. package/lib-esm/NewButton/button.js +298 -0
  322. package/lib-esm/NewButton/index.d.ts +14 -0
  323. package/lib-esm/NewButton/index.js +5 -0
  324. package/lib-esm/NewButton/types.d.ts +32 -0
  325. package/lib-esm/NewButton/types.js +1 -0
  326. package/lib-esm/Position.d.ts +4 -4
  327. package/lib-esm/SelectMenu/SelectMenu.d.ts +246 -246
  328. package/lib-esm/SelectMenu/SelectMenuItem.d.ts +1 -1
  329. package/lib-esm/SelectMenu/SelectMenuModal.d.ts +1 -1
  330. package/lib-esm/StateLabel.d.ts +1 -1
  331. package/lib-esm/StateLabel.js +7 -2
  332. package/lib-esm/TextInputWithTokens.d.ts +28 -28
  333. package/lib-esm/Timeline.d.ts +43 -43
  334. package/lib-esm/Token/AvatarToken.d.ts +1 -1
  335. package/lib-esm/Token/IssueLabelToken.d.ts +1 -1
  336. package/lib-esm/Token/Token.d.ts +1 -1
  337. package/lib-esm/__tests__/NewButton.test.d.ts +1 -0
  338. package/lib-esm/__tests__/NewButton.test.js +76 -0
  339. package/lib-esm/{unreleased.d.ts → drafts.d.ts} +2 -1
  340. package/lib-esm/{unreleased.js → drafts.js} +3 -2
  341. package/lib-esm/index.d.ts +2 -0
  342. package/lib-esm/index.js +1 -0
  343. package/lib-esm/stories/ActionList2.stories.js +3 -3
  344. package/lib-esm/stories/NewButton.stories.js +178 -0
  345. package/package-lock.json +7 -7
  346. package/package.json +4 -3
  347. package/script/build +1 -1
  348. package/src/Dialog/Dialog.tsx +1 -0
  349. package/src/NewButton/button-counter.tsx +15 -0
  350. package/src/NewButton/button.tsx +279 -0
  351. package/src/NewButton/index.ts +10 -0
  352. package/src/NewButton/types.ts +36 -0
  353. package/src/StateLabel.tsx +14 -2
  354. package/src/__tests__/NewButton.test.tsx +64 -0
  355. package/src/__tests__/__snapshots__/Autocomplete.test.tsx.snap +1 -0
  356. package/src/__tests__/__snapshots__/CircleBadge.test.tsx.snap +1 -0
  357. package/src/__tests__/__snapshots__/CircleOcticon.test.tsx.snap +1 -0
  358. package/src/__tests__/__snapshots__/Dialog.test.tsx.snap +1 -0
  359. package/src/__tests__/__snapshots__/DropdownMenu.test.tsx.snap +1 -0
  360. package/src/__tests__/__snapshots__/NewButton.test.tsx.snap +182 -0
  361. package/src/__tests__/__snapshots__/SelectMenu.test.tsx.snap +4 -0
  362. package/src/__tests__/__snapshots__/SelectPanel.test.tsx.snap +1 -0
  363. package/src/__tests__/__snapshots__/StateLabel.test.tsx.snap +13 -6
  364. package/src/__tests__/__snapshots__/StyledOcticon.test.tsx.snap +1 -0
  365. package/src/__tests__/__snapshots__/TextInputWithTokens.test.tsx.snap +66 -0
  366. package/src/__tests__/__snapshots__/Token.test.tsx.snap +17 -0
  367. package/src/{unreleased.ts → drafts.ts} +2 -1
  368. package/src/index.ts +2 -0
  369. package/src/stories/ActionList2.stories.tsx +12 -9
  370. package/src/stories/NewButton.stories.tsx +201 -0
  371. package/stats.html +1 -1
  372. package/tsconfig.base.json +20 -0
  373. package/tsconfig.build.json +2 -2
  374. package/tsconfig.json +4 -17
  375. package/lib/unreleased.js +0 -18
@@ -1,29 +1,18 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
2
+ Object.defineProperty(exports, "__esModule", { value: true });
6
3
  exports.ActionList = void 0;
7
-
8
- var _List = require("./List");
9
-
10
- var _Group = require("./Group");
11
-
12
- var _Item = require("./Item");
13
-
14
- var _Divider = require("./Divider");
15
-
4
+ const List_1 = require("./List");
5
+ const Group_1 = require("./Group");
6
+ const Item_1 = require("./Item");
7
+ const Divider_1 = require("./Divider");
16
8
  /**
17
9
  * Collection of list-related components.
18
10
  */
19
- const ActionList = Object.assign(_List.List, {
20
- /** Collects related `Items` in an `ActionList`. */
21
- Group: _Group.Group,
22
-
23
- /** An actionable or selectable `Item` with an optional icon and description. */
24
- Item: _Item.Item,
25
-
26
- /** Visually separates `Item`s or `Group`s in an `ActionList`. */
27
- Divider: _Divider.Divider
11
+ exports.ActionList = Object.assign(List_1.List, {
12
+ /** Collects related `Items` in an `ActionList`. */
13
+ Group: Group_1.Group,
14
+ /** An actionable or selectable `Item` with an optional icon and description. */
15
+ Item: Item_1.Item,
16
+ /** Visually separates `Item`s or `Group`s in an `ActionList`. */
17
+ Divider: Divider_1.Divider
28
18
  });
29
- exports.ActionList = ActionList;
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Description = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Box_1 = __importDefault(require("../Box"));
9
+ const sx_1 = require("../sx");
10
+ const Truncate_1 = __importDefault(require("../Truncate"));
11
+ const Item_1 = require("./Item");
12
+ const Description = ({ variant = 'inline', sx = {}, ...props }) => {
13
+ const styles = {
14
+ color: 'fg.muted',
15
+ fontSize: 0,
16
+ lineHeight: '16px',
17
+ flexGrow: 1,
18
+ flexBasis: 0,
19
+ minWidth: 0,
20
+ marginLeft: variant === 'block' ? 0 : 2
21
+ };
22
+ return (<Item_1.Slot name={variant === 'block' ? 'BlockDescription' : 'InlineDescription'}>
23
+ {({ blockDescriptionId, inlineDescriptionId }) => variant === 'block' ? (<Box_1.default as="span" sx={sx_1.merge(styles, sx)} id={blockDescriptionId}>
24
+ {props.children}
25
+ </Box_1.default>) : (<Truncate_1.default id={inlineDescriptionId} sx={sx_1.merge(styles, sx)} title={props.children} inline={true} maxWidth="100%">
26
+ {props.children}
27
+ </Truncate_1.default>)}
28
+ </Item_1.Slot>);
29
+ };
30
+ exports.Description = Description;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Divider = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Box_1 = __importDefault(require("../Box"));
9
+ const constants_1 = require("../constants");
10
+ /**
11
+ * Visually separates `Item`s or `Group`s in an `ActionList`.
12
+ */
13
+ function Divider() {
14
+ return (<Box_1.default as="li" role="separator" sx={{
15
+ height: 1,
16
+ backgroundColor: 'actionListItem.inlineDivider',
17
+ marginTop: (theme) => `calc(${constants_1.get('space.2')(theme)} - 1px)`,
18
+ marginBottom: 2,
19
+ listStyle: 'none' // hide the ::marker inserted by browser's stylesheet
20
+ }} data-component="ActionList.Divider"/>);
21
+ }
22
+ exports.Divider = Divider;
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Group = exports.GroupContext = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Box_1 = __importDefault(require("../Box"));
9
+ const Header_1 = require("./Header");
10
+ exports.GroupContext = react_1.default.createContext({});
11
+ const Group = ({ title, variant, auxiliaryText, selectionVariant, sx = {}, ...props }) => {
12
+ return (<Box_1.default as="li" sx={{
13
+ '&:not(:first-child)': { marginTop: 2 },
14
+ listStyle: 'none',
15
+ ...sx
16
+ }} {...props}>
17
+ {title && <Header_1.Header title={title} variant={variant} auxiliaryText={auxiliaryText}/>}
18
+ <exports.GroupContext.Provider value={{ selectionVariant }}>
19
+ <Box_1.default as="ul" sx={{ paddingInlineStart: 0 }}>
20
+ {props.children}
21
+ </Box_1.default>
22
+ </exports.GroupContext.Provider>
23
+ </Box_1.default>);
24
+ };
25
+ exports.Group = Group;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Header = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Box_1 = __importDefault(require("../Box"));
9
+ const List_1 = require("./List");
10
+ /**
11
+ * Displays the name and description of a `Group`.
12
+ */
13
+ const Header = ({ variant = 'subtle', title, auxiliaryText, sx = {}, ...props }) => {
14
+ const { variant: listVariant } = react_1.default.useContext(List_1.ListContext);
15
+ const styles = {
16
+ paddingY: '6px',
17
+ paddingX: listVariant === 'full' ? 2 : 3,
18
+ fontSize: 0,
19
+ fontWeight: 'bold',
20
+ color: 'fg.muted',
21
+ ...(variant === 'filled' && {
22
+ backgroundColor: 'canvas.subtle',
23
+ marginX: 0,
24
+ marginBottom: 2,
25
+ borderTop: '1px solid',
26
+ borderBottom: '1px solid',
27
+ borderColor: 'neutral.muted'
28
+ }),
29
+ ...sx
30
+ };
31
+ return (<Box_1.default sx={styles} role="heading" {...props}>
32
+ {title}
33
+ {auxiliaryText && <span>{auxiliaryText}</span>}
34
+ </Box_1.default>);
35
+ };
36
+ exports.Header = Header;
@@ -0,0 +1,174 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.Item = exports.TEXT_ROW_HEIGHT = exports.Slot = exports.getVariantStyles = void 0;
26
+ const react_1 = __importDefault(require("react"));
27
+ const ssr_1 = require("@react-aria/ssr");
28
+ const styled_components_1 = __importDefault(require("styled-components"));
29
+ const ThemeProvider_1 = require("../ThemeProvider");
30
+ const Box_1 = __importDefault(require("../Box"));
31
+ const sx_1 = __importStar(require("../sx"));
32
+ const create_slots_1 = __importDefault(require("../utils/create-slots"));
33
+ const List_1 = require("./List");
34
+ const Selection_1 = require("./Selection");
35
+ const getVariantStyles = (variant, disabled) => {
36
+ if (disabled) {
37
+ return {
38
+ color: 'fg.muted',
39
+ iconColor: 'fg.muted',
40
+ annotationColor: 'fg.muted'
41
+ };
42
+ }
43
+ switch (variant) {
44
+ case 'danger':
45
+ return {
46
+ color: 'danger.fg',
47
+ iconColor: 'danger.fg',
48
+ annotationColor: 'fg.muted',
49
+ hoverColor: 'actionListItem.danger.hoverText'
50
+ };
51
+ default:
52
+ return {
53
+ color: 'fg.default',
54
+ iconColor: 'fg.muted',
55
+ annotationColor: 'fg.muted',
56
+ hoverColor: 'fg.default'
57
+ };
58
+ }
59
+ };
60
+ exports.getVariantStyles = getVariantStyles;
61
+ const { Slots, Slot } = create_slots_1.default(['LeadingVisual', 'InlineDescription', 'BlockDescription', 'TrailingVisual']);
62
+ exports.Slot = Slot;
63
+ const LiBox = styled_components_1.default.li(sx_1.default);
64
+ exports.TEXT_ROW_HEIGHT = '20px'; // custom value off the scale
65
+ exports.Item = react_1.default.forwardRef(({ variant = 'default', disabled = false, selected = undefined, onSelect = () => null, sx: sxProp = {}, id, _PrivateItemWrapper, ...props }, forwardedRef) => {
66
+ const { variant: listVariant, showDividers } = react_1.default.useContext(List_1.ListContext);
67
+ const { theme } = ThemeProvider_1.useTheme();
68
+ const styles = {
69
+ display: 'flex',
70
+ paddingX: 2,
71
+ fontSize: 1,
72
+ paddingY: '6px',
73
+ lineHeight: exports.TEXT_ROW_HEIGHT,
74
+ minHeight: 5,
75
+ marginX: listVariant === 'inset' ? 2 : 0,
76
+ borderRadius: listVariant === 'inset' ? 2 : 0,
77
+ transition: 'background 33.333ms linear',
78
+ color: exports.getVariantStyles(variant, disabled).color,
79
+ textDecoration: 'none',
80
+ ':not([aria-disabled])': { cursor: 'pointer' },
81
+ '@media (hover: hover) and (pointer: fine)': {
82
+ ':hover:not([aria-disabled])': {
83
+ backgroundColor: `actionListItem.${variant}.hoverBg`,
84
+ color: exports.getVariantStyles(variant, disabled).hoverColor
85
+ },
86
+ ':focus:not([data-focus-visible-added])': {
87
+ backgroundColor: `actionListItem.${variant}.selectedBg`,
88
+ color: exports.getVariantStyles(variant, disabled).hoverColor,
89
+ outline: 'none'
90
+ },
91
+ '&[data-focus-visible-added]': {
92
+ // we don't use :focus-visible because not all browsers (safari) have it yet
93
+ outline: 'none',
94
+ border: `2 solid`,
95
+ boxShadow: `0 0 0 2px ${theme?.colors.accent.emphasis}`
96
+ },
97
+ ':active:not([aria-disabled])': {
98
+ backgroundColor: `actionListItem.${variant}.activeBg`,
99
+ color: exports.getVariantStyles(variant, disabled).hoverColor
100
+ }
101
+ },
102
+ /** Divider styles */
103
+ '[data-component="ActionList.Item--DividerContainer"]': {
104
+ position: 'relative'
105
+ },
106
+ '[data-component="ActionList.Item--DividerContainer"]::before': {
107
+ content: '" "',
108
+ display: 'block',
109
+ position: 'absolute',
110
+ width: '100%',
111
+ top: '-7px',
112
+ border: '0 solid',
113
+ borderTopWidth: showDividers ? `1px` : '0',
114
+ borderColor: 'var(--divider-color, transparent)'
115
+ },
116
+ // show between 2 items
117
+ ':not(:first-of-type)': { '--divider-color': theme?.colors.actionListItem.inlineDivider },
118
+ // hide divider after dividers & group header, with higher importance!
119
+ '[data-component="ActionList.Divider"] + &': { '--divider-color': 'transparent !important' },
120
+ // hide border on current and previous item
121
+ '&:hover:not([aria-disabled]), &:focus:not([aria-disabled]), &[data-focus-visible-added]:not([aria-disabled])': {
122
+ '--divider-color': 'transparent'
123
+ },
124
+ '&:hover:not([aria-disabled]) + &, &:focus:not([aria-disabled]) + &, &[data-focus-visible-added] + li': {
125
+ '--divider-color': 'transparent'
126
+ }
127
+ };
128
+ const clickHandler = react_1.default.useCallback(event => {
129
+ if (disabled)
130
+ return;
131
+ if (!event.defaultPrevented)
132
+ onSelect(event);
133
+ }, [onSelect, disabled]);
134
+ const keyPressHandler = react_1.default.useCallback(event => {
135
+ if (disabled)
136
+ return;
137
+ if (!event.defaultPrevented && [' ', 'Enter'].includes(event.key)) {
138
+ onSelect(event);
139
+ }
140
+ }, [onSelect, disabled]);
141
+ // use props.id if provided, otherwise generate one.
142
+ const labelId = ssr_1.useSSRSafeId(id);
143
+ const inlineDescriptionId = ssr_1.useSSRSafeId(id && `${id}--inline-description`);
144
+ const blockDescriptionId = ssr_1.useSSRSafeId(id && `${id}--block-description`);
145
+ const ItemWrapper = _PrivateItemWrapper || react_1.default.Fragment;
146
+ return (<Slots context={{ variant, disabled, inlineDescriptionId, blockDescriptionId }}>
147
+ {slots => (<LiBox ref={forwardedRef} sx={sx_1.merge(styles, sxProp)} onClick={clickHandler} onKeyPress={keyPressHandler} aria-selected={selected} aria-disabled={disabled ? true : undefined} tabIndex={disabled || _PrivateItemWrapper ? undefined : 0} aria-labelledby={`${labelId} ${slots.InlineDescription ? inlineDescriptionId : ''}`} aria-describedby={slots.BlockDescription ? blockDescriptionId : undefined} {...props}>
148
+ <ItemWrapper>
149
+ <Selection_1.Selection selected={selected} disabled={disabled}/>
150
+ {slots.LeadingVisual}
151
+ <Box_1.default data-component="ActionList.Item--DividerContainer" sx={{ display: 'flex', flexDirection: 'column', flexGrow: 1, minWidth: 0 }}>
152
+ <ConditionalBox if={Boolean(slots.TrailingVisual)} sx={{ display: 'flex', flexGrow: 1 }}>
153
+ <ConditionalBox if={Boolean(slots.InlineDescription)} sx={{ display: 'flex', flexGrow: 1, alignItems: 'baseline', minWidth: 0 }}>
154
+ <Box_1.default as="span" id={labelId} sx={{ flexGrow: slots.InlineDescription ? 0 : 1 }}>
155
+ {props.children}
156
+ </Box_1.default>
157
+ {slots.InlineDescription}
158
+ </ConditionalBox>
159
+ {slots.TrailingVisual}
160
+ </ConditionalBox>
161
+ {slots.BlockDescription}
162
+ </Box_1.default>
163
+ </ItemWrapper>
164
+ </LiBox>)}
165
+ </Slots>);
166
+ });
167
+ exports.Item.displayName = 'ActionList.Item';
168
+ const ConditionalBox = props => {
169
+ const { if: condition, ...rest } = props;
170
+ if (condition)
171
+ return <Box_1.default {...rest}>{props.children}</Box_1.default>;
172
+ else
173
+ return <>{props.children}</>;
174
+ };
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.LinkItem = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Link_1 = __importDefault(require("../Link"));
9
+ const sx_1 = require("../sx");
10
+ const Item_1 = require("./Item");
11
+ exports.LinkItem = react_1.default.forwardRef(({ sx = {}, as: Component, ...props }, forwardedRef) => {
12
+ const styles = {
13
+ // occupy full size of Item
14
+ paddingX: 2,
15
+ paddingY: '6px',
16
+ display: 'flex',
17
+ flexGrow: 1,
18
+ borderRadius: 2,
19
+ // inherit Item styles
20
+ color: 'inherit',
21
+ '&:hover': { color: 'inherit', textDecoration: 'none' }
22
+ };
23
+ return (<Item_1.Item sx={{ paddingY: 0, paddingX: 0 }} _PrivateItemWrapper={({ children }) => (<Link_1.default as={Component} sx={sx_1.merge(styles, sx)} {...props} ref={forwardedRef}>
24
+ {children}
25
+ </Link_1.default>)}>
26
+ {props.children}
27
+ </Item_1.Item>);
28
+ });
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.List = exports.ListContext = void 0;
26
+ const react_1 = __importDefault(require("react"));
27
+ const styled_components_1 = __importDefault(require("styled-components"));
28
+ const sx_1 = __importStar(require("../sx"));
29
+ exports.ListContext = react_1.default.createContext({});
30
+ const ListBox = styled_components_1.default.ul(sx_1.default);
31
+ exports.List = react_1.default.forwardRef(({ variant = 'inset', selectionVariant, showDividers = false, sx: sxProp = {}, ...props }, forwardedRef) => {
32
+ const styles = {
33
+ margin: 0,
34
+ paddingInlineStart: 0,
35
+ paddingY: variant === 'inset' ? 2 : 0
36
+ };
37
+ return (<ListBox sx={sx_1.merge(styles, sxProp)} aria-multiselectable={selectionVariant === 'multiple' ? true : undefined} {...props} ref={forwardedRef}>
38
+ <exports.ListContext.Provider value={{ variant, selectionVariant, showDividers }}>{props.children}</exports.ListContext.Provider>
39
+ </ListBox>);
40
+ });
41
+ exports.List.displayName = 'ActionList';
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Selection = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const octicons_react_1 = require("@primer/octicons-react");
9
+ const List_1 = require("./List");
10
+ const Group_1 = require("./Group");
11
+ const Visuals_1 = require("./Visuals");
12
+ const Selection = ({ selected, disabled }) => {
13
+ const { selectionVariant: listSelectionVariant } = react_1.default.useContext(List_1.ListContext);
14
+ const { selectionVariant: groupSelectionVariant } = react_1.default.useContext(Group_1.GroupContext);
15
+ /** selectionVariant in Group can override the selectionVariant in List root */
16
+ const selectionVariant = typeof groupSelectionVariant !== 'undefined' ? groupSelectionVariant : listSelectionVariant;
17
+ // if selectionVariant is not set on List, don't show selection
18
+ if (!selectionVariant) {
19
+ // to avoid confusion, fail loudly instead of silently ignoring
20
+ if (selected)
21
+ throw new Error('For Item to be selected, ActionList or ActionList.Group needs to have a selectionVariant defined');
22
+ return null;
23
+ }
24
+ if (selectionVariant === 'single') {
25
+ return <Visuals_1.LeadingVisualContainer>{selected && <octicons_react_1.CheckIcon />}</Visuals_1.LeadingVisualContainer>;
26
+ }
27
+ /**
28
+ * selectionVariant is multiple
29
+ * readOnly is required because we are doing a one-way bind to `checked`
30
+ * aria-readonly="false" tells screen that they can still interact with the checkbox
31
+ */
32
+ return (<Visuals_1.LeadingVisualContainer sx={{ input: { margin: 0, pointerEvents: 'none' } }}>
33
+ <input type="checkbox" checked={selected} disabled={disabled} tabIndex={-1} readOnly aria-readonly="false"/>
34
+ </Visuals_1.LeadingVisualContainer>);
35
+ };
36
+ exports.Selection = Selection;
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.TrailingVisual = exports.LeadingVisual = exports.LeadingVisualContainer = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Box_1 = __importDefault(require("../Box"));
9
+ const sx_1 = require("../sx");
10
+ const constants_1 = require("../constants");
11
+ const Item_1 = require("./Item");
12
+ const LeadingVisualContainer = ({ sx = {}, ...props }) => {
13
+ return (<Box_1.default as="span" sx={sx_1.merge({
14
+ height: Item_1.TEXT_ROW_HEIGHT,
15
+ minWidth: constants_1.get('space.3'),
16
+ maxWidth: Item_1.TEXT_ROW_HEIGHT,
17
+ display: 'flex',
18
+ justifyContent: 'center',
19
+ alignItems: 'center',
20
+ flexShrink: 0,
21
+ marginRight: 2
22
+ }, sx)} {...props}/>);
23
+ };
24
+ exports.LeadingVisualContainer = LeadingVisualContainer;
25
+ const LeadingVisual = ({ sx = {}, ...props }) => {
26
+ return (<Item_1.Slot name="LeadingVisual">
27
+ {({ variant, disabled }) => (<exports.LeadingVisualContainer sx={sx_1.merge({
28
+ color: Item_1.getVariantStyles(variant, disabled).iconColor,
29
+ svg: { fontSize: 0 }
30
+ }, sx)} {...props}>
31
+ {props.children}
32
+ </exports.LeadingVisualContainer>)}
33
+ </Item_1.Slot>);
34
+ };
35
+ exports.LeadingVisual = LeadingVisual;
36
+ const TrailingVisual = ({ sx = {}, ...props }) => {
37
+ return (<Item_1.Slot name="TrailingVisual">
38
+ {({ variant, disabled }) => (<Box_1.default as="span" sx={sx_1.merge({
39
+ height: '20px',
40
+ flexShrink: 0,
41
+ color: Item_1.getVariantStyles(variant, disabled).annotationColor,
42
+ marginLeft: 2
43
+ }, sx)} {...props}>
44
+ {props.children}
45
+ </Box_1.default>)}
46
+ </Item_1.Slot>);
47
+ };
48
+ exports.TrailingVisual = TrailingVisual;
@@ -1,47 +1,29 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
2
+ Object.defineProperty(exports, "__esModule", { value: true });
6
3
  exports.ActionList = void 0;
7
-
8
- var _List = require("./List");
9
-
10
- var _Group = require("./Group");
11
-
12
- var _Item = require("./Item");
13
-
14
- var _LinkItem = require("./LinkItem");
15
-
16
- var _Divider = require("./Divider");
17
-
18
- var _Description = require("./Description");
19
-
20
- var _Visuals = require("./Visuals");
21
-
4
+ const List_1 = require("./List");
5
+ const Group_1 = require("./Group");
6
+ const Item_1 = require("./Item");
7
+ const LinkItem_1 = require("./LinkItem");
8
+ const Divider_1 = require("./Divider");
9
+ const Description_1 = require("./Description");
10
+ const Visuals_1 = require("./Visuals");
22
11
  /**
23
12
  * Collection of list-related components.
24
13
  */
25
- const ActionList = Object.assign(_List.List, {
26
- /** Collects related `Items` in an `ActionList`. */
27
- Group: _Group.Group,
28
-
29
- /** An actionable or selectable `Item` */
30
- Item: _Item.Item,
31
-
32
- /** A `Item` that renders a full-size anchor inside ListItem */
33
- LinkItem: _LinkItem.LinkItem,
34
-
35
- /** Visually separates `Item`s or `Group`s in an `ActionList`. */
36
- Divider: _Divider.Divider,
37
-
38
- /** Secondary text which provides additional information about an `Item`. */
39
- Description: _Description.Description,
40
-
41
- /** Icon (or similar) positioned before `Item` text. */
42
- LeadingVisual: _Visuals.LeadingVisual,
43
-
44
- /** Icon (or similar) positioned after `Item` text. */
45
- TrailingVisual: _Visuals.TrailingVisual
14
+ exports.ActionList = Object.assign(List_1.List, {
15
+ /** Collects related `Items` in an `ActionList`. */
16
+ Group: Group_1.Group,
17
+ /** An actionable or selectable `Item` */
18
+ Item: Item_1.Item,
19
+ /** A `Item` that renders a full-size anchor inside ListItem */
20
+ LinkItem: LinkItem_1.LinkItem,
21
+ /** Visually separates `Item`s or `Group`s in an `ActionList`. */
22
+ Divider: Divider_1.Divider,
23
+ /** Secondary text which provides additional information about an `Item`. */
24
+ Description: Description_1.Description,
25
+ /** Icon (or similar) positioned before `Item` text. */
26
+ LeadingVisual: Visuals_1.LeadingVisual,
27
+ /** Icon (or similar) positioned after `Item` text. */
28
+ TrailingVisual: Visuals_1.TrailingVisual
46
29
  });
47
- exports.ActionList = ActionList;
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.ActionMenu = void 0;
26
+ const List_1 = require("./ActionList/List");
27
+ const Item_1 = require("./ActionList/Item");
28
+ const Divider_1 = require("./ActionList/Divider");
29
+ const Button_1 = __importDefault(require("./Button"));
30
+ const react_1 = __importStar(require("react"));
31
+ const AnchoredOverlay_1 = require("./AnchoredOverlay");
32
+ const useProvidedStateOrCreate_1 = require("./hooks/useProvidedStateOrCreate");
33
+ const hooks_1 = require("./hooks");
34
+ const ActionMenuItem = (props) => <Item_1.Item role="menuitem" {...props}/>;
35
+ ActionMenuItem.displayName = 'ActionMenu.Item';
36
+ const ActionMenuBase = ({ anchorContent, renderAnchor = (props) => <Button_1.default {...props}/>, anchorRef: externalAnchorRef, onAction, open, setOpen, overlayProps, items, ...listProps }) => {
37
+ const [combinedOpenState, setCombinedOpenState] = useProvidedStateOrCreate_1.useProvidedStateOrCreate(open, setOpen, false);
38
+ const anchorRef = hooks_1.useProvidedRefOrCreate(externalAnchorRef);
39
+ const onOpen = react_1.useCallback(() => setCombinedOpenState(true), [setCombinedOpenState]);
40
+ const onClose = react_1.useCallback(() => setCombinedOpenState(false), [setCombinedOpenState]);
41
+ const renderMenuAnchor = react_1.useMemo(() => {
42
+ if (renderAnchor === null) {
43
+ return null;
44
+ }
45
+ return (props) => {
46
+ return renderAnchor({
47
+ 'aria-label': 'menu',
48
+ children: anchorContent,
49
+ ...props
50
+ });
51
+ };
52
+ }, [anchorContent, renderAnchor]);
53
+ const itemsToRender = react_1.useMemo(() => {
54
+ return items.map(item => {
55
+ return {
56
+ ...item,
57
+ role: 'menuitem',
58
+ onAction: (props, event) => {
59
+ const actionCallback = item.onAction ?? onAction;
60
+ actionCallback?.(props, event);
61
+ if (!event.defaultPrevented) {
62
+ onClose();
63
+ }
64
+ }
65
+ };
66
+ });
67
+ }, [items, onAction, onClose]);
68
+ return (<AnchoredOverlay_1.AnchoredOverlay renderAnchor={renderMenuAnchor} anchorRef={anchorRef} open={combinedOpenState} onOpen={onOpen} onClose={onClose} overlayProps={overlayProps}>
69
+ <List_1.List {...listProps} role="menu" items={itemsToRender}/>
70
+ </AnchoredOverlay_1.AnchoredOverlay>);
71
+ };
72
+ ActionMenuBase.displayName = 'ActionMenu';
73
+ exports.ActionMenu = Object.assign(ActionMenuBase, { Divider: Divider_1.Divider, Item: ActionMenuItem });