@getmicdrop/svelte-components 5.6.0 → 5.6.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.
- package/dist/components/Layout/__tests__/AppShell.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/AppShell.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/AppShell.test.js +95 -0
- package/dist/components/Layout/__tests__/ContentSection.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/ContentSection.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/ContentSection.test.js +112 -0
- package/dist/components/Layout/__tests__/PageContainer.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/PageContainer.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/PageContainer.test.js +133 -0
- package/dist/components/Layout/__tests__/Responsive.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/Responsive.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/Responsive.test.js +123 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +41 -40
- package/dist/patterns/navigation/BottomNav.svelte +18 -8
- package/dist/patterns/navigation/BottomNav.svelte.d.ts.map +1 -1
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -107
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +2 -2
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -1
- package/dist/primitives/Checkbox/Checkbox.svelte +3 -3
- package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -0
- package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts +7 -0
- package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts.map +1 -0
- package/dist/primitives/Helper/Helper.svelte +33 -0
- package/dist/primitives/Helper/Helper.svelte.d.ts +18 -0
- package/dist/primitives/Helper/Helper.svelte.d.ts.map +1 -0
- package/dist/primitives/Input/Input.svelte +416 -417
- package/dist/primitives/Input/Input.svelte.d.ts +2 -4
- package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
- package/dist/primitives/Modal/Modal.svelte +157 -158
- package/dist/primitives/Modal/Modal.svelte.d.ts +6 -8
- package/dist/primitives/Modal/Modal.svelte.d.ts.map +1 -1
- package/dist/primitives/NumberInput/NumberInput.svelte +105 -106
- package/dist/primitives/NumberInput/NumberInput.svelte.d.ts +0 -2
- package/dist/primitives/NumberInput/NumberInput.svelte.d.ts.map +1 -1
- package/dist/primitives/Toggle.svelte +70 -71
- package/dist/primitives/Toggle.svelte.d.ts +2 -4
- package/dist/primitives/Toggle.svelte.d.ts.map +1 -1
- package/dist/primitives/Tooltip/Tooltip.svelte +83 -0
- package/dist/primitives/Tooltip/Tooltip.svelte.d.ts +15 -0
- package/dist/primitives/Tooltip/Tooltip.svelte.d.ts.map +1 -0
- package/dist/primitives/index.d.ts +3 -0
- package/dist/primitives/index.js +7 -0
- package/dist/recipes/ImageUploader/ImageUploader.spec.js +6 -5
- package/dist/recipes/inputs/MultiSelect.svelte +277 -256
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts +54 -21
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +9 -4
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +332 -327
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts +12 -1
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
- package/dist/stores/auth.js +8 -0
- package/dist/stores/auth.svelte.d.ts +39 -0
- package/dist/stores/auth.svelte.d.ts.map +1 -0
- package/dist/stores/auth.svelte.js +60 -0
- package/dist/stores/formDataStore.d.ts.map +1 -1
- package/dist/stores/formDataStore.js +8 -0
- package/dist/stores/formDataStore.svelte.d.ts +47 -0
- package/dist/stores/formDataStore.svelte.d.ts.map +1 -0
- package/dist/stores/formDataStore.svelte.js +84 -0
- package/dist/stores/formSave.d.ts.map +1 -1
- package/dist/stores/formSave.js +8 -0
- package/dist/stores/formSave.svelte.d.ts +33 -0
- package/dist/stores/formSave.svelte.d.ts.map +1 -0
- package/dist/stores/formSave.svelte.js +113 -0
- package/dist/stores/navigation.d.ts.map +1 -1
- package/dist/stores/navigation.js +8 -0
- package/dist/stores/navigation.svelte.d.ts +35 -0
- package/dist/stores/navigation.svelte.d.ts.map +1 -0
- package/dist/stores/navigation.svelte.js +69 -0
- package/dist/telemetry.server.spec.js +11 -8
- package/dist/telemetry.spec.js +75 -50
- package/dist/utils/imageValidation.spec.js +62 -59
- package/dist/utils/logger.d.ts +19 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +47 -0
- package/package.json +296 -292
|
@@ -1,71 +1,70 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
/**
|
|
3
|
-
* Toggle Component - Flowbite Native
|
|
4
|
-
* Migrated to Svelte 5 runes
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
/** @type {{
|
|
8
|
-
checked?: boolean,
|
|
9
|
-
disabled?: boolean,
|
|
10
|
-
size?: 'sm' | 'md' | 'lg',
|
|
11
|
-
class?: string,
|
|
12
|
-
onchange?: (detail: { checked: boolean }) => void,
|
|
13
|
-
children?:
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
checked
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
<
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
{
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
</label>
|
|
1
|
+
<script>
|
|
2
|
+
/**
|
|
3
|
+
* Toggle Component - Flowbite Native
|
|
4
|
+
* Migrated to Svelte 5 runes
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
/** @type {{
|
|
8
|
+
checked?: boolean,
|
|
9
|
+
disabled?: boolean,
|
|
10
|
+
size?: 'sm' | 'md' | 'lg',
|
|
11
|
+
class?: string,
|
|
12
|
+
onchange?: (detail: { checked: boolean }) => void,
|
|
13
|
+
children?: import('svelte').Snippet,
|
|
14
|
+
}} */
|
|
15
|
+
let {
|
|
16
|
+
checked = $bindable(false),
|
|
17
|
+
disabled = false,
|
|
18
|
+
size = 'md',
|
|
19
|
+
class: className = '',
|
|
20
|
+
onchange,
|
|
21
|
+
children,
|
|
22
|
+
...restProps
|
|
23
|
+
} = $props();
|
|
24
|
+
|
|
25
|
+
function handleChange(event) {
|
|
26
|
+
checked = event.target.checked;
|
|
27
|
+
onchange?.({ checked });
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// Flowbite toggle sizes - thumb uses after: pseudo-element
|
|
31
|
+
const sizes = {
|
|
32
|
+
sm: {
|
|
33
|
+
track: 'w-9 h-5',
|
|
34
|
+
thumb: 'after:h-4 after:w-4 after:top-0.5 after:start-0.5',
|
|
35
|
+
translate: 'peer-checked:after:translate-x-full'
|
|
36
|
+
},
|
|
37
|
+
md: {
|
|
38
|
+
track: 'w-11 h-6',
|
|
39
|
+
thumb: 'after:h-5 after:w-5 after:top-0.5 after:start-0.5',
|
|
40
|
+
translate: 'peer-checked:after:translate-x-full'
|
|
41
|
+
},
|
|
42
|
+
lg: {
|
|
43
|
+
track: 'w-14 h-7',
|
|
44
|
+
thumb: 'after:h-6 after:w-6 after:top-0.5 after:start-0.5',
|
|
45
|
+
translate: 'peer-checked:after:translate-x-full'
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
let sizeConfig = $derived(sizes[size] || sizes.md);
|
|
50
|
+
</script>
|
|
51
|
+
|
|
52
|
+
<label class="inline-flex items-center {disabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer'} {className}" {...restProps}>
|
|
53
|
+
<input
|
|
54
|
+
type="checkbox"
|
|
55
|
+
bind:checked
|
|
56
|
+
{disabled}
|
|
57
|
+
onchange={handleChange}
|
|
58
|
+
class="sr-only peer"
|
|
59
|
+
/>
|
|
60
|
+
<div
|
|
61
|
+
class="relative {sizeConfig.track} bg-gray-200 peer-focus:outline-none peer-focus:ring-4 peer-focus:ring-blue-300 dark:peer-focus:ring-blue-800 rounded-full peer dark:bg-gray-700 peer-checked:after:translate-x-full rtl:peer-checked:after:-translate-x-full peer-checked:after:border-white after:content-[''] after:absolute {sizeConfig.thumb} after:bg-white after:border-gray-300 after:border after:rounded-full after:transition-all dark:border-gray-600 peer-checked:bg-blue-600"
|
|
62
|
+
role="switch"
|
|
63
|
+
aria-checked={checked}
|
|
64
|
+
></div>
|
|
65
|
+
{#if children}
|
|
66
|
+
<span class="ms-3 text-sm font-medium text-gray-900 dark:text-gray-300">
|
|
67
|
+
{#if typeof children === 'function'}{@render children()}{:else}{children}{/if}
|
|
68
|
+
</span>
|
|
69
|
+
{/if}
|
|
70
|
+
</label>
|
|
@@ -2,7 +2,6 @@ export default Toggle;
|
|
|
2
2
|
type Toggle = {
|
|
3
3
|
$on?(type: string, callback: (e: any) => void): () => void;
|
|
4
4
|
$set?(props: Partial<{
|
|
5
|
-
[key: string]: any;
|
|
6
5
|
checked?: boolean | undefined;
|
|
7
6
|
disabled?: boolean | undefined;
|
|
8
7
|
size?: "sm" | "md" | "lg" | undefined;
|
|
@@ -10,11 +9,10 @@ type Toggle = {
|
|
|
10
9
|
onchange?: ((detail: {
|
|
11
10
|
checked: boolean;
|
|
12
11
|
}) => void) | undefined;
|
|
13
|
-
children?:
|
|
12
|
+
children?: Snippet<[]> | undefined;
|
|
14
13
|
}>): void;
|
|
15
14
|
};
|
|
16
15
|
declare const Toggle: import("svelte").Component<{
|
|
17
|
-
[key: string]: any;
|
|
18
16
|
checked?: boolean;
|
|
19
17
|
disabled?: boolean;
|
|
20
18
|
size?: "sm" | "md" | "lg";
|
|
@@ -22,6 +20,6 @@ declare const Toggle: import("svelte").Component<{
|
|
|
22
20
|
onchange?: (detail: {
|
|
23
21
|
checked: boolean;
|
|
24
22
|
}) => void;
|
|
25
|
-
children?:
|
|
23
|
+
children?: import("svelte").Snippet;
|
|
26
24
|
}, {}, "checked">;
|
|
27
25
|
//# sourceMappingURL=Toggle.svelte.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Toggle.svelte.d.ts","sourceRoot":"","sources":["../../src/lib/primitives/Toggle.svelte.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Toggle.svelte.d.ts","sourceRoot":"","sources":["../../src/lib/primitives/Toggle.svelte.js"],"names":[],"mappings":";;;;;;;;;;;;;;AAyEA;cAPc,OAAO;eACN,OAAO;WACX,IAAI,GAAG,IAAI,GAAG,IAAI;YACjB,MAAM;eACH,CAAC,MAAM,EAAE;QAAE,OAAO,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI;eACtC,OAAO,QAAQ,EAAE,OAAO;kBAEc"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
/**
|
|
3
|
+
* Tooltip Component - Native implementation
|
|
4
|
+
*
|
|
5
|
+
* Displays a tooltip on hover/focus with configurable placement
|
|
6
|
+
*/
|
|
7
|
+
import { fly } from 'svelte/transition';
|
|
8
|
+
import type { Snippet } from 'svelte';
|
|
9
|
+
|
|
10
|
+
interface Props {
|
|
11
|
+
/** Tooltip content text */
|
|
12
|
+
content: string;
|
|
13
|
+
/** Placement relative to trigger */
|
|
14
|
+
placement?: 'top' | 'bottom' | 'left' | 'right';
|
|
15
|
+
/** Additional CSS classes for the tooltip */
|
|
16
|
+
class?: string;
|
|
17
|
+
/** Child content (trigger element) */
|
|
18
|
+
children?: Snippet;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
let {
|
|
22
|
+
content,
|
|
23
|
+
placement = 'top',
|
|
24
|
+
class: className = '',
|
|
25
|
+
children
|
|
26
|
+
}: Props = $props();
|
|
27
|
+
|
|
28
|
+
let visible = $state(false);
|
|
29
|
+
|
|
30
|
+
// Placement-specific classes
|
|
31
|
+
const placementClasses: Record<string, string> = {
|
|
32
|
+
top: 'bottom-full left-1/2 -translate-x-1/2 mb-2',
|
|
33
|
+
bottom: 'top-full left-1/2 -translate-x-1/2 mt-2',
|
|
34
|
+
left: 'right-full top-1/2 -translate-y-1/2 mr-2',
|
|
35
|
+
right: 'left-full top-1/2 -translate-y-1/2 ml-2'
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
// Arrow placement classes
|
|
39
|
+
const arrowClasses: Record<string, string> = {
|
|
40
|
+
top: 'top-full left-1/2 -translate-x-1/2 border-t-gray-900 dark:border-t-gray-700 border-l-transparent border-r-transparent border-b-transparent',
|
|
41
|
+
bottom: 'bottom-full left-1/2 -translate-x-1/2 border-b-gray-900 dark:border-b-gray-700 border-l-transparent border-r-transparent border-t-transparent',
|
|
42
|
+
left: 'left-full top-1/2 -translate-y-1/2 border-l-gray-900 dark:border-l-gray-700 border-t-transparent border-b-transparent border-r-transparent',
|
|
43
|
+
right: 'right-full top-1/2 -translate-y-1/2 border-r-gray-900 dark:border-r-gray-700 border-t-transparent border-b-transparent border-l-transparent'
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
function handleMouseEnter() {
|
|
47
|
+
visible = true;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function handleMouseLeave() {
|
|
51
|
+
visible = false;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function handleFocus() {
|
|
55
|
+
visible = true;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function handleBlur() {
|
|
59
|
+
visible = false;
|
|
60
|
+
}
|
|
61
|
+
</script>
|
|
62
|
+
|
|
63
|
+
<div
|
|
64
|
+
class="relative inline-block"
|
|
65
|
+
onmouseenter={handleMouseEnter}
|
|
66
|
+
onmouseleave={handleMouseLeave}
|
|
67
|
+
onfocus={handleFocus}
|
|
68
|
+
onblur={handleBlur}
|
|
69
|
+
role="tooltip"
|
|
70
|
+
>
|
|
71
|
+
{#if children}{@render children()}{/if}
|
|
72
|
+
|
|
73
|
+
{#if visible && content}
|
|
74
|
+
<div
|
|
75
|
+
class="absolute z-50 px-3 py-2 text-sm text-white bg-gray-900 rounded-lg shadow-sm whitespace-nowrap pointer-events-none dark:bg-gray-700 {placementClasses[placement]} {className}"
|
|
76
|
+
transition:fly={{ y: placement === 'top' ? 5 : placement === 'bottom' ? -5 : 0, x: placement === 'left' ? 5 : placement === 'right' ? -5 : 0, duration: 150 }}
|
|
77
|
+
>
|
|
78
|
+
{content}
|
|
79
|
+
<!-- Arrow -->
|
|
80
|
+
<div class="absolute w-0 h-0 border-4 {arrowClasses[placement]}"></div>
|
|
81
|
+
</div>
|
|
82
|
+
{/if}
|
|
83
|
+
</div>
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Snippet } from 'svelte';
|
|
2
|
+
interface Props {
|
|
3
|
+
/** Tooltip content text */
|
|
4
|
+
content: string;
|
|
5
|
+
/** Placement relative to trigger */
|
|
6
|
+
placement?: 'top' | 'bottom' | 'left' | 'right';
|
|
7
|
+
/** Additional CSS classes for the tooltip */
|
|
8
|
+
class?: string;
|
|
9
|
+
/** Child content (trigger element) */
|
|
10
|
+
children?: Snippet;
|
|
11
|
+
}
|
|
12
|
+
declare const Tooltip: import("svelte").Component<Props, {}, "">;
|
|
13
|
+
type Tooltip = ReturnType<typeof Tooltip>;
|
|
14
|
+
export default Tooltip;
|
|
15
|
+
//# sourceMappingURL=Tooltip.svelte.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Tooltip.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/Tooltip/Tooltip.svelte.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAGpC,UAAU,KAAK;IACb,2BAA2B;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,oCAAoC;IACpC,SAAS,CAAC,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAC;IAChD,6CAA6C;IAC7C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,sCAAsC;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AA+DH,QAAA,MAAM,OAAO,2CAAwC,CAAC;AACtD,KAAK,OAAO,GAAG,UAAU,CAAC,OAAO,OAAO,CAAC,CAAC;AAC1C,eAAe,OAAO,CAAC"}
|
|
@@ -13,6 +13,8 @@ export { default as DarkModeToggle } from "./DarkModeToggle.svelte";
|
|
|
13
13
|
export { default as Drawer } from "./Drawer/Drawer.svelte";
|
|
14
14
|
export { default as Dropdown } from "./Dropdown/Dropdown.svelte";
|
|
15
15
|
export { default as DropdownItem } from "./Dropdown/DropdownItem.svelte";
|
|
16
|
+
export { default as DropdownDivider } from "./Dropdown/DropdownDivider.svelte";
|
|
17
|
+
export { default as Helper } from "./Helper/Helper.svelte";
|
|
16
18
|
export * from "./Icons/index.js";
|
|
17
19
|
export * from "./Skeleton/index.js";
|
|
18
20
|
export { default as Input } from "./Input/Input.svelte";
|
|
@@ -27,6 +29,7 @@ export { default as Spinner } from "./Spinner/Spinner.svelte";
|
|
|
27
29
|
export { default as Tabs } from "./Tabs/Tabs.svelte";
|
|
28
30
|
export { default as TabItem } from "./Tabs/TabItem.svelte";
|
|
29
31
|
export { default as Toggle } from "./Toggle.svelte";
|
|
32
|
+
export { default as Tooltip } from "./Tooltip/Tooltip.svelte";
|
|
30
33
|
export { default as Typography } from "./Typography/Typography.svelte";
|
|
31
34
|
export { default as ValidationError } from "./ValidationError.svelte";
|
|
32
35
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/primitives/index.js
CHANGED
|
@@ -40,6 +40,10 @@ export { default as Drawer } from './Drawer/Drawer.svelte';
|
|
|
40
40
|
// Dropdown
|
|
41
41
|
export { default as Dropdown } from './Dropdown/Dropdown.svelte';
|
|
42
42
|
export { default as DropdownItem } from './Dropdown/DropdownItem.svelte';
|
|
43
|
+
export { default as DropdownDivider } from './Dropdown/DropdownDivider.svelte';
|
|
44
|
+
|
|
45
|
+
// Helper
|
|
46
|
+
export { default as Helper } from './Helper/Helper.svelte';
|
|
43
47
|
|
|
44
48
|
// Icons - re-export from Icons/index.js
|
|
45
49
|
export * from './Icons/index.js';
|
|
@@ -77,6 +81,9 @@ export { default as TabItem } from './Tabs/TabItem.svelte';
|
|
|
77
81
|
// Toggle
|
|
78
82
|
export { default as Toggle } from './Toggle.svelte';
|
|
79
83
|
|
|
84
|
+
// Tooltip
|
|
85
|
+
export { default as Tooltip } from './Tooltip/Tooltip.svelte';
|
|
86
|
+
|
|
80
87
|
// Typography
|
|
81
88
|
export { default as Typography } from './Typography/Typography.svelte';
|
|
82
89
|
|
|
@@ -3,14 +3,15 @@ import { render, screen, fireEvent, waitFor } from '@testing-library/svelte';
|
|
|
3
3
|
import userEvent from '@testing-library/user-event';
|
|
4
4
|
import ImageUploader from './ImageUploader.svelte';
|
|
5
5
|
|
|
6
|
-
// Mock Sortable.js
|
|
6
|
+
// Mock Sortable.js - Vitest 4.x requires class syntax for constructor mocks
|
|
7
7
|
const mockSortableDestroy = vi.fn();
|
|
8
|
-
const mockSortableInstance = {
|
|
9
|
-
destroy: mockSortableDestroy,
|
|
10
|
-
};
|
|
11
8
|
|
|
12
9
|
vi.mock('sortablejs', () => ({
|
|
13
|
-
default:
|
|
10
|
+
default: class MockSortable {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.destroy = mockSortableDestroy;
|
|
13
|
+
}
|
|
14
|
+
},
|
|
14
15
|
}));
|
|
15
16
|
|
|
16
17
|
// Helper to create a mock file
|