sv5ui 0.0.1

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.
Files changed (144) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +124 -0
  3. package/dist/Alert/Alert.svelte +120 -0
  4. package/dist/Alert/Alert.svelte.d.ts +5 -0
  5. package/dist/Alert/alert.types.d.ts +99 -0
  6. package/dist/Alert/alert.types.js +1 -0
  7. package/dist/Alert/alert.variants.d.ts +213 -0
  8. package/dist/Alert/alert.variants.js +293 -0
  9. package/dist/Alert/index.d.ts +2 -0
  10. package/dist/Alert/index.js +1 -0
  11. package/dist/Avatar/Avatar.svelte +70 -0
  12. package/dist/Avatar/Avatar.svelte.d.ts +6 -0
  13. package/dist/Avatar/avatar.types.d.ts +40 -0
  14. package/dist/Avatar/avatar.types.js +1 -0
  15. package/dist/Avatar/avatar.variants.d.ts +178 -0
  16. package/dist/Avatar/avatar.variants.js +28 -0
  17. package/dist/Avatar/index.d.ts +2 -0
  18. package/dist/Avatar/index.js +1 -0
  19. package/dist/AvatarGroup/AvatarGroup.svelte +66 -0
  20. package/dist/AvatarGroup/AvatarGroup.svelte.d.ts +5 -0
  21. package/dist/AvatarGroup/avatar-group.types.d.ts +34 -0
  22. package/dist/AvatarGroup/avatar-group.types.js +1 -0
  23. package/dist/AvatarGroup/avatar-group.variants.d.ts +173 -0
  24. package/dist/AvatarGroup/avatar-group.variants.js +45 -0
  25. package/dist/AvatarGroup/index.d.ts +2 -0
  26. package/dist/AvatarGroup/index.js +1 -0
  27. package/dist/Badge/Badge.svelte +74 -0
  28. package/dist/Badge/Badge.svelte.d.ts +5 -0
  29. package/dist/Badge/badge.types.d.ts +74 -0
  30. package/dist/Badge/badge.types.js +1 -0
  31. package/dist/Badge/badge.variants.d.ts +303 -0
  32. package/dist/Badge/badge.variants.js +245 -0
  33. package/dist/Badge/index.d.ts +2 -0
  34. package/dist/Badge/index.js +1 -0
  35. package/dist/Button/Button.svelte +103 -0
  36. package/dist/Button/Button.svelte.d.ts +6 -0
  37. package/dist/Button/button.types.d.ts +97 -0
  38. package/dist/Button/button.types.js +1 -0
  39. package/dist/Button/button.variants.d.ts +388 -0
  40. package/dist/Button/button.variants.js +461 -0
  41. package/dist/Button/index.d.ts +2 -0
  42. package/dist/Button/index.js +1 -0
  43. package/dist/Card/Card.svelte +53 -0
  44. package/dist/Card/Card.svelte.d.ts +5 -0
  45. package/dist/Card/card.types.d.ts +32 -0
  46. package/dist/Card/card.types.js +1 -0
  47. package/dist/Card/card.variants.d.ts +108 -0
  48. package/dist/Card/card.variants.js +32 -0
  49. package/dist/Card/index.d.ts +2 -0
  50. package/dist/Card/index.js +1 -0
  51. package/dist/Chip/Chip.svelte +50 -0
  52. package/dist/Chip/Chip.svelte.d.ts +5 -0
  53. package/dist/Chip/chip.types.d.ts +62 -0
  54. package/dist/Chip/chip.types.js +1 -0
  55. package/dist/Chip/chip.variants.d.ts +328 -0
  56. package/dist/Chip/chip.variants.js +58 -0
  57. package/dist/Chip/index.d.ts +2 -0
  58. package/dist/Chip/index.js +1 -0
  59. package/dist/Container/Container.svelte +27 -0
  60. package/dist/Container/Container.svelte.d.ts +5 -0
  61. package/dist/Container/container.types.d.ts +19 -0
  62. package/dist/Container/container.types.js +1 -0
  63. package/dist/Container/container.variants.d.ts +29 -0
  64. package/dist/Container/container.variants.js +9 -0
  65. package/dist/Container/index.d.ts +2 -0
  66. package/dist/Container/index.js +1 -0
  67. package/dist/Empty/Empty.svelte +83 -0
  68. package/dist/Empty/Empty.svelte.d.ts +5 -0
  69. package/dist/Empty/empty.types.d.ts +74 -0
  70. package/dist/Empty/empty.types.js +1 -0
  71. package/dist/Empty/empty.variants.d.ts +288 -0
  72. package/dist/Empty/empty.variants.js +364 -0
  73. package/dist/Empty/index.d.ts +2 -0
  74. package/dist/Empty/index.js +1 -0
  75. package/dist/Icon/Icon.svelte +40 -0
  76. package/dist/Icon/Icon.svelte.d.ts +6 -0
  77. package/dist/Icon/icon.types.d.ts +37 -0
  78. package/dist/Icon/icon.types.js +1 -0
  79. package/dist/Icon/index.d.ts +2 -0
  80. package/dist/Icon/index.js +1 -0
  81. package/dist/Kbd/Kbd.svelte +35 -0
  82. package/dist/Kbd/Kbd.svelte.d.ts +5 -0
  83. package/dist/Kbd/index.d.ts +3 -0
  84. package/dist/Kbd/index.js +2 -0
  85. package/dist/Kbd/kbd.types.d.ts +77 -0
  86. package/dist/Kbd/kbd.types.js +1 -0
  87. package/dist/Kbd/kbd.variants.d.ts +118 -0
  88. package/dist/Kbd/kbd.variants.js +96 -0
  89. package/dist/Kbd/useKbd.svelte.d.ts +29 -0
  90. package/dist/Kbd/useKbd.svelte.js +245 -0
  91. package/dist/Link/Link.svelte +117 -0
  92. package/dist/Link/Link.svelte.d.ts +5 -0
  93. package/dist/Link/index.d.ts +2 -0
  94. package/dist/Link/index.js +1 -0
  95. package/dist/Link/link.types.d.ts +68 -0
  96. package/dist/Link/link.types.js +1 -0
  97. package/dist/Link/link.variants.d.ts +138 -0
  98. package/dist/Link/link.variants.js +145 -0
  99. package/dist/Progress/Progress.svelte +89 -0
  100. package/dist/Progress/Progress.svelte.d.ts +6 -0
  101. package/dist/Progress/index.d.ts +2 -0
  102. package/dist/Progress/index.js +1 -0
  103. package/dist/Progress/progress.types.d.ts +63 -0
  104. package/dist/Progress/progress.types.js +1 -0
  105. package/dist/Progress/progress.variants.d.ts +483 -0
  106. package/dist/Progress/progress.variants.js +190 -0
  107. package/dist/Separator/Separator.svelte +67 -0
  108. package/dist/Separator/Separator.svelte.d.ts +6 -0
  109. package/dist/Separator/index.d.ts +2 -0
  110. package/dist/Separator/index.js +1 -0
  111. package/dist/Separator/separator.types.d.ts +48 -0
  112. package/dist/Separator/separator.types.js +1 -0
  113. package/dist/Separator/separator.variants.d.ts +488 -0
  114. package/dist/Separator/separator.variants.js +104 -0
  115. package/dist/Skeleton/Skeleton.svelte +31 -0
  116. package/dist/Skeleton/Skeleton.svelte.d.ts +5 -0
  117. package/dist/Skeleton/index.d.ts +2 -0
  118. package/dist/Skeleton/index.js +1 -0
  119. package/dist/Skeleton/skeleton.types.d.ts +18 -0
  120. package/dist/Skeleton/skeleton.types.js +1 -0
  121. package/dist/Skeleton/skeleton.variants.d.ts +18 -0
  122. package/dist/Skeleton/skeleton.variants.js +12 -0
  123. package/dist/Timeline/Timeline.svelte +106 -0
  124. package/dist/Timeline/Timeline.svelte.d.ts +5 -0
  125. package/dist/Timeline/index.d.ts +2 -0
  126. package/dist/Timeline/index.js +1 -0
  127. package/dist/Timeline/timeline.types.d.ts +130 -0
  128. package/dist/Timeline/timeline.types.js +1 -0
  129. package/dist/Timeline/timeline.variants.d.ts +413 -0
  130. package/dist/Timeline/timeline.variants.js +121 -0
  131. package/dist/User/User.svelte +94 -0
  132. package/dist/User/User.svelte.d.ts +5 -0
  133. package/dist/User/index.d.ts +2 -0
  134. package/dist/User/index.js +1 -0
  135. package/dist/User/user.types.d.ts +74 -0
  136. package/dist/User/user.types.js +1 -0
  137. package/dist/User/user.variants.d.ts +308 -0
  138. package/dist/User/user.variants.js +73 -0
  139. package/dist/config.d.ts +59 -0
  140. package/dist/config.js +94 -0
  141. package/dist/index.d.ts +19 -0
  142. package/dist/index.js +20 -0
  143. package/dist/theme.css +410 -0
  144. package/package.json +104 -0
@@ -0,0 +1,303 @@
1
+ import { type VariantProps } from 'tailwind-variants';
2
+ export declare const badgeVariants: import("tailwind-variants").TVReturnType<{
3
+ variant: {
4
+ solid: string;
5
+ outline: string;
6
+ soft: string;
7
+ subtle: string;
8
+ };
9
+ color: {
10
+ primary: string;
11
+ secondary: string;
12
+ tertiary: string;
13
+ success: string;
14
+ warning: string;
15
+ error: string;
16
+ info: string;
17
+ surface: string;
18
+ };
19
+ size: {
20
+ xs: {
21
+ base: string;
22
+ leadingIcon: string;
23
+ leadingAvatarSize: string;
24
+ trailingIcon: string;
25
+ };
26
+ sm: {
27
+ base: string;
28
+ leadingIcon: string;
29
+ leadingAvatarSize: string;
30
+ trailingIcon: string;
31
+ };
32
+ md: {
33
+ base: string;
34
+ leadingIcon: string;
35
+ leadingAvatarSize: string;
36
+ trailingIcon: string;
37
+ };
38
+ lg: {
39
+ base: string;
40
+ leadingIcon: string;
41
+ leadingAvatarSize: string;
42
+ trailingIcon: string;
43
+ };
44
+ xl: {
45
+ base: string;
46
+ leadingIcon: string;
47
+ leadingAvatarSize: string;
48
+ trailingIcon: string;
49
+ };
50
+ };
51
+ square: {
52
+ true: string;
53
+ };
54
+ }, {
55
+ base: string;
56
+ label: string;
57
+ leadingIcon: string;
58
+ leadingAvatar: string;
59
+ leadingAvatarSize: string;
60
+ trailingIcon: string;
61
+ }, undefined, {
62
+ variant: {
63
+ solid: string;
64
+ outline: string;
65
+ soft: string;
66
+ subtle: string;
67
+ };
68
+ color: {
69
+ primary: string;
70
+ secondary: string;
71
+ tertiary: string;
72
+ success: string;
73
+ warning: string;
74
+ error: string;
75
+ info: string;
76
+ surface: string;
77
+ };
78
+ size: {
79
+ xs: {
80
+ base: string;
81
+ leadingIcon: string;
82
+ leadingAvatarSize: string;
83
+ trailingIcon: string;
84
+ };
85
+ sm: {
86
+ base: string;
87
+ leadingIcon: string;
88
+ leadingAvatarSize: string;
89
+ trailingIcon: string;
90
+ };
91
+ md: {
92
+ base: string;
93
+ leadingIcon: string;
94
+ leadingAvatarSize: string;
95
+ trailingIcon: string;
96
+ };
97
+ lg: {
98
+ base: string;
99
+ leadingIcon: string;
100
+ leadingAvatarSize: string;
101
+ trailingIcon: string;
102
+ };
103
+ xl: {
104
+ base: string;
105
+ leadingIcon: string;
106
+ leadingAvatarSize: string;
107
+ trailingIcon: string;
108
+ };
109
+ };
110
+ square: {
111
+ true: string;
112
+ };
113
+ }, {
114
+ base: string;
115
+ label: string;
116
+ leadingIcon: string;
117
+ leadingAvatar: string;
118
+ leadingAvatarSize: string;
119
+ trailingIcon: string;
120
+ }, import("tailwind-variants").TVReturnType<{
121
+ variant: {
122
+ solid: string;
123
+ outline: string;
124
+ soft: string;
125
+ subtle: string;
126
+ };
127
+ color: {
128
+ primary: string;
129
+ secondary: string;
130
+ tertiary: string;
131
+ success: string;
132
+ warning: string;
133
+ error: string;
134
+ info: string;
135
+ surface: string;
136
+ };
137
+ size: {
138
+ xs: {
139
+ base: string;
140
+ leadingIcon: string;
141
+ leadingAvatarSize: string;
142
+ trailingIcon: string;
143
+ };
144
+ sm: {
145
+ base: string;
146
+ leadingIcon: string;
147
+ leadingAvatarSize: string;
148
+ trailingIcon: string;
149
+ };
150
+ md: {
151
+ base: string;
152
+ leadingIcon: string;
153
+ leadingAvatarSize: string;
154
+ trailingIcon: string;
155
+ };
156
+ lg: {
157
+ base: string;
158
+ leadingIcon: string;
159
+ leadingAvatarSize: string;
160
+ trailingIcon: string;
161
+ };
162
+ xl: {
163
+ base: string;
164
+ leadingIcon: string;
165
+ leadingAvatarSize: string;
166
+ trailingIcon: string;
167
+ };
168
+ };
169
+ square: {
170
+ true: string;
171
+ };
172
+ }, {
173
+ base: string;
174
+ label: string;
175
+ leadingIcon: string;
176
+ leadingAvatar: string;
177
+ leadingAvatarSize: string;
178
+ trailingIcon: string;
179
+ }, undefined, unknown, unknown, undefined>>;
180
+ export type BadgeVariantProps = VariantProps<typeof badgeVariants>;
181
+ export type BadgeSlots = keyof ReturnType<typeof badgeVariants>;
182
+ export declare const badgeDefaults: {
183
+ defaultVariants: import("tailwind-variants").TVDefaultVariants<{
184
+ variant: {
185
+ solid: string;
186
+ outline: string;
187
+ soft: string;
188
+ subtle: string;
189
+ };
190
+ color: {
191
+ primary: string;
192
+ secondary: string;
193
+ tertiary: string;
194
+ success: string;
195
+ warning: string;
196
+ error: string;
197
+ info: string;
198
+ surface: string;
199
+ };
200
+ size: {
201
+ xs: {
202
+ base: string;
203
+ leadingIcon: string;
204
+ leadingAvatarSize: string;
205
+ trailingIcon: string;
206
+ };
207
+ sm: {
208
+ base: string;
209
+ leadingIcon: string;
210
+ leadingAvatarSize: string;
211
+ trailingIcon: string;
212
+ };
213
+ md: {
214
+ base: string;
215
+ leadingIcon: string;
216
+ leadingAvatarSize: string;
217
+ trailingIcon: string;
218
+ };
219
+ lg: {
220
+ base: string;
221
+ leadingIcon: string;
222
+ leadingAvatarSize: string;
223
+ trailingIcon: string;
224
+ };
225
+ xl: {
226
+ base: string;
227
+ leadingIcon: string;
228
+ leadingAvatarSize: string;
229
+ trailingIcon: string;
230
+ };
231
+ };
232
+ square: {
233
+ true: string;
234
+ };
235
+ }, {
236
+ base: string;
237
+ label: string;
238
+ leadingIcon: string;
239
+ leadingAvatar: string;
240
+ leadingAvatarSize: string;
241
+ trailingIcon: string;
242
+ }, {
243
+ variant: {
244
+ solid: string;
245
+ outline: string;
246
+ soft: string;
247
+ subtle: string;
248
+ };
249
+ color: {
250
+ primary: string;
251
+ secondary: string;
252
+ tertiary: string;
253
+ success: string;
254
+ warning: string;
255
+ error: string;
256
+ info: string;
257
+ surface: string;
258
+ };
259
+ size: {
260
+ xs: {
261
+ base: string;
262
+ leadingIcon: string;
263
+ leadingAvatarSize: string;
264
+ trailingIcon: string;
265
+ };
266
+ sm: {
267
+ base: string;
268
+ leadingIcon: string;
269
+ leadingAvatarSize: string;
270
+ trailingIcon: string;
271
+ };
272
+ md: {
273
+ base: string;
274
+ leadingIcon: string;
275
+ leadingAvatarSize: string;
276
+ trailingIcon: string;
277
+ };
278
+ lg: {
279
+ base: string;
280
+ leadingIcon: string;
281
+ leadingAvatarSize: string;
282
+ trailingIcon: string;
283
+ };
284
+ xl: {
285
+ base: string;
286
+ leadingIcon: string;
287
+ leadingAvatarSize: string;
288
+ trailingIcon: string;
289
+ };
290
+ };
291
+ square: {
292
+ true: string;
293
+ };
294
+ }, {
295
+ base: string;
296
+ label: string;
297
+ leadingIcon: string;
298
+ leadingAvatar: string;
299
+ leadingAvatarSize: string;
300
+ trailingIcon: string;
301
+ }>;
302
+ slots: Partial<Record<BadgeSlots, string>>;
303
+ };
@@ -0,0 +1,245 @@
1
+ import { tv } from 'tailwind-variants';
2
+ export const badgeVariants = tv({
3
+ slots: {
4
+ base: 'font-medium inline-flex items-center',
5
+ label: 'truncate',
6
+ leadingIcon: 'shrink-0',
7
+ leadingAvatar: 'shrink-0',
8
+ leadingAvatarSize: '',
9
+ trailingIcon: 'shrink-0'
10
+ },
11
+ variants: {
12
+ variant: {
13
+ solid: '',
14
+ outline: '',
15
+ soft: '',
16
+ subtle: ''
17
+ },
18
+ color: {
19
+ primary: '',
20
+ secondary: '',
21
+ tertiary: '',
22
+ success: '',
23
+ warning: '',
24
+ error: '',
25
+ info: '',
26
+ surface: ''
27
+ },
28
+ size: {
29
+ xs: {
30
+ base: 'text-[8px]/3 px-1 py-0.5 gap-1 rounded-sm',
31
+ leadingIcon: 'size-3',
32
+ leadingAvatarSize: '3xs',
33
+ trailingIcon: 'size-3'
34
+ },
35
+ sm: {
36
+ base: 'text-[10px]/3 px-1.5 py-1 gap-1 rounded-sm',
37
+ leadingIcon: 'size-3',
38
+ leadingAvatarSize: '3xs',
39
+ trailingIcon: 'size-3'
40
+ },
41
+ md: {
42
+ base: 'text-xs px-2 py-1 gap-1 rounded-md',
43
+ leadingIcon: 'size-4',
44
+ leadingAvatarSize: '3xs',
45
+ trailingIcon: 'size-4'
46
+ },
47
+ lg: {
48
+ base: 'text-sm px-2 py-1 gap-1.5 rounded-md',
49
+ leadingIcon: 'size-5',
50
+ leadingAvatarSize: '2xs',
51
+ trailingIcon: 'size-5'
52
+ },
53
+ xl: {
54
+ base: 'text-base px-2.5 py-1 gap-1.5 rounded-md',
55
+ leadingIcon: 'size-6',
56
+ leadingAvatarSize: '2xs',
57
+ trailingIcon: 'size-6'
58
+ }
59
+ },
60
+ square: {
61
+ true: ''
62
+ }
63
+ },
64
+ compoundVariants: [
65
+ // ========== SOLID VARIANTS ==========
66
+ {
67
+ variant: 'solid',
68
+ color: 'primary',
69
+ class: { base: 'bg-primary text-on-primary' }
70
+ },
71
+ {
72
+ variant: 'solid',
73
+ color: 'secondary',
74
+ class: { base: 'bg-secondary text-on-secondary' }
75
+ },
76
+ {
77
+ variant: 'solid',
78
+ color: 'tertiary',
79
+ class: { base: 'bg-tertiary text-on-tertiary' }
80
+ },
81
+ {
82
+ variant: 'solid',
83
+ color: 'success',
84
+ class: { base: 'bg-success text-on-success' }
85
+ },
86
+ {
87
+ variant: 'solid',
88
+ color: 'warning',
89
+ class: { base: 'bg-warning text-on-warning' }
90
+ },
91
+ {
92
+ variant: 'solid',
93
+ color: 'error',
94
+ class: { base: 'bg-error text-on-error' }
95
+ },
96
+ {
97
+ variant: 'solid',
98
+ color: 'info',
99
+ class: { base: 'bg-info text-on-info' }
100
+ },
101
+ {
102
+ variant: 'solid',
103
+ color: 'surface',
104
+ class: { base: 'bg-inverse-surface text-inverse-on-surface' }
105
+ },
106
+ // ========== OUTLINE VARIANTS ==========
107
+ {
108
+ variant: 'outline',
109
+ color: 'primary',
110
+ class: { base: 'text-primary ring ring-inset ring-primary/50' }
111
+ },
112
+ {
113
+ variant: 'outline',
114
+ color: 'secondary',
115
+ class: { base: 'text-secondary ring ring-inset ring-secondary/50' }
116
+ },
117
+ {
118
+ variant: 'outline',
119
+ color: 'tertiary',
120
+ class: { base: 'text-tertiary ring ring-inset ring-tertiary/50' }
121
+ },
122
+ {
123
+ variant: 'outline',
124
+ color: 'success',
125
+ class: { base: 'text-success ring ring-inset ring-success/50' }
126
+ },
127
+ {
128
+ variant: 'outline',
129
+ color: 'warning',
130
+ class: { base: 'text-warning ring ring-inset ring-warning/50' }
131
+ },
132
+ {
133
+ variant: 'outline',
134
+ color: 'error',
135
+ class: { base: 'text-error ring ring-inset ring-error/50' }
136
+ },
137
+ {
138
+ variant: 'outline',
139
+ color: 'info',
140
+ class: { base: 'text-info ring ring-inset ring-info/50' }
141
+ },
142
+ {
143
+ variant: 'outline',
144
+ color: 'surface',
145
+ class: { base: 'text-on-surface-variant ring ring-inset ring-outline-variant' }
146
+ },
147
+ // ========== SOFT VARIANTS ==========
148
+ {
149
+ variant: 'soft',
150
+ color: 'primary',
151
+ class: { base: 'bg-primary-container text-on-primary-container' }
152
+ },
153
+ {
154
+ variant: 'soft',
155
+ color: 'secondary',
156
+ class: { base: 'bg-secondary-container text-on-secondary-container' }
157
+ },
158
+ {
159
+ variant: 'soft',
160
+ color: 'tertiary',
161
+ class: { base: 'bg-tertiary-container text-on-tertiary-container' }
162
+ },
163
+ {
164
+ variant: 'soft',
165
+ color: 'success',
166
+ class: { base: 'bg-success-container text-on-success-container' }
167
+ },
168
+ {
169
+ variant: 'soft',
170
+ color: 'warning',
171
+ class: { base: 'bg-warning-container text-on-warning-container' }
172
+ },
173
+ {
174
+ variant: 'soft',
175
+ color: 'error',
176
+ class: { base: 'bg-error-container text-on-error-container' }
177
+ },
178
+ {
179
+ variant: 'soft',
180
+ color: 'info',
181
+ class: { base: 'bg-info-container text-on-info-container' }
182
+ },
183
+ {
184
+ variant: 'soft',
185
+ color: 'surface',
186
+ class: { base: 'bg-surface-container-highest text-on-surface' }
187
+ },
188
+ // ========== SUBTLE VARIANTS ==========
189
+ {
190
+ variant: 'subtle',
191
+ color: 'primary',
192
+ class: { base: 'bg-primary-container text-on-primary-container ring ring-inset ring-primary/25' }
193
+ },
194
+ {
195
+ variant: 'subtle',
196
+ color: 'secondary',
197
+ class: { base: 'bg-secondary-container text-on-secondary-container ring ring-inset ring-secondary/25' }
198
+ },
199
+ {
200
+ variant: 'subtle',
201
+ color: 'tertiary',
202
+ class: { base: 'bg-tertiary-container text-on-tertiary-container ring ring-inset ring-tertiary/25' }
203
+ },
204
+ {
205
+ variant: 'subtle',
206
+ color: 'success',
207
+ class: { base: 'bg-success-container text-on-success-container ring ring-inset ring-success/25' }
208
+ },
209
+ {
210
+ variant: 'subtle',
211
+ color: 'warning',
212
+ class: { base: 'bg-warning-container text-on-warning-container ring ring-inset ring-warning/25' }
213
+ },
214
+ {
215
+ variant: 'subtle',
216
+ color: 'error',
217
+ class: { base: 'bg-error-container text-on-error-container ring ring-inset ring-error/25' }
218
+ },
219
+ {
220
+ variant: 'subtle',
221
+ color: 'info',
222
+ class: { base: 'bg-info-container text-on-info-container ring ring-inset ring-info/25' }
223
+ },
224
+ {
225
+ variant: 'subtle',
226
+ color: 'surface',
227
+ class: { base: 'bg-surface-container-highest text-on-surface ring ring-inset ring-outline-variant' }
228
+ },
229
+ // ========== SQUARE SIZE ADJUSTMENTS ==========
230
+ { square: true, size: 'xs', class: { base: 'p-0.5' } },
231
+ { square: true, size: 'sm', class: { base: 'p-1' } },
232
+ { square: true, size: 'md', class: { base: 'p-1' } },
233
+ { square: true, size: 'lg', class: { base: 'p-1' } },
234
+ { square: true, size: 'xl', class: { base: 'p-1' } }
235
+ ],
236
+ defaultVariants: {
237
+ color: 'primary',
238
+ variant: 'solid',
239
+ size: 'md'
240
+ }
241
+ });
242
+ export const badgeDefaults = {
243
+ defaultVariants: badgeVariants.defaultVariants,
244
+ slots: {}
245
+ };
@@ -0,0 +1,2 @@
1
+ export { default as Badge } from './Badge.svelte';
2
+ export type { BadgeProps } from './badge.types.js';
@@ -0,0 +1 @@
1
+ export { default as Badge } from './Badge.svelte';
@@ -0,0 +1,103 @@
1
+ <script lang="ts" module>
2
+ import type { ButtonProps } from './button.types.js'
3
+
4
+ export type Props = ButtonProps
5
+ </script>
6
+
7
+ <script lang="ts">
8
+ import { Button } from 'bits-ui'
9
+ import { buttonVariants, buttonDefaults } from './button.variants.js'
10
+ import { getComponentConfig, iconsDefaults } from '../config.js'
11
+ import Icon from '../Icon/Icon.svelte'
12
+ import Avatar from '../Avatar/Avatar.svelte'
13
+ import type { AvatarSize } from '../Avatar/avatar.types.js'
14
+
15
+ const config = getComponentConfig('button', buttonDefaults)
16
+ const icons = getComponentConfig('icons', iconsDefaults)
17
+
18
+ let {
19
+ ref = $bindable(null),
20
+ ui,
21
+ color = config.defaultVariants.color,
22
+ variant = config.defaultVariants.variant,
23
+ size = config.defaultVariants.size,
24
+ label,
25
+ loading = false,
26
+ loadingIcon = icons.loading,
27
+ disabled = false,
28
+ block = false,
29
+ square = false,
30
+ truncate = false,
31
+ icon,
32
+ leadingIcon,
33
+ trailingIcon,
34
+ trailing = false,
35
+ avatar,
36
+ leadingSlot,
37
+ trailingSlot,
38
+ children,
39
+ class: className,
40
+ ...restProps
41
+ }: Props = $props()
42
+
43
+ const isIconOnly = $derived(square || (!label && !children))
44
+ const isLeading = $derived((!!icon && !trailing) || (loading && !trailing) || !!leadingIcon)
45
+ const isTrailing = $derived((!!icon && trailing) || (loading && trailing) || !!trailingIcon)
46
+
47
+ const leadingIconName = $derived(
48
+ loading && isLeading ? loadingIcon : (leadingIcon || (isLeading && !trailing ? icon : undefined))
49
+ )
50
+ const trailingIconName = $derived(
51
+ loading && isTrailing ? loadingIcon : (trailingIcon || (trailing ? icon : undefined))
52
+ )
53
+
54
+ const classes = $derived.by(() => {
55
+ const slots = buttonVariants({
56
+ variant,
57
+ color,
58
+ size,
59
+ block,
60
+ square: isIconOnly,
61
+ loading,
62
+ leading: isLeading,
63
+ trailing: isTrailing
64
+ })
65
+ return {
66
+ base: slots.base({ class: [config.slots.base, className, ui?.base] }),
67
+ label: slots.label({ class: [config.slots.label, ui?.label] }),
68
+ leadingIcon: slots.leadingIcon({ class: [config.slots.leadingIcon, ui?.leadingIcon] }),
69
+ trailingIcon: slots.trailingIcon({ class: [config.slots.trailingIcon, ui?.trailingIcon] }),
70
+ leadingAvatar: slots.leadingAvatar({ class: [config.slots.leadingAvatar, ui?.leadingAvatar] }),
71
+ leadingAvatarSize: slots.leadingAvatarSize() as AvatarSize
72
+ }
73
+ })
74
+ </script>
75
+
76
+ <Button.Root
77
+ bind:ref
78
+ class={classes.base}
79
+ disabled={disabled || loading}
80
+ {...restProps}
81
+ >
82
+ {#if leadingSlot}
83
+ {@render leadingSlot()}
84
+ {:else if isLeading && leadingIconName}
85
+ <Icon name={leadingIconName} class={classes.leadingIcon} />
86
+ {:else if avatar}
87
+ <Avatar {...avatar} size={classes.leadingAvatarSize} class={classes.leadingAvatar} />
88
+ {/if}
89
+
90
+ {#if !isIconOnly}
91
+ {#if label}
92
+ <span class={classes.label}>{label}</span>
93
+ {:else if children}
94
+ <span class={classes.label}>{@render children()}</span>
95
+ {/if}
96
+ {/if}
97
+
98
+ {#if trailingSlot}
99
+ {@render trailingSlot()}
100
+ {:else if isTrailing && trailingIconName}
101
+ <Icon name={trailingIconName} class={classes.trailingIcon} />
102
+ {/if}
103
+ </Button.Root>
@@ -0,0 +1,6 @@
1
+ import type { ButtonProps } from './button.types.js';
2
+ export type Props = ButtonProps;
3
+ import { Button } from 'bits-ui';
4
+ declare const Button: import("svelte").Component<ButtonProps, {}, "ref">;
5
+ type Button = ReturnType<typeof Button>;
6
+ export default Button;