ui-svelte 0.2.10 → 0.2.12

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 (206) hide show
  1. package/dist/charts/ArcChart.svelte +9 -13
  2. package/dist/charts/ArcChart.svelte.d.ts +3 -3
  3. package/dist/charts/AreaChart.svelte +347 -118
  4. package/dist/charts/AreaChart.svelte.d.ts +33 -4
  5. package/dist/charts/BarChart.svelte +288 -66
  6. package/dist/charts/BarChart.svelte.d.ts +26 -1
  7. package/dist/charts/Candlestick.svelte +53 -50
  8. package/dist/charts/Candlestick.svelte.d.ts +8 -8
  9. package/dist/charts/LineChart.svelte +391 -91
  10. package/dist/charts/LineChart.svelte.d.ts +26 -3
  11. package/dist/charts/PieChart.svelte +333 -92
  12. package/dist/charts/PieChart.svelte.d.ts +33 -5
  13. package/dist/charts/css/arc-chart.css +3 -3
  14. package/dist/charts/css/area-chart.css +127 -29
  15. package/dist/charts/css/bar-chart.css +114 -8
  16. package/dist/charts/css/candlestick.css +2 -0
  17. package/dist/charts/css/line-chart.css +111 -13
  18. package/dist/charts/css/pie-chart.css +92 -20
  19. package/dist/control/Audio.svelte +86 -44
  20. package/dist/control/Audio.svelte.d.ts +4 -1
  21. package/dist/control/Button.svelte +18 -27
  22. package/dist/control/Button.svelte.d.ts +3 -2
  23. package/dist/control/IconButton.svelte +17 -27
  24. package/dist/control/IconButton.svelte.d.ts +3 -3
  25. package/dist/control/Image.svelte +123 -0
  26. package/dist/control/Image.svelte.d.ts +13 -0
  27. package/dist/control/Record.svelte +144 -98
  28. package/dist/control/Record.svelte.d.ts +2 -1
  29. package/dist/control/ToggleGroup.svelte +22 -8
  30. package/dist/control/ToggleGroup.svelte.d.ts +2 -1
  31. package/dist/control/ToggleTheme.svelte +13 -11
  32. package/dist/control/ToggleTheme.svelte.d.ts +3 -2
  33. package/dist/control/Video.svelte +55 -29
  34. package/dist/control/Video.svelte.d.ts +1 -0
  35. package/dist/control/css/btn.css +200 -152
  36. package/dist/control/css/image.css +56 -0
  37. package/dist/control/css/media.css +95 -30
  38. package/dist/control/css/toggle-group.css +269 -84
  39. package/dist/control/css/video.css +1 -14
  40. package/dist/css/animations.css +427 -2
  41. package/dist/css/base.css +13 -347
  42. package/dist/css/decorations.css +402 -0
  43. package/dist/css/rich-text.css +485 -0
  44. package/dist/css/transitions.css +158 -0
  45. package/dist/css/typography.css +291 -0
  46. package/dist/display/Accordion.svelte +28 -4
  47. package/dist/display/Accordion.svelte.d.ts +2 -1
  48. package/dist/display/Alert.svelte +32 -12
  49. package/dist/display/Alert.svelte.d.ts +2 -3
  50. package/dist/display/Avatar.svelte +54 -26
  51. package/dist/display/Avatar.svelte.d.ts +7 -1
  52. package/dist/display/AvatarGroup.svelte +26 -18
  53. package/dist/display/AvatarGroup.svelte.d.ts +9 -3
  54. package/dist/display/Badge.svelte +11 -4
  55. package/dist/display/Badge.svelte.d.ts +2 -1
  56. package/dist/display/Card.svelte +15 -14
  57. package/dist/display/Card.svelte.d.ts +2 -3
  58. package/dist/display/Carousel.svelte +130 -99
  59. package/dist/display/Carousel.svelte.d.ts +6 -4
  60. package/dist/display/ChatBox.svelte +245 -106
  61. package/dist/display/ChatBox.svelte.d.ts +32 -5
  62. package/dist/display/Chip.svelte +31 -17
  63. package/dist/display/Chip.svelte.d.ts +3 -2
  64. package/dist/display/Code.svelte +6 -3
  65. package/dist/display/Code.svelte.d.ts +1 -0
  66. package/dist/display/Collapsible.svelte +30 -4
  67. package/dist/display/Collapsible.svelte.d.ts +2 -1
  68. package/dist/display/Empty.svelte +37 -3
  69. package/dist/display/Empty.svelte.d.ts +3 -0
  70. package/dist/display/Item.svelte +31 -18
  71. package/dist/display/Item.svelte.d.ts +2 -2
  72. package/dist/display/Map.svelte +488 -0
  73. package/dist/display/Map.svelte.d.ts +44 -0
  74. package/dist/display/Section.svelte +14 -12
  75. package/dist/display/Section.svelte.d.ts +2 -3
  76. package/dist/display/Skeleton.svelte +32 -0
  77. package/dist/display/Skeleton.svelte.d.ts +10 -0
  78. package/dist/display/Table.svelte +94 -132
  79. package/dist/display/Table.svelte.d.ts +10 -1
  80. package/dist/display/css/accordion.css +349 -52
  81. package/dist/display/css/alert.css +18 -25
  82. package/dist/display/css/avatar-group.css +38 -44
  83. package/dist/display/css/avatar.css +152 -123
  84. package/dist/display/css/badge.css +50 -27
  85. package/dist/display/css/card.css +51 -71
  86. package/dist/display/css/carousel.css +25 -5
  87. package/dist/display/css/chat-box.css +158 -26
  88. package/dist/display/css/chip.css +142 -68
  89. package/dist/display/css/code.css +2 -6
  90. package/dist/display/css/collapsible.css +349 -45
  91. package/dist/display/css/divider.css +8 -6
  92. package/dist/display/css/empty.css +7 -0
  93. package/dist/display/css/item.css +311 -89
  94. package/dist/display/css/map.css +164 -0
  95. package/dist/display/css/section.css +78 -33
  96. package/dist/display/css/skeleton.css +58 -0
  97. package/dist/display/css/table.css +320 -189
  98. package/dist/form/Checkbox.svelte +11 -5
  99. package/dist/form/Checkbox.svelte.d.ts +2 -1
  100. package/dist/form/ColorField.svelte +543 -0
  101. package/dist/form/ColorField.svelte.d.ts +29 -0
  102. package/dist/form/ComboBox.svelte +24 -9
  103. package/dist/form/ComboBox.svelte.d.ts +2 -2
  104. package/dist/form/CsvField.svelte +62 -136
  105. package/dist/form/CsvField.svelte.d.ts +2 -2
  106. package/dist/form/DateField.svelte +33 -15
  107. package/dist/form/DateField.svelte.d.ts +2 -1
  108. package/dist/form/DateRange.svelte +436 -0
  109. package/dist/form/DateRange.svelte.d.ts +24 -0
  110. package/dist/form/DragDrop.svelte +348 -0
  111. package/dist/form/DragDrop.svelte.d.ts +32 -0
  112. package/dist/form/Dropzone.svelte +28 -8
  113. package/dist/form/Dropzone.svelte.d.ts +2 -2
  114. package/dist/form/Editor.svelte +626 -0
  115. package/dist/form/Editor.svelte.d.ts +50 -0
  116. package/dist/form/ImageCropper.svelte +291 -61
  117. package/dist/form/ImageCropper.svelte.d.ts +15 -1
  118. package/dist/form/PasswordField.svelte +120 -75
  119. package/dist/form/PasswordField.svelte.d.ts +9 -10
  120. package/dist/form/PhoneField.svelte +34 -16
  121. package/dist/form/PhoneField.svelte.d.ts +4 -3
  122. package/dist/form/PinField.svelte +39 -31
  123. package/dist/form/PinField.svelte.d.ts +3 -3
  124. package/dist/form/RadioGroup.svelte +4 -4
  125. package/dist/form/RadioGroup.svelte.d.ts +1 -1
  126. package/dist/form/Select.svelte +20 -19
  127. package/dist/form/Select.svelte.d.ts +2 -2
  128. package/dist/form/Slider.svelte +4 -2
  129. package/dist/form/Slider.svelte.d.ts +1 -0
  130. package/dist/form/TextField.svelte +16 -7
  131. package/dist/form/TextField.svelte.d.ts +2 -2
  132. package/dist/form/Textarea.svelte +15 -6
  133. package/dist/form/Textarea.svelte.d.ts +2 -2
  134. package/dist/form/Toggle.svelte +11 -1
  135. package/dist/form/Toggle.svelte.d.ts +2 -0
  136. package/dist/form/css/checkbox.css +18 -2
  137. package/dist/form/css/color-field.css +141 -0
  138. package/dist/form/css/control.css +193 -82
  139. package/dist/form/css/csv-field.css +226 -0
  140. package/dist/form/css/date-range.css +122 -0
  141. package/dist/form/css/date.css +24 -2
  142. package/dist/form/css/drag-drop.css +271 -0
  143. package/dist/form/css/dropzone.css +153 -34
  144. package/dist/form/css/editor.css +367 -0
  145. package/dist/form/css/field.css +4 -0
  146. package/dist/form/css/image-cropper.css +223 -22
  147. package/dist/form/css/password.css +1 -1
  148. package/dist/form/css/radio-group.css +1 -1
  149. package/dist/form/css/select.css +2 -2
  150. package/dist/form/css/slider.css +1 -0
  151. package/dist/form/css/textarea.css +178 -75
  152. package/dist/form/css/toggle.css +11 -2
  153. package/dist/hooks/use-table.svelte.d.ts +1 -0
  154. package/dist/hooks/use-table.svelte.js +6 -0
  155. package/dist/icons/index.d.ts +38 -2
  156. package/dist/icons/index.js +40 -4
  157. package/dist/index.css +16 -1
  158. package/dist/index.d.ts +11 -3
  159. package/dist/index.js +10 -2
  160. package/dist/layout/AppBar.svelte +22 -14
  161. package/dist/layout/AppBar.svelte.d.ts +2 -1
  162. package/dist/layout/Footer.svelte +19 -11
  163. package/dist/layout/Footer.svelte.d.ts +2 -1
  164. package/dist/layout/Provider.svelte +27 -4
  165. package/dist/layout/Provider.svelte.d.ts +3 -1
  166. package/dist/layout/css/app-bar.css +63 -66
  167. package/dist/layout/css/footer.css +62 -65
  168. package/dist/navigation/BottomNav.svelte +41 -13
  169. package/dist/navigation/FooterGroup.svelte +1 -1
  170. package/dist/navigation/NavMenu.svelte +47 -23
  171. package/dist/navigation/NavMenu.svelte.d.ts +29 -0
  172. package/dist/navigation/Pagination.svelte +158 -0
  173. package/dist/navigation/Pagination.svelte.d.ts +18 -0
  174. package/dist/navigation/SideNav.svelte +30 -25
  175. package/dist/navigation/SideNav.svelte.d.ts +2 -3
  176. package/dist/navigation/Tabs.svelte +17 -7
  177. package/dist/navigation/Tabs.svelte.d.ts +2 -2
  178. package/dist/navigation/css/bottom-nav.css +279 -257
  179. package/dist/navigation/css/footer-group.css +1 -1
  180. package/dist/navigation/css/footer-nav.css +1 -1
  181. package/dist/navigation/css/nav-menu.css +332 -106
  182. package/dist/navigation/css/pagination.css +74 -0
  183. package/dist/navigation/css/side-nav.css +515 -75
  184. package/dist/navigation/css/tabs.css +246 -52
  185. package/dist/overlay/Command.svelte +340 -0
  186. package/dist/overlay/Command.svelte.d.ts +24 -25
  187. package/dist/overlay/Drawer.svelte +49 -21
  188. package/dist/overlay/Drawer.svelte.d.ts +2 -2
  189. package/dist/overlay/Dropdown.svelte +4 -5
  190. package/dist/overlay/Modal.svelte +51 -16
  191. package/dist/overlay/Modal.svelte.d.ts +3 -3
  192. package/dist/overlay/Toast.svelte +41 -17
  193. package/dist/overlay/Toast.svelte.d.ts +1 -1
  194. package/dist/overlay/Tooltip.svelte +40 -26
  195. package/dist/overlay/Tooltip.svelte.d.ts +2 -2
  196. package/dist/overlay/css/command.css +80 -0
  197. package/dist/overlay/css/drawer.css +63 -24
  198. package/dist/overlay/css/dropdown.css +1 -1
  199. package/dist/overlay/css/hovercard.css +1 -1
  200. package/dist/overlay/css/modal.css +27 -27
  201. package/dist/overlay/css/toast.css +17 -29
  202. package/dist/overlay/css/tooltip.css +83 -66
  203. package/dist/stores/theme.svelte.js +26 -1
  204. package/dist/stores/toast.svelte.d.ts +4 -4
  205. package/dist/stores/toast.svelte.js +2 -2
  206. package/package.json +1 -1
@@ -0,0 +1,348 @@
1
+ <script lang="ts" module>
2
+ export type DragDropItem = {
3
+ id: string;
4
+ [key: string]: unknown;
5
+ };
6
+
7
+ export type DragDropGroup = {
8
+ id: string;
9
+ title?: string;
10
+ items: DragDropItem[];
11
+ [key: string]: unknown;
12
+ };
13
+ </script>
14
+
15
+ <script lang="ts">
16
+ import { cn } from '../utils/class-names.js';
17
+ import type { Snippet } from 'svelte';
18
+
19
+ type Props = {
20
+ groups?: DragDropGroup[];
21
+ items?: DragDropItem[];
22
+ class?: string;
23
+ groupClass?: string;
24
+ itemClass?: string;
25
+ color?: 'primary' | 'secondary' | 'muted' | 'success' | 'info' | 'danger' | 'warning';
26
+ variant?: 'soft' | 'solid' | 'outlined' | 'ghost';
27
+ size?: 'sm' | 'md' | 'lg';
28
+ direction?: 'horizontal' | 'vertical';
29
+ isDisabled?: boolean;
30
+ allowGroupTransfer?: boolean;
31
+ onReorder?: (items: DragDropItem[], fromGroup?: string, toGroup?: string) => void;
32
+ onGroupReorder?: (groups: DragDropGroup[]) => void;
33
+ itemSnippet?: Snippet<[DragDropItem, number]>;
34
+ groupHeaderSnippet?: Snippet<[DragDropGroup, number]>;
35
+ emptySnippet?: Snippet<[DragDropGroup?]>;
36
+ };
37
+
38
+ let {
39
+ groups = $bindable([]),
40
+ items = $bindable([]),
41
+ class: className,
42
+ groupClass,
43
+ itemClass,
44
+ color = 'muted',
45
+ variant = 'soft',
46
+ size = 'md',
47
+ direction = 'vertical',
48
+ isDisabled = false,
49
+ allowGroupTransfer = true,
50
+ onReorder,
51
+ onGroupReorder,
52
+ itemSnippet,
53
+ groupHeaderSnippet,
54
+ emptySnippet
55
+ }: Props = $props();
56
+
57
+ let draggedItem = $state<DragDropItem | null>(null);
58
+ let draggedFromGroup = $state<string | null>(null);
59
+ let draggedFromIndex = $state<number>(-1);
60
+ let dragOverGroup = $state<string | null>(null);
61
+ let dragOverIndex = $state<number>(-1);
62
+ let isDragging = $state(false);
63
+
64
+ const colors = {
65
+ primary: 'is-primary',
66
+ secondary: 'is-secondary',
67
+ muted: 'is-muted',
68
+ success: 'is-success',
69
+ info: 'is-info',
70
+ danger: 'is-danger',
71
+ warning: 'is-warning'
72
+ };
73
+
74
+ const variants = {
75
+ soft: 'is-soft',
76
+ solid: 'is-solid',
77
+ outlined: 'is-outlined',
78
+ ghost: 'is-ghost'
79
+ };
80
+
81
+ const sizes = {
82
+ sm: 'is-sm',
83
+ md: 'is-md',
84
+ lg: 'is-lg'
85
+ };
86
+
87
+ const isSingleMode = $derived(groups.length === 0);
88
+
89
+ function handleDragStart(e: DragEvent, item: DragDropItem, index: number, groupId?: string) {
90
+ if (isDisabled) return;
91
+
92
+ draggedItem = item;
93
+ draggedFromIndex = index;
94
+ draggedFromGroup = groupId ?? null;
95
+ isDragging = true;
96
+
97
+ if (e.dataTransfer) {
98
+ e.dataTransfer.effectAllowed = 'move';
99
+ e.dataTransfer.setData('text/plain', item.id);
100
+ }
101
+
102
+ const target = e.target as HTMLElement;
103
+ requestAnimationFrame(() => {
104
+ target.classList.add('is-dragging');
105
+ });
106
+ }
107
+
108
+ function handleDragEnd(e: DragEvent) {
109
+ const target = e.target as HTMLElement;
110
+ target.classList.remove('is-dragging');
111
+
112
+ draggedItem = null;
113
+ draggedFromGroup = null;
114
+ draggedFromIndex = -1;
115
+ dragOverGroup = null;
116
+ dragOverIndex = -1;
117
+ isDragging = false;
118
+ }
119
+
120
+ function handleDragOver(e: DragEvent, index: number, groupId?: string) {
121
+ e.preventDefault();
122
+ if (!draggedItem || isDisabled) return;
123
+
124
+ if (!allowGroupTransfer && groupId !== draggedFromGroup) return;
125
+
126
+ dragOverIndex = index;
127
+ dragOverGroup = groupId ?? null;
128
+
129
+ if (e.dataTransfer) {
130
+ e.dataTransfer.dropEffect = 'move';
131
+ }
132
+ }
133
+
134
+ function handleDragLeave() {
135
+ dragOverIndex = -1;
136
+ }
137
+
138
+ function handleDrop(e: DragEvent, dropIndex: number, groupId?: string) {
139
+ e.preventDefault();
140
+ if (!draggedItem || isDisabled) return;
141
+
142
+ if (!allowGroupTransfer && groupId !== draggedFromGroup) {
143
+ handleDragEnd(e);
144
+ return;
145
+ }
146
+
147
+ if (isSingleMode) {
148
+ const newItems = [...items];
149
+ newItems.splice(draggedFromIndex, 1);
150
+ newItems.splice(dropIndex > draggedFromIndex ? dropIndex - 1 : dropIndex, 0, draggedItem);
151
+ items = newItems;
152
+ onReorder?.(newItems);
153
+ } else {
154
+ const newGroups = groups.map((g) => ({ ...g, items: [...g.items] }));
155
+
156
+ if (draggedFromGroup === groupId) {
157
+ const group = newGroups.find((g) => g.id === groupId);
158
+ if (group) {
159
+ group.items.splice(draggedFromIndex, 1);
160
+ group.items.splice(
161
+ dropIndex > draggedFromIndex ? dropIndex - 1 : dropIndex,
162
+ 0,
163
+ draggedItem
164
+ );
165
+ }
166
+ } else {
167
+ const fromGroup = newGroups.find((g) => g.id === draggedFromGroup);
168
+ const toGroup = newGroups.find((g) => g.id === groupId);
169
+
170
+ if (fromGroup && toGroup) {
171
+ fromGroup.items.splice(draggedFromIndex, 1);
172
+ toGroup.items.splice(dropIndex, 0, draggedItem);
173
+ }
174
+ }
175
+
176
+ groups = newGroups;
177
+ onReorder?.(
178
+ newGroups.find((g) => g.id === groupId)?.items || [],
179
+ draggedFromGroup ?? undefined,
180
+ groupId
181
+ );
182
+ onGroupReorder?.(newGroups);
183
+ }
184
+
185
+ handleDragEnd(e);
186
+ }
187
+
188
+ function handleDropOnEmpty(e: DragEvent, groupId?: string) {
189
+ e.preventDefault();
190
+ if (!draggedItem || isDisabled) return;
191
+
192
+ if (!allowGroupTransfer && groupId !== draggedFromGroup) {
193
+ handleDragEnd(e);
194
+ return;
195
+ }
196
+
197
+ if (!isSingleMode && groupId) {
198
+ const newGroups = groups.map((g) => ({ ...g, items: [...g.items] }));
199
+ const fromGroup = newGroups.find((g) => g.id === draggedFromGroup);
200
+ const toGroup = newGroups.find((g) => g.id === groupId);
201
+
202
+ if (fromGroup && toGroup) {
203
+ fromGroup.items.splice(draggedFromIndex, 1);
204
+ toGroup.items.push(draggedItem);
205
+ }
206
+
207
+ groups = newGroups;
208
+ onReorder?.(toGroup?.items || [], draggedFromGroup ?? undefined, groupId);
209
+ onGroupReorder?.(newGroups);
210
+ }
211
+
212
+ handleDragEnd(e);
213
+ }
214
+ </script>
215
+
216
+ <div
217
+ class={cn(
218
+ 'drag-drop',
219
+ colors[color],
220
+ variants[variant],
221
+ sizes[size],
222
+ direction === 'horizontal' ? 'is-horizontal' : 'is-vertical',
223
+ isDisabled && 'is-disabled',
224
+ isDragging && 'is-dragging',
225
+ className
226
+ )}
227
+ >
228
+ {#if isSingleMode}
229
+ <div class="drag-drop-list">
230
+ {#each items as item, index (item.id)}
231
+ <div
232
+ class={cn(
233
+ 'drag-drop-item',
234
+ draggedItem?.id === item.id && 'is-dragging',
235
+ dragOverIndex === index && draggedItem?.id !== item.id && 'is-drag-over',
236
+ itemClass
237
+ )}
238
+ draggable={!isDisabled}
239
+ ondragstart={(e) => handleDragStart(e, item, index)}
240
+ ondragend={handleDragEnd}
241
+ ondragover={(e) => handleDragOver(e, index)}
242
+ ondragleave={handleDragLeave}
243
+ ondrop={(e) => handleDrop(e, index)}
244
+ role="listitem"
245
+ >
246
+ {#if itemSnippet}
247
+ {@render itemSnippet(item, index)}
248
+ {:else}
249
+ <span class="drag-drop-item-content">{item.id}</span>
250
+ {/if}
251
+ <div class="drag-drop-handle">
252
+ <svg viewBox="0 0 24 24" fill="currentColor">
253
+ <circle cx="9" cy="6" r="1.5" />
254
+ <circle cx="15" cy="6" r="1.5" />
255
+ <circle cx="9" cy="12" r="1.5" />
256
+ <circle cx="15" cy="12" r="1.5" />
257
+ <circle cx="9" cy="18" r="1.5" />
258
+ <circle cx="15" cy="18" r="1.5" />
259
+ </svg>
260
+ </div>
261
+ </div>
262
+ {/each}
263
+
264
+ {#if items.length === 0}
265
+ <div
266
+ class="drag-drop-empty"
267
+ ondragover={(e) => e.preventDefault()}
268
+ ondrop={(e) => handleDropOnEmpty(e)}
269
+ role="listitem"
270
+ >
271
+ {#if emptySnippet}
272
+ {@render emptySnippet()}
273
+ {:else}
274
+ <span>Arrastra elementos aquí</span>
275
+ {/if}
276
+ </div>
277
+ {/if}
278
+ </div>
279
+ {:else}
280
+ {#each groups as group, groupIndex (group.id)}
281
+ <div class={cn('drag-drop-group', groupClass)}>
282
+ {#if groupHeaderSnippet}
283
+ {@render groupHeaderSnippet(group, groupIndex)}
284
+ {:else if group.title}
285
+ <div class="drag-drop-group-header">
286
+ <span class="drag-drop-group-title">{group.title}</span>
287
+ <span class="drag-drop-group-count">{group.items.length}</span>
288
+ </div>
289
+ {/if}
290
+
291
+ <div class="drag-drop-list">
292
+ {#each group.items as item, index (item.id)}
293
+ <div
294
+ class={cn(
295
+ 'drag-drop-item',
296
+ draggedItem?.id === item.id && 'is-dragging',
297
+ dragOverIndex === index &&
298
+ dragOverGroup === group.id &&
299
+ draggedItem?.id !== item.id &&
300
+ 'is-drag-over',
301
+ itemClass
302
+ )}
303
+ draggable={!isDisabled}
304
+ ondragstart={(e) => handleDragStart(e, item, index, group.id)}
305
+ ondragend={handleDragEnd}
306
+ ondragover={(e) => handleDragOver(e, index, group.id)}
307
+ ondragleave={handleDragLeave}
308
+ ondrop={(e) => handleDrop(e, index, group.id)}
309
+ role="listitem"
310
+ >
311
+ {#if itemSnippet}
312
+ {@render itemSnippet(item, index)}
313
+ {:else}
314
+ <span class="drag-drop-item-content">{item.id}</span>
315
+ {/if}
316
+ <div class="drag-drop-handle">
317
+ <svg viewBox="0 0 24 24" fill="currentColor">
318
+ <circle cx="9" cy="6" r="1.5" />
319
+ <circle cx="15" cy="6" r="1.5" />
320
+ <circle cx="9" cy="12" r="1.5" />
321
+ <circle cx="15" cy="12" r="1.5" />
322
+ <circle cx="9" cy="18" r="1.5" />
323
+ <circle cx="15" cy="18" r="1.5" />
324
+ </svg>
325
+ </div>
326
+ </div>
327
+ {/each}
328
+
329
+ {#if group.items.length === 0}
330
+ <div
331
+ class={cn('drag-drop-empty', dragOverGroup === group.id && 'is-drag-over')}
332
+ ondragover={(e) => handleDragOver(e, 0, group.id)}
333
+ ondragleave={handleDragLeave}
334
+ ondrop={(e) => handleDropOnEmpty(e, group.id)}
335
+ role="listitem"
336
+ >
337
+ {#if emptySnippet}
338
+ {@render emptySnippet(group)}
339
+ {:else}
340
+ <span>Arrastra elementos aquí</span>
341
+ {/if}
342
+ </div>
343
+ {/if}
344
+ </div>
345
+ </div>
346
+ {/each}
347
+ {/if}
348
+ </div>
@@ -0,0 +1,32 @@
1
+ export type DragDropItem = {
2
+ id: string;
3
+ [key: string]: unknown;
4
+ };
5
+ export type DragDropGroup = {
6
+ id: string;
7
+ title?: string;
8
+ items: DragDropItem[];
9
+ [key: string]: unknown;
10
+ };
11
+ import type { Snippet } from 'svelte';
12
+ type Props = {
13
+ groups?: DragDropGroup[];
14
+ items?: DragDropItem[];
15
+ class?: string;
16
+ groupClass?: string;
17
+ itemClass?: string;
18
+ color?: 'primary' | 'secondary' | 'muted' | 'success' | 'info' | 'danger' | 'warning';
19
+ variant?: 'soft' | 'solid' | 'outlined' | 'ghost';
20
+ size?: 'sm' | 'md' | 'lg';
21
+ direction?: 'horizontal' | 'vertical';
22
+ isDisabled?: boolean;
23
+ allowGroupTransfer?: boolean;
24
+ onReorder?: (items: DragDropItem[], fromGroup?: string, toGroup?: string) => void;
25
+ onGroupReorder?: (groups: DragDropGroup[]) => void;
26
+ itemSnippet?: Snippet<[DragDropItem, number]>;
27
+ groupHeaderSnippet?: Snippet<[DragDropGroup, number]>;
28
+ emptySnippet?: Snippet<[DragDropGroup?]>;
29
+ };
30
+ declare const DragDrop: import("svelte").Component<Props, {}, "items" | "groups">;
31
+ type DragDrop = ReturnType<typeof DragDrop>;
32
+ export default DragDrop;
@@ -20,7 +20,17 @@
20
20
  class?: string;
21
21
  controlClass?: string;
22
22
  icon?: IconData;
23
- variant?: 'primary' | 'secondary' | 'muted' | 'outlined' | 'line';
23
+ color?:
24
+ | 'primary'
25
+ | 'secondary'
26
+ | 'muted'
27
+ | 'success'
28
+ | 'info'
29
+ | 'warning'
30
+ | 'danger'
31
+ | 'surface'
32
+ | 'default';
33
+ variant?: 'solid' | 'soft' | 'outlined' | 'ghost';
24
34
  size?: 'sm' | 'md' | 'lg';
25
35
  name?: string;
26
36
  label?: string;
@@ -29,7 +39,6 @@
29
39
  placeholder?: string;
30
40
  disabled?: boolean;
31
41
  onchange?: (files: FileWithUrl[]) => void;
32
- isSolid?: boolean;
33
42
  };
34
43
 
35
44
  let {
@@ -40,6 +49,7 @@
40
49
  class: className,
41
50
  controlClass,
42
51
  icon,
52
+ color = 'default',
43
53
  variant = 'outlined',
44
54
  size = 'md',
45
55
  name,
@@ -48,8 +58,7 @@
48
58
  errorText,
49
59
  placeholder = 'Drag & drop files here or click to select',
50
60
  disabled = false,
51
- onchange,
52
- isSolid
61
+ onchange
53
62
  }: Props = $props();
54
63
 
55
64
  const uid = $props.id();
@@ -57,12 +66,23 @@
57
66
  let isActive = $state(false);
58
67
  let isDragging = $state(false);
59
68
 
60
- const variantClasses = {
69
+ const colorClasses = {
61
70
  primary: 'is-primary',
62
71
  secondary: 'is-secondary',
63
72
  muted: 'is-muted',
73
+ success: 'is-success',
74
+ info: 'is-info',
75
+ danger: 'is-danger',
76
+ warning: 'is-warning',
77
+ surface: 'is-surface',
78
+ default: 'is-default'
79
+ };
80
+
81
+ const variantClasses = {
82
+ solid: 'is-solid',
83
+ soft: 'is-soft',
64
84
  outlined: 'is-outlined',
65
- line: 'is-line'
85
+ ghost: 'is-ghost'
66
86
  };
67
87
 
68
88
  const sizeClasses = {
@@ -118,9 +138,9 @@
118
138
  for={`${uid}-${name}`}
119
139
  class={cn(
120
140
  'dropzone-input',
141
+ colorClasses[color],
121
142
  variantClasses[variant],
122
143
  sizeClasses[size],
123
- isSolid && 'is-solid',
124
144
  (isActive || isDragging) && 'is-active',
125
145
  disabled && 'is-disabled',
126
146
  controlClass
@@ -179,7 +199,7 @@
179
199
  type="button"
180
200
  class="dropzone-file-remove"
181
201
  onclick={() => removeFile(i)}
182
- aria-label="Eliminar archivo"
202
+ aria-label="Remove file"
183
203
  >
184
204
  <Icon icon={Dismiss24RegularIcon} />
185
205
  </button>
@@ -14,7 +14,8 @@ type Props = {
14
14
  class?: string;
15
15
  controlClass?: string;
16
16
  icon?: IconData;
17
- variant?: 'primary' | 'secondary' | 'muted' | 'outlined' | 'line';
17
+ color?: 'primary' | 'secondary' | 'muted' | 'success' | 'info' | 'warning' | 'danger' | 'surface' | 'default';
18
+ variant?: 'solid' | 'soft' | 'outlined' | 'ghost';
18
19
  size?: 'sm' | 'md' | 'lg';
19
20
  name?: string;
20
21
  label?: string;
@@ -23,7 +24,6 @@ type Props = {
23
24
  placeholder?: string;
24
25
  disabled?: boolean;
25
26
  onchange?: (files: FileWithUrl[]) => void;
26
- isSolid?: boolean;
27
27
  };
28
28
  declare const Dropzone: import("svelte").Component<Props, {}, "files">;
29
29
  type Dropzone = ReturnType<typeof Dropzone>;