@vanjana/vue-ui 0.1.61 → 0.1.85
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/theme-light.css +1 -1
- package/dist/types/components/chip-group.vue.d.ts +40 -0
- package/dist/types/components/chip-selector.vue.d.ts +24 -0
- package/dist/types/components/chip.vue.d.ts +28 -0
- package/dist/types/components/dialog.vue.d.ts +2 -2
- package/dist/types/components/editable-label.vue.d.ts +13 -0
- package/dist/types/components/form/form-field.vue.d.ts +2 -2
- package/dist/types/components/form/input-select.vue.d.ts +1 -1
- package/dist/types/components/form/input-slider.vue.d.ts +2 -2
- package/dist/types/components/form/input-text-area.vue.d.ts +2 -2
- package/dist/types/components/form/input-text.vue.d.ts +2 -2
- package/dist/types/components/form/input.vue.d.ts +1 -1
- package/dist/types/components/form/textarea.vue.d.ts +1 -1
- package/dist/types/components/index.d.ts +10 -2
- package/dist/types/components/notification/notification.vue.d.ts +13 -0
- package/dist/types/components/notification/notifications.vue.d.ts +3 -0
- package/dist/types/components/page.vue.d.ts +3 -0
- package/dist/types/components/paginator.vue.d.ts +1 -1
- package/dist/types/components/radio.vue.d.ts +15 -0
- package/dist/types/components/shell/shell-navigation-item.vue.d.ts +1 -1
- package/dist/types/components/shell/shell.vue.d.ts +4 -2
- package/dist/types/components/skeleton.vue.d.ts +8 -0
- package/dist/types/components/slider.vue.d.ts +2 -2
- package/dist/types/components/spinner.vue.d.ts +3 -0
- package/dist/types/config.d.ts +2 -0
- package/dist/types/directives/index.d.ts +1 -0
- package/dist/types/directives/loading.directive.d.ts +7 -0
- package/dist/types/model/FormFieldProps.d.ts +2 -1
- package/dist/types/model/Icons.d.ts +43 -3
- package/dist/types/services/flow.d.ts +3 -2
- package/dist/types/services/index.d.ts +2 -1
- package/dist/types/services/notification.service.d.ts +62 -0
- package/dist/types/stories/components/chip-group.stories.d.ts +48 -0
- package/dist/types/stories/components/chip-selector.stories.d.ts +38 -0
- package/dist/types/stories/components/chip.stories.d.ts +37 -0
- package/dist/types/stories/components/compact.stories.d.ts +2 -2
- package/dist/types/stories/components/dialog.stories.d.ts +5 -5
- package/dist/types/stories/components/editable-label.stories.d.ts +30 -0
- package/dist/types/stories/components/form-field.stories.d.ts +27 -2
- package/dist/types/stories/components/input.stories.d.ts +1 -1
- package/dist/types/stories/components/notification.stories.d.ts +44 -0
- package/dist/types/stories/components/page.stories.d.ts +13 -0
- package/dist/types/stories/components/radio.stories.d.ts +65 -0
- package/dist/types/stories/components/shell.stories.d.ts +4 -0
- package/dist/types/stories/components/skeleton.stories.d.ts +30 -0
- package/dist/types/stories/components/spinner.stories.d.ts +10 -0
- package/dist/types/stories/components/textarea.stories.d.ts +1 -1
- package/dist/types/stories/directives/loading.stories.d.ts +8 -0
- package/dist/vanjana-vue-ui.es.js +2104 -1609
- package/dist/vanjana-vue-ui.umd.js +1 -1
- package/dist/vue-ui.css +1 -1
- package/package.json +3 -2
- package/themes/common/_components.scss +6 -0
- package/themes/common/_mixins.scss +1 -1
- package/themes/common/components/_checkbox.scss +43 -9
- package/themes/common/components/_chip.scss +24 -0
- package/themes/common/components/_loading-overlay.scss +67 -0
- package/themes/common/components/_radio.scss +59 -0
- package/themes/common/components/_shell.scss +25 -28
- package/themes/common/components/_skeleton.scss +31 -0
- package/themes/common/components/form/_form-field.scss +39 -2
- package/themes/common/components/form/_input.scss +1 -1
- package/themes/common/components/notification/_notification.scss +39 -0
- package/themes/light/theme.scss +31 -7
|
@@ -1,26 +1,60 @@
|
|
|
1
|
+
@use "../mixins" as *;
|
|
2
|
+
|
|
1
3
|
.checkbox {
|
|
2
|
-
gap:
|
|
4
|
+
gap: 0.5rem;
|
|
5
|
+
}
|
|
3
6
|
|
|
4
|
-
|
|
5
|
-
|
|
7
|
+
.checkbox-input {
|
|
8
|
+
opacity: 0;
|
|
9
|
+
|
|
10
|
+
&:disabled + .checkbox-box {
|
|
11
|
+
opacity: 0.5;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
&:focus-visible + .checkbox-box {
|
|
15
|
+
outline: 2px solid var(--color-primary);
|
|
16
|
+
outline-offset: 2px;
|
|
6
17
|
}
|
|
7
18
|
}
|
|
8
19
|
|
|
9
20
|
.checkbox-box {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
21
|
+
width: 20px;
|
|
22
|
+
height: 20px;
|
|
23
|
+
border: 2px solid var(--color-border);
|
|
24
|
+
border-radius: var(--border-radius-input);
|
|
25
|
+
transition: all 0.2s ease;
|
|
26
|
+
@include useColor("input");
|
|
13
27
|
}
|
|
14
28
|
|
|
15
29
|
.checkbox-icon {
|
|
16
|
-
|
|
30
|
+
width: 16px;
|
|
31
|
+
height: 16px;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
.checkbox-check {
|
|
35
|
+
stroke-dasharray: 24;
|
|
36
|
+
stroke-dashoffset: 24;
|
|
37
|
+
transition: stroke-dashoffset 0.3s ease;
|
|
38
|
+
stroke: currentColor;
|
|
17
39
|
}
|
|
18
40
|
|
|
19
41
|
.checkbox-input:checked + .checkbox-box {
|
|
20
|
-
|
|
42
|
+
@include useColor("primary");
|
|
43
|
+
|
|
44
|
+
.checkbox-check {
|
|
45
|
+
stroke-dashoffset: 0;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.checkbox-box:hover {
|
|
21
50
|
border-color: var(--color-primary);
|
|
22
51
|
}
|
|
23
52
|
|
|
24
53
|
.checkbox-label {
|
|
25
|
-
|
|
54
|
+
font-size: 1rem;
|
|
55
|
+
@include useColor("base");
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.checkbox-input:disabled ~ .checkbox-label {
|
|
59
|
+
opacity: 0.5;
|
|
26
60
|
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
@use "../mixins" as *;
|
|
2
|
+
|
|
3
|
+
.chip {
|
|
4
|
+
justify-content: center;
|
|
5
|
+
align-items: center;
|
|
6
|
+
|
|
7
|
+
gap: var(--space-s);
|
|
8
|
+
padding: var(--space-xs) var(--space-xl);
|
|
9
|
+
border-radius: 2rem;
|
|
10
|
+
|
|
11
|
+
background: rgba(0, 0, 0, 0.06);
|
|
12
|
+
color: inherit;
|
|
13
|
+
|
|
14
|
+
@include useFont("button");
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
.chip__close {
|
|
18
|
+
align-items: center;
|
|
19
|
+
justify-content: center;
|
|
20
|
+
padding: 0;
|
|
21
|
+
border: none;
|
|
22
|
+
background: transparent;
|
|
23
|
+
cursor: pointer;
|
|
24
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
@use "../mixins" as *;
|
|
2
|
+
|
|
3
|
+
.vj-loading-overlay {
|
|
4
|
+
position: absolute;
|
|
5
|
+
inset: 0;
|
|
6
|
+
display: flex;
|
|
7
|
+
align-items: center;
|
|
8
|
+
justify-content: center;
|
|
9
|
+
background: rgba(255, 255, 255, 0.6);
|
|
10
|
+
backdrop-filter: blur(1px);
|
|
11
|
+
z-index: 9999;
|
|
12
|
+
pointer-events: all;
|
|
13
|
+
|
|
14
|
+
/* centered inner box with padding; spinner above text */
|
|
15
|
+
.vj-loading-inner {
|
|
16
|
+
display: flex;
|
|
17
|
+
flex-direction: column;
|
|
18
|
+
align-items: center;
|
|
19
|
+
justify-content: center;
|
|
20
|
+
gap: var(--space-xl);
|
|
21
|
+
padding: var(--space-xl);
|
|
22
|
+
border-radius: var(--space-m);
|
|
23
|
+
background: rgba(255, 255, 255, 0.92);
|
|
24
|
+
box-shadow: var(--box-shadow-container);
|
|
25
|
+
pointer-events: none; /* allow overlay to catch interactions but inner box should not intercept extra */
|
|
26
|
+
|
|
27
|
+
.spinner {
|
|
28
|
+
width: 5rem;
|
|
29
|
+
height: 5rem;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/* small padding variant when container has limited height */
|
|
34
|
+
.vj-loading-inner--small {
|
|
35
|
+
.spinner {
|
|
36
|
+
width: 2rem;
|
|
37
|
+
height: 2rem;
|
|
38
|
+
}
|
|
39
|
+
padding: 12px;
|
|
40
|
+
gap: 8px;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/* minimal variant: no inner frame, transparent background, no shadow */
|
|
44
|
+
.vj-loading-inner--minimal {
|
|
45
|
+
padding: 6px;
|
|
46
|
+
background: transparent;
|
|
47
|
+
box-shadow: none;
|
|
48
|
+
.spinner {
|
|
49
|
+
width: 1rem;
|
|
50
|
+
height: 1rem;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.vj-loading-overlay--hidden {
|
|
56
|
+
display: none;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
.vj-loading-text {
|
|
60
|
+
text-align: center;
|
|
61
|
+
@include useFont("secondary");
|
|
62
|
+
@include useColor("base");
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.vj-loading-text--hidden {
|
|
66
|
+
display: none;
|
|
67
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
@use "../mixins" as *;
|
|
2
|
+
|
|
3
|
+
.radio {
|
|
4
|
+
gap: 0.5rem;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.radio-input {
|
|
8
|
+
opacity: 0;
|
|
9
|
+
|
|
10
|
+
&:disabled + .radio-box {
|
|
11
|
+
opacity: 0.5;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
&:focus-visible + .radio-box {
|
|
15
|
+
outline: 2px solid var(--color-primary);
|
|
16
|
+
outline-offset: 2px;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
.radio-box {
|
|
21
|
+
width: 20px;
|
|
22
|
+
height: 20px;
|
|
23
|
+
border: 2px solid var(--color-border);
|
|
24
|
+
border-radius: 50%;
|
|
25
|
+
transition: all 0.2s ease;
|
|
26
|
+
display: flex;
|
|
27
|
+
align-items: center;
|
|
28
|
+
justify-content: center;
|
|
29
|
+
@include useColor("input");
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.radio-dot {
|
|
33
|
+
width: 10px;
|
|
34
|
+
height: 10px;
|
|
35
|
+
border-radius: 50%;
|
|
36
|
+
transform: scale(0);
|
|
37
|
+
transition: transform 180ms ease;
|
|
38
|
+
background: currentColor;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.radio-input:checked + .radio-box {
|
|
42
|
+
.radio-dot {
|
|
43
|
+
transform: scale(1);
|
|
44
|
+
@include useColor("primary");
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
.radio-box:hover {
|
|
49
|
+
border-color: var(--color-primary);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.radio-label {
|
|
53
|
+
font-size: 1rem;
|
|
54
|
+
@include useColor("base");
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.radio-input:disabled ~ .radio-label {
|
|
58
|
+
opacity: 0.5;
|
|
59
|
+
}
|
|
@@ -5,6 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
> header {
|
|
7
7
|
padding: var(--space-s);
|
|
8
|
+
@include useColor("shell-header");
|
|
8
9
|
|
|
9
10
|
.shell-title {
|
|
10
11
|
gap: var(--space-m);
|
|
@@ -19,8 +20,6 @@
|
|
|
19
20
|
gap: var(--space-s);
|
|
20
21
|
}
|
|
21
22
|
|
|
22
|
-
--application__color: blue;
|
|
23
|
-
--application-gradient: linear-gradient(90deg, #e0f7ff 0%, #c5dbff 20%, #fff9e6 50%, #ffe4f0 75%, #ffd9f2 100%);
|
|
24
23
|
border-bottom: solid var(--space-s) var(--application__color);
|
|
25
24
|
border-image-slice: 1;
|
|
26
25
|
border-image-source: var(--application-gradient);
|
|
@@ -28,7 +27,7 @@
|
|
|
28
27
|
|
|
29
28
|
.shell-content {
|
|
30
29
|
main {
|
|
31
|
-
padding:
|
|
30
|
+
padding: var(--space-s);
|
|
32
31
|
overflow: auto;
|
|
33
32
|
}
|
|
34
33
|
|
|
@@ -55,32 +54,30 @@
|
|
|
55
54
|
padding: 0;
|
|
56
55
|
margin: 0;
|
|
57
56
|
gap: var(--space-s);
|
|
57
|
+
}
|
|
58
|
+
.shell-navigation-item {
|
|
59
|
+
padding: 0;
|
|
60
|
+
margin: 0;
|
|
61
|
+
|
|
62
|
+
.shell-navigation-item-link {
|
|
63
|
+
padding: var(--space-m) var(--space-s);
|
|
64
|
+
text-decoration: none;
|
|
65
|
+
border-left: solid 5px transparent;
|
|
66
|
+
transition: all 0.2s ease;
|
|
58
67
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
border-left: solid 5px
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
@include useColor("navigation-item");
|
|
74
|
-
|
|
75
|
-
&:hover {
|
|
76
|
-
@include useColor("navigation-hover");
|
|
77
|
-
border-left: solid 5px currentColor;
|
|
78
|
-
}
|
|
79
|
-
&.router-link-active {
|
|
80
|
-
@include useColor("navigation-hover");
|
|
81
|
-
border-left: solid 5px currentColor;
|
|
82
|
-
background-color: rgba(255, 255, 255, 0.5);
|
|
83
|
-
}
|
|
68
|
+
.shell-navigation-icon {
|
|
69
|
+
font-size: 1.5rem;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
@include useColor("navigation-item");
|
|
73
|
+
|
|
74
|
+
&:hover {
|
|
75
|
+
border-left: solid 5px currentColor;
|
|
76
|
+
@include useColor("navigation-hover");
|
|
77
|
+
}
|
|
78
|
+
&.router-link-active {
|
|
79
|
+
border-left: solid 5px currentColor;
|
|
80
|
+
@include useColor("navigation-item-active");
|
|
84
81
|
}
|
|
85
82
|
}
|
|
86
83
|
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
@use "../mixins" as *;
|
|
2
|
+
|
|
3
|
+
.vj-skeleton {
|
|
4
|
+
@include useColor("skeleton");
|
|
5
|
+
|
|
6
|
+
&::after {
|
|
7
|
+
transform: translate(0, 0);
|
|
8
|
+
filter: blur(0.2px);
|
|
9
|
+
opacity: 0.95;
|
|
10
|
+
animation: shimmer-diag 2.5s linear infinite;
|
|
11
|
+
|
|
12
|
+
@include useColor("skeleton-shimmer");
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
@keyframes shimmer-diag {
|
|
16
|
+
0% {
|
|
17
|
+
transform: translate(-100%, -100%);
|
|
18
|
+
}
|
|
19
|
+
100% {
|
|
20
|
+
transform: translate(100%, 100%);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/* Respect users who prefer reduced motion */
|
|
25
|
+
@media (prefers-reduced-motion: reduce) {
|
|
26
|
+
.vj-skeleton::after {
|
|
27
|
+
animation: none;
|
|
28
|
+
opacity: 0.6;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -6,14 +6,14 @@
|
|
|
6
6
|
|
|
7
7
|
/* LABEL */
|
|
8
8
|
.form-field__label {
|
|
9
|
-
left:
|
|
9
|
+
left: var(--space-s);
|
|
10
10
|
padding: 0 var(--space-xs);
|
|
11
11
|
@include useFont("caption");
|
|
12
12
|
@include useColor("input-label");
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
.form-field__label--float {
|
|
16
|
-
left:
|
|
16
|
+
left: var(--space-m);
|
|
17
17
|
@include useFont("caption");
|
|
18
18
|
@include useColor("input-label-floating");
|
|
19
19
|
}
|
|
@@ -29,4 +29,41 @@
|
|
|
29
29
|
display: none;
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
|
+
|
|
33
|
+
&.form-field--underlined {
|
|
34
|
+
.form-field__label {
|
|
35
|
+
left: 0 !important;
|
|
36
|
+
padding-left: 0px !important;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
.input,
|
|
40
|
+
.textarea {
|
|
41
|
+
border-radius: 0 !important;
|
|
42
|
+
padding-left: 0 !important;
|
|
43
|
+
padding-right: 0 !important;
|
|
44
|
+
outline: none !important;
|
|
45
|
+
box-shadow: 0px 2px 0px var(--color-border);
|
|
46
|
+
|
|
47
|
+
&:focus-within {
|
|
48
|
+
box-shadow: 0px 2px 0px #7c3aed !important;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.select-trigger {
|
|
53
|
+
outline: none !important;
|
|
54
|
+
border-left: none !important;
|
|
55
|
+
border-right: none !important;
|
|
56
|
+
border-top: none !important;
|
|
57
|
+
border-radius: 0 !important;
|
|
58
|
+
border-width: 2px !important;
|
|
59
|
+
padding-left: 0px !important;
|
|
60
|
+
border-color: var(--color-border) !important;
|
|
61
|
+
|
|
62
|
+
&:focus-visible {
|
|
63
|
+
outline: none !important;
|
|
64
|
+
box-shadow: none !important;
|
|
65
|
+
border-color: #7c3aed !important;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
32
69
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
@use "../../mixins" as *;
|
|
2
2
|
|
|
3
3
|
.input {
|
|
4
|
-
padding: var(--space-s) var(--space-l);
|
|
5
4
|
border-radius: var(--border-radius-input);
|
|
6
5
|
outline: var(--border-input);
|
|
7
6
|
outline-offset: -1px;
|
|
7
|
+
padding: var(--space-s) var(--space-l);
|
|
8
8
|
gap: var(--space-s);
|
|
9
9
|
|
|
10
10
|
@include useFont("input");
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
@use "../../mixins" as *;
|
|
2
|
+
|
|
3
|
+
.notification {
|
|
4
|
+
position: relative;
|
|
5
|
+
gap: var(--space-s);
|
|
6
|
+
padding: var(--space-xs) var(--space-s);
|
|
7
|
+
border-radius: var(--border-radius-component);
|
|
8
|
+
border-left: 4px solid;
|
|
9
|
+
|
|
10
|
+
.notification__message {
|
|
11
|
+
flex: 1 1 auto;
|
|
12
|
+
gap: var(--space-s);
|
|
13
|
+
|
|
14
|
+
.notification__title {
|
|
15
|
+
@include useFont("button");
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.notification__icon {
|
|
20
|
+
flex-shrink: 0;
|
|
21
|
+
font-size: 24px;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.notification--success {
|
|
26
|
+
@include useColor("success");
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.notification--info {
|
|
30
|
+
@include useColor("info");
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.notification--warning {
|
|
34
|
+
@include useColor("warning");
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.notification--error {
|
|
38
|
+
@include useColor("danger");
|
|
39
|
+
}
|
package/themes/light/theme.scss
CHANGED
|
@@ -3,37 +3,61 @@
|
|
|
3
3
|
@forward "../default";
|
|
4
4
|
|
|
5
5
|
:root {
|
|
6
|
-
|
|
7
|
-
--
|
|
6
|
+
/* Restore previous primary (softer blue) and add a subtle gradient/shimmer */
|
|
7
|
+
--primary-solid: #3b82c4; /* restored soft primary */
|
|
8
|
+
--primary-gradient: linear-gradient(90deg, #3b82c4 0%, #6197ca 45%, #3b82c4 100%);
|
|
9
|
+
--application__color: var(--primary-solid);
|
|
10
|
+
--application-gradient: linear-gradient(90deg, #e8f6ff 0%, #d6e9ff 35%, #f7f9ff 70%, #fff8ea 100%);
|
|
11
|
+
|
|
12
|
+
--color-border: #cccccc;
|
|
13
|
+
--color-border-highlight: #6d5df6;
|
|
8
14
|
--border-footer: solid 1px var(--color-border);
|
|
9
15
|
--border-input: solid 1px var(--color-border); //#cbd5e1
|
|
10
16
|
--border-radius-input: 6px;
|
|
11
17
|
--opacity-disabled: 0.5;
|
|
12
18
|
--tab-indicator-height: 3px;
|
|
13
19
|
|
|
20
|
+
--spinner-gradient: linear-gradient(90deg, #00b3a6 0%, #6fb6ff 40%, #ffd39a 80%);
|
|
21
|
+
|
|
14
22
|
@include defineColor("base", #ffffff, #333333);
|
|
15
23
|
@include defineColor("input", #ffffff, #333333);
|
|
16
24
|
@include defineColor("input-label", #ffffff, #64748b);
|
|
17
25
|
@include defineColor("input-label-floating", #ffffff, #4c1d95);
|
|
18
26
|
|
|
27
|
+
@include defineColor("shell-header", #ffffff, #2d3748);
|
|
19
28
|
@include defineColor("navigation", #ffffff, #2d3748);
|
|
20
29
|
@include defineColor("navigation-item", transparent, #64748b);
|
|
21
|
-
@include defineColor("navigation-
|
|
30
|
+
@include defineColor("navigation-item-active", rgba(255, 255, 255, 0.5), #3b82c4);
|
|
31
|
+
@include defineColor("navigation-hover", transparent, #3b82c4);
|
|
22
32
|
|
|
23
|
-
@include defineColor("button-primary",
|
|
33
|
+
@include defineColor("button-primary", var(--primary-gradient), #ffffff);
|
|
24
34
|
@include defineColor("button-secondary", #f97316, #ffffff);
|
|
25
35
|
@include defineColor("button-tertiary", transparent, #374151);
|
|
26
36
|
@include defineColor("dot-menu", #eeeeee, #374151);
|
|
27
37
|
@include defineColor("button-hover", #403b9c, #ffffff);
|
|
28
38
|
|
|
29
39
|
@include defineColor("tab", transparent, #333333);
|
|
30
|
-
@include defineColor("tab-hover", transparent, #
|
|
31
|
-
@include defineColor("tab-active", transparent, #
|
|
40
|
+
@include defineColor("tab-hover", transparent, #3b82c4);
|
|
41
|
+
@include defineColor("tab-active", transparent, #3b82c4);
|
|
42
|
+
|
|
43
|
+
@include defineColor("primary", var(--primary-solid), #ffffff);
|
|
44
|
+
@include defineColor("success", #1fb67a, #ffffff);
|
|
45
|
+
@include defineColor("info", #e6f0ff, #0b57d0);
|
|
46
|
+
@include defineColor("warning", #f59e0b, #ffffff);
|
|
47
|
+
@include defineColor("danger", #e11d48, #ffffff);
|
|
48
|
+
|
|
49
|
+
@include defineColor("skeleton", #e9ecef, #b00020);
|
|
50
|
+
@include defineColor(
|
|
51
|
+
"skeleton-shimmer",
|
|
52
|
+
linear-gradient(135deg, rgba(255, 255, 255, 0) 30%, rgba(255, 255, 255, 0.65) 50%, rgba(255, 255, 255, 0) 70%),
|
|
53
|
+
#b00020
|
|
54
|
+
);
|
|
32
55
|
|
|
33
56
|
@include defineFont("title", h1, 24px, 600);
|
|
34
|
-
@include defineFont("
|
|
57
|
+
@include defineFont("subtitle", h2, 24px, 600);
|
|
35
58
|
@include defineFont("header", h3, 18px, 600, 32px);
|
|
36
59
|
@include defineFont("primary", body, 16px, 400);
|
|
60
|
+
@include defineFont("secondary", secondary, 14px, 300, 16px);
|
|
37
61
|
@include defineFont("input", input, 16px, 400, 24px);
|
|
38
62
|
@include defineFont("caption", label, 14px, 400, 24px);
|
|
39
63
|
@include defineFont("button", button, 16px, 600, 24px);
|