@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,22 @@
1
+ ---
2
+ title: Heading
3
+ ---
4
+
5
+ The Heading component will render an html `h2` tag without any default styling. Other heading level elements `h1-h6` are available through use of the `as` prop (see [System Props](/system-props) for additional explanation). Please reference the [w3 recommendations for headings](https://www.w3.org/WAI/tutorials/page-structure/headings/) to ensure your headings provide an accessible experience for screen reader users.
6
+
7
+ **Attention:** Make sure to include a valid heading element to render a Heading component other than `h2` (`<Heading as="h1">H1 Element</Heading>`).
8
+
9
+ ## Default example
10
+ ```jsx live
11
+ <Heading fontSize={1} mb={2}>H2 heading with fontSize={1}</Heading>
12
+ ```
13
+
14
+ ## System props
15
+
16
+ Heading components get `TYPOGRAPHY` and `COMMON` system props. Read our [System Props](/system-props) doc page for a full list of available props.
17
+
18
+ ## Component props
19
+
20
+ | Prop name | Type | Description |
21
+ | :-------- | :------ | :----------------------------------------------- |
22
+ | as | String or React element | sets the HTML tag for the component |
@@ -0,0 +1,49 @@
1
+ ---
2
+ title: Label
3
+ ---
4
+
5
+ The Label component is used to add contextual metadata to a design. Visually it styles text, adds padding, and rounded corners.
6
+
7
+ ## Default example
8
+
9
+ ```jsx live
10
+ <>
11
+ <Label variant="small" outline sx={{borderColor: 'danger.emphasis', mr: 2, color: 'danger.fg'}}>
12
+ small
13
+ </Label>
14
+ <Label variant="medium" sx={{mr: 2}}>
15
+ medium (default)
16
+ </Label>
17
+ <Label variant="large" sx={{mr: 2}}>
18
+ large
19
+ </Label>
20
+ <Label variant="xl">xl label</Label>
21
+
22
+ <Box mt={4} />
23
+ <Label variant="medium" sx={{bg: '#A575FF', m: 1}}>
24
+ good first issue
25
+ </Label>
26
+ <Label variant="medium" sx={{bg: '#FF75C8', m: 1}}>
27
+ 🚂 deploy: train
28
+ </Label>
29
+ <Label variant="medium" sx={{bg: '#1C90FA', m: 1}}>
30
+ css
31
+ </Label>
32
+ <Label variant="medium" sx={{bg: '#FFF06C', color: '#24292E', m: 1}}>
33
+ documentation
34
+ </Label>
35
+ <Label variant="medium" sx={{bg: '#656BFE', m: 1}}>
36
+ primer
37
+ </Label>
38
+ </>
39
+ ```
40
+
41
+ ## Component props
42
+
43
+ | Name | Type | Default | Description |
44
+ | :--------- | :---------------- | :--------------------: | :----------------------------------------------------------------------------- |
45
+ | outline | Boolean | | Creates an outline style label |
46
+ | variant | String | 'medium' | Can be one of `small`, `medium` (default), `large` or `xl` . |
47
+ | dropshadow | Boolean | | Adds a dropshadow to the label |
48
+ | bg | String | 'label.primary.border' | Part of the `COMMON` system props, used to change the background of the label. |
49
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
@@ -0,0 +1,21 @@
1
+ ---
2
+ title: LabelGroup
3
+ ---
4
+
5
+ The LabelGroup component is used to add commonly used margins and wrapping for groups of Labels.
6
+
7
+ ## Default example
8
+
9
+ ```jsx live
10
+ <LabelGroup>
11
+ <Label>Default label</Label>
12
+ <Label sx={{color: 'fg.onEmphasis', bg: 'danger.emphasis'}}>Label with background indicating a closed PR state</Label>
13
+ <Label outline>Default outline label</Label>
14
+ </LabelGroup>
15
+ ```
16
+
17
+ ## Component props
18
+
19
+ | Name | Type | Default | Description |
20
+ | :--- | :---------------- | :-----: | :----------------------------------- |
21
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
@@ -0,0 +1,28 @@
1
+ ---
2
+ title: Link
3
+ ---
4
+
5
+ The Link component styles anchor tags with default hyperlink color cues and hover text decoration. `Link` is used for destinations, or moving from one page to another.
6
+
7
+ In special cases where you'd like a `<button>` styled like a `Link`, use `<Link as='button'>`. Make sure to provide a click handler with `onClick`.
8
+
9
+ **Important:** When using the `as` prop, be sure to always render an accessible element type, like `a`, `button`, `input`, or `summary`.
10
+
11
+ ## Default example
12
+
13
+ ```jsx live
14
+ <Link sx={{mb: 1}} href="https://github.com">
15
+ Link
16
+ </Link>
17
+ ```
18
+
19
+ ## Component props
20
+
21
+ | Name | Type | Default | Description |
22
+ | :--------- | :---------------- | :-----: | :------------------------------------------------------------------------------ |
23
+ | href | String | | URL to be used for the Link |
24
+ | muted | Boolean | false | Uses a less prominent shade for Link color, and the default link shade on hover |
25
+ | underline | Boolean | false | Adds underline to the Link |
26
+ | as | String | 'a' | Can be 'a', 'button', 'input', or 'summary' |
27
+ | hoverColor | String | | Color used when hovering over link |
28
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
@@ -0,0 +1,85 @@
1
+ ---
2
+ title: Overlay
3
+ ---
4
+
5
+ An `Overlay` is a flexible floating surface, used to display transient content such as menus, selection options, dialogs, and more. Overlays use shadows to express elevation. The `Overlay` component handles all behaviors needed by overlay UIs as well as the common styles that all overlays should have. `Overlay` is the base component for many of our overlay-type components.
6
+
7
+ Behaviors include:
8
+
9
+ - Rendering the overlay in a React Portal so that it always renders on top of other content on the page
10
+ - Trapping focus
11
+ - Calling a user provided function when the user presses `Escape`
12
+ - Calling a user provided function when the user clicks outside of the container
13
+ - Focusing either user provided element, or the first focusable element in the container when it is opened
14
+ - Returning focus to an element when container is closed
15
+
16
+ ## Accessibility considerations
17
+
18
+ - The `Overlay` must either have:
19
+ - A value set for the `aria-labelledby` attribute that refers to a visible title.
20
+ - An `aria-label` attribute
21
+ - If the `Overlay` should also have a longer description, use `aria-describedby`
22
+ - The `Overlay` component has a `role="dialog"` set on it, if you are using `Overlay` for alerts, you can pass in `role="alertdialog"` instead. Please read the [W3C guidelines](https://www.w3.org/TR/wai-aria-1.1/#alertdialog) to determine which role is best for your use case
23
+ - The `Overlay` component has `aria-modal` set to `true` by default and should not be overridden as all `Overlay`s behave as modals.
24
+
25
+ See the W3C accessibility recommendations for modals [here](https://www.w3.org/TR/wai-aria-practices-1.1/#dialog_roles_states_props).
26
+
27
+ ## Positioning
28
+
29
+ `Overlay` renders its `children` within a div positioned absolutely within a portal within the default portal root. The overlay will not update its positioning if the portal root's positioning changes (e.g., if the portal root is statically positioned after some DOM element that dynamically resizes). You may consider [customizing the portal or specifying a different portal root](/Portal#customizing-the-portal-root) to achieve different positioning behavior.
30
+
31
+ ## Default example
32
+
33
+ ```javascript live noinline
34
+ const Demo = () => {
35
+ // you must manage your own open state
36
+ const [isOpen, setIsOpen] = React.useState(false)
37
+ const noButtonRef = React.useRef(null)
38
+ const anchorRef = React.useRef(null)
39
+ return (
40
+ <>
41
+ <Button ref={anchorRef} onClick={() => setIsOpen(!isOpen)}>
42
+ open overlay
43
+ </Button>
44
+ {/* be sure to conditionally render the Overlay. This helps with performance and is required. */}
45
+ {isOpen && (
46
+ <Overlay
47
+ initialFocusRef={noButtonRef}
48
+ returnFocusRef={anchorRef}
49
+ ignoreClickRefs={[anchorRef]}
50
+ onEscape={() => setIsOpen(!isOpen)}
51
+ onClickOutside={() => setIsOpen(false)}
52
+ aria-labelledby="title"
53
+ >
54
+ <Box display="flex" flexDirection="column" p={2}>
55
+ <Text id="title">Are you sure you would like to delete this item?</Text>
56
+ <Button>yes</Button>
57
+ <Button ref={noButtonRef}>no</Button>
58
+ </Box>
59
+ </Overlay>
60
+ )}
61
+ </>
62
+ )
63
+ }
64
+
65
+ render(<Demo />)
66
+ ```
67
+
68
+ ## Component props
69
+
70
+ | Name | Type | Default | Description |
71
+ | :------------------ | :------------------------------------------------------------- | :---------: | :---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
72
+ | ignoreClickRefs | `React.RefObject<HTMLElement> []` | `undefined` | Optional. An array of ref objects to ignore clicks on in the `onOutsideClick` behavior. This is often used to ignore clicking on the element that toggles the open/closed state for the `Overlay` to prevent the `Overlay` from being toggled twice. |
73
+ | initialFocusRef | `React.RefObject<HTMLElement>` | `undefined` | Optional. Ref for the element to focus when the `Overlay` is opened. If nothing is provided, the first focusable element in the `Overlay` body is focused. |
74
+ | anchorRef | `React.RefObject<HTMLElement>` | `undefined` | Required. Element the `Overlay` should be anchored to. |
75
+ | returnFocusRef | `React.RefObject<HTMLElement>` | `undefined` | Required. Ref for the element to focus when the `Overlay` is closed. |
76
+ | onClickOutside | `function` | `undefined` | Required. Function to call when clicking outside of the `Overlay`. Typically this function sets the `Overlay` visibility state to `false`. |
77
+ | onEscape | `function` | `undefined` | Required. Function to call when user presses `Escape`. Typically this function sets the `Overlay` visibility state to `false`. |
78
+ | width | `'small' │ 'medium' │ 'large' │ 'xlarge' │ 'xxlarge' │ 'auto'` | `auto` | Sets the width of the `Overlay`, pick from our set list of widths, or pass `auto` to automatically set the width based on the content of the `Overlay`. `small` corresponds to `256px`, `medium` corresponds to `320px`, `large` corresponds to `480px`, `xlarge` corresponds to `640px`, `xxlarge` corresponds to `960px`. |
79
+ | height | `'xsmall', 'small', 'medium', 'large', 'xlarge', 'auto'` | `auto` | Sets the height of the `Overlay`, pick from our set list of heights, or pass `auto` to automatically set the height based on the content of the `Overlay`. `xsmall` corresponds to `192px`, `small` corresponds to `256px`, `medium` corresponds to `320px`, `large` corresponds to `432px`, `xlarge` corresponds to `600px`. |
80
+ | visibility | `'visible', 'hidden'` | `visible` | Sets the visibility of the `Overlay`. |
81
+ | anchorSide | `AnchorSide` | undefined | Optional. If provided, the Overlay will slide into position from the side of the anchor with a brief animation |
82
+ | top | `number` | 0 | Vertical position of the overlay, relative to its closest positioned ancestor (often its `Portal`). |
83
+ | left | `number` | 0 | Horizontal position of the overlay, relative to its closest positioned ancestor (often its `Portal`). |
84
+ | portalContainerName | `string` | `undefined` | Optional. If defined, Overlays will be rendered in the named portal. See also `Portal`. |
85
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
@@ -0,0 +1,18 @@
1
+ ---
2
+ title: Pagehead
3
+ ---
4
+
5
+ Give a page a clear, separated title and optional top nav by using Pagehead.
6
+
7
+ ## Default example
8
+
9
+ ```jsx live
10
+ <Pagehead>Pagehead</Pagehead>
11
+ ```
12
+
13
+ ## Component props
14
+
15
+ | Name | Type | Default | Description |
16
+ | :--- | :---------------- | :-----: | :----------------------------------- |
17
+ | as | String | `div` | Sets the HTML tag for the component |
18
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
@@ -0,0 +1,178 @@
1
+ ---
2
+ title: Pagination
3
+ ---
4
+
5
+ import State from '../components/State'
6
+
7
+ Use the pagination component to create a connected set of links that lead to related pages (for example, previous, next, or page numbers).
8
+
9
+ ## Basic example
10
+
11
+ The pagination component only requires two properties to render: `pageCount`, which is the total number of pages, and `currentPage`, which is the currently selected page number (which should be managed by the consuming application).
12
+
13
+ ```jsx live
14
+ <Pagination pageCount={15} currentPage={2} onPageChange={e => e.preventDefault()} />
15
+ ```
16
+
17
+ However, to handle state changes when the user clicks a page, you also need to pass `onPageChange`, which is a function that takes a click event and page number as an argument:
18
+
19
+ ```javascript
20
+ type PageChangeCallback = (evt: React.MouseEvent, page: number) => void
21
+ ```
22
+
23
+ By default, clicking a link in the pagination component will cause the browser to navigate to the URL specified by the page. To cancel navigation and handle state management on your own, you should call `preventDefault` on the event, as in this example:
24
+
25
+ ```jsx live
26
+ <State default={1}>
27
+ {([page, setPage]) => {
28
+ const totalPages = 15
29
+ const onPageChange = (evt, page) => {
30
+ evt.preventDefault()
31
+ setPage(page)
32
+ }
33
+
34
+ return (
35
+ <Box borderWidth="1px" borderStyle="solid" borderColor="border.default" borderRadius={2} p={2}>
36
+ <Box>
37
+ Current page: {page} / {totalPages}
38
+ </Box>
39
+ <Pagination pageCount={totalPages} currentPage={page} onPageChange={onPageChange} />
40
+ </Box>
41
+ )
42
+ }}
43
+ </State>
44
+ ```
45
+
46
+ ## Customizing link URLs
47
+
48
+ To customize the URL generated for each link, you can pass a function to the `hrefBuilder` property. The function should take a page number as an argument and return a URL to use for the link.
49
+
50
+ ```javascript
51
+ type HrefBuilder = (page: number) => string
52
+ ```
53
+
54
+ ```jsx live
55
+ <State default={'(nothing clicked yet)'}>
56
+ {([lastUrl, setLastUrl]) => {
57
+ const onPageChange = (evt, page) => {
58
+ evt.preventDefault()
59
+ setLastUrl(evt.target.href)
60
+ }
61
+ const hrefBuilder = page => {
62
+ return `https://example.com/pages/${page}`
63
+ }
64
+
65
+ return (
66
+ <Box borderWidth="1px" borderStyle="solid" borderColor="border.default" borderRadius={2} p={2}>
67
+ <Box>The last URL clicked was: {lastUrl}</Box>
68
+ <Pagination pageCount={15} currentPage={2} onPageChange={onPageChange} hrefBuilder={hrefBuilder} />
69
+ </Box>
70
+ )
71
+ }}
72
+ </State>
73
+ ```
74
+
75
+ ## Customizing which pages are shown
76
+
77
+ Two props control how many links are displayed in the pagination container at any given time. `marginPageCount` controls how many pages are guaranteed to be displayed on the left and right of the component; `surroundingPageCount` controls how many pages will be displayed to the left and right of the current page.
78
+
79
+ ```jsx live
80
+ <Pagination
81
+ pageCount={20}
82
+ currentPage={10}
83
+ marginPageCount={1}
84
+ surroundingPageCount={2}
85
+ onPageChange={e => e.preventDefault()}
86
+ />
87
+ ```
88
+
89
+ The algorithm tries to minimize the amount the component shrinks and grows as the user changes pages; for this reason, if any of the pages in the margin (controlled via `marginPageCount`) intersect with pages in the center (controlled by `surroundingPageCount`), the center section will be shifted away from the margin. Consider the following examples, where pages one through six are shown when any of the first four pages are selected. Only when the fifth page is selected and there is a gap between the margin pages and the center pages does a break element appear.
90
+
91
+ ```jsx live
92
+ <Box>
93
+ {[1, 2, 3, 4, 5].map(page => (
94
+ <Pagination
95
+ pageCount={20}
96
+ currentPage={page}
97
+ marginPageCount={1}
98
+ surroundingPageCount={2}
99
+ onPageChange={e => e.preventDefault()}
100
+ />
101
+ ))}
102
+ </Box>
103
+ ```
104
+
105
+ ### Previous/next pagination
106
+
107
+ To hide all the page numbers and create a simple pagination container with just the Previous and Next buttons, set `showPages` to `false`.
108
+
109
+ ```jsx live
110
+ <State default={1}>
111
+ {([page, setPage]) => {
112
+ const totalPages = 10
113
+ const onPageChange = (evt, page) => {
114
+ evt.preventDefault()
115
+ setPage(page)
116
+ }
117
+
118
+ return (
119
+ <Box borderWidth="1px" borderStyle="solid" borderColor="border.default" borderRadius={2} p={2}>
120
+ <Box>
121
+ Current page: {page} / {totalPages}
122
+ </Box>
123
+ <Pagination pageCount={totalPages} currentPage={page} onPageChange={onPageChange} showPages={false} />
124
+ </Box>
125
+ )
126
+ }}
127
+ </State>
128
+ ```
129
+
130
+ ## Component props
131
+
132
+ | Name | Type | Default | Description |
133
+ | :------------------- | :---------------- | :--------: | :--------------------------------------------------------------------- |
134
+ | currentPage | Number | | **Required.** The currently selected page. |
135
+ | hrefBuilder | Function | `#${page}` | A function to generate links based on page number. |
136
+ | marginPageCount | Number | 1 | How many pages to always show at the left and right of the component. |
137
+ | onPageChange | Function | no-op | Called with event and page number when a page is clicked. |
138
+ | pageCount | Number | | **Required.** The total number of pages. |
139
+ | showPages | Boolean | `true` | Whether or not to show the individual page links. |
140
+ | surroundingPageCount | Number | 2 | How many pages to display on each side of the currently selected page. |
141
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
142
+
143
+ ## Theming
144
+
145
+ The following snippet shows the properties in the theme that control the styling of the pagination component:
146
+
147
+ ```javascript
148
+ export default {
149
+ // ... rest of theme ...
150
+ pagination: {
151
+ borderRadius,
152
+ spaceBetween,
153
+ colors: {
154
+ normal: {
155
+ fg
156
+ },
157
+ disabled: {
158
+ fg,
159
+ border
160
+ },
161
+ hover: {
162
+ border
163
+ },
164
+ selected: {
165
+ fg,
166
+ bg,
167
+ border
168
+ },
169
+ active: {
170
+ border
171
+ },
172
+ nextPrevious: {
173
+ fg
174
+ }
175
+ }
176
+ }
177
+ }
178
+ ```
@@ -0,0 +1,81 @@
1
+ ---
2
+ title: PointerBox
3
+ ---
4
+
5
+ PointerBox is a [BorderBox](./BorderBox) component with a caret added to it.
6
+
7
+ ## Default example
8
+
9
+ ```jsx live
10
+ <PointerBox m={4} p={2} minHeight={100} bg="success.subtle" borderColor="success.emphasis">
11
+ PointerBox
12
+ </PointerBox>
13
+ ```
14
+
15
+ ```javascript live noinline
16
+ function PointerBoxDemo(props) {
17
+ const [pos, setPos] = React.useState('top')
18
+
19
+ return (
20
+ <Box>
21
+ <Heading as="h3" sx={{fontSize: 3}}>
22
+ Caret Position
23
+ </Heading>
24
+ <CaretSelector current={pos} onChange={setPos} />
25
+ <Box position="relative" pt={4}>
26
+ <PointerBox m={4} p={2} minHeight={100} bg="success.subtle" borderColor="success.emphasis" caret={pos}>
27
+ {' '}
28
+ Content{' '}
29
+ </PointerBox>
30
+ </Box>
31
+ </Box>
32
+ )
33
+ }
34
+
35
+ function CaretSelector(props) {
36
+ const choices = [
37
+ 'top',
38
+ 'bottom',
39
+ 'left',
40
+ 'right',
41
+ 'left-bottom',
42
+ 'left-top',
43
+ 'right-bottom',
44
+ 'right-top',
45
+ 'top-left',
46
+ 'bottom-left',
47
+ 'top-right',
48
+ 'bottom-right'
49
+ ].map(dir => (
50
+ <label>
51
+ <input
52
+ key={dir}
53
+ type="radio"
54
+ name="caret"
55
+ value={dir}
56
+ checked={dir === props.current}
57
+ onChange={() => props.onChange(dir)}
58
+ />{' '}
59
+ {dir}
60
+ </label>
61
+ ))
62
+
63
+ return (
64
+ <Box display="grid" gridTemplateColumns="repeat(4, auto)" gridGap={3} my={2}>
65
+ {choices}
66
+ </Box>
67
+ )
68
+ }
69
+
70
+ render(<PointerBoxDemo />)
71
+ ```
72
+
73
+ ## System props
74
+
75
+ PointerBox components get `COMMON`, `LAYOUT`, `BORDER`, and `FLEX` system props. Read our [System Props](/system-props) doc page for a full list of available props.
76
+
77
+ ## Component props
78
+
79
+ | Name | Type | Default | Description |
80
+ | :---- | :----- | :-----: | :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
81
+ | caret | String | bottom | Sets the location of the caret. The format is `[edge]-[position on edge]`. For example, `right-top` will position the caret on the top of the right edge of the box. Use `top`, `right`, `bottom`, or `left` to position a caret in the center of that edge. |
@@ -0,0 +1,129 @@
1
+ ---
2
+ title: Popover
3
+ ---
4
+
5
+ Popovers are used to bring attention to specific user interface elements, typically to suggest an action or to guide users through a new experience.
6
+
7
+ Two components make up a popover; the `Popover` component controls the absolute positioning of the popover, and `Popover.Content` renders the inner content of the popover as well as the caret.
8
+
9
+ By default, the popover renders with absolute positioning, meaning it should usually be wrapped in an element with a relative position in order to be positioned properly. To render the popover with relative positioning, use the `relative` property.
10
+
11
+ It can be useful to give the `Popover.Content` element a margin to help align the popover.
12
+
13
+ ## Default Example
14
+
15
+ ```jxs live
16
+ <Box position="relative">
17
+ <Text textAlign="center" display="block">
18
+ <ButtonPrimary>Hello!</ButtonPrimary>
19
+ </Text>
20
+
21
+ <Popover relative open={true} caret="top">
22
+ <Popover.Content sx={{mt: 2}}>
23
+ <Heading sx={{fontSize: 2}}>Popover heading</Heading>
24
+ <Text as="p">Message about this particular piece of UI.</Text>
25
+ <Button>Got it!</Button>
26
+ </Popover.Content>
27
+ </Popover>
28
+ </Box>
29
+ ```
30
+
31
+ ## Caret position
32
+
33
+ `Popover` supports various caret positions, which you can specify via the `caret` property. This demo shows all the valid values for the prop. The default is `top`. Note that the `top-left`, `bottom-left`, `top-right`, and `bottom-right` values modify the horizontal alignment of the popover.
34
+
35
+ ```javascript live noinline
36
+ function PopoverDemo(props) {
37
+ const [pos, setPos] = React.useState('top')
38
+ const [open, setOpen] = React.useState(true)
39
+
40
+ return (
41
+ <Box>
42
+ <Heading as="h3" sx={{fontSize: 3}}>
43
+ Caret Position
44
+ </Heading>
45
+ <CaretSelector current={pos} onChange={setPos} />
46
+ <Heading as="h3" sx={{fontSize: 3}}>
47
+ Popover Visibility
48
+ </Heading>
49
+ <Box my={2}>
50
+ <label>
51
+ <input type="checkbox" value={open} checked={open} onChange={() => setOpen(open => !open)} /> Open
52
+ </label>
53
+ </Box>
54
+
55
+ <Box position="relative" pt={4}>
56
+ <Popover relative open={open} caret={pos}>
57
+ <Popover.Content>
58
+ <Heading sx={{fontSize: 2}}>
59
+ <code>{pos}</code> caret
60
+ </Heading>
61
+ <Text as="p">Message about this particular piece of UI.</Text>
62
+ <Button onClick={() => setOpen(false)}>Got it!</Button>
63
+ </Popover.Content>
64
+ </Popover>
65
+ </Box>
66
+ </Box>
67
+ )
68
+ }
69
+
70
+ function CaretSelector(props) {
71
+ const choices = [
72
+ 'top',
73
+ 'bottom',
74
+ 'left',
75
+ 'right',
76
+ 'left-bottom',
77
+ 'left-top',
78
+ 'right-bottom',
79
+ 'right-top',
80
+ 'top-left',
81
+ 'bottom-left',
82
+ 'top-right',
83
+ 'bottom-right'
84
+ ].map(dir => (
85
+ <label>
86
+ <input
87
+ key={dir}
88
+ type="radio"
89
+ name="caret"
90
+ value={dir}
91
+ checked={dir === props.current}
92
+ onChange={() => props.onChange(dir)}
93
+ />{' '}
94
+ {dir}
95
+ </label>
96
+ ))
97
+
98
+ return (
99
+ <Box display="grid" gridTemplateColumns="repeat(4, auto)" gridGap={3} my={2}>
100
+ {choices}
101
+ </Box>
102
+ )
103
+ }
104
+
105
+ render(<PopoverDemo />)
106
+ ```
107
+
108
+ ## Component props
109
+
110
+ ### Popover
111
+
112
+ | Name | Type | Default | Description |
113
+ | :------- | :---------------- | :-----: | :----------------------------------------------------------------------------- |
114
+ | as | String | 'div' | Sets the HTML tag for the component. |
115
+ | caret | String | 'top' | Controls the position of the caret. See below for the list of caret positions. |
116
+ | open | Boolean | false | Controls the visibility of the popover. |
117
+ | relative | Boolean | false | Set to true to render the popover using relative positioning. |
118
+ | sx | SystemStyleObject | {} | Style to be applied to the component |
119
+
120
+ #### Caret Positions
121
+
122
+ The `caret` prop can be one of the following values: `top`, `bottom`, `left`, `right`, `bottom-left`, `bottom-right`, `top-left`, `top-right`, `left-bottom`, `left-top`, `right-bottom`, or `right-top`.
123
+
124
+ ### Popover.Content
125
+
126
+ | Name | Type | Default | Description |
127
+ | :--- | :---------------- | :-----: | :----------------------------------- |
128
+ | as | String | 'div' | Sets the HTML tag for the component. |
129
+ | sx | SystemStyleObject | {} | Style to be applied to the component |