@slexkit/theme-shadcn 0.2.0 → 0.3.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.
@@ -1,104 +1,104 @@
1
- .slex-button {
2
- display: inline-flex;
3
- align-items: center;
4
- justify-content: center;
5
- gap: 0.5rem;
6
- max-width: 100%;
7
- min-width: 0;
8
- padding: 0.5rem 1rem;
9
- border: 1px solid transparent;
10
- border-radius: var(--radius);
11
- font-family: inherit;
12
- font-size: 0.875rem;
13
- font-weight: 500;
14
- line-height: 1.25;
15
- white-space: nowrap;
16
- text-overflow: ellipsis;
17
- overflow: hidden;
18
- cursor: pointer;
19
- user-select: none;
20
- transition:
21
- background 150ms ease,
22
- border-color 150ms ease,
23
- color 150ms ease,
24
- box-shadow 150ms ease,
25
- transform 150ms ease;
26
- }
27
-
28
- .slex-button--primary {
29
- background: var(--primary);
30
- color: var(--primary-foreground);
31
- border-color: var(--primary);
32
- }
33
-
34
- .slex-button--primary:hover:not(:disabled):not(.slex-button--disabled) {
35
- background: color-mix(in oklab, var(--primary) 90%, transparent);
36
- border-color: color-mix(in oklab, var(--primary) 90%, transparent);
37
- color: var(--primary-foreground);
38
- transform: translateY(-1px);
39
- box-shadow: var(--shadow-md);
40
- }
41
-
42
- .slex-button--secondary {
43
- background: var(--secondary);
44
- color: var(--secondary-foreground);
45
- border-color: var(--border);
46
- }
47
-
48
- .slex-button--secondary:hover:not(:disabled):not(.slex-button--disabled) {
49
- background: var(--accent);
50
- color: var(--accent-foreground);
51
- border-color: var(--border);
52
- }
53
-
54
- .slex-button--danger {
55
- background: var(--destructive);
56
- color: var(--destructive-foreground);
57
- border-color: var(--destructive);
58
- }
59
-
60
- .slex-button--danger:hover:not(:disabled):not(.slex-button--disabled) {
61
- background: color-mix(in oklab, var(--destructive) 90%, transparent);
62
- border-color: color-mix(in oklab, var(--destructive) 90%, transparent);
63
- }
64
-
65
- .slex-button--ghost {
66
- background: transparent;
67
- color: var(--muted-foreground);
68
- border-color: transparent;
69
- }
70
-
71
- .slex-button--ghost:hover:not(:disabled):not(.slex-button--disabled) {
72
- background: var(--accent);
73
- color: var(--accent-foreground);
74
- }
75
-
76
- .slex-button:disabled,
77
- .slex-button[disabled],
78
- .slex-button--disabled {
79
- opacity: 0.5;
80
- cursor: not-allowed;
81
- pointer-events: none;
82
- transform: none;
83
- box-shadow: none;
84
- }
85
-
86
- .slex-button:active:not(:disabled):not(.slex-button--disabled) {
87
- transform: translateY(0);
88
- box-shadow: var(--shadow-sm);
89
- }
90
-
91
- .slex-button:focus-visible {
92
- outline: 2px solid var(--ring);
93
- outline-offset: 2px;
94
- }
95
-
96
- .slex-button--icon {
97
- width: var(--slex-control-height, 2.25rem);
98
- min-height: var(--slex-control-height, 2.25rem);
99
- padding-inline: 0;
100
- }
101
-
1
+ .slex-button {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ justify-content: center;
5
+ gap: 0.5rem;
6
+ max-width: 100%;
7
+ min-width: 0;
8
+ padding: 0.5rem 1rem;
9
+ border: 1px solid transparent;
10
+ border-radius: var(--radius);
11
+ font-family: inherit;
12
+ font-size: 0.875rem;
13
+ font-weight: 500;
14
+ line-height: 1.25;
15
+ white-space: nowrap;
16
+ text-overflow: ellipsis;
17
+ overflow: hidden;
18
+ cursor: pointer;
19
+ user-select: none;
20
+ transition:
21
+ background 150ms ease,
22
+ border-color 150ms ease,
23
+ color 150ms ease,
24
+ box-shadow 150ms ease,
25
+ transform 150ms ease;
26
+ }
27
+
28
+ .slex-button--primary {
29
+ background: var(--primary);
30
+ color: var(--primary-foreground);
31
+ border-color: var(--primary);
32
+ }
33
+
34
+ .slex-button--primary:hover:not(:disabled):not(.slex-button--disabled) {
35
+ background: color-mix(in oklab, var(--primary) 90%, transparent);
36
+ border-color: color-mix(in oklab, var(--primary) 90%, transparent);
37
+ color: var(--primary-foreground);
38
+ transform: translateY(-1px);
39
+ box-shadow: var(--shadow-md);
40
+ }
41
+
42
+ .slex-button--secondary {
43
+ background: var(--secondary);
44
+ color: var(--secondary-foreground);
45
+ border-color: var(--border);
46
+ }
47
+
48
+ .slex-button--secondary:hover:not(:disabled):not(.slex-button--disabled) {
49
+ background: var(--accent);
50
+ color: var(--accent-foreground);
51
+ border-color: var(--border);
52
+ }
53
+
54
+ .slex-button--danger {
55
+ background: var(--destructive);
56
+ color: var(--destructive-foreground);
57
+ border-color: var(--destructive);
58
+ }
59
+
60
+ .slex-button--danger:hover:not(:disabled):not(.slex-button--disabled) {
61
+ background: color-mix(in oklab, var(--destructive) 90%, transparent);
62
+ border-color: color-mix(in oklab, var(--destructive) 90%, transparent);
63
+ }
64
+
65
+ .slex-button--ghost {
66
+ background: transparent;
67
+ color: var(--muted-foreground);
68
+ border-color: transparent;
69
+ }
70
+
71
+ .slex-button--ghost:hover:not(:disabled):not(.slex-button--disabled) {
72
+ background: var(--accent);
73
+ color: var(--accent-foreground);
74
+ }
75
+
76
+ .slex-button:disabled,
77
+ .slex-button[disabled],
78
+ .slex-button--disabled {
79
+ opacity: 0.5;
80
+ cursor: not-allowed;
81
+ pointer-events: none;
82
+ transform: none;
83
+ box-shadow: none;
84
+ }
85
+
86
+ .slex-button:active:not(:disabled):not(.slex-button--disabled) {
87
+ transform: translateY(0);
88
+ box-shadow: var(--shadow-sm);
89
+ }
90
+
91
+ .slex-button:focus-visible {
92
+ outline: 2px solid var(--ring);
93
+ outline-offset: 2px;
94
+ }
95
+
96
+ .slex-button--icon {
97
+ width: var(--slex-control-height, 2.25rem);
98
+ min-height: var(--slex-control-height, 2.25rem);
99
+ padding-inline: 0;
100
+ }
101
+
102
102
  .slex-button-icon {
103
103
  display: inline-flex;
104
104
  width: 1.125rem;
@@ -1,15 +1,15 @@
1
- .slex-checkbox-field,
2
- .slex-radio-field {
3
- display: inline-flex;
4
- align-items: center;
5
- gap: 0.5rem;
6
- color: var(--foreground);
7
- font-size: 0.875rem;
8
- cursor: pointer;
9
- user-select: none;
10
- transition: color 150ms ease, opacity 150ms ease;
11
- }
12
-
1
+ .slex-checkbox-field,
2
+ .slex-radio-field {
3
+ display: inline-flex;
4
+ align-items: center;
5
+ gap: 0.5rem;
6
+ color: var(--foreground);
7
+ font-size: 0.875rem;
8
+ cursor: pointer;
9
+ user-select: none;
10
+ transition: color 150ms ease, opacity 150ms ease;
11
+ }
12
+
13
13
  .slex-checkbox-label,
14
14
  .slex-radio-label {
15
15
  display: inline-flex;
@@ -17,149 +17,149 @@
17
17
  gap: 0.375rem;
18
18
  min-width: 0;
19
19
  color: var(--foreground);
20
- line-height: 1.35;
21
- transition: color 150ms ease;
22
- }
23
-
24
- .slex-checkbox,
25
- .slex-radio {
26
- box-sizing: border-box;
27
- position: relative;
28
- display: inline-grid;
29
- place-items: center;
30
- flex: 0 0 auto;
31
- width: 1rem;
32
- height: 1rem;
33
- margin: 0;
34
- border: 1.5px solid var(--input);
35
- color: var(--primary);
36
- accent-color: var(--primary);
37
- background: var(--background);
38
- cursor: pointer;
39
- appearance: none;
40
- -webkit-appearance: none;
41
- transition:
42
- background-color 150ms ease,
43
- border-color 150ms ease,
44
- box-shadow 150ms ease,
45
- transform 120ms ease;
46
- }
47
-
48
- .slex-checkbox {
49
- border-radius: calc(var(--radius) - 4px);
50
- }
51
-
52
- .slex-radio {
53
- border-radius: 999px;
54
- }
55
-
56
- .slex-checkbox::after,
57
- .slex-radio::after {
58
- content: "";
59
- display: block;
60
- opacity: 0;
61
- transform: scale(0.5);
62
- transition: opacity 120ms ease, transform 140ms ease;
63
- }
64
-
65
- .slex-checkbox::after {
66
- width: 0.55rem;
67
- height: 0.34rem;
68
- border: solid var(--primary-foreground);
69
- border-width: 0 0 2px 2px;
70
- transform: translateY(-0.08rem) rotate(-45deg) scale(0.5);
71
- }
72
-
73
- .slex-radio::after {
74
- width: 0.45rem;
75
- height: 0.45rem;
76
- border-radius: 999px;
77
- background: var(--primary-foreground);
78
- }
79
-
80
- .slex-checkbox-field:hover .slex-checkbox:not(:disabled),
81
- .slex-radio-field:hover .slex-radio:not(:disabled) {
82
- border-color: color-mix(in oklab, var(--primary) 48%, var(--input));
83
- box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 8%, transparent);
84
- }
85
-
86
- .slex-checkbox-field:active .slex-checkbox:not(:disabled),
87
- .slex-radio-field:active .slex-radio:not(:disabled) {
88
- transform: scale(0.92);
89
- box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
90
- }
91
-
92
- .slex-checkbox:checked,
93
- .slex-radio:checked {
94
- border-color: var(--primary);
95
- background: var(--primary);
96
- }
97
-
98
- .slex-checkbox:checked::after,
99
- .slex-radio:checked::after {
100
- opacity: 1;
101
- }
102
-
103
- .slex-checkbox:checked::after {
104
- transform: translateY(-0.08rem) rotate(-45deg) scale(1);
105
- }
106
-
107
- .slex-radio:checked::after {
108
- transform: scale(1);
109
- }
110
-
111
- .slex-checkbox-field:hover .slex-checkbox-label,
112
- .slex-radio-field:hover .slex-radio-label {
113
- color: var(--foreground);
114
- }
115
-
116
- .slex-checkbox:focus-visible,
117
- .slex-radio:focus-visible {
118
- outline: 2px solid var(--ring);
119
- outline-offset: 2px;
120
- }
121
-
122
- .slex-radio-group {
123
- display: flex;
124
- flex-direction: column;
125
- gap: 0.625rem;
126
- }
127
-
20
+ line-height: 1.35;
21
+ transition: color 150ms ease;
22
+ }
23
+
24
+ .slex-checkbox,
25
+ .slex-radio {
26
+ box-sizing: border-box;
27
+ position: relative;
28
+ display: inline-grid;
29
+ place-items: center;
30
+ flex: 0 0 auto;
31
+ width: 1rem;
32
+ height: 1rem;
33
+ margin: 0;
34
+ border: 1.5px solid var(--input);
35
+ color: var(--primary);
36
+ accent-color: var(--primary);
37
+ background: var(--background);
38
+ cursor: pointer;
39
+ appearance: none;
40
+ -webkit-appearance: none;
41
+ transition:
42
+ background-color 150ms ease,
43
+ border-color 150ms ease,
44
+ box-shadow 150ms ease,
45
+ transform 120ms ease;
46
+ }
47
+
48
+ .slex-checkbox {
49
+ border-radius: calc(var(--radius) - 4px);
50
+ }
51
+
52
+ .slex-radio {
53
+ border-radius: 999px;
54
+ }
55
+
56
+ .slex-checkbox::after,
57
+ .slex-radio::after {
58
+ content: "";
59
+ display: block;
60
+ opacity: 0;
61
+ transform: scale(0.5);
62
+ transition: opacity 120ms ease, transform 140ms ease;
63
+ }
64
+
65
+ .slex-checkbox::after {
66
+ width: 0.55rem;
67
+ height: 0.34rem;
68
+ border: solid var(--primary-foreground);
69
+ border-width: 0 0 2px 2px;
70
+ transform: translateY(-0.08rem) rotate(-45deg) scale(0.5);
71
+ }
72
+
73
+ .slex-radio::after {
74
+ width: 0.45rem;
75
+ height: 0.45rem;
76
+ border-radius: 999px;
77
+ background: var(--primary-foreground);
78
+ }
79
+
80
+ .slex-checkbox-field:hover .slex-checkbox:not(:disabled),
81
+ .slex-radio-field:hover .slex-radio:not(:disabled) {
82
+ border-color: color-mix(in oklab, var(--primary) 48%, var(--input));
83
+ box-shadow: 0 0 0 4px color-mix(in oklab, var(--primary) 8%, transparent);
84
+ }
85
+
86
+ .slex-checkbox-field:active .slex-checkbox:not(:disabled),
87
+ .slex-radio-field:active .slex-radio:not(:disabled) {
88
+ transform: scale(0.92);
89
+ box-shadow: 0 0 0 5px color-mix(in oklab, var(--primary) 12%, transparent);
90
+ }
91
+
92
+ .slex-checkbox:checked,
93
+ .slex-radio:checked {
94
+ border-color: var(--primary);
95
+ background: var(--primary);
96
+ }
97
+
98
+ .slex-checkbox:checked::after,
99
+ .slex-radio:checked::after {
100
+ opacity: 1;
101
+ }
102
+
103
+ .slex-checkbox:checked::after {
104
+ transform: translateY(-0.08rem) rotate(-45deg) scale(1);
105
+ }
106
+
107
+ .slex-radio:checked::after {
108
+ transform: scale(1);
109
+ }
110
+
111
+ .slex-checkbox-field:hover .slex-checkbox-label,
112
+ .slex-radio-field:hover .slex-radio-label {
113
+ color: var(--foreground);
114
+ }
115
+
116
+ .slex-checkbox:focus-visible,
117
+ .slex-radio:focus-visible {
118
+ outline: 2px solid var(--ring);
119
+ outline-offset: 2px;
120
+ }
121
+
122
+ .slex-radio-group {
123
+ display: flex;
124
+ flex-direction: column;
125
+ gap: 0.625rem;
126
+ }
127
+
128
128
  .slex-radio-group-label {
129
129
  display: inline-flex;
130
130
  align-items: center;
131
131
  gap: 0.375rem;
132
132
  min-width: 0;
133
133
  color: var(--foreground);
134
- font-size: 0.875rem;
135
- font-weight: 500;
136
- }
137
-
138
- .slex-radio-group-list {
139
- display: flex;
140
- flex-direction: column;
141
- gap: 0.5rem;
142
- }
143
-
144
- .slex-radio-group[data-orientation="horizontal"] .slex-radio-group-list {
145
- flex-direction: row;
146
- flex-wrap: wrap;
147
- }
148
-
149
- .slex-checkbox:disabled,
150
- .slex-radio:disabled {
151
- cursor: not-allowed;
152
- opacity: 0.5;
153
- box-shadow: none;
154
- transform: none;
155
- }
156
-
157
- .slex-checkbox-field:has(.slex-checkbox:disabled),
158
- .slex-radio-field:has(.slex-radio:disabled) {
159
- cursor: not-allowed;
160
- opacity: 0.65;
161
- }
162
-
163
- .slex-radio-indicator {
164
- display: none;
134
+ font-size: 0.875rem;
135
+ font-weight: 500;
136
+ }
137
+
138
+ .slex-radio-group-list {
139
+ display: flex;
140
+ flex-direction: column;
141
+ gap: 0.5rem;
142
+ }
143
+
144
+ .slex-radio-group[data-orientation="horizontal"] .slex-radio-group-list {
145
+ flex-direction: row;
146
+ flex-wrap: wrap;
147
+ }
148
+
149
+ .slex-checkbox:disabled,
150
+ .slex-radio:disabled {
151
+ cursor: not-allowed;
152
+ opacity: 0.5;
153
+ box-shadow: none;
154
+ transform: none;
155
+ }
156
+
157
+ .slex-checkbox-field:has(.slex-checkbox:disabled),
158
+ .slex-radio-field:has(.slex-radio:disabled) {
159
+ cursor: not-allowed;
160
+ opacity: 0.65;
161
+ }
162
+
163
+ .slex-radio-indicator {
164
+ display: none;
165
165
  }