@slexkit/theme-shadcn 0.2.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.
@@ -0,0 +1,260 @@
1
+ .slex-select {
2
+ position: relative;
3
+ display: flex;
4
+ width: 100%;
5
+ min-width: 0;
6
+ flex-direction: column;
7
+ gap: 0.5rem;
8
+ }
9
+
10
+ .slex-select-label {
11
+ display: inline-flex;
12
+ align-items: center;
13
+ gap: 0.375rem;
14
+ min-width: 0;
15
+ color: var(--foreground);
16
+ font-size: 0.875rem;
17
+ font-weight: 500;
18
+ line-height: 1;
19
+ }
20
+
21
+ .slex-select-control {
22
+ width: 100%;
23
+ min-width: 0;
24
+ }
25
+
26
+ .slex-select .slex-select-trigger {
27
+ box-sizing: border-box;
28
+ display: flex;
29
+ align-items: center;
30
+ justify-content: space-between;
31
+ gap: 0.75rem;
32
+ width: 100%;
33
+ min-width: 0;
34
+ min-height: 2.5rem;
35
+ margin: 0;
36
+ padding: 0.5rem 1rem;
37
+ border: 1px solid var(--input);
38
+ border-radius: var(--radius);
39
+ background: var(--background);
40
+ color: var(--foreground);
41
+ font: inherit;
42
+ font-size: 0.875rem;
43
+ line-height: 1.25rem;
44
+ outline: none;
45
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 8%, transparent);
46
+ cursor: pointer;
47
+ transition:
48
+ border-color 150ms ease,
49
+ background-color 150ms ease,
50
+ box-shadow 150ms ease,
51
+ color 150ms ease;
52
+ appearance: none;
53
+ text-align: left;
54
+ }
55
+
56
+ .slex-select .slex-select-trigger:hover:not(:disabled) {
57
+ background: color-mix(in oklab, var(--accent) 34%, var(--background));
58
+ }
59
+
60
+ .slex-select .slex-select-trigger:focus-visible {
61
+ border-color: var(--ring);
62
+ box-shadow: 0 0 0 2px color-mix(in oklab, var(--ring) 20%, transparent);
63
+ }
64
+
65
+ .slex-select .slex-select-trigger:disabled {
66
+ cursor: not-allowed;
67
+ opacity: 0.5;
68
+ }
69
+
70
+ .slex-select-value {
71
+ display: inline-flex;
72
+ align-items: center;
73
+ gap: 0.375rem;
74
+ min-width: 0;
75
+ overflow: hidden;
76
+ text-overflow: ellipsis;
77
+ white-space: nowrap;
78
+ }
79
+
80
+ .slex-select-value[data-placeholder] {
81
+ color: var(--muted-foreground);
82
+ }
83
+
84
+ .slex-select-icon {
85
+ position: relative;
86
+ flex: 0 0 auto;
87
+ width: 0.75rem;
88
+ height: 0.75rem;
89
+ opacity: 0.72;
90
+ }
91
+
92
+ .slex-select-icon::before {
93
+ position: absolute;
94
+ top: 0.2rem;
95
+ left: 0.125rem;
96
+ width: 0.45rem;
97
+ height: 0.45rem;
98
+ border-right: 1.5px solid currentColor;
99
+ border-bottom: 1.5px solid currentColor;
100
+ content: "";
101
+ transform: rotate(45deg);
102
+ }
103
+
104
+ .slex-select-native {
105
+ position: absolute;
106
+ width: 1px;
107
+ height: 1px;
108
+ margin: -1px;
109
+ padding: 0;
110
+ border: 0;
111
+ overflow: hidden;
112
+ clip: rect(0 0 0 0);
113
+ clip-path: inset(50%);
114
+ white-space: nowrap;
115
+ }
116
+
117
+ .slex-select-menu {
118
+ position: absolute;
119
+ z-index: 40;
120
+ top: calc(100% + 0.375rem);
121
+ left: 0;
122
+ right: 0;
123
+ width: 100%;
124
+ max-height: 14rem;
125
+ margin: 0;
126
+ padding: 0.25rem;
127
+ overflow-y: auto;
128
+ border: 1px solid color-mix(in oklab, var(--border) 82%, transparent);
129
+ border-radius: var(--radius);
130
+ background: var(--popover, var(--background));
131
+ color: var(--popover-foreground, var(--foreground));
132
+ box-shadow: var(
133
+ --shadow-md,
134
+ 0 6px 16px rgb(0 0 0 / 0.12),
135
+ 0 2px 4px rgb(0 0 0 / 0.08)
136
+ );
137
+ list-style: none;
138
+ }
139
+
140
+ .slexkit-root .slex-select-menu {
141
+ margin: 0;
142
+ padding: 0.25rem;
143
+ list-style: none;
144
+ }
145
+
146
+ .slexkit-root .slex-select-menu li {
147
+ margin: 0;
148
+ list-style: none;
149
+ }
150
+
151
+ .slex-select-option {
152
+ display: flex;
153
+ align-items: center;
154
+ justify-content: space-between;
155
+ gap: 0.75rem;
156
+ min-height: 2rem;
157
+ padding: 0.5rem 0.75rem;
158
+ border-radius: calc(var(--radius) - 2px);
159
+ color: var(--popover-foreground, var(--foreground));
160
+ font-size: 0.875rem;
161
+ line-height: 1.25rem;
162
+ cursor: pointer;
163
+ user-select: none;
164
+ }
165
+
166
+ .slex-select-option:hover:not([data-disabled]),
167
+ .slex-select-option--active:not([data-disabled]) {
168
+ background: var(--accent);
169
+ color: var(--accent-foreground);
170
+ }
171
+
172
+ .slex-select-menu:has(.slex-select-option:hover) .slex-select-option--active:not(:hover) {
173
+ background: transparent;
174
+ color: var(--popover-foreground, var(--foreground));
175
+ }
176
+
177
+ .slex-select-option--selected {
178
+ font-weight: 500;
179
+ }
180
+
181
+ .slex-select-option[data-disabled] {
182
+ color: var(--muted-foreground);
183
+ cursor: not-allowed;
184
+ opacity: 0.52;
185
+ }
186
+
187
+ .slex-select-option-label {
188
+ display: inline-flex;
189
+ align-items: center;
190
+ gap: 0.375rem;
191
+ min-width: 0;
192
+ overflow: hidden;
193
+ text-overflow: ellipsis;
194
+ white-space: nowrap;
195
+ }
196
+
197
+ .slex-select-check {
198
+ position: relative;
199
+ flex: 0 0 auto;
200
+ width: 0.875rem;
201
+ height: 0.875rem;
202
+ color: currentColor;
203
+ }
204
+
205
+ .slex-select-check::before {
206
+ position: absolute;
207
+ top: 0.25rem;
208
+ left: 0.18rem;
209
+ width: 0.5rem;
210
+ height: 0.28rem;
211
+ border-left: 1.75px solid currentColor;
212
+ border-bottom: 1.75px solid currentColor;
213
+ content: "";
214
+ transform: rotate(-45deg);
215
+ }
216
+
217
+ .slex-select[data-variant="toolbar"] {
218
+ height: 100%;
219
+ gap: 0;
220
+ }
221
+
222
+ .slex-select[data-variant="toolbar"] .slex-select-trigger {
223
+ height: var(--slex-control-height, 2.25rem);
224
+ min-height: 0;
225
+ border-width: 0 1px 0 0;
226
+ border-color: color-mix(in oklab, var(--border) 58%, transparent);
227
+ border-radius: 0;
228
+ background: transparent;
229
+ padding: 0 0.75rem 0 0.875rem;
230
+ font-size: 0.8125rem;
231
+ line-height: 1;
232
+ box-shadow: none;
233
+ }
234
+
235
+ .slex-select[data-variant="toolbar"] .slex-select-trigger:hover:not(:disabled) {
236
+ background: color-mix(in oklab, var(--muted) 36%, var(--background));
237
+ }
238
+
239
+ .slex-select[data-variant="toolbar"] .slex-select-menu {
240
+ top: calc(100% + 0.25rem);
241
+ left: 0;
242
+ right: auto;
243
+ width: 100%;
244
+ min-width: 100%;
245
+ border-color: color-mix(in oklab, var(--border) 76%, transparent);
246
+ border-radius: calc(var(--radius) - 2px);
247
+ padding: 0.25rem;
248
+ box-shadow: var(
249
+ --shadow-sm,
250
+ 0 4px 10px rgb(0 0 0 / 0.1),
251
+ 0 1px 3px rgb(0 0 0 / 0.06)
252
+ );
253
+ }
254
+
255
+ .slex-select[data-variant="toolbar"] .slex-select-option {
256
+ height: 1.875rem;
257
+ border-radius: calc(var(--radius) - 4px);
258
+ font-size: 0.8125rem;
259
+ padding-inline: 0.75rem;
260
+ }
@@ -0,0 +1,125 @@
1
+ .slex-slider-container,
2
+ .slex-slider-field {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: 0.5rem;
6
+ width: 100%;
7
+ }
8
+
9
+ .slex-slider-field {
10
+ padding: 0.25rem 0;
11
+ }
12
+
13
+ .slex-slider-label {
14
+ display: flex;
15
+ align-items: center;
16
+ justify-content: space-between;
17
+ color: var(--muted-foreground);
18
+ font-size: 0.875rem;
19
+ font-weight: 500;
20
+ }
21
+
22
+ .slex-slider-value {
23
+ padding: 0.125rem 0.5rem;
24
+ border: 1px solid var(--border);
25
+ border-radius: calc(var(--radius) - 2px);
26
+ background: var(--secondary);
27
+ color: var(--secondary-foreground);
28
+ font-family: var(--font-mono, "Geist Mono", "Noto Sans Mono", "Noto Sans Mono CJK SC", "SFMono-Regular", "Cascadia Code", Consolas, monospace);
29
+ font-size: 0.875rem;
30
+ font-weight: 600;
31
+ }
32
+
33
+ .slex-slider {
34
+ box-sizing: border-box;
35
+ width: 100%;
36
+ height: 0.5rem;
37
+ border-radius: 999px;
38
+ -webkit-appearance: none;
39
+ appearance: none;
40
+ background: linear-gradient(
41
+ to right,
42
+ var(--primary) 0%,
43
+ var(--primary) var(--slex-slider-progress, 0%),
44
+ var(--secondary) var(--slex-slider-progress, 0%),
45
+ var(--secondary) 100%
46
+ );
47
+ accent-color: var(--primary);
48
+ cursor: pointer;
49
+ transition: box-shadow 150ms ease, filter 150ms ease;
50
+ }
51
+
52
+ .slex-slider:hover {
53
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 8%, transparent);
54
+ }
55
+
56
+ .slex-slider:active {
57
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
58
+ }
59
+
60
+ .slex-slider:focus-visible {
61
+ outline: 2px solid var(--ring);
62
+ outline-offset: 4px;
63
+ }
64
+
65
+ .slex-slider::-webkit-slider-thumb {
66
+ width: 1rem;
67
+ height: 1rem;
68
+ border: 2px solid var(--primary);
69
+ border-radius: 999px;
70
+ background: var(--background) !important;
71
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 14%, transparent);
72
+ -webkit-appearance: none;
73
+ appearance: none;
74
+ transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, transform 120ms ease;
75
+ }
76
+
77
+ .slex-slider::-moz-range-thumb {
78
+ width: 1rem;
79
+ height: 1rem;
80
+ border: 2px solid var(--primary);
81
+ border-radius: 999px;
82
+ background: var(--background) !important;
83
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 14%, transparent);
84
+ transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, transform 120ms ease;
85
+ }
86
+
87
+ .slex-slider:hover::-webkit-slider-thumb {
88
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
89
+ transform: scale(1.06);
90
+ }
91
+
92
+ .slex-slider:hover::-moz-range-thumb {
93
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
94
+ transform: scale(1.06);
95
+ }
96
+
97
+ .slex-slider:active::-webkit-slider-thumb {
98
+ box-shadow: 0 0 0 6px color-mix(in oklab, var(--primary) 16%, transparent);
99
+ transform: scale(1.12);
100
+ }
101
+
102
+ .slex-slider:active::-moz-range-thumb {
103
+ box-shadow: 0 0 0 6px color-mix(in oklab, var(--primary) 16%, transparent);
104
+ transform: scale(1.12);
105
+ }
106
+
107
+ .slex-slider::-moz-range-track {
108
+ height: 0.5rem;
109
+ border: 0;
110
+ border-radius: 999px;
111
+ background: var(--secondary);
112
+ }
113
+
114
+ .slex-slider::-moz-range-progress {
115
+ height: 0.5rem;
116
+ border-radius: 999px;
117
+ background: var(--primary);
118
+ }
119
+
120
+ .slex-slider-label-text {
121
+ display: inline-flex;
122
+ min-width: 0;
123
+ align-items: center;
124
+ gap: 0.375rem;
125
+ }
@@ -0,0 +1,9 @@
1
+ .slex-submit-bar {
2
+ display: flex;
3
+ align-items: center;
4
+ justify-content: flex-end;
5
+ gap: 0.75rem;
6
+ flex-wrap: wrap;
7
+ padding-top: 0.75rem;
8
+ border-top: 1px solid var(--border);
9
+ }
@@ -0,0 +1,114 @@
1
+ .slex-switch {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ gap: 0.5rem;
5
+ cursor: pointer;
6
+ }
7
+
8
+ .slex-switch-event-layer {
9
+ display: inline-flex;
10
+ }
11
+
12
+ .slex-choice-event-layer {
13
+ display: inline-flex;
14
+ }
15
+
16
+ .slex-switch-label {
17
+ display: inline-flex;
18
+ align-items: center;
19
+ gap: 0.375rem;
20
+ min-width: 0;
21
+ color: var(--foreground);
22
+ font-size: 0.8125rem;
23
+ font-weight: 500;
24
+ }
25
+
26
+ .slex-switch-input {
27
+ position: absolute;
28
+ width: 1px;
29
+ height: 1px;
30
+ padding: 0;
31
+ margin: -1px;
32
+ overflow: hidden;
33
+ clip: rect(0, 0, 0, 0);
34
+ white-space: nowrap;
35
+ border: 0;
36
+ }
37
+
38
+ .slex-switch-control {
39
+ box-sizing: border-box;
40
+ position: relative;
41
+ display: inline-flex;
42
+ align-items: center;
43
+ flex: 0 0 auto;
44
+ width: 2.75rem;
45
+ height: 1.5rem;
46
+ margin-inline-end: 0;
47
+ padding: 0;
48
+ border: 2px solid transparent;
49
+ border-radius: 9999px;
50
+ background: var(--input);
51
+ transition: background-color 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
52
+ }
53
+
54
+ .slex-switch-control::after {
55
+ content: "";
56
+ display: block;
57
+ width: 1.25rem;
58
+ height: 1.25rem;
59
+ border: 0;
60
+ border-radius: 9999px;
61
+ background: var(--background);
62
+ box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 12%, transparent);
63
+ transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
64
+ transform: translateX(0);
65
+ will-change: transform;
66
+ }
67
+
68
+ .slex-switch:hover .slex-switch-control {
69
+ border-color: color-mix(in oklab, var(--primary) 42%, var(--input));
70
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 8%, transparent);
71
+ }
72
+
73
+ .slex-switch:hover .slex-switch-control::after {
74
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 10%, transparent);
75
+ }
76
+
77
+ .slex-switch:active .slex-switch-control::after {
78
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 16%, transparent);
79
+ }
80
+
81
+ .slex-switch-input:checked + .slex-switch-control {
82
+ border-color: var(--primary);
83
+ background: var(--primary);
84
+ }
85
+
86
+ .slex-switch:hover .slex-switch-input:checked + .slex-switch-control {
87
+ background: color-mix(in oklab, var(--primary) 88%, var(--background));
88
+ }
89
+
90
+ .slex-switch-input:checked + .slex-switch-control::after {
91
+ background: var(--background);
92
+ transform: translateX(1.25rem);
93
+ }
94
+
95
+ .slexkit-root[dir="rtl"] .slex-switch-input:checked + .slex-switch-control::after {
96
+ transform: translateX(-1.25rem);
97
+ }
98
+
99
+ .slex-switch-input:focus-visible + .slex-switch-control {
100
+ box-shadow: 0 0 0 3px color-mix(in oklab, var(--ring) 18%, transparent);
101
+ }
102
+
103
+ .slex-switch-input:disabled + .slex-switch-control {
104
+ opacity: 0.55;
105
+ }
106
+
107
+ .slex-switch:has(.slex-switch-input:disabled) {
108
+ cursor: not-allowed;
109
+ }
110
+
111
+ .slex-switch:has(.slex-switch-input:disabled):hover .slex-switch-control,
112
+ .slex-switch:has(.slex-switch-input:disabled):hover .slex-switch-control::after {
113
+ box-shadow: none;
114
+ }
@@ -0,0 +1,192 @@
1
+ .slex-tabs {
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: 100%;
5
+ }
6
+
7
+ .slex-tabs[data-orientation="vertical"] {
8
+ flex-direction: row;
9
+ }
10
+
11
+ .slex-tabs-list {
12
+ --slex-tabs-indicator-inline-inset: 12px;
13
+ --slex-tabs-indicator-block-inset: 8px;
14
+ position: relative;
15
+ display: flex;
16
+ gap: 0;
17
+ margin: 0;
18
+ padding: 0;
19
+ list-style: none;
20
+ overflow: hidden;
21
+ border-bottom: 1px solid var(--border);
22
+ }
23
+
24
+ .slexkit-root .slex-tabs-list {
25
+ display: flex;
26
+ gap: 0;
27
+ margin: 0;
28
+ padding: 0;
29
+ list-style: none;
30
+ }
31
+
32
+ .slexkit-root .slex-tabs-list li {
33
+ margin: 0;
34
+ padding: 0;
35
+ color: inherit;
36
+ font: inherit;
37
+ line-height: inherit;
38
+ list-style: none;
39
+ }
40
+
41
+ .slex-tabs-selected-indicator {
42
+ position: absolute;
43
+ z-index: 20;
44
+ top: 0;
45
+ left: 0;
46
+ width: var(--slex-tabs-indicator-width, 0);
47
+ height: var(--slex-tabs-indicator-height, 0.125rem);
48
+ border-radius: 999px;
49
+ background: var(--primary);
50
+ opacity: var(--slex-tabs-indicator-opacity, 0);
51
+ pointer-events: none;
52
+ transform: translate3d(var(--slex-tabs-indicator-x, 0), var(--slex-tabs-indicator-y, 0), 0);
53
+ }
54
+
55
+ .slex-tabs-list[data-indicator-ready="true"] .slex-tabs-selected-indicator {
56
+ transition:
57
+ transform var(--slex-tabs-indicator-duration, 140ms) var(--slex-motion-ease-standard, cubic-bezier(0.22, 1, 0.36, 1)),
58
+ width var(--slex-tabs-indicator-duration, 140ms) var(--slex-motion-ease-standard, cubic-bezier(0.22, 1, 0.36, 1)),
59
+ height var(--slex-tabs-indicator-duration, 140ms) var(--slex-motion-ease-standard, cubic-bezier(0.22, 1, 0.36, 1)),
60
+ opacity var(--slex-tabs-indicator-duration, 140ms) var(--slex-motion-ease-standard, cubic-bezier(0.22, 1, 0.36, 1));
61
+ }
62
+
63
+ .slex-tabs[data-orientation="vertical"] .slex-tabs-list {
64
+ flex-direction: column;
65
+ border-right: 1px solid var(--border);
66
+ border-bottom: none;
67
+ }
68
+
69
+ .slex-tabs-trigger {
70
+ position: relative;
71
+ padding: 0.5rem 1rem;
72
+ border: none;
73
+ border-radius: 0;
74
+ background: transparent;
75
+ color: var(--muted-foreground);
76
+ font-family: inherit;
77
+ font-size: 0.875rem;
78
+ font-weight: 500;
79
+ white-space: nowrap;
80
+ cursor: pointer;
81
+ outline: none;
82
+ user-select: none;
83
+ }
84
+
85
+ .slex-tabs-trigger--icon {
86
+ display: inline-grid;
87
+ width: var(--slex-control-height, 2.25rem);
88
+ min-height: var(--slex-control-height, 2.25rem);
89
+ place-items: center;
90
+ padding-inline: 0;
91
+ }
92
+
93
+ .slex-tabs-trigger--with-icon {
94
+ display: inline-flex;
95
+ align-items: center;
96
+ gap: 0.5rem;
97
+ }
98
+
99
+ .slex-tabs-trigger-icon {
100
+ display: inline-flex;
101
+ flex: 0 0 auto;
102
+ width: 1.125rem;
103
+ height: 1.125rem;
104
+ color: currentColor;
105
+ }
106
+
107
+ .slex-tabs-trigger-icon svg {
108
+ display: block;
109
+ width: 100%;
110
+ height: 100%;
111
+ fill: currentColor;
112
+ }
113
+
114
+ .slex-tabs-trigger:hover:not([data-disabled]) {
115
+ background: transparent;
116
+ color: var(--muted-foreground);
117
+ }
118
+
119
+ .slex-tabs-trigger.slex-tabs-trigger--selected {
120
+ color: var(--primary);
121
+ }
122
+
123
+ .slex-tabs-trigger.slex-tabs-trigger--selected:hover:not([data-disabled]) {
124
+ color: var(--primary);
125
+ }
126
+
127
+ .slex-tabs-trigger[data-disabled] {
128
+ opacity: 0.4;
129
+ cursor: not-allowed;
130
+ }
131
+
132
+ .slex-tabs-trigger:focus-visible {
133
+ outline: 2px solid var(--ring);
134
+ outline-offset: -2px;
135
+ }
136
+
137
+ .slex-tabs-content {
138
+ margin-top: 0.75rem !important;
139
+ border-radius: 0 !important;
140
+ background: transparent !important;
141
+ padding: 0 !important;
142
+ color: var(--foreground);
143
+ font-size: 0.875rem;
144
+ line-height: 1.625;
145
+ animation: slex-tabs-content-in 200ms ease-out;
146
+ }
147
+
148
+ .slex-tabs[data-orientation="vertical"] .slex-tabs-content {
149
+ margin-top: 0 !important;
150
+ margin-left: 0.75rem !important;
151
+ }
152
+
153
+ .slex-tabs-content:empty {
154
+ display: none;
155
+ }
156
+
157
+ @keyframes slex-tabs-content-in {
158
+ from {
159
+ opacity: 0;
160
+ transform: translateY(2px);
161
+ }
162
+ to {
163
+ opacity: 1;
164
+ transform: translateY(0);
165
+ }
166
+ }
167
+
168
+ .slex-tabs-content[hidden] {
169
+ display: none;
170
+ }
171
+
172
+ @media (max-width: 640px) {
173
+ .slex-tabs-list {
174
+ overflow-x: auto;
175
+ scrollbar-width: none;
176
+ }
177
+
178
+ .slex-tabs-list::-webkit-scrollbar {
179
+ display: none;
180
+ }
181
+
182
+ .slex-tabs[data-orientation="vertical"] {
183
+ flex-direction: column;
184
+ }
185
+
186
+ .slex-tabs[data-orientation="vertical"] .slex-tabs-list {
187
+ flex-direction: row;
188
+ border-right: 0;
189
+ border-bottom: 1px solid var(--border);
190
+ }
191
+
192
+ }