@primer/components 0.0.0-2021102995710 → 0.0.0-202110303104

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 (427) hide show
  1. package/CHANGELOG.md +4 -90
  2. package/dist/browser.esm.js +774 -718
  3. package/dist/browser.esm.js.map +1 -1
  4. package/dist/browser.umd.js +772 -716
  5. package/dist/browser.umd.js.map +1 -1
  6. package/lib/ActionList/Divider.jsx +29 -0
  7. package/lib/ActionList/Group.jsx +23 -0
  8. package/lib/ActionList/Header.jsx +66 -0
  9. package/lib/ActionList/Item.js +52 -27
  10. package/lib/ActionList/Item.jsx +311 -0
  11. package/lib/ActionList/List.jsx +138 -0
  12. package/lib/ActionList/index.js +12 -23
  13. package/lib/ActionList2/Description.jsx +29 -0
  14. package/lib/ActionList2/Divider.jsx +22 -0
  15. package/lib/ActionList2/Group.d.ts +2 -28
  16. package/lib/ActionList2/Group.js +6 -55
  17. package/lib/ActionList2/Group.jsx +25 -0
  18. package/lib/ActionList2/Header.jsx +36 -0
  19. package/lib/ActionList2/Item.jsx +174 -0
  20. package/lib/ActionList2/LinkItem.jsx +28 -0
  21. package/lib/ActionList2/List.d.ts +1 -1
  22. package/lib/ActionList2/List.js +2 -1
  23. package/lib/ActionList2/List.jsx +41 -0
  24. package/lib/ActionList2/Selection.jsx +50 -0
  25. package/lib/ActionList2/Visuals.jsx +48 -0
  26. package/lib/ActionList2/index.js +23 -41
  27. package/lib/ActionMenu.jsx +73 -0
  28. package/lib/AnchoredOverlay/AnchoredOverlay.jsx +100 -0
  29. package/lib/AnchoredOverlay/index.js +4 -12
  30. package/lib/Autocomplete/Autocomplete.d.ts +3 -3
  31. package/lib/Autocomplete/Autocomplete.jsx +100 -0
  32. package/lib/Autocomplete/AutocompleteContext.jsx +5 -0
  33. package/lib/Autocomplete/AutocompleteInput.d.ts +3 -3
  34. package/lib/Autocomplete/AutocompleteInput.jsx +113 -0
  35. package/lib/Autocomplete/AutocompleteMenu.jsx +190 -0
  36. package/lib/Autocomplete/AutocompleteOverlay.jsx +55 -0
  37. package/lib/Autocomplete/index.js +7 -14
  38. package/lib/Avatar.jsx +34 -0
  39. package/lib/AvatarPair.jsx +29 -0
  40. package/lib/AvatarStack.jsx +151 -0
  41. package/lib/BaseStyles.jsx +65 -0
  42. package/lib/BorderBox.jsx +18 -0
  43. package/lib/Box.jsx +10 -0
  44. package/lib/BranchName.jsx +20 -0
  45. package/lib/Breadcrumbs.d.ts +7 -8
  46. package/lib/Breadcrumbs.js +12 -7
  47. package/lib/Breadcrumbs.jsx +74 -0
  48. package/lib/Button/Button.d.ts +3 -2
  49. package/lib/Button/Button.js +6 -2
  50. package/lib/Button/Button.jsx +60 -0
  51. package/lib/Button/ButtonBase.d.ts +8 -5
  52. package/lib/Button/ButtonBase.js +5 -1
  53. package/lib/Button/ButtonBase.jsx +36 -0
  54. package/lib/Button/ButtonClose.d.ts +46 -3
  55. package/lib/Button/ButtonClose.js +1 -1
  56. package/lib/Button/ButtonClose.jsx +55 -0
  57. package/lib/Button/ButtonDanger.d.ts +3 -2
  58. package/lib/Button/ButtonDanger.js +6 -2
  59. package/lib/Button/ButtonDanger.jsx +63 -0
  60. package/lib/Button/ButtonGroup.jsx +55 -0
  61. package/lib/Button/ButtonInvisible.d.ts +3 -2
  62. package/lib/Button/ButtonInvisible.js +6 -2
  63. package/lib/Button/ButtonInvisible.jsx +52 -0
  64. package/lib/Button/ButtonOutline.d.ts +3 -2
  65. package/lib/Button/ButtonOutline.js +6 -2
  66. package/lib/Button/ButtonOutline.jsx +63 -0
  67. package/lib/Button/ButtonPrimary.d.ts +3 -2
  68. package/lib/Button/ButtonPrimary.js +6 -2
  69. package/lib/Button/ButtonPrimary.jsx +62 -0
  70. package/lib/Button/ButtonStyles.jsx +37 -0
  71. package/lib/Button/ButtonTableList.d.ts +2 -1
  72. package/lib/Button/ButtonTableList.js +1 -1
  73. package/lib/Button/ButtonTableList.jsx +49 -0
  74. package/lib/Button/index.js +21 -70
  75. package/lib/Caret.jsx +93 -0
  76. package/lib/CircleBadge.d.ts +5 -4
  77. package/lib/CircleBadge.js +1 -1
  78. package/lib/CircleBadge.jsx +43 -0
  79. package/lib/CircleOcticon.d.ts +1 -1
  80. package/lib/CircleOcticon.jsx +21 -0
  81. package/lib/CounterLabel.d.ts +2 -1
  82. package/lib/CounterLabel.js +1 -1
  83. package/lib/CounterLabel.jsx +44 -0
  84. package/lib/Details.jsx +21 -0
  85. package/lib/Dialog/ConfirmationDialog.jsx +146 -0
  86. package/lib/Dialog/Dialog.d.ts +9 -5
  87. package/lib/Dialog/Dialog.js +11 -17
  88. package/lib/Dialog/Dialog.jsx +273 -0
  89. package/lib/Dialog.d.ts +5 -4
  90. package/lib/Dialog.js +1 -1
  91. package/lib/Dialog.jsx +131 -0
  92. package/lib/Dropdown.d.ts +99 -10
  93. package/lib/Dropdown.js +3 -3
  94. package/lib/Dropdown.jsx +134 -0
  95. package/lib/DropdownMenu/DropdownButton.d.ts +47 -3
  96. package/lib/DropdownMenu/DropdownButton.js +1 -3
  97. package/lib/DropdownMenu/DropdownButton.jsx +14 -0
  98. package/lib/DropdownMenu/DropdownMenu.jsx +70 -0
  99. package/lib/DropdownMenu/index.js +6 -20
  100. package/lib/DropdownStyles.js +18 -26
  101. package/lib/EmojiPicker/EmojiPicker.d.ts +15 -0
  102. package/lib/EmojiPicker/EmojiPicker.js +205 -0
  103. package/lib/EmojiPicker/EmojiPicker.jsx +125 -0
  104. package/lib/EmojiPicker/EmojiPickerAnchor.d.ts +0 -0
  105. package/lib/EmojiPicker/EmojiPickerAnchor.js +1 -0
  106. package/lib/EmojiPicker/EmojiPickerAnchor.jsx +1 -0
  107. package/lib/EmojiPicker/EmojiPickerPanel.d.ts +3 -0
  108. package/lib/EmojiPicker/EmojiPickerPanel.js +18 -0
  109. package/lib/EmojiPicker/EmojiPickerPanel.jsx +10 -0
  110. package/lib/EmojiPicker/data.d.ts +9 -0
  111. package/lib/EmojiPicker/data.js +7254 -0
  112. package/lib/EmojiPicker/index.d.ts +2 -0
  113. package/lib/EmojiPicker/index.js +8 -0
  114. package/lib/FilterList.d.ts +303 -264
  115. package/lib/FilterList.js +6 -2
  116. package/lib/FilterList.jsx +63 -0
  117. package/lib/FilteredActionList/FilteredActionList.jsx +100 -0
  118. package/lib/FilteredActionList/index.js +4 -12
  119. package/lib/FilteredSearch.d.ts +2 -1
  120. package/lib/FilteredSearch.js +1 -1
  121. package/lib/FilteredSearch.jsx +29 -0
  122. package/lib/Flash.d.ts +2 -1
  123. package/lib/Flash.js +1 -1
  124. package/lib/Flash.jsx +70 -0
  125. package/lib/Flex.jsx +15 -0
  126. package/lib/FormGroup.d.ts +5 -4
  127. package/lib/FormGroup.js +2 -2
  128. package/lib/FormGroup.jsx +25 -0
  129. package/lib/Grid.jsx +15 -0
  130. package/lib/Header.d.ts +7 -6
  131. package/lib/Header.js +4 -4
  132. package/lib/Header.jsx +90 -0
  133. package/lib/Heading.jsx +21 -0
  134. package/lib/Label.d.ts +2 -1
  135. package/lib/Label.js +3 -2
  136. package/lib/Label.jsx +84 -0
  137. package/lib/LabelGroup.d.ts +2 -1
  138. package/lib/LabelGroup.js +1 -1
  139. package/lib/LabelGroup.jsx +19 -0
  140. package/lib/Link.d.ts +2 -1
  141. package/lib/Link.js +1 -1
  142. package/lib/Link.jsx +38 -0
  143. package/lib/NewButton/button-counter.jsx +14 -0
  144. package/lib/NewButton/button.js +42 -34
  145. package/lib/NewButton/button.jsx +278 -0
  146. package/lib/NewButton/index.js +5 -12
  147. package/lib/NewButton/types.js +2 -1
  148. package/lib/Overlay.d.ts +11 -14
  149. package/lib/Overlay.js +4 -3
  150. package/lib/Overlay.jsx +156 -0
  151. package/lib/Pagehead.d.ts +2 -1
  152. package/lib/Pagehead.js +1 -1
  153. package/lib/Pagehead.jsx +18 -0
  154. package/lib/Pagination/Pagination.js +1 -1
  155. package/lib/Pagination/Pagination.jsx +163 -0
  156. package/lib/Pagination/index.js +6 -12
  157. package/lib/Pagination/model.jsx +174 -0
  158. package/lib/PointerBox.jsx +25 -0
  159. package/lib/Popover.d.ts +5 -4
  160. package/lib/Popover.js +5 -4
  161. package/lib/Popover.jsx +210 -0
  162. package/lib/Portal/Portal.jsx +79 -0
  163. package/lib/Portal/index.js +5 -16
  164. package/lib/Position.d.ts +4 -4
  165. package/lib/Position.jsx +46 -0
  166. package/lib/ProgressBar.jsx +39 -0
  167. package/lib/SelectMenu/SelectMenu.d.ts +189 -21
  168. package/lib/SelectMenu/SelectMenu.js +3 -1
  169. package/lib/SelectMenu/SelectMenu.jsx +114 -0
  170. package/lib/SelectMenu/SelectMenuContext.jsx +5 -0
  171. package/lib/SelectMenu/SelectMenuDivider.d.ts +2 -1
  172. package/lib/SelectMenu/SelectMenuDivider.js +1 -1
  173. package/lib/SelectMenu/SelectMenuDivider.jsx +43 -0
  174. package/lib/SelectMenu/SelectMenuFilter.js +1 -1
  175. package/lib/SelectMenu/SelectMenuFilter.jsx +59 -0
  176. package/lib/SelectMenu/SelectMenuFooter.d.ts +2 -1
  177. package/lib/SelectMenu/SelectMenuFooter.js +1 -1
  178. package/lib/SelectMenu/SelectMenuFooter.jsx +46 -0
  179. package/lib/SelectMenu/SelectMenuHeader.d.ts +2 -1
  180. package/lib/SelectMenu/SelectMenuHeader.js +1 -1
  181. package/lib/SelectMenu/SelectMenuHeader.jsx +44 -0
  182. package/lib/SelectMenu/SelectMenuItem.d.ts +3 -2
  183. package/lib/SelectMenu/SelectMenuItem.js +1 -1
  184. package/lib/SelectMenu/SelectMenuItem.jsx +143 -0
  185. package/lib/SelectMenu/SelectMenuList.d.ts +2 -1
  186. package/lib/SelectMenu/SelectMenuList.js +1 -1
  187. package/lib/SelectMenu/SelectMenuList.jsx +60 -0
  188. package/lib/SelectMenu/SelectMenuLoadingAnimation.d.ts +2 -2
  189. package/lib/SelectMenu/SelectMenuLoadingAnimation.js +1 -3
  190. package/lib/SelectMenu/SelectMenuLoadingAnimation.jsx +21 -0
  191. package/lib/SelectMenu/SelectMenuModal.d.ts +3 -2
  192. package/lib/SelectMenu/SelectMenuModal.js +1 -1
  193. package/lib/SelectMenu/SelectMenuModal.jsx +119 -0
  194. package/lib/SelectMenu/SelectMenuTab.d.ts +2 -1
  195. package/lib/SelectMenu/SelectMenuTab.js +1 -1
  196. package/lib/SelectMenu/SelectMenuTab.jsx +93 -0
  197. package/lib/SelectMenu/SelectMenuTabPanel.d.ts +2 -1
  198. package/lib/SelectMenu/SelectMenuTabPanel.js +1 -1
  199. package/lib/SelectMenu/SelectMenuTabPanel.jsx +43 -0
  200. package/lib/SelectMenu/SelectMenuTabs.d.ts +2 -1
  201. package/lib/SelectMenu/SelectMenuTabs.js +1 -1
  202. package/lib/SelectMenu/SelectMenuTabs.jsx +58 -0
  203. package/lib/SelectMenu/hooks/useKeyboardNav.js +80 -96
  204. package/lib/SelectMenu/index.js +7 -14
  205. package/lib/SelectPanel/SelectPanel.jsx +105 -0
  206. package/lib/SelectPanel/index.js +4 -12
  207. package/lib/SideNav.d.ts +8 -11
  208. package/lib/SideNav.js +15 -8
  209. package/lib/SideNav.jsx +177 -0
  210. package/lib/Spinner.jsx +35 -0
  211. package/lib/StateLabel.d.ts +2 -1
  212. package/lib/StateLabel.js +5 -6
  213. package/lib/StateLabel.jsx +94 -0
  214. package/lib/StyledOcticon.d.ts +2 -1
  215. package/lib/StyledOcticon.js +3 -1
  216. package/lib/StyledOcticon.jsx +20 -0
  217. package/lib/SubNav.d.ts +11 -5
  218. package/lib/SubNav.js +12 -7
  219. package/lib/SubNav.jsx +104 -0
  220. package/lib/TabNav.d.ts +4 -3
  221. package/lib/TabNav.js +2 -2
  222. package/lib/TabNav.jsx +60 -0
  223. package/lib/Text.jsx +14 -0
  224. package/lib/TextInput.jsx +23 -0
  225. package/lib/TextInputWithTokens.d.ts +3 -3
  226. package/lib/TextInputWithTokens.jsx +218 -0
  227. package/lib/ThemeProvider.jsx +130 -0
  228. package/lib/Timeline.d.ts +393 -19
  229. package/lib/Timeline.js +13 -16
  230. package/lib/Timeline.jsx +124 -0
  231. package/lib/Token/AvatarToken.jsx +54 -0
  232. package/lib/Token/IssueLabelToken.jsx +125 -0
  233. package/lib/Token/Token.d.ts +1 -1
  234. package/lib/Token/Token.jsx +103 -0
  235. package/lib/Token/TokenBase.jsx +88 -0
  236. package/lib/Token/_RemoveTokenButton.jsx +108 -0
  237. package/lib/Token/_TokenTextContainer.jsx +49 -0
  238. package/lib/Token/index.js +11 -30
  239. package/lib/Tooltip.d.ts +2 -1
  240. package/lib/Tooltip.js +1 -1
  241. package/lib/Tooltip.jsx +246 -0
  242. package/lib/Truncate.d.ts +2 -1
  243. package/lib/Truncate.js +3 -1
  244. package/lib/Truncate.jsx +27 -0
  245. package/lib/UnderlineNav.d.ts +3 -2
  246. package/lib/UnderlineNav.js +2 -2
  247. package/lib/UnderlineNav.jsx +90 -0
  248. package/lib/_TextInputWrapper.jsx +120 -0
  249. package/lib/_UnstyledTextInput.jsx +22 -0
  250. package/lib/behaviors/anchoredPosition.js +205 -234
  251. package/lib/behaviors/focusTrap.js +121 -157
  252. package/lib/behaviors/focusZone.js +434 -509
  253. package/lib/behaviors/scrollIntoViewingArea.js +18 -35
  254. package/lib/constants.js +39 -43
  255. package/lib/drafts.js +20 -30
  256. package/lib/hooks/index.js +16 -60
  257. package/lib/hooks/useAnchoredPosition.js +32 -40
  258. package/lib/hooks/useCombinedRefs.js +32 -36
  259. package/lib/hooks/useDetails.jsx +39 -0
  260. package/lib/hooks/useDialog.js +72 -96
  261. package/lib/hooks/useFocusTrap.js +43 -60
  262. package/lib/hooks/useFocusZone.js +54 -50
  263. package/lib/hooks/useOnEscapePress.js +25 -36
  264. package/lib/hooks/useOnOutsideClick.jsx +61 -0
  265. package/lib/hooks/useOpenAndCloseFocus.js +22 -34
  266. package/lib/hooks/useOverlay.jsx +15 -0
  267. package/lib/hooks/useProvidedRefOrCreate.js +10 -14
  268. package/lib/hooks/useProvidedStateOrCreate.js +13 -16
  269. package/lib/hooks/useRenderForcingRef.js +13 -17
  270. package/lib/hooks/useResizeObserver.js +15 -18
  271. package/lib/hooks/useSafeTimeout.js +22 -30
  272. package/lib/hooks/useScrollFlash.js +16 -23
  273. package/lib/index.d.ts +2 -2
  274. package/lib/index.js +165 -652
  275. package/lib/polyfills/eventListenerSignal.js +37 -45
  276. package/lib/sx.js +10 -22
  277. package/lib/theme-preval.js +64 -3169
  278. package/lib/theme.js +3 -12
  279. package/lib/utils/create-slots.jsx +65 -0
  280. package/lib/utils/deprecate.jsx +59 -0
  281. package/lib/utils/isNumeric.jsx +7 -0
  282. package/lib/utils/iterateFocusableElements.js +63 -85
  283. package/lib/utils/ssr.jsx +6 -0
  284. package/lib/utils/test-deprecations.jsx +20 -0
  285. package/lib/utils/test-helpers.jsx +8 -0
  286. package/lib/utils/test-matchers.jsx +100 -0
  287. package/lib/utils/testing.d.ts +61 -28
  288. package/lib/utils/testing.js +0 -29
  289. package/lib/utils/testing.jsx +206 -0
  290. package/lib/utils/theme.js +33 -47
  291. package/lib/utils/types/AriaRole.js +2 -1
  292. package/lib/utils/types/ComponentProps.js +2 -1
  293. package/lib/utils/types/Flatten.js +2 -1
  294. package/lib/utils/types/KeyPaths.js +2 -1
  295. package/lib/utils/types/MandateProps.js +16 -1
  296. package/lib/utils/types/Merge.js +2 -1
  297. package/lib/utils/types/index.js +16 -69
  298. package/lib/utils/uniqueId.js +5 -8
  299. package/lib/utils/use-force-update.js +8 -14
  300. package/lib/utils/useIsomorphicLayoutEffect.js +8 -11
  301. package/lib/utils/userAgent.js +8 -12
  302. package/lib-esm/ActionList/Item.js +53 -28
  303. package/lib-esm/ActionList2/Group.d.ts +2 -28
  304. package/lib-esm/ActionList2/Group.js +5 -52
  305. package/lib-esm/ActionList2/List.d.ts +1 -1
  306. package/lib-esm/ActionList2/List.js +2 -1
  307. package/lib-esm/Autocomplete/Autocomplete.d.ts +3 -3
  308. package/lib-esm/Autocomplete/AutocompleteInput.d.ts +3 -3
  309. package/lib-esm/Breadcrumbs.d.ts +7 -8
  310. package/lib-esm/Breadcrumbs.js +13 -8
  311. package/lib-esm/Button/Button.d.ts +3 -2
  312. package/lib-esm/Button/Button.js +2 -2
  313. package/lib-esm/Button/ButtonBase.d.ts +8 -5
  314. package/lib-esm/Button/ButtonBase.js +3 -1
  315. package/lib-esm/Button/ButtonClose.d.ts +46 -3
  316. package/lib-esm/Button/ButtonClose.js +2 -2
  317. package/lib-esm/Button/ButtonDanger.d.ts +3 -2
  318. package/lib-esm/Button/ButtonDanger.js +2 -2
  319. package/lib-esm/Button/ButtonInvisible.d.ts +3 -2
  320. package/lib-esm/Button/ButtonInvisible.js +2 -2
  321. package/lib-esm/Button/ButtonOutline.d.ts +3 -2
  322. package/lib-esm/Button/ButtonOutline.js +2 -2
  323. package/lib-esm/Button/ButtonPrimary.d.ts +3 -2
  324. package/lib-esm/Button/ButtonPrimary.js +2 -2
  325. package/lib-esm/Button/ButtonTableList.d.ts +2 -1
  326. package/lib-esm/Button/ButtonTableList.js +2 -2
  327. package/lib-esm/CircleBadge.d.ts +5 -4
  328. package/lib-esm/CircleBadge.js +2 -2
  329. package/lib-esm/CircleOcticon.d.ts +1 -1
  330. package/lib-esm/CounterLabel.d.ts +2 -1
  331. package/lib-esm/CounterLabel.js +2 -2
  332. package/lib-esm/Dialog/Dialog.d.ts +9 -5
  333. package/lib-esm/Dialog/Dialog.js +12 -12
  334. package/lib-esm/Dialog.d.ts +5 -4
  335. package/lib-esm/Dialog.js +2 -2
  336. package/lib-esm/Dropdown.d.ts +99 -10
  337. package/lib-esm/Dropdown.js +4 -4
  338. package/lib-esm/DropdownMenu/DropdownButton.d.ts +47 -3
  339. package/lib-esm/DropdownMenu/DropdownButton.js +1 -3
  340. package/lib-esm/EmojiPicker/EmojiPicker.d.ts +15 -0
  341. package/lib-esm/EmojiPicker/EmojiPicker.js +184 -0
  342. package/lib-esm/EmojiPicker/EmojiPickerAnchor.d.ts +0 -0
  343. package/lib-esm/EmojiPicker/EmojiPickerAnchor.js +0 -0
  344. package/lib-esm/EmojiPicker/EmojiPickerPanel.d.ts +3 -0
  345. package/lib-esm/EmojiPicker/EmojiPickerPanel.js +8 -0
  346. package/lib-esm/EmojiPicker/data.d.ts +9 -0
  347. package/lib-esm/EmojiPicker/data.js +5434 -0
  348. package/lib-esm/EmojiPicker/index.d.ts +2 -0
  349. package/lib-esm/EmojiPicker/index.js +1 -0
  350. package/lib-esm/FilterList.d.ts +303 -264
  351. package/lib-esm/FilterList.js +7 -3
  352. package/lib-esm/FilteredSearch.d.ts +2 -1
  353. package/lib-esm/FilteredSearch.js +2 -2
  354. package/lib-esm/Flash.d.ts +2 -1
  355. package/lib-esm/Flash.js +2 -2
  356. package/lib-esm/FormGroup.d.ts +5 -4
  357. package/lib-esm/FormGroup.js +3 -3
  358. package/lib-esm/Header.d.ts +7 -6
  359. package/lib-esm/Header.js +5 -5
  360. package/lib-esm/Label.d.ts +2 -1
  361. package/lib-esm/Label.js +4 -3
  362. package/lib-esm/LabelGroup.d.ts +2 -1
  363. package/lib-esm/LabelGroup.js +2 -2
  364. package/lib-esm/Link.d.ts +2 -1
  365. package/lib-esm/Link.js +2 -2
  366. package/lib-esm/NewButton/button.js +42 -31
  367. package/lib-esm/Overlay.d.ts +11 -14
  368. package/lib-esm/Overlay.js +3 -2
  369. package/lib-esm/Pagehead.d.ts +2 -1
  370. package/lib-esm/Pagehead.js +2 -2
  371. package/lib-esm/Pagination/Pagination.js +2 -2
  372. package/lib-esm/Popover.d.ts +5 -4
  373. package/lib-esm/Popover.js +5 -4
  374. package/lib-esm/Position.d.ts +4 -4
  375. package/lib-esm/SelectMenu/SelectMenu.d.ts +189 -21
  376. package/lib-esm/SelectMenu/SelectMenu.js +2 -1
  377. package/lib-esm/SelectMenu/SelectMenuDivider.d.ts +2 -1
  378. package/lib-esm/SelectMenu/SelectMenuDivider.js +2 -2
  379. package/lib-esm/SelectMenu/SelectMenuFilter.js +2 -2
  380. package/lib-esm/SelectMenu/SelectMenuFooter.d.ts +2 -1
  381. package/lib-esm/SelectMenu/SelectMenuFooter.js +2 -2
  382. package/lib-esm/SelectMenu/SelectMenuHeader.d.ts +2 -1
  383. package/lib-esm/SelectMenu/SelectMenuHeader.js +2 -2
  384. package/lib-esm/SelectMenu/SelectMenuItem.d.ts +3 -2
  385. package/lib-esm/SelectMenu/SelectMenuItem.js +2 -2
  386. package/lib-esm/SelectMenu/SelectMenuList.d.ts +2 -1
  387. package/lib-esm/SelectMenu/SelectMenuList.js +2 -2
  388. package/lib-esm/SelectMenu/SelectMenuLoadingAnimation.d.ts +2 -2
  389. package/lib-esm/SelectMenu/SelectMenuLoadingAnimation.js +2 -3
  390. package/lib-esm/SelectMenu/SelectMenuModal.d.ts +3 -2
  391. package/lib-esm/SelectMenu/SelectMenuModal.js +2 -2
  392. package/lib-esm/SelectMenu/SelectMenuTab.d.ts +2 -1
  393. package/lib-esm/SelectMenu/SelectMenuTab.js +2 -2
  394. package/lib-esm/SelectMenu/SelectMenuTabPanel.d.ts +2 -1
  395. package/lib-esm/SelectMenu/SelectMenuTabPanel.js +2 -2
  396. package/lib-esm/SelectMenu/SelectMenuTabs.d.ts +2 -1
  397. package/lib-esm/SelectMenu/SelectMenuTabs.js +2 -2
  398. package/lib-esm/SideNav.d.ts +8 -11
  399. package/lib-esm/SideNav.js +16 -8
  400. package/lib-esm/StateLabel.d.ts +2 -1
  401. package/lib-esm/StateLabel.js +6 -7
  402. package/lib-esm/StyledOcticon.d.ts +2 -1
  403. package/lib-esm/StyledOcticon.js +2 -1
  404. package/lib-esm/SubNav.d.ts +11 -5
  405. package/lib-esm/SubNav.js +13 -8
  406. package/lib-esm/TabNav.d.ts +4 -3
  407. package/lib-esm/TabNav.js +3 -3
  408. package/lib-esm/TextInputWithTokens.d.ts +3 -3
  409. package/lib-esm/Timeline.d.ts +393 -19
  410. package/lib-esm/Timeline.js +13 -12
  411. package/lib-esm/Token/Token.d.ts +1 -1
  412. package/lib-esm/Tooltip.d.ts +2 -1
  413. package/lib-esm/Tooltip.js +2 -2
  414. package/lib-esm/Truncate.d.ts +2 -1
  415. package/lib-esm/Truncate.js +2 -1
  416. package/lib-esm/UnderlineNav.d.ts +3 -2
  417. package/lib-esm/UnderlineNav.js +3 -3
  418. package/lib-esm/index.d.ts +2 -2
  419. package/lib-esm/index.js +1 -1
  420. package/lib-esm/theme-preval.js +366 -512
  421. package/lib-esm/utils/testing.d.ts +61 -28
  422. package/lib-esm/utils/testing.js +0 -24
  423. package/package.json +5 -4
  424. package/lib/Checkbox.d.ts +0 -29
  425. package/lib/Checkbox.js +0 -64
  426. package/lib-esm/Checkbox.d.ts +0 -29
  427. package/lib-esm/Checkbox.js +0 -44
@@ -0,0 +1,138 @@
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.List = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Group_1 = require("./Group");
9
+ const Item_1 = require("./Item");
10
+ const Divider_1 = require("./Divider");
11
+ const styled_components_1 = __importDefault(require("styled-components"));
12
+ const constants_1 = require("../constants");
13
+ const focusZone_1 = require("../behaviors/focusZone");
14
+ /**
15
+ * Asserts that the given value fulfills the `GroupedListProps` contract.
16
+ * @param props A value which fulfills either the `ListPropsBase` or the `GroupedListProps` contract.
17
+ */
18
+ function isGroupedListProps(props) {
19
+ return 'groupMetadata' in props;
20
+ }
21
+ const StyledList = styled_components_1.default.div `
22
+ font-size: ${constants_1.get('fontSizes.1')};
23
+ /* 14px font-size * 1.428571429 = 20px line height
24
+ *
25
+ * TODO: When rem-based spacing on a 4px scale lands, replace
26
+ * hardcoded '20px'
27
+ */
28
+ line-height: 20px;
29
+
30
+ &[${focusZone_1.hasActiveDescendantAttribute}], &:focus-within {
31
+ --item-hover-bg-override: none;
32
+ --item-hover-divider-border-color-override: ${constants_1.get('colors.border.muted')};
33
+ }
34
+ `;
35
+ /**
36
+ * Returns `sx` prop values for `List` children matching the given `List` style variation.
37
+ * @param variant `List` style variation.
38
+ */
39
+ function useListVariant(variant = 'inset') {
40
+ switch (variant) {
41
+ case 'full':
42
+ return {
43
+ headerStyle: { paddingX: constants_1.get('space.2') },
44
+ itemStyle: { borderRadius: 0 }
45
+ };
46
+ default:
47
+ return {
48
+ firstGroupStyle: { marginTop: constants_1.get('space.2') },
49
+ lastGroupStyle: { marginBottom: constants_1.get('space.2') },
50
+ itemStyle: { marginX: constants_1.get('space.2') }
51
+ };
52
+ }
53
+ }
54
+ /**
55
+ * Lists `Item`s, either grouped or ungrouped, with a `Divider` between each `Group`.
56
+ */
57
+ exports.List = react_1.default.forwardRef((props, forwardedRef) => {
58
+ // Get `sx` prop values for `List` children matching the given `List` style variation.
59
+ const { firstGroupStyle, lastGroupStyle, headerStyle, itemStyle } = useListVariant(props.variant);
60
+ /**
61
+ * Render a `Group` using the first of the following renderers that is defined:
62
+ * A `Group`-level or `List`-level custom `Group` renderer, or
63
+ * the default `Group` renderer.
64
+ */
65
+ const renderGroup = (groupProps) => {
66
+ const GroupComponent = (('renderGroup' in groupProps && groupProps.renderGroup) ?? props.renderGroup) || Group_1.Group;
67
+ return <GroupComponent {...groupProps} key={groupProps.groupId}/>;
68
+ };
69
+ /**
70
+ * Render an `Item` using the first of the following renderers that is defined:
71
+ * An `Item`-level, `Group`-level, or `List`-level custom `Item` renderer,
72
+ * or the default `Item` renderer.
73
+ */
74
+ const renderItem = (itemProps, item, itemIndex) => {
75
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
76
+ const ItemComponent = ('renderItem' in itemProps && itemProps.renderItem) || props.renderItem || Item_1.Item;
77
+ const key = ('key' in itemProps ? itemProps.key : undefined) ?? itemProps.id?.toString() ?? itemIndex.toString();
78
+ return (<ItemComponent showDivider={props.showItemDividers} selectionVariant={props.selectionVariant} {...itemProps} key={key} sx={{ ...itemStyle, ...itemProps.sx }} item={item}/>);
79
+ };
80
+ /**
81
+ * An array of `Group`s, each with an associated `Header` and with an array of `Item`s belonging to that `Group`.
82
+ */
83
+ let groups = [];
84
+ // Collect rendered `Item`s into `Group`s, avoiding excess iteration over the lists of `items` and `groupMetadata`:
85
+ if (!isGroupedListProps(props)) {
86
+ // When no `groupMetadata`s is provided, collect rendered `Item`s into a single anonymous `Group`.
87
+ groups = [{ items: props.items.map((item, index) => renderItem(item, item, index)), groupId: '0' }];
88
+ }
89
+ else {
90
+ // When `groupMetadata` is provided, collect rendered `Item`s into their associated `Group`s.
91
+ /**
92
+ * A map of group identifiers to `Group`s, each with an associated array of `Item`s belonging to that `Group`.
93
+ */
94
+ const groupMap = props.groupMetadata.reduce((groupAccumulator, groupMetadata) => groupAccumulator.set(groupMetadata.groupId, groupMetadata), new Map());
95
+ for (const itemProps of props.items) {
96
+ // Look up the group associated with the current item.
97
+ const group = groupMap.get(itemProps.groupId);
98
+ const itemIndex = group?.items?.length ?? 0;
99
+ // Upsert the group to include the current item (rendered).
100
+ groupMap.set(itemProps.groupId, {
101
+ ...group,
102
+ items: [
103
+ ...(group?.items ?? []),
104
+ renderItem({
105
+ showDivider: group?.showItemDividers,
106
+ ...(group && 'renderItem' in group && { renderItem: group.renderItem }),
107
+ ...itemProps
108
+ }, itemProps, itemIndex)
109
+ ]
110
+ });
111
+ }
112
+ groups = [...groupMap.values()];
113
+ }
114
+ return (<StyledList {...props} ref={forwardedRef}>
115
+ {groups.map(({ header, ...groupProps }, index) => {
116
+ const hasFilledHeader = header?.variant === 'filled';
117
+ const shouldShowDivider = index > 0 && !hasFilledHeader;
118
+ return (<react_1.default.Fragment key={groupProps.groupId}>
119
+ {shouldShowDivider ? <Divider_1.Divider key={`${groupProps.groupId}-divider`}/> : null}
120
+ {renderGroup({
121
+ sx: {
122
+ ...(index === 0 && firstGroupStyle),
123
+ ...(index === groups.length - 1 && lastGroupStyle),
124
+ ...(index > 0 && !shouldShowDivider && { mt: 2 })
125
+ },
126
+ ...(header && {
127
+ header: {
128
+ ...header,
129
+ sx: { ...headerStyle, ...header.sx }
130
+ }
131
+ }),
132
+ ...groupProps
133
+ })}
134
+ </react_1.default.Fragment>);
135
+ })}
136
+ </StyledList>);
137
+ });
138
+ exports.List.displayName = 'ActionList';
@@ -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,29 @@
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
+ fontSize: 0,
15
+ lineHeight: '16px',
16
+ flexGrow: 1,
17
+ flexBasis: 0,
18
+ minWidth: 0,
19
+ marginLeft: variant === 'block' ? 0 : 2
20
+ };
21
+ return (<Item_1.Slot name={variant === 'block' ? 'BlockDescription' : 'InlineDescription'}>
22
+ {({ blockDescriptionId, inlineDescriptionId, disabled }) => variant === 'block' ? (<Box_1.default as="span" sx={sx_1.merge({ ...styles, color: disabled ? 'fg.disabled' : 'fg.muted' }, sx)} id={blockDescriptionId}>
23
+ {props.children}
24
+ </Box_1.default>) : (<Truncate_1.default id={inlineDescriptionId} sx={sx_1.merge({ ...styles, color: disabled ? 'fg.disabled' : 'fg.muted' }, sx)} title={props.children} inline={true} maxWidth="100%">
25
+ {props.children}
26
+ </Truncate_1.default>)}
27
+ </Item_1.Slot>);
28
+ };
29
+ 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;
@@ -1,37 +1,11 @@
1
1
  import React from 'react';
2
2
  import { SxProp } from '../sx';
3
+ import { HeaderProps } from './Header';
3
4
  import { ListProps } from './List';
4
- import { AriaRole } from '../utils/types';
5
- export declare type GroupProps = {
6
- /**
7
- * Style variations. Usage is discretionary.
8
- *
9
- * - `"filled"` - Superimposed on a background, offset from nearby content
10
- * - `"subtle"` - Relatively less offset from nearby content
11
- */
12
- variant?: 'subtle' | 'filled';
13
- /**
14
- * Primary text which names a `Group`.
15
- */
16
- title?: string;
17
- /**
18
- * Secondary text which provides additional information about a `Group`.
19
- */
20
- auxiliaryText?: string;
21
- /**
22
- * The ARIA role describing the function of the list inside `Group` component. `listbox` or `menu` are a common values.
23
- */
24
- role?: AriaRole;
25
- } & SxProp & {
26
- /**
27
- * Whether multiple Items or a single Item can be selected in the Group. Overrides value on ActionList root.
28
- */
5
+ export declare type GroupProps = HeaderProps & SxProp & {
29
6
  selectionVariant?: ListProps['selectionVariant'] | false;
30
7
  };
31
8
  declare type ContextProps = Pick<GroupProps, 'selectionVariant'>;
32
9
  export declare const GroupContext: React.Context<ContextProps>;
33
10
  export declare const Group: React.FC<GroupProps>;
34
- export declare type HeaderProps = Pick<GroupProps, 'variant' | 'title' | 'auxiliaryText'> & {
35
- labelId: string;
36
- };
37
11
  export {};
@@ -7,11 +7,9 @@ exports.Group = exports.GroupContext = void 0;
7
7
 
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
 
10
- var _ssr = require("@react-aria/ssr");
11
-
12
10
  var _Box = _interopRequireDefault(require("../Box"));
13
11
 
14
- var _List = require("./List");
12
+ var _Header = require("./Header");
15
13
 
16
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
15
 
@@ -23,14 +21,12 @@ exports.GroupContext = GroupContext;
23
21
 
24
22
  const Group = ({
25
23
  title,
26
- variant = 'subtle',
24
+ variant,
27
25
  auxiliaryText,
28
26
  selectionVariant,
29
- role,
30
27
  sx = {},
31
28
  ...props
32
29
  }) => {
33
- const labelId = (0, _ssr.useSSRSafeId)();
34
30
  return /*#__PURE__*/_react.default.createElement(_Box.default, _extends({
35
31
  as: "li",
36
32
  sx: {
@@ -41,11 +37,10 @@ const Group = ({
41
37
  // hide the ::marker inserted by browser's stylesheet
42
38
  ...sx
43
39
  }
44
- }, props), title && /*#__PURE__*/_react.default.createElement(Header, {
40
+ }, props), title && /*#__PURE__*/_react.default.createElement(_Header.Header, {
45
41
  title: title,
46
42
  variant: variant,
47
- auxiliaryText: auxiliaryText,
48
- labelId: labelId
43
+ auxiliaryText: auxiliaryText
49
44
  }), /*#__PURE__*/_react.default.createElement(GroupContext.Provider, {
50
45
  value: {
51
46
  selectionVariant
@@ -54,53 +49,9 @@ const Group = ({
54
49
  as: "ul",
55
50
  sx: {
56
51
  paddingInlineStart: 0
57
- },
58
- "aria-labelledby": title ? labelId : undefined,
59
- role: role
52
+ }
60
53
  }, props.children)));
61
54
  };
62
55
 
63
56
  exports.Group = Group;
64
- Group.displayName = "Group";
65
-
66
- /**
67
- * Displays the name and description of a `Group`.
68
- *
69
- * For visual presentation only. It's hidden from screen readers.
70
- */
71
- const Header = ({
72
- variant,
73
- title,
74
- auxiliaryText,
75
- labelId,
76
- ...props
77
- }) => {
78
- const {
79
- variant: listVariant
80
- } = _react.default.useContext(_List.ListContext);
81
-
82
- const styles = {
83
- paddingY: '6px',
84
- paddingX: listVariant === 'full' ? 2 : 3,
85
- fontSize: 0,
86
- fontWeight: 'bold',
87
- color: 'fg.muted',
88
- ...(variant === 'filled' && {
89
- backgroundColor: 'canvas.subtle',
90
- marginX: 0,
91
- marginBottom: 2,
92
- borderTop: '1px solid',
93
- borderBottom: '1px solid',
94
- borderColor: 'neutral.muted'
95
- })
96
- };
97
- return /*#__PURE__*/_react.default.createElement(_Box.default, _extends({
98
- sx: styles,
99
- role: "presentation",
100
- "aria-hidden": "true"
101
- }, props), /*#__PURE__*/_react.default.createElement("span", {
102
- id: labelId
103
- }, title), auxiliaryText && /*#__PURE__*/_react.default.createElement("span", null, auxiliaryText));
104
- };
105
-
106
- Header.displayName = "Header";
57
+ Group.displayName = "Group";
@@ -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: '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,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
+ });
@@ -20,7 +20,7 @@ export declare type ListProps = {
20
20
  */
21
21
  role?: AriaRole;
22
22
  } & SxProp;
23
- declare type ContextProps = Pick<ListProps, 'variant' | 'selectionVariant' | 'showDividers'>;
23
+ declare type ContextProps = Omit<ListProps, 'sx'>;
24
24
  export declare const ListContext: React.Context<ContextProps>;
25
25
  export declare const List: PolymorphicForwardRefComponent<"ul", ListProps>;
26
26
  export {};
@@ -42,7 +42,8 @@ const List = /*#__PURE__*/_react.default.forwardRef(({
42
42
  paddingY: variant === 'inset' ? 2 : 0
43
43
  };
44
44
  return /*#__PURE__*/_react.default.createElement(ListBox, _extends({
45
- sx: (0, _sx.merge)(styles, sxProp)
45
+ sx: (0, _sx.merge)(styles, sxProp),
46
+ "aria-multiselectable": selectionVariant === 'multiple' ? true : undefined
46
47
  }, props, {
47
48
  ref: forwardedRef
48
49
  }), /*#__PURE__*/_react.default.createElement(ListContext.Provider, {