@primer/components 31.2.0-rc.fbb10090 → 31.2.1-rc.48ecca6e

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 (502) 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 +22 -0
  5. package/dist/browser.esm.js +661 -648
  6. package/dist/browser.esm.js.map +1 -1
  7. package/dist/browser.umd.js +215 -202
  8. package/dist/browser.umd.js.map +1 -1
  9. package/docs/content/ActionList2.mdx +358 -0
  10. package/docs/content/{Box.md → Box.mdx} +22 -0
  11. package/docs/content/StateLabel.md +5 -4
  12. package/docs/content/getting-started.md +1 -1
  13. package/docs/src/@primer/gatsby-theme-doctocat/components/hero.js +1 -3
  14. package/docs/src/@primer/gatsby-theme-doctocat/components/live-preview-wrapper.js +1 -1
  15. package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +17 -0
  16. package/docs/src/component-checklist.js +81 -0
  17. package/lib/ActionList/Divider.jsx +29 -0
  18. package/lib/ActionList/Group.jsx +23 -0
  19. package/lib/ActionList/Header.jsx +66 -0
  20. package/lib/ActionList/Item.js +28 -19
  21. package/lib/ActionList/Item.jsx +311 -0
  22. package/lib/ActionList/List.jsx +138 -0
  23. package/lib/ActionList/index.js +12 -23
  24. package/lib/ActionList2/Description.d.ts +12 -0
  25. package/lib/ActionList2/Description.js +57 -0
  26. package/lib/ActionList2/Description.jsx +29 -0
  27. package/lib/ActionList2/Divider.d.ts +5 -0
  28. package/lib/ActionList2/Divider.js +35 -0
  29. package/lib/ActionList2/Divider.jsx +22 -0
  30. package/lib/ActionList2/Group.d.ts +11 -0
  31. package/lib/ActionList2/Group.js +57 -0
  32. package/lib/ActionList2/Group.jsx +25 -0
  33. package/lib/ActionList2/Header.d.ts +26 -0
  34. package/lib/ActionList2/Header.js +55 -0
  35. package/lib/ActionList2/Header.jsx +36 -0
  36. package/lib/ActionList2/Item.d.ts +63 -0
  37. package/lib/ActionList2/Item.js +242 -0
  38. package/lib/ActionList2/Item.jsx +174 -0
  39. package/lib/ActionList2/LinkItem.d.ts +17 -0
  40. package/lib/ActionList2/LinkItem.js +57 -0
  41. package/lib/ActionList2/LinkItem.jsx +28 -0
  42. package/lib/ActionList2/List.d.ts +26 -0
  43. package/lib/ActionList2/List.js +59 -0
  44. package/lib/ActionList2/List.jsx +41 -0
  45. package/lib/ActionList2/Selection.d.ts +5 -0
  46. package/lib/ActionList2/Selection.js +84 -0
  47. package/lib/ActionList2/Selection.jsx +50 -0
  48. package/lib/ActionList2/Visuals.d.ts +9 -0
  49. package/lib/ActionList2/Visuals.js +90 -0
  50. package/lib/ActionList2/Visuals.jsx +48 -0
  51. package/lib/ActionList2/index.d.ts +36 -0
  52. package/lib/ActionList2/index.js +29 -0
  53. package/lib/ActionMenu.jsx +73 -0
  54. package/lib/AnchoredOverlay/AnchoredOverlay.jsx +100 -0
  55. package/lib/AnchoredOverlay/index.js +4 -12
  56. package/lib/Autocomplete/Autocomplete.d.ts +28 -28
  57. package/lib/Autocomplete/Autocomplete.jsx +100 -0
  58. package/lib/Autocomplete/AutocompleteContext.jsx +5 -0
  59. package/lib/Autocomplete/AutocompleteInput.d.ts +28 -28
  60. package/lib/Autocomplete/AutocompleteInput.jsx +113 -0
  61. package/lib/Autocomplete/AutocompleteMenu.jsx +190 -0
  62. package/lib/Autocomplete/AutocompleteOverlay.jsx +55 -0
  63. package/lib/Autocomplete/index.js +7 -14
  64. package/lib/Avatar.jsx +34 -0
  65. package/lib/AvatarPair.jsx +29 -0
  66. package/lib/AvatarStack.jsx +151 -0
  67. package/lib/BaseStyles.jsx +65 -0
  68. package/lib/BorderBox.jsx +18 -0
  69. package/lib/Box.jsx +10 -0
  70. package/lib/BranchName.jsx +20 -0
  71. package/lib/Breadcrumbs.jsx +74 -0
  72. package/lib/Button/Button.d.ts +25 -25
  73. package/lib/Button/Button.jsx +60 -0
  74. package/lib/Button/ButtonBase.jsx +36 -0
  75. package/lib/Button/ButtonClose.d.ts +45 -45
  76. package/lib/Button/ButtonClose.jsx +55 -0
  77. package/lib/Button/ButtonDanger.d.ts +25 -25
  78. package/lib/Button/ButtonDanger.jsx +63 -0
  79. package/lib/Button/ButtonGroup.jsx +55 -0
  80. package/lib/Button/ButtonInvisible.d.ts +25 -25
  81. package/lib/Button/ButtonInvisible.jsx +52 -0
  82. package/lib/Button/ButtonOutline.d.ts +25 -25
  83. package/lib/Button/ButtonOutline.jsx +63 -0
  84. package/lib/Button/ButtonPrimary.d.ts +25 -25
  85. package/lib/Button/ButtonPrimary.jsx +62 -0
  86. package/lib/Button/ButtonStyles.jsx +37 -0
  87. package/lib/Button/ButtonTableList.jsx +49 -0
  88. package/lib/Button/index.js +21 -70
  89. package/lib/Caret.jsx +93 -0
  90. package/lib/CircleBadge.jsx +43 -0
  91. package/lib/CircleOcticon.d.ts +42 -42
  92. package/lib/CircleOcticon.jsx +21 -0
  93. package/lib/CounterLabel.jsx +44 -0
  94. package/lib/Details.jsx +21 -0
  95. package/lib/Dialog/ConfirmationDialog.jsx +146 -0
  96. package/lib/Dialog/Dialog.js +1 -0
  97. package/lib/Dialog/Dialog.jsx +273 -0
  98. package/lib/Dialog.d.ts +45 -45
  99. package/lib/Dialog.jsx +131 -0
  100. package/lib/Dropdown.d.ts +176 -176
  101. package/lib/Dropdown.jsx +134 -0
  102. package/lib/DropdownMenu/DropdownButton.d.ts +46 -46
  103. package/lib/DropdownMenu/DropdownButton.jsx +14 -0
  104. package/lib/DropdownMenu/DropdownMenu.jsx +70 -0
  105. package/lib/DropdownMenu/index.js +6 -20
  106. package/lib/DropdownStyles.js +18 -26
  107. package/lib/FilterList.d.ts +42 -42
  108. package/lib/FilterList.jsx +63 -0
  109. package/lib/FilteredActionList/FilteredActionList.jsx +100 -0
  110. package/lib/FilteredActionList/index.js +4 -12
  111. package/lib/FilteredSearch.jsx +29 -0
  112. package/lib/Flash.jsx +70 -0
  113. package/lib/Flex.jsx +15 -0
  114. package/lib/FormGroup.jsx +25 -0
  115. package/lib/Grid.jsx +15 -0
  116. package/lib/Header.jsx +90 -0
  117. package/lib/Heading.jsx +21 -0
  118. package/lib/Label.jsx +84 -0
  119. package/lib/LabelGroup.jsx +19 -0
  120. package/lib/Link.jsx +38 -0
  121. package/lib/NewButton/button-counter.d.ts +6 -0
  122. package/lib/NewButton/button-counter.js +31 -0
  123. package/lib/NewButton/button-counter.jsx +14 -0
  124. package/lib/NewButton/button.d.ts +13 -0
  125. package/lib/NewButton/button.js +316 -0
  126. package/lib/NewButton/button.jsx +278 -0
  127. package/lib/NewButton/index.d.ts +14 -0
  128. package/lib/NewButton/index.js +8 -0
  129. package/lib/NewButton/types.d.ts +32 -0
  130. package/lib/NewButton/types.js +2 -0
  131. package/lib/Overlay.js +3 -1
  132. package/lib/Overlay.jsx +156 -0
  133. package/lib/Pagehead.jsx +18 -0
  134. package/lib/Pagination/Pagination.jsx +163 -0
  135. package/lib/Pagination/index.js +6 -12
  136. package/lib/Pagination/model.jsx +174 -0
  137. package/lib/PointerBox.jsx +25 -0
  138. package/lib/Popover.jsx +210 -0
  139. package/lib/Portal/Portal.js +3 -2
  140. package/lib/Portal/Portal.jsx +79 -0
  141. package/lib/Portal/index.js +5 -16
  142. package/lib/Position.d.ts +4 -4
  143. package/lib/Position.jsx +46 -0
  144. package/lib/ProgressBar.jsx +39 -0
  145. package/lib/SelectMenu/SelectMenu.d.ts +246 -246
  146. package/lib/SelectMenu/SelectMenu.jsx +114 -0
  147. package/lib/SelectMenu/SelectMenuContext.jsx +5 -0
  148. package/lib/SelectMenu/SelectMenuDivider.jsx +43 -0
  149. package/lib/SelectMenu/SelectMenuFilter.jsx +59 -0
  150. package/lib/SelectMenu/SelectMenuFooter.jsx +46 -0
  151. package/lib/SelectMenu/SelectMenuHeader.jsx +44 -0
  152. package/lib/SelectMenu/SelectMenuItem.d.ts +1 -1
  153. package/lib/SelectMenu/SelectMenuItem.jsx +143 -0
  154. package/lib/SelectMenu/SelectMenuList.jsx +60 -0
  155. package/lib/SelectMenu/SelectMenuLoadingAnimation.jsx +21 -0
  156. package/lib/SelectMenu/SelectMenuModal.d.ts +1 -1
  157. package/lib/SelectMenu/SelectMenuModal.jsx +119 -0
  158. package/lib/SelectMenu/SelectMenuTab.jsx +93 -0
  159. package/lib/SelectMenu/SelectMenuTabPanel.jsx +43 -0
  160. package/lib/SelectMenu/SelectMenuTabs.jsx +58 -0
  161. package/lib/SelectMenu/hooks/useKeyboardNav.js +80 -96
  162. package/lib/SelectMenu/index.js +7 -14
  163. package/lib/SelectPanel/SelectPanel.jsx +105 -0
  164. package/lib/SelectPanel/index.js +4 -12
  165. package/lib/SideNav.jsx +177 -0
  166. package/lib/Spinner.jsx +35 -0
  167. package/lib/StateLabel.d.ts +1 -1
  168. package/lib/StateLabel.js +6 -1
  169. package/lib/StateLabel.jsx +94 -0
  170. package/lib/StyledOcticon.jsx +20 -0
  171. package/lib/SubNav.jsx +104 -0
  172. package/lib/TabNav.jsx +60 -0
  173. package/lib/Text.jsx +14 -0
  174. package/lib/TextInput.jsx +23 -0
  175. package/lib/TextInputWithTokens.d.ts +28 -28
  176. package/lib/TextInputWithTokens.jsx +218 -0
  177. package/lib/ThemeProvider.jsx +130 -0
  178. package/lib/Timeline.d.ts +43 -43
  179. package/lib/Timeline.jsx +124 -0
  180. package/lib/Token/AvatarToken.d.ts +1 -1
  181. package/lib/Token/AvatarToken.jsx +54 -0
  182. package/lib/Token/IssueLabelToken.d.ts +1 -1
  183. package/lib/Token/IssueLabelToken.jsx +125 -0
  184. package/lib/Token/Token.d.ts +1 -1
  185. package/lib/Token/Token.jsx +103 -0
  186. package/lib/Token/TokenBase.jsx +88 -0
  187. package/lib/Token/_RemoveTokenButton.jsx +108 -0
  188. package/lib/Token/_TokenTextContainer.jsx +49 -0
  189. package/lib/Token/index.js +11 -30
  190. package/lib/Tooltip.jsx +246 -0
  191. package/lib/Truncate.jsx +27 -0
  192. package/lib/UnderlineNav.jsx +90 -0
  193. package/lib/_TextInputWrapper.js +2 -2
  194. package/lib/_TextInputWrapper.jsx +120 -0
  195. package/lib/_UnstyledTextInput.jsx +22 -0
  196. package/lib/__tests__/ActionList.test.jsx +49 -0
  197. package/lib/__tests__/ActionList.types.test.jsx +45 -0
  198. package/lib/__tests__/ActionList2.test.d.ts +1 -0
  199. package/lib/__tests__/ActionList2.test.js +53 -0
  200. package/lib/__tests__/ActionList2.test.jsx +46 -0
  201. package/lib/__tests__/ActionMenu.test.jsx +124 -0
  202. package/lib/__tests__/AnchoredOverlay.test.js +4 -2
  203. package/lib/__tests__/AnchoredOverlay.test.jsx +121 -0
  204. package/lib/__tests__/Autocomplete.test.jsx +299 -0
  205. package/lib/__tests__/Avatar.test.jsx +42 -0
  206. package/lib/__tests__/AvatarStack.test.jsx +43 -0
  207. package/lib/__tests__/BorderBox.test.jsx +36 -0
  208. package/lib/__tests__/Box.test.jsx +41 -0
  209. package/lib/__tests__/BranchName.test.jsx +27 -0
  210. package/lib/__tests__/Breadcrumbs.test.jsx +28 -0
  211. package/lib/__tests__/BreadcrumbsItem.test.jsx +31 -0
  212. package/lib/__tests__/Button.test.jsx +100 -0
  213. package/lib/__tests__/Caret.test.jsx +37 -0
  214. package/lib/__tests__/CircleBadge.test.jsx +55 -0
  215. package/lib/__tests__/CircleOcticon.test.jsx +45 -0
  216. package/lib/__tests__/ConfirmationDialog.test.jsx +119 -0
  217. package/lib/__tests__/CounterLabel.test.jsx +36 -0
  218. package/lib/__tests__/Details.test.jsx +85 -0
  219. package/lib/__tests__/Dialog.test.jsx +139 -0
  220. package/lib/__tests__/Dropdown.test.jsx +49 -0
  221. package/lib/__tests__/DropdownMenu.test.jsx +119 -0
  222. package/lib/__tests__/FilterList.test.jsx +27 -0
  223. package/lib/__tests__/FilterListItem.test.jsx +31 -0
  224. package/lib/__tests__/FilteredSearch.test.jsx +27 -0
  225. package/lib/__tests__/Flash.test.jsx +36 -0
  226. package/lib/__tests__/Flex.test.jsx +51 -0
  227. package/lib/__tests__/FormGroup.test.jsx +36 -0
  228. package/lib/__tests__/Grid.test.jsx +69 -0
  229. package/lib/__tests__/Header.test.jsx +45 -0
  230. package/lib/__tests__/Heading.test.jsx +71 -0
  231. package/lib/__tests__/KeyPaths.types.test.d.ts +2 -1
  232. package/lib/__tests__/KeyPaths.types.test.js +5 -8
  233. package/lib/__tests__/Label.test.jsx +33 -0
  234. package/lib/__tests__/LabelGroup.test.jsx +29 -0
  235. package/lib/__tests__/Link.test.jsx +43 -0
  236. package/lib/__tests__/Merge.types.test.js +13 -19
  237. package/lib/__tests__/NewButton.test.d.ts +1 -0
  238. package/lib/__tests__/NewButton.test.js +95 -0
  239. package/lib/__tests__/NewButton.test.jsx +61 -0
  240. package/lib/__tests__/Overlay.test.jsx +105 -0
  241. package/lib/__tests__/Pagehead.test.jsx +25 -0
  242. package/lib/__tests__/Pagination/Pagination.test.jsx +32 -0
  243. package/lib/__tests__/Pagination/PaginationModel.test.jsx +118 -0
  244. package/lib/__tests__/PointerBox.test.jsx +33 -0
  245. package/lib/__tests__/Popover.test.jsx +58 -0
  246. package/lib/__tests__/Portal.test.jsx +102 -0
  247. package/lib/__tests__/Position.test.jsx +96 -0
  248. package/lib/__tests__/ProgressBar.test.jsx +38 -0
  249. package/lib/__tests__/SelectMenu.test.jsx +120 -0
  250. package/lib/__tests__/SelectPanel.test.jsx +48 -0
  251. package/lib/__tests__/SideNav.test.jsx +55 -0
  252. package/lib/__tests__/Spinner.test.jsx +41 -0
  253. package/lib/__tests__/StateLabel.test.jsx +46 -0
  254. package/lib/__tests__/StyledOcticon.test.jsx +28 -0
  255. package/lib/__tests__/SubNav.test.jsx +47 -0
  256. package/lib/__tests__/SubNavLink.test.jsx +31 -0
  257. package/lib/__tests__/TabNav.test.jsx +32 -0
  258. package/lib/__tests__/Text.test.jsx +71 -0
  259. package/lib/__tests__/TextInput.test.jsx +45 -0
  260. package/lib/__tests__/TextInputWithTokens.test.js +1 -10
  261. package/lib/__tests__/TextInputWithTokens.test.jsx +302 -0
  262. package/lib/__tests__/ThemeProvider.test.jsx +314 -0
  263. package/lib/__tests__/Timeline.test.jsx +51 -0
  264. package/lib/__tests__/Token.test.jsx +93 -0
  265. package/lib/__tests__/Tooltip.test.jsx +46 -0
  266. package/lib/__tests__/Truncate.test.jsx +41 -0
  267. package/lib/__tests__/UnderlineNav.test.jsx +53 -0
  268. package/lib/__tests__/UnderlineNavLink.test.jsx +31 -0
  269. package/lib/__tests__/behaviors/anchoredPosition.test.js +229 -376
  270. package/lib/__tests__/behaviors/focusTrap.test.jsx +184 -0
  271. package/lib/__tests__/behaviors/focusZone.test.jsx +406 -0
  272. package/lib/__tests__/behaviors/iterateFocusableElements.test.jsx +58 -0
  273. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.js +145 -216
  274. package/lib/__tests__/filterObject.test.js +48 -27
  275. package/lib/__tests__/hooks/useAnchoredPosition.test.jsx +29 -0
  276. package/lib/__tests__/hooks/useOnEscapePress.test.jsx +19 -0
  277. package/lib/__tests__/hooks/useOnOutsideClick.test.jsx +63 -0
  278. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.jsx +61 -0
  279. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.jsx +56 -0
  280. package/lib/__tests__/theme.test.js +33 -34
  281. package/lib/__tests__/themeGet.test.js +12 -23
  282. package/lib/__tests__/useSafeTimeout.test.jsx +36 -0
  283. package/lib/__tests__/utils/createSlots.test.d.ts +1 -0
  284. package/lib/__tests__/utils/createSlots.test.js +75 -0
  285. package/lib/__tests__/utils/createSlots.test.jsx +57 -0
  286. package/lib/behaviors/anchoredPosition.js +205 -234
  287. package/lib/behaviors/focusTrap.js +121 -157
  288. package/lib/behaviors/focusZone.js +434 -509
  289. package/lib/behaviors/scrollIntoViewingArea.js +18 -35
  290. package/lib/constants.js +39 -43
  291. package/lib/drafts.d.ts +8 -0
  292. package/lib/drafts.js +21 -0
  293. package/lib/hooks/index.js +16 -60
  294. package/lib/hooks/useAnchoredPosition.js +32 -39
  295. package/lib/hooks/useCombinedRefs.d.ts +2 -2
  296. package/lib/hooks/useCombinedRefs.js +32 -38
  297. package/lib/hooks/useDetails.jsx +39 -0
  298. package/lib/hooks/useDialog.js +72 -96
  299. package/lib/hooks/useFocusTrap.js +43 -60
  300. package/lib/hooks/useFocusZone.js +54 -50
  301. package/lib/hooks/useOnEscapePress.js +25 -36
  302. package/lib/hooks/useOnOutsideClick.jsx +61 -0
  303. package/lib/hooks/useOpenAndCloseFocus.js +22 -34
  304. package/lib/hooks/useOverlay.jsx +15 -0
  305. package/lib/hooks/useProvidedRefOrCreate.js +10 -14
  306. package/lib/hooks/useProvidedStateOrCreate.js +13 -16
  307. package/lib/hooks/useRenderForcingRef.js +13 -17
  308. package/lib/hooks/useResizeObserver.js +15 -18
  309. package/lib/hooks/useSafeTimeout.js +22 -30
  310. package/lib/hooks/useScrollFlash.js +16 -23
  311. package/lib/index.d.ts +2 -0
  312. package/lib/index.js +163 -636
  313. package/lib/polyfills/eventListenerSignal.js +37 -45
  314. package/lib/stories/ActionList2.stories.js +908 -0
  315. package/lib/stories/NewButton.stories.js +230 -0
  316. package/lib/stories/TextInput.stories.js +144 -0
  317. package/lib/stories/Token.stories.js +19 -2
  318. package/lib/sx.d.ts +2 -0
  319. package/lib/sx.js +10 -14
  320. package/lib/theme-preval.js +65 -2945
  321. package/lib/theme.js +3 -12
  322. package/lib/utils/create-slots.d.ts +17 -0
  323. package/lib/utils/create-slots.js +105 -0
  324. package/lib/utils/create-slots.jsx +65 -0
  325. package/lib/utils/deprecate.jsx +59 -0
  326. package/lib/utils/isNumeric.jsx +7 -0
  327. package/lib/utils/iterateFocusableElements.js +63 -85
  328. package/lib/utils/ssr.jsx +6 -0
  329. package/lib/utils/test-deprecations.jsx +20 -0
  330. package/lib/utils/test-helpers.jsx +8 -0
  331. package/lib/utils/test-matchers.jsx +100 -0
  332. package/lib/utils/testing.d.ts +14 -1
  333. package/lib/utils/testing.jsx +206 -0
  334. package/lib/utils/theme.js +33 -47
  335. package/lib/utils/types/AriaRole.js +2 -1
  336. package/lib/utils/types/ComponentProps.js +2 -1
  337. package/lib/utils/types/Flatten.js +2 -1
  338. package/lib/utils/types/KeyPaths.d.ts +1 -1
  339. package/lib/utils/types/KeyPaths.js +2 -1
  340. package/lib/utils/types/MandateProps.js +16 -1
  341. package/lib/utils/types/Merge.js +2 -1
  342. package/lib/utils/types/index.js +16 -69
  343. package/lib/utils/uniqueId.js +5 -8
  344. package/lib/utils/use-force-update.d.ts +1 -0
  345. package/lib/utils/use-force-update.js +13 -0
  346. package/lib/utils/useIsomorphicLayoutEffect.d.ts +3 -0
  347. package/lib/utils/useIsomorphicLayoutEffect.js +9 -0
  348. package/lib/utils/userAgent.js +8 -12
  349. package/lib-esm/ActionList/Item.js +28 -19
  350. package/lib-esm/ActionList2/Description.d.ts +12 -0
  351. package/lib-esm/ActionList2/Description.js +41 -0
  352. package/lib-esm/ActionList2/Divider.d.ts +5 -0
  353. package/lib-esm/ActionList2/Divider.js +23 -0
  354. package/lib-esm/ActionList2/Group.d.ts +11 -0
  355. package/lib-esm/ActionList2/Group.js +40 -0
  356. package/lib-esm/ActionList2/Header.d.ts +26 -0
  357. package/lib-esm/ActionList2/Header.js +44 -0
  358. package/lib-esm/ActionList2/Item.d.ts +63 -0
  359. package/lib-esm/ActionList2/Item.js +208 -0
  360. package/lib-esm/ActionList2/LinkItem.d.ts +17 -0
  361. package/lib-esm/ActionList2/LinkItem.js +43 -0
  362. package/lib-esm/ActionList2/List.d.ts +26 -0
  363. package/lib-esm/ActionList2/List.js +37 -0
  364. package/lib-esm/ActionList2/Selection.d.ts +5 -0
  365. package/lib-esm/ActionList2/Selection.js +66 -0
  366. package/lib-esm/ActionList2/Visuals.d.ts +9 -0
  367. package/lib-esm/ActionList2/Visuals.js +68 -0
  368. package/lib-esm/ActionList2/index.d.ts +36 -0
  369. package/lib-esm/ActionList2/index.js +33 -0
  370. package/lib-esm/Autocomplete/Autocomplete.d.ts +28 -28
  371. package/lib-esm/Autocomplete/AutocompleteInput.d.ts +28 -28
  372. package/lib-esm/Button/Button.d.ts +25 -25
  373. package/lib-esm/Button/ButtonClose.d.ts +45 -45
  374. package/lib-esm/Button/ButtonDanger.d.ts +25 -25
  375. package/lib-esm/Button/ButtonInvisible.d.ts +25 -25
  376. package/lib-esm/Button/ButtonOutline.d.ts +25 -25
  377. package/lib-esm/Button/ButtonPrimary.d.ts +25 -25
  378. package/lib-esm/CircleOcticon.d.ts +42 -42
  379. package/lib-esm/Dialog/Dialog.js +1 -0
  380. package/lib-esm/Dialog.d.ts +45 -45
  381. package/lib-esm/Dropdown.d.ts +176 -176
  382. package/lib-esm/DropdownMenu/DropdownButton.d.ts +46 -46
  383. package/lib-esm/FilterList.d.ts +42 -42
  384. package/lib-esm/NewButton/button-counter.d.ts +6 -0
  385. package/lib-esm/NewButton/button-counter.js +18 -0
  386. package/lib-esm/NewButton/button.d.ts +13 -0
  387. package/lib-esm/NewButton/button.js +298 -0
  388. package/lib-esm/NewButton/index.d.ts +14 -0
  389. package/lib-esm/NewButton/index.js +5 -0
  390. package/lib-esm/NewButton/types.d.ts +32 -0
  391. package/lib-esm/NewButton/types.js +1 -0
  392. package/lib-esm/Overlay.js +2 -1
  393. package/lib-esm/Portal/Portal.js +2 -1
  394. package/lib-esm/Position.d.ts +4 -4
  395. package/lib-esm/SelectMenu/SelectMenu.d.ts +246 -246
  396. package/lib-esm/SelectMenu/SelectMenuItem.d.ts +1 -1
  397. package/lib-esm/SelectMenu/SelectMenuModal.d.ts +1 -1
  398. package/lib-esm/StateLabel.d.ts +1 -1
  399. package/lib-esm/StateLabel.js +7 -2
  400. package/lib-esm/TextInputWithTokens.d.ts +28 -28
  401. package/lib-esm/Timeline.d.ts +43 -43
  402. package/lib-esm/Token/AvatarToken.d.ts +1 -1
  403. package/lib-esm/Token/IssueLabelToken.d.ts +1 -1
  404. package/lib-esm/Token/Token.d.ts +1 -1
  405. package/lib-esm/_TextInputWrapper.js +2 -2
  406. package/lib-esm/__tests__/ActionList2.test.d.ts +1 -0
  407. package/lib-esm/__tests__/ActionList2.test.js +41 -0
  408. package/lib-esm/__tests__/AnchoredOverlay.test.js +4 -2
  409. package/lib-esm/__tests__/KeyPaths.types.test.d.ts +2 -1
  410. package/lib-esm/__tests__/NewButton.test.d.ts +1 -0
  411. package/lib-esm/__tests__/NewButton.test.js +84 -0
  412. package/lib-esm/__tests__/TextInputWithTokens.test.js +1 -10
  413. package/lib-esm/__tests__/utils/createSlots.test.d.ts +1 -0
  414. package/lib-esm/__tests__/utils/createSlots.test.js +67 -0
  415. package/lib-esm/drafts.d.ts +8 -0
  416. package/lib-esm/drafts.js +9 -0
  417. package/lib-esm/hooks/useAnchoredPosition.js +2 -1
  418. package/lib-esm/hooks/useCombinedRefs.d.ts +2 -2
  419. package/lib-esm/hooks/useCombinedRefs.js +3 -2
  420. package/lib-esm/hooks/useResizeObserver.js +2 -2
  421. package/lib-esm/index.d.ts +2 -0
  422. package/lib-esm/index.js +1 -0
  423. package/lib-esm/stories/ActionList2.stories.js +796 -0
  424. package/lib-esm/stories/NewButton.stories.js +178 -0
  425. package/lib-esm/stories/TextInput.stories.js +117 -0
  426. package/lib-esm/stories/Token.stories.js +14 -1
  427. package/lib-esm/sx.d.ts +2 -0
  428. package/lib-esm/sx.js +3 -1
  429. package/lib-esm/theme-preval.js +81 -2
  430. package/lib-esm/utils/create-slots.d.ts +17 -0
  431. package/lib-esm/utils/create-slots.js +84 -0
  432. package/lib-esm/utils/testing.d.ts +14 -1
  433. package/lib-esm/utils/types/KeyPaths.d.ts +1 -1
  434. package/lib-esm/utils/use-force-update.d.ts +1 -0
  435. package/lib-esm/utils/use-force-update.js +6 -0
  436. package/lib-esm/utils/useIsomorphicLayoutEffect.d.ts +3 -0
  437. package/lib-esm/utils/useIsomorphicLayoutEffect.js +3 -0
  438. package/migrating.md +1 -1
  439. package/package-lock.json +168 -16
  440. package/package.json +9 -5
  441. package/script/build +3 -1
  442. package/src/ActionList/Item.tsx +32 -19
  443. package/src/ActionList2/Description.tsx +52 -0
  444. package/src/ActionList2/Divider.tsx +24 -0
  445. package/src/ActionList2/Group.tsx +34 -0
  446. package/src/ActionList2/Header.tsx +58 -0
  447. package/src/ActionList2/Item.tsx +246 -0
  448. package/src/ActionList2/LinkItem.tsx +49 -0
  449. package/src/ActionList2/List.tsx +55 -0
  450. package/src/ActionList2/Selection.tsx +60 -0
  451. package/src/ActionList2/Visuals.tsx +76 -0
  452. package/src/ActionList2/index.ts +39 -0
  453. package/src/Dialog/Dialog.tsx +1 -0
  454. package/src/NewButton/button-counter.tsx +15 -0
  455. package/src/NewButton/button.tsx +279 -0
  456. package/src/NewButton/index.ts +10 -0
  457. package/src/NewButton/types.ts +36 -0
  458. package/src/Overlay.tsx +2 -1
  459. package/src/Portal/Portal.tsx +2 -1
  460. package/src/StateLabel.tsx +14 -2
  461. package/src/_TextInputWrapper.tsx +7 -0
  462. package/src/__tests__/ActionList2.test.tsx +47 -0
  463. package/src/__tests__/AnchoredOverlay.test.tsx +2 -2
  464. package/src/__tests__/KeyPaths.types.test.ts +2 -1
  465. package/src/__tests__/NewButton.test.tsx +70 -0
  466. package/src/__tests__/TextInputWithTokens.test.tsx +0 -10
  467. package/src/__tests__/__snapshots__/ActionList2.test.tsx.snap +14 -0
  468. package/src/__tests__/__snapshots__/AnchoredOverlay.test.tsx.snap +35 -135
  469. package/src/__tests__/__snapshots__/Autocomplete.test.tsx.snap +722 -255
  470. package/src/__tests__/__snapshots__/CircleBadge.test.tsx.snap +1 -0
  471. package/src/__tests__/__snapshots__/CircleOcticon.test.tsx.snap +1 -0
  472. package/src/__tests__/__snapshots__/Dialog.test.tsx.snap +1 -0
  473. package/src/__tests__/__snapshots__/DropdownMenu.test.tsx.snap +1 -0
  474. package/src/__tests__/__snapshots__/NewButton.test.tsx.snap +300 -0
  475. package/src/__tests__/__snapshots__/SelectMenu.test.tsx.snap +4 -0
  476. package/src/__tests__/__snapshots__/SelectPanel.test.tsx.snap +1 -0
  477. package/src/__tests__/__snapshots__/StateLabel.test.tsx.snap +13 -6
  478. package/src/__tests__/__snapshots__/StyledOcticon.test.tsx.snap +1 -0
  479. package/src/__tests__/__snapshots__/TextInputWithTokens.test.tsx.snap +66 -0
  480. package/src/__tests__/__snapshots__/Token.test.tsx.snap +17 -0
  481. package/src/__tests__/utils/__snapshots__/createSlots.test.tsx.snap +55 -0
  482. package/src/__tests__/utils/createSlots.test.tsx +74 -0
  483. package/src/drafts.ts +10 -0
  484. package/src/hooks/useAnchoredPosition.ts +2 -1
  485. package/src/hooks/useCombinedRefs.ts +3 -3
  486. package/src/hooks/useResizeObserver.ts +2 -2
  487. package/src/index.ts +2 -0
  488. package/src/stories/ActionList2.stories.tsx +1291 -0
  489. package/src/stories/Button.stories.tsx +1 -1
  490. package/src/stories/NewButton.stories.tsx +201 -0
  491. package/src/stories/TextInput.stories.tsx +113 -0
  492. package/src/stories/Token.stories.tsx +12 -1
  493. package/src/sx.ts +3 -0
  494. package/src/theme-preval.js +1 -0
  495. package/src/utils/create-slots.tsx +96 -0
  496. package/src/utils/types/KeyPaths.ts +7 -1
  497. package/src/utils/use-force-update.ts +7 -0
  498. package/src/utils/useIsomorphicLayoutEffect.ts +10 -0
  499. package/stats.html +1 -1
  500. package/tsconfig.base.json +20 -0
  501. package/tsconfig.build.json +2 -2
  502. package/tsconfig.json +4 -17
@@ -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: 'primer.fg.disabled',
39
+ iconColor: 'primer.fg.disabled',
40
+ annotationColor: 'primer.fg.disabled'
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
+ cursor: 'pointer',
80
+ '&[aria-disabled]': { cursor: 'not-allowed' },
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}/>
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,17 @@
1
+ import React from 'react';
2
+ import { ForwardRefComponent as PolymorphicForwardRefComponent } from '@radix-ui/react-polymorphic';
3
+ import { ItemProps } from './Item';
4
+ declare type LinkProps = {
5
+ download?: string;
6
+ href?: string;
7
+ hrefLang?: string;
8
+ media?: string;
9
+ ping?: string;
10
+ rel?: string;
11
+ target?: string;
12
+ type?: string;
13
+ referrerPolicy?: React.AnchorHTMLAttributes<HTMLAnchorElement>['referrerPolicy'];
14
+ };
15
+ declare type LinkItemProps = Pick<ItemProps, 'children' | 'sx'> & LinkProps;
16
+ export declare const LinkItem: PolymorphicForwardRefComponent<"a", LinkItemProps>;
17
+ export {};
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.LinkItem = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _Link = _interopRequireDefault(require("../Link"));
11
+
12
+ var _sx = require("../sx");
13
+
14
+ var _Item = require("./Item");
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+
18
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
19
+
20
+ const LinkItem = /*#__PURE__*/_react.default.forwardRef(({
21
+ sx = {},
22
+ as: Component,
23
+ ...props
24
+ }, forwardedRef) => {
25
+ const styles = {
26
+ // occupy full size of Item
27
+ paddingX: 2,
28
+ paddingY: '6px',
29
+ // custom value off the scale
30
+ display: 'flex',
31
+ flexGrow: 1,
32
+ // full width
33
+ borderRadius: 2,
34
+ // inherit Item styles
35
+ color: 'inherit',
36
+ '&:hover': {
37
+ color: 'inherit',
38
+ textDecoration: 'none'
39
+ }
40
+ };
41
+ return /*#__PURE__*/_react.default.createElement(_Item.Item, {
42
+ sx: {
43
+ paddingY: 0,
44
+ paddingX: 0
45
+ },
46
+ _PrivateItemWrapper: ({
47
+ children
48
+ }) => /*#__PURE__*/_react.default.createElement(_Link.default, _extends({
49
+ as: Component,
50
+ sx: (0, _sx.merge)(styles, sx)
51
+ }, props, {
52
+ ref: forwardedRef
53
+ }), children)
54
+ }, props.children);
55
+ });
56
+
57
+ exports.LinkItem = LinkItem;
@@ -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,26 @@
1
+ import React from 'react';
2
+ import { ForwardRefComponent as PolymorphicForwardRefComponent } from '@radix-ui/react-polymorphic';
3
+ import { SxProp } from '../sx';
4
+ import { AriaRole } from '../utils/types';
5
+ export declare type ListProps = {
6
+ /**
7
+ * `inset` children are offset (vertically and horizontally) from `List`’s edges, `full` children are flush (vertically and horizontally) with `List` edges
8
+ */
9
+ variant?: 'inset' | 'full';
10
+ /**
11
+ * Whether multiple Items or a single Item can be selected.
12
+ */
13
+ selectionVariant?: 'single' | 'multiple';
14
+ /**
15
+ * Display a divider above each `Item` in this `List` when it does not follow a `Header` or `Divider`.
16
+ */
17
+ showDividers?: boolean;
18
+ /**
19
+ * The ARIA role describing the function of `List` component. `listbox` or `menu` are a common values.
20
+ */
21
+ role?: AriaRole;
22
+ } & SxProp;
23
+ declare type ContextProps = Omit<ListProps, 'sx'>;
24
+ export declare const ListContext: React.Context<ContextProps>;
25
+ export declare const List: PolymorphicForwardRefComponent<"ul", ListProps>;
26
+ export {};
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.List = exports.ListContext = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+
12
+ var _sx = _interopRequireWildcard(require("../sx"));
13
+
14
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
15
+
16
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+
20
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
21
+
22
+ const ListContext = /*#__PURE__*/_react.default.createContext({});
23
+
24
+ exports.ListContext = ListContext;
25
+
26
+ const ListBox = _styledComponents.default.ul.withConfig({
27
+ displayName: "List__ListBox",
28
+ componentId: "cvbq60-0"
29
+ })(_sx.default);
30
+
31
+ const List = /*#__PURE__*/_react.default.forwardRef(({
32
+ variant = 'inset',
33
+ selectionVariant,
34
+ showDividers = false,
35
+ sx: sxProp = {},
36
+ ...props
37
+ }, forwardedRef) => {
38
+ const styles = {
39
+ margin: 0,
40
+ paddingInlineStart: 0,
41
+ // reset ul styles
42
+ paddingY: variant === 'inset' ? 2 : 0
43
+ };
44
+ return /*#__PURE__*/_react.default.createElement(ListBox, _extends({
45
+ sx: (0, _sx.merge)(styles, sxProp),
46
+ "aria-multiselectable": selectionVariant === 'multiple' ? true : undefined
47
+ }, props, {
48
+ ref: forwardedRef
49
+ }), /*#__PURE__*/_react.default.createElement(ListContext.Provider, {
50
+ value: {
51
+ variant,
52
+ selectionVariant,
53
+ showDividers
54
+ }
55
+ }, props.children));
56
+ });
57
+
58
+ exports.List = List;
59
+ List.displayName = 'ActionList';
@@ -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,5 @@
1
+ import React from 'react';
2
+ import { ItemProps } from './Item';
3
+ declare type SelectionProps = Pick<ItemProps, 'selected'>;
4
+ export declare const Selection: React.FC<SelectionProps>;
5
+ export {};
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Selection = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _octiconsReact = require("@primer/octicons-react");
11
+
12
+ var _List = require("./List");
13
+
14
+ var _Group = require("./Group");
15
+
16
+ var _Visuals = require("./Visuals");
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+
20
+ const Selection = ({
21
+ selected
22
+ }) => {
23
+ const {
24
+ selectionVariant: listSelectionVariant
25
+ } = _react.default.useContext(_List.ListContext);
26
+
27
+ const {
28
+ selectionVariant: groupSelectionVariant
29
+ } = _react.default.useContext(_Group.GroupContext);
30
+ /** selectionVariant in Group can override the selectionVariant in List root */
31
+
32
+
33
+ const selectionVariant = typeof groupSelectionVariant !== 'undefined' ? groupSelectionVariant : listSelectionVariant; // if selectionVariant is not set on List, don't show selection
34
+
35
+ if (!selectionVariant) {
36
+ // to avoid confusion, fail loudly instead of silently ignoring
37
+ if (selected) throw new Error('For Item to be selected, ActionList or ActionList.Group needs to have a selectionVariant defined');
38
+ return null;
39
+ }
40
+
41
+ if (selectionVariant === 'single') {
42
+ return /*#__PURE__*/_react.default.createElement(_Visuals.LeadingVisualContainer, null, selected && /*#__PURE__*/_react.default.createElement(_octiconsReact.CheckIcon, null));
43
+ }
44
+ /**
45
+ * selectionVariant is multiple
46
+ * we use a svg instead of an input because there should not
47
+ * be an interactive element inside an option
48
+ * svg copied from primer/css
49
+ */
50
+
51
+
52
+ return /*#__PURE__*/_react.default.createElement(_Visuals.LeadingVisualContainer, {
53
+ sx: {
54
+ rect: {
55
+ fill: selected ? 'accent.fg' : 'canvas.default',
56
+ stroke: selected ? 'accent.fg' : 'border.default'
57
+ },
58
+ path: {
59
+ fill: 'fg.onEmphasis',
60
+ boxShadow: 'shadow.small',
61
+ opacity: selected ? 1 : 0
62
+ }
63
+ }
64
+ }, /*#__PURE__*/_react.default.createElement("svg", {
65
+ width: "16",
66
+ height: "16",
67
+ viewBox: "0 0 16 16",
68
+ xmlns: "http://www.w3.org/2000/svg",
69
+ "aria-hidden": "true"
70
+ }, /*#__PURE__*/_react.default.createElement("rect", {
71
+ x: "2",
72
+ y: "2",
73
+ width: "12",
74
+ height: "12",
75
+ rx: "4"
76
+ }), /*#__PURE__*/_react.default.createElement("path", {
77
+ fillRule: "evenodd",
78
+ strokeWidth: "0",
79
+ d: "M4.03231 8.69862C3.84775 8.20646 4.49385 7.77554 4.95539 7.77554C5.41693 7.77554 6.80154 9.85246 6.80154 9.85246C6.80154 9.85246 10.2631 4.314 10.4938 4.08323C10.7246 3.85246 11.8785 4.08323 11.4169 5.00631C11.0081 5.82388 7.26308 11.4678 7.26308 11.4678C7.26308 11.4678 6.80154 12.1602 6.34 11.4678C5.87846 10.7755 4.21687 9.19077 4.03231 8.69862Z"
80
+ })));
81
+ };
82
+
83
+ exports.Selection = Selection;
84
+ Selection.displayName = "Selection";
@@ -0,0 +1,50 @@
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 }) => {
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
+ * we use a svg instead of an input because there should not
30
+ * be an interactive element inside an option
31
+ * svg copied from primer/css
32
+ */
33
+ return (<Visuals_1.LeadingVisualContainer sx={{
34
+ rect: {
35
+ fill: selected ? 'accent.fg' : 'canvas.default',
36
+ stroke: selected ? 'accent.fg' : 'border.default'
37
+ },
38
+ path: {
39
+ fill: 'fg.onEmphasis',
40
+ boxShadow: 'shadow.small',
41
+ opacity: selected ? 1 : 0
42
+ }
43
+ }}>
44
+ <svg width="16" height="16" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg" aria-hidden="true">
45
+ <rect x="2" y="2" width="12" height="12" rx="4"></rect>
46
+ <path fillRule="evenodd" strokeWidth="0" d="M4.03231 8.69862C3.84775 8.20646 4.49385 7.77554 4.95539 7.77554C5.41693 7.77554 6.80154 9.85246 6.80154 9.85246C6.80154 9.85246 10.2631 4.314 10.4938 4.08323C10.7246 3.85246 11.8785 4.08323 11.4169 5.00631C11.0081 5.82388 7.26308 11.4678 7.26308 11.4678C7.26308 11.4678 6.80154 12.1602 6.34 11.4678C5.87846 10.7755 4.21687 9.19077 4.03231 8.69862Z"/>
47
+ </svg>
48
+ </Visuals_1.LeadingVisualContainer>);
49
+ };
50
+ exports.Selection = Selection;
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import { SxProp } from '../sx';
3
+ declare type VisualProps = SxProp & React.HTMLAttributes<HTMLSpanElement>;
4
+ export declare const LeadingVisualContainer: React.FC<VisualProps>;
5
+ export declare type LeadingVisualProps = VisualProps;
6
+ export declare const LeadingVisual: React.FC<VisualProps>;
7
+ export declare type TrailingVisualProps = VisualProps;
8
+ export declare const TrailingVisual: React.FC<VisualProps>;
9
+ export {};
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.TrailingVisual = exports.LeadingVisual = exports.LeadingVisualContainer = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _Box = _interopRequireDefault(require("../Box"));
11
+
12
+ var _sx = require("../sx");
13
+
14
+ var _constants = require("../constants");
15
+
16
+ var _Item = require("./Item");
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+
20
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
21
+
22
+ const LeadingVisualContainer = ({
23
+ sx = {},
24
+ ...props
25
+ }) => {
26
+ return /*#__PURE__*/_react.default.createElement(_Box.default, _extends({
27
+ as: "span",
28
+ sx: (0, _sx.merge)({
29
+ height: _Item.TEXT_ROW_HEIGHT,
30
+ // match height of text row
31
+ minWidth: (0, _constants.get)('space.3'),
32
+ maxWidth: _Item.TEXT_ROW_HEIGHT,
33
+ // square (same as height)
34
+ display: 'flex',
35
+ justifyContent: 'center',
36
+ alignItems: 'center',
37
+ flexShrink: 0,
38
+ marginRight: 2
39
+ }, sx)
40
+ }, props));
41
+ };
42
+
43
+ exports.LeadingVisualContainer = LeadingVisualContainer;
44
+ LeadingVisualContainer.displayName = "LeadingVisualContainer";
45
+
46
+ const LeadingVisual = ({
47
+ sx = {},
48
+ ...props
49
+ }) => {
50
+ return /*#__PURE__*/_react.default.createElement(_Item.Slot, {
51
+ name: "LeadingVisual"
52
+ }, ({
53
+ variant,
54
+ disabled
55
+ }) => /*#__PURE__*/_react.default.createElement(LeadingVisualContainer, _extends({
56
+ sx: (0, _sx.merge)({
57
+ color: (0, _Item.getVariantStyles)(variant, disabled).iconColor,
58
+ svg: {
59
+ fontSize: 0
60
+ }
61
+ }, sx)
62
+ }, props), props.children));
63
+ };
64
+
65
+ exports.LeadingVisual = LeadingVisual;
66
+ LeadingVisual.displayName = "LeadingVisual";
67
+
68
+ const TrailingVisual = ({
69
+ sx = {},
70
+ ...props
71
+ }) => {
72
+ return /*#__PURE__*/_react.default.createElement(_Item.Slot, {
73
+ name: "TrailingVisual"
74
+ }, ({
75
+ variant,
76
+ disabled
77
+ }) => /*#__PURE__*/_react.default.createElement(_Box.default, _extends({
78
+ as: "span",
79
+ sx: (0, _sx.merge)({
80
+ height: '20px',
81
+ // match height of text row
82
+ flexShrink: 0,
83
+ color: (0, _Item.getVariantStyles)(variant, disabled).annotationColor,
84
+ marginLeft: 2
85
+ }, sx)
86
+ }, props), props.children));
87
+ };
88
+
89
+ exports.TrailingVisual = TrailingVisual;
90
+ TrailingVisual.displayName = "TrailingVisual";