@primer/components 32.0.0-rc.7200a6a6 → 32.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1096) hide show
  1. package/package.json +2 -2
  2. package/.changeset/README.md +0 -8
  3. package/.changeset/config.json +0 -10
  4. package/.devcontainer/devcontainer.json +0 -8
  5. package/.eslintrc.json +0 -137
  6. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -38
  7. package/.github/ISSUE_TEMPLATE/new_component_proposal_template.md +0 -41
  8. package/.github/dependabot.yml +0 -18
  9. package/.github/pull_request_template.md +0 -18
  10. package/.github/workflows/check_for_changeset.yml +0 -25
  11. package/.github/workflows/ci.yml +0 -34
  12. package/.github/workflows/deploy_preview.yml +0 -47
  13. package/.github/workflows/deploy_production.yml +0 -70
  14. package/.github/workflows/release.yml +0 -36
  15. package/.github/workflows/release_canary.yml +0 -72
  16. package/.github/workflows/release_candidate.yml +0 -60
  17. package/.github/workflows/size.yml +0 -13
  18. package/.github/workflows/stale.yml +0 -26
  19. package/.gitignore +0 -10
  20. package/.npmrc +0 -4
  21. package/.nvmrc +0 -1
  22. package/.storybook/main.js +0 -9
  23. package/.storybook/preview.js +0 -117
  24. package/.vscode/launch.json +0 -21
  25. package/.vscode/settings.json +0 -13
  26. package/@types/@styled-system/index.d.ts +0 -0
  27. package/@types/@styled-system/prop-types/index.d.ts +0 -1
  28. package/@types/@styled-system/props/index.d.ts +0 -1
  29. package/@types/jest-styled-components/index.d.ts +0 -1
  30. package/CODEOWNERS +0 -2
  31. package/babel-defines.js +0 -13
  32. package/babel.config.js +0 -39
  33. package/contributor-docs/CODE_OF_CONDUCT.md +0 -76
  34. package/contributor-docs/CONTRIBUTING.md +0 -274
  35. package/contributor-docs/adrs/adr-001-typescript.md +0 -23
  36. package/contributor-docs/adrs/adr-002-behavior-isolation.md +0 -108
  37. package/contributor-docs/adrs/adr-003-prop-norms.md +0 -72
  38. package/contributor-docs/behaviors.md +0 -132
  39. package/contributor-docs/component-contents-api-patterns.md +0 -316
  40. package/contributor-docs/principles.md +0 -39
  41. package/docs/.eslintrc +0 -0
  42. package/docs/.gitignore +0 -91
  43. package/docs/components/PropsList.js +0 -5
  44. package/docs/components/State.js +0 -9
  45. package/docs/components/constants.js +0 -34
  46. package/docs/components/index.js +0 -2
  47. package/docs/content/ActionList.mdx +0 -99
  48. package/docs/content/ActionList2.mdx +0 -359
  49. package/docs/content/ActionMenu.mdx +0 -80
  50. package/docs/content/AnchoredOverlay.mdx +0 -37
  51. package/docs/content/Autocomplete.mdx +0 -657
  52. package/docs/content/Avatar.mdx +0 -33
  53. package/docs/content/AvatarStack.mdx +0 -37
  54. package/docs/content/BorderBox.md +0 -46
  55. package/docs/content/Box.mdx +0 -96
  56. package/docs/content/BranchName.md +0 -18
  57. package/docs/content/Breadcrumbs.md +0 -47
  58. package/docs/content/Buttons.md +0 -46
  59. package/docs/content/CircleBadge.md +0 -35
  60. package/docs/content/CircleOcticon.md +0 -18
  61. package/docs/content/CounterLabel.md +0 -22
  62. package/docs/content/Details.md +0 -105
  63. package/docs/content/Dialog.md +0 -105
  64. package/docs/content/Dialog2.mdx +0 -180
  65. package/docs/content/Dropdown.md +0 -65
  66. package/docs/content/DropdownMenu.mdx +0 -49
  67. package/docs/content/FilterList.md +0 -37
  68. package/docs/content/FilteredSearch.md +0 -32
  69. package/docs/content/Flash.md +0 -35
  70. package/docs/content/Flex.md +0 -58
  71. package/docs/content/FormGroup.md +0 -38
  72. package/docs/content/Grid.md +0 -59
  73. package/docs/content/Header.md +0 -77
  74. package/docs/content/Heading.md +0 -22
  75. package/docs/content/Label.md +0 -49
  76. package/docs/content/LabelGroup.md +0 -21
  77. package/docs/content/Link.md +0 -28
  78. package/docs/content/Overlay.mdx +0 -85
  79. package/docs/content/Pagehead.md +0 -18
  80. package/docs/content/Pagination.md +0 -178
  81. package/docs/content/PointerBox.md +0 -81
  82. package/docs/content/Popover.md +0 -129
  83. package/docs/content/Portal.mdx +0 -78
  84. package/docs/content/Position.md +0 -100
  85. package/docs/content/ProgressBar.mdx +0 -29
  86. package/docs/content/SelectMenu.md +0 -371
  87. package/docs/content/SelectPanel.mdx +0 -67
  88. package/docs/content/SideNav.md +0 -171
  89. package/docs/content/Spinner.mdx +0 -32
  90. package/docs/content/StateLabel.md +0 -27
  91. package/docs/content/StyledOcticon.md +0 -27
  92. package/docs/content/SubNav.md +0 -100
  93. package/docs/content/TabNav.md +0 -42
  94. package/docs/content/Text.md +0 -31
  95. package/docs/content/TextInput.md +0 -34
  96. package/docs/content/TextInputTokens.mdx +0 -89
  97. package/docs/content/TextInputWithTokens.mdx +0 -211
  98. package/docs/content/Timeline.md +0 -148
  99. package/docs/content/Token.mdx +0 -381
  100. package/docs/content/Tooltip.md +0 -32
  101. package/docs/content/Truncate.md +0 -55
  102. package/docs/content/UnderlineNav.md +0 -45
  103. package/docs/content/anchoredPosition.mdx +0 -163
  104. package/docs/content/core-concepts.md +0 -70
  105. package/docs/content/focusTrap.mdx +0 -103
  106. package/docs/content/focusZone.mdx +0 -145
  107. package/docs/content/getting-started.md +0 -138
  108. package/docs/content/index.md +0 -33
  109. package/docs/content/linting.md +0 -35
  110. package/docs/content/overriding-styles.mdx +0 -82
  111. package/docs/content/philosophy.md +0 -23
  112. package/docs/content/primer-theme.md +0 -89
  113. package/docs/content/ssr.mdx +0 -43
  114. package/docs/content/system-props.mdx +0 -37
  115. package/docs/content/theme-reference.md +0 -16
  116. package/docs/content/theming.md +0 -272
  117. package/docs/content/useOnEscapePress.mdx +0 -56
  118. package/docs/content/useOnOutsideClick.mdx +0 -57
  119. package/docs/content/useOpenAndCloseFocus.mdx +0 -49
  120. package/docs/content/useOverlay.mdx +0 -62
  121. package/docs/content/useSafeTimeout.mdx +0 -32
  122. package/docs/gatsby-config.js +0 -30
  123. package/docs/gatsby-node.js +0 -101
  124. package/docs/package-lock.json +0 -20756
  125. package/docs/package.json +0 -36
  126. package/docs/src/@primer/gatsby-theme-doctocat/components/hero.js +0 -21
  127. package/docs/src/@primer/gatsby-theme-doctocat/components/live-preview-wrapper.js +0 -41
  128. package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +0 -73
  129. package/docs/src/@primer/gatsby-theme-doctocat/nav.yml +0 -133
  130. package/docs/src/@primer/gatsby-theme-doctocat/primer-components-hero.svg +0 -1411
  131. package/docs/src/component-checklist.js +0 -81
  132. package/docs/src/props.js +0 -77
  133. package/jest.config.js +0 -13
  134. package/lib/__tests__/ActionList.test.d.ts +0 -1
  135. package/lib/__tests__/ActionList.test.js +0 -69
  136. package/lib/__tests__/ActionList.test.jsx +0 -49
  137. package/lib/__tests__/ActionList.types.test.d.ts +0 -6
  138. package/lib/__tests__/ActionList.types.test.js +0 -69
  139. package/lib/__tests__/ActionList.types.test.jsx +0 -45
  140. package/lib/__tests__/ActionList2.test.d.ts +0 -1
  141. package/lib/__tests__/ActionList2.test.js +0 -53
  142. package/lib/__tests__/ActionList2.test.jsx +0 -46
  143. package/lib/__tests__/ActionMenu.test.d.ts +0 -1
  144. package/lib/__tests__/ActionMenu.test.js +0 -151
  145. package/lib/__tests__/ActionMenu.test.jsx +0 -124
  146. package/lib/__tests__/AnchoredOverlay.test.d.ts +0 -1
  147. package/lib/__tests__/AnchoredOverlay.test.js +0 -162
  148. package/lib/__tests__/AnchoredOverlay.test.jsx +0 -121
  149. package/lib/__tests__/Autocomplete.test.d.ts +0 -1
  150. package/lib/__tests__/Autocomplete.test.js +0 -528
  151. package/lib/__tests__/Autocomplete.test.jsx +0 -299
  152. package/lib/__tests__/Avatar.test.d.ts +0 -1
  153. package/lib/__tests__/Avatar.test.js +0 -67
  154. package/lib/__tests__/Avatar.test.jsx +0 -42
  155. package/lib/__tests__/AvatarStack.test.d.ts +0 -1
  156. package/lib/__tests__/AvatarStack.test.js +0 -71
  157. package/lib/__tests__/AvatarStack.test.jsx +0 -43
  158. package/lib/__tests__/BorderBox.test.d.ts +0 -1
  159. package/lib/__tests__/BorderBox.test.js +0 -58
  160. package/lib/__tests__/BorderBox.test.jsx +0 -36
  161. package/lib/__tests__/Box.test.d.ts +0 -1
  162. package/lib/__tests__/Box.test.js +0 -78
  163. package/lib/__tests__/Box.test.jsx +0 -41
  164. package/lib/__tests__/BranchName.test.d.ts +0 -1
  165. package/lib/__tests__/BranchName.test.js +0 -36
  166. package/lib/__tests__/BranchName.test.jsx +0 -27
  167. package/lib/__tests__/Breadcrumbs.test.d.ts +0 -1
  168. package/lib/__tests__/Breadcrumbs.test.js +0 -40
  169. package/lib/__tests__/Breadcrumbs.test.jsx +0 -28
  170. package/lib/__tests__/Breadcrumbs.types.test.d.ts +0 -3
  171. package/lib/__tests__/Breadcrumbs.types.test.js +0 -25
  172. package/lib/__tests__/Breadcrumbs.types.test.jsx +0 -24
  173. package/lib/__tests__/BreadcrumbsItem.test.d.ts +0 -1
  174. package/lib/__tests__/BreadcrumbsItem.test.js +0 -49
  175. package/lib/__tests__/BreadcrumbsItem.test.jsx +0 -31
  176. package/lib/__tests__/Button.test.d.ts +0 -1
  177. package/lib/__tests__/Button.test.js +0 -147
  178. package/lib/__tests__/Button.test.jsx +0 -100
  179. package/lib/__tests__/Caret.test.d.ts +0 -1
  180. package/lib/__tests__/Caret.test.js +0 -52
  181. package/lib/__tests__/Caret.test.jsx +0 -37
  182. package/lib/__tests__/CircleBadge.test.d.ts +0 -1
  183. package/lib/__tests__/CircleBadge.test.js +0 -83
  184. package/lib/__tests__/CircleBadge.test.jsx +0 -55
  185. package/lib/__tests__/CircleBadge.types.test.d.ts +0 -3
  186. package/lib/__tests__/CircleBadge.types.test.js +0 -28
  187. package/lib/__tests__/CircleBadge.types.test.jsx +0 -17
  188. package/lib/__tests__/CircleOcticon.test.d.ts +0 -1
  189. package/lib/__tests__/CircleOcticon.test.js +0 -71
  190. package/lib/__tests__/CircleOcticon.test.jsx +0 -45
  191. package/lib/__tests__/ConfirmationDialog.test.d.ts +0 -1
  192. package/lib/__tests__/ConfirmationDialog.test.js +0 -134
  193. package/lib/__tests__/ConfirmationDialog.test.jsx +0 -119
  194. package/lib/__tests__/CounterLabel.test.d.ts +0 -1
  195. package/lib/__tests__/CounterLabel.test.js +0 -58
  196. package/lib/__tests__/CounterLabel.test.jsx +0 -36
  197. package/lib/__tests__/CounterLabel.types.test.d.ts +0 -3
  198. package/lib/__tests__/CounterLabel.types.test.js +0 -28
  199. package/lib/__tests__/CounterLabel.types.test.jsx +0 -17
  200. package/lib/__tests__/Details.test.d.ts +0 -1
  201. package/lib/__tests__/Details.test.js +0 -117
  202. package/lib/__tests__/Details.test.jsx +0 -85
  203. package/lib/__tests__/Dialog.test.d.ts +0 -1
  204. package/lib/__tests__/Dialog.test.js +0 -184
  205. package/lib/__tests__/Dialog.test.jsx +0 -139
  206. package/lib/__tests__/Dialog.types.test.d.ts +0 -3
  207. package/lib/__tests__/Dialog.types.test.js +0 -28
  208. package/lib/__tests__/Dialog.types.test.jsx +0 -17
  209. package/lib/__tests__/Dialog2.types.test.d.ts +0 -3
  210. package/lib/__tests__/Dialog2.types.test.js +0 -31
  211. package/lib/__tests__/Dialog2.types.test.jsx +0 -17
  212. package/lib/__tests__/Dropdown.test.d.ts +0 -1
  213. package/lib/__tests__/Dropdown.test.js +0 -63
  214. package/lib/__tests__/Dropdown.test.jsx +0 -49
  215. package/lib/__tests__/Dropdown.types.test.d.ts +0 -3
  216. package/lib/__tests__/Dropdown.types.test.js +0 -31
  217. package/lib/__tests__/Dropdown.types.test.jsx +0 -25
  218. package/lib/__tests__/DropdownMenu.test.d.ts +0 -1
  219. package/lib/__tests__/DropdownMenu.test.js +0 -150
  220. package/lib/__tests__/DropdownMenu.test.jsx +0 -119
  221. package/lib/__tests__/FilterList.test.d.ts +0 -1
  222. package/lib/__tests__/FilterList.test.js +0 -36
  223. package/lib/__tests__/FilterList.test.jsx +0 -27
  224. package/lib/__tests__/FilterList.types.test.d.ts +0 -3
  225. package/lib/__tests__/FilterList.types.test.js +0 -27
  226. package/lib/__tests__/FilterList.types.test.jsx +0 -21
  227. package/lib/__tests__/FilterListItem.test.d.ts +0 -1
  228. package/lib/__tests__/FilterListItem.test.js +0 -46
  229. package/lib/__tests__/FilterListItem.test.jsx +0 -31
  230. package/lib/__tests__/FilteredSearch.test.d.ts +0 -1
  231. package/lib/__tests__/FilteredSearch.test.js +0 -36
  232. package/lib/__tests__/FilteredSearch.test.jsx +0 -27
  233. package/lib/__tests__/FilteredSearch.types.test.d.ts +0 -3
  234. package/lib/__tests__/FilteredSearch.types.test.js +0 -28
  235. package/lib/__tests__/FilteredSearch.types.test.jsx +0 -17
  236. package/lib/__tests__/Flash.test.d.ts +0 -1
  237. package/lib/__tests__/Flash.test.js +0 -62
  238. package/lib/__tests__/Flash.test.jsx +0 -36
  239. package/lib/__tests__/Flash.types.test.d.ts +0 -3
  240. package/lib/__tests__/Flash.types.test.js +0 -28
  241. package/lib/__tests__/Flash.types.test.jsx +0 -17
  242. package/lib/__tests__/Flex.test.d.ts +0 -1
  243. package/lib/__tests__/Flex.test.js +0 -74
  244. package/lib/__tests__/Flex.test.jsx +0 -51
  245. package/lib/__tests__/FormGroup.test.d.ts +0 -1
  246. package/lib/__tests__/FormGroup.test.js +0 -54
  247. package/lib/__tests__/FormGroup.test.jsx +0 -36
  248. package/lib/__tests__/FormGroup.types.test.d.ts +0 -3
  249. package/lib/__tests__/FormGroup.types.test.js +0 -28
  250. package/lib/__tests__/FormGroup.types.test.jsx +0 -17
  251. package/lib/__tests__/Grid.test.d.ts +0 -1
  252. package/lib/__tests__/Grid.test.js +0 -104
  253. package/lib/__tests__/Grid.test.jsx +0 -69
  254. package/lib/__tests__/Header.test.d.ts +0 -1
  255. package/lib/__tests__/Header.test.js +0 -58
  256. package/lib/__tests__/Header.test.jsx +0 -45
  257. package/lib/__tests__/Header.types.test.d.ts +0 -3
  258. package/lib/__tests__/Header.types.test.js +0 -29
  259. package/lib/__tests__/Header.types.test.jsx +0 -23
  260. package/lib/__tests__/Heading.test.d.ts +0 -1
  261. package/lib/__tests__/Heading.test.js +0 -109
  262. package/lib/__tests__/Heading.test.jsx +0 -71
  263. package/lib/__tests__/KeyPaths.types.test.d.ts +0 -11
  264. package/lib/__tests__/KeyPaths.types.test.js +0 -7
  265. package/lib/__tests__/Label.test.d.ts +0 -1
  266. package/lib/__tests__/Label.test.js +0 -46
  267. package/lib/__tests__/Label.test.jsx +0 -33
  268. package/lib/__tests__/Label.types.test.d.ts +0 -3
  269. package/lib/__tests__/Label.types.test.js +0 -28
  270. package/lib/__tests__/Label.types.test.jsx +0 -17
  271. package/lib/__tests__/LabelGroup.test.d.ts +0 -1
  272. package/lib/__tests__/LabelGroup.test.js +0 -38
  273. package/lib/__tests__/LabelGroup.test.jsx +0 -29
  274. package/lib/__tests__/LabelGroup.types.test.d.ts +0 -3
  275. package/lib/__tests__/LabelGroup.types.test.js +0 -28
  276. package/lib/__tests__/LabelGroup.types.test.jsx +0 -17
  277. package/lib/__tests__/Link.test.d.ts +0 -1
  278. package/lib/__tests__/Link.test.js +0 -76
  279. package/lib/__tests__/Link.test.jsx +0 -43
  280. package/lib/__tests__/Link.types.test.d.ts +0 -3
  281. package/lib/__tests__/Link.types.test.js +0 -28
  282. package/lib/__tests__/Link.types.test.jsx +0 -17
  283. package/lib/__tests__/Merge.types.test.d.ts +0 -30
  284. package/lib/__tests__/Merge.types.test.js +0 -21
  285. package/lib/__tests__/NewButton.test.d.ts +0 -1
  286. package/lib/__tests__/NewButton.test.js +0 -95
  287. package/lib/__tests__/NewButton.test.jsx +0 -61
  288. package/lib/__tests__/Overlay.test.d.ts +0 -1
  289. package/lib/__tests__/Overlay.test.js +0 -145
  290. package/lib/__tests__/Overlay.test.jsx +0 -105
  291. package/lib/__tests__/Overlay.types.test.d.ts +0 -3
  292. package/lib/__tests__/Overlay.types.test.js +0 -35
  293. package/lib/__tests__/Overlay.types.test.jsx +0 -18
  294. package/lib/__tests__/Pagehead.test.d.ts +0 -1
  295. package/lib/__tests__/Pagehead.test.js +0 -37
  296. package/lib/__tests__/Pagehead.test.jsx +0 -25
  297. package/lib/__tests__/Pagehead.types.test.d.ts +0 -3
  298. package/lib/__tests__/Pagehead.types.test.js +0 -28
  299. package/lib/__tests__/Pagehead.types.test.jsx +0 -17
  300. package/lib/__tests__/Pagination/Pagination.test.d.ts +0 -1
  301. package/lib/__tests__/Pagination/Pagination.test.js +0 -47
  302. package/lib/__tests__/Pagination/Pagination.test.jsx +0 -32
  303. package/lib/__tests__/Pagination/PaginationModel.test.d.ts +0 -1
  304. package/lib/__tests__/Pagination/PaginationModel.test.js +0 -186
  305. package/lib/__tests__/Pagination/PaginationModel.test.jsx +0 -118
  306. package/lib/__tests__/Pagination.types.test.d.ts +0 -3
  307. package/lib/__tests__/Pagination.types.test.js +0 -33
  308. package/lib/__tests__/Pagination.types.test.jsx +0 -17
  309. package/lib/__tests__/PointerBox.test.d.ts +0 -1
  310. package/lib/__tests__/PointerBox.test.js +0 -46
  311. package/lib/__tests__/PointerBox.test.jsx +0 -33
  312. package/lib/__tests__/Popover.test.d.ts +0 -1
  313. package/lib/__tests__/Popover.test.js +0 -66
  314. package/lib/__tests__/Popover.test.jsx +0 -58
  315. package/lib/__tests__/Popover.types.test.d.ts +0 -3
  316. package/lib/__tests__/Popover.types.test.js +0 -27
  317. package/lib/__tests__/Popover.types.test.jsx +0 -21
  318. package/lib/__tests__/Portal.test.d.ts +0 -1
  319. package/lib/__tests__/Portal.test.js +0 -124
  320. package/lib/__tests__/Portal.test.jsx +0 -102
  321. package/lib/__tests__/Position.test.d.ts +0 -1
  322. package/lib/__tests__/Position.test.js +0 -143
  323. package/lib/__tests__/Position.test.jsx +0 -96
  324. package/lib/__tests__/ProgressBar.test.d.ts +0 -1
  325. package/lib/__tests__/ProgressBar.test.js +0 -68
  326. package/lib/__tests__/ProgressBar.test.jsx +0 -38
  327. package/lib/__tests__/SelectMenu.test.d.ts +0 -1
  328. package/lib/__tests__/SelectMenu.test.js +0 -155
  329. package/lib/__tests__/SelectMenu.test.jsx +0 -120
  330. package/lib/__tests__/SelectMenu.types.test.d.ts +0 -3
  331. package/lib/__tests__/SelectMenu.types.test.js +0 -47
  332. package/lib/__tests__/SelectMenu.types.test.jsx +0 -41
  333. package/lib/__tests__/SelectPanel.test.d.ts +0 -1
  334. package/lib/__tests__/SelectPanel.test.js +0 -80
  335. package/lib/__tests__/SelectPanel.test.jsx +0 -48
  336. package/lib/__tests__/SideNav.test.d.ts +0 -1
  337. package/lib/__tests__/SideNav.test.js +0 -71
  338. package/lib/__tests__/SideNav.test.jsx +0 -55
  339. package/lib/__tests__/SideNav.types.test.d.ts +0 -3
  340. package/lib/__tests__/SideNav.types.test.js +0 -28
  341. package/lib/__tests__/SideNav.types.test.jsx +0 -17
  342. package/lib/__tests__/Spinner.test.d.ts +0 -1
  343. package/lib/__tests__/Spinner.test.js +0 -53
  344. package/lib/__tests__/Spinner.test.jsx +0 -41
  345. package/lib/__tests__/StateLabel.test.d.ts +0 -1
  346. package/lib/__tests__/StateLabel.test.js +0 -71
  347. package/lib/__tests__/StateLabel.test.jsx +0 -46
  348. package/lib/__tests__/StateLabel.types.test.d.ts +0 -3
  349. package/lib/__tests__/StateLabel.types.test.js +0 -28
  350. package/lib/__tests__/StateLabel.types.test.jsx +0 -17
  351. package/lib/__tests__/StyledOcticon.test.d.ts +0 -1
  352. package/lib/__tests__/StyledOcticon.test.js +0 -40
  353. package/lib/__tests__/StyledOcticon.test.jsx +0 -28
  354. package/lib/__tests__/StyledOcticon.types.test.d.ts +0 -3
  355. package/lib/__tests__/StyledOcticon.types.test.js +0 -32
  356. package/lib/__tests__/StyledOcticon.types.test.jsx +0 -18
  357. package/lib/__tests__/SubNav.test.d.ts +0 -1
  358. package/lib/__tests__/SubNav.test.js +0 -62
  359. package/lib/__tests__/SubNav.test.jsx +0 -47
  360. package/lib/__tests__/SubNav.types.test.d.ts +0 -3
  361. package/lib/__tests__/SubNav.types.test.js +0 -27
  362. package/lib/__tests__/SubNav.types.test.jsx +0 -27
  363. package/lib/__tests__/SubNavLink.test.d.ts +0 -1
  364. package/lib/__tests__/SubNavLink.test.js +0 -49
  365. package/lib/__tests__/SubNavLink.test.jsx +0 -31
  366. package/lib/__tests__/TabNav.test.d.ts +0 -1
  367. package/lib/__tests__/TabNav.test.js +0 -49
  368. package/lib/__tests__/TabNav.test.jsx +0 -32
  369. package/lib/__tests__/TabNav.types.test.d.ts +0 -3
  370. package/lib/__tests__/TabNav.types.test.js +0 -25
  371. package/lib/__tests__/TabNav.types.test.jsx +0 -24
  372. package/lib/__tests__/Text.test.d.ts +0 -1
  373. package/lib/__tests__/Text.test.js +0 -105
  374. package/lib/__tests__/Text.test.jsx +0 -71
  375. package/lib/__tests__/TextInput.test.d.ts +0 -1
  376. package/lib/__tests__/TextInput.test.js +0 -78
  377. package/lib/__tests__/TextInput.test.jsx +0 -45
  378. package/lib/__tests__/TextInputWithTokens.test.d.ts +0 -1
  379. package/lib/__tests__/TextInputWithTokens.test.js +0 -572
  380. package/lib/__tests__/TextInputWithTokens.test.jsx +0 -302
  381. package/lib/__tests__/ThemeProvider.test.d.ts +0 -1
  382. package/lib/__tests__/ThemeProvider.test.js +0 -444
  383. package/lib/__tests__/ThemeProvider.test.jsx +0 -314
  384. package/lib/__tests__/Timeline.test.d.ts +0 -1
  385. package/lib/__tests__/Timeline.test.js +0 -75
  386. package/lib/__tests__/Timeline.test.jsx +0 -51
  387. package/lib/__tests__/Timeline.types.test.d.ts +0 -3
  388. package/lib/__tests__/Timeline.types.test.js +0 -31
  389. package/lib/__tests__/Timeline.types.test.jsx +0 -33
  390. package/lib/__tests__/Token.test.d.ts +0 -1
  391. package/lib/__tests__/Token.test.js +0 -180
  392. package/lib/__tests__/Token.test.jsx +0 -93
  393. package/lib/__tests__/Tooltip.test.d.ts +0 -1
  394. package/lib/__tests__/Tooltip.test.js +0 -69
  395. package/lib/__tests__/Tooltip.test.jsx +0 -46
  396. package/lib/__tests__/Tooltip.types.test.d.ts +0 -3
  397. package/lib/__tests__/Tooltip.types.test.js +0 -28
  398. package/lib/__tests__/Tooltip.types.test.jsx +0 -17
  399. package/lib/__tests__/Truncate.test.d.ts +0 -1
  400. package/lib/__tests__/Truncate.test.js +0 -63
  401. package/lib/__tests__/Truncate.test.jsx +0 -41
  402. package/lib/__tests__/Truncate.types.test.d.ts +0 -3
  403. package/lib/__tests__/Truncate.types.test.js +0 -31
  404. package/lib/__tests__/Truncate.types.test.jsx +0 -17
  405. package/lib/__tests__/UnderlineNav.test.d.ts +0 -1
  406. package/lib/__tests__/UnderlineNav.test.js +0 -72
  407. package/lib/__tests__/UnderlineNav.test.jsx +0 -53
  408. package/lib/__tests__/UnderlineNav.types.test.d.ts +0 -3
  409. package/lib/__tests__/UnderlineNav.types.test.js +0 -25
  410. package/lib/__tests__/UnderlineNav.types.test.jsx +0 -24
  411. package/lib/__tests__/UnderlineNavLink.test.d.ts +0 -1
  412. package/lib/__tests__/UnderlineNavLink.test.js +0 -51
  413. package/lib/__tests__/UnderlineNavLink.test.jsx +0 -31
  414. package/lib/__tests__/behaviors/anchoredPosition.test.d.ts +0 -1
  415. package/lib/__tests__/behaviors/anchoredPosition.test.js +0 -243
  416. package/lib/__tests__/behaviors/focusTrap.test.d.ts +0 -1
  417. package/lib/__tests__/behaviors/focusTrap.test.js +0 -234
  418. package/lib/__tests__/behaviors/focusTrap.test.jsx +0 -184
  419. package/lib/__tests__/behaviors/focusZone.test.d.ts +0 -1
  420. package/lib/__tests__/behaviors/focusZone.test.js +0 -570
  421. package/lib/__tests__/behaviors/focusZone.test.jsx +0 -406
  422. package/lib/__tests__/behaviors/iterateFocusableElements.test.d.ts +0 -1
  423. package/lib/__tests__/behaviors/iterateFocusableElements.test.js +0 -55
  424. package/lib/__tests__/behaviors/iterateFocusableElements.test.jsx +0 -58
  425. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +0 -1
  426. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.js +0 -155
  427. package/lib/__tests__/filterObject.test.d.ts +0 -1
  428. package/lib/__tests__/filterObject.test.js +0 -51
  429. package/lib/__tests__/hooks/useAnchoredPosition.test.d.ts +0 -1
  430. package/lib/__tests__/hooks/useAnchoredPosition.test.js +0 -54
  431. package/lib/__tests__/hooks/useAnchoredPosition.test.jsx +0 -29
  432. package/lib/__tests__/hooks/useOnEscapePress.test.d.ts +0 -1
  433. package/lib/__tests__/hooks/useOnEscapePress.test.js +0 -32
  434. package/lib/__tests__/hooks/useOnEscapePress.test.jsx +0 -19
  435. package/lib/__tests__/hooks/useOnOutsideClick.test.d.ts +0 -1
  436. package/lib/__tests__/hooks/useOnOutsideClick.test.js +0 -87
  437. package/lib/__tests__/hooks/useOnOutsideClick.test.jsx +0 -63
  438. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +0 -1
  439. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.js +0 -60
  440. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.jsx +0 -61
  441. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +0 -1
  442. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.js +0 -45
  443. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.jsx +0 -56
  444. package/lib/__tests__/theme.test.d.ts +0 -1
  445. package/lib/__tests__/theme.test.js +0 -35
  446. package/lib/__tests__/themeGet.test.d.ts +0 -1
  447. package/lib/__tests__/themeGet.test.js +0 -14
  448. package/lib/__tests__/useSafeTimeout.test.d.ts +0 -1
  449. package/lib/__tests__/useSafeTimeout.test.js +0 -45
  450. package/lib/__tests__/useSafeTimeout.test.jsx +0 -36
  451. package/lib/__tests__/utils/createSlots.test.d.ts +0 -1
  452. package/lib/__tests__/utils/createSlots.test.js +0 -75
  453. package/lib/__tests__/utils/createSlots.test.jsx +0 -57
  454. package/lib/stories/ActionList.stories.js +0 -454
  455. package/lib/stories/ActionList2.stories.js +0 -909
  456. package/lib/stories/ActionMenu.stories.js +0 -348
  457. package/lib/stories/AnchoredOverlay.stories.js +0 -127
  458. package/lib/stories/Autocomplete.stories.js +0 -619
  459. package/lib/stories/AvatarStack.stories.js +0 -49
  460. package/lib/stories/Button.stories.js +0 -125
  461. package/lib/stories/ConfirmationDialog.stories.js +0 -119
  462. package/lib/stories/Dialog.stories.js +0 -269
  463. package/lib/stories/DropdownMenu.stories.js +0 -122
  464. package/lib/stories/IssueLabelToken.stories.js +0 -165
  465. package/lib/stories/NewButton.stories.js +0 -230
  466. package/lib/stories/Overlay.stories.js +0 -204
  467. package/lib/stories/Portal.stories.js +0 -104
  468. package/lib/stories/ProfileToken.stories.js +0 -162
  469. package/lib/stories/SelectPanel.stories.js +0 -399
  470. package/lib/stories/TextInput.stories.js +0 -144
  471. package/lib/stories/TextInputWithTokens.stories.js +0 -252
  472. package/lib/stories/ThemeProvider.stories.js +0 -102
  473. package/lib/stories/Token.stories.js +0 -176
  474. package/lib/stories/useAnchoredPosition.stories.js +0 -351
  475. package/lib/stories/useFocusTrap.stories.js +0 -360
  476. package/lib/stories/useFocusZone.stories.js +0 -607
  477. package/lib-esm/__tests__/ActionList.test.d.ts +0 -1
  478. package/lib-esm/__tests__/ActionList.test.js +0 -57
  479. package/lib-esm/__tests__/ActionList.types.test.d.ts +0 -6
  480. package/lib-esm/__tests__/ActionList.types.test.js +0 -45
  481. package/lib-esm/__tests__/ActionList2.test.d.ts +0 -1
  482. package/lib-esm/__tests__/ActionList2.test.js +0 -41
  483. package/lib-esm/__tests__/ActionMenu.test.d.ts +0 -1
  484. package/lib-esm/__tests__/ActionMenu.test.js +0 -139
  485. package/lib-esm/__tests__/AnchoredOverlay.test.d.ts +0 -1
  486. package/lib-esm/__tests__/AnchoredOverlay.test.js +0 -136
  487. package/lib-esm/__tests__/Autocomplete.test.d.ts +0 -1
  488. package/lib-esm/__tests__/Autocomplete.test.js +0 -494
  489. package/lib-esm/__tests__/Avatar.test.d.ts +0 -1
  490. package/lib-esm/__tests__/Avatar.test.js +0 -56
  491. package/lib-esm/__tests__/AvatarStack.test.d.ts +0 -1
  492. package/lib-esm/__tests__/AvatarStack.test.js +0 -58
  493. package/lib-esm/__tests__/BorderBox.test.d.ts +0 -1
  494. package/lib-esm/__tests__/BorderBox.test.js +0 -47
  495. package/lib-esm/__tests__/Box.test.d.ts +0 -1
  496. package/lib-esm/__tests__/Box.test.js +0 -67
  497. package/lib-esm/__tests__/BranchName.test.d.ts +0 -1
  498. package/lib-esm/__tests__/BranchName.test.js +0 -26
  499. package/lib-esm/__tests__/Breadcrumbs.test.d.ts +0 -1
  500. package/lib-esm/__tests__/Breadcrumbs.test.js +0 -30
  501. package/lib-esm/__tests__/Breadcrumbs.types.test.d.ts +0 -3
  502. package/lib-esm/__tests__/Breadcrumbs.types.test.js +0 -12
  503. package/lib-esm/__tests__/BreadcrumbsItem.test.d.ts +0 -1
  504. package/lib-esm/__tests__/BreadcrumbsItem.test.js +0 -39
  505. package/lib-esm/__tests__/Button.test.d.ts +0 -1
  506. package/lib-esm/__tests__/Button.test.js +0 -137
  507. package/lib-esm/__tests__/Caret.test.d.ts +0 -1
  508. package/lib-esm/__tests__/Caret.test.js +0 -42
  509. package/lib-esm/__tests__/CircleBadge.test.d.ts +0 -1
  510. package/lib-esm/__tests__/CircleBadge.test.js +0 -70
  511. package/lib-esm/__tests__/CircleBadge.types.test.d.ts +0 -3
  512. package/lib-esm/__tests__/CircleBadge.types.test.js +0 -13
  513. package/lib-esm/__tests__/CircleOcticon.test.d.ts +0 -1
  514. package/lib-esm/__tests__/CircleOcticon.test.js +0 -59
  515. package/lib-esm/__tests__/ConfirmationDialog.test.d.ts +0 -1
  516. package/lib-esm/__tests__/ConfirmationDialog.test.js +0 -113
  517. package/lib-esm/__tests__/CounterLabel.test.d.ts +0 -1
  518. package/lib-esm/__tests__/CounterLabel.test.js +0 -47
  519. package/lib-esm/__tests__/CounterLabel.types.test.d.ts +0 -3
  520. package/lib-esm/__tests__/CounterLabel.types.test.js +0 -13
  521. package/lib-esm/__tests__/Details.test.d.ts +0 -1
  522. package/lib-esm/__tests__/Details.test.js +0 -107
  523. package/lib-esm/__tests__/Dialog.test.d.ts +0 -1
  524. package/lib-esm/__tests__/Dialog.test.js +0 -171
  525. package/lib-esm/__tests__/Dialog.types.test.d.ts +0 -3
  526. package/lib-esm/__tests__/Dialog.types.test.js +0 -13
  527. package/lib-esm/__tests__/Dialog2.types.test.d.ts +0 -3
  528. package/lib-esm/__tests__/Dialog2.types.test.js +0 -16
  529. package/lib-esm/__tests__/Dropdown.test.d.ts +0 -1
  530. package/lib-esm/__tests__/Dropdown.test.js +0 -53
  531. package/lib-esm/__tests__/Dropdown.types.test.d.ts +0 -3
  532. package/lib-esm/__tests__/Dropdown.types.test.js +0 -17
  533. package/lib-esm/__tests__/DropdownMenu.test.d.ts +0 -1
  534. package/lib-esm/__tests__/DropdownMenu.test.js +0 -137
  535. package/lib-esm/__tests__/FilterList.test.d.ts +0 -1
  536. package/lib-esm/__tests__/FilterList.test.js +0 -26
  537. package/lib-esm/__tests__/FilterList.types.test.d.ts +0 -3
  538. package/lib-esm/__tests__/FilterList.types.test.js +0 -13
  539. package/lib-esm/__tests__/FilterListItem.test.d.ts +0 -1
  540. package/lib-esm/__tests__/FilterListItem.test.js +0 -36
  541. package/lib-esm/__tests__/FilteredSearch.test.d.ts +0 -1
  542. package/lib-esm/__tests__/FilteredSearch.test.js +0 -26
  543. package/lib-esm/__tests__/FilteredSearch.types.test.d.ts +0 -3
  544. package/lib-esm/__tests__/FilteredSearch.types.test.js +0 -13
  545. package/lib-esm/__tests__/Flash.test.d.ts +0 -1
  546. package/lib-esm/__tests__/Flash.test.js +0 -51
  547. package/lib-esm/__tests__/Flash.types.test.d.ts +0 -3
  548. package/lib-esm/__tests__/Flash.types.test.js +0 -13
  549. package/lib-esm/__tests__/Flex.test.d.ts +0 -1
  550. package/lib-esm/__tests__/Flex.test.js +0 -64
  551. package/lib-esm/__tests__/FormGroup.test.d.ts +0 -1
  552. package/lib-esm/__tests__/FormGroup.test.js +0 -44
  553. package/lib-esm/__tests__/FormGroup.types.test.d.ts +0 -3
  554. package/lib-esm/__tests__/FormGroup.types.test.js +0 -13
  555. package/lib-esm/__tests__/Grid.test.d.ts +0 -1
  556. package/lib-esm/__tests__/Grid.test.js +0 -94
  557. package/lib-esm/__tests__/Header.test.d.ts +0 -1
  558. package/lib-esm/__tests__/Header.test.js +0 -48
  559. package/lib-esm/__tests__/Header.types.test.d.ts +0 -3
  560. package/lib-esm/__tests__/Header.types.test.js +0 -15
  561. package/lib-esm/__tests__/Heading.test.d.ts +0 -1
  562. package/lib-esm/__tests__/Heading.test.js +0 -99
  563. package/lib-esm/__tests__/KeyPaths.types.test.d.ts +0 -11
  564. package/lib-esm/__tests__/KeyPaths.types.test.js +0 -3
  565. package/lib-esm/__tests__/Label.test.d.ts +0 -1
  566. package/lib-esm/__tests__/Label.test.js +0 -36
  567. package/lib-esm/__tests__/Label.types.test.d.ts +0 -3
  568. package/lib-esm/__tests__/Label.types.test.js +0 -13
  569. package/lib-esm/__tests__/LabelGroup.test.d.ts +0 -1
  570. package/lib-esm/__tests__/LabelGroup.test.js +0 -26
  571. package/lib-esm/__tests__/LabelGroup.types.test.d.ts +0 -3
  572. package/lib-esm/__tests__/LabelGroup.types.test.js +0 -13
  573. package/lib-esm/__tests__/Link.test.d.ts +0 -1
  574. package/lib-esm/__tests__/Link.test.js +0 -66
  575. package/lib-esm/__tests__/Link.types.test.d.ts +0 -3
  576. package/lib-esm/__tests__/Link.types.test.js +0 -13
  577. package/lib-esm/__tests__/Merge.types.test.d.ts +0 -30
  578. package/lib-esm/__tests__/Merge.types.test.js +0 -14
  579. package/lib-esm/__tests__/NewButton.test.d.ts +0 -1
  580. package/lib-esm/__tests__/NewButton.test.js +0 -84
  581. package/lib-esm/__tests__/Overlay.test.d.ts +0 -1
  582. package/lib-esm/__tests__/Overlay.test.js +0 -123
  583. package/lib-esm/__tests__/Overlay.types.test.d.ts +0 -3
  584. package/lib-esm/__tests__/Overlay.types.test.js +0 -20
  585. package/lib-esm/__tests__/Pagehead.test.d.ts +0 -1
  586. package/lib-esm/__tests__/Pagehead.test.js +0 -26
  587. package/lib-esm/__tests__/Pagehead.types.test.d.ts +0 -3
  588. package/lib-esm/__tests__/Pagehead.types.test.js +0 -13
  589. package/lib-esm/__tests__/Pagination/Pagination.test.d.ts +0 -1
  590. package/lib-esm/__tests__/Pagination/Pagination.test.js +0 -35
  591. package/lib-esm/__tests__/Pagination/PaginationModel.test.d.ts +0 -1
  592. package/lib-esm/__tests__/Pagination/PaginationModel.test.js +0 -182
  593. package/lib-esm/__tests__/Pagination.types.test.d.ts +0 -3
  594. package/lib-esm/__tests__/Pagination.types.test.js +0 -18
  595. package/lib-esm/__tests__/PointerBox.test.d.ts +0 -1
  596. package/lib-esm/__tests__/PointerBox.test.js +0 -36
  597. package/lib-esm/__tests__/Popover.test.d.ts +0 -1
  598. package/lib-esm/__tests__/Popover.test.js +0 -53
  599. package/lib-esm/__tests__/Popover.types.test.d.ts +0 -3
  600. package/lib-esm/__tests__/Popover.types.test.js +0 -13
  601. package/lib-esm/__tests__/Portal.test.d.ts +0 -1
  602. package/lib-esm/__tests__/Portal.test.js +0 -104
  603. package/lib-esm/__tests__/Position.test.d.ts +0 -1
  604. package/lib-esm/__tests__/Position.test.js +0 -133
  605. package/lib-esm/__tests__/ProgressBar.test.d.ts +0 -1
  606. package/lib-esm/__tests__/ProgressBar.test.js +0 -58
  607. package/lib-esm/__tests__/SelectMenu.test.d.ts +0 -1
  608. package/lib-esm/__tests__/SelectMenu.test.js +0 -145
  609. package/lib-esm/__tests__/SelectMenu.types.test.d.ts +0 -3
  610. package/lib-esm/__tests__/SelectMenu.types.test.js +0 -33
  611. package/lib-esm/__tests__/SelectPanel.test.d.ts +0 -1
  612. package/lib-esm/__tests__/SelectPanel.test.js +0 -65
  613. package/lib-esm/__tests__/SideNav.test.d.ts +0 -1
  614. package/lib-esm/__tests__/SideNav.test.js +0 -60
  615. package/lib-esm/__tests__/SideNav.types.test.d.ts +0 -3
  616. package/lib-esm/__tests__/SideNav.types.test.js +0 -13
  617. package/lib-esm/__tests__/Spinner.test.d.ts +0 -1
  618. package/lib-esm/__tests__/Spinner.test.js +0 -43
  619. package/lib-esm/__tests__/StateLabel.test.d.ts +0 -1
  620. package/lib-esm/__tests__/StateLabel.test.js +0 -61
  621. package/lib-esm/__tests__/StateLabel.types.test.d.ts +0 -3
  622. package/lib-esm/__tests__/StateLabel.types.test.js +0 -13
  623. package/lib-esm/__tests__/StyledOcticon.test.d.ts +0 -1
  624. package/lib-esm/__tests__/StyledOcticon.test.js +0 -29
  625. package/lib-esm/__tests__/StyledOcticon.types.test.d.ts +0 -3
  626. package/lib-esm/__tests__/StyledOcticon.types.test.js +0 -16
  627. package/lib-esm/__tests__/SubNav.test.d.ts +0 -1
  628. package/lib-esm/__tests__/SubNav.test.js +0 -50
  629. package/lib-esm/__tests__/SubNav.types.test.d.ts +0 -3
  630. package/lib-esm/__tests__/SubNav.types.test.js +0 -14
  631. package/lib-esm/__tests__/SubNavLink.test.d.ts +0 -1
  632. package/lib-esm/__tests__/SubNavLink.test.js +0 -39
  633. package/lib-esm/__tests__/TabNav.test.d.ts +0 -1
  634. package/lib-esm/__tests__/TabNav.test.js +0 -39
  635. package/lib-esm/__tests__/TabNav.types.test.d.ts +0 -3
  636. package/lib-esm/__tests__/TabNav.types.test.js +0 -12
  637. package/lib-esm/__tests__/Text.test.d.ts +0 -1
  638. package/lib-esm/__tests__/Text.test.js +0 -93
  639. package/lib-esm/__tests__/TextInput.test.d.ts +0 -1
  640. package/lib-esm/__tests__/TextInput.test.js +0 -68
  641. package/lib-esm/__tests__/TextInputWithTokens.test.d.ts +0 -1
  642. package/lib-esm/__tests__/TextInputWithTokens.test.js +0 -511
  643. package/lib-esm/__tests__/ThemeProvider.test.d.ts +0 -1
  644. package/lib-esm/__tests__/ThemeProvider.test.js +0 -408
  645. package/lib-esm/__tests__/Timeline.test.d.ts +0 -1
  646. package/lib-esm/__tests__/Timeline.test.js +0 -65
  647. package/lib-esm/__tests__/Timeline.types.test.d.ts +0 -3
  648. package/lib-esm/__tests__/Timeline.types.test.js +0 -18
  649. package/lib-esm/__tests__/Token.test.d.ts +0 -1
  650. package/lib-esm/__tests__/Token.test.js +0 -166
  651. package/lib-esm/__tests__/Tooltip.test.d.ts +0 -1
  652. package/lib-esm/__tests__/Tooltip.test.js +0 -59
  653. package/lib-esm/__tests__/Tooltip.types.test.d.ts +0 -3
  654. package/lib-esm/__tests__/Tooltip.types.test.js +0 -13
  655. package/lib-esm/__tests__/Truncate.test.d.ts +0 -1
  656. package/lib-esm/__tests__/Truncate.test.js +0 -53
  657. package/lib-esm/__tests__/Truncate.types.test.d.ts +0 -3
  658. package/lib-esm/__tests__/Truncate.types.test.js +0 -16
  659. package/lib-esm/__tests__/UnderlineNav.test.d.ts +0 -1
  660. package/lib-esm/__tests__/UnderlineNav.test.js +0 -60
  661. package/lib-esm/__tests__/UnderlineNav.types.test.d.ts +0 -3
  662. package/lib-esm/__tests__/UnderlineNav.types.test.js +0 -12
  663. package/lib-esm/__tests__/UnderlineNavLink.test.d.ts +0 -1
  664. package/lib-esm/__tests__/UnderlineNavLink.test.js +0 -41
  665. package/lib-esm/__tests__/behaviors/anchoredPosition.test.d.ts +0 -1
  666. package/lib-esm/__tests__/behaviors/anchoredPosition.test.js +0 -388
  667. package/lib-esm/__tests__/behaviors/focusTrap.test.d.ts +0 -1
  668. package/lib-esm/__tests__/behaviors/focusTrap.test.js +0 -227
  669. package/lib-esm/__tests__/behaviors/focusZone.test.d.ts +0 -1
  670. package/lib-esm/__tests__/behaviors/focusZone.test.js +0 -487
  671. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.d.ts +0 -1
  672. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.js +0 -48
  673. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +0 -1
  674. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.js +0 -224
  675. package/lib-esm/__tests__/filterObject.test.d.ts +0 -1
  676. package/lib-esm/__tests__/filterObject.test.js +0 -27
  677. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.d.ts +0 -1
  678. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.js +0 -46
  679. package/lib-esm/__tests__/hooks/useOnEscapePress.test.d.ts +0 -1
  680. package/lib-esm/__tests__/hooks/useOnEscapePress.test.js +0 -23
  681. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.d.ts +0 -1
  682. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.js +0 -68
  683. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +0 -1
  684. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.js +0 -52
  685. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +0 -1
  686. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.js +0 -36
  687. package/lib-esm/__tests__/theme.test.d.ts +0 -1
  688. package/lib-esm/__tests__/theme.test.js +0 -33
  689. package/lib-esm/__tests__/themeGet.test.d.ts +0 -1
  690. package/lib-esm/__tests__/themeGet.test.js +0 -22
  691. package/lib-esm/__tests__/useSafeTimeout.test.d.ts +0 -1
  692. package/lib-esm/__tests__/useSafeTimeout.test.js +0 -39
  693. package/lib-esm/__tests__/utils/createSlots.test.d.ts +0 -1
  694. package/lib-esm/__tests__/utils/createSlots.test.js +0 -67
  695. package/lib-esm/stories/ActionList.stories.js +0 -395
  696. package/lib-esm/stories/ActionList2.stories.js +0 -797
  697. package/lib-esm/stories/ActionMenu.stories.js +0 -303
  698. package/lib-esm/stories/AnchoredOverlay.stories.js +0 -101
  699. package/lib-esm/stories/Autocomplete.stories.js +0 -560
  700. package/lib-esm/stories/AvatarStack.stories.js +0 -32
  701. package/lib-esm/stories/Button.stories.js +0 -86
  702. package/lib-esm/stories/ConfirmationDialog.stories.js +0 -94
  703. package/lib-esm/stories/Dialog.stories.js +0 -244
  704. package/lib-esm/stories/DropdownMenu.stories.js +0 -94
  705. package/lib-esm/stories/IssueLabelToken.stories.js +0 -139
  706. package/lib-esm/stories/NewButton.stories.js +0 -178
  707. package/lib-esm/stories/Overlay.stories.js +0 -173
  708. package/lib-esm/stories/Portal.stories.js +0 -68
  709. package/lib-esm/stories/ProfileToken.stories.js +0 -136
  710. package/lib-esm/stories/SelectPanel.stories.js +0 -334
  711. package/lib-esm/stories/TextInput.stories.js +0 -117
  712. package/lib-esm/stories/TextInputWithTokens.stories.js +0 -210
  713. package/lib-esm/stories/ThemeProvider.stories.js +0 -83
  714. package/lib-esm/stories/Token.stories.js +0 -146
  715. package/lib-esm/stories/useAnchoredPosition.stories.js +0 -313
  716. package/lib-esm/stories/useFocusTrap.stories.js +0 -313
  717. package/lib-esm/stories/useFocusZone.stories.js +0 -562
  718. package/migrating.md +0 -250
  719. package/now.json +0 -17
  720. package/package-lock.json +0 -66509
  721. package/rollup.config.js +0 -36
  722. package/script/build +0 -21
  723. package/script/build-storybook +0 -10
  724. package/script/setup +0 -12
  725. package/src/ActionList/Divider.tsx +0 -25
  726. package/src/ActionList/Group.tsx +0 -45
  727. package/src/ActionList/Header.tsx +0 -74
  728. package/src/ActionList/Item.tsx +0 -480
  729. package/src/ActionList/List.tsx +0 -258
  730. package/src/ActionList/index.ts +0 -21
  731. package/src/ActionList2/Description.tsx +0 -52
  732. package/src/ActionList2/Divider.tsx +0 -24
  733. package/src/ActionList2/Group.tsx +0 -103
  734. package/src/ActionList2/Header.tsx +0 -58
  735. package/src/ActionList2/Item.tsx +0 -246
  736. package/src/ActionList2/LinkItem.tsx +0 -49
  737. package/src/ActionList2/List.tsx +0 -55
  738. package/src/ActionList2/Selection.tsx +0 -60
  739. package/src/ActionList2/Visuals.tsx +0 -76
  740. package/src/ActionList2/index.ts +0 -39
  741. package/src/ActionMenu.tsx +0 -106
  742. package/src/AnchoredOverlay/AnchoredOverlay.tsx +0 -191
  743. package/src/AnchoredOverlay/index.ts +0 -2
  744. package/src/Autocomplete/Autocomplete.tsx +0 -103
  745. package/src/Autocomplete/AutocompleteContext.tsx +0 -19
  746. package/src/Autocomplete/AutocompleteInput.tsx +0 -179
  747. package/src/Autocomplete/AutocompleteMenu.tsx +0 -341
  748. package/src/Autocomplete/AutocompleteOverlay.tsx +0 -68
  749. package/src/Autocomplete/index.ts +0 -2
  750. package/src/Avatar.tsx +0 -46
  751. package/src/AvatarPair.tsx +0 -35
  752. package/src/AvatarStack.tsx +0 -159
  753. package/src/BaseStyles.tsx +0 -53
  754. package/src/BorderBox.tsx +0 -18
  755. package/src/Box.tsx +0 -54
  756. package/src/BranchName.tsx +0 -19
  757. package/src/Breadcrumbs.tsx +0 -101
  758. package/src/Button/Button.tsx +0 -39
  759. package/src/Button/ButtonBase.tsx +0 -39
  760. package/src/Button/ButtonClose.tsx +0 -36
  761. package/src/Button/ButtonDanger.tsx +0 -42
  762. package/src/Button/ButtonGroup.tsx +0 -55
  763. package/src/Button/ButtonInvisible.tsx +0 -31
  764. package/src/Button/ButtonOutline.tsx +0 -42
  765. package/src/Button/ButtonPrimary.tsx +0 -40
  766. package/src/Button/ButtonStyles.tsx +0 -36
  767. package/src/Button/ButtonTableList.tsx +0 -45
  768. package/src/Button/index.ts +0 -16
  769. package/src/Caret.tsx +0 -133
  770. package/src/CircleBadge.tsx +0 -53
  771. package/src/CircleOcticon.tsx +0 -37
  772. package/src/CounterLabel.tsx +0 -50
  773. package/src/Details.tsx +0 -23
  774. package/src/Dialog/ConfirmationDialog.tsx +0 -184
  775. package/src/Dialog/Dialog.tsx +0 -444
  776. package/src/Dialog.tsx +0 -145
  777. package/src/Dropdown.tsx +0 -154
  778. package/src/DropdownMenu/DropdownButton.tsx +0 -15
  779. package/src/DropdownMenu/DropdownMenu.tsx +0 -115
  780. package/src/DropdownMenu/index.ts +0 -4
  781. package/src/DropdownStyles.ts +0 -128
  782. package/src/FilterList.tsx +0 -75
  783. package/src/FilteredActionList/FilteredActionList.tsx +0 -142
  784. package/src/FilteredActionList/index.ts +0 -2
  785. package/src/FilteredSearch.tsx +0 -27
  786. package/src/Flash.tsx +0 -75
  787. package/src/Flex.tsx +0 -15
  788. package/src/FormGroup.tsx +0 -24
  789. package/src/Grid.tsx +0 -15
  790. package/src/Header.tsx +0 -74
  791. package/src/Heading.tsx +0 -21
  792. package/src/Label.tsx +0 -72
  793. package/src/LabelGroup.tsx +0 -17
  794. package/src/Link.tsx +0 -42
  795. package/src/NewButton/button-counter.tsx +0 -15
  796. package/src/NewButton/button.tsx +0 -283
  797. package/src/NewButton/index.ts +0 -10
  798. package/src/NewButton/types.ts +0 -36
  799. package/src/Overlay.tsx +0 -200
  800. package/src/Pagehead.tsx +0 -16
  801. package/src/Pagination/Pagination.tsx +0 -212
  802. package/src/Pagination/index.ts +0 -4
  803. package/src/Pagination/model.tsx +0 -187
  804. package/src/PointerBox.tsx +0 -31
  805. package/src/Popover.tsx +0 -225
  806. package/src/Portal/Portal.tsx +0 -97
  807. package/src/Portal/index.ts +0 -5
  808. package/src/Position.tsx +0 -63
  809. package/src/ProgressBar.tsx +0 -52
  810. package/src/SelectMenu/SelectMenu.tsx +0 -123
  811. package/src/SelectMenu/SelectMenuContext.tsx +0 -9
  812. package/src/SelectMenu/SelectMenuDivider.tsx +0 -24
  813. package/src/SelectMenu/SelectMenuFilter.tsx +0 -50
  814. package/src/SelectMenu/SelectMenuFooter.tsx +0 -27
  815. package/src/SelectMenu/SelectMenuHeader.tsx +0 -48
  816. package/src/SelectMenu/SelectMenuItem.tsx +0 -136
  817. package/src/SelectMenu/SelectMenuList.tsx +0 -41
  818. package/src/SelectMenu/SelectMenuLoadingAnimation.tsx +0 -25
  819. package/src/SelectMenu/SelectMenuModal.tsx +0 -119
  820. package/src/SelectMenu/SelectMenuTab.tsx +0 -87
  821. package/src/SelectMenu/SelectMenuTabPanel.tsx +0 -29
  822. package/src/SelectMenu/SelectMenuTabs.tsx +0 -43
  823. package/src/SelectMenu/hooks/useKeyboardNav.js +0 -90
  824. package/src/SelectMenu/index.ts +0 -15
  825. package/src/SelectPanel/SelectPanel.tsx +0 -173
  826. package/src/SelectPanel/index.ts +0 -2
  827. package/src/SideNav.tsx +0 -191
  828. package/src/Spinner.tsx +0 -59
  829. package/src/StateLabel.tsx +0 -112
  830. package/src/StyledOcticon.tsx +0 -22
  831. package/src/SubNav.tsx +0 -124
  832. package/src/TabNav.tsx +0 -73
  833. package/src/Text.tsx +0 -13
  834. package/src/TextInput.tsx +0 -68
  835. package/src/TextInputWithTokens.tsx +0 -351
  836. package/src/ThemeProvider.tsx +0 -176
  837. package/src/Timeline.tsx +0 -140
  838. package/src/Token/AvatarToken.tsx +0 -54
  839. package/src/Token/IssueLabelToken.tsx +0 -150
  840. package/src/Token/Token.tsx +0 -126
  841. package/src/Token/TokenBase.tsx +0 -129
  842. package/src/Token/_RemoveTokenButton.tsx +0 -111
  843. package/src/Token/_TokenTextContainer.tsx +0 -47
  844. package/src/Token/index.ts +0 -3
  845. package/src/Tooltip.tsx +0 -263
  846. package/src/Truncate.tsx +0 -31
  847. package/src/UnderlineNav.tsx +0 -107
  848. package/src/_TextInputWrapper.tsx +0 -113
  849. package/src/_UnstyledTextInput.tsx +0 -19
  850. package/src/__tests__/.eslintrc.json +0 -11
  851. package/src/__tests__/ActionList.test.tsx +0 -53
  852. package/src/__tests__/ActionList.types.test.tsx +0 -51
  853. package/src/__tests__/ActionList2.test.tsx +0 -47
  854. package/src/__tests__/ActionMenu.test.tsx +0 -136
  855. package/src/__tests__/AnchoredOverlay.test.tsx +0 -150
  856. package/src/__tests__/Autocomplete.test.tsx +0 -444
  857. package/src/__tests__/Avatar.test.tsx +0 -44
  858. package/src/__tests__/AvatarStack.test.tsx +0 -48
  859. package/src/__tests__/BorderBox.test.tsx +0 -43
  860. package/src/__tests__/Box.test.tsx +0 -42
  861. package/src/__tests__/BranchName.test.tsx +0 -26
  862. package/src/__tests__/Breadcrumbs.test.tsx +0 -27
  863. package/src/__tests__/Breadcrumbs.types.test.tsx +0 -22
  864. package/src/__tests__/BreadcrumbsItem.test.tsx +0 -31
  865. package/src/__tests__/Button.test.tsx +0 -128
  866. package/src/__tests__/Caret.test.tsx +0 -36
  867. package/src/__tests__/CircleBadge.test.tsx +0 -66
  868. package/src/__tests__/CircleBadge.types.test.tsx +0 -11
  869. package/src/__tests__/CircleOcticon.test.tsx +0 -50
  870. package/src/__tests__/ConfirmationDialog.test.tsx +0 -120
  871. package/src/__tests__/CounterLabel.test.tsx +0 -50
  872. package/src/__tests__/CounterLabel.types.test.tsx +0 -11
  873. package/src/__tests__/Details.test.tsx +0 -115
  874. package/src/__tests__/Dialog.test.tsx +0 -155
  875. package/src/__tests__/Dialog.types.test.tsx +0 -11
  876. package/src/__tests__/Dialog2.types.test.tsx +0 -11
  877. package/src/__tests__/Dropdown.test.tsx +0 -53
  878. package/src/__tests__/Dropdown.types.test.tsx +0 -21
  879. package/src/__tests__/DropdownMenu.test.tsx +0 -136
  880. package/src/__tests__/FilterList.test.tsx +0 -26
  881. package/src/__tests__/FilterList.types.test.tsx +0 -17
  882. package/src/__tests__/FilterListItem.test.tsx +0 -31
  883. package/src/__tests__/FilteredSearch.test.tsx +0 -26
  884. package/src/__tests__/FilteredSearch.types.test.tsx +0 -11
  885. package/src/__tests__/Flash.test.tsx +0 -45
  886. package/src/__tests__/Flash.types.test.tsx +0 -11
  887. package/src/__tests__/Flex.test.tsx +0 -58
  888. package/src/__tests__/FormGroup.test.tsx +0 -38
  889. package/src/__tests__/FormGroup.types.test.tsx +0 -11
  890. package/src/__tests__/Grid.test.tsx +0 -82
  891. package/src/__tests__/Header.test.tsx +0 -49
  892. package/src/__tests__/Header.types.test.tsx +0 -19
  893. package/src/__tests__/Heading.test.tsx +0 -91
  894. package/src/__tests__/KeyPaths.types.test.ts +0 -14
  895. package/src/__tests__/Label.test.tsx +0 -34
  896. package/src/__tests__/Label.types.test.tsx +0 -11
  897. package/src/__tests__/LabelGroup.test.tsx +0 -30
  898. package/src/__tests__/LabelGroup.types.test.tsx +0 -11
  899. package/src/__tests__/Link.test.tsx +0 -47
  900. package/src/__tests__/Link.types.test.tsx +0 -11
  901. package/src/__tests__/Merge.types.test.ts +0 -39
  902. package/src/__tests__/NewButton.test.tsx +0 -70
  903. package/src/__tests__/Overlay.test.tsx +0 -103
  904. package/src/__tests__/Overlay.types.test.tsx +0 -18
  905. package/src/__tests__/Pagehead.test.tsx +0 -23
  906. package/src/__tests__/Pagehead.types.test.tsx +0 -11
  907. package/src/__tests__/Pagination/Pagination.test.tsx +0 -30
  908. package/src/__tests__/Pagination/PaginationModel.test.tsx +0 -133
  909. package/src/__tests__/Pagination/__snapshots__/Pagination.test.tsx.snap +0 -184
  910. package/src/__tests__/Pagination.types.test.tsx +0 -11
  911. package/src/__tests__/PointerBox.test.tsx +0 -34
  912. package/src/__tests__/Popover.test.tsx +0 -68
  913. package/src/__tests__/Popover.types.test.tsx +0 -17
  914. package/src/__tests__/Portal.test.tsx +0 -103
  915. package/src/__tests__/Position.test.tsx +0 -117
  916. package/src/__tests__/ProgressBar.test.tsx +0 -40
  917. package/src/__tests__/SelectMenu.test.tsx +0 -142
  918. package/src/__tests__/SelectMenu.types.test.tsx +0 -37
  919. package/src/__tests__/SelectPanel.test.tsx +0 -63
  920. package/src/__tests__/SideNav.test.tsx +0 -62
  921. package/src/__tests__/SideNav.types.test.tsx +0 -11
  922. package/src/__tests__/Spinner.test.tsx +0 -42
  923. package/src/__tests__/StateLabel.test.tsx +0 -48
  924. package/src/__tests__/StateLabel.types.test.tsx +0 -11
  925. package/src/__tests__/StyledOcticon.test.tsx +0 -26
  926. package/src/__tests__/StyledOcticon.types.test.tsx +0 -12
  927. package/src/__tests__/SubNav.test.tsx +0 -50
  928. package/src/__tests__/SubNav.types.test.tsx +0 -25
  929. package/src/__tests__/SubNavLink.test.tsx +0 -31
  930. package/src/__tests__/TabNav.test.tsx +0 -32
  931. package/src/__tests__/TabNav.types.test.tsx +0 -22
  932. package/src/__tests__/Text.test.tsx +0 -78
  933. package/src/__tests__/TextInput.test.tsx +0 -49
  934. package/src/__tests__/TextInputWithTokens.test.tsx +0 -422
  935. package/src/__tests__/ThemeProvider.test.tsx +0 -441
  936. package/src/__tests__/Timeline.test.tsx +0 -58
  937. package/src/__tests__/Timeline.types.test.tsx +0 -31
  938. package/src/__tests__/Token.test.tsx +0 -118
  939. package/src/__tests__/Tooltip.test.tsx +0 -52
  940. package/src/__tests__/Tooltip.types.test.tsx +0 -11
  941. package/src/__tests__/Truncate.test.tsx +0 -43
  942. package/src/__tests__/Truncate.types.test.tsx +0 -11
  943. package/src/__tests__/UnderlineNav.test.tsx +0 -58
  944. package/src/__tests__/UnderlineNav.types.test.tsx +0 -22
  945. package/src/__tests__/UnderlineNavLink.test.tsx +0 -31
  946. package/src/__tests__/__snapshots__/ActionList.test.tsx.snap +0 -223
  947. package/src/__tests__/__snapshots__/ActionList2.test.tsx.snap +0 -14
  948. package/src/__tests__/__snapshots__/ActionMenu.test.tsx.snap +0 -80
  949. package/src/__tests__/__snapshots__/AnchoredOverlay.test.tsx.snap +0 -232
  950. package/src/__tests__/__snapshots__/Autocomplete.test.tsx.snap +0 -3888
  951. package/src/__tests__/__snapshots__/Avatar.test.tsx.snap +0 -19
  952. package/src/__tests__/__snapshots__/AvatarStack.test.tsx.snap +0 -377
  953. package/src/__tests__/__snapshots__/BorderBox.test.tsx.snap +0 -14
  954. package/src/__tests__/__snapshots__/Box.test.tsx.snap +0 -201
  955. package/src/__tests__/__snapshots__/BranchName.test.tsx.snap +0 -17
  956. package/src/__tests__/__snapshots__/Breadcrumbs.test.tsx.snap +0 -29
  957. package/src/__tests__/__snapshots__/BreadcrumbsItem.test.tsx.snap +0 -79
  958. package/src/__tests__/__snapshots__/Button.test.tsx.snap +0 -840
  959. package/src/__tests__/__snapshots__/Caret.test.tsx.snap +0 -373
  960. package/src/__tests__/__snapshots__/CircleBadge.test.tsx.snap +0 -142
  961. package/src/__tests__/__snapshots__/CircleOcticon.test.tsx.snap +0 -65
  962. package/src/__tests__/__snapshots__/ConfirmationDialog.test.tsx.snap +0 -89
  963. package/src/__tests__/__snapshots__/CounterLabel.test.tsx.snap +0 -22
  964. package/src/__tests__/__snapshots__/Details.test.tsx.snap +0 -15
  965. package/src/__tests__/__snapshots__/Dialog.test.tsx.snap +0 -201
  966. package/src/__tests__/__snapshots__/Dropdown.test.tsx.snap +0 -249
  967. package/src/__tests__/__snapshots__/DropdownMenu.test.tsx.snap +0 -107
  968. package/src/__tests__/__snapshots__/FilterList.test.tsx.snap +0 -13
  969. package/src/__tests__/__snapshots__/FilterListItem.test.tsx.snap +0 -80
  970. package/src/__tests__/__snapshots__/FilteredSearch.test.tsx.snap +0 -32
  971. package/src/__tests__/__snapshots__/Flash.test.tsx.snap +0 -32
  972. package/src/__tests__/__snapshots__/Flex.test.tsx.snap +0 -130
  973. package/src/__tests__/__snapshots__/FormGroup.test.tsx.snap +0 -25
  974. package/src/__tests__/__snapshots__/Grid.test.tsx.snap +0 -178
  975. package/src/__tests__/__snapshots__/Header.test.tsx.snap +0 -79
  976. package/src/__tests__/__snapshots__/Heading.test.tsx.snap +0 -13
  977. package/src/__tests__/__snapshots__/Label.test.tsx.snap +0 -73
  978. package/src/__tests__/__snapshots__/LabelGroup.test.tsx.snap +0 -15
  979. package/src/__tests__/__snapshots__/Link.test.tsx.snap +0 -212
  980. package/src/__tests__/__snapshots__/NewButton.test.tsx.snap +0 -305
  981. package/src/__tests__/__snapshots__/Pagehead.test.tsx.snap +0 -15
  982. package/src/__tests__/__snapshots__/PointerBox.test.tsx.snap +0 -174
  983. package/src/__tests__/__snapshots__/Popover.test.tsx.snap +0 -4687
  984. package/src/__tests__/__snapshots__/Position.test.tsx.snap +0 -44
  985. package/src/__tests__/__snapshots__/ProgressBar.test.tsx.snap +0 -53
  986. package/src/__tests__/__snapshots__/SelectMenu.test.tsx.snap +0 -473
  987. package/src/__tests__/__snapshots__/SelectPanel.test.tsx.snap +0 -124
  988. package/src/__tests__/__snapshots__/SideNav.test.tsx.snap +0 -143
  989. package/src/__tests__/__snapshots__/Spinner.test.tsx.snap +0 -33
  990. package/src/__tests__/__snapshots__/StateLabel.test.tsx.snap +0 -395
  991. package/src/__tests__/__snapshots__/StyledOcticon.test.tsx.snap +0 -26
  992. package/src/__tests__/__snapshots__/SubNav.test.tsx.snap +0 -44
  993. package/src/__tests__/__snapshots__/SubNavLink.test.tsx.snap +0 -199
  994. package/src/__tests__/__snapshots__/TabNav.test.tsx.snap +0 -58
  995. package/src/__tests__/__snapshots__/Text.test.tsx.snap +0 -7
  996. package/src/__tests__/__snapshots__/TextInput.test.tsx.snap +0 -446
  997. package/src/__tests__/__snapshots__/TextInputWithTokens.test.tsx.snap +0 -6045
  998. package/src/__tests__/__snapshots__/ThemeProvider.test.tsx.snap +0 -15
  999. package/src/__tests__/__snapshots__/Timeline.test.tsx.snap +0 -159
  1000. package/src/__tests__/__snapshots__/Token.test.tsx.snap +0 -3811
  1001. package/src/__tests__/__snapshots__/Tooltip.test.tsx.snap +0 -227
  1002. package/src/__tests__/__snapshots__/Truncate.test.tsx.snap +0 -17
  1003. package/src/__tests__/__snapshots__/UnderlineNav.test.tsx.snap +0 -59
  1004. package/src/__tests__/__snapshots__/UnderlineNavLink.test.tsx.snap +0 -130
  1005. package/src/__tests__/behaviors/anchoredPosition.test.ts +0 -295
  1006. package/src/__tests__/behaviors/focusTrap.test.tsx +0 -236
  1007. package/src/__tests__/behaviors/focusZone.test.tsx +0 -549
  1008. package/src/__tests__/behaviors/iterateFocusableElements.test.tsx +0 -61
  1009. package/src/__tests__/behaviors/scrollIntoViewingArea.test.ts +0 -195
  1010. package/src/__tests__/filterObject.test.ts +0 -54
  1011. package/src/__tests__/hooks/useAnchoredPosition.test.tsx +0 -31
  1012. package/src/__tests__/hooks/useOnEscapePress.test.tsx +0 -16
  1013. package/src/__tests__/hooks/useOnOutsideClick.test.tsx +0 -48
  1014. package/src/__tests__/hooks/useOpenAndCloseFocus.test.tsx +0 -48
  1015. package/src/__tests__/hooks/useProvidedStateOrCreate.test.tsx +0 -39
  1016. package/src/__tests__/theme.test.ts +0 -41
  1017. package/src/__tests__/themeGet.test.ts +0 -15
  1018. package/src/__tests__/useSafeTimeout.test.tsx +0 -36
  1019. package/src/__tests__/utils/__snapshots__/createSlots.test.tsx.snap +0 -55
  1020. package/src/__tests__/utils/createSlots.test.tsx +0 -74
  1021. package/src/behaviors/anchoredPosition.ts +0 -442
  1022. package/src/behaviors/focusTrap.ts +0 -184
  1023. package/src/behaviors/focusZone.ts +0 -713
  1024. package/src/behaviors/scrollIntoViewingArea.ts +0 -27
  1025. package/src/constants.ts +0 -62
  1026. package/src/drafts.ts +0 -10
  1027. package/src/hooks/index.ts +0 -11
  1028. package/src/hooks/useAnchoredPosition.ts +0 -54
  1029. package/src/hooks/useCombinedRefs.ts +0 -40
  1030. package/src/hooks/useDetails.tsx +0 -54
  1031. package/src/hooks/useDialog.ts +0 -121
  1032. package/src/hooks/useFocusTrap.ts +0 -80
  1033. package/src/hooks/useFocusZone.ts +0 -64
  1034. package/src/hooks/useOnEscapePress.ts +0 -63
  1035. package/src/hooks/useOnOutsideClick.tsx +0 -82
  1036. package/src/hooks/useOpenAndCloseFocus.ts +0 -32
  1037. package/src/hooks/useOverlay.tsx +0 -34
  1038. package/src/hooks/useProvidedRefOrCreate.ts +0 -14
  1039. package/src/hooks/useProvidedStateOrCreate.ts +0 -27
  1040. package/src/hooks/useRenderForcingRef.ts +0 -22
  1041. package/src/hooks/useResizeObserver.ts +0 -11
  1042. package/src/hooks/useSafeTimeout.ts +0 -38
  1043. package/src/hooks/useScrollFlash.ts +0 -21
  1044. package/src/index.ts +0 -172
  1045. package/src/polyfills/eventListenerSignal.ts +0 -66
  1046. package/src/stories/ActionList.stories.tsx +0 -436
  1047. package/src/stories/ActionList2.stories.tsx +0 -1291
  1048. package/src/stories/ActionMenu.stories.tsx +0 -331
  1049. package/src/stories/AnchoredOverlay.stories.tsx +0 -117
  1050. package/src/stories/Autocomplete.stories.tsx +0 -655
  1051. package/src/stories/AvatarStack.stories.tsx +0 -37
  1052. package/src/stories/Button.stories.tsx +0 -92
  1053. package/src/stories/ConfirmationDialog.stories.tsx +0 -105
  1054. package/src/stories/Dialog.stories.tsx +0 -240
  1055. package/src/stories/DropdownMenu.stories.tsx +0 -84
  1056. package/src/stories/IssueLabelToken.stories.tsx +0 -138
  1057. package/src/stories/NewButton.stories.tsx +0 -201
  1058. package/src/stories/Overlay.stories.tsx +0 -213
  1059. package/src/stories/Portal.stories.tsx +0 -109
  1060. package/src/stories/ProfileToken.stories.tsx +0 -129
  1061. package/src/stories/SelectPanel.stories.tsx +0 -353
  1062. package/src/stories/TextInput.stories.tsx +0 -113
  1063. package/src/stories/TextInputWithTokens.stories.tsx +0 -155
  1064. package/src/stories/ThemeProvider.stories.tsx +0 -104
  1065. package/src/stories/Token.stories.tsx +0 -137
  1066. package/src/stories/useAnchoredPosition.stories.tsx +0 -332
  1067. package/src/stories/useFocusTrap.stories.tsx +0 -400
  1068. package/src/stories/useFocusZone.stories.tsx +0 -663
  1069. package/src/sx.ts +0 -24
  1070. package/src/theme-preval.js +0 -80
  1071. package/src/theme.ts +0 -89
  1072. package/src/utils/create-slots.tsx +0 -96
  1073. package/src/utils/deprecate.tsx +0 -73
  1074. package/src/utils/isNumeric.tsx +0 -4
  1075. package/src/utils/iterateFocusableElements.ts +0 -121
  1076. package/src/utils/ssr.tsx +0 -1
  1077. package/src/utils/test-deprecations.tsx +0 -19
  1078. package/src/utils/test-helpers.tsx +0 -7
  1079. package/src/utils/test-matchers.tsx +0 -109
  1080. package/src/utils/testing.tsx +0 -242
  1081. package/src/utils/theme.js +0 -64
  1082. package/src/utils/types/AriaRole.ts +0 -71
  1083. package/src/utils/types/ComponentProps.ts +0 -13
  1084. package/src/utils/types/Flatten.ts +0 -4
  1085. package/src/utils/types/KeyPaths.ts +0 -10
  1086. package/src/utils/types/MandateProps.ts +0 -19
  1087. package/src/utils/types/Merge.ts +0 -20
  1088. package/src/utils/types/index.ts +0 -5
  1089. package/src/utils/uniqueId.ts +0 -6
  1090. package/src/utils/use-force-update.ts +0 -7
  1091. package/src/utils/useIsomorphicLayoutEffect.ts +0 -10
  1092. package/src/utils/userAgent.ts +0 -7
  1093. package/stats.html +0 -3279
  1094. package/tsconfig.base.json +0 -20
  1095. package/tsconfig.build.json +0 -7
  1096. package/tsconfig.json +0 -7
@@ -1,1291 +0,0 @@
1
- import {
2
- ServerIcon,
3
- PlusCircleIcon,
4
- TypographyIcon,
5
- VersionsIcon,
6
- SearchIcon,
7
- NoteIcon,
8
- ProjectIcon,
9
- FilterIcon,
10
- GearIcon,
11
- ArrowRightIcon,
12
- ArrowLeftIcon,
13
- LinkIcon,
14
- LawIcon,
15
- StarIcon,
16
- RepoForkedIcon,
17
- AlertIcon,
18
- TableIcon,
19
- PeopleIcon,
20
- CalendarIcon,
21
- IssueOpenedIcon,
22
- NumberIcon,
23
- XIcon,
24
- RepoIcon
25
- } from '@primer/octicons-react'
26
- import {Meta} from '@storybook/react'
27
- import React, {forwardRef} from 'react'
28
- import styled from 'styled-components'
29
- import {DndProvider, useDrag, useDrop} from 'react-dnd'
30
- import {HTML5Backend} from 'react-dnd-html5-backend'
31
- import {Label, ThemeProvider} from '..'
32
- import {ActionList as _ActionList, ItemProps} from '../ActionList2'
33
- import {Header} from '../ActionList/Header'
34
- import BaseStyles from '../BaseStyles'
35
- import Avatar from '../Avatar'
36
- import {ButtonInvisible} from '../Button'
37
- import TextInput from '../TextInput'
38
- import Spinner from '../Spinner'
39
- import Box from '../Box'
40
- import {AnchoredOverlay} from '../AnchoredOverlay'
41
-
42
- const ActionList = Object.assign(_ActionList, {
43
- Header
44
- })
45
-
46
- const meta: Meta = {
47
- title: 'Composite components/ActionList2',
48
- component: ActionList,
49
- decorators: [
50
- (Story: React.ComponentType): JSX.Element => (
51
- <ThemeProvider>
52
- <BaseStyles>
53
- <Story />
54
- </BaseStyles>
55
- </ThemeProvider>
56
- )
57
- ],
58
- parameters: {
59
- controls: {
60
- disable: true
61
- }
62
- }
63
- }
64
- export default meta
65
-
66
- const ErsatzOverlay = styled.div<{maxWidth?: string}>`
67
- border-radius: 12px;
68
- box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 8px 24px rgba(149, 157, 165, 0.2);
69
- overflow: hidden;
70
- max-width: ${({maxWidth}) => maxWidth || 'none'};
71
- `
72
- export function SimpleListStory(): JSX.Element {
73
- return (
74
- <>
75
- <h1>Simple List</h1>
76
-
77
- <ActionList>
78
- <ActionList.Item>Copy link</ActionList.Item>
79
- <ActionList.Item>Quote reply</ActionList.Item>
80
- <ActionList.Item>Edit comment</ActionList.Item>
81
- <ActionList.Divider />
82
- <ActionList.Item variant="danger">Delete file</ActionList.Item>
83
- </ActionList>
84
- </>
85
- )
86
- }
87
- SimpleListStory.storyName = 'Simple List'
88
-
89
- export function WithIcon(): JSX.Element {
90
- return (
91
- <>
92
- <h1>With Icon</h1>
93
-
94
- <ActionList>
95
- <ActionList.Item>
96
- <ActionList.LeadingVisual>
97
- <LinkIcon />
98
- </ActionList.LeadingVisual>
99
- github.com/primer
100
- </ActionList.Item>
101
- <ActionList.Item>
102
- <ActionList.LeadingVisual>
103
- <LawIcon />
104
- </ActionList.LeadingVisual>
105
- MIT License
106
- </ActionList.Item>
107
- <ActionList.Item>
108
- <ActionList.LeadingVisual>
109
- <StarIcon />
110
- </ActionList.LeadingVisual>
111
- 256 stars
112
- </ActionList.Item>
113
- <ActionList.Item>
114
- <ActionList.LeadingVisual>
115
- <RepoForkedIcon />
116
- </ActionList.LeadingVisual>
117
- 3 forks
118
- </ActionList.Item>
119
- <ActionList.Item variant="danger">
120
- <ActionList.LeadingVisual>
121
- <AlertIcon />
122
- </ActionList.LeadingVisual>
123
- 4 vulnerabilities
124
- </ActionList.Item>
125
- </ActionList>
126
- </>
127
- )
128
- }
129
- WithIcon.storyName = 'With Icon'
130
-
131
- const users = [
132
- {login: 'pksjce', name: 'Pavithra Kodmad'},
133
- {login: 'jfuchs', name: 'Jonathan Fuchs'},
134
- {login: 'colebemis', name: 'Cole Bemis'},
135
- {login: 'mperrotti', name: 'Mike Perrotti'},
136
- {login: 'dgreif', name: 'Dusty Greif'},
137
- {login: 'smockle', name: 'Clay Miller'},
138
- {login: 'siddharthkp', name: 'Siddharth Kshetrapal'}
139
- ]
140
-
141
- export function WithAvatar(): JSX.Element {
142
- return (
143
- <>
144
- <h1>With Avatar</h1>
145
- <ErsatzOverlay>
146
- <ActionList>
147
- {users.map(user => (
148
- <ActionList.Item key={user.login}>
149
- <ActionList.LeadingVisual>
150
- <Avatar src={`https://github.com/${user.login}.png`} />
151
- </ActionList.LeadingVisual>
152
- {user.login}
153
- </ActionList.Item>
154
- ))}
155
- </ActionList>
156
- </ErsatzOverlay>
157
- </>
158
- )
159
- }
160
- WithAvatar.storyName = 'With Avatar'
161
-
162
- const labels = [
163
- {name: 'blocked', color: '#86181d', description: 'Someone or something is preventing this from moving forward'},
164
- {name: 'dependencies', color: '#0366d6', description: 'Pull requests that update a dependency file'},
165
- {name: 'duplicate', color: '#cfd3d7', description: 'This issue or pull request already exists'},
166
- {name: 'good first issue', color: '#7057ff', description: 'Good for newcomers'}
167
- ]
168
-
169
- const LabelColor: React.FC<{color: string}> = ({color}) => (
170
- <Box sx={{backgroundColor: color, width: '14px', height: '14px', borderRadius: 3}} />
171
- )
172
-
173
- export function WithDescription(): JSX.Element {
174
- return (
175
- <>
176
- <h1>With Description & Dividers</h1>
177
- <ErsatzOverlay>
178
- <ActionList showDividers>
179
- {users.map(user => (
180
- <ActionList.Item key={user.login}>
181
- <ActionList.LeadingVisual>
182
- <Avatar src={`https://github.com/${user.login}.png`} />
183
- </ActionList.LeadingVisual>
184
- {user.login}
185
- <ActionList.Description>{user.name}</ActionList.Description>
186
- </ActionList.Item>
187
- ))}
188
- <ActionList.Divider />
189
- {labels.map((label, index) => (
190
- <ActionList.Item key={index}>
191
- <ActionList.LeadingVisual>
192
- <LabelColor color={label.color} />
193
- </ActionList.LeadingVisual>
194
- {label.name}
195
- <ActionList.Description variant="block">{label.description}</ActionList.Description>
196
- </ActionList.Item>
197
- ))}
198
- </ActionList>
199
- </ErsatzOverlay>
200
- </>
201
- )
202
- }
203
- WithDescription.storyName = 'With Description & Dividers'
204
-
205
- const projects = [
206
- {name: 'Primer Backlog', scope: 'GitHub'},
207
- {name: 'Accessibility', scope: 'GitHub'},
208
- {name: 'Octicons', scope: 'github/primer'},
209
- {name: 'Primer React', scope: 'github/primer'}
210
- ]
211
-
212
- export function SingleSelectListStory(): JSX.Element {
213
- const [selectedIndex, setSelectedIndex] = React.useState(1)
214
-
215
- return (
216
- <>
217
- <h1>Single Select List</h1>
218
- <ErsatzOverlay>
219
- <ActionList selectionVariant="single" showDividers role="listbox" aria-label="Select a project">
220
- {projects.map((project, index) => (
221
- <ActionList.Item
222
- key={index}
223
- role="option"
224
- selected={index === selectedIndex}
225
- onSelect={() => setSelectedIndex(index)}
226
- >
227
- <ActionList.LeadingVisual>
228
- <TableIcon />
229
- </ActionList.LeadingVisual>
230
- {project.name}
231
- <ActionList.Description variant="block">{project.scope}</ActionList.Description>
232
- </ActionList.Item>
233
- ))}
234
- </ActionList>
235
- </ErsatzOverlay>
236
- </>
237
- )
238
- }
239
- SingleSelectListStory.storyName = 'Single Select'
240
-
241
- export function MultiSelectListStory(): JSX.Element {
242
- const [assignees, setAssignees] = React.useState(users.slice(0, 2))
243
-
244
- const toggleAssignee = (assignee: typeof users[number]) => {
245
- const assigneeIndex = assignees.findIndex(a => a.login === assignee.login)
246
-
247
- if (assigneeIndex === -1) setAssignees([...assignees, assignee])
248
- else setAssignees(assignees.filter((_, index) => index !== assigneeIndex))
249
- }
250
-
251
- return (
252
- <>
253
- <h1>Multi Select List</h1>
254
- <ErsatzOverlay>
255
- <ActionList selectionVariant="multiple" showDividers role="listbox" aria-label="Select assignees">
256
- {users.map(user => (
257
- <ActionList.Item
258
- role="option"
259
- key={user.login}
260
- selected={Boolean(assignees.find(assignee => assignee.login === user.login))}
261
- onSelect={() => toggleAssignee(user)}
262
- >
263
- <ActionList.LeadingVisual>
264
- <Avatar src={`https://github.com/${user.login}.png`} />
265
- </ActionList.LeadingVisual>
266
- {user.login}
267
- <ActionList.Description>{user.name}</ActionList.Description>
268
- </ActionList.Item>
269
- ))}
270
- </ActionList>
271
- </ErsatzOverlay>
272
- </>
273
- )
274
- }
275
- MultiSelectListStory.storyName = 'Multi Select'
276
-
277
- export function DisabledStory(): JSX.Element {
278
- const [selectedIndex, setSelectedIndex] = React.useState(0)
279
-
280
- return (
281
- <>
282
- <h1>Disabled Items</h1>
283
- <ErsatzOverlay>
284
- <ActionList selectionVariant="single" showDividers role="listbox" aria-label="Select a project">
285
- {projects.map((project, index) => (
286
- <ActionList.Item
287
- key={index}
288
- role="option"
289
- selected={index === selectedIndex}
290
- onSelect={() => setSelectedIndex(index)}
291
- disabled={index === 1}
292
- >
293
- <ActionList.LeadingVisual>
294
- <TableIcon />
295
- </ActionList.LeadingVisual>
296
- {project.name}
297
- <ActionList.Description variant="block">{project.scope}</ActionList.Description>
298
- </ActionList.Item>
299
- ))}
300
- </ActionList>
301
- </ErsatzOverlay>
302
- </>
303
- )
304
- }
305
- DisabledStory.storyName = 'Disabled Items'
306
-
307
- export function GroupsStory(): JSX.Element {
308
- const [assignees, setAssignees] = React.useState(users.slice(0, 1))
309
-
310
- const toggleAssignee = (assignee: typeof users[number]) => {
311
- const assigneeIndex = assignees.findIndex(a => a.login === assignee.login)
312
-
313
- if (assigneeIndex === -1) setAssignees([...assignees, assignee])
314
- else setAssignees(assignees.filter((_, index) => index !== assigneeIndex))
315
- }
316
-
317
- return (
318
- <>
319
- <h1>Groups</h1>
320
- <ErsatzOverlay>
321
- <ActionList selectionVariant="multiple" showDividers aria-label="Select reviewers">
322
- <ActionList.Group title="Suggestions" variant="filled" role="listbox">
323
- {users.slice(0, 2).map(user => (
324
- <ActionList.Item
325
- key={user.login}
326
- role="option"
327
- selected={Boolean(assignees.find(assignee => assignee.login === user.login))}
328
- onSelect={() => toggleAssignee(user)}
329
- >
330
- <ActionList.LeadingVisual>
331
- <Avatar src={`https://github.com/${user.login}.png`} />
332
- </ActionList.LeadingVisual>
333
- {user.login}
334
- <ActionList.Description>{user.name}</ActionList.Description>
335
- <ActionList.Description variant="block">Recently edited these files</ActionList.Description>
336
- </ActionList.Item>
337
- ))}
338
- </ActionList.Group>
339
- <ActionList.Group title="Everyone" variant="filled" role="listbox">
340
- {users.slice(2).map(user => (
341
- <ActionList.Item
342
- role="option"
343
- key={user.login}
344
- selected={Boolean(assignees.find(assignee => assignee.login === user.login))}
345
- onSelect={() => toggleAssignee(user)}
346
- >
347
- <ActionList.LeadingVisual>
348
- <Avatar src={`https://github.com/${user.login}.png`} />
349
- </ActionList.LeadingVisual>
350
- {user.login}
351
- <ActionList.Description>{user.name}</ActionList.Description>
352
- </ActionList.Item>
353
- ))}
354
- </ActionList.Group>
355
- </ActionList>
356
- </ErsatzOverlay>
357
- </>
358
- )
359
- }
360
- GroupsStory.storyName = 'Groups'
361
-
362
- export function ActionsStory(): JSX.Element {
363
- return (
364
- <>
365
- <h1>Actions</h1>
366
- <ErsatzOverlay>
367
- <ActionList showDividers>
368
- <ActionList.Item>
369
- <ActionList.LeadingVisual>
370
- <ServerIcon />
371
- </ActionList.LeadingVisual>
372
- Open current Codespace
373
- <ActionList.Description variant="block">
374
- Your existing Codespace will be opened to its previous state, and you&apos;ll be asked to manually switch
375
- to new-branch.
376
- </ActionList.Description>
377
- </ActionList.Item>
378
- <ActionList.Item>
379
- <ActionList.LeadingVisual>
380
- <PlusCircleIcon />
381
- </ActionList.LeadingVisual>
382
- Create new Codespace
383
- <ActionList.Description variant="block">
384
- Create a brand new Codespace with a fresh image and checkout this branch.
385
- </ActionList.Description>
386
- </ActionList.Item>
387
- </ActionList>
388
- </ErsatzOverlay>
389
- </>
390
- )
391
- }
392
- ActionsStory.storyName = 'Actions'
393
-
394
- export function ComplexListInsetVariantStory(): JSX.Element {
395
- return (
396
- <>
397
- <h1>Complex List</h1>
398
- <h2>Inset Variant</h2>
399
- <ErsatzOverlay>
400
- <ActionList showDividers>
401
- <ActionList.Item>
402
- <ActionList.LeadingVisual>
403
- <TypographyIcon />
404
- </ActionList.LeadingVisual>
405
- Rename
406
- </ActionList.Item>
407
- <ActionList.Item>
408
- <ActionList.LeadingVisual>
409
- <VersionsIcon />
410
- </ActionList.LeadingVisual>
411
- Duplicate
412
- <ActionList.Description>Create a copy</ActionList.Description>
413
- </ActionList.Item>
414
-
415
- <ActionList.Group title="Live query" variant="filled">
416
- <ActionList.Item style={{color: 'rebeccapurple'}}>
417
- <ActionList.LeadingVisual>
418
- <SearchIcon />
419
- </ActionList.LeadingVisual>
420
- repo:github/memex,github/github
421
- </ActionList.Item>
422
- </ActionList.Group>
423
- <ActionList.Divider />
424
- <ActionList.Group title="Layout" variant="subtle">
425
- <ActionList.Item>
426
- <ActionList.LeadingVisual>
427
- <NoteIcon />
428
- </ActionList.LeadingVisual>
429
- Table
430
- <ActionList.Description variant="block">
431
- Information-dense table optimized for operations across teams
432
- </ActionList.Description>
433
- </ActionList.Item>
434
- <ActionList.Item role="listitem">
435
- <ActionList.LeadingVisual>
436
- <ProjectIcon />
437
- </ActionList.LeadingVisual>
438
- Board
439
- <ActionList.Description variant="block">
440
- Kanban-style board focused on visual states
441
- </ActionList.Description>
442
- </ActionList.Item>
443
- </ActionList.Group>
444
- <ActionList.Divider />
445
- <ActionList.Group>
446
- <ActionList.Item style={{fontWeight: 'bold'}}>
447
- <ActionList.LeadingVisual>
448
- <FilterIcon />
449
- </ActionList.LeadingVisual>
450
- Save sort and filters to current view
451
- </ActionList.Item>
452
- <ActionList.Item style={{fontWeight: 'bold'}}>
453
- <ActionList.LeadingVisual>
454
- <FilterIcon />
455
- </ActionList.LeadingVisual>
456
- Save sort and filters to new view
457
- </ActionList.Item>
458
- </ActionList.Group>
459
- <ActionList.Divider />
460
- <ActionList.Group sx={{backgroundColor: 'accent.emphasis'}}>
461
- <ActionList.Item sx={{color: 'white'}}>
462
- <ActionList.LeadingVisual sx={{color: 'white'}}>
463
- <GearIcon />
464
- </ActionList.LeadingVisual>
465
- View settings
466
- </ActionList.Item>
467
- </ActionList.Group>
468
- </ActionList>
469
- </ErsatzOverlay>
470
- </>
471
- )
472
- }
473
- ComplexListInsetVariantStory.storyName = 'Complex List — Inset Variant'
474
-
475
- export function ComplexListFullVariantStory(): JSX.Element {
476
- return (
477
- <>
478
- <h1>Complex List</h1>
479
- <h2>Full Variant</h2>
480
- <ErsatzOverlay>
481
- <ActionList variant="full">
482
- <ActionList.Item>
483
- <ActionList.LeadingVisual>
484
- <TypographyIcon />
485
- </ActionList.LeadingVisual>
486
- Rename
487
- </ActionList.Item>
488
- <ActionList.Item>
489
- <ActionList.LeadingVisual>
490
- <VersionsIcon />
491
- </ActionList.LeadingVisual>
492
- Duplicate
493
- <ActionList.Description>Create a copy</ActionList.Description>
494
- </ActionList.Item>
495
-
496
- <ActionList.Group title="Live query" variant="filled">
497
- <ActionList.Item style={{color: 'rebeccapurple'}}>
498
- <ActionList.LeadingVisual>
499
- <SearchIcon />
500
- </ActionList.LeadingVisual>
501
- repo:github/memex,github/github
502
- </ActionList.Item>
503
- </ActionList.Group>
504
- <ActionList.Divider />
505
- <ActionList.Group title="Layout" variant="subtle">
506
- <ActionList.Item>
507
- <ActionList.LeadingVisual>
508
- <NoteIcon />
509
- </ActionList.LeadingVisual>
510
- Table
511
- <ActionList.Description variant="block">
512
- Information-dense table optimized for operations across teams
513
- </ActionList.Description>
514
- </ActionList.Item>
515
- <ActionList.Item>
516
- <ActionList.LeadingVisual>
517
- <ProjectIcon />
518
- </ActionList.LeadingVisual>
519
- Board
520
- <ActionList.Description variant="block">
521
- Kanban-style board focused on visual states
522
- </ActionList.Description>
523
- </ActionList.Item>
524
- </ActionList.Group>
525
- <ActionList.Divider />
526
- <ActionList.Group>
527
- <ActionList.Item style={{fontWeight: 'bold'}}>
528
- <ActionList.LeadingVisual>
529
- <FilterIcon />
530
- </ActionList.LeadingVisual>
531
- Save sort and filters to current view
532
- </ActionList.Item>
533
- <ActionList.Item style={{fontWeight: 'bold'}}>
534
- <ActionList.LeadingVisual>
535
- <FilterIcon />
536
- </ActionList.LeadingVisual>
537
- Save sort and filters to new view
538
- </ActionList.Item>
539
- </ActionList.Group>
540
- <ActionList.Divider />
541
- <ActionList.Group sx={{backgroundColor: 'accent.emphasis'}}>
542
- <ActionList.Item sx={{color: 'white'}}>
543
- <ActionList.LeadingVisual sx={{color: 'white'}}>
544
- <GearIcon />
545
- </ActionList.LeadingVisual>
546
- View settings
547
- </ActionList.Item>
548
- </ActionList.Group>
549
- </ActionList>
550
- </ErsatzOverlay>
551
- </>
552
- )
553
- }
554
- ComplexListFullVariantStory.storyName = 'Complex List — Full Variant'
555
-
556
- type ReactRouterLikeLinkProps = {to: string; children: React.ReactNode}
557
- const ReactRouterLikeLink = forwardRef<HTMLAnchorElement, ReactRouterLikeLinkProps>(
558
- ({to, ...props}: {to: string; children: React.ReactNode}, ref) => {
559
- // eslint-disable-next-line jsx-a11y/anchor-has-content
560
- return <a ref={ref} href={to} {...props} />
561
- }
562
- )
563
-
564
- const NextJSLikeLink = forwardRef(
565
- ({href, children}: {href: string; children: React.ReactNode}, ref): React.ReactElement => {
566
- const child = React.Children.only(children)
567
- const childProps = {
568
- ref,
569
- href
570
- }
571
- return <>{React.isValidElement(child) ? React.cloneElement(child, childProps) : null}</>
572
- }
573
- )
574
-
575
- export function LinkItemStory(): JSX.Element {
576
- return (
577
- <>
578
- <h1>List with LinkItem</h1>
579
- <ErsatzOverlay>
580
- <ActionList showDividers>
581
- <ActionList.Item>
582
- <ActionList.LeadingVisual>
583
- <XIcon />
584
- </ActionList.LeadingVisual>
585
- not a link, just an Item for comparison
586
- </ActionList.Item>
587
- <ActionList.LinkItem href="https://github.com/primer">
588
- <ActionList.LeadingVisual>
589
- <LinkIcon />
590
- </ActionList.LeadingVisual>
591
- ActionList.LinkItem
592
- </ActionList.LinkItem>
593
- <ActionList.LinkItem href="https://github.com/primer" target="_blank" rel="noopener noreferrer">
594
- <ActionList.LeadingVisual>
595
- <LinkIcon />
596
- </ActionList.LeadingVisual>
597
- ActionList.LinkItem with anchor attributes
598
- </ActionList.LinkItem>
599
- <ActionList.LinkItem
600
- as={ReactRouterLikeLink}
601
- to="?path=/story/composite-components-actionlist2--simple-list-story"
602
- >
603
- <ActionList.LeadingVisual>
604
- <LinkIcon />
605
- </ActionList.LeadingVisual>
606
- as ReactRouterLink
607
- </ActionList.LinkItem>
608
- <NextJSLikeLink href="?path=/story/composite-components-actionlist2--simple-list-story">
609
- <ActionList.LinkItem>
610
- <ActionList.LeadingVisual>
611
- <LinkIcon />
612
- </ActionList.LeadingVisual>
613
- NextJS style Link
614
- </ActionList.LinkItem>
615
- </NextJSLikeLink>
616
- <ActionList.LinkItem href="?path=/story/composite-components-actionlist2--simple-list-story">
617
- <ActionList.LeadingVisual>
618
- <LinkIcon />
619
- </ActionList.LeadingVisual>
620
- ActionList.LinkItem with everything
621
- <ActionList.Description variant="inline">inline description</ActionList.Description>
622
- <ActionList.Description variant="block">Block description</ActionList.Description>
623
- <ActionList.TrailingVisual>⌘ + L</ActionList.TrailingVisual>
624
- </ActionList.LinkItem>
625
- </ActionList>
626
- </ErsatzOverlay>
627
- </>
628
- )
629
- }
630
- LinkItemStory.storyName = 'List with LinkItem'
631
-
632
- export function DOMPropsStory(): JSX.Element {
633
- return (
634
- <>
635
- <h1>Simple List</h1>
636
- <ErsatzOverlay>
637
- <ActionList>
638
- {/* eslint-disable-next-line @typescript-eslint/no-explicit-any */}
639
- <ActionList.Item id="something" onClick={(event: any) => alert(`Id is '${event.target.id}'`)}>
640
- Has an id
641
- </ActionList.Item>
642
- </ActionList>
643
- </ErsatzOverlay>
644
- </>
645
- )
646
- }
647
- DOMPropsStory.storyName = 'List an item input including DOM props'
648
-
649
- export function CustomItemChildren(): JSX.Element {
650
- return (
651
- <>
652
- <h1>Custom Item Children</h1>
653
- <ErsatzOverlay>
654
- <ActionList>
655
- <ActionList.Item>
656
- <ActionList.LeadingVisual>
657
- <ArrowRightIcon />
658
- </ActionList.LeadingVisual>
659
- <Label outline borderColor="success.emphasis">
660
- Choose this one
661
- </Label>
662
- <ActionList.TrailingVisual>
663
- <ArrowLeftIcon />
664
- </ActionList.TrailingVisual>
665
- </ActionList.Item>
666
- </ActionList>
667
- </ErsatzOverlay>
668
- </>
669
- )
670
- }
671
- CustomItemChildren.storyName = 'Custom Item Children'
672
-
673
- export function SizeStressTestingStory(): JSX.Element {
674
- return (
675
- <>
676
- <h1>Size Stress Testing</h1>
677
- <ErsatzOverlay maxWidth="300px">
678
- <ActionList showDividers>
679
- <ActionList.Item>
680
- <ActionList.LeadingVisual>
681
- <ArrowRightIcon />
682
- </ActionList.LeadingVisual>
683
- Block Description. Long text should wrap
684
- <ActionList.Description variant="block">
685
- This description is long, but it is block so it wraps
686
- </ActionList.Description>
687
- <ActionList.TrailingVisual>
688
- <ArrowLeftIcon />
689
- </ActionList.TrailingVisual>
690
- </ActionList.Item>
691
- <ActionList.Item>
692
- <ActionList.LeadingVisual>
693
- <ArrowRightIcon />
694
- </ActionList.LeadingVisual>
695
- Inline Description
696
- <ActionList.Description>This description gets truncated because it is inline</ActionList.Description>
697
- <ActionList.TrailingVisual>
698
- <ArrowLeftIcon />
699
- </ActionList.TrailingVisual>
700
- </ActionList.Item>
701
- <ActionList.Item>
702
- <ActionList.LeadingVisual>
703
- <ArrowRightIcon />
704
- </ActionList.LeadingVisual>
705
- Really long text without a description should wrap so it wraps
706
- <ActionList.TrailingVisual>
707
- <ArrowLeftIcon />
708
- </ActionList.TrailingVisual>
709
- </ActionList.Item>
710
- </ActionList>
711
- </ErsatzOverlay>
712
- </>
713
- )
714
- }
715
- SizeStressTestingStory.storyName = 'Size Stress Testing'
716
-
717
- export function AllCombinations(): JSX.Element {
718
- return (
719
- <>
720
- <h1>All Possible Combinations</h1>
721
- <code>
722
- dynamic features: L = Leading Visual, I = Inline Description, B = Block Description, T = Trailing Visual
723
- </code>
724
- <br />
725
- <code>16 possible combinations</code>
726
- <br />
727
- <br />
728
- <ErsatzOverlay maxWidth="300px">
729
- <ActionList showDividers>
730
- <ActionList.Item>
731
- <ActionList.LeadingVisual>
732
- <StarIcon />
733
- </ActionList.LeadingVisual>
734
- The everything bagel
735
- <ActionList.Description variant="inline">inline description</ActionList.Description>
736
- <ActionList.Description variant="block">Block description</ActionList.Description>
737
- <ActionList.TrailingVisual>
738
- <StarIcon />
739
- </ActionList.TrailingVisual>
740
- </ActionList.Item>
741
- <ActionList.Item>none of them, only text</ActionList.Item>
742
- <ActionList.Item>
743
- <ActionList.LeadingVisual>
744
- <StarIcon />
745
- </ActionList.LeadingVisual>
746
- only L
747
- </ActionList.Item>
748
- <ActionList.Item>
749
- only I<ActionList.Description variant="inline">inline description</ActionList.Description>
750
- </ActionList.Item>
751
- <ActionList.Item>
752
- only B<ActionList.Description variant="block">Block description</ActionList.Description>
753
- </ActionList.Item>
754
- <ActionList.Item>
755
- only T
756
- <ActionList.TrailingVisual>
757
- <StarIcon />
758
- </ActionList.TrailingVisual>
759
- </ActionList.Item>
760
- <ActionList.Item>
761
- <ActionList.LeadingVisual>
762
- <StarIcon />
763
- </ActionList.LeadingVisual>
764
- L + I<ActionList.Description variant="inline">inline description</ActionList.Description>
765
- </ActionList.Item>
766
- <ActionList.Item>
767
- <ActionList.LeadingVisual>
768
- <StarIcon />
769
- </ActionList.LeadingVisual>
770
- L + B<ActionList.Description variant="block">Block description</ActionList.Description>
771
- </ActionList.Item>
772
- <ActionList.Item>
773
- <ActionList.LeadingVisual>
774
- <StarIcon />
775
- </ActionList.LeadingVisual>
776
- L + T
777
- <ActionList.TrailingVisual>
778
- <StarIcon />
779
- </ActionList.TrailingVisual>
780
- </ActionList.Item>
781
- <ActionList.Item>
782
- I + B<ActionList.Description variant="inline">inline description</ActionList.Description>
783
- <ActionList.Description variant="block">Block description</ActionList.Description>
784
- </ActionList.Item>
785
- <ActionList.Item>
786
- I + T<ActionList.Description variant="inline">inline description</ActionList.Description>
787
- <ActionList.TrailingVisual>
788
- <StarIcon />
789
- </ActionList.TrailingVisual>
790
- </ActionList.Item>
791
- <ActionList.Item>
792
- B + T<ActionList.Description variant="block">Block description</ActionList.Description>
793
- <ActionList.TrailingVisual>
794
- <StarIcon />
795
- </ActionList.TrailingVisual>
796
- </ActionList.Item>
797
- <ActionList.Item>
798
- <ActionList.LeadingVisual>
799
- <StarIcon />
800
- </ActionList.LeadingVisual>
801
- L + I + B<ActionList.Description variant="inline">inline description</ActionList.Description>
802
- <ActionList.Description variant="block">Block description</ActionList.Description>
803
- </ActionList.Item>
804
- <ActionList.Item>
805
- <ActionList.LeadingVisual>
806
- <StarIcon />
807
- </ActionList.LeadingVisual>
808
- L + I + T<ActionList.Description variant="inline">inline description</ActionList.Description>
809
- <ActionList.TrailingVisual>
810
- <StarIcon />
811
- </ActionList.TrailingVisual>
812
- </ActionList.Item>
813
- <ActionList.Item>
814
- <ActionList.LeadingVisual>
815
- <StarIcon />
816
- </ActionList.LeadingVisual>
817
- L + B + T<ActionList.Description variant="block">Block description</ActionList.Description>
818
- <ActionList.TrailingVisual>
819
- <StarIcon />
820
- </ActionList.TrailingVisual>
821
- </ActionList.Item>
822
- <ActionList.Item>
823
- I + B + T<ActionList.Description variant="inline">inline description</ActionList.Description>
824
- <ActionList.Description variant="block">Block description</ActionList.Description>
825
- <ActionList.TrailingVisual>
826
- <StarIcon />
827
- </ActionList.TrailingVisual>
828
- </ActionList.Item>
829
- </ActionList>
830
- </ErsatzOverlay>
831
- </>
832
- )
833
- }
834
- AllCombinations.storyName = 'All Combinations'
835
-
836
- const teams = [
837
- {id: '5025661', type: 'team', slug: 'github/primer-reviewers', name: 'Primer Reviewers', members: 20},
838
- {id: '1929972', type: 'team', slug: 'github/design-infrastructure', name: 'Design Infrastructure', members: 20}
839
- ]
840
-
841
- export function ConditionalChildren(): JSX.Element {
842
- type reviewerType = {name: string; id?: string; type?: string; login?: string; slug?: string; members?: number}
843
- const potentialReviewers: reviewerType[] = [...teams, ...users]
844
- return (
845
- <>
846
- <h1>Conditional Children</h1>
847
- <ErsatzOverlay>
848
- <ActionList showDividers>
849
- {potentialReviewers.map((reviewer, index) => (
850
- <ActionList.Item key={index}>
851
- <ActionList.LeadingVisual>
852
- {reviewer.type === 'team' ? (
853
- <Avatar src={`https://avatars.githubusercontent.com/t/${reviewer.id}`} />
854
- ) : (
855
- <Avatar src={`https://avatars.githubusercontent.com/${reviewer.login}`} />
856
- )}
857
- </ActionList.LeadingVisual>
858
- {reviewer.login || reviewer.slug}
859
- {reviewer.type === 'team' ? (
860
- <ActionList.Description variant="block">{reviewer.name}</ActionList.Description>
861
- ) : (
862
- <ActionList.Description>{reviewer.name}</ActionList.Description>
863
- )}
864
- {reviewer.type === 'team' && (
865
- <ActionList.TrailingVisual>
866
- <PeopleIcon />
867
- {reviewer.members}
868
- </ActionList.TrailingVisual>
869
- )}
870
- </ActionList.Item>
871
- ))}
872
- </ActionList>
873
- </ErsatzOverlay>
874
- </>
875
- )
876
- }
877
- ConditionalChildren.storyName = 'Conditional Children'
878
-
879
- export function NestedChildren(): JSX.Element {
880
- return (
881
- <>
882
- <h1>Nested Children</h1>
883
- <ErsatzOverlay>
884
- <ActionList showDividers>
885
- <li>
886
- <ul id="i like extra lists" style={{paddingInlineStart: 0}}>
887
- {users.map(user => (
888
- <ActionList.Item key={user.login}>
889
- <ActionList.LeadingVisual>
890
- <Avatar src={`https://avatars.githubusercontent.com/${user.login}`} />
891
- </ActionList.LeadingVisual>
892
- {user.login}
893
- <ReviewerDescription user={user} />
894
- </ActionList.Item>
895
- ))}
896
- </ul>
897
- </li>
898
- </ActionList>
899
- </ErsatzOverlay>
900
- </>
901
- )
902
- }
903
- NestedChildren.storyName = 'Nested Children'
904
-
905
- const ReviewerDescription = ({user}: {user: typeof users[number]}) => {
906
- const usersRecentlyEditedFile = users.slice(0, 2)
907
-
908
- if (usersRecentlyEditedFile.find(u => u.login === user.login)) {
909
- return (
910
- <span>
911
- <ActionList.Description>{user.name}</ActionList.Description>
912
- <ActionList.Description variant="block">Recently edited this file</ActionList.Description>
913
- </span>
914
- )
915
- } else {
916
- return <ActionList.Description>{user.name}</ActionList.Description>
917
- }
918
- }
919
-
920
- export function ChildWithInternalState(): JSX.Element {
921
- return (
922
- <>
923
- <h1>Child with internal state - broken</h1>
924
- <ErsatzOverlay>
925
- <ActionList showDividers>
926
- {users.map(user => (
927
- <ActionList.Item key={user.login}>
928
- <ActionList.LeadingVisual>
929
- <Avatar src={`https://avatars.githubusercontent.com/${user.login}`} />
930
- </ActionList.LeadingVisual>
931
- {user.login}
932
- <StatefulChild>{user.name}</StatefulChild>
933
- </ActionList.Item>
934
- ))}
935
- </ActionList>
936
- </ErsatzOverlay>
937
- </>
938
- )
939
- }
940
- ChildWithInternalState.storyName = 'Child with internal state'
941
-
942
- const StatefulChild: React.FC = props => {
943
- const [nameVisible, setNameVisibility] = React.useState(false)
944
- const toggle = () => {
945
- setNameVisibility(!nameVisible)
946
- }
947
-
948
- /** once description is registered, it cannot be unregistered, only updated. */
949
-
950
- return (
951
- <>
952
- <ButtonInvisible onClick={toggle} sx={{fontSize: 0, paddingY: 0}}>
953
- {nameVisible ? 'Hide name' : 'Show name'}
954
- </ButtonInvisible>
955
- {nameVisible && <ActionList.Description>{props.children}</ActionList.Description>}
956
- </>
957
- )
958
- }
959
-
960
- export function ChildWithSideEffects(): JSX.Element {
961
- const user = users[0]
962
- const [selected, setSelected] = React.useState(true)
963
-
964
- return (
965
- <>
966
- <h1>Child with side effects</h1>
967
- <ErsatzOverlay>
968
- <ActionList selectionVariant="multiple" role="listbox" aria-label="Select assignees">
969
- <ActionList.Item selected={selected} onSelect={() => setSelected(!selected)} role="option">
970
- <ActionList.LeadingVisual>
971
- <Avatar src={`https://avatars.githubusercontent.com/${user.login}`} />
972
- </ActionList.LeadingVisual>
973
- {user.login}
974
- <SideEffectDescription />
975
- </ActionList.Item>
976
- </ActionList>
977
- </ErsatzOverlay>
978
- </>
979
- )
980
- }
981
- ChildWithSideEffects.storyName = 'Child with side effects'
982
-
983
- const SideEffectDescription = () => {
984
- const [seconds, setSeconds] = React.useState(0)
985
-
986
- React.useEffect(() => {
987
- const fn = () => setSeconds(s => s + 1)
988
- const interval = window.setInterval(fn, 1000)
989
- return () => window.clearInterval(interval)
990
- }, [])
991
-
992
- return <ActionList.Description>{seconds} seconds passed</ActionList.Description>
993
- }
994
-
995
- export function WithSx(): JSX.Element {
996
- return (
997
- <>
998
- <h1>With sx prop</h1>
999
- <ErsatzOverlay>
1000
- <ActionList sx={{paddingTop: 4}}>
1001
- <ActionList.Item sx={{backgroundColor: 'accent.subtle'}}>
1002
- <ActionList.LeadingVisual sx={{color: 'accent.emphasis'}}>
1003
- <LinkIcon />
1004
- </ActionList.LeadingVisual>
1005
- github.com/primer
1006
- <ActionList.Description sx={{paddingLeft: 4, color: 'accent.emphasis'}}>
1007
- all items support sx prop
1008
- </ActionList.Description>
1009
- </ActionList.Item>
1010
- <ActionList.Item>
1011
- <ActionList.LeadingVisual>
1012
- <LawIcon />
1013
- </ActionList.LeadingVisual>
1014
- MIT License
1015
- </ActionList.Item>
1016
- <ActionList.Item
1017
- variant="danger"
1018
- sx={{
1019
- borderLeft: '2px solid',
1020
- borderColor: 'danger.emphasis',
1021
- borderTopLeftRadius: 0,
1022
- borderBottomLeftRadius: 0
1023
- }}
1024
- >
1025
- <ActionList.LeadingVisual>
1026
- <AlertIcon />
1027
- </ActionList.LeadingVisual>
1028
- 4 vulnerabilities
1029
- </ActionList.Item>
1030
- </ActionList>
1031
- </ErsatzOverlay>
1032
- </>
1033
- )
1034
- }
1035
- WithSx.storyName = 'With sx'
1036
-
1037
- export function MemexGroupBy(): JSX.Element {
1038
- const [selectedIndex, setSelectedIndex] = React.useState<number | null>(1)
1039
-
1040
- const options = [
1041
- {text: 'Status', icon: <IssueOpenedIcon />},
1042
- {text: 'Stage', icon: <TableIcon />},
1043
- {text: 'Assignee', icon: <PeopleIcon />},
1044
- {text: 'Team', icon: <TypographyIcon />},
1045
- {text: 'Estimate', icon: <NumberIcon />},
1046
- {text: 'Due Date', icon: <CalendarIcon />}
1047
- ]
1048
-
1049
- return (
1050
- <>
1051
- <h1>Memex GroupBy List</h1>
1052
- <ErsatzOverlay>
1053
- <ActionList>
1054
- <ActionList.Group title="Group by" selectionVariant="single">
1055
- {options.map((option, index) => (
1056
- <ActionList.Item key={index} selected={index === selectedIndex} onSelect={() => setSelectedIndex(index)}>
1057
- <ActionList.LeadingVisual>{option.icon}</ActionList.LeadingVisual>
1058
- {option.text}
1059
- </ActionList.Item>
1060
- ))}
1061
- </ActionList.Group>
1062
- {typeof selectedIndex === 'number' && (
1063
- <>
1064
- <ActionList.Divider />
1065
- <ActionList.Item onSelect={() => setSelectedIndex(null)}>
1066
- <ActionList.LeadingVisual>
1067
- <XIcon />
1068
- </ActionList.LeadingVisual>
1069
- Clear Group by
1070
- </ActionList.Item>
1071
- </>
1072
- )}
1073
- </ActionList>
1074
- </ErsatzOverlay>
1075
- </>
1076
- )
1077
- }
1078
- MemexGroupBy.storyName = 'Memex GroupBy List'
1079
-
1080
- type Option = {text: string; icon: React.ReactNode; selected: boolean}
1081
- export function MemexSortable(): JSX.Element {
1082
- const [options, setOptions] = React.useState<Option[]>([
1083
- {text: 'Status', icon: <IssueOpenedIcon />, selected: true},
1084
- {text: 'Stage', icon: <TableIcon />, selected: true},
1085
- {text: 'Assignee', icon: <PeopleIcon />, selected: true},
1086
- {text: 'Team', icon: <TypographyIcon />, selected: true},
1087
- {text: 'Estimate', icon: <NumberIcon />, selected: false},
1088
- {text: 'Due Date', icon: <CalendarIcon />, selected: false}
1089
- ])
1090
-
1091
- const toggle = (text: string) => {
1092
- setOptions(
1093
- options.map(option => {
1094
- if (option.text === text) option.selected = !option.selected
1095
- return option
1096
- })
1097
- )
1098
- }
1099
-
1100
- const reorder = ({optionToMove, moveAfterOption}: {optionToMove: Option; moveAfterOption: Option}) => {
1101
- setOptions(currentOptions => {
1102
- const newOptions = [...currentOptions]
1103
- // remove option to move
1104
- const currentPosition = newOptions.findIndex(o => o.text === optionToMove.text)
1105
- newOptions.splice(currentPosition, 1)
1106
- // add it after the provided element
1107
- const newPosition = newOptions.findIndex(o => o.text === moveAfterOption.text) + 1
1108
- newOptions.splice(newPosition, 0, optionToMove)
1109
- return newOptions
1110
- })
1111
- }
1112
-
1113
- const visibleOptions = options.filter(option => option.selected)
1114
- const hiddenOptions = options.filter(option => !option.selected)
1115
-
1116
- return (
1117
- <>
1118
- <h1>Memex Sortable List</h1>
1119
- <ErsatzOverlay>
1120
- <DndProvider backend={HTML5Backend}>
1121
- <ActionList selectionVariant="multiple">
1122
- <ActionList.Group title="Visible fields (can be reordered)">
1123
- {visibleOptions.map(option => (
1124
- <SortableItem
1125
- key={option.text}
1126
- option={option}
1127
- onSelect={() => toggle(option.text)}
1128
- reorder={reorder}
1129
- />
1130
- ))}
1131
- </ActionList.Group>
1132
- <ActionList.Group
1133
- title="Hidden fields"
1134
- selectionVariant={
1135
- /** selectionVariant override on Group: disable selection if there are no options */
1136
- hiddenOptions.length ? 'multiple' : false
1137
- }
1138
- >
1139
- {hiddenOptions.map((option, index) => (
1140
- <ActionList.Item key={index} selected={option.selected} onSelect={() => toggle(option.text)}>
1141
- <ActionList.LeadingVisual>{option.icon}</ActionList.LeadingVisual>
1142
- {option.text}
1143
- </ActionList.Item>
1144
- ))}
1145
- {hiddenOptions.length === 0 && <ActionList.Item disabled>No hidden fields</ActionList.Item>}
1146
- </ActionList.Group>
1147
- </ActionList>
1148
- </DndProvider>
1149
- </ErsatzOverlay>
1150
- </>
1151
- )
1152
- }
1153
- MemexSortable.storyName = 'Memex Sortable List'
1154
-
1155
- type SortableItemProps = {
1156
- option: Option
1157
- onSelect: ItemProps['onSelect']
1158
- reorder: ({optionToMove, moveAfterOption}: {optionToMove: Option; moveAfterOption: Option}) => void
1159
- }
1160
- const SortableItem: React.FC<SortableItemProps> = ({option, onSelect, reorder}) => {
1161
- const [{isDragging}, dragRef] = useDrag(() => ({
1162
- type: 'ITEM',
1163
- item: option,
1164
- collect: monitor => {
1165
- return {isDragging: monitor.isDragging()}
1166
- }
1167
- }))
1168
-
1169
- const [{isOver}, dropRef] = useDrop(() => ({
1170
- accept: 'ITEM',
1171
- collect: monitor => {
1172
- return {isOver: monitor.isOver()}
1173
- },
1174
- drop: (optionDropped: Option) => {
1175
- reorder({optionToMove: optionDropped, moveAfterOption: option})
1176
- }
1177
- }))
1178
-
1179
- return (
1180
- <ActionList.Item
1181
- ref={element => dragRef(element) && dropRef(element)} // merge refs
1182
- selected={option.selected}
1183
- onSelect={onSelect}
1184
- sx={{
1185
- opacity: isDragging ? 0.5 : 1,
1186
- boxShadow: isOver ? theme => `0px 2px 0 0px ${theme.colors.accent.emphasis}` : undefined,
1187
- borderRadius: isOver ? 0 : 2
1188
- }}
1189
- >
1190
- <ActionList.LeadingVisual>{option.icon}</ActionList.LeadingVisual>
1191
- {option.text}
1192
- </ActionList.Item>
1193
- )
1194
- }
1195
-
1196
- const repos = [
1197
- 'primer/primer-markdown',
1198
- 'primer/octicons',
1199
- 'primer/css',
1200
- 'primer/primer-layout',
1201
- 'primer/primer-alerts',
1202
- 'primer/primer-avatars',
1203
- 'primer/react',
1204
- 'primer/primitives'
1205
- ]
1206
-
1207
- export function AsyncListStory(): JSX.Element {
1208
- const [results, setResults] = React.useState(repos.slice(0, 6))
1209
- const [loading, setLoading] = React.useState(false)
1210
-
1211
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1212
- const filter = async (event: any) => {
1213
- setLoading(true)
1214
- const filteredResults = await filterSlowly(event.target.value)
1215
- setResults(filteredResults)
1216
- setLoading(false)
1217
- }
1218
-
1219
- return (
1220
- <>
1221
- <h1>Async List Items</h1>
1222
- <ErsatzOverlay>
1223
- <TextInput
1224
- onChange={filter}
1225
- placeholder="Search repositories, showing 6 by default"
1226
- sx={{m: 2, mb: 0, width: 'calc(100% - 16px)'}}
1227
- />
1228
- <ActionList sx={{height: 208, overflow: 'auto'}}>
1229
- {loading ? (
1230
- <Box sx={{display: 'flex', justifyContent: 'center', pt: 2}}>
1231
- <Spinner />
1232
- </Box>
1233
- ) : (
1234
- results.map(name => (
1235
- <ActionList.Item key={name}>
1236
- <ActionList.LeadingVisual>
1237
- <RepoIcon />
1238
- </ActionList.LeadingVisual>
1239
- {name}
1240
- </ActionList.Item>
1241
- ))
1242
- )}
1243
- </ActionList>
1244
- </ErsatzOverlay>
1245
- </>
1246
- )
1247
- }
1248
- AsyncListStory.storyName = 'Async List Options'
1249
-
1250
- const filterSlowly = async (query: string) => {
1251
- // sleep for 1s before returning results
1252
- await new Promise(resolve => setTimeout(resolve, 1000))
1253
- return await repos.filter(name => name.includes(query))
1254
- }
1255
-
1256
- export function InsideOverlay(): JSX.Element {
1257
- const [open, setOpen] = React.useState(false)
1258
- const toggle = () => setOpen(!open)
1259
- return (
1260
- <>
1261
- <h1>Inside Overlay</h1>
1262
- <AnchoredOverlay
1263
- open={open}
1264
- onOpen={toggle}
1265
- onClose={toggle}
1266
- renderAnchor={props => <button {...props}>toggle overlay</button>}
1267
- >
1268
- <ActionList>
1269
- <ActionList.Item>
1270
- Use your arrow keys
1271
- <ActionList.TrailingVisual>↓</ActionList.TrailingVisual>
1272
- </ActionList.Item>
1273
- <ActionList.Item>
1274
- keep going
1275
- <ActionList.TrailingVisual>↓</ActionList.TrailingVisual>
1276
- </ActionList.Item>
1277
- <ActionList.Item>
1278
- more more
1279
- <ActionList.TrailingVisual>↓</ActionList.TrailingVisual>
1280
- </ActionList.Item>
1281
- <ActionList.Divider />
1282
- <ActionList.Item variant="danger">
1283
- now go up!
1284
- <ActionList.TrailingVisual>↑</ActionList.TrailingVisual>
1285
- </ActionList.Item>
1286
- </ActionList>
1287
- </AnchoredOverlay>
1288
- </>
1289
- )
1290
- }
1291
- InsideOverlay.storyName = 'Inside Overlay'