@primer/components 0.0.0-20211124581 → 0.0.0-2021113174023

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 (488) hide show
  1. package/CHANGELOG.md +4 -110
  2. package/dist/browser.esm.js +783 -738
  3. package/dist/browser.esm.js.map +1 -1
  4. package/dist/browser.umd.js +781 -736
  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 +55 -30
  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.d.ts +2 -3
  15. package/lib/ActionList2/Divider.js +5 -10
  16. package/lib/ActionList2/Divider.jsx +22 -0
  17. package/lib/ActionList2/Group.d.ts +2 -28
  18. package/lib/ActionList2/Group.js +6 -55
  19. package/lib/ActionList2/Group.jsx +25 -0
  20. package/lib/ActionList2/Header.d.ts +26 -0
  21. package/lib/ActionList2/Header.js +55 -0
  22. package/lib/ActionList2/Header.jsx +36 -0
  23. package/lib/ActionList2/Item.js +6 -24
  24. package/lib/ActionList2/Item.jsx +174 -0
  25. package/lib/ActionList2/LinkItem.jsx +28 -0
  26. package/lib/ActionList2/List.d.ts +1 -1
  27. package/lib/ActionList2/List.js +1 -10
  28. package/lib/ActionList2/List.jsx +41 -0
  29. package/lib/ActionList2/Selection.js +1 -14
  30. package/lib/ActionList2/Selection.jsx +50 -0
  31. package/lib/ActionList2/Visuals.jsx +48 -0
  32. package/lib/ActionList2/index.d.ts +2 -1
  33. package/lib/ActionList2/index.js +23 -41
  34. package/lib/ActionMenu.jsx +73 -0
  35. package/lib/AnchoredOverlay/AnchoredOverlay.jsx +100 -0
  36. package/lib/AnchoredOverlay/index.js +4 -12
  37. package/lib/Autocomplete/Autocomplete.d.ts +3 -12
  38. package/lib/Autocomplete/Autocomplete.jsx +100 -0
  39. package/lib/Autocomplete/AutocompleteContext.jsx +5 -0
  40. package/lib/Autocomplete/AutocompleteInput.d.ts +3 -12
  41. package/lib/Autocomplete/AutocompleteInput.jsx +113 -0
  42. package/lib/Autocomplete/AutocompleteMenu.jsx +190 -0
  43. package/lib/Autocomplete/AutocompleteOverlay.jsx +55 -0
  44. package/lib/Autocomplete/index.js +7 -14
  45. package/lib/Avatar.d.ts +2 -1
  46. package/lib/Avatar.js +1 -1
  47. package/lib/Avatar.jsx +34 -0
  48. package/lib/AvatarPair.jsx +29 -0
  49. package/lib/AvatarStack.jsx +151 -0
  50. package/lib/BaseStyles.jsx +65 -0
  51. package/lib/BorderBox.jsx +18 -0
  52. package/lib/Box.jsx +10 -0
  53. package/lib/BranchName.d.ts +2 -1
  54. package/lib/BranchName.js +1 -1
  55. package/lib/BranchName.jsx +20 -0
  56. package/lib/Breadcrumbs.d.ts +7 -8
  57. package/lib/Breadcrumbs.js +12 -7
  58. package/lib/Breadcrumbs.jsx +74 -0
  59. package/lib/Button/Button.d.ts +3 -3
  60. package/lib/Button/Button.js +6 -2
  61. package/lib/Button/Button.jsx +60 -0
  62. package/lib/Button/ButtonBase.d.ts +8 -5
  63. package/lib/Button/ButtonBase.js +5 -1
  64. package/lib/Button/ButtonBase.jsx +36 -0
  65. package/lib/Button/ButtonClose.d.ts +46 -4
  66. package/lib/Button/ButtonClose.js +1 -1
  67. package/lib/Button/ButtonClose.jsx +55 -0
  68. package/lib/Button/ButtonDanger.d.ts +3 -3
  69. package/lib/Button/ButtonDanger.js +6 -2
  70. package/lib/Button/ButtonDanger.jsx +63 -0
  71. package/lib/Button/ButtonGroup.jsx +55 -0
  72. package/lib/Button/ButtonInvisible.d.ts +3 -3
  73. package/lib/Button/ButtonInvisible.js +6 -2
  74. package/lib/Button/ButtonInvisible.jsx +52 -0
  75. package/lib/Button/ButtonOutline.d.ts +3 -3
  76. package/lib/Button/ButtonOutline.js +6 -2
  77. package/lib/Button/ButtonOutline.jsx +63 -0
  78. package/lib/Button/ButtonPrimary.d.ts +3 -3
  79. package/lib/Button/ButtonPrimary.js +6 -2
  80. package/lib/Button/ButtonPrimary.jsx +62 -0
  81. package/lib/Button/ButtonStyles.jsx +37 -0
  82. package/lib/Button/ButtonTableList.d.ts +2 -1
  83. package/lib/Button/ButtonTableList.js +1 -1
  84. package/lib/Button/ButtonTableList.jsx +49 -0
  85. package/lib/Button/index.js +21 -70
  86. package/lib/Caret.jsx +93 -0
  87. package/lib/CircleBadge.d.ts +5 -4
  88. package/lib/CircleBadge.js +1 -1
  89. package/lib/CircleBadge.jsx +43 -0
  90. package/lib/CircleOcticon.d.ts +1 -2
  91. package/lib/CircleOcticon.jsx +21 -0
  92. package/lib/CounterLabel.d.ts +2 -1
  93. package/lib/CounterLabel.js +1 -1
  94. package/lib/CounterLabel.jsx +44 -0
  95. package/lib/Details.d.ts +2 -1
  96. package/lib/Details.js +3 -1
  97. package/lib/Details.jsx +21 -0
  98. package/lib/Dialog/ConfirmationDialog.jsx +146 -0
  99. package/lib/Dialog/Dialog.d.ts +9 -5
  100. package/lib/Dialog/Dialog.js +11 -17
  101. package/lib/Dialog/Dialog.jsx +273 -0
  102. package/lib/Dialog.d.ts +5 -5
  103. package/lib/Dialog.js +1 -1
  104. package/lib/Dialog.jsx +131 -0
  105. package/lib/Dropdown.d.ts +165 -16
  106. package/lib/Dropdown.js +3 -3
  107. package/lib/Dropdown.jsx +134 -0
  108. package/lib/DropdownMenu/DropdownButton.d.ts +47 -4
  109. package/lib/DropdownMenu/DropdownButton.js +1 -3
  110. package/lib/DropdownMenu/DropdownButton.jsx +14 -0
  111. package/lib/DropdownMenu/DropdownMenu.jsx +70 -0
  112. package/lib/DropdownMenu/index.js +6 -20
  113. package/lib/DropdownStyles.js +18 -26
  114. package/lib/EmojiPicker/EmojiPicker.d.ts +17 -0
  115. package/lib/EmojiPicker/EmojiPicker.js +202 -0
  116. package/lib/EmojiPicker/EmojiPicker.jsx +132 -0
  117. package/lib/EmojiPicker/EmojiPickerAnchor.d.ts +0 -0
  118. package/lib/EmojiPicker/EmojiPickerAnchor.js +1 -0
  119. package/lib/EmojiPicker/EmojiPickerAnchor.jsx +1 -0
  120. package/lib/EmojiPicker/EmojiPickerPanel.d.ts +3 -0
  121. package/lib/EmojiPicker/EmojiPickerPanel.js +18 -0
  122. package/lib/EmojiPicker/EmojiPickerPanel.jsx +10 -0
  123. package/lib/EmojiPicker/data.d.ts +9 -0
  124. package/lib/EmojiPicker/data.js +7254 -0
  125. package/lib/EmojiPicker/index.d.ts +2 -0
  126. package/lib/EmojiPicker/index.js +8 -0
  127. package/lib/FilterList.d.ts +303 -265
  128. package/lib/FilterList.js +6 -2
  129. package/lib/FilterList.jsx +63 -0
  130. package/lib/FilteredActionList/FilteredActionList.jsx +100 -0
  131. package/lib/FilteredActionList/index.js +4 -12
  132. package/lib/FilteredSearch.d.ts +2 -1
  133. package/lib/FilteredSearch.js +1 -1
  134. package/lib/FilteredSearch.jsx +29 -0
  135. package/lib/Flash.d.ts +2 -1
  136. package/lib/Flash.js +1 -1
  137. package/lib/Flash.jsx +70 -0
  138. package/lib/Flex.jsx +15 -0
  139. package/lib/FormGroup.d.ts +5 -4
  140. package/lib/FormGroup.js +2 -2
  141. package/lib/FormGroup.jsx +25 -0
  142. package/lib/Grid.jsx +15 -0
  143. package/lib/Header.d.ts +7 -6
  144. package/lib/Header.js +4 -4
  145. package/lib/Header.jsx +90 -0
  146. package/lib/Heading.d.ts +2 -1
  147. package/lib/Heading.js +6 -1
  148. package/lib/Heading.jsx +21 -0
  149. package/lib/Label.d.ts +2 -1
  150. package/lib/Label.js +3 -2
  151. package/lib/Label.jsx +84 -0
  152. package/lib/LabelGroup.d.ts +2 -1
  153. package/lib/LabelGroup.js +1 -1
  154. package/lib/LabelGroup.jsx +19 -0
  155. package/lib/Link.d.ts +2 -1
  156. package/lib/Link.js +1 -1
  157. package/lib/Link.jsx +38 -0
  158. package/lib/NewButton/button-counter.jsx +14 -0
  159. package/lib/NewButton/button.js +42 -34
  160. package/lib/NewButton/button.jsx +278 -0
  161. package/lib/NewButton/index.js +5 -12
  162. package/lib/NewButton/types.js +2 -1
  163. package/lib/Overlay.d.ts +11 -14
  164. package/lib/Overlay.js +4 -3
  165. package/lib/Overlay.jsx +156 -0
  166. package/lib/Pagehead.d.ts +2 -1
  167. package/lib/Pagehead.js +1 -1
  168. package/lib/Pagehead.jsx +18 -0
  169. package/lib/Pagination/Pagination.js +1 -1
  170. package/lib/Pagination/Pagination.jsx +163 -0
  171. package/lib/Pagination/index.js +6 -12
  172. package/lib/Pagination/model.jsx +174 -0
  173. package/lib/PointerBox.jsx +25 -0
  174. package/lib/Popover.d.ts +5 -4
  175. package/lib/Popover.js +5 -4
  176. package/lib/Popover.jsx +210 -0
  177. package/lib/Portal/Portal.jsx +79 -0
  178. package/lib/Portal/index.js +5 -16
  179. package/lib/Position.d.ts +4 -4
  180. package/lib/Position.jsx +46 -0
  181. package/lib/ProgressBar.d.ts +11 -16
  182. package/lib/ProgressBar.js +10 -6
  183. package/lib/ProgressBar.jsx +39 -0
  184. package/lib/SelectMenu/SelectMenu.d.ts +189 -35
  185. package/lib/SelectMenu/SelectMenu.js +3 -1
  186. package/lib/SelectMenu/SelectMenu.jsx +114 -0
  187. package/lib/SelectMenu/SelectMenuContext.jsx +5 -0
  188. package/lib/SelectMenu/SelectMenuDivider.d.ts +2 -1
  189. package/lib/SelectMenu/SelectMenuDivider.js +1 -1
  190. package/lib/SelectMenu/SelectMenuDivider.jsx +43 -0
  191. package/lib/SelectMenu/SelectMenuFilter.js +1 -1
  192. package/lib/SelectMenu/SelectMenuFilter.jsx +59 -0
  193. package/lib/SelectMenu/SelectMenuFooter.d.ts +2 -1
  194. package/lib/SelectMenu/SelectMenuFooter.js +1 -1
  195. package/lib/SelectMenu/SelectMenuFooter.jsx +46 -0
  196. package/lib/SelectMenu/SelectMenuHeader.d.ts +2 -1
  197. package/lib/SelectMenu/SelectMenuHeader.js +1 -1
  198. package/lib/SelectMenu/SelectMenuHeader.jsx +44 -0
  199. package/lib/SelectMenu/SelectMenuItem.d.ts +3 -2
  200. package/lib/SelectMenu/SelectMenuItem.js +1 -1
  201. package/lib/SelectMenu/SelectMenuItem.jsx +143 -0
  202. package/lib/SelectMenu/SelectMenuList.d.ts +2 -1
  203. package/lib/SelectMenu/SelectMenuList.js +1 -1
  204. package/lib/SelectMenu/SelectMenuList.jsx +60 -0
  205. package/lib/SelectMenu/SelectMenuLoadingAnimation.d.ts +2 -2
  206. package/lib/SelectMenu/SelectMenuLoadingAnimation.js +1 -3
  207. package/lib/SelectMenu/SelectMenuLoadingAnimation.jsx +21 -0
  208. package/lib/SelectMenu/SelectMenuModal.d.ts +3 -2
  209. package/lib/SelectMenu/SelectMenuModal.js +1 -1
  210. package/lib/SelectMenu/SelectMenuModal.jsx +119 -0
  211. package/lib/SelectMenu/SelectMenuTab.d.ts +2 -1
  212. package/lib/SelectMenu/SelectMenuTab.js +1 -1
  213. package/lib/SelectMenu/SelectMenuTab.jsx +93 -0
  214. package/lib/SelectMenu/SelectMenuTabPanel.d.ts +2 -1
  215. package/lib/SelectMenu/SelectMenuTabPanel.js +1 -1
  216. package/lib/SelectMenu/SelectMenuTabPanel.jsx +43 -0
  217. package/lib/SelectMenu/SelectMenuTabs.d.ts +2 -1
  218. package/lib/SelectMenu/SelectMenuTabs.js +1 -1
  219. package/lib/SelectMenu/SelectMenuTabs.jsx +58 -0
  220. package/lib/SelectMenu/hooks/useKeyboardNav.js +80 -96
  221. package/lib/SelectMenu/index.js +7 -14
  222. package/lib/SelectPanel/SelectPanel.jsx +105 -0
  223. package/lib/SelectPanel/index.js +4 -12
  224. package/lib/SideNav.d.ts +8 -11
  225. package/lib/SideNav.js +15 -8
  226. package/lib/SideNav.jsx +177 -0
  227. package/lib/Spinner.d.ts +2 -1
  228. package/lib/Spinner.js +3 -1
  229. package/lib/Spinner.jsx +35 -0
  230. package/lib/StateLabel.d.ts +2 -1
  231. package/lib/StateLabel.js +5 -6
  232. package/lib/StateLabel.jsx +94 -0
  233. package/lib/StyledOcticon.d.ts +2 -1
  234. package/lib/StyledOcticon.js +3 -1
  235. package/lib/StyledOcticon.jsx +20 -0
  236. package/lib/SubNav.d.ts +11 -5
  237. package/lib/SubNav.js +12 -7
  238. package/lib/SubNav.jsx +104 -0
  239. package/lib/TabNav.d.ts +4 -3
  240. package/lib/TabNav.js +2 -2
  241. package/lib/TabNav.jsx +60 -0
  242. package/lib/Text.jsx +14 -0
  243. package/lib/TextInput.d.ts +1 -8
  244. package/lib/TextInput.js +5 -16
  245. package/lib/TextInput.jsx +23 -0
  246. package/lib/TextInputWithTokens.d.ts +3 -12
  247. package/lib/TextInputWithTokens.jsx +218 -0
  248. package/lib/ThemeProvider.jsx +130 -0
  249. package/lib/Timeline.d.ts +393 -19
  250. package/lib/Timeline.js +13 -16
  251. package/lib/Timeline.jsx +124 -0
  252. package/lib/Token/AvatarToken.d.ts +1 -1
  253. package/lib/Token/AvatarToken.jsx +54 -0
  254. package/lib/Token/IssueLabelToken.d.ts +1 -1
  255. package/lib/Token/IssueLabelToken.jsx +125 -0
  256. package/lib/Token/Token.d.ts +1 -1
  257. package/lib/Token/Token.jsx +103 -0
  258. package/lib/Token/TokenBase.jsx +88 -0
  259. package/lib/Token/_RemoveTokenButton.jsx +108 -0
  260. package/lib/Token/_TokenTextContainer.jsx +49 -0
  261. package/lib/Token/index.js +11 -30
  262. package/lib/Tooltip.d.ts +2 -1
  263. package/lib/Tooltip.js +1 -1
  264. package/lib/Tooltip.jsx +246 -0
  265. package/lib/Truncate.d.ts +2 -1
  266. package/lib/Truncate.js +3 -1
  267. package/lib/Truncate.jsx +27 -0
  268. package/lib/UnderlineNav.d.ts +3 -2
  269. package/lib/UnderlineNav.js +2 -2
  270. package/lib/UnderlineNav.jsx +90 -0
  271. package/lib/_TextInputWrapper.d.ts +0 -3
  272. package/lib/_TextInputWrapper.js +7 -18
  273. package/lib/_TextInputWrapper.jsx +120 -0
  274. package/lib/_UnstyledTextInput.jsx +22 -0
  275. package/lib/behaviors/anchoredPosition.js +205 -234
  276. package/lib/behaviors/focusTrap.js +121 -157
  277. package/lib/behaviors/focusZone.js +434 -509
  278. package/lib/behaviors/scrollIntoViewingArea.js +18 -35
  279. package/lib/constants.js +39 -43
  280. package/lib/drafts.d.ts +0 -1
  281. package/lib/drafts.js +20 -43
  282. package/lib/hooks/index.js +16 -60
  283. package/lib/hooks/useAnchoredPosition.js +32 -40
  284. package/lib/hooks/useCombinedRefs.js +32 -36
  285. package/lib/hooks/useDetails.jsx +39 -0
  286. package/lib/hooks/useDialog.js +72 -96
  287. package/lib/hooks/useFocusTrap.js +43 -60
  288. package/lib/hooks/useFocusZone.js +54 -50
  289. package/lib/hooks/useOnEscapePress.js +25 -36
  290. package/lib/hooks/useOnOutsideClick.jsx +61 -0
  291. package/lib/hooks/useOpenAndCloseFocus.js +22 -34
  292. package/lib/hooks/useOverlay.jsx +15 -0
  293. package/lib/hooks/useProvidedRefOrCreate.js +10 -14
  294. package/lib/hooks/useProvidedStateOrCreate.js +13 -16
  295. package/lib/hooks/useRenderForcingRef.js +13 -17
  296. package/lib/hooks/useResizeObserver.js +15 -18
  297. package/lib/hooks/useSafeTimeout.js +22 -30
  298. package/lib/hooks/useScrollFlash.js +16 -23
  299. package/lib/index.d.ts +2 -2
  300. package/lib/index.js +165 -652
  301. package/lib/polyfills/eventListenerSignal.js +37 -45
  302. package/lib/sx.js +10 -22
  303. package/lib/theme-preval.js +64 -3169
  304. package/lib/theme.js +3 -12
  305. package/lib/utils/create-slots.jsx +65 -0
  306. package/lib/utils/deprecate.jsx +59 -0
  307. package/lib/utils/isNumeric.jsx +7 -0
  308. package/lib/utils/iterateFocusableElements.js +63 -85
  309. package/lib/utils/ssr.jsx +6 -0
  310. package/lib/utils/test-deprecations.jsx +20 -0
  311. package/lib/utils/test-helpers.jsx +8 -0
  312. package/lib/utils/test-matchers.jsx +100 -0
  313. package/lib/utils/testing.d.ts +61 -8
  314. package/lib/utils/testing.js +0 -29
  315. package/lib/utils/testing.jsx +206 -0
  316. package/lib/utils/theme.js +33 -47
  317. package/lib/utils/types/AriaRole.js +2 -1
  318. package/lib/utils/types/ComponentProps.js +2 -1
  319. package/lib/utils/types/Flatten.js +2 -1
  320. package/lib/utils/types/KeyPaths.js +2 -1
  321. package/lib/utils/types/MandateProps.js +16 -1
  322. package/lib/utils/types/Merge.js +2 -1
  323. package/lib/utils/types/index.js +16 -69
  324. package/lib/utils/uniqueId.js +5 -8
  325. package/lib/utils/use-force-update.js +8 -14
  326. package/lib/utils/useIsomorphicLayoutEffect.js +8 -11
  327. package/lib/utils/userAgent.js +8 -12
  328. package/lib-esm/ActionList/Item.js +56 -31
  329. package/lib-esm/ActionList2/Divider.d.ts +2 -3
  330. package/lib-esm/ActionList2/Divider.js +5 -8
  331. package/lib-esm/ActionList2/Group.d.ts +2 -28
  332. package/lib-esm/ActionList2/Group.js +5 -52
  333. package/lib-esm/ActionList2/Header.d.ts +26 -0
  334. package/lib-esm/ActionList2/Header.js +44 -0
  335. package/lib-esm/ActionList2/Item.js +6 -22
  336. package/lib-esm/ActionList2/List.d.ts +1 -1
  337. package/lib-esm/ActionList2/List.js +1 -8
  338. package/lib-esm/ActionList2/Selection.js +1 -12
  339. package/lib-esm/ActionList2/index.d.ts +2 -1
  340. package/lib-esm/Autocomplete/Autocomplete.d.ts +3 -12
  341. package/lib-esm/Autocomplete/AutocompleteInput.d.ts +3 -12
  342. package/lib-esm/Avatar.d.ts +2 -1
  343. package/lib-esm/Avatar.js +2 -2
  344. package/lib-esm/BranchName.d.ts +2 -1
  345. package/lib-esm/BranchName.js +2 -2
  346. package/lib-esm/Breadcrumbs.d.ts +7 -8
  347. package/lib-esm/Breadcrumbs.js +13 -8
  348. package/lib-esm/Button/Button.d.ts +3 -3
  349. package/lib-esm/Button/Button.js +2 -2
  350. package/lib-esm/Button/ButtonBase.d.ts +8 -5
  351. package/lib-esm/Button/ButtonBase.js +3 -1
  352. package/lib-esm/Button/ButtonClose.d.ts +46 -4
  353. package/lib-esm/Button/ButtonClose.js +2 -2
  354. package/lib-esm/Button/ButtonDanger.d.ts +3 -3
  355. package/lib-esm/Button/ButtonDanger.js +2 -2
  356. package/lib-esm/Button/ButtonInvisible.d.ts +3 -3
  357. package/lib-esm/Button/ButtonInvisible.js +2 -2
  358. package/lib-esm/Button/ButtonOutline.d.ts +3 -3
  359. package/lib-esm/Button/ButtonOutline.js +2 -2
  360. package/lib-esm/Button/ButtonPrimary.d.ts +3 -3
  361. package/lib-esm/Button/ButtonPrimary.js +2 -2
  362. package/lib-esm/Button/ButtonTableList.d.ts +2 -1
  363. package/lib-esm/Button/ButtonTableList.js +2 -2
  364. package/lib-esm/CircleBadge.d.ts +5 -4
  365. package/lib-esm/CircleBadge.js +2 -2
  366. package/lib-esm/CircleOcticon.d.ts +1 -2
  367. package/lib-esm/CounterLabel.d.ts +2 -1
  368. package/lib-esm/CounterLabel.js +2 -2
  369. package/lib-esm/Details.d.ts +2 -1
  370. package/lib-esm/Details.js +2 -1
  371. package/lib-esm/Dialog/Dialog.d.ts +9 -5
  372. package/lib-esm/Dialog/Dialog.js +12 -12
  373. package/lib-esm/Dialog.d.ts +5 -5
  374. package/lib-esm/Dialog.js +2 -2
  375. package/lib-esm/Dropdown.d.ts +165 -16
  376. package/lib-esm/Dropdown.js +4 -4
  377. package/lib-esm/DropdownMenu/DropdownButton.d.ts +47 -4
  378. package/lib-esm/DropdownMenu/DropdownButton.js +1 -3
  379. package/lib-esm/EmojiPicker/EmojiPicker.d.ts +17 -0
  380. package/lib-esm/EmojiPicker/EmojiPicker.js +181 -0
  381. package/lib-esm/EmojiPicker/EmojiPickerAnchor.d.ts +0 -0
  382. package/lib-esm/EmojiPicker/EmojiPickerAnchor.js +0 -0
  383. package/lib-esm/EmojiPicker/EmojiPickerPanel.d.ts +3 -0
  384. package/lib-esm/EmojiPicker/EmojiPickerPanel.js +8 -0
  385. package/lib-esm/EmojiPicker/data.d.ts +9 -0
  386. package/lib-esm/EmojiPicker/data.js +5434 -0
  387. package/lib-esm/EmojiPicker/index.d.ts +2 -0
  388. package/lib-esm/EmojiPicker/index.js +1 -0
  389. package/lib-esm/FilterList.d.ts +303 -265
  390. package/lib-esm/FilterList.js +7 -3
  391. package/lib-esm/FilteredSearch.d.ts +2 -1
  392. package/lib-esm/FilteredSearch.js +2 -2
  393. package/lib-esm/Flash.d.ts +2 -1
  394. package/lib-esm/Flash.js +2 -2
  395. package/lib-esm/FormGroup.d.ts +5 -4
  396. package/lib-esm/FormGroup.js +3 -3
  397. package/lib-esm/Header.d.ts +7 -6
  398. package/lib-esm/Header.js +5 -5
  399. package/lib-esm/Heading.d.ts +2 -1
  400. package/lib-esm/Heading.js +6 -2
  401. package/lib-esm/Label.d.ts +2 -1
  402. package/lib-esm/Label.js +4 -3
  403. package/lib-esm/LabelGroup.d.ts +2 -1
  404. package/lib-esm/LabelGroup.js +2 -2
  405. package/lib-esm/Link.d.ts +2 -1
  406. package/lib-esm/Link.js +2 -2
  407. package/lib-esm/NewButton/button.js +42 -31
  408. package/lib-esm/Overlay.d.ts +11 -14
  409. package/lib-esm/Overlay.js +3 -2
  410. package/lib-esm/Pagehead.d.ts +2 -1
  411. package/lib-esm/Pagehead.js +2 -2
  412. package/lib-esm/Pagination/Pagination.js +2 -2
  413. package/lib-esm/Popover.d.ts +5 -4
  414. package/lib-esm/Popover.js +5 -4
  415. package/lib-esm/Position.d.ts +4 -4
  416. package/lib-esm/ProgressBar.d.ts +11 -16
  417. package/lib-esm/ProgressBar.js +11 -7
  418. package/lib-esm/SelectMenu/SelectMenu.d.ts +189 -35
  419. package/lib-esm/SelectMenu/SelectMenu.js +2 -1
  420. package/lib-esm/SelectMenu/SelectMenuDivider.d.ts +2 -1
  421. package/lib-esm/SelectMenu/SelectMenuDivider.js +2 -2
  422. package/lib-esm/SelectMenu/SelectMenuFilter.js +2 -2
  423. package/lib-esm/SelectMenu/SelectMenuFooter.d.ts +2 -1
  424. package/lib-esm/SelectMenu/SelectMenuFooter.js +2 -2
  425. package/lib-esm/SelectMenu/SelectMenuHeader.d.ts +2 -1
  426. package/lib-esm/SelectMenu/SelectMenuHeader.js +2 -2
  427. package/lib-esm/SelectMenu/SelectMenuItem.d.ts +3 -2
  428. package/lib-esm/SelectMenu/SelectMenuItem.js +2 -2
  429. package/lib-esm/SelectMenu/SelectMenuList.d.ts +2 -1
  430. package/lib-esm/SelectMenu/SelectMenuList.js +2 -2
  431. package/lib-esm/SelectMenu/SelectMenuLoadingAnimation.d.ts +2 -2
  432. package/lib-esm/SelectMenu/SelectMenuLoadingAnimation.js +2 -3
  433. package/lib-esm/SelectMenu/SelectMenuModal.d.ts +3 -2
  434. package/lib-esm/SelectMenu/SelectMenuModal.js +2 -2
  435. package/lib-esm/SelectMenu/SelectMenuTab.d.ts +2 -1
  436. package/lib-esm/SelectMenu/SelectMenuTab.js +2 -2
  437. package/lib-esm/SelectMenu/SelectMenuTabPanel.d.ts +2 -1
  438. package/lib-esm/SelectMenu/SelectMenuTabPanel.js +2 -2
  439. package/lib-esm/SelectMenu/SelectMenuTabs.d.ts +2 -1
  440. package/lib-esm/SelectMenu/SelectMenuTabs.js +2 -2
  441. package/lib-esm/SideNav.d.ts +8 -11
  442. package/lib-esm/SideNav.js +16 -8
  443. package/lib-esm/Spinner.d.ts +2 -1
  444. package/lib-esm/Spinner.js +2 -1
  445. package/lib-esm/StateLabel.d.ts +2 -1
  446. package/lib-esm/StateLabel.js +6 -7
  447. package/lib-esm/StyledOcticon.d.ts +2 -1
  448. package/lib-esm/StyledOcticon.js +2 -1
  449. package/lib-esm/SubNav.d.ts +11 -5
  450. package/lib-esm/SubNav.js +13 -8
  451. package/lib-esm/TabNav.d.ts +4 -3
  452. package/lib-esm/TabNav.js +3 -3
  453. package/lib-esm/TextInput.d.ts +1 -8
  454. package/lib-esm/TextInput.js +5 -16
  455. package/lib-esm/TextInputWithTokens.d.ts +3 -12
  456. package/lib-esm/Timeline.d.ts +393 -19
  457. package/lib-esm/Timeline.js +13 -12
  458. package/lib-esm/Token/AvatarToken.d.ts +1 -1
  459. package/lib-esm/Token/IssueLabelToken.d.ts +1 -1
  460. package/lib-esm/Token/Token.d.ts +1 -1
  461. package/lib-esm/Tooltip.d.ts +2 -1
  462. package/lib-esm/Tooltip.js +2 -2
  463. package/lib-esm/Truncate.d.ts +2 -1
  464. package/lib-esm/Truncate.js +2 -1
  465. package/lib-esm/UnderlineNav.d.ts +3 -2
  466. package/lib-esm/UnderlineNav.js +3 -3
  467. package/lib-esm/_TextInputWrapper.d.ts +0 -3
  468. package/lib-esm/_TextInputWrapper.js +7 -18
  469. package/lib-esm/drafts.d.ts +0 -1
  470. package/lib-esm/drafts.js +1 -2
  471. package/lib-esm/index.d.ts +2 -2
  472. package/lib-esm/index.js +1 -1
  473. package/lib-esm/theme-preval.js +366 -512
  474. package/lib-esm/utils/testing.d.ts +61 -8
  475. package/lib-esm/utils/testing.js +0 -24
  476. package/package.json +6 -5
  477. package/lib/ActionList2/MenuContext.d.ts +0 -10
  478. package/lib/ActionList2/MenuContext.js +0 -15
  479. package/lib/ActionMenu2.d.ts +0 -310
  480. package/lib/ActionMenu2.js +0 -91
  481. package/lib/Checkbox.d.ts +0 -29
  482. package/lib/Checkbox.js +0 -64
  483. package/lib-esm/ActionList2/MenuContext.d.ts +0 -10
  484. package/lib-esm/ActionList2/MenuContext.js +0 -3
  485. package/lib-esm/ActionMenu2.d.ts +0 -310
  486. package/lib-esm/ActionMenu2.js +0 -67
  487. package/lib-esm/Checkbox.d.ts +0 -29
  488. 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;
@@ -1,6 +1,5 @@
1
- import React from 'react';
2
- import { SxProp } from '../sx';
1
+ /// <reference types="react" />
3
2
  /**
4
3
  * Visually separates `Item`s or `Group`s in an `ActionList`.
5
4
  */
6
- export declare const Divider: React.FC<SxProp>;
5
+ export declare function Divider(): JSX.Element;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.Divider = void 0;
6
+ exports.Divider = Divider;
7
7
 
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
 
@@ -11,30 +11,25 @@ var _Box = _interopRequireDefault(require("../Box"));
11
11
 
12
12
  var _constants = require("../constants");
13
13
 
14
- var _sx = require("../sx");
15
-
16
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
15
 
18
16
  /**
19
17
  * Visually separates `Item`s or `Group`s in an `ActionList`.
20
18
  */
21
- const Divider = ({
22
- sx = {}
23
- }) => {
19
+ function Divider() {
24
20
  return /*#__PURE__*/_react.default.createElement(_Box.default, {
25
21
  as: "li",
26
22
  role: "separator",
27
- sx: (0, _sx.merge)({
23
+ sx: {
28
24
  height: 1,
29
25
  backgroundColor: 'actionListItem.inlineDivider',
30
26
  marginTop: theme => `calc(${(0, _constants.get)('space.2')(theme)} - 1px)`,
31
27
  marginBottom: 2,
32
28
  listStyle: 'none' // hide the ::marker inserted by browser's stylesheet
33
29
 
34
- }, sx),
30
+ },
35
31
  "data-component": "ActionList.Divider"
36
32
  });
37
- };
33
+ }
38
34
 
39
- exports.Divider = Divider;
40
35
  Divider.displayName = "Divider";
@@ -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,26 @@
1
+ /// <reference types="react" />
2
+ import { SxProp } from '../sx';
3
+ /**
4
+ * Contract for props passed to the `Header` component.
5
+ */
6
+ export declare type HeaderProps = {
7
+ /**
8
+ * Style variations. Usage is discretionary.
9
+ *
10
+ * - `"filled"` - Superimposed on a background, offset from nearby content
11
+ * - `"subtle"` - Relatively less offset from nearby content
12
+ */
13
+ variant?: 'subtle' | 'filled';
14
+ /**
15
+ * Primary text which names a `Group`.
16
+ */
17
+ title?: string;
18
+ /**
19
+ * Secondary text which provides additional information about a `Group`.
20
+ */
21
+ auxiliaryText?: string;
22
+ } & SxProp;
23
+ /**
24
+ * Displays the name and description of a `Group`.
25
+ */
26
+ export declare const Header: ({ variant, title, auxiliaryText, sx, ...props }: HeaderProps) => JSX.Element;
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Header = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _Box = _interopRequireDefault(require("../Box"));
11
+
12
+ var _List = require("./List");
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+
16
+ 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); }
17
+
18
+ /**
19
+ * Displays the name and description of a `Group`.
20
+ */
21
+ const Header = ({
22
+ variant = 'subtle',
23
+ title,
24
+ auxiliaryText,
25
+ sx = {},
26
+ ...props
27
+ }) => {
28
+ const {
29
+ variant: listVariant
30
+ } = _react.default.useContext(_List.ListContext);
31
+
32
+ const styles = {
33
+ paddingY: '6px',
34
+ paddingX: listVariant === 'full' ? 2 : 3,
35
+ fontSize: 0,
36
+ fontWeight: 'bold',
37
+ color: 'fg.muted',
38
+ ...(variant === 'filled' && {
39
+ backgroundColor: 'canvas.subtle',
40
+ marginX: 0,
41
+ marginBottom: 2,
42
+ borderTop: '1px solid',
43
+ borderBottom: '1px solid',
44
+ borderColor: 'neutral.muted'
45
+ }),
46
+ ...sx
47
+ };
48
+ return /*#__PURE__*/_react.default.createElement(_Box.default, _extends({
49
+ sx: styles,
50
+ role: "heading"
51
+ }, props), title, auxiliaryText && /*#__PURE__*/_react.default.createElement("span", null, auxiliaryText));
52
+ };
53
+
54
+ exports.Header = Header;
55
+ Header.displayName = "Header";
@@ -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;
@@ -21,8 +21,6 @@ var _createSlots = _interopRequireDefault(require("../utils/create-slots"));
21
21
 
22
22
  var _List = require("./List");
23
23
 
24
- var _MenuContext = require("./MenuContext");
25
-
26
24
  var _Selection = require("./Selection");
27
25
 
28
26
  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); }
@@ -81,10 +79,9 @@ const Item = /*#__PURE__*/_react.default.forwardRef(({
81
79
  variant = 'default',
82
80
  disabled = false,
83
81
  selected = undefined,
84
- onSelect,
82
+ onSelect = () => null,
85
83
  sx: sxProp = {},
86
84
  id,
87
- role,
88
85
  _PrivateItemWrapper,
89
86
  ...props
90
87
  }, forwardedRef) => {
@@ -93,11 +90,6 @@ const Item = /*#__PURE__*/_react.default.forwardRef(({
93
90
  showDividers
94
91
  } = _react.default.useContext(_List.ListContext);
95
92
 
96
- const {
97
- itemRole,
98
- afterSelect
99
- } = _react.default.useContext(_MenuContext.MenuContext);
100
-
101
93
  const {
102
94
  theme
103
95
  } = (0, _ThemeProvider.useTheme)();
@@ -171,26 +163,17 @@ const Item = /*#__PURE__*/_react.default.forwardRef(({
171
163
  };
172
164
 
173
165
  const clickHandler = _react.default.useCallback(event => {
174
- if (typeof onSelect !== 'function') return;
175
166
  if (disabled) return;
176
-
177
- if (!event.defaultPrevented) {
178
- onSelect(event); // if this Item is inside a Menu, close the Menu
179
-
180
- if (typeof afterSelect === 'function') afterSelect();
181
- }
182
- }, [onSelect, disabled, afterSelect]);
167
+ if (!event.defaultPrevented) onSelect(event);
168
+ }, [onSelect, disabled]);
183
169
 
184
170
  const keyPressHandler = _react.default.useCallback(event => {
185
- if (typeof onSelect !== 'function') return;
186
171
  if (disabled) return;
187
172
 
188
173
  if (!event.defaultPrevented && [' ', 'Enter'].includes(event.key)) {
189
- onSelect(event); // if this Item is inside a Menu, close the Menu
190
-
191
- if (typeof afterSelect === 'function') afterSelect();
174
+ onSelect(event);
192
175
  }
193
- }, [onSelect, disabled, afterSelect]); // use props.id if provided, otherwise generate one.
176
+ }, [onSelect, disabled]); // use props.id if provided, otherwise generate one.
194
177
 
195
178
 
196
179
  const labelId = (0, _ssr.useSSRSafeId)(id);
@@ -213,8 +196,7 @@ const Item = /*#__PURE__*/_react.default.forwardRef(({
213
196
  "aria-disabled": disabled ? true : undefined,
214
197
  tabIndex: disabled || _PrivateItemWrapper ? undefined : 0,
215
198
  "aria-labelledby": `${labelId} ${slots.InlineDescription ? inlineDescriptionId : ''}`,
216
- "aria-describedby": slots.BlockDescription ? blockDescriptionId : undefined,
217
- role: role || itemRole
199
+ "aria-describedby": slots.BlockDescription ? blockDescriptionId : undefined
218
200
  }, props), /*#__PURE__*/_react.default.createElement(ItemWrapper, null, /*#__PURE__*/_react.default.createElement(_Selection.Selection, {
219
201
  selected: selected
220
202
  }), slots.LeadingVisual, /*#__PURE__*/_react.default.createElement(_Box.default, {