Previews

No matching results.

x
1
2
3
4
5
6
7
8
9
10
11
12
<div class="blankslate-container">
<div data-view-component="true" class="blankslate">
<span data-view-component="true">
<svg style="box-sizing: content-box; color: var(--color-icon-primary);" width="64" height="64" viewBox="0 0 16 16" fill="none" aria-hidden="true" data-view-component="true" class="blankslate-image anim-rotate">
<circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" />
<path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" />
</svg> <span class="sr-only">Loading</span>
</span>
<h2 data-view-component="true" class="blankslate-heading">Mirroring your repository</h2>
<p data-view-component="true">We’re currently mirroring this repository. It should take anywhere from a few minutes to a couple of hours depending on the size of the repository.</p>
</div>
</div>
1
2
3
4
5
render Primer::Beta::Blankslate.new(narrow: narrow, spacious: spacious, border: border) do |component|
component.with_heading(tag: :h2).with_content("Mirroring your repository")
component.with_description { "We’re currently mirroring this repository. It should take anywhere from a few minutes to a couple of hours depending on the size of the repository." }
component.with_visual_spinner(size: :large)
end
Param Description Input

app/components/primer/beta/blankslate.css

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
/* blankslate */
.blankslate-container {
container-type: inline-size;
width: 100%;
}
.blankslate {
--blankslate-outer-padding-block: var(--base-size-32);
--blankslate-outer-padding-inline: var(--base-size-32);
position: relative;
/* stylelint-disable-next-line primer/spacing */
padding: var(--blankslate-outer-padding-block) var(--blankslate-outer-padding-inline);
text-align: center;
/* stylelint-disable-next-line selector-max-type */
}
.blankslate p {
font-size: var(--text-body-size-large);
color: var(--fgColor-muted);
}
/* stylelint-disable-next-line selector-max-type */
.blankslate code {
padding: var(--base-size-2) var(--base-size-4) var(--base-size-4);
font-size: var(--text-body-size-medium);
background: var(--bgColor-default);
border: var(--borderWidth-thin) solid var(--borderColor-muted);
border-radius: var(--borderRadius-medium);
}
/* stylelint-disable-next-line selector-max-type */
.blankslate img {
width: 56px;
height: 56px;
}
.blankslate-icon {
/* stylelint-disable-next-line primer/spacing */
margin-right: var(--control-small-gap);
/* stylelint-disable-next-line primer/spacing */
margin-bottom: var(--stack-gap-condensed);
/* stylelint-disable-next-line primer/spacing */
margin-left: var(--control-small-gap);
color: var(--fgColor-muted);
}
.blankslate-image {
/* stylelint-disable-next-line primer/spacing */
margin-bottom: var(--stack-gap-normal);
}
.blankslate-heading {
margin-bottom: var(--base-size-4);
font-size: var(--text-title-size-medium);
font-weight: var(--text-title-weight-medium);
}
.blankslate-action {
/* stylelint-disable-next-line primer/spacing */
margin-top: var(--stack-gap-normal);
}
.blankslate-action:first-of-type {
/* stylelint-disable-next-line primer/spacing */
margin-top: var(--stack-gap-spacious);
}
.blankslate-action:last-of-type {
/* stylelint-disable-next-line primer/spacing */
margin-bottom: var(--stack-gap-condensed);
}
.blankslate-capped {
border-radius: 0 0 var(--borderRadius-medium) var(--borderRadius-medium);
}
.blankslate-spacious {
--blankslate-outer-padding-block: var(--base-size-80);
--blankslate-outer-padding-inline: var(--base-size-40);
}
.blankslate-narrow {
max-width: 485px;
margin: 0 auto;
}
/* was .large-format
** QUESTION: should we deprecate this? */
/* stylelint-disable-next-line selector-max-type */
.blankslate-large img {
width: 80px;
height: 80px;
}
/* stylelint-disable-next-line selector-max-type */
.blankslate-large h3 {
/* stylelint-disable-next-line primer/spacing */
margin: var(--stack-gap-normal) 0;
/* font-size: $h3-size; // This doesn't actually make the text larger. Should this be $h2-size? */
/* stylelint-disable-next-line primer/typography */
font-size: 24px;
}
/* stylelint-disable-next-line selector-max-type */
.blankslate-large p {
font-size: var(--text-body-size-large);
}
/* was .clean-background
** TO DO: deprecate this and use utility instead */
.blankslate-clean-background {
border: 0;
}
/* At the time these styles were written,
`34rem` was our "small" breakpoint width */
@container (max-width: 34rem) {
.blankslate {
--blankslate-outer-padding-block: var(--base-size-20);
--blankslate-outer-padding-inline: var(--base-size-20);
}
.blankslate-spacious {
--blankslate-outer-padding-block: var(--base-size-44);
--blankslate-outer-padding-inline: var(--base-size-28);
}
.blankslate-icon {
/* stylelint-disable-next-line primer/spacing */
margin-bottom: var(--stack-gap-condensed);
}
.blankslate-heading {
font-size: var(--text-title-size-small);
}
/* stylelint-disable-next-line selector-max-type */
.blankslate p {
font-size: var(--text-body-size-medium);
}
.blankslate-action {
/* stylelint-disable-next-line primer/spacing */
margin-top: var(--stack-gap-condensed);
}
.blankslate-action:first-of-type {
/* stylelint-disable-next-line primer/spacing */
margin-top: var(--stack-gap-normal);
}
.blankslate-action:last-of-type {
/* stylelint-disable-next-line primer/spacing */
margin-bottom: calc(var(--stack-gap-condensed) / 2);
}
}