@progress/kendo-theme-default 5.6.1-dev.3 → 5.6.1-dev.6
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.
- package/dist/all.css +91 -144
- package/dist/all.scss +125 -157
- package/lib/swatches/default-blue.json +1 -1
- package/lib/swatches/default-dataviz-v4.json +1 -1
- package/lib/swatches/default-green.json +1 -1
- package/lib/swatches/default-main-dark.json +1 -1
- package/lib/swatches/default-main.json +1 -1
- package/lib/swatches/default-nordic.json +1 -1
- package/lib/swatches/default-ocean-blue.json +1 -1
- package/lib/swatches/default-orange.json +1 -1
- package/lib/swatches/default-purple.json +1 -1
- package/lib/swatches/default-turquoise.json +1 -1
- package/lib/swatches/default-urban.json +1 -1
- package/package.json +2 -2
- package/scss/badge/_layout.scss +18 -69
- package/scss/badge/_theme.scss +2 -2
- package/scss/badge/_variables.scss +70 -35
- package/scss/calendar/_variables.scss +1 -1
- package/scss/card/_layout.scss +6 -5
- package/scss/card/_theme.scss +8 -20
- package/scss/card/_variables.scss +0 -10
- package/scss/dataviz/_layout.scss +1 -1
- package/scss/popover/_layout.scss +10 -5
- package/scss/popover/_theme.scss +8 -6
- package/scss/popover/_variables.scss +0 -5
- package/scss/utils/_position.scss +3 -0
package/scss/badge/_layout.scss
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
.k-badge {
|
|
4
4
|
padding: 0;
|
|
5
|
-
border-width:
|
|
5
|
+
border-width: $kendo-badge-border-width;
|
|
6
6
|
border-style: solid;
|
|
7
7
|
border-color: transparent;
|
|
8
8
|
box-sizing: border-box;
|
|
@@ -52,74 +52,23 @@
|
|
|
52
52
|
|
|
53
53
|
|
|
54
54
|
// Badge sizes
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
padding: $badge-padding-y-lg $badge-padding-x-lg;
|
|
73
|
-
border-width: $badge-border-width-lg;
|
|
74
|
-
font-size: $badge-font-size-lg;
|
|
75
|
-
line-height: $badge-line-height-lg;
|
|
76
|
-
|
|
77
|
-
&:empty { padding: $badge-padding-y-lg; }
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
// Badge shapes
|
|
82
|
-
.k-badge-rounded {
|
|
83
|
-
&.k-badge-sm { @include border-radius( $badge-border-radius-sm ); }
|
|
84
|
-
&.k-badge-md { @include border-radius( $badge-border-radius ); }
|
|
85
|
-
&.k-badge-lg { @include border-radius( $badge-border-radius-lg ); }
|
|
86
|
-
}
|
|
87
|
-
.k-badge-pill {
|
|
88
|
-
border-radius: 5rem;
|
|
89
|
-
}
|
|
90
|
-
.k-badge-circle {
|
|
91
|
-
padding: 0 !important; // sass-lint:disable-line no-important
|
|
92
|
-
border-radius: 100%;
|
|
93
|
-
|
|
94
|
-
&.k-badge-sm {
|
|
95
|
-
width: $badge-size-sm;
|
|
96
|
-
height: $badge-size-sm;
|
|
97
|
-
}
|
|
98
|
-
&.k-badge-md {
|
|
99
|
-
width: $badge-size;
|
|
100
|
-
height: $badge-size;
|
|
101
|
-
}
|
|
102
|
-
&.k-badge-lg {
|
|
103
|
-
width: $badge-size-lg;
|
|
104
|
-
height: $badge-size-lg;
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
.k-badge-dot {
|
|
108
|
-
padding: 0 !important; // sass-lint:disable-line no-important
|
|
109
|
-
border-radius: 100%;
|
|
110
|
-
font-size: 0;
|
|
111
|
-
|
|
112
|
-
&.k-badge-sm {
|
|
113
|
-
width: $badge-dot-size-sm;
|
|
114
|
-
height: $badge-dot-size-sm;
|
|
115
|
-
}
|
|
116
|
-
&.k-badge-md {
|
|
117
|
-
width: $badge-dot-size;
|
|
118
|
-
height: $badge-dot-size;
|
|
119
|
-
}
|
|
120
|
-
&.k-badge-lg {
|
|
121
|
-
width: $badge-dot-size-lg;
|
|
122
|
-
height: $badge-dot-size-lg;
|
|
55
|
+
@each $size, $size-props in $kendo-badge-sizes {
|
|
56
|
+
$_padding-x: map-get( $size-props, padding-x );
|
|
57
|
+
$_padding-y: map-get( $size-props, padding-y );
|
|
58
|
+
$_font-size: map-get( $size-props, font-size );
|
|
59
|
+
$_line-height: map-get( $size-props, line-height );
|
|
60
|
+
$_min-width: map-get( $size-props, min-width );
|
|
61
|
+
|
|
62
|
+
.k-badge-#{$size} {
|
|
63
|
+
padding: $_padding-y $_padding-x;
|
|
64
|
+
font-size: $_font-size;
|
|
65
|
+
line-height: $_line-height;
|
|
66
|
+
min-width: $_min-width;
|
|
67
|
+
|
|
68
|
+
&:empty {
|
|
69
|
+
padding: $_padding-y;
|
|
70
|
+
min-width: auto;
|
|
71
|
+
}
|
|
123
72
|
}
|
|
124
73
|
}
|
|
125
74
|
|
package/scss/badge/_theme.scss
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
// Solid badges
|
|
4
4
|
@each $name, $color in $kendo-theme-colors {
|
|
5
|
-
.k-badge-solid
|
|
5
|
+
.k-badge-solid-#{$name} {
|
|
6
6
|
border-color: $color;
|
|
7
7
|
color: contrast-wcag( $color );
|
|
8
8
|
background-color: $color;
|
|
@@ -16,7 +16,7 @@
|
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
@each $name, $color in $kendo-theme-colors {
|
|
19
|
-
.k-badge-outline
|
|
19
|
+
.k-badge-outline-#{$name} {
|
|
20
20
|
color: $color;
|
|
21
21
|
}
|
|
22
22
|
}
|
|
@@ -1,36 +1,71 @@
|
|
|
1
1
|
// Badge
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
$badge-border-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
$badge-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
$badge-
|
|
15
|
-
|
|
16
|
-
$badge-padding-x-
|
|
17
|
-
$badge-padding-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
$badge-
|
|
22
|
-
|
|
23
|
-
$badge-
|
|
24
|
-
$badge-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
$badge-
|
|
29
|
-
$badge-
|
|
30
|
-
$
|
|
31
|
-
$badge-
|
|
32
|
-
|
|
33
|
-
$
|
|
34
|
-
|
|
35
|
-
$badge-
|
|
36
|
-
$badge-
|
|
2
|
+
|
|
3
|
+
/// Width of the border around the badge.
|
|
4
|
+
/// @group badge
|
|
5
|
+
$kendo-badge-border-width: 1px !default;
|
|
6
|
+
|
|
7
|
+
/// Border radius of the badge.
|
|
8
|
+
/// @group badge
|
|
9
|
+
$kendo-badge-border-radius: $kendo-border-radius-md !default;
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
/// Horizontal padding of the badge.
|
|
13
|
+
/// @group badge
|
|
14
|
+
$kendo-badge-padding-x: map-get( $spacing, 1 ) !default;
|
|
15
|
+
$kendo-badge-padding-x-sm: map-get( $spacing, 1 ) - map-get( $spacing, thin ) !default;
|
|
16
|
+
$kendo-badge-padding-x-md: map-get( $spacing, 1 ) !default;
|
|
17
|
+
$kendo-badge-padding-x-lg: map-get( $spacing, 1 ) + map-get( $spacing, thin ) !default;
|
|
18
|
+
|
|
19
|
+
/// Vertical padding of the badge.
|
|
20
|
+
/// @group badge
|
|
21
|
+
$kendo-badge-padding-y: map-get( $spacing, 1 ) !default;
|
|
22
|
+
$kendo-badge-padding-y-sm: map-get( $spacing, 1 ) - map-get( $spacing, thin ) !default;
|
|
23
|
+
$kendo-badge-padding-y-md: map-get( $spacing, 1 ) !default;
|
|
24
|
+
$kendo-badge-padding-y-lg: map-get( $spacing, 1 ) + map-get( $spacing, thin ) !default;
|
|
25
|
+
|
|
26
|
+
/// Font sizes of the badge.
|
|
27
|
+
/// @group badge
|
|
28
|
+
$kendo-badge-font-size: $font-size-xs !default;
|
|
29
|
+
$kendo-badge-font-size-sm: $font-size-xs !default;
|
|
30
|
+
$kendo-badge-font-size-md: $font-size-xs !default;
|
|
31
|
+
$kendo-badge-font-size-lg: $font-size-xs !default;
|
|
32
|
+
|
|
33
|
+
/// Line heights used along with $font-size.
|
|
34
|
+
/// @group badge
|
|
35
|
+
$kendo-badge-line-height: 1 !default;
|
|
36
|
+
$kendo-badge-line-height-sm: $kendo-badge-line-height !default;
|
|
37
|
+
$kendo-badge-line-height-md: $kendo-badge-line-height !default;
|
|
38
|
+
$kendo-badge-line-height-lg: $kendo-badge-line-height !default;
|
|
39
|
+
|
|
40
|
+
/// Badge min width used for circle badge.
|
|
41
|
+
/// @group badge
|
|
42
|
+
$kendo-badge-min-width: calc( #{$kendo-badge-line-height * 1em} + #{$kendo-badge-padding-y * 2} + #{$kendo-badge-border-width * 2}) !default;
|
|
43
|
+
$kendo-badge-min-width-sm: calc( #{$kendo-badge-line-height-sm * 1em} + #{$kendo-badge-padding-y-sm * 2} + #{$kendo-badge-border-width * 2} ) !default;
|
|
44
|
+
$kendo-badge-min-width-md: calc( #{$kendo-badge-line-height-md * 1em} + #{$kendo-badge-padding-y-md * 2} + #{$kendo-badge-border-width * 2} ) !default;
|
|
45
|
+
$kendo-badge-min-width-lg: calc( #{$kendo-badge-line-height-lg * 1em} + #{$kendo-badge-padding-y-lg * 2} + #{$kendo-badge-border-width * 2} ) !default;
|
|
46
|
+
|
|
47
|
+
/// Sizes map for the badge.
|
|
48
|
+
/// @group badge
|
|
49
|
+
$kendo-badge-sizes: (
|
|
50
|
+
sm: (
|
|
51
|
+
padding-x: $kendo-badge-padding-x-sm,
|
|
52
|
+
padding-y: $kendo-badge-padding-y-sm,
|
|
53
|
+
font-size: $kendo-badge-font-size-sm,
|
|
54
|
+
line-height: $kendo-badge-line-height-sm,
|
|
55
|
+
min-width: $kendo-badge-min-width-sm
|
|
56
|
+
),
|
|
57
|
+
md: (
|
|
58
|
+
padding-x: $kendo-badge-padding-x-md,
|
|
59
|
+
padding-y: $kendo-badge-padding-y-md,
|
|
60
|
+
font-size: $kendo-badge-font-size-md,
|
|
61
|
+
line-height: $kendo-badge-line-height-md,
|
|
62
|
+
min-width: $kendo-badge-min-width-md
|
|
63
|
+
),
|
|
64
|
+
lg: (
|
|
65
|
+
padding-x: $kendo-badge-padding-x-lg,
|
|
66
|
+
padding-y: $kendo-badge-padding-y-lg,
|
|
67
|
+
font-size: $kendo-badge-font-size-lg,
|
|
68
|
+
line-height: $kendo-badge-line-height-lg,
|
|
69
|
+
min-width: $kendo-badge-min-width-lg
|
|
70
|
+
)
|
|
71
|
+
) !default;
|
|
@@ -28,7 +28,7 @@ $calendar-today-nav-hover-text: $link-hover-text !default;
|
|
|
28
28
|
$calendar-footer-padding-x: map-get( $spacing, 4 ) !default;
|
|
29
29
|
$calendar-footer-padding-y: map-get( $spacing, 2 ) !default;
|
|
30
30
|
|
|
31
|
-
$calendar-cell-padding-x: .
|
|
31
|
+
$calendar-cell-padding-x: .25em !default;
|
|
32
32
|
$calendar-cell-padding-y: $calendar-cell-padding-x !default;
|
|
33
33
|
$calendar-cell-line-height: $calendar-line-height !default;
|
|
34
34
|
$calendar-cell-border-radius: $kendo-border-radius-md !default;
|
package/scss/card/_layout.scss
CHANGED
|
@@ -39,6 +39,7 @@
|
|
|
39
39
|
display: flex;
|
|
40
40
|
flex-direction: inherit;
|
|
41
41
|
overflow: hidden;
|
|
42
|
+
position: relative;
|
|
42
43
|
}
|
|
43
44
|
|
|
44
45
|
|
|
@@ -329,7 +330,7 @@
|
|
|
329
330
|
margin: 0;
|
|
330
331
|
width: $card-callout-width;
|
|
331
332
|
height: $card-callout-height;
|
|
332
|
-
border-width: $card-border-width
|
|
333
|
+
border-width: $card-border-width;
|
|
333
334
|
border-style: solid;
|
|
334
335
|
box-sizing: border-box;
|
|
335
336
|
position: absolute;
|
|
@@ -338,22 +339,22 @@
|
|
|
338
339
|
.k-card-callout.k-callout-n {
|
|
339
340
|
top: 0;
|
|
340
341
|
left: 50%;
|
|
341
|
-
transform: translate(-50%, -50%) rotate(
|
|
342
|
+
transform: translate(-50%, -50%) rotate(45deg);
|
|
342
343
|
}
|
|
343
344
|
.k-card-callout.k-callout-e {
|
|
344
345
|
top: 50%;
|
|
345
346
|
right: 0;
|
|
346
|
-
transform: translate(50%, -50%) rotate(
|
|
347
|
+
transform: translate(50%, -50%) rotate(-45deg);
|
|
347
348
|
}
|
|
348
349
|
.k-card-callout.k-callout-s {
|
|
349
350
|
bottom: 0;
|
|
350
351
|
left: 50%;
|
|
351
|
-
transform: translate(-50%, 50%) rotate(
|
|
352
|
+
transform: translate(-50%, 50%) rotate(45deg);
|
|
352
353
|
}
|
|
353
354
|
.k-card-callout.k-callout-w {
|
|
354
355
|
top: 50%;
|
|
355
356
|
left: 0;
|
|
356
|
-
transform: translate(-50%, -50%) rotate(
|
|
357
|
+
transform: translate(-50%, -50%) rotate(45deg);
|
|
357
358
|
}
|
|
358
359
|
|
|
359
360
|
}
|
package/scss/card/_theme.scss
CHANGED
|
@@ -9,6 +9,11 @@
|
|
|
9
9
|
);
|
|
10
10
|
@include box-shadow( $card-shadow );
|
|
11
11
|
|
|
12
|
+
.k-card-inner {
|
|
13
|
+
background-color: inherit;
|
|
14
|
+
border-color: inherit;
|
|
15
|
+
}
|
|
16
|
+
|
|
12
17
|
&:focus,
|
|
13
18
|
&.k-focus,
|
|
14
19
|
&.k-state-focus {
|
|
@@ -88,28 +93,11 @@
|
|
|
88
93
|
// Card callout
|
|
89
94
|
.k-card-callout {
|
|
90
95
|
@include fill(
|
|
91
|
-
$bg:
|
|
92
|
-
$border:
|
|
93
|
-
);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
.k-card-callout.k-callout-n { @include box-shadow( $card-callout-box-shadow-n ); }
|
|
97
|
-
.k-card-callout.k-callout-e { @include box-shadow( $card-callout-box-shadow-e ); }
|
|
98
|
-
.k-card-callout.k-callout-s { @include box-shadow( $card-callout-box-shadow-s ); }
|
|
99
|
-
.k-card-callout.k-callout-w { @include box-shadow( $card-callout-box-shadow-w ); }
|
|
100
|
-
|
|
101
|
-
.k-card:focus .k-card-callout,
|
|
102
|
-
.k-card.k-focus .k-card-callout,
|
|
103
|
-
.k-card.k-state-focus .k-card-callout {
|
|
104
|
-
@include fill(
|
|
105
|
-
$bg: $card-focus-bg,
|
|
106
|
-
$border: $card-focus-border
|
|
96
|
+
$bg: inherit,
|
|
97
|
+
$border: inherit
|
|
107
98
|
);
|
|
108
99
|
|
|
109
|
-
|
|
110
|
-
&.k-callout-e { @include box-shadow( $card-focus-callout-box-shadow-e ); }
|
|
111
|
-
&.k-callout-s { @include box-shadow( $card-focus-callout-box-shadow-s ); }
|
|
112
|
-
&.k-callout-w { @include box-shadow( $card-focus-callout-box-shadow-w ); }
|
|
100
|
+
@include box-shadow( inherit );
|
|
113
101
|
}
|
|
114
102
|
|
|
115
103
|
}
|
|
@@ -66,13 +66,3 @@ $card-deck-scroll-button-offset: -$kendo-button-border-width !default;
|
|
|
66
66
|
|
|
67
67
|
$card-callout-width: 20px !default;
|
|
68
68
|
$card-callout-height: 20px !default;
|
|
69
|
-
|
|
70
|
-
$card-callout-box-shadow-n: null !default;
|
|
71
|
-
$card-callout-box-shadow-e: null !default;
|
|
72
|
-
$card-callout-box-shadow-s: null !default;
|
|
73
|
-
$card-callout-box-shadow-w: null !default;
|
|
74
|
-
|
|
75
|
-
$card-focus-callout-box-shadow-n: 1px -1px 4px 0 rgba( black, .06) !default;
|
|
76
|
-
$card-focus-callout-box-shadow-e: 2px -1px 4px 0 rgba( black, .06) !default;
|
|
77
|
-
$card-focus-callout-box-shadow-s: 2px -2px 4px 0 rgba( black, .06) !default;
|
|
78
|
-
$card-focus-callout-box-shadow-w: 2px -1px 4px 0 rgba( black, .06) !default;
|
|
@@ -24,6 +24,11 @@
|
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
26
|
|
|
27
|
+
.k-popover-inner {
|
|
28
|
+
position: relative;
|
|
29
|
+
border-radius: inherit;
|
|
30
|
+
}
|
|
31
|
+
|
|
27
32
|
// Header
|
|
28
33
|
.k-popover-header {
|
|
29
34
|
@include border-top-radius( $popover-border-radius );
|
|
@@ -50,32 +55,32 @@
|
|
|
50
55
|
margin: 0;
|
|
51
56
|
width: $popover-callout-width;
|
|
52
57
|
height: $popover-callout-height;
|
|
53
|
-
border-width: $popover-callout-border-width
|
|
58
|
+
border-width: $popover-callout-border-width;
|
|
54
59
|
border-style: $popover-callout-border-style;
|
|
55
60
|
position: absolute;
|
|
56
61
|
|
|
57
62
|
&.k-callout-n {
|
|
58
63
|
top: 0;
|
|
59
64
|
left: 50%;
|
|
60
|
-
transform: translate(-50%, -50%) rotate(
|
|
65
|
+
transform: translate(-50%, -50%) rotate(45deg);
|
|
61
66
|
}
|
|
62
67
|
|
|
63
68
|
&.k-callout-e {
|
|
64
69
|
top: 50%;
|
|
65
70
|
right: 0;
|
|
66
|
-
transform: translate(50%, -50%) rotate(
|
|
71
|
+
transform: translate(50%, -50%) rotate(-45deg);
|
|
67
72
|
}
|
|
68
73
|
|
|
69
74
|
&.k-callout-s {
|
|
70
75
|
bottom: 0;
|
|
71
76
|
left: 50%;
|
|
72
|
-
transform: translate(-50%, 50%) rotate(
|
|
77
|
+
transform: translate(-50%, 50%) rotate(45deg);
|
|
73
78
|
}
|
|
74
79
|
|
|
75
80
|
&.k-callout-w {
|
|
76
81
|
top: 50%;
|
|
77
82
|
left: 0;
|
|
78
|
-
transform: translate(-50%, -50%) rotate(
|
|
83
|
+
transform: translate(-50%, -50%) rotate(45deg);
|
|
79
84
|
}
|
|
80
85
|
}
|
|
81
86
|
|
package/scss/popover/_theme.scss
CHANGED
|
@@ -11,6 +11,11 @@
|
|
|
11
11
|
);
|
|
12
12
|
}
|
|
13
13
|
|
|
14
|
+
.k-popover-inner {
|
|
15
|
+
background-color: inherit;
|
|
16
|
+
border-color: inherit;
|
|
17
|
+
}
|
|
18
|
+
|
|
14
19
|
// Header
|
|
15
20
|
.k-popover-header {
|
|
16
21
|
@include fill(
|
|
@@ -23,14 +28,11 @@
|
|
|
23
28
|
// Callout
|
|
24
29
|
.k-popover-callout {
|
|
25
30
|
@include fill(
|
|
26
|
-
$bg:
|
|
27
|
-
$border:
|
|
31
|
+
$bg: inherit,
|
|
32
|
+
$border: inherit
|
|
28
33
|
);
|
|
29
34
|
|
|
30
|
-
|
|
31
|
-
&.k-callout-e { @include box-shadow( $popover-callout-shadow-e ); }
|
|
32
|
-
&.k-callout-s { @include box-shadow( $popover-callout-shadow-s ); }
|
|
33
|
-
&.k-callout-w { @include box-shadow( $popover-callout-shadow-w ); }
|
|
35
|
+
@include box-shadow( inherit )
|
|
34
36
|
}
|
|
35
37
|
|
|
36
38
|
}
|
|
@@ -29,8 +29,3 @@ $popover-callout-border-width: $popover-border-width !default;
|
|
|
29
29
|
$popover-callout-border-style: $popover-border-style !default;
|
|
30
30
|
$popover-callout-bg: $popover-bg !default;
|
|
31
31
|
$popover-callout-border: $popover-border !default;
|
|
32
|
-
|
|
33
|
-
$popover-callout-shadow-n: null !default;
|
|
34
|
-
$popover-callout-shadow-e: rgba( black, .03 ) 2px -1px 4px 0px !default;
|
|
35
|
-
$popover-callout-shadow-s: rgba( black, .06 ) 2px -2px 4px 0px !default;
|
|
36
|
-
$popover-callout-shadow-w: rgba( black, .03 ) 2px -1px 4px 0px !default;
|
|
@@ -25,6 +25,9 @@
|
|
|
25
25
|
@each $pos in (static, relative, absolute, fixed, sticky) {
|
|
26
26
|
.k-#{$pos},
|
|
27
27
|
.k-pos-#{$pos} { position: $pos !important; } // sass-lint:disable-line brace-style no-important
|
|
28
|
+
|
|
29
|
+
.\!k-#{$pos},
|
|
30
|
+
.\!k-pos-#{$pos} { position: $pos !important; } // sass-lint:disable-line brace-style no-important
|
|
28
31
|
}
|
|
29
32
|
|
|
30
33
|
/// @name k-pos-top
|