@mixtint/primer-view-components 0.72.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. package/LICENSE.txt +21 -0
  2. package/README.md +30 -0
  3. package/app/assets/images/loading_indicator.svg +1 -0
  4. package/app/assets/javascripts/components/primer/alpha/action_bar_element.d.ts +17 -0
  5. package/app/assets/javascripts/components/primer/alpha/action_list.d.ts +16 -0
  6. package/app/assets/javascripts/components/primer/alpha/action_menu/action_menu_element.d.ts +49 -0
  7. package/app/assets/javascripts/components/primer/alpha/action_menu/action_menu_focus_zone_stack.d.ts +17 -0
  8. package/app/assets/javascripts/components/primer/alpha/dropdown/menu.d.ts +1 -0
  9. package/app/assets/javascripts/components/primer/alpha/dropdown.d.ts +1 -0
  10. package/app/assets/javascripts/components/primer/alpha/modal_dialog.d.ts +18 -0
  11. package/app/assets/javascripts/components/primer/alpha/segmented_control.d.ts +12 -0
  12. package/app/assets/javascripts/components/primer/alpha/select_panel_element.d.ts +65 -0
  13. package/app/assets/javascripts/components/primer/alpha/tab_container.d.ts +1 -0
  14. package/app/assets/javascripts/components/primer/alpha/toggle_switch.d.ts +34 -0
  15. package/app/assets/javascripts/components/primer/alpha/tool_tip.d.ts +27 -0
  16. package/app/assets/javascripts/components/primer/alpha/tree_view/tree_view.d.ts +42 -0
  17. package/app/assets/javascripts/components/primer/alpha/tree_view/tree_view_icon_pair_element.d.ts +15 -0
  18. package/app/assets/javascripts/components/primer/alpha/tree_view/tree_view_include_fragment_element.d.ts +9 -0
  19. package/app/assets/javascripts/components/primer/alpha/tree_view/tree_view_roving_tab_index.d.ts +3 -0
  20. package/app/assets/javascripts/components/primer/alpha/tree_view/tree_view_sub_tree_node_element.d.ts +45 -0
  21. package/app/assets/javascripts/components/primer/alpha/x_banner.d.ts +18 -0
  22. package/app/assets/javascripts/components/primer/anchored_position.d.ts +27 -0
  23. package/app/assets/javascripts/components/primer/beta/auto_complete/auto_complete.d.ts +1 -0
  24. package/app/assets/javascripts/components/primer/beta/clipboard_copy.d.ts +1 -0
  25. package/app/assets/javascripts/components/primer/beta/details_toggle_element.d.ts +40 -0
  26. package/app/assets/javascripts/components/primer/beta/nav_list.d.ts +20 -0
  27. package/app/assets/javascripts/components/primer/beta/nav_list_group_element.d.ts +19 -0
  28. package/app/assets/javascripts/components/primer/beta/relative_time.d.ts +1 -0
  29. package/app/assets/javascripts/components/primer/dialog_helper.d.ts +15 -0
  30. package/app/assets/javascripts/components/primer/focus_group.d.ts +19 -0
  31. package/app/assets/javascripts/components/primer/open_project/border_box/collapsible_header.d.ts +11 -0
  32. package/app/assets/javascripts/components/primer/open_project/collapsible.d.ts +13 -0
  33. package/app/assets/javascripts/components/primer/open_project/collapsible_section.d.ts +10 -0
  34. package/app/assets/javascripts/components/primer/open_project/danger_dialog_form_helper.d.ts +14 -0
  35. package/app/assets/javascripts/components/primer/open_project/filterable_tree_view.d.ts +29 -0
  36. package/app/assets/javascripts/components/primer/open_project/page_header_element.d.ts +9 -0
  37. package/app/assets/javascripts/components/primer/open_project/sub_header_element.d.ts +17 -0
  38. package/app/assets/javascripts/components/primer/open_project/zen_mode_button.d.ts +18 -0
  39. package/app/assets/javascripts/components/primer/primer.d.ts +40 -0
  40. package/app/assets/javascripts/components/primer/scrollable_region.d.ts +13 -0
  41. package/app/assets/javascripts/components/primer/shared_events.d.ts +26 -0
  42. package/app/assets/javascripts/components/primer/utils.d.ts +1 -0
  43. package/app/assets/javascripts/lib/primer/forms/primer_multi_input.d.ts +10 -0
  44. package/app/assets/javascripts/lib/primer/forms/primer_text_field.d.ts +28 -0
  45. package/app/assets/javascripts/lib/primer/forms/toggle_switch_input.d.ts +5 -0
  46. package/app/assets/javascripts/primer_view_components.js +2 -0
  47. package/app/assets/javascripts/primer_view_components.js.map +1 -0
  48. package/app/assets/styles/primer_view_components.css +7336 -0
  49. package/app/assets/styles/primer_view_components.css.map +1 -0
  50. package/app/components/primer/alpha/action_bar.css +49 -0
  51. package/app/components/primer/alpha/action_bar.css.json +14 -0
  52. package/app/components/primer/alpha/action_bar_element.d.ts +17 -0
  53. package/app/components/primer/alpha/action_bar_element.js +170 -0
  54. package/app/components/primer/alpha/action_list.css +526 -0
  55. package/app/components/primer/alpha/action_list.css.json +117 -0
  56. package/app/components/primer/alpha/action_list.d.ts +16 -0
  57. package/app/components/primer/alpha/action_list.js +70 -0
  58. package/app/components/primer/alpha/action_menu/action_menu_element.d.ts +49 -0
  59. package/app/components/primer/alpha/action_menu/action_menu_element.js +591 -0
  60. package/app/components/primer/alpha/action_menu/action_menu_focus_zone_stack.d.ts +17 -0
  61. package/app/components/primer/alpha/action_menu/action_menu_focus_zone_stack.js +62 -0
  62. package/app/components/primer/alpha/auto_complete.css +131 -0
  63. package/app/components/primer/alpha/auto_complete.css.json +21 -0
  64. package/app/components/primer/alpha/banner.css +146 -0
  65. package/app/components/primer/alpha/banner.css.json +26 -0
  66. package/app/components/primer/alpha/button_marketing.css +183 -0
  67. package/app/components/primer/alpha/button_marketing.css.json +30 -0
  68. package/app/components/primer/alpha/dialog.css +377 -0
  69. package/app/components/primer/alpha/dialog.css.json +66 -0
  70. package/app/components/primer/alpha/dropdown/menu.d.ts +1 -0
  71. package/app/components/primer/alpha/dropdown/menu.js +1 -0
  72. package/app/components/primer/alpha/dropdown.css +296 -0
  73. package/app/components/primer/alpha/dropdown.css.json +40 -0
  74. package/app/components/primer/alpha/dropdown.d.ts +1 -0
  75. package/app/components/primer/alpha/dropdown.js +1 -0
  76. package/app/components/primer/alpha/layout.css +374 -0
  77. package/app/components/primer/alpha/layout.css.json +74 -0
  78. package/app/components/primer/alpha/menu.css +124 -0
  79. package/app/components/primer/alpha/menu.css.json +26 -0
  80. package/app/components/primer/alpha/modal_dialog.d.ts +18 -0
  81. package/app/components/primer/alpha/modal_dialog.js +187 -0
  82. package/app/components/primer/alpha/overlay.css +25 -0
  83. package/app/components/primer/alpha/overlay.css.json +12 -0
  84. package/app/components/primer/alpha/segmented_control.css +161 -0
  85. package/app/components/primer/alpha/segmented_control.css.json +31 -0
  86. package/app/components/primer/alpha/segmented_control.d.ts +12 -0
  87. package/app/components/primer/alpha/segmented_control.js +59 -0
  88. package/app/components/primer/alpha/select_panel.css +10 -0
  89. package/app/components/primer/alpha/select_panel.css.json +7 -0
  90. package/app/components/primer/alpha/select_panel_element.d.ts +65 -0
  91. package/app/components/primer/alpha/select_panel_element.js +988 -0
  92. package/app/components/primer/alpha/skeleton_box.css +36 -0
  93. package/app/components/primer/alpha/skeleton_box.css.json +6 -0
  94. package/app/components/primer/alpha/stack.css +266 -0
  95. package/app/components/primer/alpha/stack.css.json +94 -0
  96. package/app/components/primer/alpha/stack_item.css +27 -0
  97. package/app/components/primer/alpha/stack_item.css.json +12 -0
  98. package/app/components/primer/alpha/tab_container.d.ts +1 -0
  99. package/app/components/primer/alpha/tab_container.js +1 -0
  100. package/app/components/primer/alpha/tab_nav.css +112 -0
  101. package/app/components/primer/alpha/tab_nav.css.json +22 -0
  102. package/app/components/primer/alpha/text_field.css +838 -0
  103. package/app/components/primer/alpha/text_field.css.json +134 -0
  104. package/app/components/primer/alpha/toggle_switch.css +230 -0
  105. package/app/components/primer/alpha/toggle_switch.css.json +40 -0
  106. package/app/components/primer/alpha/toggle_switch.d.ts +34 -0
  107. package/app/components/primer/alpha/toggle_switch.js +179 -0
  108. package/app/components/primer/alpha/tool_tip.d.ts +27 -0
  109. package/app/components/primer/alpha/tool_tip.js +443 -0
  110. package/app/components/primer/alpha/tree_view/tree_view.d.ts +42 -0
  111. package/app/components/primer/alpha/tree_view/tree_view.js +391 -0
  112. package/app/components/primer/alpha/tree_view/tree_view_icon_pair_element.d.ts +15 -0
  113. package/app/components/primer/alpha/tree_view/tree_view_icon_pair_element.js +62 -0
  114. package/app/components/primer/alpha/tree_view/tree_view_include_fragment_element.d.ts +9 -0
  115. package/app/components/primer/alpha/tree_view/tree_view_include_fragment_element.js +28 -0
  116. package/app/components/primer/alpha/tree_view/tree_view_roving_tab_index.d.ts +3 -0
  117. package/app/components/primer/alpha/tree_view/tree_view_roving_tab_index.js +130 -0
  118. package/app/components/primer/alpha/tree_view/tree_view_sub_tree_node_element.d.ts +45 -0
  119. package/app/components/primer/alpha/tree_view/tree_view_sub_tree_node_element.js +429 -0
  120. package/app/components/primer/alpha/tree_view.css +396 -0
  121. package/app/components/primer/alpha/tree_view.css.json +52 -0
  122. package/app/components/primer/alpha/underline_nav.css +150 -0
  123. package/app/components/primer/alpha/underline_nav.css.json +26 -0
  124. package/app/components/primer/alpha/x_banner.d.ts +18 -0
  125. package/app/components/primer/alpha/x_banner.js +51 -0
  126. package/app/components/primer/anchored_position.d.ts +27 -0
  127. package/app/components/primer/anchored_position.js +159 -0
  128. package/app/components/primer/beta/auto_complete/auto_complete.d.ts +1 -0
  129. package/app/components/primer/beta/auto_complete/auto_complete.js +1 -0
  130. package/app/components/primer/beta/avatar.css +77 -0
  131. package/app/components/primer/beta/avatar.css.json +17 -0
  132. package/app/components/primer/beta/avatar_stack.css +145 -0
  133. package/app/components/primer/beta/avatar_stack.css.json +28 -0
  134. package/app/components/primer/beta/blankslate.css +168 -0
  135. package/app/components/primer/beta/blankslate.css.json +23 -0
  136. package/app/components/primer/beta/border_box.css +218 -0
  137. package/app/components/primer/beta/border_box.css.json +54 -0
  138. package/app/components/primer/beta/breadcrumbs.css +29 -0
  139. package/app/components/primer/beta/breadcrumbs.css.json +9 -0
  140. package/app/components/primer/beta/button.css +359 -0
  141. package/app/components/primer/beta/button.css.json +86 -0
  142. package/app/components/primer/beta/button_group.css +20 -0
  143. package/app/components/primer/beta/button_group.css.json +12 -0
  144. package/app/components/primer/beta/clipboard_copy.d.ts +1 -0
  145. package/app/components/primer/beta/clipboard_copy.js +58 -0
  146. package/app/components/primer/beta/counter.css +38 -0
  147. package/app/components/primer/beta/counter.css.json +10 -0
  148. package/app/components/primer/beta/details_toggle_element.d.ts +40 -0
  149. package/app/components/primer/beta/details_toggle_element.js +65 -0
  150. package/app/components/primer/beta/flash.css +152 -0
  151. package/app/components/primer/beta/flash.css.json +27 -0
  152. package/app/components/primer/beta/label.css +109 -0
  153. package/app/components/primer/beta/label.css.json +24 -0
  154. package/app/components/primer/beta/link.css +79 -0
  155. package/app/components/primer/beta/link.css.json +19 -0
  156. package/app/components/primer/beta/nav_list.d.ts +20 -0
  157. package/app/components/primer/beta/nav_list.js +192 -0
  158. package/app/components/primer/beta/nav_list_group_element.d.ts +19 -0
  159. package/app/components/primer/beta/nav_list_group_element.js +111 -0
  160. package/app/components/primer/beta/popover.css +215 -0
  161. package/app/components/primer/beta/popover.css.json +33 -0
  162. package/app/components/primer/beta/progress_bar.css +27 -0
  163. package/app/components/primer/beta/progress_bar.css.json +10 -0
  164. package/app/components/primer/beta/relative_time.d.ts +1 -0
  165. package/app/components/primer/beta/relative_time.js +1 -0
  166. package/app/components/primer/beta/state.css +59 -0
  167. package/app/components/primer/beta/state.css.json +13 -0
  168. package/app/components/primer/beta/subhead.css +64 -0
  169. package/app/components/primer/beta/subhead.css.json +14 -0
  170. package/app/components/primer/beta/timeline_item.css +106 -0
  171. package/app/components/primer/beta/timeline_item.css.json +16 -0
  172. package/app/components/primer/beta/truncate.css +30 -0
  173. package/app/components/primer/beta/truncate.css.json +12 -0
  174. package/app/components/primer/dialog_helper.d.ts +15 -0
  175. package/app/components/primer/dialog_helper.js +132 -0
  176. package/app/components/primer/focus_group.d.ts +19 -0
  177. package/app/components/primer/focus_group.js +163 -0
  178. package/app/components/primer/open_project/border_box/collapsible_header.css +21 -0
  179. package/app/components/primer/open_project/border_box/collapsible_header.css.json +11 -0
  180. package/app/components/primer/open_project/border_box/collapsible_header.d.ts +11 -0
  181. package/app/components/primer/open_project/border_box/collapsible_header.js +21 -0
  182. package/app/components/primer/open_project/border_grid.css +35 -0
  183. package/app/components/primer/open_project/border_grid.css.json +11 -0
  184. package/app/components/primer/open_project/collapsible.d.ts +13 -0
  185. package/app/components/primer/open_project/collapsible.js +67 -0
  186. package/app/components/primer/open_project/collapsible_section.css +5 -0
  187. package/app/components/primer/open_project/collapsible_section.css.json +6 -0
  188. package/app/components/primer/open_project/collapsible_section.d.ts +10 -0
  189. package/app/components/primer/open_project/collapsible_section.js +16 -0
  190. package/app/components/primer/open_project/danger_dialog_form_helper.d.ts +14 -0
  191. package/app/components/primer/open_project/danger_dialog_form_helper.js +54 -0
  192. package/app/components/primer/open_project/drag_handle.css +6 -0
  193. package/app/components/primer/open_project/drag_handle.css.json +6 -0
  194. package/app/components/primer/open_project/filterable_tree_view.d.ts +29 -0
  195. package/app/components/primer/open_project/filterable_tree_view.js +409 -0
  196. package/app/components/primer/open_project/input_group.css +22 -0
  197. package/app/components/primer/open_project/input_group.css.json +12 -0
  198. package/app/components/primer/open_project/page_header.css +87 -0
  199. package/app/components/primer/open_project/page_header.css.json +20 -0
  200. package/app/components/primer/open_project/page_header_element.d.ts +9 -0
  201. package/app/components/primer/open_project/page_header_element.js +23 -0
  202. package/app/components/primer/open_project/side_panel/section.css +27 -0
  203. package/app/components/primer/open_project/side_panel/section.css.json +11 -0
  204. package/app/components/primer/open_project/sub_header.css +80 -0
  205. package/app/components/primer/open_project/sub_header.css.json +17 -0
  206. package/app/components/primer/open_project/sub_header_element.d.ts +17 -0
  207. package/app/components/primer/open_project/sub_header_element.js +76 -0
  208. package/app/components/primer/open_project/zen_mode_button.d.ts +18 -0
  209. package/app/components/primer/open_project/zen_mode_button.js +64 -0
  210. package/app/components/primer/primer.d.ts +40 -0
  211. package/app/components/primer/primer.js +40 -0
  212. package/app/components/primer/scrollable_region.d.ts +13 -0
  213. package/app/components/primer/scrollable_region.js +52 -0
  214. package/app/components/primer/shared_events.d.ts +26 -0
  215. package/app/components/primer/shared_events.js +1 -0
  216. package/app/components/primer/truncate.css +23 -0
  217. package/app/components/primer/truncate.css.json +13 -0
  218. package/app/components/primer/utils.d.ts +1 -0
  219. package/app/components/primer/utils.js +16 -0
  220. package/app/lib/primer/forms/primer_multi_input.d.ts +10 -0
  221. package/app/lib/primer/forms/primer_multi_input.js +44 -0
  222. package/app/lib/primer/forms/primer_text_field.d.ts +28 -0
  223. package/app/lib/primer/forms/primer_text_field.js +119 -0
  224. package/app/lib/primer/forms/toggle_switch_input.d.ts +5 -0
  225. package/app/lib/primer/forms/toggle_switch_input.js +34 -0
  226. package/package.json +103 -0
  227. package/static/arguments.json +6472 -0
  228. package/static/audited_at.json +173 -0
  229. package/static/classes.json +781 -0
  230. package/static/constants.json +1972 -0
  231. package/static/form_previews.json +118 -0
  232. package/static/info_arch.json +21331 -0
  233. package/static/previews.json +9436 -0
  234. package/static/statuses.json +173 -0
@@ -0,0 +1,218 @@
1
+ /* stylelint-disable primer/spacing */
2
+ /* stylelint-disable primer/typography */
3
+ /* BorderBox */
4
+ /* TODO: Rename to BorderBox to match PVC */
5
+ .Box {
6
+ background-color: var(--bgColor-default);
7
+ border-color: var(--borderColor-default);
8
+ border-style: solid;
9
+ border-width: var(--borderWidth-thin);
10
+ border-radius: var(--borderRadius-medium);
11
+ }
12
+ /* Box padding density options */
13
+ .Box--condensed {
14
+ line-height: 1.25;
15
+ }
16
+ .Box--condensed .Box-header {
17
+ padding: var(--stack-padding-condensed) var(--stack-padding-normal);
18
+ }
19
+ .Box--condensed .Box-body {
20
+ padding: var(--stack-padding-condensed) var(--stack-padding-normal);
21
+ }
22
+ .Box--condensed .Box-footer {
23
+ padding: var(--stack-padding-condensed) var(--stack-padding-normal);
24
+ }
25
+ .btn-octicon:is(.Box--condensed .Box-btn-octicon) {
26
+ padding: var(--control-medium-paddingInline-condensed) var(--control-medium-paddingInline-spacious);
27
+ margin: calc(var(--controlStack-medium-gap-condensed) * -1) calc(var(--controlStack-small-gap-spacious) * -1);
28
+ line-height: 1.25;
29
+ }
30
+ .Box--condensed .Box-row {
31
+ padding: var(--stack-padding-condensed) var(--stack-padding-normal);
32
+ }
33
+ .Box--spacious .Box-header {
34
+ padding: var(--stack-padding-spacious);
35
+ line-height: 1.25;
36
+ }
37
+ .Box--spacious .Box-title {
38
+ font-size: var(--text-title-size-medium);
39
+ }
40
+ .Box--spacious .Box-body {
41
+ padding: var(--stack-padding-spacious);
42
+ }
43
+ .Box--spacious .Box-footer {
44
+ padding: var(--stack-padding-spacious);
45
+ }
46
+ .btn-octicon:is(.Box--spacious .Box-btn-octicon) {
47
+ padding: var(--stack-padding-spacious);
48
+ margin: calc(var(--stack-gap-spacious) * -1);
49
+ }
50
+ .Box--spacious .Box-row {
51
+ padding: var(--stack-padding-spacious);
52
+ }
53
+ .Box-header {
54
+ padding: var(--stack-padding-normal);
55
+ margin: calc(var(--borderWidth-thin) * -1) calc(var(--borderWidth-thin) * -1) 0;
56
+ background-color: var(--bgColor-muted);
57
+ border-color: var(--borderColor-default);
58
+ border-style: solid;
59
+ border-width: var(--borderWidth-thin);
60
+ border-top-left-radius: var(--borderRadius-medium);
61
+ border-top-right-radius: var(--borderRadius-medium);
62
+ }
63
+ .Box-title {
64
+ font-size: var(--text-body-size-medium);
65
+ font-weight: var(--base-text-weight-semibold);
66
+ }
67
+ .Box-body {
68
+ padding: var(--stack-padding-normal);
69
+ border-bottom: var(--borderWidth-thin) solid var(--borderColor-default);
70
+
71
+ /* Ensures bottom-border doesn't poke out when .Box-body used without box-footer */
72
+ }
73
+ .Box-body:last-of-type {
74
+ margin-bottom: calc(var(--borderWidth-thin) * -1);
75
+ border-bottom-right-radius: var(--borderRadius-medium);
76
+ border-bottom-left-radius: var(--borderRadius-medium);
77
+ }
78
+ /* Box rows */
79
+ .Box-row {
80
+ padding: var(--stack-padding-normal);
81
+ margin-top: calc(var(--borderWidth-thin) * -1);
82
+ list-style-type: none; /* To account for applying Box component to a list */
83
+ border-top-color: var(--borderColor-muted);
84
+ border-top-style: solid;
85
+ border-top-width: var(--borderWidth-thin);
86
+ }
87
+ .Box-row:first-of-type {
88
+ border-top-left-radius: var(--borderRadius-medium);
89
+ border-top-right-radius: var(--borderRadius-medium);
90
+ }
91
+ .Box-row:last-of-type {
92
+ border-bottom-right-radius: var(--borderRadius-medium);
93
+ border-bottom-left-radius: var(--borderRadius-medium);
94
+ }
95
+ /* Adds a blue vertical line to the left of the row
96
+ ** For indicating a row item is unread */
97
+ .Box-row.Box-row--unread,.Box-row.unread {
98
+ /* stylelint-disable-next-line primer/box-shadow */
99
+ box-shadow: inset 2px 0 0 var(--borderColor-accent-emphasis);
100
+ }
101
+ /* Focus styles for when drag icon */
102
+ .Box-row.navigation-focus .Box-row--drag-button {
103
+ color: var(--fgColor-accent);
104
+ cursor: grab;
105
+ opacity: 100;
106
+ }
107
+ /* Grabbing while row is dragged */
108
+ .Box-row.navigation-focus.is-dragging .Box-row--drag-button {
109
+ cursor: grabbing;
110
+ }
111
+ /* Row dragging styles */
112
+ .Box-row.navigation-focus.sortable-chosen {
113
+ background-color: var(--bgColor-muted);
114
+ }
115
+ /* Makes dragging row background gray */
116
+ .Box-row.navigation-focus.sortable-ghost {
117
+ background-color: var(--bgColor-muted);
118
+
119
+ /* Hides contents of row while dragging so row looks solid gray */
120
+ }
121
+ .Box-row.navigation-focus.sortable-ghost .Box-row--drag-hide {
122
+ opacity: 0;
123
+ }
124
+ .Box-row--focus-gray.navigation-focus {
125
+ background-color: var(--bgColor-muted);
126
+ }
127
+ .Box-row--focus-blue.navigation-focus {
128
+ background-color: var(--bgColor-accent-muted);
129
+ }
130
+ .Box-row--hover-gray:hover {
131
+ background-color: var(--bgColor-muted);
132
+ }
133
+ .Box-row--hover-blue:hover {
134
+ background-color: var(--bgColor-accent-muted);
135
+ }
136
+ /* Optional link style
137
+ ** Makes links on mobile blue since they don't have hover state,
138
+ ** and links are dark-gray with blue hover on desktop. */
139
+ @media (min-width: 768px) {
140
+ .Box-row-link {
141
+ color: var(--fgColor-default);
142
+ -webkit-text-decoration: none;
143
+ text-decoration: none;
144
+ }
145
+
146
+ .Box-row-link:hover {
147
+ color: var(--fgColor-accent);
148
+ -webkit-text-decoration: none;
149
+ text-decoration: none;
150
+ }
151
+ }
152
+ /* Optional drag icon styles for reordering items
153
+ ** Focus styles included in .Box-row above */
154
+ .Box-row--drag-button {
155
+ opacity: 0;
156
+ }
157
+ .Box-footer {
158
+ padding: var(--stack-padding-normal);
159
+ margin-top: calc(var(--borderWidth-thin) * -1); /* prevents double border when used with .Box-body */
160
+ border-top-color: var(--borderColor-default);
161
+ border-top-style: solid;
162
+ border-top-width: var(--borderWidth-thin);
163
+ border-radius: 0 0 var(--borderRadius-medium) var(--borderRadius-medium);
164
+ }
165
+ /* Option for a box with scrolling content */
166
+ .Box--scrollable {
167
+ max-height: 324px;
168
+ overflow: scroll;
169
+ }
170
+ /* Box themes */
171
+ .Box--blue {
172
+ border-color: var(--borderColor-accent-muted);
173
+ }
174
+ .Box--blue .Box-header {
175
+ background-color: var(--bgColor-accent-muted);
176
+ border-color: var(--borderColor-accent-muted);
177
+ }
178
+ .Box--blue .Box-body {
179
+ border-color: var(--borderColor-accent-muted);
180
+ }
181
+ .Box--blue .Box-row {
182
+ border-color: var(--borderColor-accent-muted);
183
+ }
184
+ .Box--blue .Box-footer {
185
+ border-color: var(--borderColor-accent-muted);
186
+ }
187
+ /* Applies and red border to the outside of the box,
188
+ ** but not to the border separating rows. */
189
+ .Box--danger {
190
+ border-color: var(--borderColor-danger-emphasis);
191
+ }
192
+ :is(.Box--danger .Box-row):first-of-type {
193
+ border-color: var(--borderColor-danger-emphasis);
194
+ }
195
+ :is(.Box--danger .Box-body):last-of-type {
196
+ border-color: var(--borderColor-danger-emphasis);
197
+ }
198
+ .Box-header--blue {
199
+ background-color: var(--bgColor-accent-muted);
200
+ border-color: var(--borderColor-accent-muted);
201
+ }
202
+ /* Box row highlight themes */
203
+ .Box-row--yellow {
204
+ background-color: var(--bgColor-attention-muted);
205
+ }
206
+ .Box-row--blue {
207
+ background-color: var(--bgColor-accent-muted);
208
+ }
209
+ .Box-row--gray {
210
+ background-color: var(--bgColor-muted);
211
+ }
212
+ /* Box with btn-octicon */
213
+ /* Increase specificity when btn-octicon is used because comes after .Box in the cascade */
214
+ .Box-btn-octicon.btn-octicon {
215
+ padding: var(--control-medium-paddingInline-spacious);
216
+ margin: calc(var(--controlStack-small-gap-spacious) * -1);
217
+ line-height: var(--text-title-lineHeight-large); /* override btn-octicon line-height */
218
+ }
@@ -0,0 +1,54 @@
1
+ {
2
+ "name": "beta/border_box",
3
+ "selectors": [
4
+ ".Box",
5
+ ".Box--condensed",
6
+ ".Box--condensed .Box-header",
7
+ ".Box--condensed .Box-body",
8
+ ".Box--condensed .Box-footer",
9
+ ".btn-octicon:is(.Box--condensed .Box-btn-octicon)",
10
+ ".Box--condensed .Box-row",
11
+ ".Box--spacious .Box-header",
12
+ ".Box--spacious .Box-title",
13
+ ".Box--spacious .Box-body",
14
+ ".Box--spacious .Box-footer",
15
+ ".btn-octicon:is(.Box--spacious .Box-btn-octicon)",
16
+ ".Box--spacious .Box-row",
17
+ ".Box-header",
18
+ ".Box-title",
19
+ ".Box-body",
20
+ ".Box-body:last-of-type",
21
+ ".Box-row",
22
+ ".Box-row:first-of-type",
23
+ ".Box-row:last-of-type",
24
+ ".Box-row.Box-row--unread",
25
+ ".Box-row.unread",
26
+ ".Box-row.navigation-focus .Box-row--drag-button",
27
+ ".Box-row.navigation-focus.is-dragging .Box-row--drag-button",
28
+ ".Box-row.navigation-focus.sortable-chosen",
29
+ ".Box-row.navigation-focus.sortable-ghost",
30
+ ".Box-row.navigation-focus.sortable-ghost .Box-row--drag-hide",
31
+ ".Box-row--focus-gray.navigation-focus",
32
+ ".Box-row--focus-blue.navigation-focus",
33
+ ".Box-row--hover-gray:hover",
34
+ ".Box-row--hover-blue:hover",
35
+ ".Box-row-link",
36
+ ".Box-row-link:hover",
37
+ ".Box-row--drag-button",
38
+ ".Box-footer",
39
+ ".Box--scrollable",
40
+ ".Box--blue",
41
+ ".Box--blue .Box-header",
42
+ ".Box--blue .Box-body",
43
+ ".Box--blue .Box-row",
44
+ ".Box--blue .Box-footer",
45
+ ".Box--danger",
46
+ ":is(.Box--danger .Box-row):first-of-type",
47
+ ":is(.Box--danger .Box-body):last-of-type",
48
+ ".Box-header--blue",
49
+ ".Box-row--yellow",
50
+ ".Box-row--blue",
51
+ ".Box-row--gray",
52
+ ".Box-btn-octicon.btn-octicon"
53
+ ]
54
+ }
@@ -0,0 +1,29 @@
1
+ .breadcrumb-item {
2
+ display: inline-block;
3
+ list-style: none;
4
+ max-width: 100%;
5
+ }
6
+
7
+ .breadcrumb-item::after {
8
+ display: inline-block;
9
+ height: 0.8em;
10
+ /* stylelint-disable-next-line primer/spacing */
11
+ margin: 0 0.15em 0 0.5em;
12
+ content: '';
13
+ /* stylelint-disable-next-line primer/borders */
14
+ border-right: 0.1em solid var(--borderColor-neutral-emphasis);
15
+ transform: rotate(15deg) translateY(0.0625em);
16
+ }
17
+
18
+ :is(.breadcrumb-item-selected,.breadcrumb-item[aria-current]:not([aria-current='false']))::after {
19
+ content: none;
20
+ }
21
+
22
+ /* stylelint-disable-next-line selector-max-type */
23
+
24
+ .breadcrumb-item-selected a {
25
+ color: var(--fgColor-default);
26
+ -webkit-text-decoration: none !important;
27
+ text-decoration: none !important;
28
+ cursor: default !important;
29
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "name": "beta/breadcrumbs",
3
+ "selectors": [
4
+ ".breadcrumb-item",
5
+ ".breadcrumb-item::after",
6
+ ":is(.breadcrumb-item-selected,.breadcrumb-item[aria-current]:not([aria-current='false']))::after",
7
+ ".breadcrumb-item-selected a"
8
+ ]
9
+ }
@@ -0,0 +1,359 @@
1
+ /* stylelint-disable selector-no-qualifying-type */
2
+ /* stylelint-disable selector-max-type */
3
+ /* stylelint-disable primer/spacing */
4
+ /* CSS for Button */
5
+ /* temporary, pre primitives release */
6
+ :root {
7
+ --duration-fast: 80ms;
8
+ --easing-easeInOut: cubic-bezier(0.65, 0, 0.35, 1);
9
+ }
10
+ /* base button */
11
+ .Button {
12
+ position: relative;
13
+ display: inline-flex;
14
+ min-width: max-content;
15
+ height: var(--control-medium-size);
16
+ padding: 0 var(--control-medium-paddingInline-normal);
17
+ font-size: var(--text-body-size-medium);
18
+ font-weight: var(--base-text-weight-medium);
19
+ color: var(--button-default-fgColor-rest);
20
+ text-align: center;
21
+ cursor: pointer;
22
+ flex-direction: row;
23
+ -webkit-user-select: none;
24
+ user-select: none;
25
+ background-color: transparent;
26
+ border: var(--borderWidth-thin) solid;
27
+ border-color: transparent;
28
+ border-radius: var(--borderRadius-medium);
29
+ transition: var(--duration-fast) var(--easing-easeInOut);
30
+ transition-property: color, fill, background-color, border-color;
31
+ justify-content: space-between;
32
+ align-items: center;
33
+ gap: var(--base-size-4);
34
+
35
+ /* mobile friendly sizing */
36
+ }
37
+ @media (pointer: coarse) {
38
+ :is(.Button::before) {
39
+ position: absolute;
40
+ top: 50%;
41
+ left: 50%;
42
+ width: 100%;
43
+ height: 100%;
44
+ min-height: 48px;
45
+ content: "";
46
+ transform: translateX(-50%) translateY(-50%);
47
+ min-width: 48px;
48
+ }
49
+ }
50
+ /* base states */
51
+ .Button:hover {
52
+ transition-duration: var(--duration-fast);
53
+ }
54
+ .Button:active {
55
+ transition: none;
56
+ }
57
+ .Button:disabled,.Button[aria-disabled='true'] {
58
+ cursor: not-allowed;
59
+ box-shadow: none;
60
+ }
61
+ .Button.Button--iconOnly {
62
+ color: var(--fgColor-muted);
63
+ }
64
+ :is(a.Button,summary.Button):hover {
65
+ -webkit-text-decoration: none;
66
+ text-decoration: none;
67
+ }
68
+ /* wrap grid content to allow trailingAction to lock-right */
69
+ .Button-content {
70
+ flex: 1 0 auto;
71
+ display: grid;
72
+ grid-template-areas: 'leadingVisual text trailingVisual';
73
+ grid-template-columns: min-content minmax(0, auto) min-content;
74
+ align-items: center;
75
+ place-content: center;
76
+
77
+ /* padding-bottom: 1px; optical alignment for firefox */
78
+ }
79
+ .Button-content > :not(:last-child) {
80
+ margin-right: var(--control-medium-gap);
81
+ }
82
+ /* center child elements for fullWidth */
83
+ .Button-content--alignStart {
84
+ justify-content: start;
85
+ }
86
+ /* button child elements */
87
+ /* align svg */
88
+ .Button-visual {
89
+ display: flex;
90
+ pointer-events: none; /* allow click handler to work, avoiding visuals */
91
+ }
92
+ .Button-visual .Counter {
93
+ color: inherit;
94
+ background-color: var(--buttonCounter-default-bgColor-rest);
95
+ }
96
+ .Button-label {
97
+ line-height: var(--text-body-lineHeight-medium);
98
+ white-space: nowrap;
99
+ grid-area: text;
100
+ }
101
+ .Button-leadingVisual {
102
+ grid-area: leadingVisual;
103
+ }
104
+ .Button-leadingVisual svg {
105
+ fill: currentcolor;
106
+ }
107
+ .Button-trailingVisual {
108
+ grid-area: trailingVisual;
109
+ }
110
+ .Button-trailingAction {
111
+ margin-right: calc(var(--base-size-4) * -1);
112
+ }
113
+ /* sizes */
114
+ .Button--small {
115
+ min-width: var(--control-small-size);
116
+ height: var(--control-small-size);
117
+ padding: 0 var(--control-small-paddingInline-condensed);
118
+ font-size: var(--text-body-size-small);
119
+ gap: var(--control-small-gap);
120
+ }
121
+ .Button--small .Button-label {
122
+ line-height: var(--text-body-lineHeight-small);
123
+ }
124
+ :is(.Button--small .Button-content) > :not(:last-child) {
125
+ margin-right: var(--control-small-gap);
126
+ }
127
+ .Button--large {
128
+ height: var(--control-large-size);
129
+ padding: 0 var(--control-large-paddingInline-spacious);
130
+ gap: var(--control-large-gap);
131
+ }
132
+ .Button--large .Button-label {
133
+ line-height: var(--text-body-lineHeight-large);
134
+ }
135
+ :is(.Button--large .Button-content) > :not(:last-child) {
136
+ margin-right: var(--control-large-gap);
137
+ }
138
+ .Button--fullWidth {
139
+ width: 100%;
140
+ }
141
+ /* allow button label text to wrap */
142
+ .Button--labelWrap {
143
+ min-width: fit-content;
144
+ height: unset;
145
+ min-height: var(--control-medium-size);
146
+ }
147
+ .Button--labelWrap .Button-content {
148
+ flex: 1 1 auto;
149
+ align-self: stretch;
150
+ padding-block: calc(var(--control-medium-paddingBlock) - var(--base-size-2));
151
+ }
152
+ .Button--labelWrap .Button-label {
153
+ white-space: unset;
154
+ }
155
+ .Button--labelWrap.Button--small {
156
+ height: unset;
157
+ min-height: var(--control-small-size);
158
+ }
159
+ .Button--labelWrap.Button--small .Button-content {
160
+ padding-block: calc(var(--control-small-paddingBlock) - var(--base-size-2));
161
+ }
162
+ .Button--labelWrap.Button--large {
163
+ height: unset;
164
+ min-height: var(--control-large-size);
165
+ padding-inline: var(--control-large-paddingInline-spacious);
166
+ }
167
+ .Button--labelWrap.Button--large .Button-content {
168
+ padding-block: calc(var(--control-large-paddingBlock) - var(--base-size-2));
169
+ }
170
+ /* variants */
171
+ /* primary */
172
+ .Button--primary {
173
+ color: var(--button-primary-fgColor-rest);
174
+ fill: var(--button-primary-iconColor-rest);
175
+ background-color: var(--button-primary-bgColor-rest);
176
+ border-color: var(--button-primary-borderColor-rest);
177
+ box-shadow: var(--shadow-resting-small, var(--color-btn-primary-shadow));
178
+ }
179
+ .Button--primary.Button--iconOnly {
180
+ color: var(--button-primary-iconColor-rest);
181
+ }
182
+ .Button--primary:hover:not(:disabled,.Button--inactive) {
183
+ background-color: var(--button-primary-bgColor-hover);
184
+ border-color: var(--button-primary-borderColor-hover);
185
+ }
186
+ /* fallback :focus state */
187
+ .Button--primary:focus {
188
+ outline: 2px solid var(--focus-outlineColor);
189
+ outline-offset: -2px;
190
+ box-shadow: inset 0 0 0 3px var(--fgColor-onEmphasis);
191
+
192
+ /* remove fallback :focus if :focus-visible is supported */
193
+ }
194
+ .Button--primary:focus:not(:focus-visible) {
195
+ outline: solid 1px transparent;
196
+ box-shadow: none;
197
+ }
198
+ /* default focus state */
199
+ .Button--primary:focus-visible {
200
+ outline: 2px solid var(--focus-outlineColor);
201
+ outline-offset: -2px;
202
+ box-shadow: inset 0 0 0 3px var(--fgColor-onEmphasis);
203
+ }
204
+ .Button--primary:active:not(:disabled),.Button--primary[aria-pressed='true'] {
205
+ background-color: var(--button-primary-bgColor-active);
206
+ box-shadow: var(--button-primary-shadow-selected);
207
+ }
208
+ .Button--primary:disabled,.Button--primary[aria-disabled='true'] {
209
+ color: var(--button-primary-fgColor-disabled);
210
+ fill: var(--button-primary-fgColor-disabled);
211
+ background-color: var(--button-primary-bgColor-disabled);
212
+ border-color: var(--button-primary-borderColor-disabled);
213
+ }
214
+ .Button--primary .Counter {
215
+ color: inherit;
216
+ background-color: var(--buttonCounter-primary-bgColor-rest);
217
+ }
218
+ /* default (secondary) */
219
+ .Button--secondary {
220
+ color: var(--button-default-fgColor-rest);
221
+ fill: var(--fgColor-muted); /* help this */
222
+ background-color: var(--button-default-bgColor-rest);
223
+ border-color: var(--button-default-borderColor-rest);
224
+ box-shadow: var(--button-default-shadow-resting), var(--button-default-shadow-inset);
225
+ }
226
+ .Button--secondary:hover:not(:disabled,.Button--inactive) {
227
+ background-color: var(--button-default-bgColor-hover);
228
+ border-color: var(--button-default-borderColor-hover);
229
+ }
230
+ .Button--secondary:active:not(:disabled) {
231
+ background-color: var(--button-default-bgColor-active);
232
+ border-color: var(--button-default-borderColor-active);
233
+ }
234
+ .Button--secondary[aria-pressed='true'] {
235
+ background-color: var(--button-default-bgColor-selected);
236
+ box-shadow: var(--shadow-inset);
237
+ }
238
+ .Button--secondary:disabled,.Button--secondary[aria-disabled='true'] {
239
+ color: var(--control-fgColor-disabled);
240
+ fill: var(--control-fgColor-disabled);
241
+ background-color: var(--button-default-bgColor-disabled);
242
+ border-color: var(--button-default-borderColor-disabled);
243
+ }
244
+ .Button--invisible {
245
+ color: var(--button-invisible-fgColor-rest);
246
+ }
247
+ .Button--invisible.Button--iconOnly {
248
+ color: var(--button-invisible-iconColor-rest, var(--color-fg-muted));
249
+ }
250
+ .Button--invisible:hover:not(:disabled,.Button--inactive) {
251
+ background-color: var(--control-transparent-bgColor-hover, var(--color-action-list-item-default-hover-bg));
252
+ }
253
+ .Button--invisible[aria-pressed='true'],.Button--invisible:active:not(:disabled) {
254
+ background-color: var(--button-invisible-bgColor-active);
255
+ }
256
+ .Button--invisible:disabled,.Button--invisible[aria-disabled='true'] {
257
+ color: var(--button-invisible-fgColor-disabled);
258
+ fill: var(--button-invisible-fgColor-disabled);
259
+ background-color: var(--button-invisible-bgColor-disabled);
260
+ border-color: var(--button-invisible-borderColor-disabled);
261
+ }
262
+ /* if button has no visuals, use link blue for text */
263
+ .Button--invisible.Button--invisible-noVisuals .Button-label {
264
+ color: var(--button-invisible-fgColor-rest);
265
+ }
266
+ .Button--invisible .Button-visual {
267
+ color: var(--button-invisible-iconColor-rest, var(--color-fg-muted));
268
+ }
269
+ :is(.Button--invisible .Button-visual) .Counter {
270
+ color: var(--fgColor-default);
271
+ }
272
+ .Button--link {
273
+ display: inline-block;
274
+ min-width: fit-content;
275
+ height: unset;
276
+ padding: 0;
277
+ font-size: inherit;
278
+ color: var(--fgColor-link);
279
+ fill: var(--fgColor-link);
280
+ border: none;
281
+ }
282
+ .Button--link:hover:not(:disabled,.Button--inactive) {
283
+ -webkit-text-decoration: underline;
284
+ text-decoration: underline;
285
+ }
286
+ .Button--link:focus-visible,.Button--link:focus {
287
+ outline-offset: 2px;
288
+ }
289
+ .Button--link:disabled,.Button--link[aria-disabled='true'] {
290
+ color: var(--control-fgColor-disabled);
291
+ fill: var(--control-fgColor-disabled);
292
+ background-color: transparent;
293
+ border-color: transparent;
294
+ }
295
+ .Button--link .Button-label {
296
+ white-space: unset;
297
+ }
298
+ /* danger */
299
+ .Button--danger {
300
+ color: var(--button-danger-fgColor-rest);
301
+ fill: var(--button-danger-iconColor-rest);
302
+ background-color: var(--button-danger-bgColor-rest);
303
+ border-color: var(--button-danger-borderColor-rest);
304
+ box-shadow: var(--button-default-shadow-resting), var(--button-default-shadow-inset);
305
+ }
306
+ .Button--danger.Button--iconOnly {
307
+ color: var(--button-danger-iconColor-rest);
308
+ }
309
+ .Button--danger:hover:not(:disabled,.Button--inactive) {
310
+ color: var(--button-danger-fgColor-hover);
311
+ fill: var(--button-danger-fgColor-hover);
312
+ background-color: var(--button-danger-bgColor-hover);
313
+ border-color: var(--button-danger-borderColor-hover);
314
+ box-shadow: var(--shadow-resting-small);
315
+ }
316
+ .Button--danger:hover:not(:disabled,.Button--inactive) .Counter {
317
+ color: var(--buttonCounter-danger-fgColor-hover);
318
+ background-color: var(--buttonCounter-danger-bgColor-hover);
319
+ }
320
+ .Button--danger:active:not(:disabled),.Button--danger[aria-pressed='true'] {
321
+ color: var(--button-danger-fgColor-active);
322
+ fill: var(--button-danger-fgColor-active);
323
+ background-color: var(--button-danger-bgColor-active);
324
+ border-color: var(--button-danger-borderColor-active);
325
+ box-shadow: var(--button-danger-shadow-selected);
326
+ }
327
+ .Button--danger:disabled,.Button--danger[aria-disabled='true'] {
328
+ color: var(--button-danger-fgColor-disabled);
329
+ fill: var(--button-danger-fgColor-disabled);
330
+ background-color: var(--button-danger-bgColor-disabled);
331
+ border-color: var(--button-default-borderColor-disabled);
332
+ }
333
+ :is(.Button--danger:disabled,.Button--danger[aria-disabled='true']) .Counter {
334
+ color: var(--buttonCounter-danger-fgColor-disabled);
335
+ background-color: var(--buttonCounter-danger-bgColor-disabled);
336
+ }
337
+ .Button--danger .Counter {
338
+ color: var(--buttonCounter-danger-fgColor-rest);
339
+ background-color: var(--buttonCounter-danger-bgColor-rest);
340
+ }
341
+ .Button--iconOnly {
342
+ display: inline-grid;
343
+ width: var(--control-medium-size);
344
+ padding: unset;
345
+ place-content: center;
346
+ }
347
+ .Button--iconOnly.Button--small {
348
+ width: var(--control-small-size);
349
+ }
350
+ .Button--iconOnly.Button--large {
351
+ width: var(--control-large-size);
352
+ }
353
+ /* `disabled` takes precedence over `inactive` */
354
+ .Button--inactive:not([aria-disabled='true'], :disabled) {
355
+ color: var(--button-inactive-fgColor);
356
+ cursor: default;
357
+ background-color: var(--button-inactive-bgColor);
358
+ border: 0;
359
+ }