ui-ingredients 0.0.6 → 0.0.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (163) hide show
  1. package/README.md +75 -75
  2. package/dist/accordion/item-content.svelte +22 -13
  3. package/dist/accordion/item-indicator.svelte +22 -13
  4. package/dist/accordion/item-trigger.svelte +22 -13
  5. package/dist/accordion/item.svelte +35 -24
  6. package/dist/accordion/root.svelte +61 -40
  7. package/dist/avatar/fallback.svelte +21 -12
  8. package/dist/avatar/image.svelte +19 -10
  9. package/dist/avatar/root.svelte +46 -29
  10. package/dist/carousel/indicator-group.svelte +21 -12
  11. package/dist/carousel/indicator.svelte +31 -20
  12. package/dist/carousel/item-group.svelte +21 -12
  13. package/dist/carousel/item.svelte +22 -12
  14. package/dist/carousel/next-trigger.svelte +21 -12
  15. package/dist/carousel/prev-trigger.svelte +21 -12
  16. package/dist/carousel/root.svelte +58 -40
  17. package/dist/carousel/viewport.svelte +21 -12
  18. package/dist/checkbox/control.svelte +21 -12
  19. package/dist/checkbox/hidden-input.svelte +19 -10
  20. package/dist/checkbox/indicator.svelte +21 -12
  21. package/dist/checkbox/label.svelte +21 -12
  22. package/dist/checkbox/root.svelte +62 -44
  23. package/dist/clipboard/control.svelte +21 -12
  24. package/dist/clipboard/indicator.svelte +23 -12
  25. package/dist/clipboard/input.svelte +19 -10
  26. package/dist/clipboard/label.svelte +21 -12
  27. package/dist/clipboard/root.svelte +51 -30
  28. package/dist/clipboard/trigger.svelte +21 -12
  29. package/dist/collapsible/content.svelte +21 -12
  30. package/dist/collapsible/root.svelte +57 -36
  31. package/dist/collapsible/trigger.svelte +19 -12
  32. package/dist/combobox/clear-trigger.svelte +21 -12
  33. package/dist/combobox/content.svelte +21 -12
  34. package/dist/combobox/control.svelte +21 -12
  35. package/dist/combobox/input.svelte +19 -10
  36. package/dist/combobox/item-group-label.svelte +29 -20
  37. package/dist/combobox/item-group.svelte +26 -14
  38. package/dist/combobox/item-indicator.svelte +22 -13
  39. package/dist/combobox/item-text.svelte +26 -17
  40. package/dist/combobox/item.svelte +35 -24
  41. package/dist/combobox/label.svelte +21 -12
  42. package/dist/combobox/list.svelte +21 -12
  43. package/dist/combobox/positioner.svelte +21 -12
  44. package/dist/combobox/root.svelte +122 -104
  45. package/dist/combobox/trigger.svelte +21 -12
  46. package/dist/dialog/backdrop.svelte +21 -12
  47. package/dist/dialog/close-trigger.svelte +21 -12
  48. package/dist/dialog/content.svelte +21 -12
  49. package/dist/dialog/description.svelte +21 -12
  50. package/dist/dialog/positioner.svelte +21 -12
  51. package/dist/dialog/root.svelte +22 -10
  52. package/dist/dialog/title.svelte +21 -12
  53. package/dist/dialog/trigger.svelte +21 -12
  54. package/dist/hover-card/arrow-tip.svelte +21 -12
  55. package/dist/hover-card/arrow.svelte +21 -12
  56. package/dist/hover-card/content.svelte +21 -12
  57. package/dist/hover-card/positioner.svelte +21 -12
  58. package/dist/hover-card/root.svelte +25 -10
  59. package/dist/hover-card/trigger.svelte +21 -12
  60. package/dist/number-input/control.svelte +21 -12
  61. package/dist/number-input/decrement-trigger.svelte +22 -12
  62. package/dist/number-input/increment-trigger.svelte +22 -12
  63. package/dist/number-input/input.svelte +19 -10
  64. package/dist/number-input/label.svelte +21 -12
  65. package/dist/number-input/root.svelte +93 -72
  66. package/dist/number-input/scrubber.svelte +21 -12
  67. package/dist/pagination/ellipsis.svelte +23 -12
  68. package/dist/pagination/item.svelte +31 -20
  69. package/dist/pagination/next-trigger.svelte +21 -12
  70. package/dist/pagination/prev-trigger.svelte +21 -12
  71. package/dist/pagination/root.svelte +63 -42
  72. package/dist/pin-input/clear-trigger.svelte +25 -17
  73. package/dist/pin-input/hidden-input.svelte +19 -10
  74. package/dist/pin-input/input.svelte +20 -10
  75. package/dist/pin-input/label.svelte +21 -12
  76. package/dist/pin-input/root.svelte +82 -64
  77. package/dist/popover/arrow-tip.svelte +21 -12
  78. package/dist/popover/arrow.svelte +21 -12
  79. package/dist/popover/close-trigger.svelte +21 -12
  80. package/dist/popover/content.svelte +21 -12
  81. package/dist/popover/description.svelte +21 -12
  82. package/dist/popover/positioner.svelte +21 -12
  83. package/dist/popover/root.svelte +22 -10
  84. package/dist/popover/title.svelte +21 -12
  85. package/dist/popover/trigger.svelte +21 -12
  86. package/dist/portal/root.svelte +20 -10
  87. package/dist/presence/root.svelte +39 -27
  88. package/dist/progress/circle-range.svelte +21 -12
  89. package/dist/progress/circle-track.svelte +21 -12
  90. package/dist/progress/circle.svelte +21 -12
  91. package/dist/progress/label.svelte +21 -12
  92. package/dist/progress/range.svelte +21 -12
  93. package/dist/progress/root.svelte +54 -36
  94. package/dist/progress/track.svelte +21 -12
  95. package/dist/progress/value-text.svelte +25 -16
  96. package/dist/radio-group/indicator.svelte +21 -12
  97. package/dist/radio-group/item-control.svelte +22 -13
  98. package/dist/radio-group/item-hidden-input.svelte +20 -11
  99. package/dist/radio-group/item-text.svelte +22 -13
  100. package/dist/radio-group/item.svelte +37 -26
  101. package/dist/radio-group/label.svelte +21 -12
  102. package/dist/radio-group/root.svelte +61 -40
  103. package/dist/select/clear-trigger.svelte +21 -12
  104. package/dist/select/content.svelte +21 -12
  105. package/dist/select/control.svelte +21 -12
  106. package/dist/select/hidden-select.svelte +21 -12
  107. package/dist/select/indicator.svelte +21 -12
  108. package/dist/select/item-group-label.svelte +24 -15
  109. package/dist/select/item-group.svelte +26 -14
  110. package/dist/select/item-indicator.svelte +22 -13
  111. package/dist/select/item-text.svelte +26 -17
  112. package/dist/select/item.svelte +35 -24
  113. package/dist/select/label.svelte +21 -12
  114. package/dist/select/list.svelte +21 -12
  115. package/dist/select/positioner.svelte +21 -12
  116. package/dist/select/root.svelte +96 -78
  117. package/dist/select/trigger.svelte +21 -12
  118. package/dist/select/value-text.svelte +27 -18
  119. package/dist/slider/control.svelte +21 -12
  120. package/dist/slider/hidden-input.svelte +20 -11
  121. package/dist/slider/label.svelte +21 -12
  122. package/dist/slider/marker-group.svelte +21 -12
  123. package/dist/slider/marker.svelte +29 -19
  124. package/dist/slider/range.svelte +21 -12
  125. package/dist/slider/root.svelte +84 -66
  126. package/dist/slider/thumb.svelte +35 -24
  127. package/dist/slider/track.svelte +21 -12
  128. package/dist/slider/value-text.svelte +25 -16
  129. package/dist/steps/content.svelte +22 -12
  130. package/dist/steps/indicator.svelte +22 -13
  131. package/dist/steps/item.svelte +24 -13
  132. package/dist/steps/list.svelte +21 -12
  133. package/dist/steps/next-trigger.svelte +21 -12
  134. package/dist/steps/prev-trigger.svelte +21 -12
  135. package/dist/steps/progress.svelte +21 -12
  136. package/dist/steps/root.svelte +56 -38
  137. package/dist/steps/separator.svelte +22 -13
  138. package/dist/steps/trigger.svelte +22 -13
  139. package/dist/switch/control.svelte +21 -12
  140. package/dist/switch/hidden-input.svelte +19 -10
  141. package/dist/switch/label.svelte +21 -12
  142. package/dist/switch/root.svelte +64 -46
  143. package/dist/switch/thumb.svelte +21 -12
  144. package/dist/tabs/content.svelte +22 -12
  145. package/dist/tabs/list.svelte +21 -12
  146. package/dist/tabs/root.svelte +57 -42
  147. package/dist/tabs/trigger.svelte +22 -12
  148. package/dist/toast/action-trigger.svelte +21 -12
  149. package/dist/toast/actor.svelte +22 -11
  150. package/dist/toast/close-trigger.svelte +21 -12
  151. package/dist/toast/description.svelte +25 -16
  152. package/dist/toast/root.svelte +25 -16
  153. package/dist/toast/title.svelte +25 -16
  154. package/dist/toast/toaster.svelte +40 -25
  155. package/dist/toggle-group/item.svelte +22 -12
  156. package/dist/toggle-group/root.svelte +61 -40
  157. package/dist/tooltip/arrow-tip.svelte +21 -12
  158. package/dist/tooltip/arrow.svelte +21 -12
  159. package/dist/tooltip/content.svelte +21 -12
  160. package/dist/tooltip/positioner.svelte +21 -12
  161. package/dist/tooltip/root.svelte +22 -10
  162. package/dist/tooltip/trigger.svelte +21 -12
  163. package/package.json +6 -14
@@ -1,66 +1,84 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { uuid } from "../utils.svelte.js";
4
- import { mergeProps } from "@zag-js/svelte";
5
- import { createSliderContext, setSliderContext } from "./context.svelte.js";
6
- let {
7
- id = uuid(),
8
- ids,
9
- dir,
10
- max,
11
- min,
12
- step,
13
- form,
14
- name,
15
- value,
16
- origin,
17
- invalid,
18
- readOnly,
19
- disabled,
20
- orientation,
21
- thumbAlignment,
22
- thumbSize,
23
- minStepsBetweenThumbs,
24
- "aria-label": ariaLabel,
25
- "aria-labelledby": ariaLabelledby,
26
- onFocusChange,
27
- onValueChange,
28
- onValueChangeEnd,
29
- getAriaValueText,
30
- getRootNode,
31
- children,
32
- ...props
33
- } = $props();
34
- let context = createSliderContext({
35
- id,
36
- ids,
37
- dir,
38
- max,
39
- min,
40
- step,
41
- form,
42
- name,
43
- value: $state.snapshot(value),
44
- origin,
45
- invalid,
46
- readOnly,
47
- disabled,
48
- orientation,
49
- thumbAlignment,
50
- thumbSize,
51
- minStepsBetweenThumbs,
52
- "aria-label": ariaLabel,
53
- "aria-labelledby": ariaLabelledby,
54
- onFocusChange,
55
- onValueChange,
56
- onValueChangeEnd,
57
- getAriaValueText,
58
- getRootNode
59
- });
60
- let attrs = $derived(mergeProps(props, context.getRootProps()));
61
- setSliderContext(context);
62
- </script>
63
-
64
- <div {...attrs}>
65
- {@render children?.(context)}
66
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign, OptionalId, WithoutChildren} from '../types.js';
3
+ import type {Snippet} from 'svelte';
4
+ import type {SvelteHTMLElements} from 'svelte/elements';
5
+ import type {CreateSliderContextProps, CreateSliderContextReturn} from './context.svelte.js';
6
+
7
+ export interface SliderProps
8
+ extends Assign<
9
+ WithoutChildren<SvelteHTMLElements['div']>,
10
+ OptionalId<CreateSliderContextProps>
11
+ > {
12
+ children?: Snippet<[CreateSliderContextReturn]>;
13
+ }
14
+ </script>
15
+
16
+ <script lang="ts">
17
+ import {uuid} from '../utils.svelte.js';
18
+ import {mergeProps} from '@zag-js/svelte';
19
+ import {createSliderContext, setSliderContext} from './context.svelte.js';
20
+
21
+ let {
22
+ id = uuid(),
23
+ ids,
24
+ dir,
25
+ max,
26
+ min,
27
+ step,
28
+ form,
29
+ name,
30
+ value,
31
+ origin,
32
+ invalid,
33
+ readOnly,
34
+ disabled,
35
+ orientation,
36
+ thumbAlignment,
37
+ thumbSize,
38
+ minStepsBetweenThumbs,
39
+ 'aria-label': ariaLabel,
40
+ 'aria-labelledby': ariaLabelledby,
41
+ onFocusChange,
42
+ onValueChange,
43
+ onValueChangeEnd,
44
+ getAriaValueText,
45
+ getRootNode,
46
+ children,
47
+ ...props
48
+ }: SliderProps = $props();
49
+
50
+ let context = createSliderContext({
51
+ id,
52
+ ids,
53
+ dir,
54
+ max,
55
+ min,
56
+ step,
57
+ form,
58
+ name,
59
+ value: $state.snapshot(value),
60
+ origin,
61
+ invalid,
62
+ readOnly,
63
+ disabled,
64
+ orientation,
65
+ thumbAlignment,
66
+ thumbSize,
67
+ minStepsBetweenThumbs,
68
+ 'aria-label': ariaLabel,
69
+ 'aria-labelledby': ariaLabelledby,
70
+ onFocusChange,
71
+ onValueChange,
72
+ onValueChangeEnd,
73
+ getAriaValueText,
74
+ getRootNode,
75
+ });
76
+
77
+ let attrs = $derived(mergeProps(props, context.getRootProps()));
78
+
79
+ setSliderContext(context);
80
+ </script>
81
+
82
+ <div {...attrs}>
83
+ {@render children?.(context)}
84
+ </div>
@@ -1,24 +1,35 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { setSliderThumbContext, useSliderContext } from "./context.svelte.js";
5
- let { name, index, children, ...props } = $props();
6
- let context = useSliderContext();
7
- let attrs = $derived(
8
- mergeProps(
9
- props,
10
- context.getThumbProps({
11
- name,
12
- index
13
- })
14
- )
15
- );
16
- setSliderThumbContext({
17
- name,
18
- index
19
- });
20
- </script>
21
-
22
- <div {...attrs}>
23
- {@render children?.()}
24
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {ThumbProps} from '@zag-js/slider';
4
+ import type {SvelteHTMLElements} from 'svelte/elements';
5
+
6
+ export interface SliderThumbProps extends Assign<SvelteHTMLElements['div'], ThumbProps> {}
7
+ </script>
8
+
9
+ <script lang="ts">
10
+ import {mergeProps} from '@zag-js/svelte';
11
+ import {setSliderThumbContext, useSliderContext} from './context.svelte.js';
12
+
13
+ let {name, index, children, ...props}: SliderThumbProps = $props();
14
+
15
+ let context = useSliderContext();
16
+
17
+ let attrs = $derived(
18
+ mergeProps(
19
+ props,
20
+ context.getThumbProps({
21
+ name,
22
+ index,
23
+ }),
24
+ ),
25
+ );
26
+
27
+ setSliderThumbContext({
28
+ name,
29
+ index,
30
+ });
31
+ </script>
32
+
33
+ <div {...attrs}>
34
+ {@render children?.()}
35
+ </div>
@@ -1,12 +1,21 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useSliderContext } from "./context.svelte.js";
5
- let { children, ...props } = $props();
6
- let context = useSliderContext();
7
- let attrs = $derived(mergeProps(props, context.getTrackProps()));
8
- </script>
9
-
10
- <div {...attrs}>
11
- {@render children?.()}
12
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ export interface SliderTrackProps extends Assign<SvelteHTMLElements['div'], {}> {}
6
+ </script>
7
+
8
+ <script lang="ts">
9
+ import {mergeProps} from '@zag-js/svelte';
10
+ import {useSliderContext} from './context.svelte.js';
11
+
12
+ let {children, ...props}: SliderTrackProps = $props();
13
+
14
+ let context = useSliderContext();
15
+
16
+ let attrs = $derived(mergeProps(props, context.getTrackProps()));
17
+ </script>
18
+
19
+ <div {...attrs}>
20
+ {@render children?.()}
21
+ </div>
@@ -1,16 +1,25 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useSliderContext } from "./context.svelte.js";
5
- let { children, ...props } = $props();
6
- let context = useSliderContext();
7
- let attrs = $derived(mergeProps(props, context.getValueTextProps()));
8
- </script>
9
-
10
- <span {...attrs}>
11
- {#if children}
12
- {@render children()}
13
- {:else}
14
- {context.value.join(', ')}
15
- {/if}
16
- </span>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ export interface SliderValueTextProps extends Assign<SvelteHTMLElements['span'], {}> {}
6
+ </script>
7
+
8
+ <script lang="ts">
9
+ import {mergeProps} from '@zag-js/svelte';
10
+ import {useSliderContext} from './context.svelte.js';
11
+
12
+ let {children, ...props}: SliderValueTextProps = $props();
13
+
14
+ let context = useSliderContext();
15
+
16
+ let attrs = $derived(mergeProps(props, context.getValueTextProps()));
17
+ </script>
18
+
19
+ <span {...attrs}>
20
+ {#if children}
21
+ {@render children()}
22
+ {:else}
23
+ {context.value.join(', ')}
24
+ {/if}
25
+ </span>
@@ -1,12 +1,22 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useStepsContext } from "./context.svelte.js";
5
- let { index, children, ...props } = $props();
6
- let context = useStepsContext();
7
- let attrs = $derived(mergeProps(props, context.getContentProps({ index })));
8
- </script>
9
-
10
- <div {...attrs}>
11
- {@render children?.()}
12
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {ItemProps} from '@zag-js/steps';
4
+ import type {SvelteHTMLElements} from 'svelte/elements';
5
+
6
+ export interface StepsContentProps extends Assign<SvelteHTMLElements['div'], ItemProps> {}
7
+ </script>
8
+
9
+ <script lang="ts">
10
+ import {mergeProps} from '@zag-js/svelte';
11
+ import {useStepsContext} from './context.svelte.js';
12
+
13
+ let {index, children, ...props}: StepsContentProps = $props();
14
+
15
+ let context = useStepsContext();
16
+
17
+ let attrs = $derived(mergeProps(props, context.getContentProps({index})));
18
+ </script>
19
+
20
+ <div {...attrs}>
21
+ {@render children?.()}
22
+ </div>
@@ -1,13 +1,22 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useStepsContext, useStepsItemContext } from "./context.svelte.js";
5
- let { children, ...props } = $props();
6
- let context = useStepsContext();
7
- let itemContext = useStepsItemContext();
8
- let attrs = $derived(mergeProps(props, context.getIndicatorProps(itemContext)));
9
- </script>
10
-
11
- <div {...attrs}>
12
- {@render children?.()}
13
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ export interface StepsIndicatorProps extends Assign<SvelteHTMLElements['div'], {}> {}
6
+ </script>
7
+
8
+ <script lang="ts">
9
+ import {mergeProps} from '@zag-js/svelte';
10
+ import {useStepsContext, useStepsItemContext} from './context.svelte.js';
11
+
12
+ let {children, ...props}: StepsIndicatorProps = $props();
13
+
14
+ let context = useStepsContext();
15
+ let itemContext = useStepsItemContext();
16
+
17
+ let attrs = $derived(mergeProps(props, context.getIndicatorProps(itemContext)));
18
+ </script>
19
+
20
+ <div {...attrs}>
21
+ {@render children?.()}
22
+ </div>
@@ -1,13 +1,24 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { setStepsItemContext, useStepsContext } from "./context.svelte.js";
5
- let { index, children, ...props } = $props();
6
- let context = useStepsContext();
7
- let attrs = $derived(mergeProps(props, context.getItemProps({ index })));
8
- setStepsItemContext({ index });
9
- </script>
10
-
11
- <div {...attrs}>
12
- {@render children?.()}
13
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {ItemProps} from '@zag-js/steps';
4
+ import type {SvelteHTMLElements} from 'svelte/elements';
5
+
6
+ export interface StepsItemProps extends Assign<SvelteHTMLElements['div'], ItemProps> {}
7
+ </script>
8
+
9
+ <script lang="ts">
10
+ import {mergeProps} from '@zag-js/svelte';
11
+ import {setStepsItemContext, useStepsContext} from './context.svelte.js';
12
+
13
+ let {index, children, ...props}: StepsItemProps = $props();
14
+
15
+ let context = useStepsContext();
16
+
17
+ let attrs = $derived(mergeProps(props, context.getItemProps({index})));
18
+
19
+ setStepsItemContext({index});
20
+ </script>
21
+
22
+ <div {...attrs}>
23
+ {@render children?.()}
24
+ </div>
@@ -1,12 +1,21 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useStepsContext } from "./context.svelte.js";
5
- let { children, ...props } = $props();
6
- let context = useStepsContext();
7
- let attrs = $derived(mergeProps(props, context.getListProps()));
8
- </script>
9
-
10
- <div {...attrs}>
11
- {@render children?.()}
12
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ export interface StepsListProps extends Assign<SvelteHTMLElements['div'], {}> {}
6
+ </script>
7
+
8
+ <script lang="ts">
9
+ import {mergeProps} from '@zag-js/svelte';
10
+ import {useStepsContext} from './context.svelte.js';
11
+
12
+ let {children, ...props}: StepsListProps = $props();
13
+
14
+ let context = useStepsContext();
15
+
16
+ let attrs = $derived(mergeProps(props, context.getListProps()));
17
+ </script>
18
+
19
+ <div {...attrs}>
20
+ {@render children?.()}
21
+ </div>
@@ -1,12 +1,21 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useStepsContext } from "./context.svelte.js";
5
- let { children, ...props } = $props();
6
- let context = useStepsContext();
7
- let attrs = $derived(mergeProps(props, context.getNextTriggerProps()));
8
- </script>
9
-
10
- <button type="button" {...attrs}>
11
- {@render children?.()}
12
- </button>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ export interface StepsNextTriggerProps extends Assign<SvelteHTMLElements['button'], {}> {}
6
+ </script>
7
+
8
+ <script lang="ts">
9
+ import {mergeProps} from '@zag-js/svelte';
10
+ import {useStepsContext} from './context.svelte.js';
11
+
12
+ let {children, ...props}: StepsNextTriggerProps = $props();
13
+
14
+ let context = useStepsContext();
15
+
16
+ let attrs = $derived(mergeProps(props, context.getNextTriggerProps()));
17
+ </script>
18
+
19
+ <button type="button" {...attrs}>
20
+ {@render children?.()}
21
+ </button>
@@ -1,12 +1,21 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useStepsContext } from "./context.svelte.js";
5
- let { children, ...props } = $props();
6
- let context = useStepsContext();
7
- let attrs = $derived(mergeProps(props, context.getPrevTriggerProps()));
8
- </script>
9
-
10
- <button type="button" {...attrs}>
11
- {@render children?.()}
12
- </button>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ export interface StepsPrevTriggerProps extends Assign<SvelteHTMLElements['button'], {}> {}
6
+ </script>
7
+
8
+ <script lang="ts">
9
+ import {mergeProps} from '@zag-js/svelte';
10
+ import {useStepsContext} from './context.svelte.js';
11
+
12
+ let {children, ...props}: StepsPrevTriggerProps = $props();
13
+
14
+ let context = useStepsContext();
15
+
16
+ let attrs = $derived(mergeProps(props, context.getPrevTriggerProps()));
17
+ </script>
18
+
19
+ <button type="button" {...attrs}>
20
+ {@render children?.()}
21
+ </button>
@@ -1,12 +1,21 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { mergeProps } from "@zag-js/svelte";
4
- import { useStepsContext } from "./context.svelte.js";
5
- let { children, ...props } = $props();
6
- let context = useStepsContext();
7
- let attrs = $derived(mergeProps(props, context.getProgressProps()));
8
- </script>
9
-
10
- <div {...attrs}>
11
- {@render children?.()}
12
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign} from '../types.js';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ export interface StepsProgressProps extends Assign<SvelteHTMLElements['div'], {}> {}
6
+ </script>
7
+
8
+ <script lang="ts">
9
+ import {mergeProps} from '@zag-js/svelte';
10
+ import {useStepsContext} from './context.svelte.js';
11
+
12
+ let {children, ...props}: StepsProgressProps = $props();
13
+
14
+ let context = useStepsContext();
15
+
16
+ let attrs = $derived(mergeProps(props, context.getProgressProps()));
17
+ </script>
18
+
19
+ <div {...attrs}>
20
+ {@render children?.()}
21
+ </div>
@@ -1,38 +1,56 @@
1
- <script lang="ts" context="module"></script>
2
-
3
- <script lang="ts">import { uuid } from "../utils.svelte.js";
4
- import { mergeProps } from "@zag-js/svelte";
5
- import { createStepsContext, setStepsContext } from "./context.svelte.js";
6
- let {
7
- id = uuid(),
8
- ids,
9
- dir,
10
- step,
11
- count,
12
- linear,
13
- orientation,
14
- onStepChange,
15
- onStepComplete,
16
- getRootNode,
17
- children,
18
- ...props
19
- } = $props();
20
- let context = createStepsContext({
21
- id,
22
- ids,
23
- dir,
24
- step,
25
- count,
26
- linear,
27
- orientation,
28
- onStepChange,
29
- onStepComplete,
30
- getRootNode
31
- });
32
- let attrs = $derived(mergeProps(props, context.getRootProps()));
33
- setStepsContext(context);
34
- </script>
35
-
36
- <div {...attrs}>
37
- {@render children?.(context)}
38
- </div>
1
+ <script lang="ts" context="module">
2
+ import type {Assign, OptionalId, WithoutChildren} from '../types.js';
3
+ import type {Snippet} from 'svelte';
4
+ import type {SvelteHTMLElements} from 'svelte/elements';
5
+ import type {CreateStepsContextProps, CreateStepsContextReturn} from './context.svelte.js';
6
+
7
+ export interface StepsProps
8
+ extends Assign<
9
+ WithoutChildren<SvelteHTMLElements['div']>,
10
+ OptionalId<CreateStepsContextProps>
11
+ > {
12
+ children?: Snippet<[CreateStepsContextReturn]>;
13
+ }
14
+ </script>
15
+
16
+ <script lang="ts">
17
+ import {uuid} from '../utils.svelte.js';
18
+ import {mergeProps} from '@zag-js/svelte';
19
+ import {createStepsContext, setStepsContext} from './context.svelte.js';
20
+
21
+ let {
22
+ id = uuid(),
23
+ ids,
24
+ dir,
25
+ step,
26
+ count,
27
+ linear,
28
+ orientation,
29
+ onStepChange,
30
+ onStepComplete,
31
+ getRootNode,
32
+ children,
33
+ ...props
34
+ }: StepsProps = $props();
35
+
36
+ let context = createStepsContext({
37
+ id,
38
+ ids,
39
+ dir,
40
+ step,
41
+ count,
42
+ linear,
43
+ orientation,
44
+ onStepChange,
45
+ onStepComplete,
46
+ getRootNode,
47
+ });
48
+
49
+ let attrs = $derived(mergeProps(props, context.getRootProps()));
50
+
51
+ setStepsContext(context);
52
+ </script>
53
+
54
+ <div {...attrs}>
55
+ {@render children?.(context)}
56
+ </div>