@primer/components 32.0.0 → 32.0.2-rc.859381a1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1176) hide show
  1. package/.changeset/README.md +8 -0
  2. package/.changeset/config.json +10 -0
  3. package/.devcontainer/devcontainer.json +8 -0
  4. package/.eslintrc.json +137 -0
  5. package/.github/ISSUE_TEMPLATE/bug_report.md +38 -0
  6. package/.github/ISSUE_TEMPLATE/new_component_proposal_template.md +41 -0
  7. package/.github/dependabot.yml +18 -0
  8. package/.github/pull_request_template.md +18 -0
  9. package/.github/workflows/check_for_changeset.yml +25 -0
  10. package/.github/workflows/ci.yml +31 -0
  11. package/.github/workflows/deploy_preview.yml +47 -0
  12. package/.github/workflows/deploy_production.yml +70 -0
  13. package/.github/workflows/release.yml +35 -0
  14. package/.github/workflows/release_canary.yml +70 -0
  15. package/.github/workflows/release_candidate.yml +60 -0
  16. package/.github/workflows/size.yml +13 -0
  17. package/.github/workflows/stale.yml +26 -0
  18. package/.gitignore +10 -0
  19. package/.npmrc +4 -0
  20. package/.nvmrc +1 -0
  21. package/.storybook/main.js +9 -0
  22. package/.storybook/preview.js +117 -0
  23. package/.vscode/launch.json +21 -0
  24. package/.vscode/settings.json +13 -0
  25. package/@types/@styled-system/index.d.ts +0 -0
  26. package/@types/@styled-system/prop-types/index.d.ts +1 -0
  27. package/@types/@styled-system/props/index.d.ts +1 -0
  28. package/@types/jest-styled-components/index.d.ts +1 -0
  29. package/CHANGELOG.md +14 -0
  30. package/CODEOWNERS +2 -0
  31. package/babel-defines.js +13 -0
  32. package/babel.config.js +39 -0
  33. package/contributor-docs/CODE_OF_CONDUCT.md +76 -0
  34. package/contributor-docs/CONTRIBUTING.md +274 -0
  35. package/contributor-docs/adrs/adr-001-typescript.md +23 -0
  36. package/contributor-docs/adrs/adr-002-behavior-isolation.md +108 -0
  37. package/contributor-docs/adrs/adr-003-prop-norms.md +72 -0
  38. package/contributor-docs/behaviors.md +132 -0
  39. package/contributor-docs/component-contents-api-patterns.md +316 -0
  40. package/contributor-docs/principles.md +39 -0
  41. package/dist/browser.esm.js +136 -136
  42. package/dist/browser.esm.js.map +1 -1
  43. package/dist/browser.umd.js +120 -120
  44. package/dist/browser.umd.js.map +1 -1
  45. package/docs/.eslintrc +0 -0
  46. package/docs/.gitignore +91 -0
  47. package/docs/components/PropsList.js +5 -0
  48. package/docs/components/State.js +9 -0
  49. package/docs/components/constants.js +34 -0
  50. package/docs/components/index.js +2 -0
  51. package/docs/content/ActionList.mdx +99 -0
  52. package/docs/content/ActionList2.mdx +359 -0
  53. package/docs/content/ActionMenu.mdx +80 -0
  54. package/docs/content/AnchoredOverlay.mdx +37 -0
  55. package/docs/content/Autocomplete.mdx +657 -0
  56. package/docs/content/Avatar.mdx +33 -0
  57. package/docs/content/AvatarStack.mdx +37 -0
  58. package/docs/content/BorderBox.md +46 -0
  59. package/docs/content/Box.mdx +96 -0
  60. package/docs/content/BranchName.md +18 -0
  61. package/docs/content/Breadcrumbs.md +47 -0
  62. package/docs/content/Buttons.md +46 -0
  63. package/docs/content/CircleBadge.md +35 -0
  64. package/docs/content/CircleOcticon.md +18 -0
  65. package/docs/content/CounterLabel.md +22 -0
  66. package/docs/content/Details.md +105 -0
  67. package/docs/content/Dialog.md +105 -0
  68. package/docs/content/Dialog2.mdx +180 -0
  69. package/docs/content/Dropdown.md +65 -0
  70. package/docs/content/DropdownMenu.mdx +49 -0
  71. package/docs/content/FilterList.md +37 -0
  72. package/docs/content/FilteredSearch.md +32 -0
  73. package/docs/content/Flash.md +35 -0
  74. package/docs/content/Flex.md +58 -0
  75. package/docs/content/FormGroup.md +38 -0
  76. package/docs/content/Grid.md +59 -0
  77. package/docs/content/Header.md +77 -0
  78. package/docs/content/Heading.md +22 -0
  79. package/docs/content/Label.md +49 -0
  80. package/docs/content/LabelGroup.md +21 -0
  81. package/docs/content/Link.md +28 -0
  82. package/docs/content/Overlay.mdx +85 -0
  83. package/docs/content/Pagehead.md +18 -0
  84. package/docs/content/Pagination.md +178 -0
  85. package/docs/content/PointerBox.md +81 -0
  86. package/docs/content/Popover.md +129 -0
  87. package/docs/content/Portal.mdx +78 -0
  88. package/docs/content/Position.md +100 -0
  89. package/docs/content/ProgressBar.mdx +29 -0
  90. package/docs/content/SelectMenu.md +371 -0
  91. package/docs/content/SelectPanel.mdx +67 -0
  92. package/docs/content/SideNav.md +171 -0
  93. package/docs/content/Spinner.mdx +32 -0
  94. package/docs/content/StateLabel.md +27 -0
  95. package/docs/content/StyledOcticon.md +27 -0
  96. package/docs/content/SubNav.md +100 -0
  97. package/docs/content/TabNav.md +42 -0
  98. package/docs/content/Text.md +31 -0
  99. package/docs/content/TextInput.md +34 -0
  100. package/docs/content/TextInputTokens.mdx +89 -0
  101. package/docs/content/TextInputWithTokens.mdx +211 -0
  102. package/docs/content/Timeline.md +148 -0
  103. package/docs/content/Token.mdx +381 -0
  104. package/docs/content/Tooltip.md +32 -0
  105. package/docs/content/Truncate.md +55 -0
  106. package/docs/content/UnderlineNav.md +45 -0
  107. package/docs/content/anchoredPosition.mdx +163 -0
  108. package/docs/content/core-concepts.md +70 -0
  109. package/docs/content/focusTrap.mdx +103 -0
  110. package/docs/content/focusZone.mdx +145 -0
  111. package/docs/content/getting-started.md +138 -0
  112. package/docs/content/index.md +33 -0
  113. package/docs/content/linting.md +35 -0
  114. package/docs/content/overriding-styles.mdx +82 -0
  115. package/docs/content/philosophy.md +23 -0
  116. package/docs/content/primer-theme.md +89 -0
  117. package/docs/content/ssr.mdx +43 -0
  118. package/docs/content/system-props.mdx +37 -0
  119. package/docs/content/theme-reference.md +16 -0
  120. package/docs/content/theming.md +272 -0
  121. package/docs/content/useOnEscapePress.mdx +56 -0
  122. package/docs/content/useOnOutsideClick.mdx +57 -0
  123. package/docs/content/useOpenAndCloseFocus.mdx +49 -0
  124. package/docs/content/useOverlay.mdx +62 -0
  125. package/docs/content/useSafeTimeout.mdx +32 -0
  126. package/docs/gatsby-config.js +30 -0
  127. package/docs/gatsby-node.js +101 -0
  128. package/docs/package-lock.json +20867 -0
  129. package/docs/package.json +36 -0
  130. package/docs/src/@primer/gatsby-theme-doctocat/components/hero.js +21 -0
  131. package/docs/src/@primer/gatsby-theme-doctocat/components/live-preview-wrapper.js +41 -0
  132. package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +73 -0
  133. package/docs/src/@primer/gatsby-theme-doctocat/nav.yml +133 -0
  134. package/docs/src/@primer/gatsby-theme-doctocat/primer-components-hero.svg +1411 -0
  135. package/docs/src/component-checklist.js +81 -0
  136. package/docs/src/props.js +77 -0
  137. package/jest.config.js +13 -0
  138. package/lib/ActionList/index.js +23 -12
  139. package/lib/ActionList2/index.js +41 -23
  140. package/lib/AnchoredOverlay/index.js +12 -4
  141. package/lib/Autocomplete/index.js +14 -7
  142. package/lib/Button/index.js +70 -21
  143. package/lib/DropdownMenu/index.js +20 -6
  144. package/lib/DropdownStyles.js +26 -18
  145. package/lib/FilteredActionList/index.js +12 -4
  146. package/lib/NewButton/index.js +12 -5
  147. package/lib/NewButton/types.js +1 -2
  148. package/lib/Overlay.d.ts +5 -3
  149. package/lib/Pagination/index.js +12 -6
  150. package/lib/Portal/index.js +16 -5
  151. package/lib/SelectMenu/hooks/useKeyboardNav.js +96 -80
  152. package/lib/SelectMenu/index.js +14 -7
  153. package/lib/SelectPanel/index.js +12 -4
  154. package/lib/Token/index.js +30 -11
  155. package/lib/__tests__/ActionList.test.d.ts +1 -0
  156. package/lib/__tests__/ActionList.test.js +69 -0
  157. package/lib/__tests__/ActionList.types.test.d.ts +6 -0
  158. package/lib/__tests__/ActionList.types.test.js +69 -0
  159. package/lib/__tests__/ActionList2.test.d.ts +1 -0
  160. package/lib/__tests__/ActionList2.test.js +53 -0
  161. package/lib/__tests__/ActionMenu.test.d.ts +1 -0
  162. package/lib/__tests__/ActionMenu.test.js +151 -0
  163. package/lib/__tests__/AnchoredOverlay.test.d.ts +1 -0
  164. package/lib/__tests__/AnchoredOverlay.test.js +162 -0
  165. package/lib/__tests__/Autocomplete.test.d.ts +1 -0
  166. package/lib/__tests__/Autocomplete.test.js +528 -0
  167. package/lib/__tests__/Avatar.test.d.ts +1 -0
  168. package/lib/__tests__/Avatar.test.js +67 -0
  169. package/lib/__tests__/AvatarStack.test.d.ts +1 -0
  170. package/lib/__tests__/AvatarStack.test.js +71 -0
  171. package/lib/__tests__/BorderBox.test.d.ts +1 -0
  172. package/lib/__tests__/BorderBox.test.js +58 -0
  173. package/lib/__tests__/Box.test.d.ts +1 -0
  174. package/lib/__tests__/Box.test.js +78 -0
  175. package/lib/__tests__/BranchName.test.d.ts +1 -0
  176. package/lib/__tests__/BranchName.test.js +36 -0
  177. package/lib/__tests__/Breadcrumbs.test.d.ts +1 -0
  178. package/lib/__tests__/Breadcrumbs.test.js +40 -0
  179. package/lib/__tests__/Breadcrumbs.types.test.d.ts +3 -0
  180. package/lib/__tests__/Breadcrumbs.types.test.js +25 -0
  181. package/lib/__tests__/BreadcrumbsItem.test.d.ts +1 -0
  182. package/lib/__tests__/BreadcrumbsItem.test.js +49 -0
  183. package/lib/__tests__/Button.test.d.ts +1 -0
  184. package/lib/__tests__/Button.test.js +147 -0
  185. package/lib/__tests__/Caret.test.d.ts +1 -0
  186. package/lib/__tests__/Caret.test.js +52 -0
  187. package/lib/__tests__/CircleBadge.test.d.ts +1 -0
  188. package/lib/__tests__/CircleBadge.test.js +83 -0
  189. package/lib/__tests__/CircleBadge.types.test.d.ts +3 -0
  190. package/lib/__tests__/CircleBadge.types.test.js +28 -0
  191. package/lib/__tests__/CircleOcticon.test.d.ts +1 -0
  192. package/lib/__tests__/CircleOcticon.test.js +71 -0
  193. package/lib/__tests__/ConfirmationDialog.test.d.ts +1 -0
  194. package/lib/__tests__/ConfirmationDialog.test.js +134 -0
  195. package/lib/__tests__/CounterLabel.test.d.ts +1 -0
  196. package/lib/__tests__/CounterLabel.test.js +58 -0
  197. package/lib/__tests__/CounterLabel.types.test.d.ts +3 -0
  198. package/lib/__tests__/CounterLabel.types.test.js +28 -0
  199. package/lib/__tests__/Details.test.d.ts +1 -0
  200. package/lib/__tests__/Details.test.js +117 -0
  201. package/lib/__tests__/Dialog.test.d.ts +1 -0
  202. package/lib/__tests__/Dialog.test.js +184 -0
  203. package/lib/__tests__/Dialog.types.test.d.ts +3 -0
  204. package/lib/__tests__/Dialog.types.test.js +28 -0
  205. package/lib/__tests__/Dialog2.types.test.d.ts +3 -0
  206. package/lib/__tests__/Dialog2.types.test.js +31 -0
  207. package/lib/__tests__/Dropdown.test.d.ts +1 -0
  208. package/lib/__tests__/Dropdown.test.js +63 -0
  209. package/lib/__tests__/Dropdown.types.test.d.ts +3 -0
  210. package/lib/__tests__/Dropdown.types.test.js +31 -0
  211. package/lib/__tests__/DropdownMenu.test.d.ts +1 -0
  212. package/lib/__tests__/DropdownMenu.test.js +150 -0
  213. package/lib/__tests__/FilterList.test.d.ts +1 -0
  214. package/lib/__tests__/FilterList.test.js +36 -0
  215. package/lib/__tests__/FilterList.types.test.d.ts +3 -0
  216. package/lib/__tests__/FilterList.types.test.js +27 -0
  217. package/lib/__tests__/FilterListItem.test.d.ts +1 -0
  218. package/lib/__tests__/FilterListItem.test.js +46 -0
  219. package/lib/__tests__/FilteredSearch.test.d.ts +1 -0
  220. package/lib/__tests__/FilteredSearch.test.js +36 -0
  221. package/lib/__tests__/FilteredSearch.types.test.d.ts +3 -0
  222. package/lib/__tests__/FilteredSearch.types.test.js +28 -0
  223. package/lib/__tests__/Flash.test.d.ts +1 -0
  224. package/lib/__tests__/Flash.test.js +62 -0
  225. package/lib/__tests__/Flash.types.test.d.ts +3 -0
  226. package/lib/__tests__/Flash.types.test.js +28 -0
  227. package/lib/__tests__/Flex.test.d.ts +1 -0
  228. package/lib/__tests__/Flex.test.js +74 -0
  229. package/lib/__tests__/FormGroup.test.d.ts +1 -0
  230. package/lib/__tests__/FormGroup.test.js +54 -0
  231. package/lib/__tests__/FormGroup.types.test.d.ts +3 -0
  232. package/lib/__tests__/FormGroup.types.test.js +28 -0
  233. package/lib/__tests__/Grid.test.d.ts +1 -0
  234. package/lib/__tests__/Grid.test.js +104 -0
  235. package/lib/__tests__/Header.test.d.ts +1 -0
  236. package/lib/__tests__/Header.test.js +58 -0
  237. package/lib/__tests__/Header.types.test.d.ts +3 -0
  238. package/lib/__tests__/Header.types.test.js +29 -0
  239. package/lib/__tests__/Heading.test.d.ts +1 -0
  240. package/lib/__tests__/Heading.test.js +109 -0
  241. package/lib/__tests__/KeyPaths.types.test.d.ts +11 -0
  242. package/lib/__tests__/KeyPaths.types.test.js +10 -0
  243. package/lib/__tests__/Label.test.d.ts +1 -0
  244. package/lib/__tests__/Label.test.js +46 -0
  245. package/lib/__tests__/Label.types.test.d.ts +3 -0
  246. package/lib/__tests__/Label.types.test.js +28 -0
  247. package/lib/__tests__/LabelGroup.test.d.ts +1 -0
  248. package/lib/__tests__/LabelGroup.test.js +38 -0
  249. package/lib/__tests__/LabelGroup.types.test.d.ts +3 -0
  250. package/lib/__tests__/LabelGroup.types.test.js +28 -0
  251. package/lib/__tests__/Link.test.d.ts +1 -0
  252. package/lib/__tests__/Link.test.js +76 -0
  253. package/lib/__tests__/Link.types.test.d.ts +3 -0
  254. package/lib/__tests__/Link.types.test.js +28 -0
  255. package/lib/__tests__/Merge.types.test.d.ts +30 -0
  256. package/lib/__tests__/Merge.types.test.js +27 -0
  257. package/lib/__tests__/NewButton.test.d.ts +1 -0
  258. package/lib/__tests__/NewButton.test.js +95 -0
  259. package/lib/__tests__/Overlay.test.d.ts +1 -0
  260. package/lib/__tests__/Overlay.test.js +145 -0
  261. package/lib/__tests__/Overlay.types.test.d.ts +6 -0
  262. package/lib/__tests__/Overlay.types.test.js +73 -0
  263. package/lib/__tests__/Pagehead.test.d.ts +1 -0
  264. package/lib/__tests__/Pagehead.test.js +37 -0
  265. package/lib/__tests__/Pagehead.types.test.d.ts +3 -0
  266. package/lib/__tests__/Pagehead.types.test.js +28 -0
  267. package/lib/__tests__/Pagination/Pagination.test.d.ts +1 -0
  268. package/lib/__tests__/Pagination/Pagination.test.js +47 -0
  269. package/lib/__tests__/Pagination/PaginationModel.test.d.ts +1 -0
  270. package/lib/__tests__/Pagination/PaginationModel.test.js +186 -0
  271. package/lib/__tests__/Pagination.types.test.d.ts +3 -0
  272. package/lib/__tests__/Pagination.types.test.js +33 -0
  273. package/lib/__tests__/PointerBox.test.d.ts +1 -0
  274. package/lib/__tests__/PointerBox.test.js +46 -0
  275. package/lib/__tests__/Popover.test.d.ts +1 -0
  276. package/lib/__tests__/Popover.test.js +66 -0
  277. package/lib/__tests__/Popover.types.test.d.ts +3 -0
  278. package/lib/__tests__/Popover.types.test.js +27 -0
  279. package/lib/__tests__/Portal.test.d.ts +1 -0
  280. package/lib/__tests__/Portal.test.js +124 -0
  281. package/lib/__tests__/Position.test.d.ts +1 -0
  282. package/lib/__tests__/Position.test.js +143 -0
  283. package/lib/__tests__/ProgressBar.test.d.ts +1 -0
  284. package/lib/__tests__/ProgressBar.test.js +68 -0
  285. package/lib/__tests__/SelectMenu.test.d.ts +1 -0
  286. package/lib/__tests__/SelectMenu.test.js +155 -0
  287. package/lib/__tests__/SelectMenu.types.test.d.ts +3 -0
  288. package/lib/__tests__/SelectMenu.types.test.js +47 -0
  289. package/lib/__tests__/SelectPanel.test.d.ts +1 -0
  290. package/lib/__tests__/SelectPanel.test.js +80 -0
  291. package/lib/__tests__/SelectPanel.types.test.d.ts +3 -0
  292. package/lib/__tests__/SelectPanel.types.test.js +44 -0
  293. package/lib/__tests__/SideNav.test.d.ts +1 -0
  294. package/lib/__tests__/SideNav.test.js +71 -0
  295. package/lib/__tests__/SideNav.types.test.d.ts +3 -0
  296. package/lib/__tests__/SideNav.types.test.js +28 -0
  297. package/lib/__tests__/Spinner.test.d.ts +1 -0
  298. package/lib/__tests__/Spinner.test.js +53 -0
  299. package/lib/__tests__/StateLabel.test.d.ts +1 -0
  300. package/lib/__tests__/StateLabel.test.js +71 -0
  301. package/lib/__tests__/StateLabel.types.test.d.ts +3 -0
  302. package/lib/__tests__/StateLabel.types.test.js +28 -0
  303. package/lib/__tests__/StyledOcticon.test.d.ts +1 -0
  304. package/lib/__tests__/StyledOcticon.test.js +40 -0
  305. package/lib/__tests__/StyledOcticon.types.test.d.ts +3 -0
  306. package/lib/__tests__/StyledOcticon.types.test.js +32 -0
  307. package/lib/__tests__/SubNav.test.d.ts +1 -0
  308. package/lib/__tests__/SubNav.test.js +62 -0
  309. package/lib/__tests__/SubNav.types.test.d.ts +3 -0
  310. package/lib/__tests__/SubNav.types.test.js +27 -0
  311. package/lib/__tests__/SubNavLink.test.d.ts +1 -0
  312. package/lib/__tests__/SubNavLink.test.js +49 -0
  313. package/lib/__tests__/TabNav.test.d.ts +1 -0
  314. package/lib/__tests__/TabNav.test.js +49 -0
  315. package/lib/__tests__/TabNav.types.test.d.ts +3 -0
  316. package/lib/__tests__/TabNav.types.test.js +25 -0
  317. package/lib/__tests__/Text.test.d.ts +1 -0
  318. package/lib/__tests__/Text.test.js +105 -0
  319. package/lib/__tests__/TextInput.test.d.ts +1 -0
  320. package/lib/__tests__/TextInput.test.js +78 -0
  321. package/lib/__tests__/TextInputWithTokens.test.d.ts +1 -0
  322. package/lib/__tests__/TextInputWithTokens.test.js +572 -0
  323. package/lib/__tests__/ThemeProvider.test.d.ts +1 -0
  324. package/lib/__tests__/ThemeProvider.test.js +444 -0
  325. package/lib/__tests__/Timeline.test.d.ts +1 -0
  326. package/lib/__tests__/Timeline.test.js +75 -0
  327. package/lib/__tests__/Timeline.types.test.d.ts +3 -0
  328. package/lib/__tests__/Timeline.types.test.js +31 -0
  329. package/lib/__tests__/Token.test.d.ts +1 -0
  330. package/lib/__tests__/Token.test.js +180 -0
  331. package/lib/__tests__/Tooltip.test.d.ts +1 -0
  332. package/lib/__tests__/Tooltip.test.js +69 -0
  333. package/lib/__tests__/Tooltip.types.test.d.ts +3 -0
  334. package/lib/__tests__/Tooltip.types.test.js +28 -0
  335. package/lib/__tests__/Truncate.test.d.ts +1 -0
  336. package/lib/__tests__/Truncate.test.js +63 -0
  337. package/lib/__tests__/Truncate.types.test.d.ts +3 -0
  338. package/lib/__tests__/Truncate.types.test.js +31 -0
  339. package/lib/__tests__/UnderlineNav.test.d.ts +1 -0
  340. package/lib/__tests__/UnderlineNav.test.js +72 -0
  341. package/lib/__tests__/UnderlineNav.types.test.d.ts +3 -0
  342. package/lib/__tests__/UnderlineNav.types.test.js +25 -0
  343. package/lib/__tests__/UnderlineNavLink.test.d.ts +1 -0
  344. package/lib/__tests__/UnderlineNavLink.test.js +51 -0
  345. package/lib/__tests__/behaviors/anchoredPosition.test.d.ts +1 -0
  346. package/lib/__tests__/behaviors/anchoredPosition.test.js +390 -0
  347. package/lib/__tests__/behaviors/focusTrap.test.d.ts +1 -0
  348. package/lib/__tests__/behaviors/focusTrap.test.js +234 -0
  349. package/lib/__tests__/behaviors/focusZone.test.d.ts +1 -0
  350. package/lib/__tests__/behaviors/focusZone.test.js +570 -0
  351. package/lib/__tests__/behaviors/iterateFocusableElements.test.d.ts +1 -0
  352. package/lib/__tests__/behaviors/iterateFocusableElements.test.js +55 -0
  353. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +1 -0
  354. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.js +226 -0
  355. package/lib/__tests__/filterObject.test.d.ts +1 -0
  356. package/lib/__tests__/filterObject.test.js +30 -0
  357. package/lib/__tests__/hooks/useAnchoredPosition.test.d.ts +1 -0
  358. package/lib/__tests__/hooks/useAnchoredPosition.test.js +54 -0
  359. package/lib/__tests__/hooks/useOnEscapePress.test.d.ts +1 -0
  360. package/lib/__tests__/hooks/useOnEscapePress.test.js +32 -0
  361. package/lib/__tests__/hooks/useOnOutsideClick.test.d.ts +1 -0
  362. package/lib/__tests__/hooks/useOnOutsideClick.test.js +87 -0
  363. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +1 -0
  364. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.js +60 -0
  365. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +1 -0
  366. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.js +45 -0
  367. package/lib/__tests__/theme.test.d.ts +1 -0
  368. package/lib/__tests__/theme.test.js +36 -0
  369. package/lib/__tests__/themeGet.test.d.ts +1 -0
  370. package/lib/__tests__/themeGet.test.js +25 -0
  371. package/lib/__tests__/useSafeTimeout.test.d.ts +1 -0
  372. package/lib/__tests__/useSafeTimeout.test.js +45 -0
  373. package/lib/__tests__/utils/createSlots.test.d.ts +1 -0
  374. package/lib/__tests__/utils/createSlots.test.js +75 -0
  375. package/lib/behaviors/anchoredPosition.js +234 -205
  376. package/lib/behaviors/focusTrap.js +157 -121
  377. package/lib/behaviors/focusZone.js +509 -434
  378. package/lib/behaviors/scrollIntoViewingArea.js +35 -18
  379. package/lib/constants.js +43 -39
  380. package/lib/drafts.js +30 -20
  381. package/lib/hooks/index.js +60 -16
  382. package/lib/hooks/useAnchoredPosition.js +40 -32
  383. package/lib/hooks/useCombinedRefs.js +36 -32
  384. package/lib/hooks/useDialog.js +96 -72
  385. package/lib/hooks/useFocusTrap.js +60 -43
  386. package/lib/hooks/useFocusZone.js +50 -54
  387. package/lib/hooks/useOnEscapePress.js +36 -25
  388. package/lib/hooks/useOpenAndCloseFocus.js +34 -22
  389. package/lib/hooks/useProvidedRefOrCreate.js +14 -10
  390. package/lib/hooks/useProvidedStateOrCreate.js +16 -13
  391. package/lib/hooks/useRenderForcingRef.js +17 -13
  392. package/lib/hooks/useResizeObserver.js +18 -15
  393. package/lib/hooks/useSafeTimeout.js +30 -22
  394. package/lib/hooks/useScrollFlash.js +23 -16
  395. package/lib/index.js +644 -163
  396. package/lib/polyfills/eventListenerSignal.js +45 -37
  397. package/lib/stories/ActionList.stories.js +454 -0
  398. package/lib/stories/ActionList2.stories.js +909 -0
  399. package/lib/stories/ActionMenu.stories.js +348 -0
  400. package/lib/stories/AnchoredOverlay.stories.js +127 -0
  401. package/lib/stories/Autocomplete.stories.js +619 -0
  402. package/lib/stories/AvatarStack.stories.js +49 -0
  403. package/lib/stories/Button.stories.js +125 -0
  404. package/lib/stories/ConfirmationDialog.stories.js +119 -0
  405. package/lib/stories/Dialog.stories.js +269 -0
  406. package/lib/stories/DropdownMenu.stories.js +122 -0
  407. package/lib/stories/IssueLabelToken.stories.js +165 -0
  408. package/lib/stories/NewButton.stories.js +230 -0
  409. package/lib/stories/Overlay.stories.js +204 -0
  410. package/lib/stories/Portal.stories.js +104 -0
  411. package/lib/stories/ProfileToken.stories.js +162 -0
  412. package/lib/stories/SelectPanel.stories.js +399 -0
  413. package/lib/stories/TextInput.stories.js +144 -0
  414. package/lib/stories/TextInputWithTokens.stories.js +252 -0
  415. package/lib/stories/ThemeProvider.stories.js +102 -0
  416. package/lib/stories/Token.stories.js +176 -0
  417. package/lib/stories/useAnchoredPosition.stories.js +351 -0
  418. package/lib/stories/useFocusTrap.stories.js +360 -0
  419. package/lib/stories/useFocusZone.stories.js +607 -0
  420. package/lib/sx.js +22 -10
  421. package/lib/theme-preval.js +3169 -64
  422. package/lib/theme.js +12 -3
  423. package/lib/utils/iterateFocusableElements.js +85 -63
  424. package/lib/utils/testing.d.ts +1 -1
  425. package/lib/utils/theme.js +47 -33
  426. package/lib/utils/types/AriaRole.js +1 -2
  427. package/lib/utils/types/ComponentProps.js +1 -2
  428. package/lib/utils/types/Flatten.js +1 -2
  429. package/lib/utils/types/KeyPaths.js +1 -2
  430. package/lib/utils/types/MandateProps.js +1 -16
  431. package/lib/utils/types/Merge.js +1 -2
  432. package/lib/utils/types/index.js +69 -16
  433. package/lib/utils/uniqueId.js +8 -5
  434. package/lib/utils/use-force-update.js +14 -8
  435. package/lib/utils/useIsomorphicLayoutEffect.js +11 -8
  436. package/lib/utils/userAgent.js +12 -8
  437. package/lib-esm/Overlay.d.ts +5 -3
  438. package/lib-esm/__tests__/ActionList.test.d.ts +1 -0
  439. package/lib-esm/__tests__/ActionList.test.js +57 -0
  440. package/lib-esm/__tests__/ActionList.types.test.d.ts +6 -0
  441. package/lib-esm/__tests__/ActionList.types.test.js +45 -0
  442. package/lib-esm/__tests__/ActionList2.test.d.ts +1 -0
  443. package/lib-esm/__tests__/ActionList2.test.js +41 -0
  444. package/lib-esm/__tests__/ActionMenu.test.d.ts +1 -0
  445. package/lib-esm/__tests__/ActionMenu.test.js +139 -0
  446. package/lib-esm/__tests__/AnchoredOverlay.test.d.ts +1 -0
  447. package/lib-esm/__tests__/AnchoredOverlay.test.js +136 -0
  448. package/lib-esm/__tests__/Autocomplete.test.d.ts +1 -0
  449. package/lib-esm/__tests__/Autocomplete.test.js +494 -0
  450. package/lib-esm/__tests__/Avatar.test.d.ts +1 -0
  451. package/lib-esm/__tests__/Avatar.test.js +56 -0
  452. package/lib-esm/__tests__/AvatarStack.test.d.ts +1 -0
  453. package/lib-esm/__tests__/AvatarStack.test.js +58 -0
  454. package/lib-esm/__tests__/BorderBox.test.d.ts +1 -0
  455. package/lib-esm/__tests__/BorderBox.test.js +47 -0
  456. package/lib-esm/__tests__/Box.test.d.ts +1 -0
  457. package/lib-esm/__tests__/Box.test.js +67 -0
  458. package/lib-esm/__tests__/BranchName.test.d.ts +1 -0
  459. package/lib-esm/__tests__/BranchName.test.js +26 -0
  460. package/lib-esm/__tests__/Breadcrumbs.test.d.ts +1 -0
  461. package/lib-esm/__tests__/Breadcrumbs.test.js +30 -0
  462. package/lib-esm/__tests__/Breadcrumbs.types.test.d.ts +3 -0
  463. package/lib-esm/__tests__/Breadcrumbs.types.test.js +12 -0
  464. package/lib-esm/__tests__/BreadcrumbsItem.test.d.ts +1 -0
  465. package/lib-esm/__tests__/BreadcrumbsItem.test.js +39 -0
  466. package/lib-esm/__tests__/Button.test.d.ts +1 -0
  467. package/lib-esm/__tests__/Button.test.js +137 -0
  468. package/lib-esm/__tests__/Caret.test.d.ts +1 -0
  469. package/lib-esm/__tests__/Caret.test.js +42 -0
  470. package/lib-esm/__tests__/CircleBadge.test.d.ts +1 -0
  471. package/lib-esm/__tests__/CircleBadge.test.js +70 -0
  472. package/lib-esm/__tests__/CircleBadge.types.test.d.ts +3 -0
  473. package/lib-esm/__tests__/CircleBadge.types.test.js +13 -0
  474. package/lib-esm/__tests__/CircleOcticon.test.d.ts +1 -0
  475. package/lib-esm/__tests__/CircleOcticon.test.js +59 -0
  476. package/lib-esm/__tests__/ConfirmationDialog.test.d.ts +1 -0
  477. package/lib-esm/__tests__/ConfirmationDialog.test.js +113 -0
  478. package/lib-esm/__tests__/CounterLabel.test.d.ts +1 -0
  479. package/lib-esm/__tests__/CounterLabel.test.js +47 -0
  480. package/lib-esm/__tests__/CounterLabel.types.test.d.ts +3 -0
  481. package/lib-esm/__tests__/CounterLabel.types.test.js +13 -0
  482. package/lib-esm/__tests__/Details.test.d.ts +1 -0
  483. package/lib-esm/__tests__/Details.test.js +107 -0
  484. package/lib-esm/__tests__/Dialog.test.d.ts +1 -0
  485. package/lib-esm/__tests__/Dialog.test.js +171 -0
  486. package/lib-esm/__tests__/Dialog.types.test.d.ts +3 -0
  487. package/lib-esm/__tests__/Dialog.types.test.js +13 -0
  488. package/lib-esm/__tests__/Dialog2.types.test.d.ts +3 -0
  489. package/lib-esm/__tests__/Dialog2.types.test.js +16 -0
  490. package/lib-esm/__tests__/Dropdown.test.d.ts +1 -0
  491. package/lib-esm/__tests__/Dropdown.test.js +53 -0
  492. package/lib-esm/__tests__/Dropdown.types.test.d.ts +3 -0
  493. package/lib-esm/__tests__/Dropdown.types.test.js +17 -0
  494. package/lib-esm/__tests__/DropdownMenu.test.d.ts +1 -0
  495. package/lib-esm/__tests__/DropdownMenu.test.js +137 -0
  496. package/lib-esm/__tests__/FilterList.test.d.ts +1 -0
  497. package/lib-esm/__tests__/FilterList.test.js +26 -0
  498. package/lib-esm/__tests__/FilterList.types.test.d.ts +3 -0
  499. package/lib-esm/__tests__/FilterList.types.test.js +13 -0
  500. package/lib-esm/__tests__/FilterListItem.test.d.ts +1 -0
  501. package/lib-esm/__tests__/FilterListItem.test.js +36 -0
  502. package/lib-esm/__tests__/FilteredSearch.test.d.ts +1 -0
  503. package/lib-esm/__tests__/FilteredSearch.test.js +26 -0
  504. package/lib-esm/__tests__/FilteredSearch.types.test.d.ts +3 -0
  505. package/lib-esm/__tests__/FilteredSearch.types.test.js +13 -0
  506. package/lib-esm/__tests__/Flash.test.d.ts +1 -0
  507. package/lib-esm/__tests__/Flash.test.js +51 -0
  508. package/lib-esm/__tests__/Flash.types.test.d.ts +3 -0
  509. package/lib-esm/__tests__/Flash.types.test.js +13 -0
  510. package/lib-esm/__tests__/Flex.test.d.ts +1 -0
  511. package/lib-esm/__tests__/Flex.test.js +64 -0
  512. package/lib-esm/__tests__/FormGroup.test.d.ts +1 -0
  513. package/lib-esm/__tests__/FormGroup.test.js +44 -0
  514. package/lib-esm/__tests__/FormGroup.types.test.d.ts +3 -0
  515. package/lib-esm/__tests__/FormGroup.types.test.js +13 -0
  516. package/lib-esm/__tests__/Grid.test.d.ts +1 -0
  517. package/lib-esm/__tests__/Grid.test.js +94 -0
  518. package/lib-esm/__tests__/Header.test.d.ts +1 -0
  519. package/lib-esm/__tests__/Header.test.js +48 -0
  520. package/lib-esm/__tests__/Header.types.test.d.ts +3 -0
  521. package/lib-esm/__tests__/Header.types.test.js +15 -0
  522. package/lib-esm/__tests__/Heading.test.d.ts +1 -0
  523. package/lib-esm/__tests__/Heading.test.js +99 -0
  524. package/lib-esm/__tests__/KeyPaths.types.test.d.ts +11 -0
  525. package/lib-esm/__tests__/KeyPaths.types.test.js +3 -0
  526. package/lib-esm/__tests__/Label.test.d.ts +1 -0
  527. package/lib-esm/__tests__/Label.test.js +36 -0
  528. package/lib-esm/__tests__/Label.types.test.d.ts +3 -0
  529. package/lib-esm/__tests__/Label.types.test.js +13 -0
  530. package/lib-esm/__tests__/LabelGroup.test.d.ts +1 -0
  531. package/lib-esm/__tests__/LabelGroup.test.js +26 -0
  532. package/lib-esm/__tests__/LabelGroup.types.test.d.ts +3 -0
  533. package/lib-esm/__tests__/LabelGroup.types.test.js +13 -0
  534. package/lib-esm/__tests__/Link.test.d.ts +1 -0
  535. package/lib-esm/__tests__/Link.test.js +66 -0
  536. package/lib-esm/__tests__/Link.types.test.d.ts +3 -0
  537. package/lib-esm/__tests__/Link.types.test.js +13 -0
  538. package/lib-esm/__tests__/Merge.types.test.d.ts +30 -0
  539. package/lib-esm/__tests__/Merge.types.test.js +14 -0
  540. package/lib-esm/__tests__/NewButton.test.d.ts +1 -0
  541. package/lib-esm/__tests__/NewButton.test.js +84 -0
  542. package/lib-esm/__tests__/Overlay.test.d.ts +1 -0
  543. package/lib-esm/__tests__/Overlay.test.js +123 -0
  544. package/lib-esm/__tests__/Overlay.types.test.d.ts +6 -0
  545. package/lib-esm/__tests__/Overlay.types.test.js +49 -0
  546. package/lib-esm/__tests__/Pagehead.test.d.ts +1 -0
  547. package/lib-esm/__tests__/Pagehead.test.js +26 -0
  548. package/lib-esm/__tests__/Pagehead.types.test.d.ts +3 -0
  549. package/lib-esm/__tests__/Pagehead.types.test.js +13 -0
  550. package/lib-esm/__tests__/Pagination/Pagination.test.d.ts +1 -0
  551. package/lib-esm/__tests__/Pagination/Pagination.test.js +35 -0
  552. package/lib-esm/__tests__/Pagination/PaginationModel.test.d.ts +1 -0
  553. package/lib-esm/__tests__/Pagination/PaginationModel.test.js +182 -0
  554. package/lib-esm/__tests__/Pagination.types.test.d.ts +3 -0
  555. package/lib-esm/__tests__/Pagination.types.test.js +18 -0
  556. package/lib-esm/__tests__/PointerBox.test.d.ts +1 -0
  557. package/lib-esm/__tests__/PointerBox.test.js +36 -0
  558. package/lib-esm/__tests__/Popover.test.d.ts +1 -0
  559. package/lib-esm/__tests__/Popover.test.js +53 -0
  560. package/lib-esm/__tests__/Popover.types.test.d.ts +3 -0
  561. package/lib-esm/__tests__/Popover.types.test.js +13 -0
  562. package/lib-esm/__tests__/Portal.test.d.ts +1 -0
  563. package/lib-esm/__tests__/Portal.test.js +104 -0
  564. package/lib-esm/__tests__/Position.test.d.ts +1 -0
  565. package/lib-esm/__tests__/Position.test.js +133 -0
  566. package/lib-esm/__tests__/ProgressBar.test.d.ts +1 -0
  567. package/lib-esm/__tests__/ProgressBar.test.js +58 -0
  568. package/lib-esm/__tests__/SelectMenu.test.d.ts +1 -0
  569. package/lib-esm/__tests__/SelectMenu.test.js +145 -0
  570. package/lib-esm/__tests__/SelectMenu.types.test.d.ts +3 -0
  571. package/lib-esm/__tests__/SelectMenu.types.test.js +33 -0
  572. package/lib-esm/__tests__/SelectPanel.test.d.ts +1 -0
  573. package/lib-esm/__tests__/SelectPanel.test.js +65 -0
  574. package/lib-esm/__tests__/SelectPanel.types.test.d.ts +3 -0
  575. package/lib-esm/__tests__/SelectPanel.types.test.js +29 -0
  576. package/lib-esm/__tests__/SideNav.test.d.ts +1 -0
  577. package/lib-esm/__tests__/SideNav.test.js +60 -0
  578. package/lib-esm/__tests__/SideNav.types.test.d.ts +3 -0
  579. package/lib-esm/__tests__/SideNav.types.test.js +13 -0
  580. package/lib-esm/__tests__/Spinner.test.d.ts +1 -0
  581. package/lib-esm/__tests__/Spinner.test.js +43 -0
  582. package/lib-esm/__tests__/StateLabel.test.d.ts +1 -0
  583. package/lib-esm/__tests__/StateLabel.test.js +61 -0
  584. package/lib-esm/__tests__/StateLabel.types.test.d.ts +3 -0
  585. package/lib-esm/__tests__/StateLabel.types.test.js +13 -0
  586. package/lib-esm/__tests__/StyledOcticon.test.d.ts +1 -0
  587. package/lib-esm/__tests__/StyledOcticon.test.js +29 -0
  588. package/lib-esm/__tests__/StyledOcticon.types.test.d.ts +3 -0
  589. package/lib-esm/__tests__/StyledOcticon.types.test.js +16 -0
  590. package/lib-esm/__tests__/SubNav.test.d.ts +1 -0
  591. package/lib-esm/__tests__/SubNav.test.js +50 -0
  592. package/lib-esm/__tests__/SubNav.types.test.d.ts +3 -0
  593. package/lib-esm/__tests__/SubNav.types.test.js +14 -0
  594. package/lib-esm/__tests__/SubNavLink.test.d.ts +1 -0
  595. package/lib-esm/__tests__/SubNavLink.test.js +39 -0
  596. package/lib-esm/__tests__/TabNav.test.d.ts +1 -0
  597. package/lib-esm/__tests__/TabNav.test.js +39 -0
  598. package/lib-esm/__tests__/TabNav.types.test.d.ts +3 -0
  599. package/lib-esm/__tests__/TabNav.types.test.js +12 -0
  600. package/lib-esm/__tests__/Text.test.d.ts +1 -0
  601. package/lib-esm/__tests__/Text.test.js +93 -0
  602. package/lib-esm/__tests__/TextInput.test.d.ts +1 -0
  603. package/lib-esm/__tests__/TextInput.test.js +68 -0
  604. package/lib-esm/__tests__/TextInputWithTokens.test.d.ts +1 -0
  605. package/lib-esm/__tests__/TextInputWithTokens.test.js +511 -0
  606. package/lib-esm/__tests__/ThemeProvider.test.d.ts +1 -0
  607. package/lib-esm/__tests__/ThemeProvider.test.js +408 -0
  608. package/lib-esm/__tests__/Timeline.test.d.ts +1 -0
  609. package/lib-esm/__tests__/Timeline.test.js +65 -0
  610. package/lib-esm/__tests__/Timeline.types.test.d.ts +3 -0
  611. package/lib-esm/__tests__/Timeline.types.test.js +18 -0
  612. package/lib-esm/__tests__/Token.test.d.ts +1 -0
  613. package/lib-esm/__tests__/Token.test.js +166 -0
  614. package/lib-esm/__tests__/Tooltip.test.d.ts +1 -0
  615. package/lib-esm/__tests__/Tooltip.test.js +59 -0
  616. package/lib-esm/__tests__/Tooltip.types.test.d.ts +3 -0
  617. package/lib-esm/__tests__/Tooltip.types.test.js +13 -0
  618. package/lib-esm/__tests__/Truncate.test.d.ts +1 -0
  619. package/lib-esm/__tests__/Truncate.test.js +53 -0
  620. package/lib-esm/__tests__/Truncate.types.test.d.ts +3 -0
  621. package/lib-esm/__tests__/Truncate.types.test.js +16 -0
  622. package/lib-esm/__tests__/UnderlineNav.test.d.ts +1 -0
  623. package/lib-esm/__tests__/UnderlineNav.test.js +60 -0
  624. package/lib-esm/__tests__/UnderlineNav.types.test.d.ts +3 -0
  625. package/lib-esm/__tests__/UnderlineNav.types.test.js +12 -0
  626. package/lib-esm/__tests__/UnderlineNavLink.test.d.ts +1 -0
  627. package/lib-esm/__tests__/UnderlineNavLink.test.js +41 -0
  628. package/lib-esm/__tests__/behaviors/anchoredPosition.test.d.ts +1 -0
  629. package/lib-esm/__tests__/behaviors/anchoredPosition.test.js +388 -0
  630. package/lib-esm/__tests__/behaviors/focusTrap.test.d.ts +1 -0
  631. package/lib-esm/__tests__/behaviors/focusTrap.test.js +227 -0
  632. package/lib-esm/__tests__/behaviors/focusZone.test.d.ts +1 -0
  633. package/lib-esm/__tests__/behaviors/focusZone.test.js +487 -0
  634. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.d.ts +1 -0
  635. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.js +48 -0
  636. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +1 -0
  637. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.js +224 -0
  638. package/lib-esm/__tests__/filterObject.test.d.ts +1 -0
  639. package/lib-esm/__tests__/filterObject.test.js +27 -0
  640. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.d.ts +1 -0
  641. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.js +46 -0
  642. package/lib-esm/__tests__/hooks/useOnEscapePress.test.d.ts +1 -0
  643. package/lib-esm/__tests__/hooks/useOnEscapePress.test.js +23 -0
  644. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.d.ts +1 -0
  645. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.js +68 -0
  646. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +1 -0
  647. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.js +52 -0
  648. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +1 -0
  649. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.js +36 -0
  650. package/lib-esm/__tests__/theme.test.d.ts +1 -0
  651. package/lib-esm/__tests__/theme.test.js +33 -0
  652. package/lib-esm/__tests__/themeGet.test.d.ts +1 -0
  653. package/lib-esm/__tests__/themeGet.test.js +22 -0
  654. package/lib-esm/__tests__/useSafeTimeout.test.d.ts +1 -0
  655. package/lib-esm/__tests__/useSafeTimeout.test.js +39 -0
  656. package/lib-esm/__tests__/utils/createSlots.test.d.ts +1 -0
  657. package/lib-esm/__tests__/utils/createSlots.test.js +67 -0
  658. package/lib-esm/stories/ActionList.stories.js +395 -0
  659. package/lib-esm/stories/ActionList2.stories.js +797 -0
  660. package/lib-esm/stories/ActionMenu.stories.js +303 -0
  661. package/lib-esm/stories/AnchoredOverlay.stories.js +101 -0
  662. package/lib-esm/stories/Autocomplete.stories.js +560 -0
  663. package/lib-esm/stories/AvatarStack.stories.js +32 -0
  664. package/lib-esm/stories/Button.stories.js +86 -0
  665. package/lib-esm/stories/ConfirmationDialog.stories.js +94 -0
  666. package/lib-esm/stories/Dialog.stories.js +244 -0
  667. package/lib-esm/stories/DropdownMenu.stories.js +94 -0
  668. package/lib-esm/stories/IssueLabelToken.stories.js +139 -0
  669. package/lib-esm/stories/NewButton.stories.js +178 -0
  670. package/lib-esm/stories/Overlay.stories.js +173 -0
  671. package/lib-esm/stories/Portal.stories.js +68 -0
  672. package/lib-esm/stories/ProfileToken.stories.js +136 -0
  673. package/lib-esm/stories/SelectPanel.stories.js +334 -0
  674. package/lib-esm/stories/TextInput.stories.js +117 -0
  675. package/lib-esm/stories/TextInputWithTokens.stories.js +210 -0
  676. package/lib-esm/stories/ThemeProvider.stories.js +83 -0
  677. package/lib-esm/stories/Token.stories.js +146 -0
  678. package/lib-esm/stories/useAnchoredPosition.stories.js +313 -0
  679. package/lib-esm/stories/useFocusTrap.stories.js +313 -0
  680. package/lib-esm/stories/useFocusZone.stories.js +562 -0
  681. package/lib-esm/theme-preval.js +446 -0
  682. package/lib-esm/utils/testing.d.ts +1 -1
  683. package/migrating.md +250 -0
  684. package/now.json +17 -0
  685. package/package-lock.json +66509 -0
  686. package/package.json +4 -5
  687. package/rollup.config.js +36 -0
  688. package/script/build +21 -0
  689. package/script/build-storybook +10 -0
  690. package/script/setup +12 -0
  691. package/src/ActionList/Divider.tsx +25 -0
  692. package/src/ActionList/Group.tsx +45 -0
  693. package/src/ActionList/Header.tsx +74 -0
  694. package/src/ActionList/Item.tsx +480 -0
  695. package/src/ActionList/List.tsx +258 -0
  696. package/src/ActionList/index.ts +21 -0
  697. package/src/ActionList2/Description.tsx +52 -0
  698. package/src/ActionList2/Divider.tsx +24 -0
  699. package/src/ActionList2/Group.tsx +103 -0
  700. package/src/ActionList2/Header.tsx +58 -0
  701. package/src/ActionList2/Item.tsx +246 -0
  702. package/src/ActionList2/LinkItem.tsx +49 -0
  703. package/src/ActionList2/List.tsx +55 -0
  704. package/src/ActionList2/Selection.tsx +60 -0
  705. package/src/ActionList2/Visuals.tsx +76 -0
  706. package/src/ActionList2/index.ts +39 -0
  707. package/src/ActionMenu.tsx +106 -0
  708. package/src/AnchoredOverlay/AnchoredOverlay.tsx +191 -0
  709. package/src/AnchoredOverlay/index.ts +2 -0
  710. package/src/Autocomplete/Autocomplete.tsx +103 -0
  711. package/src/Autocomplete/AutocompleteContext.tsx +19 -0
  712. package/src/Autocomplete/AutocompleteInput.tsx +179 -0
  713. package/src/Autocomplete/AutocompleteMenu.tsx +341 -0
  714. package/src/Autocomplete/AutocompleteOverlay.tsx +68 -0
  715. package/src/Autocomplete/index.ts +2 -0
  716. package/src/Avatar.tsx +46 -0
  717. package/src/AvatarPair.tsx +35 -0
  718. package/{lib/AvatarStack.jsx → src/AvatarStack.tsx} +49 -41
  719. package/src/BaseStyles.tsx +53 -0
  720. package/src/BorderBox.tsx +18 -0
  721. package/src/Box.tsx +54 -0
  722. package/src/BranchName.tsx +19 -0
  723. package/src/Breadcrumbs.tsx +101 -0
  724. package/src/Button/Button.tsx +39 -0
  725. package/src/Button/ButtonBase.tsx +39 -0
  726. package/src/Button/ButtonClose.tsx +36 -0
  727. package/src/Button/ButtonDanger.tsx +42 -0
  728. package/src/Button/ButtonGroup.tsx +55 -0
  729. package/src/Button/ButtonInvisible.tsx +31 -0
  730. package/src/Button/ButtonOutline.tsx +42 -0
  731. package/src/Button/ButtonPrimary.tsx +40 -0
  732. package/{lib/Button/ButtonStyles.jsx → src/Button/ButtonStyles.tsx} +7 -8
  733. package/src/Button/ButtonTableList.tsx +45 -0
  734. package/src/Button/index.ts +16 -0
  735. package/src/Caret.tsx +133 -0
  736. package/src/CircleBadge.tsx +53 -0
  737. package/src/CircleOcticon.tsx +37 -0
  738. package/src/CounterLabel.tsx +50 -0
  739. package/src/Details.tsx +23 -0
  740. package/src/Dialog/ConfirmationDialog.tsx +184 -0
  741. package/src/Dialog/Dialog.tsx +444 -0
  742. package/src/Dialog.tsx +145 -0
  743. package/src/Dropdown.tsx +154 -0
  744. package/src/DropdownMenu/DropdownButton.tsx +15 -0
  745. package/src/DropdownMenu/DropdownMenu.tsx +115 -0
  746. package/src/DropdownMenu/index.ts +4 -0
  747. package/src/DropdownStyles.ts +128 -0
  748. package/src/FilterList.tsx +75 -0
  749. package/src/FilteredActionList/FilteredActionList.tsx +142 -0
  750. package/src/FilteredActionList/index.ts +2 -0
  751. package/src/FilteredSearch.tsx +27 -0
  752. package/src/Flash.tsx +75 -0
  753. package/src/Flex.tsx +15 -0
  754. package/src/FormGroup.tsx +24 -0
  755. package/src/Grid.tsx +15 -0
  756. package/src/Header.tsx +74 -0
  757. package/src/Heading.tsx +21 -0
  758. package/src/Label.tsx +72 -0
  759. package/src/LabelGroup.tsx +17 -0
  760. package/src/Link.tsx +42 -0
  761. package/src/NewButton/button-counter.tsx +15 -0
  762. package/src/NewButton/button.tsx +283 -0
  763. package/src/NewButton/index.ts +10 -0
  764. package/src/NewButton/types.ts +36 -0
  765. package/src/Overlay.tsx +203 -0
  766. package/src/Pagehead.tsx +16 -0
  767. package/src/Pagination/Pagination.tsx +212 -0
  768. package/src/Pagination/index.ts +4 -0
  769. package/src/Pagination/model.tsx +187 -0
  770. package/src/PointerBox.tsx +31 -0
  771. package/{lib/Popover.jsx → src/Popover.tsx} +71 -48
  772. package/src/Portal/Portal.tsx +97 -0
  773. package/src/Portal/index.ts +5 -0
  774. package/src/Position.tsx +63 -0
  775. package/src/ProgressBar.tsx +52 -0
  776. package/src/SelectMenu/SelectMenu.tsx +123 -0
  777. package/src/SelectMenu/SelectMenuContext.tsx +9 -0
  778. package/src/SelectMenu/SelectMenuDivider.tsx +24 -0
  779. package/src/SelectMenu/SelectMenuFilter.tsx +50 -0
  780. package/src/SelectMenu/SelectMenuFooter.tsx +27 -0
  781. package/src/SelectMenu/SelectMenuHeader.tsx +48 -0
  782. package/src/SelectMenu/SelectMenuItem.tsx +136 -0
  783. package/src/SelectMenu/SelectMenuList.tsx +41 -0
  784. package/src/SelectMenu/SelectMenuLoadingAnimation.tsx +25 -0
  785. package/src/SelectMenu/SelectMenuModal.tsx +119 -0
  786. package/src/SelectMenu/SelectMenuTab.tsx +87 -0
  787. package/src/SelectMenu/SelectMenuTabPanel.tsx +29 -0
  788. package/src/SelectMenu/SelectMenuTabs.tsx +43 -0
  789. package/src/SelectMenu/hooks/useKeyboardNav.js +90 -0
  790. package/src/SelectMenu/index.ts +15 -0
  791. package/src/SelectPanel/SelectPanel.tsx +173 -0
  792. package/src/SelectPanel/index.ts +2 -0
  793. package/src/SideNav.tsx +191 -0
  794. package/src/Spinner.tsx +59 -0
  795. package/src/StateLabel.tsx +112 -0
  796. package/src/StyledOcticon.tsx +22 -0
  797. package/src/SubNav.tsx +124 -0
  798. package/src/TabNav.tsx +73 -0
  799. package/src/Text.tsx +13 -0
  800. package/src/TextInput.tsx +68 -0
  801. package/src/TextInputWithTokens.tsx +351 -0
  802. package/src/ThemeProvider.tsx +176 -0
  803. package/src/Timeline.tsx +140 -0
  804. package/src/Token/AvatarToken.tsx +54 -0
  805. package/src/Token/IssueLabelToken.tsx +150 -0
  806. package/src/Token/Token.tsx +126 -0
  807. package/src/Token/TokenBase.tsx +129 -0
  808. package/src/Token/_RemoveTokenButton.tsx +111 -0
  809. package/{lib/Token/_TokenTextContainer.jsx → src/Token/_TokenTextContainer.tsx} +7 -9
  810. package/src/Token/index.ts +3 -0
  811. package/{lib/Tooltip.jsx → src/Tooltip.tsx} +50 -33
  812. package/src/Truncate.tsx +31 -0
  813. package/src/UnderlineNav.tsx +107 -0
  814. package/src/_TextInputWrapper.tsx +113 -0
  815. package/src/_UnstyledTextInput.tsx +19 -0
  816. package/src/__tests__/.eslintrc.json +11 -0
  817. package/src/__tests__/ActionList.test.tsx +53 -0
  818. package/src/__tests__/ActionList.types.test.tsx +51 -0
  819. package/src/__tests__/ActionList2.test.tsx +47 -0
  820. package/src/__tests__/ActionMenu.test.tsx +136 -0
  821. package/src/__tests__/AnchoredOverlay.test.tsx +150 -0
  822. package/src/__tests__/Autocomplete.test.tsx +444 -0
  823. package/src/__tests__/Avatar.test.tsx +44 -0
  824. package/src/__tests__/AvatarStack.test.tsx +48 -0
  825. package/src/__tests__/BorderBox.test.tsx +43 -0
  826. package/src/__tests__/Box.test.tsx +42 -0
  827. package/src/__tests__/BranchName.test.tsx +26 -0
  828. package/src/__tests__/Breadcrumbs.test.tsx +27 -0
  829. package/src/__tests__/Breadcrumbs.types.test.tsx +22 -0
  830. package/src/__tests__/BreadcrumbsItem.test.tsx +31 -0
  831. package/src/__tests__/Button.test.tsx +128 -0
  832. package/src/__tests__/Caret.test.tsx +36 -0
  833. package/src/__tests__/CircleBadge.test.tsx +66 -0
  834. package/src/__tests__/CircleBadge.types.test.tsx +11 -0
  835. package/src/__tests__/CircleOcticon.test.tsx +50 -0
  836. package/src/__tests__/ConfirmationDialog.test.tsx +120 -0
  837. package/src/__tests__/CounterLabel.test.tsx +50 -0
  838. package/src/__tests__/CounterLabel.types.test.tsx +11 -0
  839. package/src/__tests__/Details.test.tsx +115 -0
  840. package/src/__tests__/Dialog.test.tsx +155 -0
  841. package/src/__tests__/Dialog.types.test.tsx +11 -0
  842. package/src/__tests__/Dialog2.types.test.tsx +11 -0
  843. package/src/__tests__/Dropdown.test.tsx +53 -0
  844. package/src/__tests__/Dropdown.types.test.tsx +21 -0
  845. package/src/__tests__/DropdownMenu.test.tsx +136 -0
  846. package/src/__tests__/FilterList.test.tsx +26 -0
  847. package/src/__tests__/FilterList.types.test.tsx +17 -0
  848. package/src/__tests__/FilterListItem.test.tsx +31 -0
  849. package/src/__tests__/FilteredSearch.test.tsx +26 -0
  850. package/src/__tests__/FilteredSearch.types.test.tsx +11 -0
  851. package/src/__tests__/Flash.test.tsx +45 -0
  852. package/src/__tests__/Flash.types.test.tsx +11 -0
  853. package/src/__tests__/Flex.test.tsx +58 -0
  854. package/src/__tests__/FormGroup.test.tsx +38 -0
  855. package/src/__tests__/FormGroup.types.test.tsx +11 -0
  856. package/src/__tests__/Grid.test.tsx +82 -0
  857. package/src/__tests__/Header.test.tsx +49 -0
  858. package/src/__tests__/Header.types.test.tsx +19 -0
  859. package/src/__tests__/Heading.test.tsx +91 -0
  860. package/src/__tests__/KeyPaths.types.test.ts +14 -0
  861. package/src/__tests__/Label.test.tsx +34 -0
  862. package/src/__tests__/Label.types.test.tsx +11 -0
  863. package/src/__tests__/LabelGroup.test.tsx +30 -0
  864. package/src/__tests__/LabelGroup.types.test.tsx +11 -0
  865. package/src/__tests__/Link.test.tsx +47 -0
  866. package/src/__tests__/Link.types.test.tsx +11 -0
  867. package/src/__tests__/Merge.types.test.ts +39 -0
  868. package/src/__tests__/NewButton.test.tsx +70 -0
  869. package/src/__tests__/Overlay.test.tsx +103 -0
  870. package/src/__tests__/Overlay.types.test.tsx +33 -0
  871. package/src/__tests__/Pagehead.test.tsx +23 -0
  872. package/src/__tests__/Pagehead.types.test.tsx +11 -0
  873. package/src/__tests__/Pagination/Pagination.test.tsx +30 -0
  874. package/src/__tests__/Pagination/PaginationModel.test.tsx +133 -0
  875. package/src/__tests__/Pagination/__snapshots__/Pagination.test.tsx.snap +184 -0
  876. package/src/__tests__/Pagination.types.test.tsx +11 -0
  877. package/src/__tests__/PointerBox.test.tsx +34 -0
  878. package/src/__tests__/Popover.test.tsx +68 -0
  879. package/src/__tests__/Popover.types.test.tsx +17 -0
  880. package/src/__tests__/Portal.test.tsx +103 -0
  881. package/src/__tests__/Position.test.tsx +117 -0
  882. package/src/__tests__/ProgressBar.test.tsx +40 -0
  883. package/src/__tests__/SelectMenu.test.tsx +142 -0
  884. package/src/__tests__/SelectMenu.types.test.tsx +37 -0
  885. package/src/__tests__/SelectPanel.test.tsx +63 -0
  886. package/src/__tests__/SelectPanel.types.test.tsx +31 -0
  887. package/src/__tests__/SideNav.test.tsx +62 -0
  888. package/src/__tests__/SideNav.types.test.tsx +11 -0
  889. package/src/__tests__/Spinner.test.tsx +42 -0
  890. package/src/__tests__/StateLabel.test.tsx +48 -0
  891. package/src/__tests__/StateLabel.types.test.tsx +11 -0
  892. package/src/__tests__/StyledOcticon.test.tsx +26 -0
  893. package/src/__tests__/StyledOcticon.types.test.tsx +12 -0
  894. package/src/__tests__/SubNav.test.tsx +50 -0
  895. package/src/__tests__/SubNav.types.test.tsx +25 -0
  896. package/src/__tests__/SubNavLink.test.tsx +31 -0
  897. package/src/__tests__/TabNav.test.tsx +32 -0
  898. package/src/__tests__/TabNav.types.test.tsx +22 -0
  899. package/src/__tests__/Text.test.tsx +78 -0
  900. package/src/__tests__/TextInput.test.tsx +49 -0
  901. package/src/__tests__/TextInputWithTokens.test.tsx +422 -0
  902. package/src/__tests__/ThemeProvider.test.tsx +441 -0
  903. package/src/__tests__/Timeline.test.tsx +58 -0
  904. package/src/__tests__/Timeline.types.test.tsx +31 -0
  905. package/src/__tests__/Token.test.tsx +118 -0
  906. package/src/__tests__/Tooltip.test.tsx +52 -0
  907. package/src/__tests__/Tooltip.types.test.tsx +11 -0
  908. package/src/__tests__/Truncate.test.tsx +43 -0
  909. package/src/__tests__/Truncate.types.test.tsx +11 -0
  910. package/src/__tests__/UnderlineNav.test.tsx +58 -0
  911. package/src/__tests__/UnderlineNav.types.test.tsx +22 -0
  912. package/src/__tests__/UnderlineNavLink.test.tsx +31 -0
  913. package/src/__tests__/__snapshots__/ActionList.test.tsx.snap +223 -0
  914. package/src/__tests__/__snapshots__/ActionList2.test.tsx.snap +14 -0
  915. package/src/__tests__/__snapshots__/ActionMenu.test.tsx.snap +80 -0
  916. package/src/__tests__/__snapshots__/AnchoredOverlay.test.tsx.snap +232 -0
  917. package/src/__tests__/__snapshots__/Autocomplete.test.tsx.snap +3888 -0
  918. package/src/__tests__/__snapshots__/Avatar.test.tsx.snap +19 -0
  919. package/src/__tests__/__snapshots__/AvatarStack.test.tsx.snap +377 -0
  920. package/src/__tests__/__snapshots__/BorderBox.test.tsx.snap +14 -0
  921. package/src/__tests__/__snapshots__/Box.test.tsx.snap +201 -0
  922. package/src/__tests__/__snapshots__/BranchName.test.tsx.snap +17 -0
  923. package/src/__tests__/__snapshots__/Breadcrumbs.test.tsx.snap +29 -0
  924. package/src/__tests__/__snapshots__/BreadcrumbsItem.test.tsx.snap +79 -0
  925. package/src/__tests__/__snapshots__/Button.test.tsx.snap +840 -0
  926. package/src/__tests__/__snapshots__/Caret.test.tsx.snap +373 -0
  927. package/src/__tests__/__snapshots__/CircleBadge.test.tsx.snap +142 -0
  928. package/src/__tests__/__snapshots__/CircleOcticon.test.tsx.snap +65 -0
  929. package/src/__tests__/__snapshots__/ConfirmationDialog.test.tsx.snap +89 -0
  930. package/src/__tests__/__snapshots__/CounterLabel.test.tsx.snap +22 -0
  931. package/src/__tests__/__snapshots__/Details.test.tsx.snap +15 -0
  932. package/src/__tests__/__snapshots__/Dialog.test.tsx.snap +201 -0
  933. package/src/__tests__/__snapshots__/Dropdown.test.tsx.snap +249 -0
  934. package/src/__tests__/__snapshots__/DropdownMenu.test.tsx.snap +107 -0
  935. package/src/__tests__/__snapshots__/FilterList.test.tsx.snap +13 -0
  936. package/src/__tests__/__snapshots__/FilterListItem.test.tsx.snap +80 -0
  937. package/src/__tests__/__snapshots__/FilteredSearch.test.tsx.snap +32 -0
  938. package/src/__tests__/__snapshots__/Flash.test.tsx.snap +32 -0
  939. package/src/__tests__/__snapshots__/Flex.test.tsx.snap +130 -0
  940. package/src/__tests__/__snapshots__/FormGroup.test.tsx.snap +25 -0
  941. package/src/__tests__/__snapshots__/Grid.test.tsx.snap +178 -0
  942. package/src/__tests__/__snapshots__/Header.test.tsx.snap +79 -0
  943. package/src/__tests__/__snapshots__/Heading.test.tsx.snap +13 -0
  944. package/src/__tests__/__snapshots__/Label.test.tsx.snap +73 -0
  945. package/src/__tests__/__snapshots__/LabelGroup.test.tsx.snap +15 -0
  946. package/src/__tests__/__snapshots__/Link.test.tsx.snap +212 -0
  947. package/src/__tests__/__snapshots__/NewButton.test.tsx.snap +305 -0
  948. package/src/__tests__/__snapshots__/Pagehead.test.tsx.snap +15 -0
  949. package/src/__tests__/__snapshots__/PointerBox.test.tsx.snap +174 -0
  950. package/src/__tests__/__snapshots__/Popover.test.tsx.snap +4687 -0
  951. package/src/__tests__/__snapshots__/Position.test.tsx.snap +44 -0
  952. package/src/__tests__/__snapshots__/ProgressBar.test.tsx.snap +53 -0
  953. package/src/__tests__/__snapshots__/SelectMenu.test.tsx.snap +473 -0
  954. package/src/__tests__/__snapshots__/SelectPanel.test.tsx.snap +124 -0
  955. package/src/__tests__/__snapshots__/SideNav.test.tsx.snap +143 -0
  956. package/src/__tests__/__snapshots__/Spinner.test.tsx.snap +33 -0
  957. package/src/__tests__/__snapshots__/StateLabel.test.tsx.snap +395 -0
  958. package/src/__tests__/__snapshots__/StyledOcticon.test.tsx.snap +26 -0
  959. package/src/__tests__/__snapshots__/SubNav.test.tsx.snap +44 -0
  960. package/src/__tests__/__snapshots__/SubNavLink.test.tsx.snap +199 -0
  961. package/src/__tests__/__snapshots__/TabNav.test.tsx.snap +58 -0
  962. package/src/__tests__/__snapshots__/Text.test.tsx.snap +7 -0
  963. package/src/__tests__/__snapshots__/TextInput.test.tsx.snap +446 -0
  964. package/src/__tests__/__snapshots__/TextInputWithTokens.test.tsx.snap +6045 -0
  965. package/src/__tests__/__snapshots__/ThemeProvider.test.tsx.snap +15 -0
  966. package/src/__tests__/__snapshots__/Timeline.test.tsx.snap +159 -0
  967. package/src/__tests__/__snapshots__/Token.test.tsx.snap +3811 -0
  968. package/src/__tests__/__snapshots__/Tooltip.test.tsx.snap +227 -0
  969. package/src/__tests__/__snapshots__/Truncate.test.tsx.snap +17 -0
  970. package/src/__tests__/__snapshots__/UnderlineNav.test.tsx.snap +59 -0
  971. package/src/__tests__/__snapshots__/UnderlineNavLink.test.tsx.snap +130 -0
  972. package/src/__tests__/behaviors/anchoredPosition.test.ts +295 -0
  973. package/src/__tests__/behaviors/focusTrap.test.tsx +236 -0
  974. package/src/__tests__/behaviors/focusZone.test.tsx +549 -0
  975. package/src/__tests__/behaviors/iterateFocusableElements.test.tsx +61 -0
  976. package/src/__tests__/behaviors/scrollIntoViewingArea.test.ts +195 -0
  977. package/src/__tests__/filterObject.test.ts +54 -0
  978. package/src/__tests__/hooks/useAnchoredPosition.test.tsx +31 -0
  979. package/src/__tests__/hooks/useOnEscapePress.test.tsx +16 -0
  980. package/src/__tests__/hooks/useOnOutsideClick.test.tsx +48 -0
  981. package/src/__tests__/hooks/useOpenAndCloseFocus.test.tsx +48 -0
  982. package/src/__tests__/hooks/useProvidedStateOrCreate.test.tsx +39 -0
  983. package/src/__tests__/theme.test.ts +41 -0
  984. package/src/__tests__/themeGet.test.ts +15 -0
  985. package/src/__tests__/useSafeTimeout.test.tsx +36 -0
  986. package/src/__tests__/utils/__snapshots__/createSlots.test.tsx.snap +55 -0
  987. package/src/__tests__/utils/createSlots.test.tsx +74 -0
  988. package/src/behaviors/anchoredPosition.ts +442 -0
  989. package/src/behaviors/focusTrap.ts +184 -0
  990. package/src/behaviors/focusZone.ts +713 -0
  991. package/src/behaviors/scrollIntoViewingArea.ts +27 -0
  992. package/src/constants.ts +62 -0
  993. package/src/drafts.ts +10 -0
  994. package/src/hooks/index.ts +11 -0
  995. package/src/hooks/useAnchoredPosition.ts +54 -0
  996. package/src/hooks/useCombinedRefs.ts +40 -0
  997. package/src/hooks/useDetails.tsx +54 -0
  998. package/src/hooks/useDialog.ts +121 -0
  999. package/src/hooks/useFocusTrap.ts +80 -0
  1000. package/src/hooks/useFocusZone.ts +64 -0
  1001. package/src/hooks/useOnEscapePress.ts +63 -0
  1002. package/src/hooks/useOnOutsideClick.tsx +82 -0
  1003. package/src/hooks/useOpenAndCloseFocus.ts +32 -0
  1004. package/src/hooks/useOverlay.tsx +34 -0
  1005. package/src/hooks/useProvidedRefOrCreate.ts +14 -0
  1006. package/src/hooks/useProvidedStateOrCreate.ts +27 -0
  1007. package/src/hooks/useRenderForcingRef.ts +22 -0
  1008. package/src/hooks/useResizeObserver.ts +11 -0
  1009. package/src/hooks/useSafeTimeout.ts +38 -0
  1010. package/src/hooks/useScrollFlash.ts +21 -0
  1011. package/src/index.ts +172 -0
  1012. package/src/polyfills/eventListenerSignal.ts +66 -0
  1013. package/src/stories/ActionList.stories.tsx +436 -0
  1014. package/src/stories/ActionList2.stories.tsx +1291 -0
  1015. package/src/stories/ActionMenu.stories.tsx +331 -0
  1016. package/src/stories/AnchoredOverlay.stories.tsx +117 -0
  1017. package/src/stories/Autocomplete.stories.tsx +655 -0
  1018. package/src/stories/AvatarStack.stories.tsx +37 -0
  1019. package/src/stories/Button.stories.tsx +92 -0
  1020. package/src/stories/ConfirmationDialog.stories.tsx +105 -0
  1021. package/src/stories/Dialog.stories.tsx +240 -0
  1022. package/src/stories/DropdownMenu.stories.tsx +84 -0
  1023. package/src/stories/IssueLabelToken.stories.tsx +138 -0
  1024. package/src/stories/NewButton.stories.tsx +201 -0
  1025. package/src/stories/Overlay.stories.tsx +213 -0
  1026. package/src/stories/Portal.stories.tsx +109 -0
  1027. package/src/stories/ProfileToken.stories.tsx +129 -0
  1028. package/src/stories/SelectPanel.stories.tsx +353 -0
  1029. package/src/stories/TextInput.stories.tsx +113 -0
  1030. package/src/stories/TextInputWithTokens.stories.tsx +155 -0
  1031. package/src/stories/ThemeProvider.stories.tsx +104 -0
  1032. package/src/stories/Token.stories.tsx +137 -0
  1033. package/src/stories/useAnchoredPosition.stories.tsx +332 -0
  1034. package/src/stories/useFocusTrap.stories.tsx +400 -0
  1035. package/src/stories/useFocusZone.stories.tsx +663 -0
  1036. package/src/sx.ts +24 -0
  1037. package/src/theme-preval.js +80 -0
  1038. package/src/theme.ts +89 -0
  1039. package/src/utils/create-slots.tsx +96 -0
  1040. package/src/utils/deprecate.tsx +73 -0
  1041. package/src/utils/isNumeric.tsx +4 -0
  1042. package/src/utils/iterateFocusableElements.ts +121 -0
  1043. package/src/utils/ssr.tsx +1 -0
  1044. package/src/utils/test-deprecations.tsx +19 -0
  1045. package/{lib/utils/test-helpers.jsx → src/utils/test-helpers.tsx} +5 -6
  1046. package/src/utils/test-matchers.tsx +109 -0
  1047. package/src/utils/testing.tsx +242 -0
  1048. package/src/utils/theme.js +64 -0
  1049. package/src/utils/types/AriaRole.ts +71 -0
  1050. package/src/utils/types/ComponentProps.ts +13 -0
  1051. package/src/utils/types/Flatten.ts +4 -0
  1052. package/src/utils/types/KeyPaths.ts +10 -0
  1053. package/src/utils/types/MandateProps.ts +19 -0
  1054. package/src/utils/types/Merge.ts +20 -0
  1055. package/src/utils/types/index.ts +5 -0
  1056. package/src/utils/uniqueId.ts +6 -0
  1057. package/src/utils/use-force-update.ts +7 -0
  1058. package/src/utils/useIsomorphicLayoutEffect.ts +10 -0
  1059. package/src/utils/userAgent.ts +7 -0
  1060. package/stats.html +3279 -0
  1061. package/tsconfig.build.json +7 -0
  1062. package/tsconfig.json +20 -0
  1063. package/lib/ActionList/Divider.jsx +0 -29
  1064. package/lib/ActionList/Group.jsx +0 -23
  1065. package/lib/ActionList/Header.jsx +0 -66
  1066. package/lib/ActionList/Item.jsx +0 -288
  1067. package/lib/ActionList/List.jsx +0 -138
  1068. package/lib/ActionList2/Description.jsx +0 -29
  1069. package/lib/ActionList2/Divider.jsx +0 -22
  1070. package/lib/ActionList2/Group.jsx +0 -54
  1071. package/lib/ActionList2/Header.jsx +0 -36
  1072. package/lib/ActionList2/Item.jsx +0 -174
  1073. package/lib/ActionList2/LinkItem.jsx +0 -28
  1074. package/lib/ActionList2/List.jsx +0 -41
  1075. package/lib/ActionList2/Selection.jsx +0 -50
  1076. package/lib/ActionList2/Visuals.jsx +0 -48
  1077. package/lib/ActionMenu.jsx +0 -73
  1078. package/lib/AnchoredOverlay/AnchoredOverlay.jsx +0 -100
  1079. package/lib/Autocomplete/Autocomplete.jsx +0 -100
  1080. package/lib/Autocomplete/AutocompleteContext.jsx +0 -5
  1081. package/lib/Autocomplete/AutocompleteInput.jsx +0 -113
  1082. package/lib/Autocomplete/AutocompleteMenu.jsx +0 -190
  1083. package/lib/Autocomplete/AutocompleteOverlay.jsx +0 -55
  1084. package/lib/Avatar.jsx +0 -34
  1085. package/lib/AvatarPair.jsx +0 -29
  1086. package/lib/BaseStyles.jsx +0 -65
  1087. package/lib/BorderBox.jsx +0 -18
  1088. package/lib/Box.jsx +0 -10
  1089. package/lib/BranchName.jsx +0 -20
  1090. package/lib/Breadcrumbs.jsx +0 -71
  1091. package/lib/Button/Button.jsx +0 -40
  1092. package/lib/Button/ButtonBase.jsx +0 -33
  1093. package/lib/Button/ButtonClose.jsx +0 -53
  1094. package/lib/Button/ButtonDanger.jsx +0 -43
  1095. package/lib/Button/ButtonGroup.jsx +0 -55
  1096. package/lib/Button/ButtonInvisible.jsx +0 -32
  1097. package/lib/Button/ButtonOutline.jsx +0 -43
  1098. package/lib/Button/ButtonPrimary.jsx +0 -42
  1099. package/lib/Button/ButtonTableList.jsx +0 -46
  1100. package/lib/Caret.jsx +0 -93
  1101. package/lib/CircleBadge.jsx +0 -42
  1102. package/lib/CircleOcticon.jsx +0 -21
  1103. package/lib/CounterLabel.jsx +0 -43
  1104. package/lib/Details.jsx +0 -21
  1105. package/lib/Dialog/ConfirmationDialog.jsx +0 -146
  1106. package/lib/Dialog/Dialog.jsx +0 -279
  1107. package/lib/Dialog.jsx +0 -129
  1108. package/lib/Dropdown.jsx +0 -131
  1109. package/lib/DropdownMenu/DropdownButton.jsx +0 -14
  1110. package/lib/DropdownMenu/DropdownMenu.jsx +0 -70
  1111. package/lib/FilterList.jsx +0 -59
  1112. package/lib/FilteredActionList/FilteredActionList.jsx +0 -100
  1113. package/lib/FilteredSearch.jsx +0 -28
  1114. package/lib/Flash.jsx +0 -69
  1115. package/lib/Flex.jsx +0 -15
  1116. package/lib/FormGroup.jsx +0 -22
  1117. package/lib/Grid.jsx +0 -15
  1118. package/lib/Header.jsx +0 -83
  1119. package/lib/Heading.jsx +0 -21
  1120. package/lib/Label.jsx +0 -82
  1121. package/lib/LabelGroup.jsx +0 -18
  1122. package/lib/Link.jsx +0 -36
  1123. package/lib/NewButton/button-counter.jsx +0 -14
  1124. package/lib/NewButton/button.jsx +0 -279
  1125. package/lib/Overlay.jsx +0 -154
  1126. package/lib/Pagehead.jsx +0 -17
  1127. package/lib/Pagination/Pagination.jsx +0 -161
  1128. package/lib/Pagination/model.jsx +0 -174
  1129. package/lib/PointerBox.jsx +0 -25
  1130. package/lib/Portal/Portal.jsx +0 -79
  1131. package/lib/Position.jsx +0 -46
  1132. package/lib/ProgressBar.jsx +0 -39
  1133. package/lib/SelectMenu/SelectMenu.jsx +0 -112
  1134. package/lib/SelectMenu/SelectMenuContext.jsx +0 -5
  1135. package/lib/SelectMenu/SelectMenuDivider.jsx +0 -42
  1136. package/lib/SelectMenu/SelectMenuFilter.jsx +0 -58
  1137. package/lib/SelectMenu/SelectMenuFooter.jsx +0 -45
  1138. package/lib/SelectMenu/SelectMenuHeader.jsx +0 -42
  1139. package/lib/SelectMenu/SelectMenuItem.jsx +0 -142
  1140. package/lib/SelectMenu/SelectMenuList.jsx +0 -59
  1141. package/lib/SelectMenu/SelectMenuLoadingAnimation.jsx +0 -22
  1142. package/lib/SelectMenu/SelectMenuModal.jsx +0 -118
  1143. package/lib/SelectMenu/SelectMenuTab.jsx +0 -92
  1144. package/lib/SelectMenu/SelectMenuTabPanel.jsx +0 -42
  1145. package/lib/SelectMenu/SelectMenuTabs.jsx +0 -57
  1146. package/lib/SelectPanel/SelectPanel.jsx +0 -105
  1147. package/lib/SideNav.jsx +0 -173
  1148. package/lib/Spinner.jsx +0 -35
  1149. package/lib/StateLabel.jsx +0 -93
  1150. package/lib/StyledOcticon.jsx +0 -18
  1151. package/lib/SubNav.jsx +0 -101
  1152. package/lib/TabNav.jsx +0 -58
  1153. package/lib/Text.jsx +0 -14
  1154. package/lib/TextInput.jsx +0 -23
  1155. package/lib/TextInputWithTokens.jsx +0 -218
  1156. package/lib/ThemeProvider.jsx +0 -130
  1157. package/lib/Timeline.jsx +0 -123
  1158. package/lib/Token/AvatarToken.jsx +0 -54
  1159. package/lib/Token/IssueLabelToken.jsx +0 -125
  1160. package/lib/Token/Token.jsx +0 -103
  1161. package/lib/Token/TokenBase.jsx +0 -88
  1162. package/lib/Token/_RemoveTokenButton.jsx +0 -108
  1163. package/lib/Truncate.jsx +0 -24
  1164. package/lib/UnderlineNav.jsx +0 -88
  1165. package/lib/_TextInputWrapper.jsx +0 -120
  1166. package/lib/_UnstyledTextInput.jsx +0 -22
  1167. package/lib/hooks/useDetails.jsx +0 -39
  1168. package/lib/hooks/useOnOutsideClick.jsx +0 -61
  1169. package/lib/hooks/useOverlay.jsx +0 -15
  1170. package/lib/utils/create-slots.jsx +0 -65
  1171. package/lib/utils/deprecate.jsx +0 -59
  1172. package/lib/utils/isNumeric.jsx +0 -7
  1173. package/lib/utils/ssr.jsx +0 -6
  1174. package/lib/utils/test-deprecations.jsx +0 -20
  1175. package/lib/utils/test-matchers.jsx +0 -100
  1176. package/lib/utils/testing.jsx +0 -206
@@ -0,0 +1,78 @@
1
+ ---
2
+ title: Portal
3
+ ---
4
+
5
+ Portals allow you to create a separation between the logical React component hierarchy and the physical DOM. See the [React documentation on portals](https://reactjs.org/docs/portals.html) for an in-depth explanation.
6
+
7
+ This Portal component will render all children into the portal root DOM node instead of as children of this Portal's parent DOM element. This is useful for breaking out of the current stacking context. For example, popup menus and tooltips may need to render on top of (read: covering up) other UI. The best way to guarantee this is to add these elements to top-level DOM, such as directly on `document.body`. These elements can then be moved to the correct location using absolute positioning.
8
+
9
+ ## Customizing the portal root
10
+
11
+ By default, Primer will create a portal root for you as a child of the closest `<BaseStyles>` element, or `document.body` if none is found. That root will be positioned absolutely in the top-left corner of its parent element. If you would like to specify your own portal root, there are two options:
12
+
13
+ 1. Before rendering a `<Portal>` for the first time, ensure that an element exists with id `__primerPortalRoot__`. If that exists, it will be used as the default portal root.
14
+ 2. Call the `registerPortalRoot` function, passing in the element you would like to use as your default portal root.
15
+
16
+ Keep in mind that any inherited styles applied to portaled elements are based on its physical DOM parent. Practically this means that styles added by a `<BaseStyles>` element will not apply to the portaled content unless the portal root is a descendent of a `<BaseStyles>` element.
17
+
18
+ Also, as `<ThemeProvider>` affects the _React_ context, which applies to the logical React component hierarchy, the portal root is not required to be a child of a `<ThemeProvider>` for its children to receive that context.
19
+
20
+ ## Multiple portal roots
21
+
22
+ There may be situations where you want to have multiple portal roots. Advanced scenarios may necessitate multiple stacking contexts for overlays. You can set up multiple roots using the `registerPortalRoot` function. Calling this function with an element and a string `name` will register the root, which can then be used by creating a `<Portal>` with a `name` prop matching the one you registered.
23
+
24
+ ## Default example
25
+
26
+ ```jsx
27
+ <Portal>
28
+ Regardless of where this appears in the React component tree, this text will be rendered in the DOM within the portal
29
+ root at document.body.
30
+ </Portal>
31
+ ```
32
+
33
+ ## Example: custom portal root
34
+
35
+ ```html
36
+ <!-- Wherever in your DOM tree you would like to have the default portal root -->
37
+ <div id="__primerPortalRoot__"></div>
38
+ ```
39
+
40
+ or
41
+
42
+ ```js
43
+ import { registerPortalRoot } from "@primer/components"
44
+ registerPortalRoot(document.querySelector(".my-portal-root")!)
45
+ ```
46
+
47
+ ## Example: multiple portal roots
48
+
49
+ ```jsx
50
+ import { Portal, registerPortalRoot } from "@primer/components"
51
+
52
+ registerPortalRoot(document.querySelector(".scrolling-canvas-root")!, "scrolling-canvas")
53
+
54
+ // ...
55
+
56
+ export default () => (
57
+ <Portal containerName="scrolling-canvas">
58
+ <div>This div will be rendered into the element registered above.</div>
59
+ <Portal>
60
+ <div>
61
+ This div will be rendered into the default
62
+ portal root created at document.body
63
+ </div>
64
+ </Portal>
65
+ </Portal>
66
+ )
67
+ ```
68
+
69
+ ## System props
70
+
71
+ Since Portals do not render UI on their own, they do not accept any system props.
72
+
73
+ ## Component props
74
+
75
+ | Name | Type | Default | Description |
76
+ | :------------ | :--------- | :-----: | :--------------------------------------------------------------------------------------------------------------------------------------------- |
77
+ | onMount | () => void | | Called when this portal is added to the DOM |
78
+ | containerName | string | | Renders the portal children into the container registered with the given name. If omitted, children are rendered into the default portal root. |
@@ -0,0 +1,100 @@
1
+ ---
2
+ title: Position Components
3
+ status: Deprecated
4
+ ---
5
+
6
+ The Position component is a wrapper component that gives the containing component css positioning abilities.
7
+
8
+ ## Deprecation
9
+
10
+ Use [Box](/Box) instead.
11
+
12
+ **Before**
13
+
14
+ ```jsx
15
+ <>
16
+ <Position position="absolute">...</Position>
17
+ <Absolute>...</Absolute>
18
+ <Relative>...</Relative>
19
+ <Fixed>...</Fixed>
20
+ <Sticky>...</Sticky>
21
+ </>
22
+ ```
23
+
24
+ **After**
25
+
26
+ ```jsx
27
+ <>
28
+ <Box position="absolute">...</Box>
29
+ <Box position="absolute">...</Box>
30
+ <Box position="relative">...</Box>
31
+ <Box position="fixed">...</Box>
32
+ <Box position="sticky">...</Box>
33
+ </>
34
+ ```
35
+
36
+ ## Default examples
37
+
38
+ ```jsx live
39
+ <Box p={2} mb={200}>
40
+ <Heading mb={2}>Relative + Absolute</Heading>
41
+ <Relative size={128} mx={128} my={6}>
42
+ <Box borderWidth="1px" borderStyle="solid" borderColor="border.default" borderRadius={2} size="100%">
43
+ <Absolute left="100%" top={0} color="fg.onEmphasis" bg="success.emphasis" p={1}>
44
+ rt
45
+ </Absolute>
46
+ <Absolute right="100%" top={0} color="fg.onEmphasis" bg="success.emphasis" p={1}>
47
+ lt
48
+ </Absolute>
49
+ <Absolute left="100%" bottom={0} color="fg.onEmphasis" bg="success.emphasis" p={1}>
50
+ rb
51
+ </Absolute>
52
+ <Absolute right="100%" bottom={0} color="fg.onEmphasis" bg="success.emphasis" p={1}>
53
+ lb
54
+ </Absolute>
55
+ <Absolute left={0} top="100%" color="fg.onEmphasis" bg="success.emphasis" p={1}>
56
+ bl
57
+ </Absolute>
58
+ <Absolute right={0} top="100%" color="fg.onEmphasis" bg="success.emphasis" p={1}>
59
+ br
60
+ </Absolute>
61
+ <Absolute left={0} bottom="100%" color="fg.onEmphasis" bg="success.emphasis" p={1}>
62
+ tl
63
+ </Absolute>
64
+ <Absolute right={0} bottom="100%" color="fg.onEmphasis" bg="success.emphasis" p={1}>
65
+ tr
66
+ </Absolute>
67
+ </Box>
68
+ </Relative>
69
+
70
+ <Heading my={2}>Sticky</Heading>
71
+
72
+ <Box
73
+ borderWidth="1px"
74
+ borderStyle="solid"
75
+ borderColor="success.emphasis"
76
+ borderRadius={2}
77
+ border={1}
78
+ height={500}
79
+ >
80
+ <Sticky top={0} bg="success.subtle" p={6}>
81
+ I'm sticky!
82
+ </Sticky>
83
+ </Box>
84
+
85
+ <Heading my={2}>Fixed</Heading>
86
+ <p>(see the bottom right of the screen)</p>
87
+
88
+ <Fixed bottom={0} right={0} color="fg.onEmphasis" bg="danger.emphasis" p={2}>
89
+ I'm fixed to the bottom right.
90
+ </Fixed>
91
+ </Box>
92
+ ```
93
+
94
+ ## System props
95
+
96
+ Position components get `POSITION`, `LAYOUT`, `FLEX`, and `COMMON` system props. Read our [System Props](/system-props) doc page for a full list of available props.
97
+
98
+ ## Component props
99
+
100
+ Position does not get any additional props other than the system props mentioned above.
@@ -0,0 +1,29 @@
1
+ ---
2
+ title: ProgressBar
3
+ componentId: progress_bar
4
+ source: https://github.com/primer/react/blob/main/src/ProgressBar.tsx
5
+ ---
6
+
7
+ ## Default example
8
+
9
+ ```jsx live
10
+ <ProgressBar progress={80} />
11
+ ```
12
+
13
+ If you'd like to use ProgressBar inline, pass the `inline` boolean prop & **be sure to set a width**.
14
+
15
+ ```jsx live
16
+ <>
17
+ <Text mr={3}>5 of 10</Text>
18
+ <ProgressBar progress={50} inline sx={{width: '100px'}} />
19
+ </>
20
+ ```
21
+
22
+ ## Component props
23
+
24
+ | Name | Type | Default | Description |
25
+ | :------- | :------ | :-----------------: | :------------------------------------------------------------------------------------------------------------------------------- |
26
+ | progress | Number | | Used to set the size of the green bar |
27
+ | barSize | String | 'default' | Controls the height of the progress bar. Can be 'small', 'large', or 'default'. If omitted, height is set to the default height. |
28
+ | inline | Boolean | false | Styles the progress bar inline |
29
+ | bg | String | 'bg.successInverse' | Set the progress bar color, defaults to bg-green |
@@ -0,0 +1,371 @@
1
+ ---
2
+ title: SelectMenu
3
+ ---
4
+
5
+ The `SelectMenu` components are a suite of components which can be combined together to make several different variations of our GitHub select menu. At it's most basic form, a select menu is comprised of a `SelectMenu` wrapper, which contains a `summary` component of your choice and a `Select.Modal` which contains the select menu content. Use `SelectMenu.List` to wrap items in the select menu, and `SelectMenu.Item` to wrap each item.
6
+
7
+ Several additional components exist to provide even more functionality: `SelectMenu.Header`, `SelectMenu.Filter`, `SelectMenu.Tabs`, `SelectMenu.TabPanel` `SelectMenu.Footer` and `SelectMenu.Divider`.
8
+
9
+ ## Basic Example
10
+
11
+ ```jsx live
12
+ <SelectMenu>
13
+ <Button as="summary">Projects</Button>
14
+ <SelectMenu.Modal>
15
+ <SelectMenu.Header>Projects</SelectMenu.Header>
16
+ <SelectMenu.List>
17
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
18
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
19
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
20
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
21
+ </SelectMenu.List>
22
+ </SelectMenu.Modal>
23
+ </SelectMenu>
24
+ ```
25
+
26
+ ## SelectMenu
27
+
28
+ Main wrapper component for select menu.
29
+
30
+ ```jsx
31
+ <SelectMenu>{/* all other sub components are wrapped here*/}</SelectMenu>
32
+ ```
33
+
34
+ ### Component Props
35
+
36
+ | Name | Type | Default | Description |
37
+ | :--------- | :---------------- | :-----: | :--------------------------------------------------------------------------------------------------------------------------------------- |
38
+ | initialTab | String | | If using the `SelectMenu.Tabs` component, you can use this prop to change the tab shown on open. By default, the first tab will be used. |
39
+ | ref | React ref | | ref to pass down to SelectMenu component |
40
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
41
+
42
+ ## SelectMenu.MenuContext
43
+
44
+ SelectMenu.MenuContext is a [context object](https://reactjs.org/docs/context.html#reactcreatecontext) that exposes some helpful state values to be used via [`React.useContext`](https://reactjs.org/docs/hooks-reference.html#usecontext) in consuming applications. SelectMenu.MenuContext can only be used in components that are already wrapped in a `SelectMenu` as `SelectMenu` contains the [context provider](https://reactjs.org/docs/context.html#contextprovider).
45
+
46
+ ### Values available on MenuContext
47
+
48
+ | Name | Type | Description |
49
+ | :------------- | :------- | :---------------------------------------------------------------------------------------------------------------------------------------------- |
50
+ | selectedTab | string | The currently selected tab |
51
+ | setSelectedTab | function | Used to update the currently selected tab state |
52
+ | open | boolean | State for open/closed status of the menu modal |
53
+ | setOpen | function | Used to update the `open` state |
54
+ | initialTab | string | Mostly used internally to pass down which tab should be set to open by default. To change this value use the `initialTab` prop on `SelectMenu`. |
55
+
56
+ ### Example Usage
57
+
58
+ ```jsx
59
+ import {SelectMenu, Button} from `@primer/components`
60
+ import React, {useContext} from 'react'
61
+
62
+ const MyMenu = () => {
63
+ <SelectMenu>
64
+ <MyButton />
65
+ <SelectMenu.Modal>
66
+ content
67
+ </SelectMenu.Modal>
68
+ </SelectMenu>
69
+ }
70
+
71
+ // note that we can only use the context in components that are already wrapped by SelectMenu (and thus the Context.Provider)
72
+ const MyButton = () => {
73
+ const menuContext = useContext(SelectMenu.MenuContext);
74
+
75
+ return (
76
+ <Button as="summary">{menuContext.open ? 'Open' : 'Closed'}</Button>
77
+ )
78
+ }
79
+ ```
80
+
81
+ ## SelectMenu.Modal
82
+
83
+ Used to wrap the content in a `SelectMenu`.
84
+
85
+ ```jsx
86
+ <SelectMenu.Modal>{/* all menu content is wrapped in the modal*/}</SelectMenu.Modal>
87
+ ```
88
+
89
+ ### Right-aligned modal
90
+
91
+ Use the `align='right'` prop to align the modal to the right. Note that this only modifies alignment for the modal, and not the SelectMenu itself. You will need to wrap the SelectMenu in a relatively positioned element for this to work properly.
92
+
93
+ ```jsx live
94
+ <Box position="relative" display="flex" justifyContent="flex-end">
95
+ <SelectMenu>
96
+ <Button as="summary">Projects</Button>
97
+ <SelectMenu.Modal align="right">
98
+ <SelectMenu.Header>Projects</SelectMenu.Header>
99
+ <SelectMenu.List>
100
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
101
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
102
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
103
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
104
+ </SelectMenu.List>
105
+ </SelectMenu.Modal>
106
+ </SelectMenu>
107
+ </Box>
108
+ ```
109
+
110
+ ### Component Props
111
+
112
+ | Prop name | Type | Default | Description |
113
+ | :-------- | :---------------- | :------ | ------------------------------------------------- |
114
+ | align | String | 'left' | Use `right` to align the select menu to the right |
115
+ | width | String or Number | 300px | Sets the modal width |
116
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
117
+
118
+ ## SelectMenu.List
119
+
120
+ Used to wrap the select menu list content. All menu items **must** be wrapped in a SelectMenu.List in order for the accessbility keyboard handling to function properly. If you are using the `SelectMenu.TabPanel` you do not need to provide a `SelectMenu.List` as that component renders a `SelectMenu.List` as a wrapper.
121
+
122
+ ```jsx
123
+ <SelectMenu.List>{/* all menu list items are wrapped in the list*/}</SelectMenu.List>
124
+ ```
125
+
126
+ ### Component Props
127
+
128
+ | Name | Type | Default | Description |
129
+ | :--- | :---------------- | :-----: | :----------------------------------- |
130
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
131
+
132
+ ## SelectMenu.Item
133
+
134
+ Individual items in a select menu. SelectMenu.Item renders an anchor tag by default, you'll need to make sure to provide the appropriate `href`.
135
+
136
+ You can use a `button` tag instead by utilizing the [`as` prop](/core-concepts#the-as-prop). Be sure to consider [which HTML element is the right choice](https://marcysutton.com/links-vs-buttons-in-modern-web-applications) for your usage of the component.
137
+
138
+ ```jsx
139
+ <SelectMenu.Item href="/link/to/thing" selected={true}>
140
+ {/* wraps an individual list item*/}
141
+ </SelectMenu.Item>
142
+ ```
143
+
144
+ ### Component Props
145
+
146
+ | Name | Type | Default | Description |
147
+ | :------- | :---------------- | :-----: | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
148
+ | selected | boolean | | Used to apply styles to the selected items in the list. |
149
+ | onClick | function | | Function called when item is clicked. By default we also close the menu when items are clicked. If you would like the menu to stay open, pass an `e.preventDefault()` to your onClick handler. |
150
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
151
+
152
+ ## SelectMenu.Filter
153
+
154
+ Use a `SelectMenu.Filter` to add a filter UI to your select menu. Users are expected to implement their own filtering and manage the state of the `value` prop on the input. This gives users more flexibility over the type of filtering and type of content passed into each select menu item.
155
+
156
+ ```jsx live
157
+ <SelectMenu>
158
+ <Button as="summary">Projects</Button>
159
+ <SelectMenu.Modal>
160
+ <SelectMenu.Header>Filter by Project</SelectMenu.Header>
161
+ <SelectMenu.Filter placeholder="Filter projects" value="" aria-label="Filter Projects" />
162
+ <SelectMenu.List>
163
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
164
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
165
+ <SelectMenu.Divider>More Options</SelectMenu.Divider>
166
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
167
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
168
+ </SelectMenu.List>
169
+ </SelectMenu.Modal>
170
+ </SelectMenu>
171
+ ```
172
+
173
+ ### Component Props
174
+
175
+ SelectMenu.Filter components receive all the props that the [TextInput](/TextInput) component gets.
176
+
177
+ | Name | Type | Default | Description |
178
+ | :---- | :---------------- | :-----: | :------------------------------------------------------------------------------------------------------------- |
179
+ | value | String | | Users of this component must provide a value for the filter input that is managed in the consuming application |
180
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
181
+
182
+ ## SelectMenu.Tabs
183
+
184
+ Use `SelectMenu.Tabs` to wrap the the tab navigation and `SelectMenu.Tab` for each tab in the navigation.
185
+
186
+ `SelectMenu.TabPanel` should wrap each corresponding panel for each of the tabs. The `tabName` prop for each `SelectMenu.TabPanel` must match the name provided in the `tabName` prop on `SelectMenu.Tab`.
187
+
188
+ To set one of the tabs to be open by default, use `initialTab` on the main `SelectMenu` component. Otherwise, the first tab will be shown by default.
189
+
190
+ Each `Select.Menu` tab will need to have an `index` prop. The first tab should be at index `0`, the second at index `1` and so forth. The `index` prop is used to show the first tab by default.
191
+
192
+ If you need access to the selected tab state, you can find it in the MenuContext object exported from `SelectMenu` as `MenuContext.selectedTab`.
193
+
194
+ ```jsx live
195
+ <SelectMenu>
196
+ <Button as="summary">Projects</Button>
197
+ <SelectMenu.Modal>
198
+ <SelectMenu.Header>Projects</SelectMenu.Header>
199
+ <SelectMenu.Tabs>
200
+ <SelectMenu.Tab index={0} tabName="Repository" />
201
+ <SelectMenu.Tab index={1} tabName="Organization" />
202
+ </SelectMenu.Tabs>
203
+ <SelectMenu.TabPanel tabName="Repository">
204
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
205
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
206
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
207
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
208
+ </SelectMenu.TabPanel>
209
+ <SelectMenu.TabPanel tabName="Organization">
210
+ <SelectMenu.Item href="#"> Project 2</SelectMenu.Item>
211
+ </SelectMenu.TabPanel>
212
+ <SelectMenu.Footer>Showing 3 of 3</SelectMenu.Footer>
213
+ </SelectMenu.Modal>
214
+ </SelectMenu>
215
+ ```
216
+
217
+ ### Component Props
218
+
219
+ | Name | Type | Default | Description |
220
+ | :--- | :---------------- | :-----: | :----------------------------------- |
221
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
222
+
223
+ ## SelectMenu.Tab
224
+
225
+ Used for each individual tab inside of a `SelectMenu.Tabs`. Be sure to set the `index` prop to correspond to the order the tab is in. The `tabName` prop should correspond to the `tabName` set on the `SelectMenu.TabPanel`.
226
+
227
+ The `onClick` prop is optional and can be used for any events or data fetching you might need to trigger on tab clicks.
228
+
229
+ ```jsx
230
+ <>
231
+ <SelectMenu.Tab index={0} tabName="Repository" />
232
+ <SelectMenu.Tab index={1} tabName="Organization" />
233
+ </>
234
+ ```
235
+
236
+ ### Component Props
237
+
238
+ | Name | Type | Default | Description |
239
+ | :------ | :---------------- | :-----: | :------------------------------------------------------------------------------------------------------------------------- |
240
+ | tabName | String | | Used to identify the corresponding tab. Must match the string used in the `tabs` array in the `SelectMenu.Tabs` component. |
241
+ | index | Number | | The index at which the tab is in the list of tabs |
242
+ | onClick | Function | | Function to be called when the tab is clicked. Optional. |
243
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
244
+
245
+ ## SelectMenu.TabPanel
246
+
247
+ Wraps the content for each tab. Make sure to use the `tabName` prop to identify each tab panel with the correct tab in the tab navigation.
248
+
249
+ **Note**: SelectMenu.TabPanel wraps content in a SelectMenu.List, so adding a SelectMenu.List manually is not necessary.
250
+
251
+ ```jsx
252
+ <SelectMenu.TabPanel tabName="Repository">{/* Wraps content for each tab */}</SelectMenu.TabPanel>
253
+ ```
254
+
255
+ ### Component Props
256
+
257
+ | Name | Type | Default | Description |
258
+ | :------ | :---------------- | :-----: | :------------------------------------------------------------------------------------------------------------------------- |
259
+ | tabName | String | | Used to identify the corresponding tab. Must match the string used in the `tabs` array in the `SelectMenu.Tabs` component. |
260
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
261
+
262
+ ## SelectMenu.Divider
263
+
264
+ Use a `SelectMenu.Divider` to add information between items in a `SelectMenu.List`.
265
+
266
+ ```jsx live
267
+ <SelectMenu>
268
+ <Button as="summary">Projects</Button>
269
+ <SelectMenu.Modal>
270
+ <SelectMenu.Header>Projects</SelectMenu.Header>
271
+ <SelectMenu.List>
272
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
273
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
274
+ <SelectMenu.Divider>More Options</SelectMenu.Divider>
275
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
276
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
277
+ </SelectMenu.List>
278
+ </SelectMenu.Modal>
279
+ </SelectMenu>
280
+ ```
281
+
282
+ ### Component Props
283
+
284
+ | Name | Type | Default | Description |
285
+ | :--- | :---------------- | :-----: | :----------------------------------- |
286
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
287
+
288
+ ## SelectMenu.Footer
289
+
290
+ Use a `SelectMenu.Footer` to add content to the bottom of the select menu.
291
+
292
+ ```jsx live
293
+ <SelectMenu>
294
+ <Button as="summary">Projects</Button>
295
+ <SelectMenu.Modal>
296
+ <SelectMenu.Header>Projects</SelectMenu.Header>
297
+ <SelectMenu.List>
298
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
299
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
300
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
301
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
302
+ <SelectMenu.Footer>Use ⌥ + click/return to exclude labels.</SelectMenu.Footer>
303
+ </SelectMenu.List>
304
+ </SelectMenu.Modal>
305
+ </SelectMenu>
306
+ ```
307
+
308
+ ### Component Props
309
+
310
+ | Name | Type | Default | Description |
311
+ | :--- | :---------------- | :-----: | :----------------------------------- |
312
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
313
+
314
+ ## SelectMenu.Header
315
+
316
+ Use a `SelectMenu.Header` to add a header to the top of the select menu content.
317
+
318
+ ```jsx live
319
+ <SelectMenu>
320
+ <Button as="summary">Projects</Button>
321
+ <SelectMenu.Modal>
322
+ <SelectMenu.Header>Projects</SelectMenu.Header>
323
+ <SelectMenu.List>
324
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
325
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
326
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
327
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
328
+ <SelectMenu.Footer>Use ⌥ + click/return to exclude labels.</SelectMenu.Footer>
329
+ </SelectMenu.List>
330
+ </SelectMenu.Modal>
331
+ </SelectMenu>
332
+ ```
333
+
334
+ ### Component Props
335
+
336
+ | Name | Type | Default | Description |
337
+ | :--- | :---------------- | :-----: | :----------------------------------- |
338
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
339
+
340
+ ## SelectMenu.LoadingAnimation
341
+
342
+ Use a `SelectMenu.LoadingAnimation` to add a loading animation inside of the SelectMenu.
343
+
344
+ **Note**: You will need to handle showing/hiding the appropriate modal content for your application during the loading state. We recommend always showing the `SelectMenu.Filter` and `SelectMenu.Header` (if used) and hiding the rest of the modal content during the loading state.
345
+
346
+ ```jsx live
347
+ <SelectMenu>
348
+ <Button as="summary">Projects</Button>
349
+ <SelectMenu.Modal>
350
+ <SelectMenu.Header>Projects</SelectMenu.Header>
351
+ <SelectMenu.Filter placeholder="Filter projects" value="" aria-label="Filter Projects" />
352
+ {true ? (
353
+ <SelectMenu.LoadingAnimation />
354
+ ) : (
355
+ <SelectMenu.List>
356
+ <SelectMenu.Item href="#">Primer React bugs</SelectMenu.Item>
357
+ <SelectMenu.Item href="#">Primer React roadmap</SelectMenu.Item>
358
+ <SelectMenu.Item href="#"> Project 3</SelectMenu.Item>
359
+ <SelectMenu.Item href="#">Project 4</SelectMenu.Item>
360
+ <SelectMenu.Footer>Use ⌥ + click/return to exclude labels.</SelectMenu.Footer>
361
+ </SelectMenu.List>
362
+ )}
363
+ </SelectMenu.Modal>
364
+ </SelectMenu>
365
+ ```
366
+
367
+ ### Component Props
368
+
369
+ | Name | Type | Default | Description |
370
+ | :--- | :---------------- | :-----: | :----------------------------------- |
371
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
@@ -0,0 +1,67 @@
1
+ ---
2
+ title: SelectPanel
3
+ status: Alpha
4
+ ---
5
+
6
+ A `SelectPanel` provides an anchor that will open an overlay with a list of selectable items, and a text input to filter the selectable items
7
+
8
+ ## Example
9
+
10
+ ```javascript live noinline
11
+ function getColorCircle(color) {
12
+ return function () {
13
+ return (
14
+ <Box
15
+ borderWidth="1px"
16
+ borderStyle="solid"
17
+ bg={color}
18
+ borderColor={color}
19
+ width={14}
20
+ height={14}
21
+ borderRadius={10}
22
+ margin="auto"
23
+ />
24
+ )
25
+ }
26
+ }
27
+
28
+ const items = [
29
+ {leadingVisual: getColorCircle('#a2eeef'), text: 'enhancement', id: 1},
30
+ {leadingVisual: getColorCircle('#d73a4a'), text: 'bug', id: 2},
31
+ {leadingVisual: getColorCircle('#0cf478'), text: 'good first issue', id: 3},
32
+ {leadingVisual: getColorCircle('#ffd78e'), text: 'design', id: 4},
33
+ {leadingVisual: getColorCircle('#ff0000'), text: 'blocker', id: 5},
34
+ {leadingVisual: getColorCircle('#a4f287'), text: 'backend', id: 6},
35
+ {leadingVisual: getColorCircle('#8dc6fc'), text: 'frontend', id: 7}
36
+ ]
37
+
38
+ function DemoComponent() {
39
+ const [selected, setSelected] = React.useState([items[0], items[1]])
40
+ const [filter, setFilter] = React.useState('')
41
+ const filteredItems = items.filter(item => item.text.toLowerCase().startsWith(filter.toLowerCase()))
42
+ const [open, setOpen] = React.useState(false)
43
+
44
+ return (
45
+ <SelectPanel
46
+ renderAnchor={({children, 'aria-labelledby': ariaLabelledBy, ...anchorProps}) => (
47
+ <DropdownButton aria-labelledby={` ${ariaLabelledBy}`} {...anchorProps}>
48
+ {children || 'Select Labels'}
49
+ </DropdownButton>
50
+ )}
51
+ placeholderText="Filter Labels"
52
+ open={open}
53
+ onOpenChange={setOpen}
54
+ items={filteredItems}
55
+ selected={selected}
56
+ onSelectedChange={setSelected}
57
+ onFilterChange={setFilter}
58
+ showItemDividers={true}
59
+ overlayProps={{width: 'small', height: 'xsmall'}}
60
+ />
61
+ )
62
+ }
63
+
64
+ render(<DemoComponent />)
65
+ ```
66
+
67
+ ## Component props