@primer/components 31.2.0-rc.5ccefd7d → 31.2.0-rc.5e503f97

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 (206) hide show
  1. package/.github/workflows/release.yml +1 -0
  2. package/.github/workflows/release_canary.yml +1 -0
  3. package/CHANGELOG.md +14 -0
  4. package/dist/browser.esm.js +626 -624
  5. package/dist/browser.esm.js.map +1 -1
  6. package/dist/browser.umd.js +196 -194
  7. package/dist/browser.umd.js.map +1 -1
  8. package/docs/content/ActionList2.mdx +360 -0
  9. package/docs/content/StateLabel.md +5 -4
  10. package/docs/content/getting-started.md +1 -1
  11. package/docs/src/@primer/gatsby-theme-doctocat/components/hero.js +1 -3
  12. package/docs/src/@primer/gatsby-theme-doctocat/components/live-preview-wrapper.js +1 -1
  13. package/docs/src/@primer/gatsby-theme-doctocat/live-code-scope.js +17 -0
  14. package/lib/ActionList2/Description.d.ts +12 -0
  15. package/lib/ActionList2/Description.js +53 -0
  16. package/lib/ActionList2/Divider.d.ts +5 -0
  17. package/lib/ActionList2/Divider.js +35 -0
  18. package/lib/ActionList2/Group.d.ts +11 -0
  19. package/lib/ActionList2/Group.js +57 -0
  20. package/lib/ActionList2/Header.d.ts +26 -0
  21. package/lib/ActionList2/Header.js +55 -0
  22. package/lib/ActionList2/Item.d.ts +63 -0
  23. package/lib/ActionList2/Item.js +244 -0
  24. package/lib/ActionList2/LinkItem.d.ts +17 -0
  25. package/lib/ActionList2/LinkItem.js +57 -0
  26. package/lib/ActionList2/List.d.ts +26 -0
  27. package/lib/ActionList2/List.js +59 -0
  28. package/lib/ActionList2/Selection.d.ts +5 -0
  29. package/lib/ActionList2/Selection.js +70 -0
  30. package/lib/ActionList2/Visuals.d.ts +9 -0
  31. package/lib/ActionList2/Visuals.js +90 -0
  32. package/lib/ActionList2/index.d.ts +36 -0
  33. package/lib/ActionList2/index.js +47 -0
  34. package/lib/Autocomplete/Autocomplete.d.ts +28 -28
  35. package/lib/Autocomplete/AutocompleteInput.d.ts +28 -28
  36. package/lib/Button/Button.d.ts +25 -25
  37. package/lib/Button/ButtonClose.d.ts +45 -45
  38. package/lib/Button/ButtonDanger.d.ts +25 -25
  39. package/lib/Button/ButtonInvisible.d.ts +25 -25
  40. package/lib/Button/ButtonOutline.d.ts +25 -25
  41. package/lib/Button/ButtonPrimary.d.ts +25 -25
  42. package/lib/CircleOcticon.d.ts +42 -42
  43. package/lib/Dialog.d.ts +45 -45
  44. package/lib/Dropdown.d.ts +176 -176
  45. package/lib/DropdownMenu/DropdownButton.d.ts +46 -46
  46. package/lib/FilterList.d.ts +42 -42
  47. package/lib/Overlay.js +3 -1
  48. package/lib/Portal/Portal.js +3 -2
  49. package/lib/Position.d.ts +4 -4
  50. package/lib/SelectMenu/SelectMenu.d.ts +246 -246
  51. package/lib/SelectMenu/SelectMenuItem.d.ts +1 -1
  52. package/lib/SelectMenu/SelectMenuModal.d.ts +1 -1
  53. package/lib/StateLabel.d.ts +1 -1
  54. package/lib/StateLabel.js +6 -1
  55. package/lib/TextInputWithTokens.d.ts +28 -28
  56. package/lib/Timeline.d.ts +43 -43
  57. package/lib/Token/AvatarToken.d.ts +1 -1
  58. package/lib/Token/IssueLabelToken.d.ts +1 -1
  59. package/lib/Token/Token.d.ts +1 -1
  60. package/lib/_TextInputWrapper.js +2 -2
  61. package/lib/__tests__/ActionList2.test.d.ts +1 -0
  62. package/lib/__tests__/ActionList2.test.js +53 -0
  63. package/lib/__tests__/AnchoredOverlay.test.js +4 -2
  64. package/lib/__tests__/TextInputWithTokens.test.js +1 -10
  65. package/lib/__tests__/utils/createSlots.test.d.ts +1 -0
  66. package/lib/__tests__/utils/createSlots.test.js +75 -0
  67. package/lib/drafts.d.ts +7 -0
  68. package/lib/drafts.js +18 -0
  69. package/lib/hooks/useAnchoredPosition.js +3 -2
  70. package/lib/hooks/useCombinedRefs.d.ts +2 -2
  71. package/lib/hooks/useCombinedRefs.js +4 -6
  72. package/lib/hooks/useResizeObserver.js +2 -2
  73. package/lib/stories/ActionList2.stories.js +907 -0
  74. package/lib/stories/TextInput.stories.js +144 -0
  75. package/lib/stories/Token.stories.js +19 -2
  76. package/lib/sx.d.ts +2 -0
  77. package/lib/sx.js +8 -0
  78. package/lib/theme-preval.js +81 -2
  79. package/lib/utils/create-slots.d.ts +17 -0
  80. package/lib/utils/create-slots.js +105 -0
  81. package/lib/utils/testing.d.ts +14 -1
  82. package/lib/utils/use-force-update.d.ts +1 -0
  83. package/lib/utils/use-force-update.js +19 -0
  84. package/lib/utils/useIsomorphicLayoutEffect.d.ts +3 -0
  85. package/lib/utils/useIsomorphicLayoutEffect.js +12 -0
  86. package/lib-esm/ActionList2/Description.d.ts +12 -0
  87. package/lib-esm/ActionList2/Description.js +37 -0
  88. package/lib-esm/ActionList2/Divider.d.ts +5 -0
  89. package/lib-esm/ActionList2/Divider.js +23 -0
  90. package/lib-esm/ActionList2/Group.d.ts +11 -0
  91. package/lib-esm/ActionList2/Group.js +40 -0
  92. package/lib-esm/ActionList2/Header.d.ts +26 -0
  93. package/lib-esm/ActionList2/Header.js +44 -0
  94. package/lib-esm/ActionList2/Item.d.ts +63 -0
  95. package/lib-esm/ActionList2/Item.js +210 -0
  96. package/lib-esm/ActionList2/LinkItem.d.ts +17 -0
  97. package/lib-esm/ActionList2/LinkItem.js +43 -0
  98. package/lib-esm/ActionList2/List.d.ts +26 -0
  99. package/lib-esm/ActionList2/List.js +37 -0
  100. package/lib-esm/ActionList2/Selection.d.ts +5 -0
  101. package/lib-esm/ActionList2/Selection.js +52 -0
  102. package/lib-esm/ActionList2/Visuals.d.ts +9 -0
  103. package/lib-esm/ActionList2/Visuals.js +68 -0
  104. package/lib-esm/ActionList2/index.d.ts +36 -0
  105. package/lib-esm/ActionList2/index.js +33 -0
  106. package/lib-esm/Autocomplete/Autocomplete.d.ts +28 -28
  107. package/lib-esm/Autocomplete/AutocompleteInput.d.ts +28 -28
  108. package/lib-esm/Button/Button.d.ts +25 -25
  109. package/lib-esm/Button/ButtonClose.d.ts +45 -45
  110. package/lib-esm/Button/ButtonDanger.d.ts +25 -25
  111. package/lib-esm/Button/ButtonInvisible.d.ts +25 -25
  112. package/lib-esm/Button/ButtonOutline.d.ts +25 -25
  113. package/lib-esm/Button/ButtonPrimary.d.ts +25 -25
  114. package/lib-esm/CircleOcticon.d.ts +42 -42
  115. package/lib-esm/Dialog.d.ts +45 -45
  116. package/lib-esm/Dropdown.d.ts +176 -176
  117. package/lib-esm/DropdownMenu/DropdownButton.d.ts +46 -46
  118. package/lib-esm/FilterList.d.ts +42 -42
  119. package/lib-esm/Overlay.js +2 -1
  120. package/lib-esm/Portal/Portal.js +2 -1
  121. package/lib-esm/Position.d.ts +4 -4
  122. package/lib-esm/SelectMenu/SelectMenu.d.ts +246 -246
  123. package/lib-esm/SelectMenu/SelectMenuItem.d.ts +1 -1
  124. package/lib-esm/SelectMenu/SelectMenuModal.d.ts +1 -1
  125. package/lib-esm/StateLabel.d.ts +1 -1
  126. package/lib-esm/StateLabel.js +7 -2
  127. package/lib-esm/TextInputWithTokens.d.ts +28 -28
  128. package/lib-esm/Timeline.d.ts +43 -43
  129. package/lib-esm/Token/AvatarToken.d.ts +1 -1
  130. package/lib-esm/Token/IssueLabelToken.d.ts +1 -1
  131. package/lib-esm/Token/Token.d.ts +1 -1
  132. package/lib-esm/_TextInputWrapper.js +2 -2
  133. package/lib-esm/__tests__/ActionList2.test.d.ts +1 -0
  134. package/lib-esm/__tests__/ActionList2.test.js +41 -0
  135. package/lib-esm/__tests__/AnchoredOverlay.test.js +4 -2
  136. package/lib-esm/__tests__/TextInputWithTokens.test.js +1 -10
  137. package/lib-esm/__tests__/utils/createSlots.test.d.ts +1 -0
  138. package/lib-esm/__tests__/utils/createSlots.test.js +67 -0
  139. package/lib-esm/drafts.d.ts +7 -0
  140. package/lib-esm/drafts.js +8 -0
  141. package/lib-esm/hooks/useAnchoredPosition.js +2 -1
  142. package/lib-esm/hooks/useCombinedRefs.d.ts +2 -2
  143. package/lib-esm/hooks/useCombinedRefs.js +3 -2
  144. package/lib-esm/hooks/useResizeObserver.js +2 -2
  145. package/lib-esm/stories/ActionList2.stories.js +796 -0
  146. package/lib-esm/stories/TextInput.stories.js +117 -0
  147. package/lib-esm/stories/Token.stories.js +14 -1
  148. package/lib-esm/sx.d.ts +2 -0
  149. package/lib-esm/sx.js +3 -1
  150. package/lib-esm/theme-preval.js +81 -2
  151. package/lib-esm/utils/create-slots.d.ts +17 -0
  152. package/lib-esm/utils/create-slots.js +84 -0
  153. package/lib-esm/utils/testing.d.ts +14 -1
  154. package/lib-esm/utils/use-force-update.d.ts +1 -0
  155. package/lib-esm/utils/use-force-update.js +6 -0
  156. package/lib-esm/utils/useIsomorphicLayoutEffect.d.ts +3 -0
  157. package/lib-esm/utils/useIsomorphicLayoutEffect.js +3 -0
  158. package/migrating.md +1 -1
  159. package/package-lock.json +153 -14
  160. package/package.json +6 -4
  161. package/script/build +2 -0
  162. package/src/ActionList2/Description.tsx +49 -0
  163. package/src/ActionList2/Divider.tsx +24 -0
  164. package/src/ActionList2/Group.tsx +34 -0
  165. package/src/ActionList2/Header.tsx +58 -0
  166. package/src/ActionList2/Item.tsx +245 -0
  167. package/src/ActionList2/LinkItem.tsx +49 -0
  168. package/src/ActionList2/List.tsx +55 -0
  169. package/src/ActionList2/Selection.tsx +40 -0
  170. package/src/ActionList2/Visuals.tsx +76 -0
  171. package/src/ActionList2/index.ts +39 -0
  172. package/src/Overlay.tsx +2 -1
  173. package/src/Portal/Portal.tsx +2 -1
  174. package/src/StateLabel.tsx +14 -2
  175. package/src/_TextInputWrapper.tsx +7 -0
  176. package/src/__tests__/ActionList2.test.tsx +47 -0
  177. package/src/__tests__/AnchoredOverlay.test.tsx +2 -2
  178. package/src/__tests__/TextInputWithTokens.test.tsx +0 -10
  179. package/src/__tests__/__snapshots__/ActionList2.test.tsx.snap +14 -0
  180. package/src/__tests__/__snapshots__/AnchoredOverlay.test.tsx.snap +35 -135
  181. package/src/__tests__/__snapshots__/Autocomplete.test.tsx.snap +1 -0
  182. package/src/__tests__/__snapshots__/CircleBadge.test.tsx.snap +1 -0
  183. package/src/__tests__/__snapshots__/CircleOcticon.test.tsx.snap +1 -0
  184. package/src/__tests__/__snapshots__/Dialog.test.tsx.snap +1 -0
  185. package/src/__tests__/__snapshots__/DropdownMenu.test.tsx.snap +1 -0
  186. package/src/__tests__/__snapshots__/SelectMenu.test.tsx.snap +4 -0
  187. package/src/__tests__/__snapshots__/SelectPanel.test.tsx.snap +1 -0
  188. package/src/__tests__/__snapshots__/StateLabel.test.tsx.snap +13 -6
  189. package/src/__tests__/__snapshots__/StyledOcticon.test.tsx.snap +1 -0
  190. package/src/__tests__/__snapshots__/TextInputWithTokens.test.tsx.snap +66 -0
  191. package/src/__tests__/__snapshots__/Token.test.tsx.snap +17 -0
  192. package/src/__tests__/utils/__snapshots__/createSlots.test.tsx.snap +55 -0
  193. package/src/__tests__/utils/createSlots.test.tsx +74 -0
  194. package/src/drafts.ts +9 -0
  195. package/src/hooks/useAnchoredPosition.ts +2 -1
  196. package/src/hooks/useCombinedRefs.ts +3 -3
  197. package/src/hooks/useResizeObserver.ts +2 -2
  198. package/src/stories/ActionList2.stories.tsx +1288 -0
  199. package/src/stories/TextInput.stories.tsx +113 -0
  200. package/src/stories/Token.stories.tsx +12 -1
  201. package/src/sx.ts +3 -0
  202. package/src/theme-preval.js +1 -0
  203. package/src/utils/create-slots.tsx +96 -0
  204. package/src/utils/use-force-update.ts +7 -0
  205. package/src/utils/useIsomorphicLayoutEffect.ts +10 -0
  206. package/stats.html +1 -1
package/package-lock.json CHANGED
@@ -9,8 +9,8 @@
9
9
  "version": "31.1.0",
10
10
  "license": "MIT",
11
11
  "dependencies": {
12
- "@primer/octicons-react": "^13.0.0",
13
- "@primer/primitives": "5.1.0",
12
+ "@primer/octicons-react": "^16.1.0",
13
+ "@primer/primitives": "6.1.0",
14
14
  "@radix-ui/react-polymorphic": "0.0.14",
15
15
  "@react-aria/ssr": "3.1.0",
16
16
  "@styled-system/css": "5.1.5",
@@ -90,6 +90,8 @@
90
90
  "lodash.isobject": "3.0.2",
91
91
  "prettier": "2.3.2",
92
92
  "react": "17.0.2",
93
+ "react-dnd": "14.0.4",
94
+ "react-dnd-html5-backend": "14.0.2",
93
95
  "react-dom": "17.0.2",
94
96
  "react-test-renderer": "17.0.2",
95
97
  "rollup": "2.56.3",
@@ -7548,9 +7550,9 @@
7548
7550
  }
7549
7551
  },
7550
7552
  "node_modules/@primer/octicons-react": {
7551
- "version": "13.0.0",
7552
- "resolved": "https://registry.npmjs.org/@primer/octicons-react/-/octicons-react-13.0.0.tgz",
7553
- "integrity": "sha512-j5XppNRCvgaMZLPsVvvmp6GSh7P5pq6PUbsfLNBWi2Kz3KYDeoGDWbPr5MjoxFOGUn6Hjnt6qjHPRxahd11vLQ==",
7553
+ "version": "16.1.1",
7554
+ "resolved": "https://registry.npmjs.org/@primer/octicons-react/-/octicons-react-16.1.1.tgz",
7555
+ "integrity": "sha512-xCxQ5z23ol7yDuJs85Lc4ARzyoay+b3zOhAKkEMU7chk0xi2hT2OnRP23QUudNNDPTGozX268RGYLexUa6P4xw==",
7554
7556
  "engines": {
7555
7557
  "node": ">=8"
7556
7558
  },
@@ -7559,9 +7561,9 @@
7559
7561
  }
7560
7562
  },
7561
7563
  "node_modules/@primer/primitives": {
7562
- "version": "5.1.0",
7563
- "resolved": "https://registry.npmjs.org/@primer/primitives/-/primitives-5.1.0.tgz",
7564
- "integrity": "sha512-pW8DIh6rZV0/R7lxHnVRJ/tdN4kDVSpAtdcCecxKsvtgK5d9haekt3ERpM6i93xKwB5CJYy9ouuC9C0UqWPI0A=="
7564
+ "version": "6.1.0",
7565
+ "resolved": "https://registry.npmjs.org/@primer/primitives/-/primitives-6.1.0.tgz",
7566
+ "integrity": "sha512-gwSVf5rVf2CMa/bU3/47LZosDHNfODMRJfKi7uJOqHWABVNl6Lf+thDM7Jb8tS9sEQQsUnrLDiGNjCScS81IXA=="
7565
7567
  },
7566
7568
  "node_modules/@radix-ui/react-polymorphic": {
7567
7569
  "version": "0.0.14",
@@ -7598,6 +7600,24 @@
7598
7600
  "react": "^16.8.0 || ^17.0.0-rc.1"
7599
7601
  }
7600
7602
  },
7603
+ "node_modules/@react-dnd/asap": {
7604
+ "version": "4.0.0",
7605
+ "resolved": "https://registry.npmjs.org/@react-dnd/asap/-/asap-4.0.0.tgz",
7606
+ "integrity": "sha512-0XhqJSc6pPoNnf8DhdsPHtUhRzZALVzYMTzRwV4VI6DJNJ/5xxfL9OQUwb8IH5/2x7lSf7nAZrnzUD+16VyOVQ==",
7607
+ "dev": true
7608
+ },
7609
+ "node_modules/@react-dnd/invariant": {
7610
+ "version": "2.0.0",
7611
+ "resolved": "https://registry.npmjs.org/@react-dnd/invariant/-/invariant-2.0.0.tgz",
7612
+ "integrity": "sha512-xL4RCQBCBDJ+GRwKTFhGUW8GXa4yoDfJrPbLblc3U09ciS+9ZJXJ3Qrcs/x2IODOdIE5kQxvMmE2UKyqUictUw==",
7613
+ "dev": true
7614
+ },
7615
+ "node_modules/@react-dnd/shallowequal": {
7616
+ "version": "2.0.0",
7617
+ "resolved": "https://registry.npmjs.org/@react-dnd/shallowequal/-/shallowequal-2.0.0.tgz",
7618
+ "integrity": "sha512-Pc/AFTdwZwEKJxFJvlxrSmGe/di+aAOBn60sremrpLo6VI/6cmiUYNNwlI5KNYttg7uypzA3ILPMPgxB2GYZEg==",
7619
+ "dev": true
7620
+ },
7601
7621
  "node_modules/@rollup/plugin-commonjs": {
7602
7622
  "version": "19.0.2",
7603
7623
  "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-19.0.2.tgz",
@@ -17234,6 +17254,17 @@
17234
17254
  "integrity": "sha1-44Mx8IRLukm5qctxx3FYWqsbxlo=",
17235
17255
  "dev": true
17236
17256
  },
17257
+ "node_modules/dnd-core": {
17258
+ "version": "14.0.1",
17259
+ "resolved": "https://registry.npmjs.org/dnd-core/-/dnd-core-14.0.1.tgz",
17260
+ "integrity": "sha512-+PVS2VPTgKFPYWo3vAFEA8WPbTf7/xo43TifH9G8S1KqnrQu0o77A3unrF5yOugy4mIz7K5wAVFHUcha7wsz6A==",
17261
+ "dev": true,
17262
+ "dependencies": {
17263
+ "@react-dnd/asap": "^4.0.0",
17264
+ "@react-dnd/invariant": "^2.0.0",
17265
+ "redux": "^4.1.1"
17266
+ }
17267
+ },
17237
17268
  "node_modules/doctrine": {
17238
17269
  "version": "3.0.0",
17239
17270
  "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
@@ -31528,6 +31559,45 @@
31528
31559
  "node": ">= 8"
31529
31560
  }
31530
31561
  },
31562
+ "node_modules/react-dnd": {
31563
+ "version": "14.0.4",
31564
+ "resolved": "https://registry.npmjs.org/react-dnd/-/react-dnd-14.0.4.tgz",
31565
+ "integrity": "sha512-AFJJXzUIWp5WAhgvI85ESkDCawM0lhoVvfo/lrseLXwFdH3kEO3v8I2C81QPqBW2UEyJBIPStOhPMGYGFtq/bg==",
31566
+ "dev": true,
31567
+ "dependencies": {
31568
+ "@react-dnd/invariant": "^2.0.0",
31569
+ "@react-dnd/shallowequal": "^2.0.0",
31570
+ "dnd-core": "14.0.1",
31571
+ "fast-deep-equal": "^3.1.3",
31572
+ "hoist-non-react-statics": "^3.3.2"
31573
+ },
31574
+ "peerDependencies": {
31575
+ "@types/hoist-non-react-statics": ">= 3.3.1",
31576
+ "@types/node": ">= 12",
31577
+ "@types/react": ">= 16",
31578
+ "react": ">= 16.14"
31579
+ },
31580
+ "peerDependenciesMeta": {
31581
+ "@types/hoist-non-react-statics": {
31582
+ "optional": true
31583
+ },
31584
+ "@types/node": {
31585
+ "optional": true
31586
+ },
31587
+ "@types/react": {
31588
+ "optional": true
31589
+ }
31590
+ }
31591
+ },
31592
+ "node_modules/react-dnd-html5-backend": {
31593
+ "version": "14.0.2",
31594
+ "resolved": "https://registry.npmjs.org/react-dnd-html5-backend/-/react-dnd-html5-backend-14.0.2.tgz",
31595
+ "integrity": "sha512-QgN6rYrOm4UUj6tIvN8ovImu6uP48xBXF2rzVsp6tvj6d5XQ7OjHI4SJ/ZgGobOneRAU3WCX4f8DGCYx0tuhlw==",
31596
+ "dev": true,
31597
+ "dependencies": {
31598
+ "dnd-core": "14.0.1"
31599
+ }
31600
+ },
31531
31601
  "node_modules/react-docgen": {
31532
31602
  "version": "5.4.0",
31533
31603
  "resolved": "https://registry.npmjs.org/react-docgen/-/react-docgen-5.4.0.tgz",
@@ -31956,6 +32026,15 @@
31956
32026
  "node": ">=8"
31957
32027
  }
31958
32028
  },
32029
+ "node_modules/redux": {
32030
+ "version": "4.1.2",
32031
+ "resolved": "https://registry.npmjs.org/redux/-/redux-4.1.2.tgz",
32032
+ "integrity": "sha512-SH8PglcebESbd/shgf6mii6EIoRM0zrQyjcuQ+ojmfxjTtE0z9Y8pa62iA/OJ58qjP6j27uyW4kUF4jl/jd6sw==",
32033
+ "dev": true,
32034
+ "dependencies": {
32035
+ "@babel/runtime": "^7.9.2"
32036
+ }
32037
+ },
31959
32038
  "node_modules/refractor": {
31960
32039
  "version": "3.5.0",
31961
32040
  "resolved": "https://registry.npmjs.org/refractor/-/refractor-3.5.0.tgz",
@@ -43266,15 +43345,15 @@
43266
43345
  "dev": true
43267
43346
  },
43268
43347
  "@primer/octicons-react": {
43269
- "version": "13.0.0",
43270
- "resolved": "https://registry.npmjs.org/@primer/octicons-react/-/octicons-react-13.0.0.tgz",
43271
- "integrity": "sha512-j5XppNRCvgaMZLPsVvvmp6GSh7P5pq6PUbsfLNBWi2Kz3KYDeoGDWbPr5MjoxFOGUn6Hjnt6qjHPRxahd11vLQ==",
43348
+ "version": "16.1.1",
43349
+ "resolved": "https://registry.npmjs.org/@primer/octicons-react/-/octicons-react-16.1.1.tgz",
43350
+ "integrity": "sha512-xCxQ5z23ol7yDuJs85Lc4ARzyoay+b3zOhAKkEMU7chk0xi2hT2OnRP23QUudNNDPTGozX268RGYLexUa6P4xw==",
43272
43351
  "requires": {}
43273
43352
  },
43274
43353
  "@primer/primitives": {
43275
- "version": "5.1.0",
43276
- "resolved": "https://registry.npmjs.org/@primer/primitives/-/primitives-5.1.0.tgz",
43277
- "integrity": "sha512-pW8DIh6rZV0/R7lxHnVRJ/tdN4kDVSpAtdcCecxKsvtgK5d9haekt3ERpM6i93xKwB5CJYy9ouuC9C0UqWPI0A=="
43354
+ "version": "6.1.0",
43355
+ "resolved": "https://registry.npmjs.org/@primer/primitives/-/primitives-6.1.0.tgz",
43356
+ "integrity": "sha512-gwSVf5rVf2CMa/bU3/47LZosDHNfODMRJfKi7uJOqHWABVNl6Lf+thDM7Jb8tS9sEQQsUnrLDiGNjCScS81IXA=="
43278
43357
  },
43279
43358
  "@radix-ui/react-polymorphic": {
43280
43359
  "version": "0.0.14",
@@ -43302,6 +43381,24 @@
43302
43381
  "@babel/runtime": "^7.6.2"
43303
43382
  }
43304
43383
  },
43384
+ "@react-dnd/asap": {
43385
+ "version": "4.0.0",
43386
+ "resolved": "https://registry.npmjs.org/@react-dnd/asap/-/asap-4.0.0.tgz",
43387
+ "integrity": "sha512-0XhqJSc6pPoNnf8DhdsPHtUhRzZALVzYMTzRwV4VI6DJNJ/5xxfL9OQUwb8IH5/2x7lSf7nAZrnzUD+16VyOVQ==",
43388
+ "dev": true
43389
+ },
43390
+ "@react-dnd/invariant": {
43391
+ "version": "2.0.0",
43392
+ "resolved": "https://registry.npmjs.org/@react-dnd/invariant/-/invariant-2.0.0.tgz",
43393
+ "integrity": "sha512-xL4RCQBCBDJ+GRwKTFhGUW8GXa4yoDfJrPbLblc3U09ciS+9ZJXJ3Qrcs/x2IODOdIE5kQxvMmE2UKyqUictUw==",
43394
+ "dev": true
43395
+ },
43396
+ "@react-dnd/shallowequal": {
43397
+ "version": "2.0.0",
43398
+ "resolved": "https://registry.npmjs.org/@react-dnd/shallowequal/-/shallowequal-2.0.0.tgz",
43399
+ "integrity": "sha512-Pc/AFTdwZwEKJxFJvlxrSmGe/di+aAOBn60sremrpLo6VI/6cmiUYNNwlI5KNYttg7uypzA3ILPMPgxB2GYZEg==",
43400
+ "dev": true
43401
+ },
43305
43402
  "@rollup/plugin-commonjs": {
43306
43403
  "version": "19.0.2",
43307
43404
  "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-19.0.2.tgz",
@@ -50661,6 +50758,17 @@
50661
50758
  "integrity": "sha1-44Mx8IRLukm5qctxx3FYWqsbxlo=",
50662
50759
  "dev": true
50663
50760
  },
50761
+ "dnd-core": {
50762
+ "version": "14.0.1",
50763
+ "resolved": "https://registry.npmjs.org/dnd-core/-/dnd-core-14.0.1.tgz",
50764
+ "integrity": "sha512-+PVS2VPTgKFPYWo3vAFEA8WPbTf7/xo43TifH9G8S1KqnrQu0o77A3unrF5yOugy4mIz7K5wAVFHUcha7wsz6A==",
50765
+ "dev": true,
50766
+ "requires": {
50767
+ "@react-dnd/asap": "^4.0.0",
50768
+ "@react-dnd/invariant": "^2.0.0",
50769
+ "redux": "^4.1.1"
50770
+ }
50771
+ },
50664
50772
  "doctrine": {
50665
50773
  "version": "3.0.0",
50666
50774
  "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
@@ -61611,6 +61719,28 @@
61611
61719
  }
61612
61720
  }
61613
61721
  },
61722
+ "react-dnd": {
61723
+ "version": "14.0.4",
61724
+ "resolved": "https://registry.npmjs.org/react-dnd/-/react-dnd-14.0.4.tgz",
61725
+ "integrity": "sha512-AFJJXzUIWp5WAhgvI85ESkDCawM0lhoVvfo/lrseLXwFdH3kEO3v8I2C81QPqBW2UEyJBIPStOhPMGYGFtq/bg==",
61726
+ "dev": true,
61727
+ "requires": {
61728
+ "@react-dnd/invariant": "^2.0.0",
61729
+ "@react-dnd/shallowequal": "^2.0.0",
61730
+ "dnd-core": "14.0.1",
61731
+ "fast-deep-equal": "^3.1.3",
61732
+ "hoist-non-react-statics": "^3.3.2"
61733
+ }
61734
+ },
61735
+ "react-dnd-html5-backend": {
61736
+ "version": "14.0.2",
61737
+ "resolved": "https://registry.npmjs.org/react-dnd-html5-backend/-/react-dnd-html5-backend-14.0.2.tgz",
61738
+ "integrity": "sha512-QgN6rYrOm4UUj6tIvN8ovImu6uP48xBXF2rzVsp6tvj6d5XQ7OjHI4SJ/ZgGobOneRAU3WCX4f8DGCYx0tuhlw==",
61739
+ "dev": true,
61740
+ "requires": {
61741
+ "dnd-core": "14.0.1"
61742
+ }
61743
+ },
61614
61744
  "react-docgen": {
61615
61745
  "version": "5.4.0",
61616
61746
  "resolved": "https://registry.npmjs.org/react-docgen/-/react-docgen-5.4.0.tgz",
@@ -61956,6 +62086,15 @@
61956
62086
  "strip-indent": "^3.0.0"
61957
62087
  }
61958
62088
  },
62089
+ "redux": {
62090
+ "version": "4.1.2",
62091
+ "resolved": "https://registry.npmjs.org/redux/-/redux-4.1.2.tgz",
62092
+ "integrity": "sha512-SH8PglcebESbd/shgf6mii6EIoRM0zrQyjcuQ+ojmfxjTtE0z9Y8pa62iA/OJ58qjP6j27uyW4kUF4jl/jd6sw==",
62093
+ "dev": true,
62094
+ "requires": {
62095
+ "@babel/runtime": "^7.9.2"
62096
+ }
62097
+ },
61959
62098
  "refractor": {
61960
62099
  "version": "3.5.0",
61961
62100
  "resolved": "https://registry.npmjs.org/refractor/-/refractor-3.5.0.tgz",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@primer/components",
3
- "version": "31.2.0-rc.5ccefd7d",
3
+ "version": "31.2.0-rc.5e503f97",
4
4
  "description": "Primer react components",
5
5
  "main": "lib/index.js",
6
6
  "module": "lib-esm/index.js",
@@ -15,7 +15,7 @@
15
15
  "start": "concurrently npm:start:*",
16
16
  "start:docs": "cd docs && npm run develop",
17
17
  "start:storybook": "start-storybook -p 6006",
18
- "lint": "eslint '**/*.{js,ts,tsx,md,mdx}'",
18
+ "lint": "eslint '**/*.{js,ts,tsx,md,mdx}' --max-warnings=0",
19
19
  "lint:fix": "npm run lint -- --fix",
20
20
  "test": "jest",
21
21
  "test:update": "npm run test -- --updateSnapshot",
@@ -43,8 +43,8 @@
43
43
  "author": "GitHub, Inc.",
44
44
  "license": "MIT",
45
45
  "dependencies": {
46
- "@primer/octicons-react": "^13.0.0",
47
- "@primer/primitives": "5.1.0",
46
+ "@primer/octicons-react": "^16.1.0",
47
+ "@primer/primitives": "6.1.0",
48
48
  "@radix-ui/react-polymorphic": "0.0.14",
49
49
  "@react-aria/ssr": "3.1.0",
50
50
  "@styled-system/css": "5.1.5",
@@ -124,6 +124,8 @@
124
124
  "lodash.isobject": "3.0.2",
125
125
  "prettier": "2.3.2",
126
126
  "react": "17.0.2",
127
+ "react-dnd": "14.0.4",
128
+ "react-dnd-html5-backend": "14.0.2",
127
129
  "react-dom": "17.0.2",
128
130
  "react-test-renderer": "17.0.2",
129
131
  "rollup": "2.56.3",
package/script/build CHANGED
@@ -1,5 +1,7 @@
1
1
  #!/bin/bash
2
2
 
3
+ set -e
4
+
3
5
  # Clean up
4
6
  rm -rf dist
5
7
  rm -rf lib
@@ -0,0 +1,49 @@
1
+ import React from 'react'
2
+ import Box from '../Box'
3
+ import {SxProp, merge} from '../sx'
4
+ import Truncate from '../Truncate'
5
+ import {Slot, ItemContext} from './Item'
6
+
7
+ export type DescriptionProps = {
8
+ /**
9
+ * Secondary text style variations.
10
+ *
11
+ * - `"inline"` - Secondary text is positioned beside primary text.
12
+ * - `"block"` - Secondary text is positioned below primary text.
13
+ */
14
+ variant?: 'inline' | 'block'
15
+ } & SxProp
16
+
17
+ export const Description: React.FC<DescriptionProps> = ({variant = 'inline', sx = {}, ...props}) => {
18
+ const styles = {
19
+ color: 'fg.muted',
20
+ fontSize: 0,
21
+ lineHeight: '16px',
22
+ flexGrow: 1,
23
+ flexBasis: 0,
24
+ minWidth: 0,
25
+ marginLeft: variant === 'block' ? 0 : 2
26
+ }
27
+
28
+ return (
29
+ <Slot name={variant === 'block' ? 'BlockDescription' : 'InlineDescription'}>
30
+ {({blockDescriptionId, inlineDescriptionId}: ItemContext) =>
31
+ variant === 'block' ? (
32
+ <Box as="span" sx={merge(styles, sx as SxProp)} id={blockDescriptionId}>
33
+ {props.children}
34
+ </Box>
35
+ ) : (
36
+ <Truncate
37
+ id={inlineDescriptionId}
38
+ sx={merge(styles, sx as SxProp)}
39
+ title={props.children as string}
40
+ inline={true}
41
+ maxWidth="100%"
42
+ >
43
+ {props.children}
44
+ </Truncate>
45
+ )
46
+ }
47
+ </Slot>
48
+ )
49
+ }
@@ -0,0 +1,24 @@
1
+ import React from 'react'
2
+ import Box from '../Box'
3
+ import {get} from '../constants'
4
+ import {Theme} from '../ThemeProvider'
5
+
6
+ /**
7
+ * Visually separates `Item`s or `Group`s in an `ActionList`.
8
+ */
9
+ export function Divider(): JSX.Element {
10
+ return (
11
+ <Box
12
+ as="li"
13
+ role="separator"
14
+ sx={{
15
+ height: 1,
16
+ backgroundColor: 'actionListItem.inlineDivider',
17
+ marginTop: (theme: Theme) => `calc(${get('space.2')(theme)} - 1px)`,
18
+ marginBottom: 2,
19
+ listStyle: 'none' // hide the ::marker inserted by browser's stylesheet
20
+ }}
21
+ data-component="ActionList.Divider"
22
+ />
23
+ )
24
+ }
@@ -0,0 +1,34 @@
1
+ import React from 'react'
2
+ import Box from '../Box'
3
+ import {SxProp} from '../sx'
4
+ import {Header, HeaderProps} from './Header'
5
+ import {ListProps} from './List'
6
+
7
+ export type GroupProps = HeaderProps &
8
+ SxProp & {
9
+ selectionVariant?: ListProps['selectionVariant'] | false
10
+ }
11
+
12
+ type ContextProps = Pick<GroupProps, 'selectionVariant'>
13
+ export const GroupContext = React.createContext<ContextProps>({})
14
+
15
+ export const Group: React.FC<GroupProps> = ({title, variant, auxiliaryText, selectionVariant, sx = {}, ...props}) => {
16
+ return (
17
+ <Box
18
+ as="li"
19
+ sx={{
20
+ '&:not(:first-child)': {marginTop: 2},
21
+ listStyle: 'none', // hide the ::marker inserted by browser's stylesheet
22
+ ...sx
23
+ }}
24
+ {...props}
25
+ >
26
+ {title && <Header title={title} variant={variant} auxiliaryText={auxiliaryText} />}
27
+ <GroupContext.Provider value={{selectionVariant}}>
28
+ <Box as="ul" sx={{paddingInlineStart: 0}}>
29
+ {props.children}
30
+ </Box>
31
+ </GroupContext.Provider>
32
+ </Box>
33
+ )
34
+ }
@@ -0,0 +1,58 @@
1
+ import React from 'react'
2
+ import Box from '../Box'
3
+ import {SxProp} from '../sx'
4
+ import {ListContext} from './List'
5
+
6
+ /**
7
+ * Contract for props passed to the `Header` component.
8
+ */
9
+ export type HeaderProps = {
10
+ /**
11
+ * Style variations. Usage is discretionary.
12
+ *
13
+ * - `"filled"` - Superimposed on a background, offset from nearby content
14
+ * - `"subtle"` - Relatively less offset from nearby content
15
+ */
16
+ variant?: 'subtle' | 'filled'
17
+
18
+ /**
19
+ * Primary text which names a `Group`.
20
+ */
21
+ title?: string
22
+
23
+ /**
24
+ * Secondary text which provides additional information about a `Group`.
25
+ */
26
+ auxiliaryText?: string
27
+ } & SxProp
28
+
29
+ /**
30
+ * Displays the name and description of a `Group`.
31
+ */
32
+ export const Header = ({variant = 'subtle', title, auxiliaryText, sx = {}, ...props}: HeaderProps): JSX.Element => {
33
+ const {variant: listVariant} = React.useContext(ListContext)
34
+
35
+ const styles = {
36
+ paddingY: '6px',
37
+ paddingX: listVariant === 'full' ? 2 : 3,
38
+ fontSize: 0,
39
+ fontWeight: 'bold',
40
+ color: 'fg.muted',
41
+ ...(variant === 'filled' && {
42
+ backgroundColor: 'canvas.subtle',
43
+ marginX: 0,
44
+ marginBottom: 2,
45
+ borderTop: '1px solid',
46
+ borderBottom: '1px solid',
47
+ borderColor: 'neutral.muted'
48
+ }),
49
+ ...sx
50
+ }
51
+
52
+ return (
53
+ <Box sx={styles} role="heading" {...props}>
54
+ {title}
55
+ {auxiliaryText && <span>{auxiliaryText}</span>}
56
+ </Box>
57
+ )
58
+ }