@primer/components 32.1.0 → 33.0.0-rc.b3e4ccee

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1123) 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 +18 -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 +230 -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 +106 -109
  42. package/dist/browser.esm.js.map +1 -1
  43. package/dist/browser.umd.js +106 -109
  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 +379 -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 +53 -0
  57. package/docs/content/AvatarStack.mdx +57 -0
  58. package/docs/content/BorderBox.md +46 -0
  59. package/docs/content/Box.mdx +96 -0
  60. package/docs/content/BranchName.md +39 -0
  61. package/docs/content/Breadcrumbs.md +68 -0
  62. package/docs/content/Buttons.md +47 -0
  63. package/docs/content/Checkbox.md +118 -0
  64. package/docs/content/CircleBadge.md +36 -0
  65. package/docs/content/CircleOcticon.md +19 -0
  66. package/docs/content/CounterLabel.md +22 -0
  67. package/docs/content/Details.md +102 -0
  68. package/docs/content/Dialog.md +106 -0
  69. package/docs/content/Dialog2.mdx +181 -0
  70. package/docs/content/Dropdown.md +66 -0
  71. package/docs/content/DropdownMenu.mdx +50 -0
  72. package/docs/content/FilterList.md +38 -0
  73. package/docs/content/FilteredSearch.md +33 -0
  74. package/docs/content/Flash.md +36 -0
  75. package/docs/content/Flex.md +58 -0
  76. package/docs/content/FormGroup.md +39 -0
  77. package/docs/content/Grid.md +59 -0
  78. package/docs/content/Header.md +78 -0
  79. package/docs/content/Heading.md +21 -0
  80. package/docs/content/Label.md +49 -0
  81. package/docs/content/LabelGroup.md +22 -0
  82. package/docs/content/Link.md +29 -0
  83. package/docs/content/Overlay.mdx +86 -0
  84. package/docs/content/Pagehead.md +19 -0
  85. package/docs/content/Pagination.md +179 -0
  86. package/docs/content/PointerBox.md +82 -0
  87. package/docs/content/Popover.md +130 -0
  88. package/docs/content/Portal.mdx +79 -0
  89. package/docs/content/Position.md +93 -0
  90. package/docs/content/ProgressBar.mdx +31 -0
  91. package/docs/content/SelectMenu.md +372 -0
  92. package/docs/content/SelectPanel.mdx +67 -0
  93. package/docs/content/SideNav.md +172 -0
  94. package/docs/content/Spinner.mdx +32 -0
  95. package/docs/content/StateLabel.md +28 -0
  96. package/docs/content/StyledOcticon.md +27 -0
  97. package/docs/content/SubNav.md +101 -0
  98. package/docs/content/TabNav.md +43 -0
  99. package/docs/content/Text.md +32 -0
  100. package/docs/content/TextInput.md +42 -0
  101. package/docs/content/TextInputWithTokens.mdx +211 -0
  102. package/docs/content/Timeline.md +149 -0
  103. package/docs/content/Token.mdx +381 -0
  104. package/docs/content/Tooltip.md +33 -0
  105. package/docs/content/Truncate.md +56 -0
  106. package/docs/content/UnderlineNav.md +46 -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/status.mdx +10 -0
  119. package/docs/content/system-props.mdx +37 -0
  120. package/docs/content/theme-reference.md +16 -0
  121. package/docs/content/theming.md +272 -0
  122. package/docs/content/useOnEscapePress.mdx +56 -0
  123. package/docs/content/useOnOutsideClick.mdx +57 -0
  124. package/docs/content/useOpenAndCloseFocus.mdx +49 -0
  125. package/docs/content/useOverlay.mdx +62 -0
  126. package/docs/content/useSafeTimeout.mdx +32 -0
  127. package/docs/gatsby-config.js +30 -0
  128. package/docs/gatsby-node.js +101 -0
  129. package/docs/package-lock.json +20867 -0
  130. package/docs/package.json +36 -0
  131. package/docs/src/@primer/gatsby-theme-doctocat/components/hero.js +21 -0
  132. package/docs/src/@primer/gatsby-theme-doctocat/components/live-preview-wrapper.js +41 -0
  133. package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +73 -0
  134. package/docs/src/@primer/gatsby-theme-doctocat/mdx-components.js +9 -0
  135. package/docs/src/@primer/gatsby-theme-doctocat/nav.yml +137 -0
  136. package/docs/src/@primer/gatsby-theme-doctocat/primer-components-hero.svg +1411 -0
  137. package/docs/src/component-checklist.js +81 -0
  138. package/docs/src/component-statuses.js +74 -0
  139. package/docs/src/props.js +77 -0
  140. package/jest.config.js +13 -0
  141. package/lib/ActionList/Item.js +3 -3
  142. package/lib/ActionList2/Item.js +3 -1
  143. package/lib/ActionList2/List.js +1 -2
  144. package/lib/ActionList2/Selection.js +3 -1
  145. package/lib/Autocomplete/Autocomplete.d.ts +1 -0
  146. package/lib/Autocomplete/AutocompleteInput.d.ts +1 -0
  147. package/lib/Avatar.d.ts +1 -2
  148. package/lib/Avatar.js +1 -1
  149. package/lib/BranchName.d.ts +1 -2
  150. package/lib/BranchName.js +1 -1
  151. package/lib/Button/Button.d.ts +1 -0
  152. package/lib/Button/ButtonClose.d.ts +2 -1
  153. package/lib/Button/ButtonDanger.d.ts +1 -0
  154. package/lib/Button/ButtonInvisible.d.ts +1 -0
  155. package/lib/Button/ButtonOutline.d.ts +1 -0
  156. package/lib/Button/ButtonPrimary.d.ts +1 -0
  157. package/lib/CircleOcticon.d.ts +1 -0
  158. package/lib/Details.d.ts +1 -2
  159. package/lib/Details.js +1 -3
  160. package/lib/Dialog.d.ts +3 -2
  161. package/lib/Dropdown.d.ts +6 -66
  162. package/lib/DropdownMenu/DropdownButton.d.ts +2 -1
  163. package/lib/FilterList.d.ts +1 -0
  164. package/lib/Heading.d.ts +1 -2
  165. package/lib/Heading.js +1 -6
  166. package/lib/Position.d.ts +4 -4
  167. package/lib/ProgressBar.d.ts +16 -11
  168. package/lib/ProgressBar.js +6 -10
  169. package/lib/SelectMenu/SelectMenu.d.ts +10 -4
  170. package/lib/SelectMenu/SelectMenuItem.d.ts +1 -1
  171. package/lib/SelectMenu/SelectMenuModal.d.ts +1 -1
  172. package/lib/Spinner.d.ts +1 -2
  173. package/lib/Spinner.js +1 -3
  174. package/lib/TextInputWithTokens.d.ts +1 -0
  175. package/lib/Token/AvatarToken.d.ts +1 -1
  176. package/lib/Token/IssueLabelToken.d.ts +1 -1
  177. package/lib/Token/Token.d.ts +1 -1
  178. package/lib/__tests__/ActionList.test.d.ts +1 -0
  179. package/lib/__tests__/ActionList.test.js +69 -0
  180. package/lib/__tests__/ActionList.types.test.d.ts +6 -0
  181. package/lib/__tests__/ActionList.types.test.js +69 -0
  182. package/lib/__tests__/ActionList2.test.d.ts +2 -0
  183. package/lib/__tests__/ActionList2.test.js +170 -0
  184. package/lib/__tests__/ActionMenu.test.d.ts +1 -0
  185. package/lib/__tests__/ActionMenu.test.js +151 -0
  186. package/lib/__tests__/AnchoredOverlay.test.d.ts +1 -0
  187. package/lib/__tests__/AnchoredOverlay.test.js +162 -0
  188. package/lib/__tests__/Autocomplete.test.d.ts +1 -0
  189. package/lib/__tests__/Autocomplete.test.js +528 -0
  190. package/lib/__tests__/Avatar.test.d.ts +1 -0
  191. package/lib/__tests__/Avatar.test.js +69 -0
  192. package/lib/__tests__/Avatar.types.test.d.ts +3 -0
  193. package/lib/__tests__/Avatar.types.test.js +31 -0
  194. package/lib/__tests__/AvatarStack.test.d.ts +1 -0
  195. package/lib/__tests__/AvatarStack.test.js +71 -0
  196. package/lib/__tests__/BorderBox.test.d.ts +1 -0
  197. package/lib/__tests__/BorderBox.test.js +58 -0
  198. package/lib/__tests__/Box.test.d.ts +1 -0
  199. package/lib/__tests__/Box.test.js +78 -0
  200. package/lib/__tests__/BranchName.test.d.ts +1 -0
  201. package/lib/__tests__/BranchName.test.js +36 -0
  202. package/lib/__tests__/BranchName.types.test.d.ts +3 -0
  203. package/lib/__tests__/BranchName.types.test.js +28 -0
  204. package/lib/__tests__/Breadcrumbs.test.d.ts +1 -0
  205. package/lib/__tests__/Breadcrumbs.test.js +40 -0
  206. package/lib/__tests__/Breadcrumbs.types.test.d.ts +3 -0
  207. package/lib/__tests__/Breadcrumbs.types.test.js +25 -0
  208. package/lib/__tests__/BreadcrumbsItem.test.d.ts +1 -0
  209. package/lib/__tests__/BreadcrumbsItem.test.js +49 -0
  210. package/lib/__tests__/Button.test.d.ts +1 -0
  211. package/lib/__tests__/Button.test.js +147 -0
  212. package/lib/__tests__/Caret.test.d.ts +1 -0
  213. package/lib/__tests__/Caret.test.js +52 -0
  214. package/lib/__tests__/Checkbox.test.d.ts +2 -0
  215. package/lib/__tests__/Checkbox.test.js +189 -0
  216. package/lib/__tests__/CircleBadge.test.d.ts +1 -0
  217. package/lib/__tests__/CircleBadge.test.js +83 -0
  218. package/lib/__tests__/CircleBadge.types.test.d.ts +3 -0
  219. package/lib/__tests__/CircleBadge.types.test.js +28 -0
  220. package/lib/__tests__/CircleOcticon.test.d.ts +1 -0
  221. package/lib/__tests__/CircleOcticon.test.js +71 -0
  222. package/lib/__tests__/ConfirmationDialog.test.d.ts +1 -0
  223. package/lib/__tests__/ConfirmationDialog.test.js +134 -0
  224. package/lib/__tests__/CounterLabel.test.d.ts +1 -0
  225. package/lib/__tests__/CounterLabel.test.js +58 -0
  226. package/lib/__tests__/CounterLabel.types.test.d.ts +3 -0
  227. package/lib/__tests__/CounterLabel.types.test.js +28 -0
  228. package/lib/__tests__/Details.test.d.ts +1 -0
  229. package/lib/__tests__/Details.test.js +117 -0
  230. package/lib/__tests__/Details.types.test.d.ts +3 -0
  231. package/lib/__tests__/Details.types.test.js +28 -0
  232. package/lib/__tests__/Dialog.test.d.ts +1 -0
  233. package/lib/__tests__/Dialog.test.js +184 -0
  234. package/lib/__tests__/Dialog.types.test.d.ts +3 -0
  235. package/lib/__tests__/Dialog.types.test.js +28 -0
  236. package/lib/__tests__/Dialog2.types.test.d.ts +3 -0
  237. package/lib/__tests__/Dialog2.types.test.js +31 -0
  238. package/lib/__tests__/Dropdown.test.d.ts +1 -0
  239. package/lib/__tests__/Dropdown.test.js +63 -0
  240. package/lib/__tests__/Dropdown.types.test.d.ts +3 -0
  241. package/lib/__tests__/Dropdown.types.test.js +31 -0
  242. package/lib/__tests__/DropdownMenu.test.d.ts +1 -0
  243. package/lib/__tests__/DropdownMenu.test.js +150 -0
  244. package/lib/__tests__/FilterList.test.d.ts +1 -0
  245. package/lib/__tests__/FilterList.test.js +36 -0
  246. package/lib/__tests__/FilterList.types.test.d.ts +3 -0
  247. package/lib/__tests__/FilterList.types.test.js +27 -0
  248. package/lib/__tests__/FilterListItem.test.d.ts +1 -0
  249. package/lib/__tests__/FilterListItem.test.js +46 -0
  250. package/lib/__tests__/FilteredSearch.test.d.ts +1 -0
  251. package/lib/__tests__/FilteredSearch.test.js +36 -0
  252. package/lib/__tests__/FilteredSearch.types.test.d.ts +3 -0
  253. package/lib/__tests__/FilteredSearch.types.test.js +28 -0
  254. package/lib/__tests__/Flash.test.d.ts +1 -0
  255. package/lib/__tests__/Flash.test.js +62 -0
  256. package/lib/__tests__/Flash.types.test.d.ts +3 -0
  257. package/lib/__tests__/Flash.types.test.js +28 -0
  258. package/lib/__tests__/Flex.test.d.ts +1 -0
  259. package/lib/__tests__/Flex.test.js +74 -0
  260. package/lib/__tests__/FormGroup.test.d.ts +1 -0
  261. package/lib/__tests__/FormGroup.test.js +54 -0
  262. package/lib/__tests__/FormGroup.types.test.d.ts +3 -0
  263. package/lib/__tests__/FormGroup.types.test.js +28 -0
  264. package/lib/__tests__/Grid.test.d.ts +1 -0
  265. package/lib/__tests__/Grid.test.js +104 -0
  266. package/lib/__tests__/Header.test.d.ts +1 -0
  267. package/lib/__tests__/Header.test.js +58 -0
  268. package/lib/__tests__/Header.types.test.d.ts +3 -0
  269. package/lib/__tests__/Header.types.test.js +29 -0
  270. package/lib/__tests__/Heading.test.d.ts +1 -0
  271. package/lib/__tests__/Heading.test.js +142 -0
  272. package/lib/__tests__/Heading.types.test.d.ts +3 -0
  273. package/lib/__tests__/Heading.types.test.js +28 -0
  274. package/lib/__tests__/KeyPaths.types.test.d.ts +11 -0
  275. package/lib/__tests__/KeyPaths.types.test.js +10 -0
  276. package/lib/__tests__/Label.test.d.ts +1 -0
  277. package/lib/__tests__/Label.test.js +46 -0
  278. package/lib/__tests__/Label.types.test.d.ts +3 -0
  279. package/lib/__tests__/Label.types.test.js +28 -0
  280. package/lib/__tests__/LabelGroup.test.d.ts +1 -0
  281. package/lib/__tests__/LabelGroup.test.js +38 -0
  282. package/lib/__tests__/LabelGroup.types.test.d.ts +3 -0
  283. package/lib/__tests__/LabelGroup.types.test.js +28 -0
  284. package/lib/__tests__/Link.test.d.ts +1 -0
  285. package/lib/__tests__/Link.test.js +76 -0
  286. package/lib/__tests__/Link.types.test.d.ts +3 -0
  287. package/lib/__tests__/Link.types.test.js +28 -0
  288. package/lib/__tests__/Merge.types.test.d.ts +30 -0
  289. package/lib/__tests__/Merge.types.test.js +27 -0
  290. package/lib/__tests__/NewButton.test.d.ts +1 -0
  291. package/lib/__tests__/NewButton.test.js +95 -0
  292. package/lib/__tests__/Overlay.test.d.ts +1 -0
  293. package/lib/__tests__/Overlay.test.js +145 -0
  294. package/lib/__tests__/Overlay.types.test.d.ts +6 -0
  295. package/lib/__tests__/Overlay.types.test.js +73 -0
  296. package/lib/__tests__/Pagehead.test.d.ts +1 -0
  297. package/lib/__tests__/Pagehead.test.js +37 -0
  298. package/lib/__tests__/Pagehead.types.test.d.ts +3 -0
  299. package/lib/__tests__/Pagehead.types.test.js +28 -0
  300. package/lib/__tests__/Pagination/Pagination.test.d.ts +1 -0
  301. package/lib/__tests__/Pagination/Pagination.test.js +47 -0
  302. package/lib/__tests__/Pagination/PaginationModel.test.d.ts +1 -0
  303. package/lib/__tests__/Pagination/PaginationModel.test.js +186 -0
  304. package/lib/__tests__/Pagination.types.test.d.ts +3 -0
  305. package/lib/__tests__/Pagination.types.test.js +33 -0
  306. package/lib/__tests__/PointerBox.test.d.ts +1 -0
  307. package/lib/__tests__/PointerBox.test.js +46 -0
  308. package/lib/__tests__/Popover.test.d.ts +1 -0
  309. package/lib/__tests__/Popover.test.js +66 -0
  310. package/lib/__tests__/Popover.types.test.d.ts +3 -0
  311. package/lib/__tests__/Popover.types.test.js +27 -0
  312. package/lib/__tests__/Portal.test.d.ts +1 -0
  313. package/lib/__tests__/Portal.test.js +124 -0
  314. package/lib/__tests__/Position.test.d.ts +1 -0
  315. package/lib/__tests__/Position.test.js +143 -0
  316. package/lib/__tests__/ProgressBar.test.d.ts +1 -0
  317. package/lib/__tests__/ProgressBar.test.js +68 -0
  318. package/lib/__tests__/SelectMenu.test.d.ts +1 -0
  319. package/lib/__tests__/SelectMenu.test.js +155 -0
  320. package/lib/__tests__/SelectMenu.types.test.d.ts +3 -0
  321. package/lib/__tests__/SelectMenu.types.test.js +47 -0
  322. package/lib/__tests__/SelectPanel.test.d.ts +1 -0
  323. package/lib/__tests__/SelectPanel.test.js +80 -0
  324. package/lib/__tests__/SelectPanel.types.test.d.ts +3 -0
  325. package/lib/__tests__/SelectPanel.types.test.js +44 -0
  326. package/lib/__tests__/SideNav.test.d.ts +1 -0
  327. package/lib/__tests__/SideNav.test.js +71 -0
  328. package/lib/__tests__/SideNav.types.test.d.ts +3 -0
  329. package/lib/__tests__/SideNav.types.test.js +28 -0
  330. package/lib/__tests__/Spinner.test.d.ts +1 -0
  331. package/lib/__tests__/Spinner.test.js +53 -0
  332. package/lib/__tests__/StateLabel.test.d.ts +1 -0
  333. package/lib/__tests__/StateLabel.test.js +71 -0
  334. package/lib/__tests__/StateLabel.types.test.d.ts +3 -0
  335. package/lib/__tests__/StateLabel.types.test.js +28 -0
  336. package/lib/__tests__/StyledOcticon.test.d.ts +1 -0
  337. package/lib/__tests__/StyledOcticon.test.js +40 -0
  338. package/lib/__tests__/StyledOcticon.types.test.d.ts +3 -0
  339. package/lib/__tests__/StyledOcticon.types.test.js +32 -0
  340. package/lib/__tests__/SubNav.test.d.ts +1 -0
  341. package/lib/__tests__/SubNav.test.js +62 -0
  342. package/lib/__tests__/SubNav.types.test.d.ts +3 -0
  343. package/lib/__tests__/SubNav.types.test.js +27 -0
  344. package/lib/__tests__/SubNavLink.test.d.ts +1 -0
  345. package/lib/__tests__/SubNavLink.test.js +49 -0
  346. package/lib/__tests__/TabNav.test.d.ts +1 -0
  347. package/lib/__tests__/TabNav.test.js +49 -0
  348. package/lib/__tests__/TabNav.types.test.d.ts +3 -0
  349. package/lib/__tests__/TabNav.types.test.js +25 -0
  350. package/lib/__tests__/Text.test.d.ts +1 -0
  351. package/lib/__tests__/Text.test.js +105 -0
  352. package/lib/__tests__/TextInput.test.d.ts +1 -0
  353. package/lib/__tests__/TextInput.test.js +78 -0
  354. package/lib/__tests__/TextInputWithTokens.test.d.ts +1 -0
  355. package/lib/__tests__/TextInputWithTokens.test.js +572 -0
  356. package/lib/__tests__/ThemeProvider.test.d.ts +1 -0
  357. package/lib/__tests__/ThemeProvider.test.js +444 -0
  358. package/lib/__tests__/Timeline.test.d.ts +1 -0
  359. package/lib/__tests__/Timeline.test.js +75 -0
  360. package/lib/__tests__/Timeline.types.test.d.ts +3 -0
  361. package/lib/__tests__/Timeline.types.test.js +31 -0
  362. package/lib/__tests__/Token.test.d.ts +1 -0
  363. package/lib/__tests__/Token.test.js +180 -0
  364. package/lib/__tests__/Tooltip.test.d.ts +1 -0
  365. package/lib/__tests__/Tooltip.test.js +69 -0
  366. package/lib/__tests__/Tooltip.types.test.d.ts +3 -0
  367. package/lib/__tests__/Tooltip.types.test.js +28 -0
  368. package/lib/__tests__/Truncate.test.d.ts +1 -0
  369. package/lib/__tests__/Truncate.test.js +63 -0
  370. package/lib/__tests__/Truncate.types.test.d.ts +3 -0
  371. package/lib/__tests__/Truncate.types.test.js +31 -0
  372. package/lib/__tests__/UnderlineNav.test.d.ts +1 -0
  373. package/lib/__tests__/UnderlineNav.test.js +72 -0
  374. package/lib/__tests__/UnderlineNav.types.test.d.ts +3 -0
  375. package/lib/__tests__/UnderlineNav.types.test.js +25 -0
  376. package/lib/__tests__/UnderlineNavLink.test.d.ts +1 -0
  377. package/lib/__tests__/UnderlineNavLink.test.js +51 -0
  378. package/lib/__tests__/behaviors/anchoredPosition.test.d.ts +1 -0
  379. package/lib/__tests__/behaviors/anchoredPosition.test.js +390 -0
  380. package/lib/__tests__/behaviors/focusTrap.test.d.ts +1 -0
  381. package/lib/__tests__/behaviors/focusTrap.test.js +234 -0
  382. package/lib/__tests__/behaviors/focusZone.test.d.ts +1 -0
  383. package/lib/__tests__/behaviors/focusZone.test.js +570 -0
  384. package/lib/__tests__/behaviors/iterateFocusableElements.test.d.ts +1 -0
  385. package/lib/__tests__/behaviors/iterateFocusableElements.test.js +55 -0
  386. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +1 -0
  387. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.js +226 -0
  388. package/lib/__tests__/filterObject.test.d.ts +1 -0
  389. package/lib/__tests__/filterObject.test.js +30 -0
  390. package/lib/__tests__/hooks/useAnchoredPosition.test.d.ts +1 -0
  391. package/lib/__tests__/hooks/useAnchoredPosition.test.js +54 -0
  392. package/lib/__tests__/hooks/useOnEscapePress.test.d.ts +1 -0
  393. package/lib/__tests__/hooks/useOnEscapePress.test.js +32 -0
  394. package/lib/__tests__/hooks/useOnOutsideClick.test.d.ts +1 -0
  395. package/lib/__tests__/hooks/useOnOutsideClick.test.js +87 -0
  396. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +1 -0
  397. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.js +60 -0
  398. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +1 -0
  399. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.js +45 -0
  400. package/lib/__tests__/theme.test.d.ts +1 -0
  401. package/lib/__tests__/theme.test.js +36 -0
  402. package/lib/__tests__/themeGet.test.d.ts +1 -0
  403. package/lib/__tests__/themeGet.test.js +25 -0
  404. package/lib/__tests__/themePreval.test.d.ts +1 -0
  405. package/lib/__tests__/themePreval.test.js +14 -0
  406. package/lib/__tests__/useSafeTimeout.test.d.ts +1 -0
  407. package/lib/__tests__/useSafeTimeout.test.js +45 -0
  408. package/lib/__tests__/utils/createSlots.test.d.ts +1 -0
  409. package/lib/__tests__/utils/createSlots.test.js +75 -0
  410. package/lib/stories/ActionList.stories.js +454 -0
  411. package/lib/stories/ActionList2.stories.js +923 -0
  412. package/lib/stories/ActionMenu.stories.js +348 -0
  413. package/lib/stories/AnchoredOverlay.stories.js +127 -0
  414. package/lib/stories/Autocomplete.stories.js +619 -0
  415. package/lib/stories/AvatarStack.stories.js +49 -0
  416. package/lib/stories/Button.stories.js +125 -0
  417. package/lib/stories/Checkbox.stories.js +227 -0
  418. package/lib/stories/ConfirmationDialog.stories.js +119 -0
  419. package/lib/stories/Dialog.stories.js +269 -0
  420. package/lib/stories/DropdownMenu.stories.js +122 -0
  421. package/lib/stories/IssueLabelToken.stories.js +165 -0
  422. package/lib/stories/NewButton.stories.js +230 -0
  423. package/lib/stories/Overlay.stories.js +204 -0
  424. package/lib/stories/Portal.stories.js +104 -0
  425. package/lib/stories/ProfileToken.stories.js +162 -0
  426. package/lib/stories/SelectPanel.stories.js +399 -0
  427. package/lib/stories/TextInput.stories.js +144 -0
  428. package/lib/stories/TextInputWithTokens.stories.js +252 -0
  429. package/lib/stories/ThemeProvider.stories.js +102 -0
  430. package/lib/stories/Token.stories.js +176 -0
  431. package/lib/stories/useAnchoredPosition.stories.js +351 -0
  432. package/lib/stories/useFocusTrap.stories.js +360 -0
  433. package/lib/stories/useFocusZone.stories.js +607 -0
  434. package/lib/utils/testing.d.ts +1 -0
  435. package/lib/utils/testing.js +29 -0
  436. package/lib-esm/ActionList/Item.js +3 -3
  437. package/lib-esm/ActionList2/Item.js +3 -1
  438. package/lib-esm/ActionList2/List.js +1 -2
  439. package/lib-esm/ActionList2/Selection.js +3 -1
  440. package/lib-esm/Autocomplete/Autocomplete.d.ts +1 -0
  441. package/lib-esm/Autocomplete/AutocompleteInput.d.ts +1 -0
  442. package/lib-esm/Avatar.d.ts +1 -2
  443. package/lib-esm/Avatar.js +2 -2
  444. package/lib-esm/BranchName.d.ts +1 -2
  445. package/lib-esm/BranchName.js +2 -2
  446. package/lib-esm/Button/Button.d.ts +1 -0
  447. package/lib-esm/Button/ButtonClose.d.ts +2 -1
  448. package/lib-esm/Button/ButtonDanger.d.ts +1 -0
  449. package/lib-esm/Button/ButtonInvisible.d.ts +1 -0
  450. package/lib-esm/Button/ButtonOutline.d.ts +1 -0
  451. package/lib-esm/Button/ButtonPrimary.d.ts +1 -0
  452. package/lib-esm/CircleOcticon.d.ts +1 -0
  453. package/lib-esm/Details.d.ts +1 -2
  454. package/lib-esm/Details.js +1 -2
  455. package/lib-esm/Dialog.d.ts +3 -2
  456. package/lib-esm/Dropdown.d.ts +6 -66
  457. package/lib-esm/DropdownMenu/DropdownButton.d.ts +2 -1
  458. package/lib-esm/FilterList.d.ts +1 -0
  459. package/lib-esm/Heading.d.ts +1 -2
  460. package/lib-esm/Heading.js +2 -6
  461. package/lib-esm/Position.d.ts +4 -4
  462. package/lib-esm/ProgressBar.d.ts +16 -11
  463. package/lib-esm/ProgressBar.js +7 -11
  464. package/lib-esm/SelectMenu/SelectMenu.d.ts +10 -4
  465. package/lib-esm/SelectMenu/SelectMenuItem.d.ts +1 -1
  466. package/lib-esm/SelectMenu/SelectMenuModal.d.ts +1 -1
  467. package/lib-esm/Spinner.d.ts +1 -2
  468. package/lib-esm/Spinner.js +1 -2
  469. package/lib-esm/TextInputWithTokens.d.ts +1 -0
  470. package/lib-esm/Token/AvatarToken.d.ts +1 -1
  471. package/lib-esm/Token/IssueLabelToken.d.ts +1 -1
  472. package/lib-esm/Token/Token.d.ts +1 -1
  473. package/lib-esm/__tests__/ActionList.test.d.ts +1 -0
  474. package/lib-esm/__tests__/ActionList.test.js +57 -0
  475. package/lib-esm/__tests__/ActionList.types.test.d.ts +6 -0
  476. package/lib-esm/__tests__/ActionList.types.test.js +45 -0
  477. package/lib-esm/__tests__/ActionList2.test.d.ts +2 -0
  478. package/lib-esm/__tests__/ActionList2.test.js +144 -0
  479. package/lib-esm/__tests__/ActionMenu.test.d.ts +1 -0
  480. package/lib-esm/__tests__/ActionMenu.test.js +139 -0
  481. package/lib-esm/__tests__/AnchoredOverlay.test.d.ts +1 -0
  482. package/lib-esm/__tests__/AnchoredOverlay.test.js +136 -0
  483. package/lib-esm/__tests__/Autocomplete.test.d.ts +1 -0
  484. package/lib-esm/__tests__/Autocomplete.test.js +494 -0
  485. package/lib-esm/__tests__/Avatar.test.d.ts +1 -0
  486. package/lib-esm/__tests__/Avatar.test.js +58 -0
  487. package/lib-esm/__tests__/Avatar.types.test.d.ts +3 -0
  488. package/lib-esm/__tests__/Avatar.types.test.js +16 -0
  489. package/lib-esm/__tests__/AvatarStack.test.d.ts +1 -0
  490. package/lib-esm/__tests__/AvatarStack.test.js +58 -0
  491. package/lib-esm/__tests__/BorderBox.test.d.ts +1 -0
  492. package/lib-esm/__tests__/BorderBox.test.js +47 -0
  493. package/lib-esm/__tests__/Box.test.d.ts +1 -0
  494. package/lib-esm/__tests__/Box.test.js +67 -0
  495. package/lib-esm/__tests__/BranchName.test.d.ts +1 -0
  496. package/lib-esm/__tests__/BranchName.test.js +26 -0
  497. package/lib-esm/__tests__/BranchName.types.test.d.ts +3 -0
  498. package/lib-esm/__tests__/BranchName.types.test.js +13 -0
  499. package/lib-esm/__tests__/Breadcrumbs.test.d.ts +1 -0
  500. package/lib-esm/__tests__/Breadcrumbs.test.js +30 -0
  501. package/lib-esm/__tests__/Breadcrumbs.types.test.d.ts +3 -0
  502. package/lib-esm/__tests__/Breadcrumbs.types.test.js +12 -0
  503. package/lib-esm/__tests__/BreadcrumbsItem.test.d.ts +1 -0
  504. package/lib-esm/__tests__/BreadcrumbsItem.test.js +39 -0
  505. package/lib-esm/__tests__/Button.test.d.ts +1 -0
  506. package/lib-esm/__tests__/Button.test.js +137 -0
  507. package/lib-esm/__tests__/Caret.test.d.ts +1 -0
  508. package/lib-esm/__tests__/Caret.test.js +42 -0
  509. package/lib-esm/__tests__/Checkbox.test.d.ts +2 -0
  510. package/lib-esm/__tests__/Checkbox.test.js +169 -0
  511. package/lib-esm/__tests__/CircleBadge.test.d.ts +1 -0
  512. package/lib-esm/__tests__/CircleBadge.test.js +70 -0
  513. package/lib-esm/__tests__/CircleBadge.types.test.d.ts +3 -0
  514. package/lib-esm/__tests__/CircleBadge.types.test.js +13 -0
  515. package/lib-esm/__tests__/CircleOcticon.test.d.ts +1 -0
  516. package/lib-esm/__tests__/CircleOcticon.test.js +59 -0
  517. package/lib-esm/__tests__/ConfirmationDialog.test.d.ts +1 -0
  518. package/lib-esm/__tests__/ConfirmationDialog.test.js +113 -0
  519. package/lib-esm/__tests__/CounterLabel.test.d.ts +1 -0
  520. package/lib-esm/__tests__/CounterLabel.test.js +47 -0
  521. package/lib-esm/__tests__/CounterLabel.types.test.d.ts +3 -0
  522. package/lib-esm/__tests__/CounterLabel.types.test.js +13 -0
  523. package/lib-esm/__tests__/Details.test.d.ts +1 -0
  524. package/lib-esm/__tests__/Details.test.js +107 -0
  525. package/lib-esm/__tests__/Details.types.test.d.ts +3 -0
  526. package/lib-esm/__tests__/Details.types.test.js +13 -0
  527. package/lib-esm/__tests__/Dialog.test.d.ts +1 -0
  528. package/lib-esm/__tests__/Dialog.test.js +171 -0
  529. package/lib-esm/__tests__/Dialog.types.test.d.ts +3 -0
  530. package/lib-esm/__tests__/Dialog.types.test.js +13 -0
  531. package/lib-esm/__tests__/Dialog2.types.test.d.ts +3 -0
  532. package/lib-esm/__tests__/Dialog2.types.test.js +16 -0
  533. package/lib-esm/__tests__/Dropdown.test.d.ts +1 -0
  534. package/lib-esm/__tests__/Dropdown.test.js +53 -0
  535. package/lib-esm/__tests__/Dropdown.types.test.d.ts +3 -0
  536. package/lib-esm/__tests__/Dropdown.types.test.js +17 -0
  537. package/lib-esm/__tests__/DropdownMenu.test.d.ts +1 -0
  538. package/lib-esm/__tests__/DropdownMenu.test.js +137 -0
  539. package/lib-esm/__tests__/FilterList.test.d.ts +1 -0
  540. package/lib-esm/__tests__/FilterList.test.js +26 -0
  541. package/lib-esm/__tests__/FilterList.types.test.d.ts +3 -0
  542. package/lib-esm/__tests__/FilterList.types.test.js +13 -0
  543. package/lib-esm/__tests__/FilterListItem.test.d.ts +1 -0
  544. package/lib-esm/__tests__/FilterListItem.test.js +36 -0
  545. package/lib-esm/__tests__/FilteredSearch.test.d.ts +1 -0
  546. package/lib-esm/__tests__/FilteredSearch.test.js +26 -0
  547. package/lib-esm/__tests__/FilteredSearch.types.test.d.ts +3 -0
  548. package/lib-esm/__tests__/FilteredSearch.types.test.js +13 -0
  549. package/lib-esm/__tests__/Flash.test.d.ts +1 -0
  550. package/lib-esm/__tests__/Flash.test.js +51 -0
  551. package/lib-esm/__tests__/Flash.types.test.d.ts +3 -0
  552. package/lib-esm/__tests__/Flash.types.test.js +13 -0
  553. package/lib-esm/__tests__/Flex.test.d.ts +1 -0
  554. package/lib-esm/__tests__/Flex.test.js +64 -0
  555. package/lib-esm/__tests__/FormGroup.test.d.ts +1 -0
  556. package/lib-esm/__tests__/FormGroup.test.js +44 -0
  557. package/lib-esm/__tests__/FormGroup.types.test.d.ts +3 -0
  558. package/lib-esm/__tests__/FormGroup.types.test.js +13 -0
  559. package/lib-esm/__tests__/Grid.test.d.ts +1 -0
  560. package/lib-esm/__tests__/Grid.test.js +94 -0
  561. package/lib-esm/__tests__/Header.test.d.ts +1 -0
  562. package/lib-esm/__tests__/Header.test.js +48 -0
  563. package/lib-esm/__tests__/Header.types.test.d.ts +3 -0
  564. package/lib-esm/__tests__/Header.types.test.js +15 -0
  565. package/lib-esm/__tests__/Heading.test.d.ts +1 -0
  566. package/lib-esm/__tests__/Heading.test.js +131 -0
  567. package/lib-esm/__tests__/Heading.types.test.d.ts +3 -0
  568. package/lib-esm/__tests__/Heading.types.test.js +13 -0
  569. package/lib-esm/__tests__/KeyPaths.types.test.d.ts +11 -0
  570. package/lib-esm/__tests__/KeyPaths.types.test.js +3 -0
  571. package/lib-esm/__tests__/Label.test.d.ts +1 -0
  572. package/lib-esm/__tests__/Label.test.js +36 -0
  573. package/lib-esm/__tests__/Label.types.test.d.ts +3 -0
  574. package/lib-esm/__tests__/Label.types.test.js +13 -0
  575. package/lib-esm/__tests__/LabelGroup.test.d.ts +1 -0
  576. package/lib-esm/__tests__/LabelGroup.test.js +26 -0
  577. package/lib-esm/__tests__/LabelGroup.types.test.d.ts +3 -0
  578. package/lib-esm/__tests__/LabelGroup.types.test.js +13 -0
  579. package/lib-esm/__tests__/Link.test.d.ts +1 -0
  580. package/lib-esm/__tests__/Link.test.js +66 -0
  581. package/lib-esm/__tests__/Link.types.test.d.ts +3 -0
  582. package/lib-esm/__tests__/Link.types.test.js +13 -0
  583. package/lib-esm/__tests__/Merge.types.test.d.ts +30 -0
  584. package/lib-esm/__tests__/Merge.types.test.js +14 -0
  585. package/lib-esm/__tests__/NewButton.test.d.ts +1 -0
  586. package/lib-esm/__tests__/NewButton.test.js +84 -0
  587. package/lib-esm/__tests__/Overlay.test.d.ts +1 -0
  588. package/lib-esm/__tests__/Overlay.test.js +123 -0
  589. package/lib-esm/__tests__/Overlay.types.test.d.ts +6 -0
  590. package/lib-esm/__tests__/Overlay.types.test.js +49 -0
  591. package/lib-esm/__tests__/Pagehead.test.d.ts +1 -0
  592. package/lib-esm/__tests__/Pagehead.test.js +26 -0
  593. package/lib-esm/__tests__/Pagehead.types.test.d.ts +3 -0
  594. package/lib-esm/__tests__/Pagehead.types.test.js +13 -0
  595. package/lib-esm/__tests__/Pagination/Pagination.test.d.ts +1 -0
  596. package/lib-esm/__tests__/Pagination/Pagination.test.js +35 -0
  597. package/lib-esm/__tests__/Pagination/PaginationModel.test.d.ts +1 -0
  598. package/lib-esm/__tests__/Pagination/PaginationModel.test.js +182 -0
  599. package/lib-esm/__tests__/Pagination.types.test.d.ts +3 -0
  600. package/lib-esm/__tests__/Pagination.types.test.js +18 -0
  601. package/lib-esm/__tests__/PointerBox.test.d.ts +1 -0
  602. package/lib-esm/__tests__/PointerBox.test.js +36 -0
  603. package/lib-esm/__tests__/Popover.test.d.ts +1 -0
  604. package/lib-esm/__tests__/Popover.test.js +53 -0
  605. package/lib-esm/__tests__/Popover.types.test.d.ts +3 -0
  606. package/lib-esm/__tests__/Popover.types.test.js +13 -0
  607. package/lib-esm/__tests__/Portal.test.d.ts +1 -0
  608. package/lib-esm/__tests__/Portal.test.js +104 -0
  609. package/lib-esm/__tests__/Position.test.d.ts +1 -0
  610. package/lib-esm/__tests__/Position.test.js +133 -0
  611. package/lib-esm/__tests__/ProgressBar.test.d.ts +1 -0
  612. package/lib-esm/__tests__/ProgressBar.test.js +58 -0
  613. package/lib-esm/__tests__/SelectMenu.test.d.ts +1 -0
  614. package/lib-esm/__tests__/SelectMenu.test.js +145 -0
  615. package/lib-esm/__tests__/SelectMenu.types.test.d.ts +3 -0
  616. package/lib-esm/__tests__/SelectMenu.types.test.js +33 -0
  617. package/lib-esm/__tests__/SelectPanel.test.d.ts +1 -0
  618. package/lib-esm/__tests__/SelectPanel.test.js +65 -0
  619. package/lib-esm/__tests__/SelectPanel.types.test.d.ts +3 -0
  620. package/lib-esm/__tests__/SelectPanel.types.test.js +29 -0
  621. package/lib-esm/__tests__/SideNav.test.d.ts +1 -0
  622. package/lib-esm/__tests__/SideNav.test.js +60 -0
  623. package/lib-esm/__tests__/SideNav.types.test.d.ts +3 -0
  624. package/lib-esm/__tests__/SideNav.types.test.js +13 -0
  625. package/lib-esm/__tests__/Spinner.test.d.ts +1 -0
  626. package/lib-esm/__tests__/Spinner.test.js +43 -0
  627. package/lib-esm/__tests__/StateLabel.test.d.ts +1 -0
  628. package/lib-esm/__tests__/StateLabel.test.js +61 -0
  629. package/lib-esm/__tests__/StateLabel.types.test.d.ts +3 -0
  630. package/lib-esm/__tests__/StateLabel.types.test.js +13 -0
  631. package/lib-esm/__tests__/StyledOcticon.test.d.ts +1 -0
  632. package/lib-esm/__tests__/StyledOcticon.test.js +29 -0
  633. package/lib-esm/__tests__/StyledOcticon.types.test.d.ts +3 -0
  634. package/lib-esm/__tests__/StyledOcticon.types.test.js +16 -0
  635. package/lib-esm/__tests__/SubNav.test.d.ts +1 -0
  636. package/lib-esm/__tests__/SubNav.test.js +50 -0
  637. package/lib-esm/__tests__/SubNav.types.test.d.ts +3 -0
  638. package/lib-esm/__tests__/SubNav.types.test.js +14 -0
  639. package/lib-esm/__tests__/SubNavLink.test.d.ts +1 -0
  640. package/lib-esm/__tests__/SubNavLink.test.js +39 -0
  641. package/lib-esm/__tests__/TabNav.test.d.ts +1 -0
  642. package/lib-esm/__tests__/TabNav.test.js +39 -0
  643. package/lib-esm/__tests__/TabNav.types.test.d.ts +3 -0
  644. package/lib-esm/__tests__/TabNav.types.test.js +12 -0
  645. package/lib-esm/__tests__/Text.test.d.ts +1 -0
  646. package/lib-esm/__tests__/Text.test.js +93 -0
  647. package/lib-esm/__tests__/TextInput.test.d.ts +1 -0
  648. package/lib-esm/__tests__/TextInput.test.js +68 -0
  649. package/lib-esm/__tests__/TextInputWithTokens.test.d.ts +1 -0
  650. package/lib-esm/__tests__/TextInputWithTokens.test.js +511 -0
  651. package/lib-esm/__tests__/ThemeProvider.test.d.ts +1 -0
  652. package/lib-esm/__tests__/ThemeProvider.test.js +408 -0
  653. package/lib-esm/__tests__/Timeline.test.d.ts +1 -0
  654. package/lib-esm/__tests__/Timeline.test.js +65 -0
  655. package/lib-esm/__tests__/Timeline.types.test.d.ts +3 -0
  656. package/lib-esm/__tests__/Timeline.types.test.js +18 -0
  657. package/lib-esm/__tests__/Token.test.d.ts +1 -0
  658. package/lib-esm/__tests__/Token.test.js +166 -0
  659. package/lib-esm/__tests__/Tooltip.test.d.ts +1 -0
  660. package/lib-esm/__tests__/Tooltip.test.js +59 -0
  661. package/lib-esm/__tests__/Tooltip.types.test.d.ts +3 -0
  662. package/lib-esm/__tests__/Tooltip.types.test.js +13 -0
  663. package/lib-esm/__tests__/Truncate.test.d.ts +1 -0
  664. package/lib-esm/__tests__/Truncate.test.js +53 -0
  665. package/lib-esm/__tests__/Truncate.types.test.d.ts +3 -0
  666. package/lib-esm/__tests__/Truncate.types.test.js +16 -0
  667. package/lib-esm/__tests__/UnderlineNav.test.d.ts +1 -0
  668. package/lib-esm/__tests__/UnderlineNav.test.js +60 -0
  669. package/lib-esm/__tests__/UnderlineNav.types.test.d.ts +3 -0
  670. package/lib-esm/__tests__/UnderlineNav.types.test.js +12 -0
  671. package/lib-esm/__tests__/UnderlineNavLink.test.d.ts +1 -0
  672. package/lib-esm/__tests__/UnderlineNavLink.test.js +41 -0
  673. package/lib-esm/__tests__/behaviors/anchoredPosition.test.d.ts +1 -0
  674. package/lib-esm/__tests__/behaviors/anchoredPosition.test.js +388 -0
  675. package/lib-esm/__tests__/behaviors/focusTrap.test.d.ts +1 -0
  676. package/lib-esm/__tests__/behaviors/focusTrap.test.js +227 -0
  677. package/lib-esm/__tests__/behaviors/focusZone.test.d.ts +1 -0
  678. package/lib-esm/__tests__/behaviors/focusZone.test.js +487 -0
  679. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.d.ts +1 -0
  680. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.js +48 -0
  681. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +1 -0
  682. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.js +224 -0
  683. package/lib-esm/__tests__/filterObject.test.d.ts +1 -0
  684. package/lib-esm/__tests__/filterObject.test.js +27 -0
  685. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.d.ts +1 -0
  686. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.js +46 -0
  687. package/lib-esm/__tests__/hooks/useOnEscapePress.test.d.ts +1 -0
  688. package/lib-esm/__tests__/hooks/useOnEscapePress.test.js +23 -0
  689. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.d.ts +1 -0
  690. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.js +68 -0
  691. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +1 -0
  692. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.js +52 -0
  693. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +1 -0
  694. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.js +36 -0
  695. package/lib-esm/__tests__/theme.test.d.ts +1 -0
  696. package/lib-esm/__tests__/theme.test.js +33 -0
  697. package/lib-esm/__tests__/themeGet.test.d.ts +1 -0
  698. package/lib-esm/__tests__/themeGet.test.js +22 -0
  699. package/lib-esm/__tests__/themePreval.test.d.ts +1 -0
  700. package/lib-esm/__tests__/themePreval.test.js +7 -0
  701. package/lib-esm/__tests__/useSafeTimeout.test.d.ts +1 -0
  702. package/lib-esm/__tests__/useSafeTimeout.test.js +39 -0
  703. package/lib-esm/__tests__/utils/createSlots.test.d.ts +1 -0
  704. package/lib-esm/__tests__/utils/createSlots.test.js +67 -0
  705. package/lib-esm/stories/ActionList.stories.js +395 -0
  706. package/lib-esm/stories/ActionList2.stories.js +811 -0
  707. package/lib-esm/stories/ActionMenu.stories.js +303 -0
  708. package/lib-esm/stories/AnchoredOverlay.stories.js +101 -0
  709. package/lib-esm/stories/Autocomplete.stories.js +560 -0
  710. package/lib-esm/stories/AvatarStack.stories.js +32 -0
  711. package/lib-esm/stories/Button.stories.js +86 -0
  712. package/lib-esm/stories/Checkbox.stories.js +197 -0
  713. package/lib-esm/stories/ConfirmationDialog.stories.js +94 -0
  714. package/lib-esm/stories/Dialog.stories.js +244 -0
  715. package/lib-esm/stories/DropdownMenu.stories.js +94 -0
  716. package/lib-esm/stories/IssueLabelToken.stories.js +139 -0
  717. package/lib-esm/stories/NewButton.stories.js +178 -0
  718. package/lib-esm/stories/Overlay.stories.js +173 -0
  719. package/lib-esm/stories/Portal.stories.js +68 -0
  720. package/lib-esm/stories/ProfileToken.stories.js +136 -0
  721. package/lib-esm/stories/SelectPanel.stories.js +334 -0
  722. package/lib-esm/stories/TextInput.stories.js +117 -0
  723. package/lib-esm/stories/TextInputWithTokens.stories.js +210 -0
  724. package/lib-esm/stories/ThemeProvider.stories.js +83 -0
  725. package/lib-esm/stories/Token.stories.js +146 -0
  726. package/lib-esm/stories/useAnchoredPosition.stories.js +313 -0
  727. package/lib-esm/stories/useFocusTrap.stories.js +313 -0
  728. package/lib-esm/stories/useFocusZone.stories.js +562 -0
  729. package/lib-esm/utils/testing.d.ts +1 -0
  730. package/lib-esm/utils/testing.js +24 -0
  731. package/migrating.md +250 -0
  732. package/now.json +17 -0
  733. package/package-lock.json +66668 -0
  734. package/package.json +2 -2
  735. package/rollup.config.js +36 -0
  736. package/script/build +21 -0
  737. package/script/build-storybook +10 -0
  738. package/script/setup +12 -0
  739. package/src/ActionList/Divider.tsx +25 -0
  740. package/src/ActionList/Group.tsx +45 -0
  741. package/src/ActionList/Header.tsx +74 -0
  742. package/src/ActionList/Item.tsx +481 -0
  743. package/src/ActionList/List.tsx +258 -0
  744. package/src/ActionList/index.ts +21 -0
  745. package/src/ActionList2/Description.tsx +52 -0
  746. package/src/ActionList2/Divider.tsx +24 -0
  747. package/src/ActionList2/Group.tsx +103 -0
  748. package/src/ActionList2/Item.tsx +247 -0
  749. package/src/ActionList2/LinkItem.tsx +49 -0
  750. package/src/ActionList2/List.tsx +50 -0
  751. package/src/ActionList2/Selection.tsx +61 -0
  752. package/src/ActionList2/Visuals.tsx +76 -0
  753. package/src/ActionList2/index.ts +39 -0
  754. package/src/ActionMenu.tsx +106 -0
  755. package/src/AnchoredOverlay/AnchoredOverlay.tsx +191 -0
  756. package/src/AnchoredOverlay/index.ts +2 -0
  757. package/src/Autocomplete/Autocomplete.tsx +103 -0
  758. package/src/Autocomplete/AutocompleteContext.tsx +19 -0
  759. package/src/Autocomplete/AutocompleteInput.tsx +179 -0
  760. package/src/Autocomplete/AutocompleteMenu.tsx +341 -0
  761. package/src/Autocomplete/AutocompleteOverlay.tsx +68 -0
  762. package/src/Autocomplete/index.ts +2 -0
  763. package/src/Avatar.tsx +44 -0
  764. package/src/AvatarPair.tsx +35 -0
  765. package/src/AvatarStack.tsx +159 -0
  766. package/src/BaseStyles.tsx +53 -0
  767. package/src/BorderBox.tsx +18 -0
  768. package/src/Box.tsx +54 -0
  769. package/src/BranchName.tsx +19 -0
  770. package/src/Breadcrumbs.tsx +101 -0
  771. package/src/Button/Button.tsx +39 -0
  772. package/src/Button/ButtonBase.tsx +39 -0
  773. package/src/Button/ButtonClose.tsx +36 -0
  774. package/src/Button/ButtonDanger.tsx +42 -0
  775. package/src/Button/ButtonGroup.tsx +55 -0
  776. package/src/Button/ButtonInvisible.tsx +31 -0
  777. package/src/Button/ButtonOutline.tsx +42 -0
  778. package/src/Button/ButtonPrimary.tsx +40 -0
  779. package/src/Button/ButtonStyles.tsx +36 -0
  780. package/src/Button/ButtonTableList.tsx +45 -0
  781. package/src/Button/index.ts +16 -0
  782. package/src/Caret.tsx +133 -0
  783. package/src/Checkbox.tsx +75 -0
  784. package/src/CircleBadge.tsx +53 -0
  785. package/src/CircleOcticon.tsx +37 -0
  786. package/src/CounterLabel.tsx +50 -0
  787. package/src/Details.tsx +19 -0
  788. package/src/Dialog/ConfirmationDialog.tsx +184 -0
  789. package/src/Dialog/Dialog.tsx +444 -0
  790. package/src/Dialog.tsx +145 -0
  791. package/src/Dropdown.tsx +154 -0
  792. package/src/DropdownMenu/DropdownButton.tsx +15 -0
  793. package/src/DropdownMenu/DropdownMenu.tsx +115 -0
  794. package/src/DropdownMenu/index.ts +4 -0
  795. package/src/DropdownStyles.ts +128 -0
  796. package/src/FilterList.tsx +75 -0
  797. package/src/FilteredActionList/FilteredActionList.tsx +142 -0
  798. package/src/FilteredActionList/index.ts +2 -0
  799. package/src/FilteredSearch.tsx +27 -0
  800. package/src/Flash.tsx +75 -0
  801. package/src/Flex.tsx +15 -0
  802. package/src/FormGroup.tsx +24 -0
  803. package/src/Grid.tsx +15 -0
  804. package/src/Header.tsx +74 -0
  805. package/src/Heading.tsx +14 -0
  806. package/src/Label.tsx +72 -0
  807. package/src/LabelGroup.tsx +17 -0
  808. package/src/Link.tsx +42 -0
  809. package/src/NewButton/button-counter.tsx +15 -0
  810. package/src/NewButton/button.tsx +283 -0
  811. package/src/NewButton/index.ts +10 -0
  812. package/src/NewButton/types.ts +36 -0
  813. package/src/Overlay.tsx +203 -0
  814. package/src/Pagehead.tsx +16 -0
  815. package/src/Pagination/Pagination.tsx +212 -0
  816. package/src/Pagination/index.ts +4 -0
  817. package/src/Pagination/model.tsx +187 -0
  818. package/src/PointerBox.tsx +31 -0
  819. package/src/Popover.tsx +225 -0
  820. package/src/Portal/Portal.tsx +97 -0
  821. package/src/Portal/index.ts +5 -0
  822. package/src/Position.tsx +63 -0
  823. package/src/ProgressBar.tsx +53 -0
  824. package/src/SelectMenu/SelectMenu.tsx +123 -0
  825. package/src/SelectMenu/SelectMenuContext.tsx +9 -0
  826. package/src/SelectMenu/SelectMenuDivider.tsx +24 -0
  827. package/src/SelectMenu/SelectMenuFilter.tsx +50 -0
  828. package/src/SelectMenu/SelectMenuFooter.tsx +27 -0
  829. package/src/SelectMenu/SelectMenuHeader.tsx +48 -0
  830. package/src/SelectMenu/SelectMenuItem.tsx +136 -0
  831. package/src/SelectMenu/SelectMenuList.tsx +41 -0
  832. package/src/SelectMenu/SelectMenuLoadingAnimation.tsx +25 -0
  833. package/src/SelectMenu/SelectMenuModal.tsx +119 -0
  834. package/src/SelectMenu/SelectMenuTab.tsx +87 -0
  835. package/src/SelectMenu/SelectMenuTabPanel.tsx +29 -0
  836. package/src/SelectMenu/SelectMenuTabs.tsx +43 -0
  837. package/src/SelectMenu/hooks/useKeyboardNav.js +90 -0
  838. package/src/SelectMenu/index.ts +15 -0
  839. package/src/SelectPanel/SelectPanel.tsx +173 -0
  840. package/src/SelectPanel/index.ts +2 -0
  841. package/src/SideNav.tsx +191 -0
  842. package/src/Spinner.tsx +57 -0
  843. package/src/StateLabel.tsx +112 -0
  844. package/src/StyledOcticon.tsx +22 -0
  845. package/src/SubNav.tsx +124 -0
  846. package/src/TabNav.tsx +73 -0
  847. package/src/Text.tsx +13 -0
  848. package/src/TextInput.tsx +68 -0
  849. package/src/TextInputWithTokens.tsx +351 -0
  850. package/src/ThemeProvider.tsx +176 -0
  851. package/src/Timeline.tsx +140 -0
  852. package/src/Token/AvatarToken.tsx +54 -0
  853. package/src/Token/IssueLabelToken.tsx +150 -0
  854. package/src/Token/Token.tsx +126 -0
  855. package/src/Token/TokenBase.tsx +129 -0
  856. package/src/Token/_RemoveTokenButton.tsx +111 -0
  857. package/src/Token/_TokenTextContainer.tsx +47 -0
  858. package/src/Token/index.ts +3 -0
  859. package/src/Tooltip.tsx +263 -0
  860. package/src/Truncate.tsx +31 -0
  861. package/src/UnderlineNav.tsx +107 -0
  862. package/src/_TextInputWrapper.tsx +113 -0
  863. package/src/_UnstyledTextInput.tsx +19 -0
  864. package/src/__tests__/.eslintrc.json +11 -0
  865. package/src/__tests__/ActionList.test.tsx +53 -0
  866. package/src/__tests__/ActionList.types.test.tsx +51 -0
  867. package/src/__tests__/ActionList2.test.tsx +156 -0
  868. package/src/__tests__/ActionMenu.test.tsx +136 -0
  869. package/src/__tests__/AnchoredOverlay.test.tsx +150 -0
  870. package/src/__tests__/Autocomplete.test.tsx +444 -0
  871. package/src/__tests__/Avatar.test.tsx +44 -0
  872. package/src/__tests__/Avatar.types.test.tsx +11 -0
  873. package/src/__tests__/AvatarStack.test.tsx +48 -0
  874. package/src/__tests__/BorderBox.test.tsx +43 -0
  875. package/src/__tests__/Box.test.tsx +42 -0
  876. package/src/__tests__/BranchName.test.tsx +26 -0
  877. package/src/__tests__/BranchName.types.test.tsx +11 -0
  878. package/src/__tests__/Breadcrumbs.test.tsx +27 -0
  879. package/src/__tests__/Breadcrumbs.types.test.tsx +22 -0
  880. package/src/__tests__/BreadcrumbsItem.test.tsx +31 -0
  881. package/src/__tests__/Button.test.tsx +128 -0
  882. package/src/__tests__/Caret.test.tsx +36 -0
  883. package/src/__tests__/Checkbox.test.tsx +155 -0
  884. package/src/__tests__/CircleBadge.test.tsx +66 -0
  885. package/src/__tests__/CircleBadge.types.test.tsx +11 -0
  886. package/src/__tests__/CircleOcticon.test.tsx +50 -0
  887. package/src/__tests__/ConfirmationDialog.test.tsx +120 -0
  888. package/src/__tests__/CounterLabel.test.tsx +50 -0
  889. package/src/__tests__/CounterLabel.types.test.tsx +11 -0
  890. package/src/__tests__/Details.test.tsx +115 -0
  891. package/src/__tests__/Details.types.test.tsx +11 -0
  892. package/src/__tests__/Dialog.test.tsx +155 -0
  893. package/src/__tests__/Dialog.types.test.tsx +11 -0
  894. package/src/__tests__/Dialog2.types.test.tsx +11 -0
  895. package/src/__tests__/Dropdown.test.tsx +53 -0
  896. package/src/__tests__/Dropdown.types.test.tsx +21 -0
  897. package/src/__tests__/DropdownMenu.test.tsx +136 -0
  898. package/src/__tests__/FilterList.test.tsx +26 -0
  899. package/src/__tests__/FilterList.types.test.tsx +17 -0
  900. package/src/__tests__/FilterListItem.test.tsx +31 -0
  901. package/src/__tests__/FilteredSearch.test.tsx +26 -0
  902. package/src/__tests__/FilteredSearch.types.test.tsx +11 -0
  903. package/src/__tests__/Flash.test.tsx +45 -0
  904. package/src/__tests__/Flash.types.test.tsx +11 -0
  905. package/src/__tests__/Flex.test.tsx +58 -0
  906. package/src/__tests__/FormGroup.test.tsx +38 -0
  907. package/src/__tests__/FormGroup.types.test.tsx +11 -0
  908. package/src/__tests__/Grid.test.tsx +82 -0
  909. package/src/__tests__/Header.test.tsx +49 -0
  910. package/src/__tests__/Header.types.test.tsx +19 -0
  911. package/src/__tests__/Heading.test.tsx +137 -0
  912. package/src/__tests__/Heading.types.test.tsx +11 -0
  913. package/src/__tests__/KeyPaths.types.test.ts +14 -0
  914. package/src/__tests__/Label.test.tsx +34 -0
  915. package/src/__tests__/Label.types.test.tsx +11 -0
  916. package/src/__tests__/LabelGroup.test.tsx +30 -0
  917. package/src/__tests__/LabelGroup.types.test.tsx +11 -0
  918. package/src/__tests__/Link.test.tsx +47 -0
  919. package/src/__tests__/Link.types.test.tsx +11 -0
  920. package/src/__tests__/Merge.types.test.ts +39 -0
  921. package/src/__tests__/NewButton.test.tsx +70 -0
  922. package/src/__tests__/Overlay.test.tsx +103 -0
  923. package/src/__tests__/Overlay.types.test.tsx +33 -0
  924. package/src/__tests__/Pagehead.test.tsx +23 -0
  925. package/src/__tests__/Pagehead.types.test.tsx +11 -0
  926. package/src/__tests__/Pagination/Pagination.test.tsx +30 -0
  927. package/src/__tests__/Pagination/PaginationModel.test.tsx +133 -0
  928. package/src/__tests__/Pagination/__snapshots__/Pagination.test.tsx.snap +184 -0
  929. package/src/__tests__/Pagination.types.test.tsx +11 -0
  930. package/src/__tests__/PointerBox.test.tsx +34 -0
  931. package/src/__tests__/Popover.test.tsx +68 -0
  932. package/src/__tests__/Popover.types.test.tsx +17 -0
  933. package/src/__tests__/Portal.test.tsx +103 -0
  934. package/src/__tests__/Position.test.tsx +117 -0
  935. package/src/__tests__/ProgressBar.test.tsx +40 -0
  936. package/src/__tests__/SelectMenu.test.tsx +142 -0
  937. package/src/__tests__/SelectMenu.types.test.tsx +37 -0
  938. package/src/__tests__/SelectPanel.test.tsx +63 -0
  939. package/src/__tests__/SelectPanel.types.test.tsx +31 -0
  940. package/src/__tests__/SideNav.test.tsx +62 -0
  941. package/src/__tests__/SideNav.types.test.tsx +11 -0
  942. package/src/__tests__/Spinner.test.tsx +42 -0
  943. package/src/__tests__/StateLabel.test.tsx +48 -0
  944. package/src/__tests__/StateLabel.types.test.tsx +11 -0
  945. package/src/__tests__/StyledOcticon.test.tsx +26 -0
  946. package/src/__tests__/StyledOcticon.types.test.tsx +12 -0
  947. package/src/__tests__/SubNav.test.tsx +50 -0
  948. package/src/__tests__/SubNav.types.test.tsx +25 -0
  949. package/src/__tests__/SubNavLink.test.tsx +31 -0
  950. package/src/__tests__/TabNav.test.tsx +32 -0
  951. package/src/__tests__/TabNav.types.test.tsx +22 -0
  952. package/src/__tests__/Text.test.tsx +78 -0
  953. package/src/__tests__/TextInput.test.tsx +49 -0
  954. package/src/__tests__/TextInputWithTokens.test.tsx +422 -0
  955. package/src/__tests__/ThemeProvider.test.tsx +441 -0
  956. package/src/__tests__/Timeline.test.tsx +58 -0
  957. package/src/__tests__/Timeline.types.test.tsx +31 -0
  958. package/src/__tests__/Token.test.tsx +118 -0
  959. package/src/__tests__/Tooltip.test.tsx +52 -0
  960. package/src/__tests__/Tooltip.types.test.tsx +11 -0
  961. package/src/__tests__/Truncate.test.tsx +43 -0
  962. package/src/__tests__/Truncate.types.test.tsx +11 -0
  963. package/src/__tests__/UnderlineNav.test.tsx +58 -0
  964. package/src/__tests__/UnderlineNav.types.test.tsx +22 -0
  965. package/src/__tests__/UnderlineNavLink.test.tsx +31 -0
  966. package/src/__tests__/__snapshots__/ActionList.test.tsx.snap +223 -0
  967. package/src/__tests__/__snapshots__/ActionList2.test.tsx.snap +14 -0
  968. package/src/__tests__/__snapshots__/ActionMenu.test.tsx.snap +80 -0
  969. package/src/__tests__/__snapshots__/AnchoredOverlay.test.tsx.snap +232 -0
  970. package/src/__tests__/__snapshots__/Autocomplete.test.tsx.snap +3901 -0
  971. package/src/__tests__/__snapshots__/Avatar.test.tsx.snap +19 -0
  972. package/src/__tests__/__snapshots__/AvatarStack.test.tsx.snap +377 -0
  973. package/src/__tests__/__snapshots__/BorderBox.test.tsx.snap +14 -0
  974. package/src/__tests__/__snapshots__/Box.test.tsx.snap +201 -0
  975. package/src/__tests__/__snapshots__/BranchName.test.tsx.snap +17 -0
  976. package/src/__tests__/__snapshots__/Breadcrumbs.test.tsx.snap +29 -0
  977. package/src/__tests__/__snapshots__/BreadcrumbsItem.test.tsx.snap +79 -0
  978. package/src/__tests__/__snapshots__/Button.test.tsx.snap +840 -0
  979. package/src/__tests__/__snapshots__/Caret.test.tsx.snap +373 -0
  980. package/src/__tests__/__snapshots__/Checkbox.test.tsx.snap +16 -0
  981. package/src/__tests__/__snapshots__/CircleBadge.test.tsx.snap +142 -0
  982. package/src/__tests__/__snapshots__/CircleOcticon.test.tsx.snap +65 -0
  983. package/src/__tests__/__snapshots__/ConfirmationDialog.test.tsx.snap +89 -0
  984. package/src/__tests__/__snapshots__/CounterLabel.test.tsx.snap +22 -0
  985. package/src/__tests__/__snapshots__/Details.test.tsx.snap +15 -0
  986. package/src/__tests__/__snapshots__/Dialog.test.tsx.snap +201 -0
  987. package/src/__tests__/__snapshots__/Dropdown.test.tsx.snap +249 -0
  988. package/src/__tests__/__snapshots__/DropdownMenu.test.tsx.snap +107 -0
  989. package/src/__tests__/__snapshots__/FilterList.test.tsx.snap +13 -0
  990. package/src/__tests__/__snapshots__/FilterListItem.test.tsx.snap +80 -0
  991. package/src/__tests__/__snapshots__/FilteredSearch.test.tsx.snap +32 -0
  992. package/src/__tests__/__snapshots__/Flash.test.tsx.snap +32 -0
  993. package/src/__tests__/__snapshots__/Flex.test.tsx.snap +130 -0
  994. package/src/__tests__/__snapshots__/FormGroup.test.tsx.snap +25 -0
  995. package/src/__tests__/__snapshots__/Grid.test.tsx.snap +178 -0
  996. package/src/__tests__/__snapshots__/Header.test.tsx.snap +79 -0
  997. package/src/__tests__/__snapshots__/Heading.test.tsx.snap +13 -0
  998. package/src/__tests__/__snapshots__/Label.test.tsx.snap +73 -0
  999. package/src/__tests__/__snapshots__/LabelGroup.test.tsx.snap +15 -0
  1000. package/src/__tests__/__snapshots__/Link.test.tsx.snap +212 -0
  1001. package/src/__tests__/__snapshots__/NewButton.test.tsx.snap +305 -0
  1002. package/src/__tests__/__snapshots__/Pagehead.test.tsx.snap +15 -0
  1003. package/src/__tests__/__snapshots__/PointerBox.test.tsx.snap +174 -0
  1004. package/src/__tests__/__snapshots__/Popover.test.tsx.snap +4687 -0
  1005. package/src/__tests__/__snapshots__/Position.test.tsx.snap +44 -0
  1006. package/src/__tests__/__snapshots__/ProgressBar.test.tsx.snap +53 -0
  1007. package/src/__tests__/__snapshots__/SelectMenu.test.tsx.snap +473 -0
  1008. package/src/__tests__/__snapshots__/SelectPanel.test.tsx.snap +124 -0
  1009. package/src/__tests__/__snapshots__/SideNav.test.tsx.snap +143 -0
  1010. package/src/__tests__/__snapshots__/Spinner.test.tsx.snap +33 -0
  1011. package/src/__tests__/__snapshots__/StateLabel.test.tsx.snap +395 -0
  1012. package/src/__tests__/__snapshots__/StyledOcticon.test.tsx.snap +26 -0
  1013. package/src/__tests__/__snapshots__/SubNav.test.tsx.snap +44 -0
  1014. package/src/__tests__/__snapshots__/SubNavLink.test.tsx.snap +199 -0
  1015. package/src/__tests__/__snapshots__/TabNav.test.tsx.snap +58 -0
  1016. package/src/__tests__/__snapshots__/Text.test.tsx.snap +7 -0
  1017. package/src/__tests__/__snapshots__/TextInput.test.tsx.snap +446 -0
  1018. package/src/__tests__/__snapshots__/TextInputWithTokens.test.tsx.snap +6045 -0
  1019. package/src/__tests__/__snapshots__/ThemeProvider.test.tsx.snap +15 -0
  1020. package/src/__tests__/__snapshots__/Timeline.test.tsx.snap +159 -0
  1021. package/src/__tests__/__snapshots__/Token.test.tsx.snap +3811 -0
  1022. package/src/__tests__/__snapshots__/Tooltip.test.tsx.snap +227 -0
  1023. package/src/__tests__/__snapshots__/Truncate.test.tsx.snap +17 -0
  1024. package/src/__tests__/__snapshots__/UnderlineNav.test.tsx.snap +59 -0
  1025. package/src/__tests__/__snapshots__/UnderlineNavLink.test.tsx.snap +130 -0
  1026. package/src/__tests__/__snapshots__/themePreval.test.ts.snap +3176 -0
  1027. package/src/__tests__/behaviors/anchoredPosition.test.ts +295 -0
  1028. package/src/__tests__/behaviors/focusTrap.test.tsx +236 -0
  1029. package/src/__tests__/behaviors/focusZone.test.tsx +549 -0
  1030. package/src/__tests__/behaviors/iterateFocusableElements.test.tsx +61 -0
  1031. package/src/__tests__/behaviors/scrollIntoViewingArea.test.ts +195 -0
  1032. package/src/__tests__/filterObject.test.ts +54 -0
  1033. package/src/__tests__/hooks/useAnchoredPosition.test.tsx +31 -0
  1034. package/src/__tests__/hooks/useOnEscapePress.test.tsx +16 -0
  1035. package/src/__tests__/hooks/useOnOutsideClick.test.tsx +48 -0
  1036. package/src/__tests__/hooks/useOpenAndCloseFocus.test.tsx +48 -0
  1037. package/src/__tests__/hooks/useProvidedStateOrCreate.test.tsx +39 -0
  1038. package/src/__tests__/theme.test.ts +41 -0
  1039. package/src/__tests__/themeGet.test.ts +15 -0
  1040. package/src/__tests__/themePreval.test.ts +8 -0
  1041. package/src/__tests__/useSafeTimeout.test.tsx +36 -0
  1042. package/src/__tests__/utils/__snapshots__/createSlots.test.tsx.snap +55 -0
  1043. package/src/__tests__/utils/createSlots.test.tsx +74 -0
  1044. package/src/behaviors/anchoredPosition.ts +442 -0
  1045. package/src/behaviors/focusTrap.ts +184 -0
  1046. package/src/behaviors/focusZone.ts +713 -0
  1047. package/src/behaviors/scrollIntoViewingArea.ts +27 -0
  1048. package/src/constants.ts +62 -0
  1049. package/src/drafts.ts +10 -0
  1050. package/src/hooks/index.ts +11 -0
  1051. package/src/hooks/useAnchoredPosition.ts +54 -0
  1052. package/src/hooks/useCombinedRefs.ts +40 -0
  1053. package/src/hooks/useDetails.tsx +54 -0
  1054. package/src/hooks/useDialog.ts +121 -0
  1055. package/src/hooks/useFocusTrap.ts +80 -0
  1056. package/src/hooks/useFocusZone.ts +64 -0
  1057. package/src/hooks/useOnEscapePress.ts +63 -0
  1058. package/src/hooks/useOnOutsideClick.tsx +82 -0
  1059. package/src/hooks/useOpenAndCloseFocus.ts +32 -0
  1060. package/src/hooks/useOverlay.tsx +34 -0
  1061. package/src/hooks/useProvidedRefOrCreate.ts +14 -0
  1062. package/src/hooks/useProvidedStateOrCreate.ts +27 -0
  1063. package/src/hooks/useRenderForcingRef.ts +22 -0
  1064. package/src/hooks/useResizeObserver.ts +11 -0
  1065. package/src/hooks/useSafeTimeout.ts +38 -0
  1066. package/src/hooks/useScrollFlash.ts +21 -0
  1067. package/src/index.ts +175 -0
  1068. package/src/polyfills/eventListenerSignal.ts +66 -0
  1069. package/src/stories/ActionList.stories.tsx +436 -0
  1070. package/src/stories/ActionList2.stories.tsx +1305 -0
  1071. package/src/stories/ActionMenu.stories.tsx +331 -0
  1072. package/src/stories/AnchoredOverlay.stories.tsx +117 -0
  1073. package/src/stories/Autocomplete.stories.tsx +655 -0
  1074. package/src/stories/AvatarStack.stories.tsx +37 -0
  1075. package/src/stories/Button.stories.tsx +92 -0
  1076. package/src/stories/Checkbox.stories.tsx +164 -0
  1077. package/src/stories/ConfirmationDialog.stories.tsx +105 -0
  1078. package/src/stories/Dialog.stories.tsx +240 -0
  1079. package/src/stories/DropdownMenu.stories.tsx +84 -0
  1080. package/src/stories/IssueLabelToken.stories.tsx +138 -0
  1081. package/src/stories/NewButton.stories.tsx +201 -0
  1082. package/src/stories/Overlay.stories.tsx +213 -0
  1083. package/src/stories/Portal.stories.tsx +109 -0
  1084. package/src/stories/ProfileToken.stories.tsx +129 -0
  1085. package/src/stories/SelectPanel.stories.tsx +353 -0
  1086. package/src/stories/TextInput.stories.tsx +113 -0
  1087. package/src/stories/TextInputWithTokens.stories.tsx +155 -0
  1088. package/src/stories/ThemeProvider.stories.tsx +104 -0
  1089. package/src/stories/Token.stories.tsx +137 -0
  1090. package/src/stories/useAnchoredPosition.stories.tsx +332 -0
  1091. package/src/stories/useFocusTrap.stories.tsx +400 -0
  1092. package/src/stories/useFocusZone.stories.tsx +663 -0
  1093. package/src/sx.ts +24 -0
  1094. package/src/theme-preval.js +80 -0
  1095. package/src/theme.ts +89 -0
  1096. package/src/utils/create-slots.tsx +96 -0
  1097. package/src/utils/deprecate.tsx +73 -0
  1098. package/src/utils/isNumeric.tsx +4 -0
  1099. package/src/utils/iterateFocusableElements.ts +121 -0
  1100. package/src/utils/ssr.tsx +1 -0
  1101. package/src/utils/test-deprecations.tsx +19 -0
  1102. package/src/utils/test-helpers.tsx +7 -0
  1103. package/src/utils/test-matchers.tsx +109 -0
  1104. package/src/utils/testing.tsx +264 -0
  1105. package/src/utils/theme.js +64 -0
  1106. package/src/utils/types/AriaRole.ts +71 -0
  1107. package/src/utils/types/ComponentProps.ts +13 -0
  1108. package/src/utils/types/Flatten.ts +4 -0
  1109. package/src/utils/types/KeyPaths.ts +10 -0
  1110. package/src/utils/types/MandateProps.ts +19 -0
  1111. package/src/utils/types/Merge.ts +20 -0
  1112. package/src/utils/types/index.ts +5 -0
  1113. package/src/utils/uniqueId.ts +6 -0
  1114. package/src/utils/use-force-update.ts +7 -0
  1115. package/src/utils/useIsomorphicLayoutEffect.ts +10 -0
  1116. package/src/utils/userAgent.ts +7 -0
  1117. package/stats.html +3279 -0
  1118. package/tsconfig.build.json +7 -0
  1119. package/tsconfig.json +20 -0
  1120. package/lib/ActionList2/Header.d.ts +0 -26
  1121. package/lib/ActionList2/Header.js +0 -55
  1122. package/lib-esm/ActionList2/Header.d.ts +0 -26
  1123. package/lib-esm/ActionList2/Header.js +0 -44
@@ -0,0 +1,108 @@
1
+ # ADR 2: Isolating behaviors through custom clements and vanilla JavaScript
2
+
3
+ ## Status
4
+
5
+ Approved 2021-02-04
6
+
7
+ ## Related documents
8
+
9
+ - April 18th, 2018: [Custom Elements Example](https://github.com/primer/react/pull/13)
10
+ - May 8th, 2018: [Custom Elements Experiment](https://github.com/primer/react/pull/14)
11
+ - May 18th 2018: [React & Custom Elements](https://docs.google.com/document/d/1b6D2jW3ztQJiKEtQINbb4JoHJ3F3szU6lBX-fGce6aY/edit?usp=sharing)
12
+ - October 16th 2019: [Issue exploring pros & cons of reusing .com JS in React](https://github.com/github/issues-index-experiment/issues/90)
13
+ - November 15th 2019: [Experiment porting PRC to web components](https://github.com/github/ui-engineering/issues/12#issuecomment-558257842)
14
+ - November 27th 2019: [Usage of custom elements in IIE project](https://github.com/github/issues-index-experiment/pull/133)
15
+ - November 27th 2019: [Styling custom elements with styled components](https://github.slack.com/archives/CMZ4DC9BL/p1574883198055600)
16
+ - June 9th 2020: [Discussion in Slack about using skatejs for SSR](https://github.slack.com/archives/C0ER2LCG2/p1591707104461300)
17
+ - November 10th 2020: [Replace dialog with details-dialog](https://github.com/primer/react/issues/907)
18
+ - January 27th 2021: [Guidelines for authoring behaviors](https://github.com/primer/react/pull/992)
19
+ - February 1st 2021: [Example of a vanilla JS behavior & accompanying hook](https://github.com/T-Hugs/components/commit/105c3a191681381377f5aa193cb241a2189db8a6)
20
+
21
+ ## Providing behaviors via custom elements
22
+
23
+ ### Context
24
+
25
+ Throughout the last few years folks from the Design Infrastructure, Web Systems, and UI Platform teams have discussed the idea of using custom elements for behaviors in Primer React. The main goal of using custom elements in Primer React is to be able to author behaviors once and reuse them in any framework. Several experiments have been conducted which are listed above.
26
+
27
+ ### Assumptions
28
+
29
+ De-duplication is not our highest or only priority. Attempts at de-duplication must be weighed against changes to the maintainer, developer, and customer experience.
30
+
31
+ ### Findings
32
+
33
+ #### Developer experience regressions
34
+
35
+ - Custom elements rendering their own subtrees (ShadowDOM) requires polyfills for as-yet implemented specifications. This means Primer React will accumulate added complexity if we were to implement Custom Elements with ShadowDOM.
36
+
37
+ - Implementing Custom Elements in Primer React will require a division of client side and server side code, as custom elements should only be executed in a browser environment. Currently Primer React is "isomorphic" - in that the code can be executed anywhere that React can be, which includes NodeJS server runtimes, as well as the client side. While not insurmountable this does mean Primer React will accumulate added complexity, which likely will be surfaced to the user.
38
+
39
+ - While it's possible to add server side libraries to enable Custom Elements to be rendered on the Server, this adds more complexity and is antithetical to the usage patterns of custom elements.
40
+
41
+ - As of this writing, you cannot style custom elements with styled-components[^1]. This means that if a component wants to use a custom element to get behaviors and you also want to style that component, you must use another wrapper div to apply styles. This is a bug in styled-components and should be fixed in the next release.
42
+
43
+ #### Incompatibility with some React tools
44
+
45
+ Some of our GitHub custom elements such as `details-dialog` and `details-menu` make assumptions about the DOM tree. For example, `details-dialog` expects a `details` element to wrap the custom element and uses this assumption[^2] to determine whether or not clicks are happening inside or outside of the dialog and closes the dialog if the click happened outside of the dialog. This makes sense in most cases and is a nice way of enforcing proper usage of the details element, but breaks down when used with [React Portals](https://reactjs.org/docs/portals.html) which are often used to ensure menus are displayed correctly in cases where a parent has an overflow: hidden applied to it, or incompatible z-index.
46
+
47
+ #### Extensibility
48
+
49
+ Building behaviors in React Hooks gives us the ability to provide things like state and state change hooks to the consumer of the component. This allows the user to build on additional behaviors to the component based on the state or other variables provided to the component consumer. Doing the same with custom elements would require listening to events on the document[^3] and reacting to them. This is certainly do-able, but goes against some of the foundational principles of React (reacting to changes in the DOM vs changes in React state).
50
+
51
+ #### Organizational overhead
52
+
53
+ - GitHub’s custom elements are all managed in different repos which introduces more maintenance overhead.
54
+ - You'd need to npm link while developing if you want to test changes out with the presentational components themselves instead of making changes and seeing updates instantly. npm link usually doesn't work well with hot module reloading either.
55
+ - You'd need to draft & publish releases to both libraries every time you want to update the behavior
56
+ - If the behaviors are shared between github.com and Primer React, you'd need to do careful testing in both environments to make sure that changes don't create any regressions. That greatly widens the context that engineers need to keep in mind every time a change is made.
57
+ - Reacting to changes will take a bit more time as we’ll need to orchestrate releases between custom elements and Primer React - as opposed to having behaviors already present in Primer React which can be versioned in lockstep.
58
+ - Engineers who want to contribute to Primer React Components to build new components and behaviors would need to be familiar with both custom elements and React, two very different paradigms, and context switch between the two.
59
+
60
+ #### Other
61
+
62
+ - The custom element and web component API progress slower than React due to changes needing to go through the whatwq standards process.
63
+
64
+ #### Risks of not switching to custom elements for behaviors
65
+
66
+ - We spend extra time building behaviors in React that have already been built in our [custom elements library](https://github.github.io/web-systems-documentation/#custom-elements).
67
+ - There are currently 19 behaviors/components listed on the custom elements documentation site. Several of these we have already implemented in React in either Priemr React, Doctocat, or other React applications at GitHub which can be upstreamed (details-dialog, details-menu, clipboard-copy, text-expander, autocomplete, task-list via drag and drop hooks, tab-container, text-expander).
68
+ - We decide not to invest further in React at GitHub and have wasted time we could have spent building more custom elements.
69
+ - This seems unlikely as there seems to be clear consensus that we will continue to build more and more highly interactive products.
70
+ - The React library is abandoned and becomes obsolete.
71
+ - This is a risk with any technology that we may use, seems highly unlikely in the near term.
72
+ - While also a possibility for custom elements, the track record demonstrates deprecations of Web APIs is extremely rare and has a long deprecation path.
73
+ - Behaviors in github.com using custom elements and behaviors in Primer REact diverge, leading to an inconsistent experience.
74
+ - This is probably the biggest risk we face, but moving to custom elements isn’t necessarily the only or best solution. We should explore other ways of detecting divergence such as integration tests.
75
+
76
+ ## Providing behaviors through vanilla JavaScript
77
+
78
+ A simpler method of isolating component behaviors is to implement them in vanilla JavaScript (or TypeScript). This way, they can be shared between React components and web components. Both types of consumers would need to hook up the vanilla behavior to the component(s) that use(s) them.
79
+
80
+ In some cases, this strategy is very straightforward. When a behavior can be made to have no dependencies other than the DOM, it is easy to isolate and consume in various frameworks. Behaviors that have effects on interactions/events, shared state, and component styles will be more difficult to isolate in this manner.
81
+
82
+ ### Interactions and events
83
+
84
+ Many user interactions rely on DOM events, such as `click`, `keypress`, and `focus`. React's event system is _not_ the same as the native DOM event system. React implements a [SyntheticEvent](https://reactjs.org/docs/events.html) that wraps native events. Working with both `SyntheticEvent`s and native events simultaneously is significant additional complexity for maintainers and consumers. However, vanilla JavaScript must operate only using native events. This makes isolating behaviors that automatically hook up event listeners to DOM elements difficult to achieve, and the resulting simultaneous usage of native events and `SyntheticEvent` has the potential to degrade both the maintainer's and the consumer's developer experience using Primer React.
85
+
86
+ ### Shared state
87
+
88
+ There are countless ways to manage state in a web application. React has its own ecosystem of state management strategies and libraries (in addition to its own primitive constructs for state management). Since there is no standard state management pattern in vanilla JavaScript, introducing such a pattern would add a new layer of complexity to the component behavior API.
89
+
90
+ ### Component styles
91
+
92
+ Since Primer React uses styled-components to manage CSS styles, any behaviors that affect styles should be doing so with styled-components. Any vanilla JavaScript behaviors that affect styles will add complexity by introducing a second mechanism for applying styles, since they will not be able to use styled-components.
93
+
94
+ ## Decision
95
+
96
+ ### Custom elements
97
+
98
+ Due to the challenges listed above and our priorities listed in the [Assumptions](#assumptions) section, we are not investing time in building out behaviors with custom elements in our Primer React library. Instead, we should spend time expanding coverage using React Hooks and focus on finding other approaches for making sure implementation of behaviors in our different stacks are consistent (such as integration tests).
99
+
100
+ ### Vanilla JavaScript behaviors
101
+
102
+ Some behaviors can be implemented as vanilla JavaScript without introducing additional complexity to Primer React or its consumers. In cases where this is possible, behaviors will be implemented with no dependencies except the DOM and consumed within React Hooks to provide their functionality to Primer React.
103
+
104
+ In general, _portions of behaviors_ that affect or rely on **user interactions and events**, **shared state**, or **CSS styles** should be kept in React Hooks. Parts of the behavior that can be implemented in isolation of these concepts should be built with no dependency on React or other libraries.
105
+
106
+ [^1]: https://codesandbox.io/s/demo-styling-custom-element-g973d?file=/src/index.tsx
107
+ [^2]: https://github.com/github/details-dialog-element/blob/main/src/index.ts#L195
108
+ [^3]: https://github.com/github/details-dialog-element#details-dialog-close
@@ -0,0 +1,72 @@
1
+ # ADR 003: Prop norms in Primer React Components
2
+
3
+ ## Status
4
+
5
+ Proposed
6
+
7
+ ## Context
8
+
9
+ Today our component prop APIs have:
10
+
11
+ - Implicit conventions not documented anywhere but consistently reflected in our code (e.g., the type of the `sx` prop)
12
+ - Explicit plans to change some of those (e.g., the deprecation of Styled System props)
13
+ - Inconsistencies in our implementation (e.g., when components accept a `ref` prop)
14
+
15
+ This ADR aims to unify some of these conversations about prop APIs, codify our decisions, and sequence the work to get there.
16
+
17
+ ## Decision
18
+
19
+ ### 🟢 `sx`
20
+
21
+ All components that ultimately render to the DOM should accept an `sx` prop.
22
+
23
+ The `sx` prop (of type `SystemStyleObject`) should generally set styles for the root HTML element rendered by the component. An exception would be components like `<Dialog>`, whose outermost HTML element is a backdrop. In that case, it would be appropriate for `sx` styles to apply to child of the backdrop that is more likely to need styling overrides.
24
+
25
+ ### 🟢 `ref`
26
+
27
+ All components that ultimately render to the DOM should accept a `ref` prop. That `ref` prop should most often be passed to the root HTMLElement rendered by the component, although occasionally a different descendent node may make more sense.
28
+
29
+ See also: [Discussion on `ref` props (internal)](https://github.com/github/primer/discussions/131)
30
+
31
+ ### 🟡 `as`
32
+
33
+ Only components with a clear need for polymorphism should accept an `as` prop. Reasonable cases include:
34
+
35
+ - Components that need functionality from the component passed to the `as` prop, like a `<Button>` that renders a React Router link.
36
+ - Components whose accessibility are improved by using semantically appropriate HTML elements, like an ActionList
37
+
38
+ When a Primer component user passes an `as` prop to a component, it should be done in a way that is consistent with the component’s intended use. In some situations we can enforce that with a narrowed type for our `as` prop.
39
+
40
+ See also: [Discussion on `as` props (internal)](https://github.com/github/primer/discussions/130)
41
+
42
+ ### 🟡 DOM props: Limited
43
+
44
+ All components that accept an `as` prop should accept props en masse for the element specified by the `as` prop (excluding props of the same name already used by the component). _Additionally_, some other elements that do _not_ accept an `as` prop should accept the props for their root HTML element when those props are fundamental to the component’s function (e.g., `<TextInput>` should accept DOM props for its underlying `<input>`).
45
+
46
+ ### 🔴 Styled System props
47
+
48
+ Components should not accept Styled System props (except our utility components: `Box` and `Type`)
49
+
50
+ _Reasoning:_ Utility components are meant to provide a convenient API for writing styles (including styles that reference theme and other context managed within Primer). Non-utility components implement specific design patterns where additional styling is available for exceptional cases.
51
+
52
+ See also: [Discussion on the deprecation of styled-system props (internal)](https://github.com/github/primer/discussions/132)
53
+
54
+ ### 🔴 `theme`
55
+
56
+ Components should not accept a `theme` prop (with the exception of `ThemeProvider`).
57
+
58
+ _Reasoning:_ The `theme` prop doesn't enable anything that can't be done with `<ThemeProvider>`, and promotes the anti-pattern of per-component theme overrides.
59
+
60
+ ### `children`
61
+
62
+ I'm intentionally withholding advocacy about `children` prop types because I expect that topic will be covered by a future ADR.
63
+
64
+ ### Sequencing
65
+
66
+ 1. Deprecate remaining unwanted Styled System props (should be done? Let's verify.)
67
+ 1. Release an eslint rule to disallow Styled System props
68
+ 1. Release an eslint rule to disallow `theme`
69
+ 1. Migrate all usage within PRC
70
+ 1. Assist GitHub projects with migration
71
+ 1. Remove support for unwanted props
72
+ 1. Update docs to reflect the standards in this ADR
@@ -0,0 +1,132 @@
1
+ _Note: This documentation is a draft and is expected to undergo several revisions before being adopted._
2
+
3
+ # Implementing Behaviors in Primer Components
4
+
5
+ Behaviors in Primer Components are implemented via React Hooks. Primer Components provides two types of behaviors: generic behaviors and component behaviors.
6
+
7
+ ## Dependencies
8
+
9
+ **External dependencies:** Third-party/external dependencies are not allowed, except under very strict circumstances. If you need to use an external dependency, open an issue and discuss with the team.
10
+
11
+ **Internal dependencies:** Internal dependencies are fine and encouraged to reduce code duplication and maintain consistency. When taking an internal dependency, observe the following:
12
+
13
+ - No circular dependencies
14
+ - Components may depend on other components and component behaviors, but should avoid depending directly on generic behaviors.
15
+ - Component behaviors may depend on other component behaviors and generic behaviors.
16
+ - Generic behaviors may only depend on other generic behaviors.
17
+
18
+ See below for a visualization of allowed dependencies.
19
+
20
+ ```
21
+ ____________
22
+ | \*
23
+ +-------------V--------+ /
24
+ | Generic behaviors |---
25
+ +----------------------+
26
+ ^
27
+ *| ___________
28
+ | | \*
29
+ +----------|----V-------+ /
30
+ | Component behaviors |---
31
+ +-----------------------+
32
+ ^
33
+ 1| _____
34
+ | | \*
35
+ +--------|---V-+ /
36
+ | Components |---
37
+ +--------------+
38
+
39
+ ```
40
+
41
+ ## Generic behaviors
42
+
43
+ Generic behaviors provide functionality that is not specific to any single component or class of components. If you can't tell which component it should operate on, it's probably a generic behavior. Generic behaviors are _low-level_. Generic behaviors may only have dependencies on other generic behaviors.
44
+
45
+ ### Examples
46
+
47
+ - `useProvidedRefOrCreate`
48
+ - `usePosition`
49
+ - `useClickAway`
50
+ - `useTypeAhead`
51
+
52
+ ## Component behaviors
53
+
54
+ Component behaviors specifically implement behaviors for components. Therefore, hooks that implement component behaviors should always return an object containing props objects to be spread across the elements that make up the component's JSX. While component behaviors do not necessarily have to be one-to-one, **a component may only use one component behavior**. Sometimes it makes sense to use the same component behavior on several components. For example: the Dialog, Popover, and PointerBox components may all use the `usePopover` component behavior.
55
+
56
+ ### Examples
57
+
58
+ - `usePopover`
59
+ - `useComboBox`
60
+ - `useFilteredSearch`
61
+ - `useDetails`
62
+
63
+ ## Implementation guidelines
64
+
65
+ All behaviors should be implemented as [React Hooks](https://reactjs.org/docs/hooks-intro.html).
66
+
67
+ Component behaviors should be relatively brief. A component behavior should build a component's experience through the combination of several configured generic behaviors.
68
+
69
+ Example: The Dialog component uses a `usePopover` behavior. The `usePopover` behavior in turn may call generic behaviors such as `usePosition` (to position the popover on the screen), `useClickAway` (to set up an event handler for clicking outside of the dialog), and `useFocusTrap` (to prevent focus from leaving the dialog while it is being shown).
70
+
71
+ ### Component implementation
72
+
73
+ Component implementation is [discussed elsewhere](https://github.com/primer/react/blob/main/contributor-docs/CONTRIBUTING.md#developing-components), but with respect to behaviors, follow these guidelines.
74
+
75
+ - If a component has behaviors, it should make a call to exactly one component behavior hook.
76
+ - The hook will return an object containing multiple props objects. Each of the returned objects are props that should be spread onto the appropriate JSX element.
77
+ - Component implementations should be as clean as possible, mostly consisting of the JSX tree definition that the component renders.
78
+ - Component props and, in some circumstances, context values, should serve as arguments to component behavior hooks.
79
+
80
+ ### Balancing API surface with supported scenarios
81
+
82
+ The [YAGNI Principle](https://en.wikipedia.org/wiki/You_aren%27t_gonna_need_it) cautions developers against building out functionality that isn't presently needed, but as a library, Primer Components should carefully balance the API surface area with building a library that functions for a wide range of use cases. Since it is difficult to define a quantitative test to determine whether or not a component or a behavior should support a certain scenario, there will be some subjectivity when it comes to choosing to build certain features. When adding a feature that seems too specific, try to _generalize_ it. Can multiple use cases be accounted for by implementing a single generalized feature? Can a known needed use case be extrapolated into a feature that supports that use case along with other use cases that are not yet known to be needed? If so, use these considerations when designing your APIs.
83
+
84
+ ### Sensible defaults, powerful configuration, and last-resort "escape hatches"
85
+
86
+ - Defaults should take users down the “happy path” and place them into the “pit of success.”
87
+ - Configuration allows the component to reach more use cases. Components that use configurations to deviate from defaults should be viewed as first-class supported scenarios, just as important as the defaults.
88
+ - Escape hatches may be necessary to support consumers with requirements that we haven’t considered. It should be cleared that using escape hatches “voids your warranty,” yet, they should be fully documented.
89
+
90
+ ### Arguments to behaviors
91
+
92
+ - As mentioned above, behaviors should have sensible defaults but powerful configuration. Behaviors are configured via arguments passed to the hook.
93
+ - When possible, a hook should be able to be called with zero arguments to get all the defaults.
94
+ - Each argument that is required should have an individual parameter on the hook function.
95
+ - Optional arguments (i.e. “settings”) should be provided via a strongly typed settings object as the last argument to a hook function.
96
+
97
+ ### Return value of behavior hooks
98
+
99
+ #### Component behavior hook return value
100
+
101
+ Component behavior hooks produce _props_. Therefore, the return value of a component behavior should be a collection of props objects, intended to be spread onto JSX elements that render a component.
102
+
103
+ - Each element of the object returned from a component behavior hook is a props object that can be spread onto a JSX element
104
+ - The names of the keys should accurately indicate the JSX element onto which those props should be spread
105
+
106
+ Example: The Dialog component uses a `usePopover` component behavior, which may return an object like:
107
+
108
+ ```
109
+ {
110
+ popoverProps: PropsObject,
111
+ openClickTargetProps: PropsObject,
112
+ closeClickTargetProps: PropsObject
113
+ }
114
+ ```
115
+
116
+ Each of these props objects would then get spread onto their respective JSX elements.
117
+
118
+ #### Generic behavior hook return value
119
+
120
+ There are no restrictions on return values of generic behavior hooks. In fact, some behavioral hooks might not need to return anything. For example, a `useEscape` hook might simply set up a callback for an `Escape` keypress.
121
+
122
+ ### Refs
123
+
124
+ - Often, a behavior will need to act on a real DOM element.
125
+ - In this case, the hook should return a ref as part of the returned props for that element. The ref will get spread onto the element, giving the ref access to it.
126
+ - Whenever you need a ref, it must be accepted as an optional setting to the hook. The hook then uses the `useProvidedRefOrCreate` hook to resolve a usable ref. Remember to return the resulting ref from the hook.
127
+
128
+ ## Testing behaviors
129
+
130
+ - Whenever possible, test your changes in another application that makes heavy use of Primer Components.
131
+ - You may even want to build and “marinate” your component in another application before merging a change to Primer Components.
132
+ - Build the component, start using it in the application, and see how the component API feels. This approach works best for engineers at GitHub already working on a product written in React.
@@ -0,0 +1,316 @@
1
+ # React Component APIs: Contents as data vs. Contents as children
2
+
3
+ Consider a React component that renders a list of items. Here are two possible APIs that component might expose, both achieving an equivalent result.
4
+
5
+ ### A: Contents passed as React children
6
+
7
+ ```jsx
8
+ <List>
9
+ <List.Item>New file</List.Item>
10
+ <List.Divider />
11
+ <List.Item>Copy link</List.Item>
12
+ <List.Item>Edit file</List.Item>
13
+ <List.Item variant="danger">Delete file</List.Item>
14
+ </List>
15
+ ```
16
+
17
+ ### B: Contents passed as data
18
+
19
+ ```jsx
20
+ <List
21
+ items={[
22
+ { text: "New file" },
23
+ ActionList.Divider,
24
+ { text: "Copy link" },
25
+ { text: "Edit file" },
26
+ { text: "Delete file", variant: "danger" },
27
+ ]}
28
+ />
29
+ ```
30
+
31
+ Is one API better than the other generally? What about in this context (a "List" component)? Are there situations where it is better to choose one over the other? Let's try to answer these questions.
32
+
33
+ ## Both APIs have valid use cases
34
+
35
+ This section simply argues that both of the patterns above are valid. Once we do this, we can attempt to define the criteria that helps the API designer choose one over the other.
36
+
37
+ ### Contents passed as React children
38
+
39
+ This is the most common way to define the structure of content in React. In fact, all HTML elements work this way:
40
+
41
+ ```jsx
42
+ <div>
43
+ <div>Some content</div>
44
+ <div>More content</div>
45
+ </div>
46
+ ```
47
+
48
+ ```jsx
49
+ <ul>
50
+ <li>Item 1</li>
51
+ <li>Item 2</li>
52
+ </ul>
53
+ ```
54
+
55
+ ```jsx
56
+ <select>
57
+ <option value="1">First option</option>
58
+ <option value="1">Second option</option>
59
+ </select>
60
+ ```
61
+
62
+ Though less common, sometimes the HTML schema puts tight restrictions on the kinds of children an element may contain:
63
+
64
+ - `<select>` elements may only contain `<option>` and `<optgroup>` children.
65
+ - `<ul>` may only contain `<li>` children.
66
+ - `<span>` elements may only contain [phrasing content](https://html.spec.whatwg.org/multipage/dom.html#phrasing-content-2).
67
+
68
+ Furthermore, for custom React components, there is a first-class approach for rendering your component's children:
69
+
70
+ ```jsx
71
+ function MyFancyBox({ children }) {
72
+ return <div style="border: 4px double cornflowerblue;">{children}</div>;
73
+ }
74
+
75
+ // usage
76
+ <MyFancyBox>I have a blue border!</MyFancyBox>;
77
+ ```
78
+
79
+ I call this "first class" because the JSX children that are defined between your component's opening and closing tags are wrapped up into a special prop called `children`. It is the component's responsibility to render those children in the appropriate spot.
80
+
81
+ **Clearly, this is a valid approach for a component API.**
82
+
83
+ ### Contents passed as data
84
+
85
+ An alternative approach is to accept data in the form of a prop, which eventually gets turned into a React element by the component's implementation. In plain HTML, this is far less common. One example is the `title` attribute, which results in a tooltip:
86
+
87
+ ```html
88
+ <button title="Save">💾</button>
89
+ ```
90
+
91
+ One _could_ imagine a parallel universe where a tooltip is achieved by some other means!
92
+
93
+ ```html
94
+ <button>
95
+ <title>Save</title>
96
+ 💾
97
+ </button>
98
+ ```
99
+
100
+ In custom React components, this pattern can be more common. In this example, the text to render is passed as a prop, as data rather than as pre-created React elements (i.e. JSX):
101
+
102
+ ```jsx
103
+ function WordWrap({ text, charactersPerLine }) {
104
+ const lines = [];
105
+ for (
106
+ let low = 0;
107
+ low + charactersPerLine < text.length;
108
+ low += charactersPerLine
109
+ ) {
110
+ lines.push(text.substr(low, charactersPerLine));
111
+ }
112
+ const remaining = text.length % charactersPerLine;
113
+ if (remaining !== 0) {
114
+ lines.push(text.substr(text.length - remaining));
115
+ }
116
+ return (
117
+ <>
118
+ {lines.map((l, index) => (
119
+ <div key={index + l}>{l}</div>
120
+ ))}
121
+ </>
122
+ );
123
+ }
124
+
125
+ // usage
126
+ <WordWrap
127
+ text="the quick brown fox jumps over the lazy dog"
128
+ charactersPerLine={5}
129
+ />;
130
+ ```
131
+
132
+ For further customization, one could imagine an optional `renderLine` prop that is used to give consumers control over the way a single line is rendered (see the section "Customization of content passed as data" below).
133
+
134
+ ## Can't we just stick to one of the two patterns?
135
+
136
+ As shown above, both patterns can be valid approaches based on the component. But _why_ did we choose the data API for `WordWrap`, and _why_ did we choose the React children API for `MyFancyBox`?
137
+
138
+ ### Let's try swapping
139
+
140
+ Since both patterns are equally powerful, we should be able to write equivalent components using the alternate approach.
141
+
142
+ #### MyFancyBox
143
+
144
+ Let's start with `MyFancyBox`:
145
+
146
+ ```jsx
147
+ function MyFancyBox({ contents }) {
148
+ const boxChildren = [];
149
+ if (typeof contents === "string" || React.isValidElement(contents)) {
150
+ boxChildren.push(contents);
151
+ } else if (typeof contents === "function") {
152
+ boxChildren.push(contents());
153
+ } // implementation abbreviated for clarity
154
+ return <div style="border: 4px double cornflowerblue;">{boxChildren}</div>;
155
+ }
156
+
157
+ // usage
158
+ <MyFancyBox contents="I have a blue border!" />;
159
+ ```
160
+
161
+ This example is so esoteric that I think it's obvious which is superior. The original has a less-complex implementation and a clearer API (in the second, just looking at the usage example, there is no way to know that contents can also accept a React element or a function callback).
162
+
163
+ #### WordWrap
164
+
165
+ Now let's dive into `WordWrap`, implemented with a React children-based API:
166
+
167
+ ```jsx
168
+ function WordWrap({ children, charactersPerLine }) {
169
+ const items = React.Children.toArray(children);
170
+ let textContent = "";
171
+ for (const child of items) {
172
+ if (typeof child === "string") {
173
+ textContent += child;
174
+ }
175
+ }
176
+ const lines = [];
177
+ for (
178
+ let low = 0;
179
+ low + charactersPerLine < textContent.length;
180
+ low += charactersPerLine
181
+ ) {
182
+ lines.push(textContent.substr(low, charactersPerLine));
183
+ }
184
+ const remaining = textContent.length % charactersPerLine;
185
+ if (remaining !== 0) {
186
+ lines.push(textContent.substr(textContent.length - remaining));
187
+ }
188
+ return (
189
+ <>
190
+ {lines.map((l, index) => (
191
+ <div key={index + l}>{l}</div>
192
+ ))}
193
+ </>
194
+ );
195
+ }
196
+
197
+ // usage
198
+ <WordWrap charactersPerLine={5}>
199
+ the quick brown fox jumps over the lazy dog
200
+ </WordWrap>;
201
+ ```
202
+
203
+ Let's get the obvious out of the way: the component implementation is more complex. Instead of receiving the raw text as a prop, the component has to iterate through its children, figure out which ones are text nodes, and build up the string.
204
+
205
+ But sometimes we are willing to make the sacrifice of increasing the complexity of our components if they become easier to use for our consumers. Is that what is happening here? One could argue that our new API is more straightforward and more readable! It's clear that the child text node of `WordWrap` will serve as the eventually-rendered contents, whereas the prop passed (`charactersPerLine`) is more of a configuration of the behavior.
206
+
207
+ On the other hand, if you are consuming this `WordWrap`, you might be left more confused. It is not clear without reading the code what is allowed as a child node. Can I include links or styled elements? How does it respond to receiving component children? In fact, if we want to the [principle of least surprise](https://en.wikipedia.org/wiki/Principle_of_least_astonishment), it may be necessary to support links or bolded text. While possible, this greatly increases the complexity of the component. Even if we do support this, it might be hard to discover this feature unless the user reads the docs or source code.
208
+
209
+ The first `WordWrap` implementation comparatively has a very strict API, easily discovered (with strong typing), and there is no possible way to use it which would produce a surprising result.
210
+
211
+ Because of the trade-offs described, I postulate that the first implementation of `WordWrap` is superior.
212
+
213
+ ### The hybrid approach
214
+
215
+ It is possible to build a component API that supports both patterns. In other words, the consumer can pass data as a prop, which gets rendered into React elements, while also accepting those children being passed in directly.
216
+
217
+ We do not recommend this approach. The resulting behavior can be very hard to predict. How do the elements generated from data interact with the passed-in children? How are they ordered? Furthermore, the approach likely does not improve the developer experience.
218
+
219
+ ## The ownership of React elements
220
+
221
+ I shall make the following claim:
222
+
223
+ > The owner of a React element is the component that _originally_ added it to the component tree.
224
+
225
+ For example, take the following two implementations of a simple (contrived) List component:
226
+
227
+ ```jsx
228
+ function List({ children, ordered }) {
229
+ const Elem = ordered ? "ol" : "ul";
230
+ return <Elem>{children}</Elem>;
231
+ }
232
+ function Item({ children }) {
233
+ return <li>{children}</li>;
234
+ }
235
+
236
+ // usage
237
+ function MyApp() {
238
+ return (
239
+ <List ordered={true}>
240
+ <Item>Apple</Item>
241
+ <Item>Banana</Item>
242
+ <Item>Cantaloupe</Item>
243
+ </List>
244
+ );
245
+ }
246
+ ```
247
+
248
+ ```jsx
249
+ function List({ items, ordered }) {
250
+ const Elem = ordered ? "ol" : "ul";
251
+ const listItems = items.map((i) => <li key={i}>i</li>);
252
+ return <Elem>{listItems}</Elem>;
253
+ }
254
+
255
+ // usage
256
+ function MyApp() {
257
+ return <List ordered={true} items={["Apple", "Banana", "Cantaloupe"]} />;
258
+ }
259
+ ```
260
+
261
+ In the first example, `MyApp` "owns" the `List` and its 3 `Item`s. In the second example, `MyApp` only "owns" `List`, while the `List` owns the `Item`s it renders.
262
+
263
+ Why do I bring this up? If you assume that the _owner_ of an element has the _highest authority_ to configure that element (i.e. change the element type, its props, and its children), then any component API should strive to be designed to respect this assumption.
264
+
265
+ I believe this is a reasonable assumption: an element owner should be able to expect that the element will be rendered as close to the definition as possible. Otherwise, this violates the principle of least surprise.
266
+
267
+ ### The `React.Children` anti-pattern
268
+ Based on the above assumption, using `React.Children` can be an anti-pattern. `React.Children` allows a component to reach into elements that it does not own. In our `WordWrap` example that uses React children, it is clear that we do not respect the owner (as defined above) of these elements. We iterate through children, ignoring anything that is not a text node.
269
+
270
+ With this reasoning, it's also easy to argue that `React.cloneElement` should be an anti-pattern. While that is true, there are ways to use `React.cloneElement` to simply augment children without altering their primary purpose or function. Adding additional props is a common use.
271
+
272
+ While anti-patterns sometimes have their valid uses, those uses should be individually scrutinized and avoided where possible.
273
+
274
+ ## Customization of content passed as data
275
+
276
+ One significant benefit to the contents as children pattern is the fact that it lends itself very naturally to customization. Since the parent owns the children, it can create whatever children it likes, deciding their props and element types. This level of customization can be achieved using the contents as data pattern too, but it's not quite as straightforward (for the component author or the component consumer).
277
+
278
+ One common practice is for a component to accept a "render prop." The render prop is a function that returns JSX (the same as a function component). That function should be passed any data that may be needed for rendering. Of course, components should ship with a default renderer and not rely on being passed a render prop.
279
+
280
+ ## How to decide
281
+
282
+ At this point we have shown that both patterns are valid, so how do we know which to use? Here is a comparison of the two approaches:
283
+
284
+ ### Advantages of data contract
285
+
286
+ - Strongly typed
287
+ - All use cases are clearly defined
288
+ - Easy to manipulate data
289
+ - Easy to define a "pit of success" and lead the user there
290
+ - Can support "escape hatches"
291
+ - Component retains ownership of rendered contents
292
+ - Usually less code in the implementation
293
+
294
+ ### Advantages of children-based contract
295
+
296
+ - Indicates flexibility
297
+ - Leaves room for a flexible implementation
298
+ - Recognizable from HTML
299
+ - Easier to read
300
+ - Ownership of contents remains with a parent or ancestor component
301
+
302
+ Based on these observations, here are some guidelines to decide which type of API to build:
303
+
304
+ ### When to use a data contract
305
+ - Data doesn't cleanly transfer to an element structure
306
+ - Data needs to be manipulated before being converted to an element structure
307
+ - Certain well-defined scenarios need to be supported
308
+ - You want to control the types and structure of child elements
309
+ - The default rendering of the component is useful in many cases
310
+ - You are building a composite component
311
+
312
+ ### When to use a children-based contract
313
+ - Your component doesn't care about the structure of children
314
+ - Your component doesn't need to use `React.Children`
315
+ - Your component is flexible enough to accommodate almost any child structure
316
+ - You are building an intermediate component that provides behaviors or styles to a container