@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.
Files changed (77) hide show
  1. package/dist/components/Layout/__tests__/AppShell.test.d.ts +2 -0
  2. package/dist/components/Layout/__tests__/AppShell.test.d.ts.map +1 -0
  3. package/dist/components/Layout/__tests__/AppShell.test.js +95 -0
  4. package/dist/components/Layout/__tests__/ContentSection.test.d.ts +2 -0
  5. package/dist/components/Layout/__tests__/ContentSection.test.d.ts.map +1 -0
  6. package/dist/components/Layout/__tests__/ContentSection.test.js +112 -0
  7. package/dist/components/Layout/__tests__/PageContainer.test.d.ts +2 -0
  8. package/dist/components/Layout/__tests__/PageContainer.test.d.ts.map +1 -0
  9. package/dist/components/Layout/__tests__/PageContainer.test.js +133 -0
  10. package/dist/components/Layout/__tests__/Responsive.test.d.ts +2 -0
  11. package/dist/components/Layout/__tests__/Responsive.test.d.ts.map +1 -0
  12. package/dist/components/Layout/__tests__/Responsive.test.js +123 -0
  13. package/dist/index.d.ts +1 -0
  14. package/dist/index.js +41 -40
  15. package/dist/patterns/navigation/BottomNav.svelte +18 -8
  16. package/dist/patterns/navigation/BottomNav.svelte.d.ts.map +1 -1
  17. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -107
  18. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +2 -2
  19. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -1
  20. package/dist/primitives/Checkbox/Checkbox.svelte +3 -3
  21. package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -0
  22. package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts +7 -0
  23. package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts.map +1 -0
  24. package/dist/primitives/Helper/Helper.svelte +33 -0
  25. package/dist/primitives/Helper/Helper.svelte.d.ts +18 -0
  26. package/dist/primitives/Helper/Helper.svelte.d.ts.map +1 -0
  27. package/dist/primitives/Input/Input.svelte +416 -417
  28. package/dist/primitives/Input/Input.svelte.d.ts +2 -4
  29. package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
  30. package/dist/primitives/Modal/Modal.svelte +157 -158
  31. package/dist/primitives/Modal/Modal.svelte.d.ts +6 -8
  32. package/dist/primitives/Modal/Modal.svelte.d.ts.map +1 -1
  33. package/dist/primitives/NumberInput/NumberInput.svelte +105 -106
  34. package/dist/primitives/NumberInput/NumberInput.svelte.d.ts +0 -2
  35. package/dist/primitives/NumberInput/NumberInput.svelte.d.ts.map +1 -1
  36. package/dist/primitives/Toggle.svelte +70 -71
  37. package/dist/primitives/Toggle.svelte.d.ts +2 -4
  38. package/dist/primitives/Toggle.svelte.d.ts.map +1 -1
  39. package/dist/primitives/Tooltip/Tooltip.svelte +83 -0
  40. package/dist/primitives/Tooltip/Tooltip.svelte.d.ts +15 -0
  41. package/dist/primitives/Tooltip/Tooltip.svelte.d.ts.map +1 -0
  42. package/dist/primitives/index.d.ts +3 -0
  43. package/dist/primitives/index.js +7 -0
  44. package/dist/recipes/ImageUploader/ImageUploader.spec.js +6 -5
  45. package/dist/recipes/inputs/MultiSelect.svelte +277 -256
  46. package/dist/recipes/inputs/MultiSelect.svelte.d.ts +54 -21
  47. package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
  48. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +9 -4
  49. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +332 -327
  50. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts +12 -1
  51. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
  52. package/dist/stores/auth.js +8 -0
  53. package/dist/stores/auth.svelte.d.ts +39 -0
  54. package/dist/stores/auth.svelte.d.ts.map +1 -0
  55. package/dist/stores/auth.svelte.js +60 -0
  56. package/dist/stores/formDataStore.d.ts.map +1 -1
  57. package/dist/stores/formDataStore.js +8 -0
  58. package/dist/stores/formDataStore.svelte.d.ts +47 -0
  59. package/dist/stores/formDataStore.svelte.d.ts.map +1 -0
  60. package/dist/stores/formDataStore.svelte.js +84 -0
  61. package/dist/stores/formSave.d.ts.map +1 -1
  62. package/dist/stores/formSave.js +8 -0
  63. package/dist/stores/formSave.svelte.d.ts +33 -0
  64. package/dist/stores/formSave.svelte.d.ts.map +1 -0
  65. package/dist/stores/formSave.svelte.js +113 -0
  66. package/dist/stores/navigation.d.ts.map +1 -1
  67. package/dist/stores/navigation.js +8 -0
  68. package/dist/stores/navigation.svelte.d.ts +35 -0
  69. package/dist/stores/navigation.svelte.d.ts.map +1 -0
  70. package/dist/stores/navigation.svelte.js +69 -0
  71. package/dist/telemetry.server.spec.js +11 -8
  72. package/dist/telemetry.spec.js +75 -50
  73. package/dist/utils/imageValidation.spec.js +62 -59
  74. package/dist/utils/logger.d.ts +19 -0
  75. package/dist/utils/logger.d.ts.map +1 -0
  76. package/dist/utils/logger.js +47 -0
  77. 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?: any,
14
- [key: string]: any
15
- }} */
16
- let {
17
- checked = $bindable(false),
18
- disabled = false,
19
- size = 'md',
20
- class: className = '',
21
- onchange,
22
- children,
23
- ...restProps
24
- } = $props();
25
-
26
- function handleChange(event) {
27
- checked = event.target.checked;
28
- onchange?.({ checked });
29
- }
30
-
31
- // Flowbite toggle sizes - thumb uses after: pseudo-element
32
- const sizes = {
33
- sm: {
34
- track: 'w-9 h-5',
35
- thumb: 'after:h-4 after:w-4 after:top-0.5 after:start-0.5',
36
- translate: 'peer-checked:after:translate-x-full'
37
- },
38
- md: {
39
- track: 'w-11 h-6',
40
- thumb: 'after:h-5 after:w-5 after:top-0.5 after:start-0.5',
41
- translate: 'peer-checked:after:translate-x-full'
42
- },
43
- lg: {
44
- track: 'w-14 h-7',
45
- thumb: 'after:h-6 after:w-6 after:top-0.5 after:start-0.5',
46
- translate: 'peer-checked:after:translate-x-full'
47
- }
48
- };
49
-
50
- let sizeConfig = $derived(sizes[size] || sizes.md);
51
- </script>
52
-
53
- <label class="inline-flex items-center {disabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer'} {className}" {...restProps}>
54
- <input
55
- type="checkbox"
56
- bind:checked
57
- {disabled}
58
- onchange={handleChange}
59
- class="sr-only peer"
60
- />
61
- <div
62
- 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"
63
- role="switch"
64
- aria-checked={checked}
65
- ></div>
66
- {#if children}
67
- <span class="ms-3 text-sm font-medium text-gray-900 dark:text-gray-300">
68
- {#if typeof children === 'function'}{@render children()}{:else}{children}{/if}
69
- </span>
70
- {/if}
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?: any;
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?: any;
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":";;;;;;;;;;;;;;;AA2EA;;cARc,OAAO;eACN,OAAO;WACX,IAAI,GAAG,IAAI,GAAG,IAAI;YACjB,MAAM;eACH,CAAC,MAAM,EAAE;QAAE,OAAO,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI;eACtC,GAAG;kBAGmC"}
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
@@ -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: vi.fn(() => mockSortableInstance),
10
+ default: class MockSortable {
11
+ constructor() {
12
+ this.destroy = mockSortableDestroy;
13
+ }
14
+ },
14
15
  }));
15
16
 
16
17
  // Helper to create a mock file