yoyoyo 0.0.5 → 0.0.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/LICENSE +21 -0
- data/README.md +116 -0
- data/_includes/categories.html +8 -0
- data/_includes/footer.html +3 -0
- data/_includes/head.html +104 -0
- data/_includes/header.html +13 -0
- data/_includes/home-footer.html +3 -0
- data/_includes/home-header.html +4 -0
- data/_includes/home-navigation.html +7 -0
- data/_includes/navigation.html +7 -0
- data/_includes/pagination.html +41 -0
- data/_includes/post-card.html +12 -0
- data/_includes/tags.html +8 -0
- data/_layouts/about.html +6 -0
- data/_layouts/author.html +15 -0
- data/_layouts/default.html +30 -0
- data/_layouts/home.html +22 -0
- data/_layouts/post.html +14 -0
- data/_sass/.DS_Store +0 -0
- data/_sass/_alert.scss +51 -0
- data/_sass/_badge.scss +53 -0
- data/_sass/_breadcrumb.scss +41 -0
- data/_sass/_button-group.scss +163 -0
- data/_sass/_buttons.scss +140 -0
- data/_sass/_card.scss +310 -0
- data/_sass/_carousel.scss +198 -0
- data/_sass/_close.scss +44 -0
- data/_sass/_code.scss +48 -0
- data/_sass/_custom-forms.scss +507 -0
- data/_sass/_dropdown.scss +191 -0
- data/_sass/_forms.scss +334 -0
- data/_sass/_functions.scss +86 -0
- data/_sass/_grid.scss +52 -0
- data/_sass/_images.scss +42 -0
- data/_sass/_input-group.scss +193 -0
- data/_sass/_jumbotron.scss +16 -0
- data/_sass/_list-group.scss +121 -0
- data/_sass/_media.scss +8 -0
- data/_sass/_mixins.scss +41 -0
- data/_sass/_modal.scss +186 -0
- data/_sass/_nav.scss +120 -0
- data/_sass/_navbar.scss +299 -0
- data/_sass/_pagination.scss +78 -0
- data/_sass/_popover.scss +183 -0
- data/_sass/_print.scss +141 -0
- data/_sass/_progress.scss +34 -0
- data/_sass/_reboot.scss +462 -0
- data/_sass/_root.scss +19 -0
- data/_sass/_spinners.scss +53 -0
- data/_sass/_tables.scss +187 -0
- data/_sass/_toasts.scss +43 -0
- data/_sass/_tooltip.scss +115 -0
- data/_sass/_transitions.scss +22 -0
- data/_sass/_type.scss +125 -0
- data/_sass/_utilities.scss +16 -0
- data/_sass/_variables.scss +1091 -0
- data/_sass/body.scss +22 -0
- data/_sass/bootstrap-grid.scss +29 -0
- data/_sass/bootstrap-reboot.scss +12 -0
- data/_sass/bootstrap.scss +44 -0
- data/_sass/header.scss +54 -0
- data/_sass/main.scss +22 -0
- data/_sass/mixins/_alert.scss +13 -0
- data/_sass/mixins/_background-variant.scss +21 -0
- data/_sass/mixins/_badge.scss +11 -0
- data/_sass/mixins/_border-radius.scss +35 -0
- data/_sass/mixins/_box-shadow.scss +5 -0
- data/_sass/mixins/_breakpoints.scss +123 -0
- data/_sass/mixins/_buttons.scss +111 -0
- data/_sass/mixins/_caret.scss +62 -0
- data/_sass/mixins/_clearfix.scss +7 -0
- data/_sass/mixins/_float.scss +11 -0
- data/_sass/mixins/_forms.scss +198 -0
- data/_sass/mixins/_gradients.scss +45 -0
- data/_sass/mixins/_grid-framework.scss +66 -0
- data/_sass/mixins/_grid.scss +51 -0
- data/_sass/mixins/_hover.scss +37 -0
- data/_sass/mixins/_image.scss +36 -0
- data/_sass/mixins/_list-group.scss +21 -0
- data/_sass/mixins/_lists.scss +7 -0
- data/_sass/mixins/_nav-divider.scss +10 -0
- data/_sass/mixins/_pagination.scss +22 -0
- data/_sass/mixins/_reset-text.scss +17 -0
- data/_sass/mixins/_resize.scss +6 -0
- data/_sass/mixins/_screen-reader.scss +33 -0
- data/_sass/mixins/_size.scss +6 -0
- data/_sass/mixins/_table-row.scss +39 -0
- data/_sass/mixins/_text-emphasis.scss +14 -0
- data/_sass/mixins/_text-hide.scss +13 -0
- data/_sass/mixins/_text-truncate.scss +8 -0
- data/_sass/mixins/_transition.scss +16 -0
- data/_sass/mixins/_visibility.scss +7 -0
- data/_sass/utilities/_align.scss +8 -0
- data/_sass/utilities/_background.scss +19 -0
- data/_sass/utilities/_borders.scss +63 -0
- data/_sass/utilities/_clearfix.scss +3 -0
- data/_sass/utilities/_display.scss +38 -0
- data/_sass/utilities/_embed.scss +39 -0
- data/_sass/utilities/_flex.scss +51 -0
- data/_sass/utilities/_float.scss +9 -0
- data/_sass/utilities/_overflow.scss +5 -0
- data/_sass/utilities/_position.scss +32 -0
- data/_sass/utilities/_screenreaders.scss +11 -0
- data/_sass/utilities/_shadows.scss +6 -0
- data/_sass/utilities/_sizing.scss +20 -0
- data/_sass/utilities/_spacing.scss +73 -0
- data/_sass/utilities/_text.scss +67 -0
- data/_sass/utilities/_visibility.scss +11 -0
- data/assets/.DS_Store +0 -0
- data/assets/css/styles.scss +6 -0
- data/assets/images/programming_code.svg +1 -0
- data/assets/images/wxmp.png +0 -0
- data/assets/js/app.js +4504 -0
- data/assets/js/app.js.map +1 -0
- data/assets/ts/app.ts +10 -0
- metadata +117 -2
@@ -0,0 +1,78 @@
|
|
1
|
+
.pagination {
|
2
|
+
display: flex;
|
3
|
+
@include list-unstyled();
|
4
|
+
@include border-radius();
|
5
|
+
}
|
6
|
+
|
7
|
+
.page-link {
|
8
|
+
position: relative;
|
9
|
+
display: block;
|
10
|
+
padding: $pagination-padding-y $pagination-padding-x;
|
11
|
+
margin-left: -$pagination-border-width;
|
12
|
+
line-height: $pagination-line-height;
|
13
|
+
color: $pagination-color;
|
14
|
+
background-color: $pagination-bg;
|
15
|
+
border: $pagination-border-width solid $pagination-border-color;
|
16
|
+
|
17
|
+
&:hover {
|
18
|
+
z-index: 2;
|
19
|
+
color: $pagination-hover-color;
|
20
|
+
text-decoration: none;
|
21
|
+
background-color: $pagination-hover-bg;
|
22
|
+
border-color: $pagination-hover-border-color;
|
23
|
+
}
|
24
|
+
|
25
|
+
&:focus {
|
26
|
+
z-index: 2;
|
27
|
+
outline: $pagination-focus-outline;
|
28
|
+
box-shadow: $pagination-focus-box-shadow;
|
29
|
+
}
|
30
|
+
|
31
|
+
// Opinionated: add "hand" cursor to non-disabled .page-link elements
|
32
|
+
&:not(:disabled):not(.disabled) {
|
33
|
+
cursor: pointer;
|
34
|
+
}
|
35
|
+
}
|
36
|
+
|
37
|
+
.page-item {
|
38
|
+
&:first-child {
|
39
|
+
.page-link {
|
40
|
+
margin-left: 0;
|
41
|
+
@include border-left-radius($border-radius);
|
42
|
+
}
|
43
|
+
}
|
44
|
+
&:last-child {
|
45
|
+
.page-link {
|
46
|
+
@include border-right-radius($border-radius);
|
47
|
+
}
|
48
|
+
}
|
49
|
+
|
50
|
+
&.active .page-link {
|
51
|
+
z-index: 1;
|
52
|
+
color: $pagination-active-color;
|
53
|
+
background-color: $pagination-active-bg;
|
54
|
+
border-color: $pagination-active-border-color;
|
55
|
+
}
|
56
|
+
|
57
|
+
&.disabled .page-link {
|
58
|
+
color: $pagination-disabled-color;
|
59
|
+
pointer-events: none;
|
60
|
+
// Opinionated: remove the "hand" cursor set previously for .page-link
|
61
|
+
cursor: auto;
|
62
|
+
background-color: $pagination-disabled-bg;
|
63
|
+
border-color: $pagination-disabled-border-color;
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
|
68
|
+
//
|
69
|
+
// Sizing
|
70
|
+
//
|
71
|
+
|
72
|
+
.pagination-lg {
|
73
|
+
@include pagination-size($pagination-padding-y-lg, $pagination-padding-x-lg, $font-size-lg, $line-height-lg, $border-radius-lg);
|
74
|
+
}
|
75
|
+
|
76
|
+
.pagination-sm {
|
77
|
+
@include pagination-size($pagination-padding-y-sm, $pagination-padding-x-sm, $font-size-sm, $line-height-sm, $border-radius-sm);
|
78
|
+
}
|
data/_sass/_popover.scss
ADDED
@@ -0,0 +1,183 @@
|
|
1
|
+
.popover {
|
2
|
+
position: absolute;
|
3
|
+
top: 0;
|
4
|
+
left: 0;
|
5
|
+
z-index: $zindex-popover;
|
6
|
+
display: block;
|
7
|
+
max-width: $popover-max-width;
|
8
|
+
// Our parent element can be arbitrary since tooltips are by default inserted as a sibling of their target element.
|
9
|
+
// So reset our font and text properties to avoid inheriting weird values.
|
10
|
+
@include reset-text();
|
11
|
+
font-size: $popover-font-size;
|
12
|
+
// Allow breaking very long words so they don't overflow the popover's bounds
|
13
|
+
word-wrap: break-word;
|
14
|
+
background-color: $popover-bg;
|
15
|
+
background-clip: padding-box;
|
16
|
+
border: $popover-border-width solid $popover-border-color;
|
17
|
+
@include border-radius($popover-border-radius);
|
18
|
+
@include box-shadow($popover-box-shadow);
|
19
|
+
|
20
|
+
.arrow {
|
21
|
+
position: absolute;
|
22
|
+
display: block;
|
23
|
+
width: $popover-arrow-width;
|
24
|
+
height: $popover-arrow-height;
|
25
|
+
margin: 0 $border-radius-lg;
|
26
|
+
|
27
|
+
&::before,
|
28
|
+
&::after {
|
29
|
+
position: absolute;
|
30
|
+
display: block;
|
31
|
+
content: "";
|
32
|
+
border-color: transparent;
|
33
|
+
border-style: solid;
|
34
|
+
}
|
35
|
+
}
|
36
|
+
}
|
37
|
+
|
38
|
+
.bs-popover-top {
|
39
|
+
margin-bottom: $popover-arrow-height;
|
40
|
+
|
41
|
+
.arrow {
|
42
|
+
bottom: calc((#{$popover-arrow-height} + #{$popover-border-width}) * -1);
|
43
|
+
}
|
44
|
+
|
45
|
+
.arrow::before,
|
46
|
+
.arrow::after {
|
47
|
+
border-width: $popover-arrow-height ($popover-arrow-width / 2) 0;
|
48
|
+
}
|
49
|
+
|
50
|
+
.arrow::before {
|
51
|
+
bottom: 0;
|
52
|
+
border-top-color: $popover-arrow-outer-color;
|
53
|
+
}
|
54
|
+
|
55
|
+
.arrow::after {
|
56
|
+
bottom: $popover-border-width;
|
57
|
+
border-top-color: $popover-arrow-color;
|
58
|
+
}
|
59
|
+
}
|
60
|
+
|
61
|
+
.bs-popover-right {
|
62
|
+
margin-left: $popover-arrow-height;
|
63
|
+
|
64
|
+
.arrow {
|
65
|
+
left: calc((#{$popover-arrow-height} + #{$popover-border-width}) * -1);
|
66
|
+
width: $popover-arrow-height;
|
67
|
+
height: $popover-arrow-width;
|
68
|
+
margin: $border-radius-lg 0; // make sure the arrow does not touch the popover's rounded corners
|
69
|
+
}
|
70
|
+
|
71
|
+
.arrow::before,
|
72
|
+
.arrow::after {
|
73
|
+
border-width: ($popover-arrow-width / 2) $popover-arrow-height ($popover-arrow-width / 2) 0;
|
74
|
+
}
|
75
|
+
|
76
|
+
.arrow::before {
|
77
|
+
left: 0;
|
78
|
+
border-right-color: $popover-arrow-outer-color;
|
79
|
+
}
|
80
|
+
|
81
|
+
.arrow::after {
|
82
|
+
left: $popover-border-width;
|
83
|
+
border-right-color: $popover-arrow-color;
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
.bs-popover-bottom {
|
88
|
+
margin-top: $popover-arrow-height;
|
89
|
+
|
90
|
+
.arrow {
|
91
|
+
top: calc((#{$popover-arrow-height} + #{$popover-border-width}) * -1);
|
92
|
+
}
|
93
|
+
|
94
|
+
.arrow::before,
|
95
|
+
.arrow::after {
|
96
|
+
border-width: 0 ($popover-arrow-width / 2) $popover-arrow-height ($popover-arrow-width / 2);
|
97
|
+
}
|
98
|
+
|
99
|
+
.arrow::before {
|
100
|
+
top: 0;
|
101
|
+
border-bottom-color: $popover-arrow-outer-color;
|
102
|
+
}
|
103
|
+
|
104
|
+
.arrow::after {
|
105
|
+
top: $popover-border-width;
|
106
|
+
border-bottom-color: $popover-arrow-color;
|
107
|
+
}
|
108
|
+
|
109
|
+
// This will remove the popover-header's border just below the arrow
|
110
|
+
.popover-header::before {
|
111
|
+
position: absolute;
|
112
|
+
top: 0;
|
113
|
+
left: 50%;
|
114
|
+
display: block;
|
115
|
+
width: $popover-arrow-width;
|
116
|
+
margin-left: -$popover-arrow-width / 2;
|
117
|
+
content: "";
|
118
|
+
border-bottom: $popover-border-width solid $popover-header-bg;
|
119
|
+
}
|
120
|
+
}
|
121
|
+
|
122
|
+
.bs-popover-left {
|
123
|
+
margin-right: $popover-arrow-height;
|
124
|
+
|
125
|
+
.arrow {
|
126
|
+
right: calc((#{$popover-arrow-height} + #{$popover-border-width}) * -1);
|
127
|
+
width: $popover-arrow-height;
|
128
|
+
height: $popover-arrow-width;
|
129
|
+
margin: $border-radius-lg 0; // make sure the arrow does not touch the popover's rounded corners
|
130
|
+
}
|
131
|
+
|
132
|
+
.arrow::before,
|
133
|
+
.arrow::after {
|
134
|
+
border-width: ($popover-arrow-width / 2) 0 ($popover-arrow-width / 2) $popover-arrow-height;
|
135
|
+
}
|
136
|
+
|
137
|
+
.arrow::before {
|
138
|
+
right: 0;
|
139
|
+
border-left-color: $popover-arrow-outer-color;
|
140
|
+
}
|
141
|
+
|
142
|
+
.arrow::after {
|
143
|
+
right: $popover-border-width;
|
144
|
+
border-left-color: $popover-arrow-color;
|
145
|
+
}
|
146
|
+
}
|
147
|
+
|
148
|
+
.bs-popover-auto {
|
149
|
+
&[x-placement^="top"] {
|
150
|
+
@extend .bs-popover-top;
|
151
|
+
}
|
152
|
+
&[x-placement^="right"] {
|
153
|
+
@extend .bs-popover-right;
|
154
|
+
}
|
155
|
+
&[x-placement^="bottom"] {
|
156
|
+
@extend .bs-popover-bottom;
|
157
|
+
}
|
158
|
+
&[x-placement^="left"] {
|
159
|
+
@extend .bs-popover-left;
|
160
|
+
}
|
161
|
+
}
|
162
|
+
|
163
|
+
|
164
|
+
// Offset the popover to account for the popover arrow
|
165
|
+
.popover-header {
|
166
|
+
padding: $popover-header-padding-y $popover-header-padding-x;
|
167
|
+
margin-bottom: 0; // Reset the default from Reboot
|
168
|
+
font-size: $font-size-base;
|
169
|
+
color: $popover-header-color;
|
170
|
+
background-color: $popover-header-bg;
|
171
|
+
border-bottom: $popover-border-width solid darken($popover-header-bg, 5%);
|
172
|
+
$offset-border-width: calc(#{$border-radius-lg} - #{$popover-border-width});
|
173
|
+
@include border-top-radius($offset-border-width);
|
174
|
+
|
175
|
+
&:empty {
|
176
|
+
display: none;
|
177
|
+
}
|
178
|
+
}
|
179
|
+
|
180
|
+
.popover-body {
|
181
|
+
padding: $popover-body-padding-y $popover-body-padding-x;
|
182
|
+
color: $popover-body-color;
|
183
|
+
}
|
data/_sass/_print.scss
ADDED
@@ -0,0 +1,141 @@
|
|
1
|
+
// stylelint-disable declaration-no-important, selector-no-qualifying-type
|
2
|
+
|
3
|
+
// Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css
|
4
|
+
|
5
|
+
// ==========================================================================
|
6
|
+
// Print styles.
|
7
|
+
// Inlined to avoid the additional HTTP request:
|
8
|
+
// https://www.phpied.com/delay-loading-your-print-css/
|
9
|
+
// ==========================================================================
|
10
|
+
|
11
|
+
@if $enable-print-styles {
|
12
|
+
@media print {
|
13
|
+
*,
|
14
|
+
*::before,
|
15
|
+
*::after {
|
16
|
+
// Bootstrap specific; comment out `color` and `background`
|
17
|
+
//color: $black !important; // Black prints faster
|
18
|
+
text-shadow: none !important;
|
19
|
+
//background: transparent !important;
|
20
|
+
box-shadow: none !important;
|
21
|
+
}
|
22
|
+
|
23
|
+
a {
|
24
|
+
&:not(.btn) {
|
25
|
+
text-decoration: underline;
|
26
|
+
}
|
27
|
+
}
|
28
|
+
|
29
|
+
// Bootstrap specific; comment the following selector out
|
30
|
+
//a[href]::after {
|
31
|
+
// content: " (" attr(href) ")";
|
32
|
+
//}
|
33
|
+
|
34
|
+
abbr[title]::after {
|
35
|
+
content: " (" attr(title) ")";
|
36
|
+
}
|
37
|
+
|
38
|
+
// Bootstrap specific; comment the following selector out
|
39
|
+
//
|
40
|
+
// Don't show links that are fragment identifiers,
|
41
|
+
// or use the `javascript:` pseudo protocol
|
42
|
+
//
|
43
|
+
|
44
|
+
//a[href^="#"]::after,
|
45
|
+
//a[href^="javascript:"]::after {
|
46
|
+
// content: "";
|
47
|
+
//}
|
48
|
+
|
49
|
+
pre {
|
50
|
+
white-space: pre-wrap !important;
|
51
|
+
}
|
52
|
+
pre,
|
53
|
+
blockquote {
|
54
|
+
border: $border-width solid $gray-500; // Bootstrap custom code; using `$border-width` instead of 1px
|
55
|
+
page-break-inside: avoid;
|
56
|
+
}
|
57
|
+
|
58
|
+
//
|
59
|
+
// Printing Tables:
|
60
|
+
// http://css-discuss.incutio.com/wiki/Printing_Tables
|
61
|
+
//
|
62
|
+
|
63
|
+
thead {
|
64
|
+
display: table-header-group;
|
65
|
+
}
|
66
|
+
|
67
|
+
tr,
|
68
|
+
img {
|
69
|
+
page-break-inside: avoid;
|
70
|
+
}
|
71
|
+
|
72
|
+
p,
|
73
|
+
h2,
|
74
|
+
h3 {
|
75
|
+
orphans: 3;
|
76
|
+
widows: 3;
|
77
|
+
}
|
78
|
+
|
79
|
+
h2,
|
80
|
+
h3 {
|
81
|
+
page-break-after: avoid;
|
82
|
+
}
|
83
|
+
|
84
|
+
// Bootstrap specific changes start
|
85
|
+
|
86
|
+
// Specify a size and min-width to make printing closer across browsers.
|
87
|
+
// We don't set margin here because it breaks `size` in Chrome. We also
|
88
|
+
// don't use `!important` on `size` as it breaks in Chrome.
|
89
|
+
@page {
|
90
|
+
size: $print-page-size;
|
91
|
+
}
|
92
|
+
body {
|
93
|
+
min-width: $print-body-min-width !important;
|
94
|
+
}
|
95
|
+
.container {
|
96
|
+
min-width: $print-body-min-width !important;
|
97
|
+
}
|
98
|
+
|
99
|
+
// Bootstrap components
|
100
|
+
.navbar {
|
101
|
+
display: none;
|
102
|
+
}
|
103
|
+
.badge {
|
104
|
+
border: $border-width solid $black;
|
105
|
+
}
|
106
|
+
|
107
|
+
.table {
|
108
|
+
border-collapse: collapse !important;
|
109
|
+
|
110
|
+
td,
|
111
|
+
th {
|
112
|
+
background-color: $white !important;
|
113
|
+
}
|
114
|
+
}
|
115
|
+
|
116
|
+
.table-bordered {
|
117
|
+
th,
|
118
|
+
td {
|
119
|
+
border: 1px solid $gray-300 !important;
|
120
|
+
}
|
121
|
+
}
|
122
|
+
|
123
|
+
.table-dark {
|
124
|
+
color: inherit;
|
125
|
+
|
126
|
+
th,
|
127
|
+
td,
|
128
|
+
thead th,
|
129
|
+
tbody + tbody {
|
130
|
+
border-color: $table-border-color;
|
131
|
+
}
|
132
|
+
}
|
133
|
+
|
134
|
+
.table .thead-dark th {
|
135
|
+
color: inherit;
|
136
|
+
border-color: $table-border-color;
|
137
|
+
}
|
138
|
+
|
139
|
+
// Bootstrap specific changes end
|
140
|
+
}
|
141
|
+
}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
@keyframes progress-bar-stripes {
|
2
|
+
from { background-position: $progress-height 0; }
|
3
|
+
to { background-position: 0 0; }
|
4
|
+
}
|
5
|
+
|
6
|
+
.progress {
|
7
|
+
display: flex;
|
8
|
+
height: $progress-height;
|
9
|
+
overflow: hidden; // force rounded corners by cropping it
|
10
|
+
font-size: $progress-font-size;
|
11
|
+
background-color: $progress-bg;
|
12
|
+
@include border-radius($progress-border-radius);
|
13
|
+
@include box-shadow($progress-box-shadow);
|
14
|
+
}
|
15
|
+
|
16
|
+
.progress-bar {
|
17
|
+
display: flex;
|
18
|
+
flex-direction: column;
|
19
|
+
justify-content: center;
|
20
|
+
color: $progress-bar-color;
|
21
|
+
text-align: center;
|
22
|
+
white-space: nowrap;
|
23
|
+
background-color: $progress-bar-bg;
|
24
|
+
@include transition($progress-bar-transition);
|
25
|
+
}
|
26
|
+
|
27
|
+
.progress-bar-striped {
|
28
|
+
@include gradient-striped();
|
29
|
+
background-size: $progress-height $progress-height;
|
30
|
+
}
|
31
|
+
|
32
|
+
.progress-bar-animated {
|
33
|
+
animation: progress-bar-stripes $progress-bar-animation-timing;
|
34
|
+
}
|
data/_sass/_reboot.scss
ADDED
@@ -0,0 +1,462 @@
|
|
1
|
+
// stylelint-disable at-rule-no-vendor-prefix, declaration-no-important, selector-no-qualifying-type, property-no-vendor-prefix
|
2
|
+
|
3
|
+
// Reboot
|
4
|
+
//
|
5
|
+
// Normalization of HTML elements, manually forked from Normalize.css to remove
|
6
|
+
// styles targeting irrelevant browsers while applying new styles.
|
7
|
+
//
|
8
|
+
// Normalize is licensed MIT. https://github.com/necolas/normalize.css
|
9
|
+
|
10
|
+
|
11
|
+
// Document
|
12
|
+
//
|
13
|
+
// 1. Change from `box-sizing: content-box` so that `width` is not affected by `padding` or `border`.
|
14
|
+
// 2. Change the default font family in all browsers.
|
15
|
+
// 3. Correct the line height in all browsers.
|
16
|
+
// 4. Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.
|
17
|
+
// 5. Change the default tap highlight to be completely transparent in iOS.
|
18
|
+
|
19
|
+
*,
|
20
|
+
*::before,
|
21
|
+
*::after {
|
22
|
+
box-sizing: border-box; // 1
|
23
|
+
}
|
24
|
+
|
25
|
+
html {
|
26
|
+
font-family: sans-serif; // 2
|
27
|
+
line-height: 1.15; // 3
|
28
|
+
-webkit-text-size-adjust: 100%; // 4
|
29
|
+
-webkit-tap-highlight-color: rgba($black, 0); // 5
|
30
|
+
}
|
31
|
+
|
32
|
+
// Shim for "new" HTML5 structural elements to display correctly (IE10, older browsers)
|
33
|
+
// TODO: remove in v5
|
34
|
+
// stylelint-disable-next-line selector-list-comma-newline-after
|
35
|
+
article, aside, figcaption, figure, footer, header, hgroup, main, nav, section {
|
36
|
+
display: block;
|
37
|
+
}
|
38
|
+
|
39
|
+
// Body
|
40
|
+
//
|
41
|
+
// 1. Remove the margin in all browsers.
|
42
|
+
// 2. As a best practice, apply a default `background-color`.
|
43
|
+
// 3. Set an explicit initial text-align value so that we can later use
|
44
|
+
// the `inherit` value on things like `<th>` elements.
|
45
|
+
|
46
|
+
body {
|
47
|
+
margin: 0; // 1
|
48
|
+
font-family: $font-family-base;
|
49
|
+
font-size: $font-size-base;
|
50
|
+
font-weight: $font-weight-base;
|
51
|
+
line-height: $line-height-base;
|
52
|
+
color: $body-color;
|
53
|
+
text-align: left; // 3
|
54
|
+
background-color: $body-bg; // 2
|
55
|
+
}
|
56
|
+
|
57
|
+
// Suppress the focus outline on elements that cannot be accessed via keyboard.
|
58
|
+
// This prevents an unwanted focus outline from appearing around elements that
|
59
|
+
// might still respond to pointer events.
|
60
|
+
//
|
61
|
+
// Credit: https://github.com/suitcss/base
|
62
|
+
[tabindex="-1"]:focus {
|
63
|
+
outline: 0 !important;
|
64
|
+
}
|
65
|
+
|
66
|
+
|
67
|
+
// Content grouping
|
68
|
+
//
|
69
|
+
// 1. Add the correct box sizing in Firefox.
|
70
|
+
// 2. Show the overflow in Edge and IE.
|
71
|
+
|
72
|
+
hr {
|
73
|
+
box-sizing: content-box; // 1
|
74
|
+
height: 0; // 1
|
75
|
+
overflow: visible; // 2
|
76
|
+
}
|
77
|
+
|
78
|
+
|
79
|
+
//
|
80
|
+
// Typography
|
81
|
+
//
|
82
|
+
|
83
|
+
// Remove top margins from headings
|
84
|
+
//
|
85
|
+
// By default, `<h1>`-`<h6>` all receive top and bottom margins. We nuke the top
|
86
|
+
// margin for easier control within type scales as it avoids margin collapsing.
|
87
|
+
// stylelint-disable-next-line selector-list-comma-newline-after
|
88
|
+
h1, h2, h3, h4, h5, h6 {
|
89
|
+
margin-top: 0;
|
90
|
+
margin-bottom: $headings-margin-bottom;
|
91
|
+
}
|
92
|
+
|
93
|
+
// Reset margins on paragraphs
|
94
|
+
//
|
95
|
+
// Similarly, the top margin on `<p>`s get reset. However, we also reset the
|
96
|
+
// bottom margin to use `rem` units instead of `em`.
|
97
|
+
p {
|
98
|
+
margin-top: 0;
|
99
|
+
margin-bottom: $paragraph-margin-bottom;
|
100
|
+
}
|
101
|
+
|
102
|
+
// Abbreviations
|
103
|
+
//
|
104
|
+
// 1. Duplicate behavior to the data-* attribute for our tooltip plugin
|
105
|
+
// 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
|
106
|
+
// 3. Add explicit cursor to indicate changed behavior.
|
107
|
+
// 4. Remove the bottom border in Firefox 39-.
|
108
|
+
// 5. Prevent the text-decoration to be skipped.
|
109
|
+
|
110
|
+
abbr[title],
|
111
|
+
abbr[data-original-title] { // 1
|
112
|
+
text-decoration: underline; // 2
|
113
|
+
text-decoration: underline dotted; // 2
|
114
|
+
cursor: help; // 3
|
115
|
+
border-bottom: 0; // 4
|
116
|
+
text-decoration-skip-ink: none; // 5
|
117
|
+
}
|
118
|
+
|
119
|
+
address {
|
120
|
+
margin-bottom: 1rem;
|
121
|
+
font-style: normal;
|
122
|
+
line-height: inherit;
|
123
|
+
}
|
124
|
+
|
125
|
+
ol,
|
126
|
+
ul,
|
127
|
+
dl {
|
128
|
+
margin-top: 0;
|
129
|
+
margin-bottom: 1rem;
|
130
|
+
}
|
131
|
+
|
132
|
+
ol ol,
|
133
|
+
ul ul,
|
134
|
+
ol ul,
|
135
|
+
ul ol {
|
136
|
+
margin-bottom: 0;
|
137
|
+
}
|
138
|
+
|
139
|
+
dt {
|
140
|
+
font-weight: $dt-font-weight;
|
141
|
+
}
|
142
|
+
|
143
|
+
dd {
|
144
|
+
margin-bottom: .5rem;
|
145
|
+
margin-left: 0; // Undo browser default
|
146
|
+
}
|
147
|
+
|
148
|
+
blockquote {
|
149
|
+
margin: 0 0 1rem;
|
150
|
+
}
|
151
|
+
|
152
|
+
b,
|
153
|
+
strong {
|
154
|
+
font-weight: $font-weight-bolder; // Add the correct font weight in Chrome, Edge, and Safari
|
155
|
+
}
|
156
|
+
|
157
|
+
small {
|
158
|
+
font-size: 80%; // Add the correct font size in all browsers
|
159
|
+
}
|
160
|
+
|
161
|
+
//
|
162
|
+
// Prevent `sub` and `sup` elements from affecting the line height in
|
163
|
+
// all browsers.
|
164
|
+
//
|
165
|
+
|
166
|
+
sub,
|
167
|
+
sup {
|
168
|
+
position: relative;
|
169
|
+
font-size: 75%;
|
170
|
+
line-height: 0;
|
171
|
+
vertical-align: baseline;
|
172
|
+
}
|
173
|
+
|
174
|
+
sub { bottom: -.25em; }
|
175
|
+
sup { top: -.5em; }
|
176
|
+
|
177
|
+
|
178
|
+
//
|
179
|
+
// Links
|
180
|
+
//
|
181
|
+
|
182
|
+
a {
|
183
|
+
color: $link-color;
|
184
|
+
text-decoration: $link-decoration;
|
185
|
+
background-color: transparent; // Remove the gray background on active links in IE 10.
|
186
|
+
|
187
|
+
@include hover {
|
188
|
+
color: $link-hover-color;
|
189
|
+
text-decoration: $link-hover-decoration;
|
190
|
+
}
|
191
|
+
}
|
192
|
+
|
193
|
+
// And undo these styles for placeholder links/named anchors (without href)
|
194
|
+
// which have not been made explicitly keyboard-focusable (without tabindex).
|
195
|
+
// It would be more straightforward to just use a[href] in previous block, but that
|
196
|
+
// causes specificity issues in many other styles that are too complex to fix.
|
197
|
+
// See https://github.com/twbs/bootstrap/issues/19402
|
198
|
+
|
199
|
+
a:not([href]):not([tabindex]) {
|
200
|
+
color: inherit;
|
201
|
+
text-decoration: none;
|
202
|
+
|
203
|
+
@include hover-focus {
|
204
|
+
color: inherit;
|
205
|
+
text-decoration: none;
|
206
|
+
}
|
207
|
+
|
208
|
+
&:focus {
|
209
|
+
outline: 0;
|
210
|
+
}
|
211
|
+
}
|
212
|
+
|
213
|
+
|
214
|
+
//
|
215
|
+
// Code
|
216
|
+
//
|
217
|
+
|
218
|
+
pre,
|
219
|
+
code,
|
220
|
+
kbd,
|
221
|
+
samp {
|
222
|
+
font-family: $font-family-monospace;
|
223
|
+
font-size: 1em; // Correct the odd `em` font sizing in all browsers.
|
224
|
+
}
|
225
|
+
|
226
|
+
pre {
|
227
|
+
// Remove browser default top margin
|
228
|
+
margin-top: 0;
|
229
|
+
// Reset browser default of `1em` to use `rem`s
|
230
|
+
margin-bottom: 1rem;
|
231
|
+
// Don't allow content to break outside
|
232
|
+
overflow: auto;
|
233
|
+
}
|
234
|
+
|
235
|
+
|
236
|
+
//
|
237
|
+
// Figures
|
238
|
+
//
|
239
|
+
|
240
|
+
figure {
|
241
|
+
// Apply a consistent margin strategy (matches our type styles).
|
242
|
+
margin: 0 0 1rem;
|
243
|
+
}
|
244
|
+
|
245
|
+
|
246
|
+
//
|
247
|
+
// Images and content
|
248
|
+
//
|
249
|
+
|
250
|
+
img {
|
251
|
+
vertical-align: middle;
|
252
|
+
border-style: none; // Remove the border on images inside links in IE 10-.
|
253
|
+
}
|
254
|
+
|
255
|
+
svg {
|
256
|
+
// Workaround for the SVG overflow bug in IE10/11 is still required.
|
257
|
+
// See https://github.com/twbs/bootstrap/issues/26878
|
258
|
+
overflow: hidden;
|
259
|
+
vertical-align: middle;
|
260
|
+
}
|
261
|
+
|
262
|
+
|
263
|
+
//
|
264
|
+
// Tables
|
265
|
+
//
|
266
|
+
|
267
|
+
table {
|
268
|
+
border-collapse: collapse; // Prevent double borders
|
269
|
+
}
|
270
|
+
|
271
|
+
caption {
|
272
|
+
padding-top: $table-cell-padding;
|
273
|
+
padding-bottom: $table-cell-padding;
|
274
|
+
color: $table-caption-color;
|
275
|
+
text-align: left;
|
276
|
+
caption-side: bottom;
|
277
|
+
}
|
278
|
+
|
279
|
+
th {
|
280
|
+
// Matches default `<td>` alignment by inheriting from the `<body>`, or the
|
281
|
+
// closest parent with a set `text-align`.
|
282
|
+
text-align: inherit;
|
283
|
+
}
|
284
|
+
|
285
|
+
|
286
|
+
//
|
287
|
+
// Forms
|
288
|
+
//
|
289
|
+
|
290
|
+
label {
|
291
|
+
// Allow labels to use `margin` for spacing.
|
292
|
+
display: inline-block;
|
293
|
+
margin-bottom: $label-margin-bottom;
|
294
|
+
}
|
295
|
+
|
296
|
+
// Remove the default `border-radius` that macOS Chrome adds.
|
297
|
+
//
|
298
|
+
// Details at https://github.com/twbs/bootstrap/issues/24093
|
299
|
+
button {
|
300
|
+
border-radius: 0;
|
301
|
+
}
|
302
|
+
|
303
|
+
// Work around a Firefox/IE bug where the transparent `button` background
|
304
|
+
// results in a loss of the default `button` focus styles.
|
305
|
+
//
|
306
|
+
// Credit: https://github.com/suitcss/base/
|
307
|
+
button:focus {
|
308
|
+
outline: 1px dotted;
|
309
|
+
outline: 5px auto -webkit-focus-ring-color;
|
310
|
+
}
|
311
|
+
|
312
|
+
input,
|
313
|
+
button,
|
314
|
+
select,
|
315
|
+
optgroup,
|
316
|
+
textarea {
|
317
|
+
margin: 0; // Remove the margin in Firefox and Safari
|
318
|
+
font-family: inherit;
|
319
|
+
font-size: inherit;
|
320
|
+
line-height: inherit;
|
321
|
+
}
|
322
|
+
|
323
|
+
button,
|
324
|
+
input {
|
325
|
+
overflow: visible; // Show the overflow in Edge
|
326
|
+
}
|
327
|
+
|
328
|
+
button,
|
329
|
+
select {
|
330
|
+
text-transform: none; // Remove the inheritance of text transform in Firefox
|
331
|
+
}
|
332
|
+
|
333
|
+
// 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
|
334
|
+
// controls in Android 4.
|
335
|
+
// 2. Correct the inability to style clickable types in iOS and Safari.
|
336
|
+
button,
|
337
|
+
[type="button"], // 1
|
338
|
+
[type="reset"],
|
339
|
+
[type="submit"] {
|
340
|
+
-webkit-appearance: button; // 2
|
341
|
+
}
|
342
|
+
|
343
|
+
// Remove inner border and padding from Firefox, but don't restore the outline like Normalize.
|
344
|
+
button::-moz-focus-inner,
|
345
|
+
[type="button"]::-moz-focus-inner,
|
346
|
+
[type="reset"]::-moz-focus-inner,
|
347
|
+
[type="submit"]::-moz-focus-inner {
|
348
|
+
padding: 0;
|
349
|
+
border-style: none;
|
350
|
+
}
|
351
|
+
|
352
|
+
input[type="radio"],
|
353
|
+
input[type="checkbox"] {
|
354
|
+
box-sizing: border-box; // 1. Add the correct box sizing in IE 10-
|
355
|
+
padding: 0; // 2. Remove the padding in IE 10-
|
356
|
+
}
|
357
|
+
|
358
|
+
|
359
|
+
input[type="date"],
|
360
|
+
input[type="time"],
|
361
|
+
input[type="datetime-local"],
|
362
|
+
input[type="month"] {
|
363
|
+
// Remove the default appearance of temporal inputs to avoid a Mobile Safari
|
364
|
+
// bug where setting a custom line-height prevents text from being vertically
|
365
|
+
// centered within the input.
|
366
|
+
// See https://bugs.webkit.org/show_bug.cgi?id=139848
|
367
|
+
// and https://github.com/twbs/bootstrap/issues/11266
|
368
|
+
-webkit-appearance: listbox;
|
369
|
+
}
|
370
|
+
|
371
|
+
textarea {
|
372
|
+
overflow: auto; // Remove the default vertical scrollbar in IE.
|
373
|
+
// Textareas should really only resize vertically so they don't break their (horizontal) containers.
|
374
|
+
resize: vertical;
|
375
|
+
}
|
376
|
+
|
377
|
+
fieldset {
|
378
|
+
// Browsers set a default `min-width: min-content;` on fieldsets,
|
379
|
+
// unlike e.g. `<div>`s, which have `min-width: 0;` by default.
|
380
|
+
// So we reset that to ensure fieldsets behave more like a standard block element.
|
381
|
+
// See https://github.com/twbs/bootstrap/issues/12359
|
382
|
+
// and https://html.spec.whatwg.org/multipage/#the-fieldset-and-legend-elements
|
383
|
+
min-width: 0;
|
384
|
+
// Reset the default outline behavior of fieldsets so they don't affect page layout.
|
385
|
+
padding: 0;
|
386
|
+
margin: 0;
|
387
|
+
border: 0;
|
388
|
+
}
|
389
|
+
|
390
|
+
// 1. Correct the text wrapping in Edge and IE.
|
391
|
+
// 2. Correct the color inheritance from `fieldset` elements in IE.
|
392
|
+
legend {
|
393
|
+
display: block;
|
394
|
+
width: 100%;
|
395
|
+
max-width: 100%; // 1
|
396
|
+
padding: 0;
|
397
|
+
margin-bottom: .5rem;
|
398
|
+
font-size: 1.5rem;
|
399
|
+
line-height: inherit;
|
400
|
+
color: inherit; // 2
|
401
|
+
white-space: normal; // 1
|
402
|
+
}
|
403
|
+
|
404
|
+
progress {
|
405
|
+
vertical-align: baseline; // Add the correct vertical alignment in Chrome, Firefox, and Opera.
|
406
|
+
}
|
407
|
+
|
408
|
+
// Correct the cursor style of increment and decrement buttons in Chrome.
|
409
|
+
[type="number"]::-webkit-inner-spin-button,
|
410
|
+
[type="number"]::-webkit-outer-spin-button {
|
411
|
+
height: auto;
|
412
|
+
}
|
413
|
+
|
414
|
+
[type="search"] {
|
415
|
+
// This overrides the extra rounded corners on search inputs in iOS so that our
|
416
|
+
// `.form-control` class can properly style them. Note that this cannot simply
|
417
|
+
// be added to `.form-control` as it's not specific enough. For details, see
|
418
|
+
// https://github.com/twbs/bootstrap/issues/11586.
|
419
|
+
outline-offset: -2px; // 2. Correct the outline style in Safari.
|
420
|
+
-webkit-appearance: none;
|
421
|
+
}
|
422
|
+
|
423
|
+
//
|
424
|
+
// Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
|
425
|
+
//
|
426
|
+
|
427
|
+
[type="search"]::-webkit-search-decoration {
|
428
|
+
-webkit-appearance: none;
|
429
|
+
}
|
430
|
+
|
431
|
+
//
|
432
|
+
// 1. Correct the inability to style clickable types in iOS and Safari.
|
433
|
+
// 2. Change font properties to `inherit` in Safari.
|
434
|
+
//
|
435
|
+
|
436
|
+
::-webkit-file-upload-button {
|
437
|
+
font: inherit; // 2
|
438
|
+
-webkit-appearance: button; // 1
|
439
|
+
}
|
440
|
+
|
441
|
+
//
|
442
|
+
// Correct element displays
|
443
|
+
//
|
444
|
+
|
445
|
+
output {
|
446
|
+
display: inline-block;
|
447
|
+
}
|
448
|
+
|
449
|
+
summary {
|
450
|
+
display: list-item; // Add the correct display in all browsers
|
451
|
+
cursor: pointer;
|
452
|
+
}
|
453
|
+
|
454
|
+
template {
|
455
|
+
display: none; // Add the correct display in IE
|
456
|
+
}
|
457
|
+
|
458
|
+
// Always hide an element with the `hidden` HTML attribute (from PureCSS).
|
459
|
+
// Needed for proper display in IE 10-.
|
460
|
+
[hidden] {
|
461
|
+
display: none !important;
|
462
|
+
}
|