@primer/components 32.1.0-rc.6f5d2b00 → 32.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1009) hide show
  1. package/package.json +1 -1
  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 -31
  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 -35
  15. package/.github/workflows/release_canary.yml +0 -70
  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/Checkbox.md +0 -118
  60. package/docs/content/CircleBadge.md +0 -35
  61. package/docs/content/CircleOcticon.md +0 -18
  62. package/docs/content/CounterLabel.md +0 -22
  63. package/docs/content/Details.md +0 -105
  64. package/docs/content/Dialog.md +0 -105
  65. package/docs/content/Dialog2.mdx +0 -180
  66. package/docs/content/Dropdown.md +0 -65
  67. package/docs/content/DropdownMenu.mdx +0 -49
  68. package/docs/content/FilterList.md +0 -37
  69. package/docs/content/FilteredSearch.md +0 -32
  70. package/docs/content/Flash.md +0 -35
  71. package/docs/content/Flex.md +0 -58
  72. package/docs/content/FormGroup.md +0 -38
  73. package/docs/content/Grid.md +0 -59
  74. package/docs/content/Header.md +0 -77
  75. package/docs/content/Heading.md +0 -22
  76. package/docs/content/Label.md +0 -49
  77. package/docs/content/LabelGroup.md +0 -21
  78. package/docs/content/Link.md +0 -28
  79. package/docs/content/Overlay.mdx +0 -85
  80. package/docs/content/Pagehead.md +0 -18
  81. package/docs/content/Pagination.md +0 -178
  82. package/docs/content/PointerBox.md +0 -81
  83. package/docs/content/Popover.md +0 -129
  84. package/docs/content/Portal.mdx +0 -78
  85. package/docs/content/Position.md +0 -100
  86. package/docs/content/ProgressBar.mdx +0 -29
  87. package/docs/content/SelectMenu.md +0 -371
  88. package/docs/content/SelectPanel.mdx +0 -67
  89. package/docs/content/SideNav.md +0 -171
  90. package/docs/content/Spinner.mdx +0 -32
  91. package/docs/content/StateLabel.md +0 -27
  92. package/docs/content/StyledOcticon.md +0 -27
  93. package/docs/content/SubNav.md +0 -100
  94. package/docs/content/TabNav.md +0 -42
  95. package/docs/content/Text.md +0 -31
  96. package/docs/content/TextInput.md +0 -34
  97. package/docs/content/TextInputTokens.mdx +0 -89
  98. package/docs/content/TextInputWithTokens.mdx +0 -211
  99. package/docs/content/Timeline.md +0 -148
  100. package/docs/content/Token.mdx +0 -381
  101. package/docs/content/Tooltip.md +0 -32
  102. package/docs/content/Truncate.md +0 -55
  103. package/docs/content/UnderlineNav.md +0 -45
  104. package/docs/content/anchoredPosition.mdx +0 -163
  105. package/docs/content/core-concepts.md +0 -70
  106. package/docs/content/focusTrap.mdx +0 -103
  107. package/docs/content/focusZone.mdx +0 -145
  108. package/docs/content/getting-started.md +0 -138
  109. package/docs/content/index.md +0 -33
  110. package/docs/content/linting.md +0 -35
  111. package/docs/content/overriding-styles.mdx +0 -82
  112. package/docs/content/philosophy.md +0 -23
  113. package/docs/content/primer-theme.md +0 -89
  114. package/docs/content/ssr.mdx +0 -43
  115. package/docs/content/system-props.mdx +0 -37
  116. package/docs/content/theme-reference.md +0 -16
  117. package/docs/content/theming.md +0 -272
  118. package/docs/content/useOnEscapePress.mdx +0 -56
  119. package/docs/content/useOnOutsideClick.mdx +0 -57
  120. package/docs/content/useOpenAndCloseFocus.mdx +0 -49
  121. package/docs/content/useOverlay.mdx +0 -62
  122. package/docs/content/useSafeTimeout.mdx +0 -32
  123. package/docs/gatsby-config.js +0 -30
  124. package/docs/gatsby-node.js +0 -101
  125. package/docs/package-lock.json +0 -20867
  126. package/docs/package.json +0 -36
  127. package/docs/src/@primer/gatsby-theme-doctocat/components/hero.js +0 -21
  128. package/docs/src/@primer/gatsby-theme-doctocat/components/live-preview-wrapper.js +0 -41
  129. package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +0 -73
  130. package/docs/src/@primer/gatsby-theme-doctocat/nav.yml +0 -135
  131. package/docs/src/@primer/gatsby-theme-doctocat/primer-components-hero.svg +0 -1411
  132. package/docs/src/component-checklist.js +0 -81
  133. package/docs/src/props.js +0 -77
  134. package/jest.config.js +0 -13
  135. package/lib/__tests__/ActionList.test.d.ts +0 -1
  136. package/lib/__tests__/ActionList.test.js +0 -69
  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__/ActionList2.test.d.ts +0 -1
  140. package/lib/__tests__/ActionList2.test.js +0 -53
  141. package/lib/__tests__/ActionMenu.test.d.ts +0 -1
  142. package/lib/__tests__/ActionMenu.test.js +0 -151
  143. package/lib/__tests__/AnchoredOverlay.test.d.ts +0 -1
  144. package/lib/__tests__/AnchoredOverlay.test.js +0 -162
  145. package/lib/__tests__/Autocomplete.test.d.ts +0 -1
  146. package/lib/__tests__/Autocomplete.test.js +0 -528
  147. package/lib/__tests__/Avatar.test.d.ts +0 -1
  148. package/lib/__tests__/Avatar.test.js +0 -67
  149. package/lib/__tests__/AvatarStack.test.d.ts +0 -1
  150. package/lib/__tests__/AvatarStack.test.js +0 -71
  151. package/lib/__tests__/BorderBox.test.d.ts +0 -1
  152. package/lib/__tests__/BorderBox.test.js +0 -58
  153. package/lib/__tests__/Box.test.d.ts +0 -1
  154. package/lib/__tests__/Box.test.js +0 -78
  155. package/lib/__tests__/BranchName.test.d.ts +0 -1
  156. package/lib/__tests__/BranchName.test.js +0 -36
  157. package/lib/__tests__/Breadcrumbs.test.d.ts +0 -1
  158. package/lib/__tests__/Breadcrumbs.test.js +0 -40
  159. package/lib/__tests__/Breadcrumbs.types.test.d.ts +0 -3
  160. package/lib/__tests__/Breadcrumbs.types.test.js +0 -25
  161. package/lib/__tests__/BreadcrumbsItem.test.d.ts +0 -1
  162. package/lib/__tests__/BreadcrumbsItem.test.js +0 -49
  163. package/lib/__tests__/Button.test.d.ts +0 -1
  164. package/lib/__tests__/Button.test.js +0 -147
  165. package/lib/__tests__/Caret.test.d.ts +0 -1
  166. package/lib/__tests__/Caret.test.js +0 -52
  167. package/lib/__tests__/Checkbox.test.d.ts +0 -2
  168. package/lib/__tests__/Checkbox.test.js +0 -189
  169. package/lib/__tests__/CircleBadge.test.d.ts +0 -1
  170. package/lib/__tests__/CircleBadge.test.js +0 -83
  171. package/lib/__tests__/CircleBadge.types.test.d.ts +0 -3
  172. package/lib/__tests__/CircleBadge.types.test.js +0 -28
  173. package/lib/__tests__/CircleOcticon.test.d.ts +0 -1
  174. package/lib/__tests__/CircleOcticon.test.js +0 -71
  175. package/lib/__tests__/ConfirmationDialog.test.d.ts +0 -1
  176. package/lib/__tests__/ConfirmationDialog.test.js +0 -134
  177. package/lib/__tests__/CounterLabel.test.d.ts +0 -1
  178. package/lib/__tests__/CounterLabel.test.js +0 -58
  179. package/lib/__tests__/CounterLabel.types.test.d.ts +0 -3
  180. package/lib/__tests__/CounterLabel.types.test.js +0 -28
  181. package/lib/__tests__/Details.test.d.ts +0 -1
  182. package/lib/__tests__/Details.test.js +0 -117
  183. package/lib/__tests__/Dialog.test.d.ts +0 -1
  184. package/lib/__tests__/Dialog.test.js +0 -184
  185. package/lib/__tests__/Dialog.types.test.d.ts +0 -3
  186. package/lib/__tests__/Dialog.types.test.js +0 -28
  187. package/lib/__tests__/Dialog2.types.test.d.ts +0 -3
  188. package/lib/__tests__/Dialog2.types.test.js +0 -31
  189. package/lib/__tests__/Dropdown.test.d.ts +0 -1
  190. package/lib/__tests__/Dropdown.test.js +0 -63
  191. package/lib/__tests__/Dropdown.types.test.d.ts +0 -3
  192. package/lib/__tests__/Dropdown.types.test.js +0 -31
  193. package/lib/__tests__/DropdownMenu.test.d.ts +0 -1
  194. package/lib/__tests__/DropdownMenu.test.js +0 -150
  195. package/lib/__tests__/FilterList.test.d.ts +0 -1
  196. package/lib/__tests__/FilterList.test.js +0 -36
  197. package/lib/__tests__/FilterList.types.test.d.ts +0 -3
  198. package/lib/__tests__/FilterList.types.test.js +0 -27
  199. package/lib/__tests__/FilterListItem.test.d.ts +0 -1
  200. package/lib/__tests__/FilterListItem.test.js +0 -46
  201. package/lib/__tests__/FilteredSearch.test.d.ts +0 -1
  202. package/lib/__tests__/FilteredSearch.test.js +0 -36
  203. package/lib/__tests__/FilteredSearch.types.test.d.ts +0 -3
  204. package/lib/__tests__/FilteredSearch.types.test.js +0 -28
  205. package/lib/__tests__/Flash.test.d.ts +0 -1
  206. package/lib/__tests__/Flash.test.js +0 -62
  207. package/lib/__tests__/Flash.types.test.d.ts +0 -3
  208. package/lib/__tests__/Flash.types.test.js +0 -28
  209. package/lib/__tests__/Flex.test.d.ts +0 -1
  210. package/lib/__tests__/Flex.test.js +0 -74
  211. package/lib/__tests__/FormGroup.test.d.ts +0 -1
  212. package/lib/__tests__/FormGroup.test.js +0 -54
  213. package/lib/__tests__/FormGroup.types.test.d.ts +0 -3
  214. package/lib/__tests__/FormGroup.types.test.js +0 -28
  215. package/lib/__tests__/Grid.test.d.ts +0 -1
  216. package/lib/__tests__/Grid.test.js +0 -104
  217. package/lib/__tests__/Header.test.d.ts +0 -1
  218. package/lib/__tests__/Header.test.js +0 -58
  219. package/lib/__tests__/Header.types.test.d.ts +0 -3
  220. package/lib/__tests__/Header.types.test.js +0 -29
  221. package/lib/__tests__/Heading.test.d.ts +0 -1
  222. package/lib/__tests__/Heading.test.js +0 -109
  223. package/lib/__tests__/KeyPaths.types.test.d.ts +0 -11
  224. package/lib/__tests__/KeyPaths.types.test.js +0 -10
  225. package/lib/__tests__/Label.test.d.ts +0 -1
  226. package/lib/__tests__/Label.test.js +0 -46
  227. package/lib/__tests__/Label.types.test.d.ts +0 -3
  228. package/lib/__tests__/Label.types.test.js +0 -28
  229. package/lib/__tests__/LabelGroup.test.d.ts +0 -1
  230. package/lib/__tests__/LabelGroup.test.js +0 -38
  231. package/lib/__tests__/LabelGroup.types.test.d.ts +0 -3
  232. package/lib/__tests__/LabelGroup.types.test.js +0 -28
  233. package/lib/__tests__/Link.test.d.ts +0 -1
  234. package/lib/__tests__/Link.test.js +0 -76
  235. package/lib/__tests__/Link.types.test.d.ts +0 -3
  236. package/lib/__tests__/Link.types.test.js +0 -28
  237. package/lib/__tests__/Merge.types.test.d.ts +0 -30
  238. package/lib/__tests__/Merge.types.test.js +0 -27
  239. package/lib/__tests__/NewButton.test.d.ts +0 -1
  240. package/lib/__tests__/NewButton.test.js +0 -95
  241. package/lib/__tests__/Overlay.test.d.ts +0 -1
  242. package/lib/__tests__/Overlay.test.js +0 -145
  243. package/lib/__tests__/Overlay.types.test.d.ts +0 -6
  244. package/lib/__tests__/Overlay.types.test.js +0 -73
  245. package/lib/__tests__/Pagehead.test.d.ts +0 -1
  246. package/lib/__tests__/Pagehead.test.js +0 -37
  247. package/lib/__tests__/Pagehead.types.test.d.ts +0 -3
  248. package/lib/__tests__/Pagehead.types.test.js +0 -28
  249. package/lib/__tests__/Pagination/Pagination.test.d.ts +0 -1
  250. package/lib/__tests__/Pagination/Pagination.test.js +0 -47
  251. package/lib/__tests__/Pagination/PaginationModel.test.d.ts +0 -1
  252. package/lib/__tests__/Pagination/PaginationModel.test.js +0 -186
  253. package/lib/__tests__/Pagination.types.test.d.ts +0 -3
  254. package/lib/__tests__/Pagination.types.test.js +0 -33
  255. package/lib/__tests__/PointerBox.test.d.ts +0 -1
  256. package/lib/__tests__/PointerBox.test.js +0 -46
  257. package/lib/__tests__/Popover.test.d.ts +0 -1
  258. package/lib/__tests__/Popover.test.js +0 -66
  259. package/lib/__tests__/Popover.types.test.d.ts +0 -3
  260. package/lib/__tests__/Popover.types.test.js +0 -27
  261. package/lib/__tests__/Portal.test.d.ts +0 -1
  262. package/lib/__tests__/Portal.test.js +0 -124
  263. package/lib/__tests__/Position.test.d.ts +0 -1
  264. package/lib/__tests__/Position.test.js +0 -143
  265. package/lib/__tests__/ProgressBar.test.d.ts +0 -1
  266. package/lib/__tests__/ProgressBar.test.js +0 -68
  267. package/lib/__tests__/SelectMenu.test.d.ts +0 -1
  268. package/lib/__tests__/SelectMenu.test.js +0 -155
  269. package/lib/__tests__/SelectMenu.types.test.d.ts +0 -3
  270. package/lib/__tests__/SelectMenu.types.test.js +0 -47
  271. package/lib/__tests__/SelectPanel.test.d.ts +0 -1
  272. package/lib/__tests__/SelectPanel.test.js +0 -80
  273. package/lib/__tests__/SelectPanel.types.test.d.ts +0 -3
  274. package/lib/__tests__/SelectPanel.types.test.js +0 -44
  275. package/lib/__tests__/SideNav.test.d.ts +0 -1
  276. package/lib/__tests__/SideNav.test.js +0 -71
  277. package/lib/__tests__/SideNav.types.test.d.ts +0 -3
  278. package/lib/__tests__/SideNav.types.test.js +0 -28
  279. package/lib/__tests__/Spinner.test.d.ts +0 -1
  280. package/lib/__tests__/Spinner.test.js +0 -53
  281. package/lib/__tests__/StateLabel.test.d.ts +0 -1
  282. package/lib/__tests__/StateLabel.test.js +0 -71
  283. package/lib/__tests__/StateLabel.types.test.d.ts +0 -3
  284. package/lib/__tests__/StateLabel.types.test.js +0 -28
  285. package/lib/__tests__/StyledOcticon.test.d.ts +0 -1
  286. package/lib/__tests__/StyledOcticon.test.js +0 -40
  287. package/lib/__tests__/StyledOcticon.types.test.d.ts +0 -3
  288. package/lib/__tests__/StyledOcticon.types.test.js +0 -32
  289. package/lib/__tests__/SubNav.test.d.ts +0 -1
  290. package/lib/__tests__/SubNav.test.js +0 -62
  291. package/lib/__tests__/SubNav.types.test.d.ts +0 -3
  292. package/lib/__tests__/SubNav.types.test.js +0 -27
  293. package/lib/__tests__/SubNavLink.test.d.ts +0 -1
  294. package/lib/__tests__/SubNavLink.test.js +0 -49
  295. package/lib/__tests__/TabNav.test.d.ts +0 -1
  296. package/lib/__tests__/TabNav.test.js +0 -49
  297. package/lib/__tests__/TabNav.types.test.d.ts +0 -3
  298. package/lib/__tests__/TabNav.types.test.js +0 -25
  299. package/lib/__tests__/Text.test.d.ts +0 -1
  300. package/lib/__tests__/Text.test.js +0 -105
  301. package/lib/__tests__/TextInput.test.d.ts +0 -1
  302. package/lib/__tests__/TextInput.test.js +0 -78
  303. package/lib/__tests__/TextInputWithTokens.test.d.ts +0 -1
  304. package/lib/__tests__/TextInputWithTokens.test.js +0 -572
  305. package/lib/__tests__/ThemeProvider.test.d.ts +0 -1
  306. package/lib/__tests__/ThemeProvider.test.js +0 -444
  307. package/lib/__tests__/Timeline.test.d.ts +0 -1
  308. package/lib/__tests__/Timeline.test.js +0 -75
  309. package/lib/__tests__/Timeline.types.test.d.ts +0 -3
  310. package/lib/__tests__/Timeline.types.test.js +0 -31
  311. package/lib/__tests__/Token.test.d.ts +0 -1
  312. package/lib/__tests__/Token.test.js +0 -180
  313. package/lib/__tests__/Tooltip.test.d.ts +0 -1
  314. package/lib/__tests__/Tooltip.test.js +0 -69
  315. package/lib/__tests__/Tooltip.types.test.d.ts +0 -3
  316. package/lib/__tests__/Tooltip.types.test.js +0 -28
  317. package/lib/__tests__/Truncate.test.d.ts +0 -1
  318. package/lib/__tests__/Truncate.test.js +0 -63
  319. package/lib/__tests__/Truncate.types.test.d.ts +0 -3
  320. package/lib/__tests__/Truncate.types.test.js +0 -31
  321. package/lib/__tests__/UnderlineNav.test.d.ts +0 -1
  322. package/lib/__tests__/UnderlineNav.test.js +0 -72
  323. package/lib/__tests__/UnderlineNav.types.test.d.ts +0 -3
  324. package/lib/__tests__/UnderlineNav.types.test.js +0 -25
  325. package/lib/__tests__/UnderlineNavLink.test.d.ts +0 -1
  326. package/lib/__tests__/UnderlineNavLink.test.js +0 -51
  327. package/lib/__tests__/behaviors/anchoredPosition.test.d.ts +0 -1
  328. package/lib/__tests__/behaviors/anchoredPosition.test.js +0 -390
  329. package/lib/__tests__/behaviors/focusTrap.test.d.ts +0 -1
  330. package/lib/__tests__/behaviors/focusTrap.test.js +0 -234
  331. package/lib/__tests__/behaviors/focusZone.test.d.ts +0 -1
  332. package/lib/__tests__/behaviors/focusZone.test.js +0 -570
  333. package/lib/__tests__/behaviors/iterateFocusableElements.test.d.ts +0 -1
  334. package/lib/__tests__/behaviors/iterateFocusableElements.test.js +0 -55
  335. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +0 -1
  336. package/lib/__tests__/behaviors/scrollIntoViewingArea.test.js +0 -226
  337. package/lib/__tests__/filterObject.test.d.ts +0 -1
  338. package/lib/__tests__/filterObject.test.js +0 -30
  339. package/lib/__tests__/hooks/useAnchoredPosition.test.d.ts +0 -1
  340. package/lib/__tests__/hooks/useAnchoredPosition.test.js +0 -54
  341. package/lib/__tests__/hooks/useOnEscapePress.test.d.ts +0 -1
  342. package/lib/__tests__/hooks/useOnEscapePress.test.js +0 -32
  343. package/lib/__tests__/hooks/useOnOutsideClick.test.d.ts +0 -1
  344. package/lib/__tests__/hooks/useOnOutsideClick.test.js +0 -87
  345. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +0 -1
  346. package/lib/__tests__/hooks/useOpenAndCloseFocus.test.js +0 -60
  347. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +0 -1
  348. package/lib/__tests__/hooks/useProvidedStateOrCreate.test.js +0 -45
  349. package/lib/__tests__/theme.test.d.ts +0 -1
  350. package/lib/__tests__/theme.test.js +0 -36
  351. package/lib/__tests__/themeGet.test.d.ts +0 -1
  352. package/lib/__tests__/themeGet.test.js +0 -25
  353. package/lib/__tests__/useSafeTimeout.test.d.ts +0 -1
  354. package/lib/__tests__/useSafeTimeout.test.js +0 -45
  355. package/lib/__tests__/utils/createSlots.test.d.ts +0 -1
  356. package/lib/__tests__/utils/createSlots.test.js +0 -75
  357. package/lib/stories/ActionList.stories.js +0 -454
  358. package/lib/stories/ActionList2.stories.js +0 -909
  359. package/lib/stories/ActionMenu.stories.js +0 -348
  360. package/lib/stories/AnchoredOverlay.stories.js +0 -127
  361. package/lib/stories/Autocomplete.stories.js +0 -619
  362. package/lib/stories/AvatarStack.stories.js +0 -49
  363. package/lib/stories/Button.stories.js +0 -125
  364. package/lib/stories/Checkbox.stories.js +0 -227
  365. package/lib/stories/ConfirmationDialog.stories.js +0 -119
  366. package/lib/stories/Dialog.stories.js +0 -269
  367. package/lib/stories/DropdownMenu.stories.js +0 -122
  368. package/lib/stories/IssueLabelToken.stories.js +0 -165
  369. package/lib/stories/NewButton.stories.js +0 -230
  370. package/lib/stories/Overlay.stories.js +0 -204
  371. package/lib/stories/Portal.stories.js +0 -104
  372. package/lib/stories/ProfileToken.stories.js +0 -162
  373. package/lib/stories/SelectPanel.stories.js +0 -399
  374. package/lib/stories/TextInput.stories.js +0 -144
  375. package/lib/stories/TextInputWithTokens.stories.js +0 -252
  376. package/lib/stories/ThemeProvider.stories.js +0 -102
  377. package/lib/stories/Token.stories.js +0 -176
  378. package/lib/stories/useAnchoredPosition.stories.js +0 -351
  379. package/lib/stories/useFocusTrap.stories.js +0 -360
  380. package/lib/stories/useFocusZone.stories.js +0 -607
  381. package/lib-esm/__tests__/ActionList.test.d.ts +0 -1
  382. package/lib-esm/__tests__/ActionList.test.js +0 -57
  383. package/lib-esm/__tests__/ActionList.types.test.d.ts +0 -6
  384. package/lib-esm/__tests__/ActionList.types.test.js +0 -45
  385. package/lib-esm/__tests__/ActionList2.test.d.ts +0 -1
  386. package/lib-esm/__tests__/ActionList2.test.js +0 -41
  387. package/lib-esm/__tests__/ActionMenu.test.d.ts +0 -1
  388. package/lib-esm/__tests__/ActionMenu.test.js +0 -139
  389. package/lib-esm/__tests__/AnchoredOverlay.test.d.ts +0 -1
  390. package/lib-esm/__tests__/AnchoredOverlay.test.js +0 -136
  391. package/lib-esm/__tests__/Autocomplete.test.d.ts +0 -1
  392. package/lib-esm/__tests__/Autocomplete.test.js +0 -494
  393. package/lib-esm/__tests__/Avatar.test.d.ts +0 -1
  394. package/lib-esm/__tests__/Avatar.test.js +0 -56
  395. package/lib-esm/__tests__/AvatarStack.test.d.ts +0 -1
  396. package/lib-esm/__tests__/AvatarStack.test.js +0 -58
  397. package/lib-esm/__tests__/BorderBox.test.d.ts +0 -1
  398. package/lib-esm/__tests__/BorderBox.test.js +0 -47
  399. package/lib-esm/__tests__/Box.test.d.ts +0 -1
  400. package/lib-esm/__tests__/Box.test.js +0 -67
  401. package/lib-esm/__tests__/BranchName.test.d.ts +0 -1
  402. package/lib-esm/__tests__/BranchName.test.js +0 -26
  403. package/lib-esm/__tests__/Breadcrumbs.test.d.ts +0 -1
  404. package/lib-esm/__tests__/Breadcrumbs.test.js +0 -30
  405. package/lib-esm/__tests__/Breadcrumbs.types.test.d.ts +0 -3
  406. package/lib-esm/__tests__/Breadcrumbs.types.test.js +0 -12
  407. package/lib-esm/__tests__/BreadcrumbsItem.test.d.ts +0 -1
  408. package/lib-esm/__tests__/BreadcrumbsItem.test.js +0 -39
  409. package/lib-esm/__tests__/Button.test.d.ts +0 -1
  410. package/lib-esm/__tests__/Button.test.js +0 -137
  411. package/lib-esm/__tests__/Caret.test.d.ts +0 -1
  412. package/lib-esm/__tests__/Caret.test.js +0 -42
  413. package/lib-esm/__tests__/Checkbox.test.d.ts +0 -2
  414. package/lib-esm/__tests__/Checkbox.test.js +0 -169
  415. package/lib-esm/__tests__/CircleBadge.test.d.ts +0 -1
  416. package/lib-esm/__tests__/CircleBadge.test.js +0 -70
  417. package/lib-esm/__tests__/CircleBadge.types.test.d.ts +0 -3
  418. package/lib-esm/__tests__/CircleBadge.types.test.js +0 -13
  419. package/lib-esm/__tests__/CircleOcticon.test.d.ts +0 -1
  420. package/lib-esm/__tests__/CircleOcticon.test.js +0 -59
  421. package/lib-esm/__tests__/ConfirmationDialog.test.d.ts +0 -1
  422. package/lib-esm/__tests__/ConfirmationDialog.test.js +0 -113
  423. package/lib-esm/__tests__/CounterLabel.test.d.ts +0 -1
  424. package/lib-esm/__tests__/CounterLabel.test.js +0 -47
  425. package/lib-esm/__tests__/CounterLabel.types.test.d.ts +0 -3
  426. package/lib-esm/__tests__/CounterLabel.types.test.js +0 -13
  427. package/lib-esm/__tests__/Details.test.d.ts +0 -1
  428. package/lib-esm/__tests__/Details.test.js +0 -107
  429. package/lib-esm/__tests__/Dialog.test.d.ts +0 -1
  430. package/lib-esm/__tests__/Dialog.test.js +0 -171
  431. package/lib-esm/__tests__/Dialog.types.test.d.ts +0 -3
  432. package/lib-esm/__tests__/Dialog.types.test.js +0 -13
  433. package/lib-esm/__tests__/Dialog2.types.test.d.ts +0 -3
  434. package/lib-esm/__tests__/Dialog2.types.test.js +0 -16
  435. package/lib-esm/__tests__/Dropdown.test.d.ts +0 -1
  436. package/lib-esm/__tests__/Dropdown.test.js +0 -53
  437. package/lib-esm/__tests__/Dropdown.types.test.d.ts +0 -3
  438. package/lib-esm/__tests__/Dropdown.types.test.js +0 -17
  439. package/lib-esm/__tests__/DropdownMenu.test.d.ts +0 -1
  440. package/lib-esm/__tests__/DropdownMenu.test.js +0 -137
  441. package/lib-esm/__tests__/FilterList.test.d.ts +0 -1
  442. package/lib-esm/__tests__/FilterList.test.js +0 -26
  443. package/lib-esm/__tests__/FilterList.types.test.d.ts +0 -3
  444. package/lib-esm/__tests__/FilterList.types.test.js +0 -13
  445. package/lib-esm/__tests__/FilterListItem.test.d.ts +0 -1
  446. package/lib-esm/__tests__/FilterListItem.test.js +0 -36
  447. package/lib-esm/__tests__/FilteredSearch.test.d.ts +0 -1
  448. package/lib-esm/__tests__/FilteredSearch.test.js +0 -26
  449. package/lib-esm/__tests__/FilteredSearch.types.test.d.ts +0 -3
  450. package/lib-esm/__tests__/FilteredSearch.types.test.js +0 -13
  451. package/lib-esm/__tests__/Flash.test.d.ts +0 -1
  452. package/lib-esm/__tests__/Flash.test.js +0 -51
  453. package/lib-esm/__tests__/Flash.types.test.d.ts +0 -3
  454. package/lib-esm/__tests__/Flash.types.test.js +0 -13
  455. package/lib-esm/__tests__/Flex.test.d.ts +0 -1
  456. package/lib-esm/__tests__/Flex.test.js +0 -64
  457. package/lib-esm/__tests__/FormGroup.test.d.ts +0 -1
  458. package/lib-esm/__tests__/FormGroup.test.js +0 -44
  459. package/lib-esm/__tests__/FormGroup.types.test.d.ts +0 -3
  460. package/lib-esm/__tests__/FormGroup.types.test.js +0 -13
  461. package/lib-esm/__tests__/Grid.test.d.ts +0 -1
  462. package/lib-esm/__tests__/Grid.test.js +0 -94
  463. package/lib-esm/__tests__/Header.test.d.ts +0 -1
  464. package/lib-esm/__tests__/Header.test.js +0 -48
  465. package/lib-esm/__tests__/Header.types.test.d.ts +0 -3
  466. package/lib-esm/__tests__/Header.types.test.js +0 -15
  467. package/lib-esm/__tests__/Heading.test.d.ts +0 -1
  468. package/lib-esm/__tests__/Heading.test.js +0 -99
  469. package/lib-esm/__tests__/KeyPaths.types.test.d.ts +0 -11
  470. package/lib-esm/__tests__/KeyPaths.types.test.js +0 -3
  471. package/lib-esm/__tests__/Label.test.d.ts +0 -1
  472. package/lib-esm/__tests__/Label.test.js +0 -36
  473. package/lib-esm/__tests__/Label.types.test.d.ts +0 -3
  474. package/lib-esm/__tests__/Label.types.test.js +0 -13
  475. package/lib-esm/__tests__/LabelGroup.test.d.ts +0 -1
  476. package/lib-esm/__tests__/LabelGroup.test.js +0 -26
  477. package/lib-esm/__tests__/LabelGroup.types.test.d.ts +0 -3
  478. package/lib-esm/__tests__/LabelGroup.types.test.js +0 -13
  479. package/lib-esm/__tests__/Link.test.d.ts +0 -1
  480. package/lib-esm/__tests__/Link.test.js +0 -66
  481. package/lib-esm/__tests__/Link.types.test.d.ts +0 -3
  482. package/lib-esm/__tests__/Link.types.test.js +0 -13
  483. package/lib-esm/__tests__/Merge.types.test.d.ts +0 -30
  484. package/lib-esm/__tests__/Merge.types.test.js +0 -14
  485. package/lib-esm/__tests__/NewButton.test.d.ts +0 -1
  486. package/lib-esm/__tests__/NewButton.test.js +0 -84
  487. package/lib-esm/__tests__/Overlay.test.d.ts +0 -1
  488. package/lib-esm/__tests__/Overlay.test.js +0 -123
  489. package/lib-esm/__tests__/Overlay.types.test.d.ts +0 -6
  490. package/lib-esm/__tests__/Overlay.types.test.js +0 -49
  491. package/lib-esm/__tests__/Pagehead.test.d.ts +0 -1
  492. package/lib-esm/__tests__/Pagehead.test.js +0 -26
  493. package/lib-esm/__tests__/Pagehead.types.test.d.ts +0 -3
  494. package/lib-esm/__tests__/Pagehead.types.test.js +0 -13
  495. package/lib-esm/__tests__/Pagination/Pagination.test.d.ts +0 -1
  496. package/lib-esm/__tests__/Pagination/Pagination.test.js +0 -35
  497. package/lib-esm/__tests__/Pagination/PaginationModel.test.d.ts +0 -1
  498. package/lib-esm/__tests__/Pagination/PaginationModel.test.js +0 -182
  499. package/lib-esm/__tests__/Pagination.types.test.d.ts +0 -3
  500. package/lib-esm/__tests__/Pagination.types.test.js +0 -18
  501. package/lib-esm/__tests__/PointerBox.test.d.ts +0 -1
  502. package/lib-esm/__tests__/PointerBox.test.js +0 -36
  503. package/lib-esm/__tests__/Popover.test.d.ts +0 -1
  504. package/lib-esm/__tests__/Popover.test.js +0 -53
  505. package/lib-esm/__tests__/Popover.types.test.d.ts +0 -3
  506. package/lib-esm/__tests__/Popover.types.test.js +0 -13
  507. package/lib-esm/__tests__/Portal.test.d.ts +0 -1
  508. package/lib-esm/__tests__/Portal.test.js +0 -104
  509. package/lib-esm/__tests__/Position.test.d.ts +0 -1
  510. package/lib-esm/__tests__/Position.test.js +0 -133
  511. package/lib-esm/__tests__/ProgressBar.test.d.ts +0 -1
  512. package/lib-esm/__tests__/ProgressBar.test.js +0 -58
  513. package/lib-esm/__tests__/SelectMenu.test.d.ts +0 -1
  514. package/lib-esm/__tests__/SelectMenu.test.js +0 -145
  515. package/lib-esm/__tests__/SelectMenu.types.test.d.ts +0 -3
  516. package/lib-esm/__tests__/SelectMenu.types.test.js +0 -33
  517. package/lib-esm/__tests__/SelectPanel.test.d.ts +0 -1
  518. package/lib-esm/__tests__/SelectPanel.test.js +0 -65
  519. package/lib-esm/__tests__/SelectPanel.types.test.d.ts +0 -3
  520. package/lib-esm/__tests__/SelectPanel.types.test.js +0 -29
  521. package/lib-esm/__tests__/SideNav.test.d.ts +0 -1
  522. package/lib-esm/__tests__/SideNav.test.js +0 -60
  523. package/lib-esm/__tests__/SideNav.types.test.d.ts +0 -3
  524. package/lib-esm/__tests__/SideNav.types.test.js +0 -13
  525. package/lib-esm/__tests__/Spinner.test.d.ts +0 -1
  526. package/lib-esm/__tests__/Spinner.test.js +0 -43
  527. package/lib-esm/__tests__/StateLabel.test.d.ts +0 -1
  528. package/lib-esm/__tests__/StateLabel.test.js +0 -61
  529. package/lib-esm/__tests__/StateLabel.types.test.d.ts +0 -3
  530. package/lib-esm/__tests__/StateLabel.types.test.js +0 -13
  531. package/lib-esm/__tests__/StyledOcticon.test.d.ts +0 -1
  532. package/lib-esm/__tests__/StyledOcticon.test.js +0 -29
  533. package/lib-esm/__tests__/StyledOcticon.types.test.d.ts +0 -3
  534. package/lib-esm/__tests__/StyledOcticon.types.test.js +0 -16
  535. package/lib-esm/__tests__/SubNav.test.d.ts +0 -1
  536. package/lib-esm/__tests__/SubNav.test.js +0 -50
  537. package/lib-esm/__tests__/SubNav.types.test.d.ts +0 -3
  538. package/lib-esm/__tests__/SubNav.types.test.js +0 -14
  539. package/lib-esm/__tests__/SubNavLink.test.d.ts +0 -1
  540. package/lib-esm/__tests__/SubNavLink.test.js +0 -39
  541. package/lib-esm/__tests__/TabNav.test.d.ts +0 -1
  542. package/lib-esm/__tests__/TabNav.test.js +0 -39
  543. package/lib-esm/__tests__/TabNav.types.test.d.ts +0 -3
  544. package/lib-esm/__tests__/TabNav.types.test.js +0 -12
  545. package/lib-esm/__tests__/Text.test.d.ts +0 -1
  546. package/lib-esm/__tests__/Text.test.js +0 -93
  547. package/lib-esm/__tests__/TextInput.test.d.ts +0 -1
  548. package/lib-esm/__tests__/TextInput.test.js +0 -68
  549. package/lib-esm/__tests__/TextInputWithTokens.test.d.ts +0 -1
  550. package/lib-esm/__tests__/TextInputWithTokens.test.js +0 -511
  551. package/lib-esm/__tests__/ThemeProvider.test.d.ts +0 -1
  552. package/lib-esm/__tests__/ThemeProvider.test.js +0 -408
  553. package/lib-esm/__tests__/Timeline.test.d.ts +0 -1
  554. package/lib-esm/__tests__/Timeline.test.js +0 -65
  555. package/lib-esm/__tests__/Timeline.types.test.d.ts +0 -3
  556. package/lib-esm/__tests__/Timeline.types.test.js +0 -18
  557. package/lib-esm/__tests__/Token.test.d.ts +0 -1
  558. package/lib-esm/__tests__/Token.test.js +0 -166
  559. package/lib-esm/__tests__/Tooltip.test.d.ts +0 -1
  560. package/lib-esm/__tests__/Tooltip.test.js +0 -59
  561. package/lib-esm/__tests__/Tooltip.types.test.d.ts +0 -3
  562. package/lib-esm/__tests__/Tooltip.types.test.js +0 -13
  563. package/lib-esm/__tests__/Truncate.test.d.ts +0 -1
  564. package/lib-esm/__tests__/Truncate.test.js +0 -53
  565. package/lib-esm/__tests__/Truncate.types.test.d.ts +0 -3
  566. package/lib-esm/__tests__/Truncate.types.test.js +0 -16
  567. package/lib-esm/__tests__/UnderlineNav.test.d.ts +0 -1
  568. package/lib-esm/__tests__/UnderlineNav.test.js +0 -60
  569. package/lib-esm/__tests__/UnderlineNav.types.test.d.ts +0 -3
  570. package/lib-esm/__tests__/UnderlineNav.types.test.js +0 -12
  571. package/lib-esm/__tests__/UnderlineNavLink.test.d.ts +0 -1
  572. package/lib-esm/__tests__/UnderlineNavLink.test.js +0 -41
  573. package/lib-esm/__tests__/behaviors/anchoredPosition.test.d.ts +0 -1
  574. package/lib-esm/__tests__/behaviors/anchoredPosition.test.js +0 -388
  575. package/lib-esm/__tests__/behaviors/focusTrap.test.d.ts +0 -1
  576. package/lib-esm/__tests__/behaviors/focusTrap.test.js +0 -227
  577. package/lib-esm/__tests__/behaviors/focusZone.test.d.ts +0 -1
  578. package/lib-esm/__tests__/behaviors/focusZone.test.js +0 -487
  579. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.d.ts +0 -1
  580. package/lib-esm/__tests__/behaviors/iterateFocusableElements.test.js +0 -48
  581. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.d.ts +0 -1
  582. package/lib-esm/__tests__/behaviors/scrollIntoViewingArea.test.js +0 -224
  583. package/lib-esm/__tests__/filterObject.test.d.ts +0 -1
  584. package/lib-esm/__tests__/filterObject.test.js +0 -27
  585. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.d.ts +0 -1
  586. package/lib-esm/__tests__/hooks/useAnchoredPosition.test.js +0 -46
  587. package/lib-esm/__tests__/hooks/useOnEscapePress.test.d.ts +0 -1
  588. package/lib-esm/__tests__/hooks/useOnEscapePress.test.js +0 -23
  589. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.d.ts +0 -1
  590. package/lib-esm/__tests__/hooks/useOnOutsideClick.test.js +0 -68
  591. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.d.ts +0 -1
  592. package/lib-esm/__tests__/hooks/useOpenAndCloseFocus.test.js +0 -52
  593. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.d.ts +0 -1
  594. package/lib-esm/__tests__/hooks/useProvidedStateOrCreate.test.js +0 -36
  595. package/lib-esm/__tests__/theme.test.d.ts +0 -1
  596. package/lib-esm/__tests__/theme.test.js +0 -33
  597. package/lib-esm/__tests__/themeGet.test.d.ts +0 -1
  598. package/lib-esm/__tests__/themeGet.test.js +0 -22
  599. package/lib-esm/__tests__/useSafeTimeout.test.d.ts +0 -1
  600. package/lib-esm/__tests__/useSafeTimeout.test.js +0 -39
  601. package/lib-esm/__tests__/utils/createSlots.test.d.ts +0 -1
  602. package/lib-esm/__tests__/utils/createSlots.test.js +0 -67
  603. package/lib-esm/stories/ActionList.stories.js +0 -395
  604. package/lib-esm/stories/ActionList2.stories.js +0 -797
  605. package/lib-esm/stories/ActionMenu.stories.js +0 -303
  606. package/lib-esm/stories/AnchoredOverlay.stories.js +0 -101
  607. package/lib-esm/stories/Autocomplete.stories.js +0 -560
  608. package/lib-esm/stories/AvatarStack.stories.js +0 -32
  609. package/lib-esm/stories/Button.stories.js +0 -86
  610. package/lib-esm/stories/Checkbox.stories.js +0 -197
  611. package/lib-esm/stories/ConfirmationDialog.stories.js +0 -94
  612. package/lib-esm/stories/Dialog.stories.js +0 -244
  613. package/lib-esm/stories/DropdownMenu.stories.js +0 -94
  614. package/lib-esm/stories/IssueLabelToken.stories.js +0 -139
  615. package/lib-esm/stories/NewButton.stories.js +0 -178
  616. package/lib-esm/stories/Overlay.stories.js +0 -173
  617. package/lib-esm/stories/Portal.stories.js +0 -68
  618. package/lib-esm/stories/ProfileToken.stories.js +0 -136
  619. package/lib-esm/stories/SelectPanel.stories.js +0 -334
  620. package/lib-esm/stories/TextInput.stories.js +0 -117
  621. package/lib-esm/stories/TextInputWithTokens.stories.js +0 -210
  622. package/lib-esm/stories/ThemeProvider.stories.js +0 -83
  623. package/lib-esm/stories/Token.stories.js +0 -146
  624. package/lib-esm/stories/useAnchoredPosition.stories.js +0 -313
  625. package/lib-esm/stories/useFocusTrap.stories.js +0 -313
  626. package/lib-esm/stories/useFocusZone.stories.js +0 -562
  627. package/migrating.md +0 -250
  628. package/now.json +0 -17
  629. package/package-lock.json +0 -66509
  630. package/rollup.config.js +0 -36
  631. package/script/build +0 -21
  632. package/script/build-storybook +0 -10
  633. package/script/setup +0 -12
  634. package/src/ActionList/Divider.tsx +0 -25
  635. package/src/ActionList/Group.tsx +0 -45
  636. package/src/ActionList/Header.tsx +0 -74
  637. package/src/ActionList/Item.tsx +0 -480
  638. package/src/ActionList/List.tsx +0 -258
  639. package/src/ActionList/index.ts +0 -21
  640. package/src/ActionList2/Description.tsx +0 -52
  641. package/src/ActionList2/Divider.tsx +0 -24
  642. package/src/ActionList2/Group.tsx +0 -103
  643. package/src/ActionList2/Header.tsx +0 -58
  644. package/src/ActionList2/Item.tsx +0 -246
  645. package/src/ActionList2/LinkItem.tsx +0 -49
  646. package/src/ActionList2/List.tsx +0 -55
  647. package/src/ActionList2/Selection.tsx +0 -60
  648. package/src/ActionList2/Visuals.tsx +0 -76
  649. package/src/ActionList2/index.ts +0 -39
  650. package/src/ActionMenu.tsx +0 -106
  651. package/src/AnchoredOverlay/AnchoredOverlay.tsx +0 -191
  652. package/src/AnchoredOverlay/index.ts +0 -2
  653. package/src/Autocomplete/Autocomplete.tsx +0 -103
  654. package/src/Autocomplete/AutocompleteContext.tsx +0 -19
  655. package/src/Autocomplete/AutocompleteInput.tsx +0 -179
  656. package/src/Autocomplete/AutocompleteMenu.tsx +0 -341
  657. package/src/Autocomplete/AutocompleteOverlay.tsx +0 -68
  658. package/src/Autocomplete/index.ts +0 -2
  659. package/src/Avatar.tsx +0 -46
  660. package/src/AvatarPair.tsx +0 -35
  661. package/src/AvatarStack.tsx +0 -159
  662. package/src/BaseStyles.tsx +0 -53
  663. package/src/BorderBox.tsx +0 -18
  664. package/src/Box.tsx +0 -54
  665. package/src/BranchName.tsx +0 -19
  666. package/src/Breadcrumbs.tsx +0 -101
  667. package/src/Button/Button.tsx +0 -39
  668. package/src/Button/ButtonBase.tsx +0 -39
  669. package/src/Button/ButtonClose.tsx +0 -36
  670. package/src/Button/ButtonDanger.tsx +0 -42
  671. package/src/Button/ButtonGroup.tsx +0 -55
  672. package/src/Button/ButtonInvisible.tsx +0 -31
  673. package/src/Button/ButtonOutline.tsx +0 -42
  674. package/src/Button/ButtonPrimary.tsx +0 -40
  675. package/src/Button/ButtonStyles.tsx +0 -36
  676. package/src/Button/ButtonTableList.tsx +0 -45
  677. package/src/Button/index.ts +0 -16
  678. package/src/Caret.tsx +0 -133
  679. package/src/Checkbox.tsx +0 -75
  680. package/src/CircleBadge.tsx +0 -53
  681. package/src/CircleOcticon.tsx +0 -37
  682. package/src/CounterLabel.tsx +0 -50
  683. package/src/Details.tsx +0 -23
  684. package/src/Dialog/ConfirmationDialog.tsx +0 -184
  685. package/src/Dialog/Dialog.tsx +0 -444
  686. package/src/Dialog.tsx +0 -145
  687. package/src/Dropdown.tsx +0 -154
  688. package/src/DropdownMenu/DropdownButton.tsx +0 -15
  689. package/src/DropdownMenu/DropdownMenu.tsx +0 -115
  690. package/src/DropdownMenu/index.ts +0 -4
  691. package/src/DropdownStyles.ts +0 -128
  692. package/src/FilterList.tsx +0 -75
  693. package/src/FilteredActionList/FilteredActionList.tsx +0 -142
  694. package/src/FilteredActionList/index.ts +0 -2
  695. package/src/FilteredSearch.tsx +0 -27
  696. package/src/Flash.tsx +0 -75
  697. package/src/Flex.tsx +0 -15
  698. package/src/FormGroup.tsx +0 -24
  699. package/src/Grid.tsx +0 -15
  700. package/src/Header.tsx +0 -74
  701. package/src/Heading.tsx +0 -21
  702. package/src/Label.tsx +0 -72
  703. package/src/LabelGroup.tsx +0 -17
  704. package/src/Link.tsx +0 -42
  705. package/src/NewButton/button-counter.tsx +0 -15
  706. package/src/NewButton/button.tsx +0 -283
  707. package/src/NewButton/index.ts +0 -10
  708. package/src/NewButton/types.ts +0 -36
  709. package/src/Overlay.tsx +0 -203
  710. package/src/Pagehead.tsx +0 -16
  711. package/src/Pagination/Pagination.tsx +0 -212
  712. package/src/Pagination/index.ts +0 -4
  713. package/src/Pagination/model.tsx +0 -187
  714. package/src/PointerBox.tsx +0 -31
  715. package/src/Popover.tsx +0 -225
  716. package/src/Portal/Portal.tsx +0 -97
  717. package/src/Portal/index.ts +0 -5
  718. package/src/Position.tsx +0 -63
  719. package/src/ProgressBar.tsx +0 -52
  720. package/src/SelectMenu/SelectMenu.tsx +0 -123
  721. package/src/SelectMenu/SelectMenuContext.tsx +0 -9
  722. package/src/SelectMenu/SelectMenuDivider.tsx +0 -24
  723. package/src/SelectMenu/SelectMenuFilter.tsx +0 -50
  724. package/src/SelectMenu/SelectMenuFooter.tsx +0 -27
  725. package/src/SelectMenu/SelectMenuHeader.tsx +0 -48
  726. package/src/SelectMenu/SelectMenuItem.tsx +0 -136
  727. package/src/SelectMenu/SelectMenuList.tsx +0 -41
  728. package/src/SelectMenu/SelectMenuLoadingAnimation.tsx +0 -25
  729. package/src/SelectMenu/SelectMenuModal.tsx +0 -119
  730. package/src/SelectMenu/SelectMenuTab.tsx +0 -87
  731. package/src/SelectMenu/SelectMenuTabPanel.tsx +0 -29
  732. package/src/SelectMenu/SelectMenuTabs.tsx +0 -43
  733. package/src/SelectMenu/hooks/useKeyboardNav.js +0 -90
  734. package/src/SelectMenu/index.ts +0 -15
  735. package/src/SelectPanel/SelectPanel.tsx +0 -173
  736. package/src/SelectPanel/index.ts +0 -2
  737. package/src/SideNav.tsx +0 -191
  738. package/src/Spinner.tsx +0 -59
  739. package/src/StateLabel.tsx +0 -112
  740. package/src/StyledOcticon.tsx +0 -22
  741. package/src/SubNav.tsx +0 -124
  742. package/src/TabNav.tsx +0 -73
  743. package/src/Text.tsx +0 -13
  744. package/src/TextInput.tsx +0 -68
  745. package/src/TextInputWithTokens.tsx +0 -351
  746. package/src/ThemeProvider.tsx +0 -176
  747. package/src/Timeline.tsx +0 -140
  748. package/src/Token/AvatarToken.tsx +0 -54
  749. package/src/Token/IssueLabelToken.tsx +0 -150
  750. package/src/Token/Token.tsx +0 -126
  751. package/src/Token/TokenBase.tsx +0 -129
  752. package/src/Token/_RemoveTokenButton.tsx +0 -111
  753. package/src/Token/_TokenTextContainer.tsx +0 -47
  754. package/src/Token/index.ts +0 -3
  755. package/src/Tooltip.tsx +0 -263
  756. package/src/Truncate.tsx +0 -31
  757. package/src/UnderlineNav.tsx +0 -107
  758. package/src/_TextInputWrapper.tsx +0 -113
  759. package/src/_UnstyledTextInput.tsx +0 -19
  760. package/src/__tests__/.eslintrc.json +0 -11
  761. package/src/__tests__/ActionList.test.tsx +0 -53
  762. package/src/__tests__/ActionList.types.test.tsx +0 -51
  763. package/src/__tests__/ActionList2.test.tsx +0 -47
  764. package/src/__tests__/ActionMenu.test.tsx +0 -136
  765. package/src/__tests__/AnchoredOverlay.test.tsx +0 -150
  766. package/src/__tests__/Autocomplete.test.tsx +0 -444
  767. package/src/__tests__/Avatar.test.tsx +0 -44
  768. package/src/__tests__/AvatarStack.test.tsx +0 -48
  769. package/src/__tests__/BorderBox.test.tsx +0 -43
  770. package/src/__tests__/Box.test.tsx +0 -42
  771. package/src/__tests__/BranchName.test.tsx +0 -26
  772. package/src/__tests__/Breadcrumbs.test.tsx +0 -27
  773. package/src/__tests__/Breadcrumbs.types.test.tsx +0 -22
  774. package/src/__tests__/BreadcrumbsItem.test.tsx +0 -31
  775. package/src/__tests__/Button.test.tsx +0 -128
  776. package/src/__tests__/Caret.test.tsx +0 -36
  777. package/src/__tests__/Checkbox.test.tsx +0 -155
  778. package/src/__tests__/CircleBadge.test.tsx +0 -66
  779. package/src/__tests__/CircleBadge.types.test.tsx +0 -11
  780. package/src/__tests__/CircleOcticon.test.tsx +0 -50
  781. package/src/__tests__/ConfirmationDialog.test.tsx +0 -120
  782. package/src/__tests__/CounterLabel.test.tsx +0 -50
  783. package/src/__tests__/CounterLabel.types.test.tsx +0 -11
  784. package/src/__tests__/Details.test.tsx +0 -115
  785. package/src/__tests__/Dialog.test.tsx +0 -155
  786. package/src/__tests__/Dialog.types.test.tsx +0 -11
  787. package/src/__tests__/Dialog2.types.test.tsx +0 -11
  788. package/src/__tests__/Dropdown.test.tsx +0 -53
  789. package/src/__tests__/Dropdown.types.test.tsx +0 -21
  790. package/src/__tests__/DropdownMenu.test.tsx +0 -136
  791. package/src/__tests__/FilterList.test.tsx +0 -26
  792. package/src/__tests__/FilterList.types.test.tsx +0 -17
  793. package/src/__tests__/FilterListItem.test.tsx +0 -31
  794. package/src/__tests__/FilteredSearch.test.tsx +0 -26
  795. package/src/__tests__/FilteredSearch.types.test.tsx +0 -11
  796. package/src/__tests__/Flash.test.tsx +0 -45
  797. package/src/__tests__/Flash.types.test.tsx +0 -11
  798. package/src/__tests__/Flex.test.tsx +0 -58
  799. package/src/__tests__/FormGroup.test.tsx +0 -38
  800. package/src/__tests__/FormGroup.types.test.tsx +0 -11
  801. package/src/__tests__/Grid.test.tsx +0 -82
  802. package/src/__tests__/Header.test.tsx +0 -49
  803. package/src/__tests__/Header.types.test.tsx +0 -19
  804. package/src/__tests__/Heading.test.tsx +0 -91
  805. package/src/__tests__/KeyPaths.types.test.ts +0 -14
  806. package/src/__tests__/Label.test.tsx +0 -34
  807. package/src/__tests__/Label.types.test.tsx +0 -11
  808. package/src/__tests__/LabelGroup.test.tsx +0 -30
  809. package/src/__tests__/LabelGroup.types.test.tsx +0 -11
  810. package/src/__tests__/Link.test.tsx +0 -47
  811. package/src/__tests__/Link.types.test.tsx +0 -11
  812. package/src/__tests__/Merge.types.test.ts +0 -39
  813. package/src/__tests__/NewButton.test.tsx +0 -70
  814. package/src/__tests__/Overlay.test.tsx +0 -103
  815. package/src/__tests__/Overlay.types.test.tsx +0 -33
  816. package/src/__tests__/Pagehead.test.tsx +0 -23
  817. package/src/__tests__/Pagehead.types.test.tsx +0 -11
  818. package/src/__tests__/Pagination/Pagination.test.tsx +0 -30
  819. package/src/__tests__/Pagination/PaginationModel.test.tsx +0 -133
  820. package/src/__tests__/Pagination/__snapshots__/Pagination.test.tsx.snap +0 -184
  821. package/src/__tests__/Pagination.types.test.tsx +0 -11
  822. package/src/__tests__/PointerBox.test.tsx +0 -34
  823. package/src/__tests__/Popover.test.tsx +0 -68
  824. package/src/__tests__/Popover.types.test.tsx +0 -17
  825. package/src/__tests__/Portal.test.tsx +0 -103
  826. package/src/__tests__/Position.test.tsx +0 -117
  827. package/src/__tests__/ProgressBar.test.tsx +0 -40
  828. package/src/__tests__/SelectMenu.test.tsx +0 -142
  829. package/src/__tests__/SelectMenu.types.test.tsx +0 -37
  830. package/src/__tests__/SelectPanel.test.tsx +0 -63
  831. package/src/__tests__/SelectPanel.types.test.tsx +0 -31
  832. package/src/__tests__/SideNav.test.tsx +0 -62
  833. package/src/__tests__/SideNav.types.test.tsx +0 -11
  834. package/src/__tests__/Spinner.test.tsx +0 -42
  835. package/src/__tests__/StateLabel.test.tsx +0 -48
  836. package/src/__tests__/StateLabel.types.test.tsx +0 -11
  837. package/src/__tests__/StyledOcticon.test.tsx +0 -26
  838. package/src/__tests__/StyledOcticon.types.test.tsx +0 -12
  839. package/src/__tests__/SubNav.test.tsx +0 -50
  840. package/src/__tests__/SubNav.types.test.tsx +0 -25
  841. package/src/__tests__/SubNavLink.test.tsx +0 -31
  842. package/src/__tests__/TabNav.test.tsx +0 -32
  843. package/src/__tests__/TabNav.types.test.tsx +0 -22
  844. package/src/__tests__/Text.test.tsx +0 -78
  845. package/src/__tests__/TextInput.test.tsx +0 -49
  846. package/src/__tests__/TextInputWithTokens.test.tsx +0 -422
  847. package/src/__tests__/ThemeProvider.test.tsx +0 -441
  848. package/src/__tests__/Timeline.test.tsx +0 -58
  849. package/src/__tests__/Timeline.types.test.tsx +0 -31
  850. package/src/__tests__/Token.test.tsx +0 -118
  851. package/src/__tests__/Tooltip.test.tsx +0 -52
  852. package/src/__tests__/Tooltip.types.test.tsx +0 -11
  853. package/src/__tests__/Truncate.test.tsx +0 -43
  854. package/src/__tests__/Truncate.types.test.tsx +0 -11
  855. package/src/__tests__/UnderlineNav.test.tsx +0 -58
  856. package/src/__tests__/UnderlineNav.types.test.tsx +0 -22
  857. package/src/__tests__/UnderlineNavLink.test.tsx +0 -31
  858. package/src/__tests__/__snapshots__/ActionList.test.tsx.snap +0 -223
  859. package/src/__tests__/__snapshots__/ActionList2.test.tsx.snap +0 -14
  860. package/src/__tests__/__snapshots__/ActionMenu.test.tsx.snap +0 -80
  861. package/src/__tests__/__snapshots__/AnchoredOverlay.test.tsx.snap +0 -232
  862. package/src/__tests__/__snapshots__/Autocomplete.test.tsx.snap +0 -3888
  863. package/src/__tests__/__snapshots__/Avatar.test.tsx.snap +0 -19
  864. package/src/__tests__/__snapshots__/AvatarStack.test.tsx.snap +0 -377
  865. package/src/__tests__/__snapshots__/BorderBox.test.tsx.snap +0 -14
  866. package/src/__tests__/__snapshots__/Box.test.tsx.snap +0 -201
  867. package/src/__tests__/__snapshots__/BranchName.test.tsx.snap +0 -17
  868. package/src/__tests__/__snapshots__/Breadcrumbs.test.tsx.snap +0 -29
  869. package/src/__tests__/__snapshots__/BreadcrumbsItem.test.tsx.snap +0 -79
  870. package/src/__tests__/__snapshots__/Button.test.tsx.snap +0 -840
  871. package/src/__tests__/__snapshots__/Caret.test.tsx.snap +0 -373
  872. package/src/__tests__/__snapshots__/Checkbox.test.tsx.snap +0 -16
  873. package/src/__tests__/__snapshots__/CircleBadge.test.tsx.snap +0 -142
  874. package/src/__tests__/__snapshots__/CircleOcticon.test.tsx.snap +0 -65
  875. package/src/__tests__/__snapshots__/ConfirmationDialog.test.tsx.snap +0 -89
  876. package/src/__tests__/__snapshots__/CounterLabel.test.tsx.snap +0 -22
  877. package/src/__tests__/__snapshots__/Details.test.tsx.snap +0 -15
  878. package/src/__tests__/__snapshots__/Dialog.test.tsx.snap +0 -201
  879. package/src/__tests__/__snapshots__/Dropdown.test.tsx.snap +0 -249
  880. package/src/__tests__/__snapshots__/DropdownMenu.test.tsx.snap +0 -107
  881. package/src/__tests__/__snapshots__/FilterList.test.tsx.snap +0 -13
  882. package/src/__tests__/__snapshots__/FilterListItem.test.tsx.snap +0 -80
  883. package/src/__tests__/__snapshots__/FilteredSearch.test.tsx.snap +0 -32
  884. package/src/__tests__/__snapshots__/Flash.test.tsx.snap +0 -32
  885. package/src/__tests__/__snapshots__/Flex.test.tsx.snap +0 -130
  886. package/src/__tests__/__snapshots__/FormGroup.test.tsx.snap +0 -25
  887. package/src/__tests__/__snapshots__/Grid.test.tsx.snap +0 -178
  888. package/src/__tests__/__snapshots__/Header.test.tsx.snap +0 -79
  889. package/src/__tests__/__snapshots__/Heading.test.tsx.snap +0 -13
  890. package/src/__tests__/__snapshots__/Label.test.tsx.snap +0 -73
  891. package/src/__tests__/__snapshots__/LabelGroup.test.tsx.snap +0 -15
  892. package/src/__tests__/__snapshots__/Link.test.tsx.snap +0 -212
  893. package/src/__tests__/__snapshots__/NewButton.test.tsx.snap +0 -305
  894. package/src/__tests__/__snapshots__/Pagehead.test.tsx.snap +0 -15
  895. package/src/__tests__/__snapshots__/PointerBox.test.tsx.snap +0 -174
  896. package/src/__tests__/__snapshots__/Popover.test.tsx.snap +0 -4687
  897. package/src/__tests__/__snapshots__/Position.test.tsx.snap +0 -44
  898. package/src/__tests__/__snapshots__/ProgressBar.test.tsx.snap +0 -53
  899. package/src/__tests__/__snapshots__/SelectMenu.test.tsx.snap +0 -473
  900. package/src/__tests__/__snapshots__/SelectPanel.test.tsx.snap +0 -124
  901. package/src/__tests__/__snapshots__/SideNav.test.tsx.snap +0 -143
  902. package/src/__tests__/__snapshots__/Spinner.test.tsx.snap +0 -33
  903. package/src/__tests__/__snapshots__/StateLabel.test.tsx.snap +0 -395
  904. package/src/__tests__/__snapshots__/StyledOcticon.test.tsx.snap +0 -26
  905. package/src/__tests__/__snapshots__/SubNav.test.tsx.snap +0 -44
  906. package/src/__tests__/__snapshots__/SubNavLink.test.tsx.snap +0 -199
  907. package/src/__tests__/__snapshots__/TabNav.test.tsx.snap +0 -58
  908. package/src/__tests__/__snapshots__/Text.test.tsx.snap +0 -7
  909. package/src/__tests__/__snapshots__/TextInput.test.tsx.snap +0 -446
  910. package/src/__tests__/__snapshots__/TextInputWithTokens.test.tsx.snap +0 -6045
  911. package/src/__tests__/__snapshots__/ThemeProvider.test.tsx.snap +0 -15
  912. package/src/__tests__/__snapshots__/Timeline.test.tsx.snap +0 -159
  913. package/src/__tests__/__snapshots__/Token.test.tsx.snap +0 -3811
  914. package/src/__tests__/__snapshots__/Tooltip.test.tsx.snap +0 -227
  915. package/src/__tests__/__snapshots__/Truncate.test.tsx.snap +0 -17
  916. package/src/__tests__/__snapshots__/UnderlineNav.test.tsx.snap +0 -59
  917. package/src/__tests__/__snapshots__/UnderlineNavLink.test.tsx.snap +0 -130
  918. package/src/__tests__/behaviors/anchoredPosition.test.ts +0 -295
  919. package/src/__tests__/behaviors/focusTrap.test.tsx +0 -236
  920. package/src/__tests__/behaviors/focusZone.test.tsx +0 -549
  921. package/src/__tests__/behaviors/iterateFocusableElements.test.tsx +0 -61
  922. package/src/__tests__/behaviors/scrollIntoViewingArea.test.ts +0 -195
  923. package/src/__tests__/filterObject.test.ts +0 -54
  924. package/src/__tests__/hooks/useAnchoredPosition.test.tsx +0 -31
  925. package/src/__tests__/hooks/useOnEscapePress.test.tsx +0 -16
  926. package/src/__tests__/hooks/useOnOutsideClick.test.tsx +0 -48
  927. package/src/__tests__/hooks/useOpenAndCloseFocus.test.tsx +0 -48
  928. package/src/__tests__/hooks/useProvidedStateOrCreate.test.tsx +0 -39
  929. package/src/__tests__/theme.test.ts +0 -41
  930. package/src/__tests__/themeGet.test.ts +0 -15
  931. package/src/__tests__/useSafeTimeout.test.tsx +0 -36
  932. package/src/__tests__/utils/__snapshots__/createSlots.test.tsx.snap +0 -55
  933. package/src/__tests__/utils/createSlots.test.tsx +0 -74
  934. package/src/behaviors/anchoredPosition.ts +0 -442
  935. package/src/behaviors/focusTrap.ts +0 -184
  936. package/src/behaviors/focusZone.ts +0 -713
  937. package/src/behaviors/scrollIntoViewingArea.ts +0 -27
  938. package/src/constants.ts +0 -62
  939. package/src/drafts.ts +0 -10
  940. package/src/hooks/index.ts +0 -11
  941. package/src/hooks/useAnchoredPosition.ts +0 -54
  942. package/src/hooks/useCombinedRefs.ts +0 -40
  943. package/src/hooks/useDetails.tsx +0 -54
  944. package/src/hooks/useDialog.ts +0 -121
  945. package/src/hooks/useFocusTrap.ts +0 -80
  946. package/src/hooks/useFocusZone.ts +0 -64
  947. package/src/hooks/useOnEscapePress.ts +0 -63
  948. package/src/hooks/useOnOutsideClick.tsx +0 -82
  949. package/src/hooks/useOpenAndCloseFocus.ts +0 -32
  950. package/src/hooks/useOverlay.tsx +0 -34
  951. package/src/hooks/useProvidedRefOrCreate.ts +0 -14
  952. package/src/hooks/useProvidedStateOrCreate.ts +0 -27
  953. package/src/hooks/useRenderForcingRef.ts +0 -22
  954. package/src/hooks/useResizeObserver.ts +0 -11
  955. package/src/hooks/useSafeTimeout.ts +0 -38
  956. package/src/hooks/useScrollFlash.ts +0 -21
  957. package/src/index.ts +0 -175
  958. package/src/polyfills/eventListenerSignal.ts +0 -66
  959. package/src/stories/ActionList.stories.tsx +0 -436
  960. package/src/stories/ActionList2.stories.tsx +0 -1291
  961. package/src/stories/ActionMenu.stories.tsx +0 -331
  962. package/src/stories/AnchoredOverlay.stories.tsx +0 -117
  963. package/src/stories/Autocomplete.stories.tsx +0 -655
  964. package/src/stories/AvatarStack.stories.tsx +0 -37
  965. package/src/stories/Button.stories.tsx +0 -92
  966. package/src/stories/Checkbox.stories.tsx +0 -164
  967. package/src/stories/ConfirmationDialog.stories.tsx +0 -105
  968. package/src/stories/Dialog.stories.tsx +0 -240
  969. package/src/stories/DropdownMenu.stories.tsx +0 -84
  970. package/src/stories/IssueLabelToken.stories.tsx +0 -138
  971. package/src/stories/NewButton.stories.tsx +0 -201
  972. package/src/stories/Overlay.stories.tsx +0 -213
  973. package/src/stories/Portal.stories.tsx +0 -109
  974. package/src/stories/ProfileToken.stories.tsx +0 -129
  975. package/src/stories/SelectPanel.stories.tsx +0 -353
  976. package/src/stories/TextInput.stories.tsx +0 -113
  977. package/src/stories/TextInputWithTokens.stories.tsx +0 -155
  978. package/src/stories/ThemeProvider.stories.tsx +0 -104
  979. package/src/stories/Token.stories.tsx +0 -137
  980. package/src/stories/useAnchoredPosition.stories.tsx +0 -332
  981. package/src/stories/useFocusTrap.stories.tsx +0 -400
  982. package/src/stories/useFocusZone.stories.tsx +0 -663
  983. package/src/sx.ts +0 -24
  984. package/src/theme-preval.js +0 -80
  985. package/src/theme.ts +0 -89
  986. package/src/utils/create-slots.tsx +0 -96
  987. package/src/utils/deprecate.tsx +0 -73
  988. package/src/utils/isNumeric.tsx +0 -4
  989. package/src/utils/iterateFocusableElements.ts +0 -121
  990. package/src/utils/ssr.tsx +0 -1
  991. package/src/utils/test-deprecations.tsx +0 -19
  992. package/src/utils/test-helpers.tsx +0 -7
  993. package/src/utils/test-matchers.tsx +0 -109
  994. package/src/utils/testing.tsx +0 -242
  995. package/src/utils/theme.js +0 -64
  996. package/src/utils/types/AriaRole.ts +0 -71
  997. package/src/utils/types/ComponentProps.ts +0 -13
  998. package/src/utils/types/Flatten.ts +0 -4
  999. package/src/utils/types/KeyPaths.ts +0 -10
  1000. package/src/utils/types/MandateProps.ts +0 -19
  1001. package/src/utils/types/Merge.ts +0 -20
  1002. package/src/utils/types/index.ts +0 -5
  1003. package/src/utils/uniqueId.ts +0 -6
  1004. package/src/utils/use-force-update.ts +0 -7
  1005. package/src/utils/useIsomorphicLayoutEffect.ts +0 -10
  1006. package/src/utils/userAgent.ts +0 -7
  1007. package/stats.html +0 -3279
  1008. package/tsconfig.build.json +0 -7
  1009. package/tsconfig.json +0 -20
package/.gitignore DELETED
@@ -1,10 +0,0 @@
1
- .test
2
- node_modules
3
- .DS_Store
4
- .idea
5
- coverage/
6
- dist/
7
- lib/
8
- lib-esm/
9
- public/
10
- stats.html
package/.npmrc DELETED
@@ -1,4 +0,0 @@
1
- save=true
2
- save-exact=true
3
- # we create our tags in Releases now
4
- git-tag-version=false
package/.nvmrc DELETED
@@ -1 +0,0 @@
1
- v14
@@ -1,9 +0,0 @@
1
- module.exports = {
2
- stories: ['../src/**/*.stories.mdx', '../src/**/*.stories.@(js|jsx|ts|tsx)'],
3
- addons: [
4
- '@storybook/addon-a11y',
5
- '@storybook/addon-links',
6
- '@storybook/addon-essentials',
7
- 'storybook-addon-performance/register'
8
- ]
9
- }
@@ -1,117 +0,0 @@
1
- import {addons} from '@storybook/addons'
2
- import {ThemeProvider, themeGet, theme} from '../src'
3
- import styled, {createGlobalStyle} from 'styled-components'
4
- import {addDecorator} from '@storybook/react'
5
- import {withPerformance} from 'storybook-addon-performance'
6
-
7
- addDecorator(withPerformance)
8
-
9
- // set global theme styles for each story
10
- const GlobalStyle = createGlobalStyle`
11
- body {
12
- background-color: ${themeGet('colors.canvas.default')};
13
- color: ${themeGet('colors.fg.default')};
14
- }
15
- `
16
-
17
- // only remove padding for multi-theme view grid
18
- const GlobalStyleMultiTheme = createGlobalStyle`
19
- body {
20
- padding: 0 !important;
21
- }
22
- `
23
-
24
- // duo theme view, this can be extended for more themes
25
- const Wrapper = styled.div`
26
- display: grid;
27
- grid-template-columns: 1fr 1fr;
28
- grid-template-rows: 100vh;
29
- `
30
-
31
- // instead of global theme, only theme wrapper for each story
32
- const ThemedSectionStyle = styled.div`
33
- background-color: ${themeGet('colors.canvas.default')};
34
- color: ${themeGet('colors.fg.default')};
35
- padding: 1rem;
36
- `
37
-
38
- export const globalTypes = {
39
- colorMode: {
40
- name: 'Color mode',
41
- description: 'Color mode (day, night, auto, all)',
42
- defaultValue: 'day',
43
- toolbar: {
44
- icon: 'paintbrush',
45
- // array of colorMode items
46
- items: ['day', 'night', 'auto', 'all'],
47
- showName: true
48
- }
49
- },
50
- dayScheme: {
51
- name: 'Day color scheme',
52
- description: 'Day color scheme',
53
- defaultValue: 'light',
54
- toolbar: {
55
- icon: 'circlehollow',
56
- items: Object.keys(theme.colorSchemes),
57
- showName: true
58
- }
59
- },
60
- nightScheme: {
61
- name: 'Night color scheme',
62
- description: 'Night color scheme',
63
- defaultValue: 'dark',
64
- toolbar: {
65
- icon: 'circle',
66
- items: Object.keys(theme.colorSchemes),
67
- showName: true
68
- }
69
- }
70
- }
71
-
72
- // context.globals.X references items in globalTypes
73
- const withThemeProvider = (Story, context) => {
74
- if (context.globals.colorMode === 'all') {
75
- return (
76
- <Wrapper>
77
- <GlobalStyleMultiTheme />
78
- <ThemeProvider colorMode="day" dayScheme={context.globals.dayScheme} nightScheme={context.globals.nightScheme}>
79
- <ThemedSectionStyle>
80
- <Story {...context} />
81
- </ThemedSectionStyle>
82
- </ThemeProvider>
83
- <ThemeProvider
84
- colorMode="night"
85
- dayScheme={context.globals.dayScheme}
86
- nightScheme={context.globals.nightScheme}
87
- >
88
- <ThemedSectionStyle>
89
- <Story {...context} />
90
- </ThemedSectionStyle>
91
- </ThemeProvider>
92
- </Wrapper>
93
- )
94
- }
95
-
96
- return (
97
- <ThemeProvider
98
- colorMode={context.globals.colorMode}
99
- dayScheme={context.globals.dayScheme}
100
- nightScheme={context.globals.nightScheme}
101
- >
102
- <GlobalStyle />
103
- <Story {...context} />
104
- </ThemeProvider>
105
- )
106
- }
107
- export const decorators = [withThemeProvider, withPerformance]
108
-
109
- addons.setConfig({
110
- // Some stories may set up keyboard event handlers, which can can be interfered
111
- // with by these keyboard shortcuts.
112
- enableShortcuts: false
113
- })
114
-
115
- export const parameters = {
116
- actions: {argTypesRegex: '^on[A-Z].*'}
117
- }
@@ -1,21 +0,0 @@
1
- {
2
- // Use IntelliSense to learn about possible attributes.
3
- // Hover to view descriptions of existing attributes.
4
- // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
5
- "version": "0.2.0",
6
- "configurations": [
7
- {
8
- "type": "node",
9
- "request": "launch",
10
- "name": "Jest Current File",
11
- "program": "${workspaceFolder}/node_modules/.bin/jest",
12
- "args": ["${fileBasenameNoExtension}", "--config", "jest.config.js"],
13
- "console": "integratedTerminal",
14
- "internalConsoleOptions": "neverOpen",
15
- "disableOptimisticBPs": true,
16
- "windows": {
17
- "program": "${workspaceFolder}/node_modules/jest/bin/jest"
18
- }
19
- }
20
- ]
21
- }
@@ -1,13 +0,0 @@
1
- {
2
- "typescript.tsdk": "node_modules/typescript/lib",
3
- "editor.formatOnSave": true,
4
- "[javascript]": {
5
- "editor.defaultFormatter": "esbenp.prettier-vscode"
6
- },
7
- "[typescript]": {
8
- "editor.defaultFormatter": "esbenp.prettier-vscode"
9
- },
10
- "[typescriptreact]": {
11
- "editor.defaultFormatter": "esbenp.prettier-vscode"
12
- }
13
- }
File without changes
@@ -1 +0,0 @@
1
- declare module '@styled-system/prop-types'
@@ -1 +0,0 @@
1
- declare module '@styled-system/props'
@@ -1 +0,0 @@
1
- declare module 'jest-styled-components/serializer'
package/CODEOWNERS DELETED
@@ -1,2 +0,0 @@
1
- # All changes should be reviewed by a member of the @react-reviewers team
2
- * @primer/react-reviewers
package/babel-defines.js DELETED
@@ -1,13 +0,0 @@
1
- const shared = {
2
- __DEV__: "process.env.NODE_ENV !== 'production'"
3
- }
4
-
5
- module.exports = {
6
- development: shared,
7
- test: shared,
8
- production: {
9
- ...shared,
10
- __DEV__: 'false',
11
- 'process.env.NODE_ENV': "'production'"
12
- }
13
- }
package/babel.config.js DELETED
@@ -1,39 +0,0 @@
1
- const defines = require('./babel-defines')
2
-
3
- function replacementPlugin(env) {
4
- return ['babel-plugin-transform-replace-expressions', {replace: defines[env]}]
5
- }
6
-
7
- const sharedPlugins = [
8
- 'macros',
9
- 'preval',
10
- 'add-react-displayname',
11
- 'babel-plugin-styled-components',
12
- '@babel/plugin-proposal-nullish-coalescing-operator',
13
- '@babel/plugin-proposal-optional-chaining'
14
- ]
15
-
16
- function makePresets(moduleValue) {
17
- return ['@babel/preset-typescript', ['@babel/preset-react', {modules: moduleValue}]]
18
- }
19
-
20
- module.exports = {
21
- env: {
22
- development: {
23
- presets: makePresets(process.env.BABEL_MODULE || false),
24
- plugins: [
25
- ...(process.env.BABEL_MODULE === 'commonjs' ? ['@babel/plugin-transform-modules-commonjs'] : []),
26
- ...sharedPlugins,
27
- replacementPlugin('development')
28
- ]
29
- },
30
- production: {
31
- presets: makePresets(false),
32
- plugins: [...sharedPlugins, replacementPlugin('production')]
33
- },
34
- test: {
35
- presets: makePresets('commonjs'),
36
- plugins: [...sharedPlugins, ['@babel/plugin-transform-modules-commonjs'], replacementPlugin('test')]
37
- }
38
- }
39
- }
@@ -1,76 +0,0 @@
1
- # Contributor Covenant Code of Conduct
2
-
3
- ## Our Pledge
4
-
5
- In the interest of fostering an open and welcoming environment, we as
6
- contributors and maintainers pledge to making participation in our project and
7
- our community a harassment-free experience for everyone, regardless of age, body
8
- size, disability, ethnicity, sex characteristics, gender identity and expression,
9
- level of experience, education, socio-economic status, nationality, personal
10
- appearance, race, religion, or sexual identity and orientation.
11
-
12
- ## Our Standards
13
-
14
- Examples of behavior that contributes to creating a positive environment
15
- include:
16
-
17
- * Using welcoming and inclusive language
18
- * Being respectful of differing viewpoints and experiences
19
- * Gracefully accepting constructive criticism
20
- * Focusing on what is best for the community
21
- * Showing empathy towards other community members
22
-
23
- Examples of unacceptable behavior by participants include:
24
-
25
- * The use of sexualized language or imagery and unwelcome sexual attention or
26
- advances
27
- * Trolling, insulting/derogatory comments, and personal or political attacks
28
- * Public or private harassment
29
- * Publishing others' private information, such as a physical or electronic
30
- address, without explicit permission
31
- * Other conduct which could reasonably be considered inappropriate in a
32
- professional setting
33
-
34
- ## Our Responsibilities
35
-
36
- Project maintainers are responsible for clarifying the standards of acceptable
37
- behavior and are expected to take appropriate and fair corrective action in
38
- response to any instances of unacceptable behavior.
39
-
40
- Project maintainers have the right and responsibility to remove, edit, or
41
- reject comments, commits, code, wiki edits, issues, and other contributions
42
- that are not aligned to this Code of Conduct, or to ban temporarily or
43
- permanently any contributor for other behaviors that they deem inappropriate,
44
- threatening, offensive, or harmful.
45
-
46
- ## Scope
47
-
48
- This Code of Conduct applies both within project spaces and in public spaces
49
- when an individual is representing the project or its community. Examples of
50
- representing a project or community include using an official project e-mail
51
- address, posting via an official social media account, or acting as an appointed
52
- representative at an online or offline event. Representation of a project may be
53
- further defined and clarified by project maintainers.
54
-
55
- ## Enforcement
56
-
57
- Instances of abusive, harassing, or otherwise unacceptable behavior may be
58
- reported by contacting the project team at design-systems@github.com. All
59
- complaints will be reviewed and investigated and will result in a response that
60
- is deemed necessary and appropriate to the circumstances. The project team is
61
- obligated to maintain confidentiality with regard to the reporter of an incident.
62
- Further details of specific enforcement policies may be posted separately.
63
-
64
- Project maintainers who do not follow or enforce the Code of Conduct in good
65
- faith may face temporary or permanent repercussions as determined by other
66
- members of the project's leadership.
67
-
68
- ## Attribution
69
-
70
- This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
71
- available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html
72
-
73
- [homepage]: https://www.contributor-covenant.org
74
-
75
- For answers to common questions about this code of conduct, see
76
- https://www.contributor-covenant.org/faq
@@ -1,274 +0,0 @@
1
- # Contribution guidelines
2
-
3
- 1. [Roadmap](#roadmap)
4
- 2. [Before Getting Started](#before-getting-started)
5
- 3. [Discussing non-public features or products](#discussing-non-public-features-or-products)
6
- 4. [Developing Components](#developing-components)
7
- - [Tools we use](#tools-we-use)
8
- - [Component patterns](#component-patterns)
9
- - [Adding system props](#adding-system-props)
10
- - [Adding the sx prop](#adding-the-sx-prop)
11
- - [Linting](#linting)
12
- - [Testing](#testing)
13
- - [TypeScript support](#typescript-support)
14
- - [Additional resources](#additional-resources)
15
- 5. [Writing documentation](#writing-documentation)
16
- 6. [Creating a pull request](#creating-a-pull-request)
17
- - [What to expect after opening a pull request](#what-to-expect-after-opening-a-pull-request)
18
- - [What we look for in reviews](#what-we-look-for-in-reviews)
19
- 7. [Deploying & publishing](#deploying-and-publishing)
20
- - [Deploying](#deploying)
21
- - [Path aliasing](#path-aliasing)
22
- - [Publishing](#publishing)
23
- 8. [Troubleshooting](#troubleshooting)
24
- 9. [Glossary](#glossary)
25
- - [System Props](#system-props)
26
-
27
- ## Roadmap
28
-
29
- If you're looking for something to work on, a great place to start is our issues labeled [up for grabs](https://github.com/primer/react/issues?q=is%3Aopen+is%3Aissue+label%3A%22up+for+grabs%22)! If you've got a feature that you'd like to implement, be sure to check out our [Primer Components Roadmap](https://github.com/primer/react/projects/3) to make sure it hasn't already been started on.
30
-
31
- ## Before Getting Started
32
-
33
- A common question asked about Primer Components is how to know what should be added to Primer Components and what is best left as a local component in a consuming application. Though there are no hard & fast rules about what can and cannot be added to Primer Components, here are a few things we take into consideration:
34
-
35
- - Is the new feature an existing pattern in Primer CSS or related to UI built at GitHub? Primer Components is first and foremost a library for building UI at GitHub - patterns that aren't currently being used in GitHub UI (either on github.com or in a GitHub owned project outside of github.com) probably shouldn't be added to Primer Components. Exceptions to this could be helper components that don't necessarily render UI but help with the development process (like `Flex`, `Grid`, or `Box`).
36
-
37
- - Does the proposed component get used in more than one or two places across GitHub UI? A component that's only meant to be used in one place and doesn't have potential to be reused in many places probably should exist as a local component. An example of something like this might be a component that renders content specific to a single GitHub product.
38
-
39
- **In general, we tend to be pretty excited about 99% of feature proposals and contributions!** If you would like to get started with a component proposal, open an issue using the [component proposal template](https://github.com/primer/react/issues/new?template=new-component-proposal.md).
40
-
41
- ## Discussing non-public features or products
42
-
43
- As this is a public repo, please be careful not to include details or screenshots from unreleased GitHub products or features. In most cases, a good bug report, feature request, or pull request should be able to describe the work without including business logic or feature details, but if you must discuss context relating to an unreleased feature, please open an issue in the private [Design Systems repo](https://github.com/github/design-systems/issues/new/choose) and link to it in your issue or pull request.
44
-
45
- ## Developing components
46
-
47
- We primarily use our documentation site as a workspace to develop new components or make changes to existing components (stay tuned for a better development environment coming soon!).
48
-
49
- Before running the documentation site locally, you'll need to install packages in the root and `docs` directories:
50
-
51
- ```sh
52
- npm install && cd docs && npm install
53
- ```
54
-
55
- Then navigate back to the root folder and run the following to start up the site:
56
-
57
- ```sh
58
- npm start
59
- ```
60
-
61
- Navigate to http://localhost:8000/ to see the site in your browser ✨
62
-
63
- ### Tools we use
64
-
65
- 1. We use [styled-components](https://www.styled-components.com/) to style our components.
66
- 2. We use style functions from [styled-system](https://styled-system.com/) whenever possible, and styled-systems' `style()` function to create new ones.
67
-
68
- ### Component patterns
69
-
70
- With a couple of exceptions, all components should be created with the `styled` function from [styled-components] and should have the appropriate groups of system props attached.
71
-
72
- Default values for system props can be set in `Component.defaultProps`.
73
-
74
- ⚠️ **Do not set the default `theme` prop! This can sometimes override the theme provided by the ThemeProvider and cause unexpected theming issues.**
75
-
76
- Additionally, every component should support [the `sx` prop](https://primer.style/components/overriding-styles); remember to add `${sx}` to the style literal.
77
-
78
- Here's an example of a basic component written in the style of Primer Components:
79
-
80
- ```jsx
81
- import {TYPOGRAPHY, COMMON} from './constants'
82
- import sx from './sx'
83
-
84
- const Component = styled.div`
85
- // additional styles here
86
-
87
- ${COMMON};
88
- ${TYPOGRAPHY};
89
- ${sx};
90
- `
91
-
92
- Component.defaultProps = {
93
- m: 0,
94
- fontSize: 5,
95
- }
96
-
97
- export default Component
98
- ```
99
-
100
- ### Adding system props
101
-
102
- Each component should have access to the appropriate system props. Every component has access to `COMMON`. For **most** components added, you'll only need to give the component to `COMMON`. If you are unsure, ping a DS team member on your PR.
103
-
104
- Categories of system props are exported from `src/constants.js`:
105
-
106
- - `COMMON` includes color and spacing (margin and padding) props
107
- - `TYPOGRAPHY` includes font family, font weight, and line-height props
108
- - `POSITION` includes positioning props
109
- - `FLEX` includes flexbox props
110
- - `BORDER` includes border and box-shadow props
111
- - `GRID` includes grid props
112
-
113
- To give the component access to a group of system props, import the system prop function from `./constants` and include the system prop function in your styled-component like so:
114
-
115
- ```jsx
116
- import {COMMON} from './constants'
117
-
118
- const Component = styled.div`
119
- // additional styles here
120
- ${COMMON};
121
- `
122
- ```
123
-
124
- Remember that the system prop function inside your style declaration needs to go _after_ any built-in styles you want to be overridable.
125
-
126
- ### Adding the `sx` prop
127
-
128
- Each component should provide access to a prop called `sx` that allows for setting theme-aware ad-hoc styles. See the [overriding styles](https://primer.style/components/overriding-styles) doc for more information on using the prop.
129
-
130
- Adding the `sx` prop is similar to adding system props; import the default export from the `sx` module, add it to your style definition, and add the appropriate prop types. **The `sx` prop should go at the _very end_ of your style definition.**
131
-
132
- ```jsx
133
- import {COMMON} from './constants'
134
- import sx from './sx'
135
-
136
- const Component = styled.div`
137
- // additional styles here
138
- ${COMMON};
139
- ${sx};
140
- `
141
- ```
142
-
143
- ### Linting
144
-
145
- We use the [React configuration](https://github.com/github/eslint-plugin-github/blob/master/lib/configs/react.js) from [GitHub's eslint plugin](https://github.com/github/eslint-plugin-github) to lint our JavaScript. To check your work before pushing, run:
146
-
147
- ```sh
148
- npm run lint
149
- ```
150
-
151
- Or, you can use [npx] to run eslint on one or more specific files:
152
-
153
- ```sh
154
- # lint the component and the tests in src/__tests__
155
- npx eslint src/**/MyComponent.js
156
- ```
157
-
158
- **Protip:** The [eslint `--fix` flag](https://eslint.org/docs/user-guide/command-line-interface#--fix) can automatically fix most linting errors, such as those involving whitespace or incorrect ordering of object keys and imports. You can fix those issues across the entire project with:
159
-
160
- ```sh
161
- npm run lint -- --fix
162
- ```
163
-
164
- **Protip:** `npm run lint -- --quiet` (or `npx eslint --quiet ...`) will suppress warnings so that you can focus on fixing errors.
165
-
166
- ### Testing
167
-
168
- We test our components with [Jest](https://facebook.github.io/jest/) and [react-test-renderer](https://reactjs.org/docs/test-renderer.html). You can run the tests locally with `npm test`. To run the tests as you work, run Jest in watch mode with:
169
-
170
- ```sh
171
- npm test -- --watch
172
- ```
173
-
174
- See [`src/__tests__/example.js`](src/__tests__/example.js) for examples of ways that we test our components.
175
-
176
- ### TypeScript support
177
-
178
- Several of the projects that consume Primer Components are written in TypeScript. Though Primer Components is not currently written in TS, we do export type definitions in order to make Primer Components compatible with other TS projects.
179
-
180
- Whenever adding new components or modifying the props of an existing component, **please make sure to update the type definition** in `index.d.ts`! This is super important to make sure we don't break compatibility :)
181
-
182
- ### Additional resources
183
-
184
- - [Primer Components Philosophy](https://primer.style/components/philosophy)
185
- - [Primer Components Core Concepts](https://primer.style/components/core-concepts)
186
- - [Primer Components System Props](https://primer.style/components/system-props)
187
- - [Styled Components docs](https://styled-components.com/)
188
- - [Styled System docs](https://styled-system.com/)
189
-
190
- ## Writing documentation
191
-
192
- We use [Doctocat](https://github.com/primer/doctocat) to power our documentation site at [https://primer.style/components](https://primer.style/components/).
193
-
194
- To add a new component to our documentation site, create a new file with the `.md` extension for your component in `docs/content` (e.g. `docs/content/Button.md`).
195
-
196
- ## Creating a pull request
197
-
198
- When creating a new pull request, please follow the guidelines in the auto-populated pull request template. Be sure to add screenshots of any relevant work and a thoughtful description.
199
-
200
- ### What to expect after opening a pull request
201
-
202
- After opening a pull request, a member of the design systems team will add the appropriate labels (major, minor, patch release labels) and update the base branch to the correct release branch. Usually, you'll receive a response from the design systems team within a day or two. The design systems team member will review the pull request keeping the following items in mind:
203
-
204
- ### What we look for in reviews
205
-
206
- - If it's a new component, does the component make sense to add to Primer Components? (Ideally this is discussed before the pull request stage, please reach out to a DS member if you aren't sure if a component should be added to Primer Components!)
207
- - Does the component follow our [Primer Components code style](#component-patterns)?
208
- - Does the component use theme values for most CSS values?
209
- - Does the component have the [correct system props implemented](#adding-system-props)?
210
- - Is the component API intuitive?
211
- - Does the component have the appropriate [type definitions in `index.d.ts`](#typescript-support)?
212
- - Is the component documented accurately?
213
- - Does the component have appropriate tests?
214
- - Does the pull request increase the bundle size significantly?
215
-
216
- If everything looks great, the design systems team member will approve the pull request and merge when appropriate. Minor and patch changes are released frequently, and we try to bundle up breaking changes and avoid shipping major versions too often. If your pull request is time-sensitive, please let a design systems team member know. You do not need to worry about merging pull requests on your own, we'll take care of that for you :)
217
-
218
- ## Deploying and publishing
219
-
220
- ### Deploying
221
-
222
- All of our documentation sites use the [Now integration](https://github.com/organizations/primer/settings/installations/1007619) to deploy documentation changes whenever code is merged into main. The integration also creates a preview site every time you commit code to a branch. To view the preview site, navigate to the PR and find the comment from the `now` bot. This will include a link to the preview site for your branch.
223
-
224
- Once you merge your branch into main, any changes to the docs will automatically deploy. No further action is necessary.
225
-
226
- ### Path aliasing
227
-
228
- This site is served as a subdirectory of [primer.style] using a [path alias](https://zeit.co/docs/features/path-aliases) configured in that repo's [`rules.json`](https://github.com/primer/primer.style/tree/master/rules.json). If you change the production deployment URL for this app, you will also need to change it there and re-deploy that app; otherwise, Now will automatically route requests from [primer.style/components](https://primer.style/components/) to the new deployment whenever you alias this one to `primer-components.now.sh`.
229
-
230
- ### Publishing
231
-
232
- We use [changesets](https://github.com/atlassian/changesets) to managing versioning, publishing, and release notes. Here's how it works:
233
-
234
- #### Using changesets to prepare and publish a release
235
-
236
- 1. When creating a new PR, changeset-bot will remind you to add a changeset if your change should trigger a new version number for the package.
237
- 2. To create a new changeset on your local machine, run `npx changeset` and answer the prompts. If you are introducing multiple features in the PR, add a separate changeset for each.
238
- 3. Push your new changes along with the changeset file to your PR; changeset-bot will show that there are valid changesets in the PR.
239
- 4. When the PR is ready, merge it to the main branch.
240
- 5. The changeset action will automatically create a new PR that bumps the version number appropriately, creates or updates `CHANGELOG.md`, and shows the release notes that will be used in the GitHub Release notes.
241
- 6. If you want to release more features, merge them into the main branch and changesets will update the release PR. Note that it does this via force-pushing, so you should not edit the release PR yourself.
242
- 7. When you're ready to release, merge the release PR into the main branch and changesets will publish the new version to npm and create a GitHub Release.
243
-
244
- ## Troubleshooting
245
-
246
- **`npm start` fails with an error like `gatsby: command not found`**
247
-
248
- Make sure to run `npm install` from inside the `docs/` subfolder _as well as_ the root folder.
249
-
250
- **`npm start` fails with a different error**
251
-
252
- Ensure you are using the latest minor of Node.js for the major version specified in the `.nvmrc` file. For example, if `.nvmrc` contains `8`, make sure you're using the latest version of Node.js with the major version of 8.
253
-
254
- ## Glossary
255
-
256
- ### System props
257
-
258
- System props are style functions that provide one or more props, and can be passed directly the return value of [styled-components]'s `styled()` function:
259
-
260
- ```jsx
261
- import styled from 'styled-components'
262
- import {space} from 'styled-system'
263
- const SpaceDiv = styled.div`
264
- ${space}
265
- `
266
- ```
267
-
268
- [classnames]: https://www.npmjs.com/package/classnames
269
- [spread syntax]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Spread_syntax
270
- [styled-system]: https://styled-system.com
271
- [table]: https://jxnblk.com/styled-system/table
272
- [npx]: https://www.npmjs.com/package/npx
273
- [now]: https://zeit.co/now
274
- [primer.style]: https://primer.style
@@ -1,23 +0,0 @@
1
- # ADR 1: TypeScript
2
-
3
- ## Status
4
-
5
- Approved 2021-01-15
6
-
7
- ## Context
8
-
9
- Primer React components was originally released without TypeScript type definitions, making it difficult for engineers to consume the library in TypeScript applications. In [July 2019](https://github.com/primer/react/commit/2983c935ea9ad600c04078adb25e40c3624c11fa#diff-7aa4473ede4abd9ec099e87fec67fd57afafaf39e05d493ab4533acc38547eb8), we created an [ambient declaration](https://www.geeksforgeeks.org/typescript-ambients-declaration/) file (`index.d.ts`) file to provide type definitions for TypeScript applications without having to rewrite Primer React components in TypeScript.
10
-
11
- `index.d.ts` has been an effective stopgap, enabling teams to build complex applications with Primer React components and TypeScript. However, because `index.d.ts` is disconnected from the implementation code, we've struggled to keep the type definitions up-to-date and accurate, as evidenced by [many](https://github.com/primer/react/issues/906) [TypeScript](https://github.com/primer/react/issues/540) [bug](https://github.com/primer/react/issues/520) [reports](https://github.com/primer/react/issues/534). As the library continues to grow in size and complexity, manually maintaining type definitions will become unsustainable.
12
-
13
- ## Decision
14
-
15
- We will rewrite Primer React components in TypeScript.
16
-
17
- ## Consequences
18
-
19
- - Type definitions can be generated by the TypeScript compiler, eliminating bugs caused by hand-written type definitions.
20
- - Engineers can upstream components from other TypeScript projects at GitHub without having to remove type annotations, improving the contributor experience.
21
- - We can refactor components with increased confidence.
22
- - Component prop documentation can be generated by [react-docgen-typescript](https://github.com/styleguidist/react-docgen-typescript), eliminating inaccurate and out-of-date hand-written prop documentation.
23
- - New contributors will need some familiarity with TypeScript in order to make code contributions.