bits-ui 0.16.0 → 0.18.0

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 (223) hide show
  1. package/dist/bits/accordion/_export.types.d.ts +1 -1
  2. package/dist/bits/accordion/components/accordion-content.svelte +3 -18
  3. package/dist/bits/accordion/ctx.d.ts +40 -10
  4. package/dist/bits/accordion/ctx.js +3 -3
  5. package/dist/bits/accordion/types.d.ts +1 -1
  6. package/dist/bits/alert-dialog/_export.types.d.ts +1 -1
  7. package/dist/bits/alert-dialog/_types.d.ts +1 -1
  8. package/dist/bits/alert-dialog/components/alert-dialog-overlay.svelte +2 -12
  9. package/dist/bits/alert-dialog/components/alert-dialog-title.svelte +1 -6
  10. package/dist/bits/alert-dialog/components/alert-dialog.svelte.d.ts +1 -1
  11. package/dist/bits/alert-dialog/ctx.d.ts +18 -10
  12. package/dist/bits/alert-dialog/ctx.js +4 -4
  13. package/dist/bits/alert-dialog/types.d.ts +1 -1
  14. package/dist/bits/aspect-ratio/components/aspect-ratio.svelte +1 -5
  15. package/dist/bits/avatar/_export.types.d.ts +1 -1
  16. package/dist/bits/avatar/ctx.d.ts +7 -1
  17. package/dist/bits/avatar/ctx.js +2 -2
  18. package/dist/bits/button/_export.types.d.ts +1 -1
  19. package/dist/bits/button/types.d.ts +1 -1
  20. package/dist/bits/calendar/_export.types.d.ts +1 -1
  21. package/dist/bits/calendar/_types.d.ts +1 -1
  22. package/dist/bits/calendar/components/calendar-next-button.svelte +1 -7
  23. package/dist/bits/calendar/components/calendar-prev-button.svelte +1 -7
  24. package/dist/bits/calendar/components/calendar.svelte +2 -12
  25. package/dist/bits/calendar/ctx.d.ts +22 -17
  26. package/dist/bits/calendar/ctx.js +2 -2
  27. package/dist/bits/calendar/types.d.ts +1 -1
  28. package/dist/bits/checkbox/_export.types.d.ts +1 -1
  29. package/dist/bits/checkbox/_types.d.ts +1 -1
  30. package/dist/bits/checkbox/components/checkbox-input.svelte +1 -6
  31. package/dist/bits/checkbox/ctx.d.ts +8 -2
  32. package/dist/bits/checkbox/ctx.js +2 -2
  33. package/dist/bits/checkbox/types.d.ts +1 -1
  34. package/dist/bits/collapsible/_export.types.d.ts +1 -1
  35. package/dist/bits/collapsible/components/collapsible-content.svelte +3 -18
  36. package/dist/bits/collapsible/components/collapsible-trigger.svelte +1 -7
  37. package/dist/bits/collapsible/ctx.d.ts +9 -3
  38. package/dist/bits/collapsible/ctx.js +2 -2
  39. package/dist/bits/collapsible/types.d.ts +1 -1
  40. package/dist/bits/combobox/_export.types.d.ts +1 -0
  41. package/dist/bits/combobox/_export.types.js +1 -0
  42. package/dist/bits/combobox/_types.d.ts +62 -0
  43. package/dist/bits/combobox/_types.js +1 -0
  44. package/dist/bits/combobox/components/combobox-arrow.svelte +21 -0
  45. package/dist/bits/combobox/components/combobox-arrow.svelte.d.ts +26 -0
  46. package/dist/bits/combobox/components/combobox-content.svelte +104 -0
  47. package/dist/bits/combobox/components/combobox-content.svelte.d.ts +27 -0
  48. package/dist/bits/combobox/components/combobox-group-label.svelte +25 -0
  49. package/dist/bits/combobox/components/combobox-group-label.svelte.d.ts +23 -0
  50. package/dist/bits/combobox/components/combobox-group.svelte +19 -0
  51. package/dist/bits/combobox/components/combobox-group.svelte.d.ts +26 -0
  52. package/dist/bits/combobox/components/combobox-hidden-input.svelte +25 -0
  53. package/dist/bits/combobox/components/combobox-hidden-input.svelte.d.ts +32 -0
  54. package/dist/bits/combobox/components/combobox-input.svelte +31 -0
  55. package/dist/bits/combobox/components/combobox-input.svelte.d.ts +33 -0
  56. package/dist/bits/combobox/components/combobox-item-indicator.svelte +16 -0
  57. package/dist/bits/combobox/components/combobox-item-indicator.svelte.d.ts +20 -0
  58. package/dist/bits/combobox/components/combobox-item.svelte +47 -0
  59. package/dist/bits/combobox/components/combobox-item.svelte.d.ts +31 -0
  60. package/dist/bits/combobox/components/combobox-label.svelte +22 -0
  61. package/dist/bits/combobox/components/combobox-label.svelte.d.ts +17 -0
  62. package/dist/bits/combobox/components/combobox.svelte +113 -0
  63. package/dist/bits/combobox/components/combobox.svelte.d.ts +41 -0
  64. package/dist/bits/combobox/ctx.d.ts +187 -0
  65. package/dist/bits/combobox/ctx.js +91 -0
  66. package/dist/bits/combobox/index.d.ts +12 -0
  67. package/dist/bits/combobox/index.js +12 -0
  68. package/dist/bits/combobox/types.d.ts +36 -0
  69. package/dist/bits/combobox/types.js +1 -0
  70. package/dist/bits/context-menu/_export.types.d.ts +1 -1
  71. package/dist/bits/context-menu/components/context-menu-content.svelte +1 -6
  72. package/dist/bits/context-menu/components/context-menu.svelte +4 -7
  73. package/dist/bits/context-menu/components/context-menu.svelte.d.ts +2 -2
  74. package/dist/bits/context-menu/ctx.d.ts +24 -8
  75. package/dist/bits/context-menu/ctx.js +5 -5
  76. package/dist/bits/context-menu/types.d.ts +1 -1
  77. package/dist/bits/date-field/_export.types.d.ts +1 -1
  78. package/dist/bits/date-field/components/date-field.svelte +1 -5
  79. package/dist/bits/date-field/ctx.d.ts +24 -13
  80. package/dist/bits/date-field/ctx.js +2 -2
  81. package/dist/bits/date-field/types.d.ts +1 -1
  82. package/dist/bits/date-picker/_export.types.d.ts +1 -1
  83. package/dist/bits/date-picker/components/date-picker-calendar.svelte +1 -6
  84. package/dist/bits/date-picker/components/date-picker-content.svelte +3 -18
  85. package/dist/bits/date-picker/components/date-picker-field.svelte +1 -5
  86. package/dist/bits/date-picker/components/date-picker-next-button.svelte +1 -7
  87. package/dist/bits/date-picker/components/date-picker-prev-button.svelte +1 -7
  88. package/dist/bits/date-picker/components/date-picker.svelte +1 -5
  89. package/dist/bits/date-picker/ctx.d.ts +174 -140
  90. package/dist/bits/date-picker/ctx.js +5 -5
  91. package/dist/bits/date-picker/types.d.ts +1 -1
  92. package/dist/bits/date-range-field/_export.types.d.ts +1 -1
  93. package/dist/bits/date-range-field/components/date-range-field.svelte +2 -11
  94. package/dist/bits/date-range-field/ctx.d.ts +60 -45
  95. package/dist/bits/date-range-field/ctx.js +1 -1
  96. package/dist/bits/date-range-picker/_export.types.d.ts +1 -1
  97. package/dist/bits/date-range-picker/components/date-range-picker-content.svelte +3 -18
  98. package/dist/bits/date-range-picker/components/date-range-picker-field.svelte +1 -5
  99. package/dist/bits/date-range-picker/ctx.d.ts +224 -182
  100. package/dist/bits/date-range-picker/ctx.js +5 -5
  101. package/dist/bits/date-range-picker/types.d.ts +1 -1
  102. package/dist/bits/dialog/_export.types.d.ts +1 -1
  103. package/dist/bits/dialog/_types.d.ts +1 -1
  104. package/dist/bits/dialog/components/dialog-title.svelte +1 -6
  105. package/dist/bits/dialog/components/dialog.svelte.d.ts +1 -1
  106. package/dist/bits/dialog/ctx.d.ts +9 -5
  107. package/dist/bits/dialog/ctx.js +4 -4
  108. package/dist/bits/dialog/types.d.ts +1 -1
  109. package/dist/bits/dropdown-menu/_export.types.d.ts +1 -1
  110. package/dist/bits/dropdown-menu/types.d.ts +1 -1
  111. package/dist/bits/floating/helpers.js +3 -3
  112. package/dist/bits/index.d.ts +1 -0
  113. package/dist/bits/index.js +1 -0
  114. package/dist/bits/label/_export.types.d.ts +1 -1
  115. package/dist/bits/label/components/label.svelte +1 -6
  116. package/dist/bits/label/ctx.js +1 -1
  117. package/dist/bits/label/types.d.ts +1 -1
  118. package/dist/bits/link-preview/_export.types.d.ts +1 -1
  119. package/dist/bits/link-preview/components/link-preview.svelte +4 -7
  120. package/dist/bits/link-preview/ctx.d.ts +7 -3
  121. package/dist/bits/link-preview/ctx.js +6 -6
  122. package/dist/bits/link-preview/types.d.ts +1 -1
  123. package/dist/bits/menu/_types.d.ts +1 -1
  124. package/dist/bits/menu/components/menu-content.svelte +1 -6
  125. package/dist/bits/menu/components/menu-sub-trigger.svelte +7 -2
  126. package/dist/bits/menu/components/menu-sub.svelte +4 -7
  127. package/dist/bits/menu/components/menu.svelte +4 -7
  128. package/dist/bits/menu/components/menu.svelte.d.ts +2 -2
  129. package/dist/bits/menu/ctx.d.ts +54 -18
  130. package/dist/bits/menu/ctx.js +20 -20
  131. package/dist/bits/menu/types.d.ts +1 -1
  132. package/dist/bits/menubar/_export.types.d.ts +1 -1
  133. package/dist/bits/menubar/components/menubar-menu.svelte +4 -7
  134. package/dist/bits/menubar/components/menubar-menu.svelte.d.ts +2 -2
  135. package/dist/bits/menubar/components/menubar-sub.svelte +4 -7
  136. package/dist/bits/menubar/ctx.d.ts +51 -23
  137. package/dist/bits/menubar/ctx.js +12 -12
  138. package/dist/bits/menubar/types.d.ts +1 -1
  139. package/dist/bits/pagination/_export.types.d.ts +1 -1
  140. package/dist/bits/pagination/components/pagination-next-button.svelte +1 -7
  141. package/dist/bits/pagination/components/pagination-page.svelte +1 -7
  142. package/dist/bits/pagination/components/pagination-prev-button.svelte +1 -7
  143. package/dist/bits/pagination/ctx.d.ts +9 -1
  144. package/dist/bits/pagination/ctx.js +2 -2
  145. package/dist/bits/pagination/types.d.ts +1 -1
  146. package/dist/bits/pin-input/_export.types.d.ts +1 -1
  147. package/dist/bits/pin-input/ctx.d.ts +10 -4
  148. package/dist/bits/pin-input/ctx.js +2 -2
  149. package/dist/bits/pin-input/types.d.ts +1 -1
  150. package/dist/bits/popover/_export.types.d.ts +1 -1
  151. package/dist/bits/popover/components/popover-content.svelte +3 -18
  152. package/dist/bits/popover/components/popover.svelte +4 -7
  153. package/dist/bits/popover/ctx.d.ts +7 -3
  154. package/dist/bits/popover/ctx.js +7 -7
  155. package/dist/bits/popover/types.d.ts +1 -1
  156. package/dist/bits/progress/ctx.d.ts +5 -1
  157. package/dist/bits/progress/ctx.js +2 -2
  158. package/dist/bits/radio-group/_export.types.d.ts +1 -1
  159. package/dist/bits/radio-group/ctx.d.ts +24 -12
  160. package/dist/bits/radio-group/ctx.js +2 -2
  161. package/dist/bits/radio-group/types.d.ts +1 -1
  162. package/dist/bits/range-calendar/_export.types.d.ts +1 -1
  163. package/dist/bits/range-calendar/_types.d.ts +1 -1
  164. package/dist/bits/range-calendar/components/range-calendar-next-button.svelte +1 -7
  165. package/dist/bits/range-calendar/components/range-calendar-prev-button.svelte +1 -7
  166. package/dist/bits/range-calendar/components/range-calendar.svelte +1 -6
  167. package/dist/bits/range-calendar/ctx.d.ts +27 -22
  168. package/dist/bits/range-calendar/ctx.js +2 -2
  169. package/dist/bits/range-calendar/types.d.ts +1 -1
  170. package/dist/bits/select/_export.types.d.ts +1 -1
  171. package/dist/bits/select/_types.d.ts +1 -1
  172. package/dist/bits/select/components/select-content.svelte +1 -7
  173. package/dist/bits/select/components/select-trigger.svelte.d.ts +1 -0
  174. package/dist/bits/select/components/select-value.svelte +1 -6
  175. package/dist/bits/select/components/select.svelte.d.ts +1 -1
  176. package/dist/bits/select/ctx.d.ts +26 -17
  177. package/dist/bits/select/ctx.js +11 -11
  178. package/dist/bits/select/types.d.ts +1 -1
  179. package/dist/bits/separator/ctx.d.ts +1 -1
  180. package/dist/bits/separator/ctx.js +2 -2
  181. package/dist/bits/slider/_export.types.d.ts +1 -1
  182. package/dist/bits/slider/_types.d.ts +19 -3
  183. package/dist/bits/slider/components/slider-thumb.svelte +4 -11
  184. package/dist/bits/slider/components/slider-tick.svelte +3 -5
  185. package/dist/bits/slider/components/slider.svelte +4 -4
  186. package/dist/bits/slider/components/slider.svelte.d.ts +40 -1
  187. package/dist/bits/slider/ctx.d.ts +11 -16
  188. package/dist/bits/slider/ctx.js +2 -2
  189. package/dist/bits/slider/types.d.ts +1 -1
  190. package/dist/bits/switch/_export.types.d.ts +1 -1
  191. package/dist/bits/switch/ctx.d.ts +9 -3
  192. package/dist/bits/switch/ctx.js +2 -2
  193. package/dist/bits/switch/types.d.ts +1 -1
  194. package/dist/bits/tabs/_export.types.d.ts +1 -1
  195. package/dist/bits/tabs/components/tabs-trigger.svelte.d.ts +1 -1
  196. package/dist/bits/tabs/ctx.d.ts +10 -4
  197. package/dist/bits/tabs/ctx.js +2 -2
  198. package/dist/bits/tabs/types.d.ts +1 -1
  199. package/dist/bits/toggle/_export.types.d.ts +1 -1
  200. package/dist/bits/toggle/_types.d.ts +1 -1
  201. package/dist/bits/toggle/ctx.d.ts +5 -1
  202. package/dist/bits/toggle/ctx.js +2 -2
  203. package/dist/bits/toggle/types.d.ts +1 -1
  204. package/dist/bits/toggle-group/_export.types.d.ts +1 -1
  205. package/dist/bits/toggle-group/ctx.d.ts +6 -2
  206. package/dist/bits/toggle-group/ctx.js +2 -2
  207. package/dist/bits/toggle-group/types.d.ts +1 -1
  208. package/dist/bits/toolbar/_export.types.d.ts +1 -1
  209. package/dist/bits/toolbar/components/toolbar-button.svelte +1 -7
  210. package/dist/bits/toolbar/ctx.d.ts +16 -8
  211. package/dist/bits/toolbar/ctx.js +5 -5
  212. package/dist/bits/toolbar/types.d.ts +1 -1
  213. package/dist/bits/tooltip/_export.types.d.ts +1 -1
  214. package/dist/bits/tooltip/components/tooltip.svelte +4 -7
  215. package/dist/bits/tooltip/ctx.d.ts +9 -3
  216. package/dist/bits/tooltip/ctx.js +7 -7
  217. package/dist/bits/tooltip/types.d.ts +1 -1
  218. package/dist/helpers/builders.js +1 -1
  219. package/dist/internal/attrs.js +1 -1
  220. package/dist/internal/focus.js +1 -1
  221. package/dist/internal/kbd.js +1 -1
  222. package/dist/internal/style.js +1 -1
  223. package/package.json +22 -22
@@ -0,0 +1,187 @@
1
+ /// <reference types="svelte" />
2
+ import { type CreateComboboxProps } from "@melt-ui/svelte";
3
+ import type { Writable } from "svelte/store";
4
+ import type { FloatingProps } from "../floating/_types.js";
5
+ type GetReturn = Omit<ReturnType<typeof setCtx>, "updateOption">;
6
+ export declare function getCtx(): GetReturn;
7
+ type Items<T> = {
8
+ value: T;
9
+ label?: string;
10
+ };
11
+ type Props<T = unknown, M extends boolean = false> = CreateComboboxProps<T, M> & {
12
+ items?: Items<T>[];
13
+ };
14
+ export declare function setCtx<T = unknown, M extends boolean = false>(props: Props<T, M>): {
15
+ updateOption: <K extends string, V extends unknown>(key: K, value: V | undefined) => void;
16
+ getAttrs: (part: "content" | "label" | "hidden-input" | "arrow" | "menu" | "group" | "input" | "item" | "indicator" | "group-label") => Record<string, string>;
17
+ elements: {
18
+ input: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[{
19
+ update: (updater: import("svelte/store").Updater<boolean>, sideEffect?: ((newValue: boolean) => void) | undefined) => void;
20
+ set: (this: void, value: boolean) => void;
21
+ subscribe(this: void, run: import("svelte/store").Subscriber<boolean>, invalidate?: import("svelte/store").Invalidator<boolean> | undefined): import("svelte/store").Unsubscriber;
22
+ get: () => boolean;
23
+ destroy?: (() => void) | undefined;
24
+ }, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<HTMLElement | null>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<boolean>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"input" | "keydown" | "click">, ([$open, $highlightedItem, $disabled, $menuId, $triggerId, $labelId]: [boolean, HTMLElement | null, boolean, string, string, string]) => {
25
+ readonly 'aria-activedescendant': string | undefined;
26
+ readonly 'aria-autocomplete': "list";
27
+ readonly 'aria-controls': string;
28
+ readonly 'aria-expanded': boolean;
29
+ readonly 'aria-labelledby': string;
30
+ readonly id: string;
31
+ readonly role: "combobox";
32
+ readonly disabled: true | undefined;
33
+ readonly type: "button" | undefined;
34
+ }, string>, Writable<string>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"input" | "keydown" | "click">, ([$trigger, $inputValue]: [{
35
+ readonly 'aria-activedescendant': string | undefined;
36
+ readonly 'aria-autocomplete': "list";
37
+ readonly 'aria-controls': string;
38
+ readonly 'aria-expanded': boolean;
39
+ readonly 'aria-labelledby': string;
40
+ readonly id: string;
41
+ readonly role: "combobox";
42
+ readonly disabled: true | undefined;
43
+ readonly type: "button" | undefined;
44
+ } & {
45
+ [x: `data-melt-${string}`]: "";
46
+ } & {
47
+ action: (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"input" | "keydown" | "click">;
48
+ }, string]) => {
49
+ readonly role: "combobox";
50
+ readonly value: string;
51
+ readonly disabled: true | undefined;
52
+ readonly type: "button" | undefined;
53
+ readonly 'aria-expanded': boolean;
54
+ readonly 'aria-controls': string;
55
+ readonly 'aria-activedescendant': string | undefined;
56
+ readonly 'aria-autocomplete': "list";
57
+ readonly 'aria-labelledby': string;
58
+ readonly id: string;
59
+ }, string>;
60
+ label: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"mousedown">, ([$labelId, $triggerId]: [string, string]) => {
61
+ id: string;
62
+ for: string;
63
+ }, string>;
64
+ menu: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("svelte/store").Readable<boolean>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"pointerleave">, ([$isVisible, $menuId]: [boolean, string]) => {
65
+ readonly hidden: true | undefined;
66
+ readonly id: string;
67
+ readonly role: "listbox";
68
+ readonly style: string;
69
+ }, string>;
70
+ option: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("svelte/store").Readable<(value: unknown) => boolean>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"click" | "pointermove">, ([$isSelected]: [(value: unknown) => boolean]) => (props: import("@melt-ui/svelte/index.js").ComboboxOptionProps<unknown>) => {
71
+ readonly 'data-value': string;
72
+ readonly 'data-label': string | undefined;
73
+ readonly 'data-disabled': true | undefined;
74
+ readonly 'aria-disabled': true | undefined;
75
+ readonly 'aria-selected': boolean;
76
+ readonly 'data-selected': "" | undefined;
77
+ readonly id: string;
78
+ readonly role: "option";
79
+ }, string>;
80
+ group: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<import("svelte/store").Stores | undefined, import("svelte/action").Action<any, any, Record<never, any>>, () => (groupId: string) => {
81
+ role: string;
82
+ 'aria-labelledby': string;
83
+ }, string>;
84
+ arrow: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<import("@melt-ui/svelte/internal/helpers").WithGet<Writable<number | undefined>>, import("svelte/action").Action<any, any, Record<never, any>>, ($arrowSize: number | undefined) => {
85
+ 'data-arrow': boolean;
86
+ style: string;
87
+ }, string>;
88
+ groupLabel: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<import("svelte/store").Stores | undefined, import("svelte/action").Action<any, any, Record<never, any>>, () => (groupId: string) => {
89
+ id: string;
90
+ }, string>;
91
+ hiddenInput: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[{
92
+ update: (updater: import("svelte/store").Updater<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined>, sideEffect?: ((newValue: import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined) => void) | undefined) => void;
93
+ set: (this: void, value: import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined) => void;
94
+ subscribe(this: void, run: import("svelte/store").Subscriber<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined>, invalidate?: import("svelte/store").Invalidator<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined> | undefined): import("svelte/store").Unsubscriber;
95
+ get: () => import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined;
96
+ destroy?: (() => void) | undefined;
97
+ }, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<boolean>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string | undefined>>], import("svelte/action").Action<any, any, Record<never, any>>, ([$selected, $required, $name]: [import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined, boolean, string | undefined]) => {
98
+ required: boolean | undefined;
99
+ value: unknown;
100
+ name: string | undefined;
101
+ type: string;
102
+ 'aria-hidden': boolean;
103
+ hidden: boolean;
104
+ tabIndex: number;
105
+ style: string;
106
+ }, string>;
107
+ };
108
+ states: {
109
+ touchedInput: Writable<boolean>;
110
+ inputValue: Writable<string>;
111
+ open: {
112
+ update: (updater: import("svelte/store").Updater<boolean>, sideEffect?: ((newValue: boolean) => void) | undefined) => void;
113
+ set: (this: void, value: boolean) => void;
114
+ subscribe(this: void, run: import("svelte/store").Subscriber<boolean>, invalidate?: import("svelte/store").Invalidator<boolean> | undefined): import("svelte/store").Unsubscriber;
115
+ get: () => boolean;
116
+ destroy?: (() => void) | undefined;
117
+ };
118
+ selected: {
119
+ update: (updater: import("svelte/store").Updater<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined>, sideEffect?: ((newValue: import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined) => void) | undefined) => void;
120
+ set: (this: void, value: import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined) => void;
121
+ subscribe(this: void, run: import("svelte/store").Subscriber<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined>, invalidate?: import("svelte/store").Invalidator<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined> | undefined): import("svelte/store").Unsubscriber;
122
+ get: () => import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined;
123
+ destroy?: (() => void) | undefined;
124
+ };
125
+ highlighted: import("svelte/store").Readable<import("@melt-ui/svelte/index.js").ComboboxOption<unknown> | undefined>;
126
+ highlightedItem: import("@melt-ui/svelte/internal/helpers").WithGet<Writable<HTMLElement | null>>;
127
+ };
128
+ ids: import("@melt-ui/svelte/internal/helpers").ToWritableStores<{
129
+ label: string;
130
+ menu: string;
131
+ trigger: string;
132
+ }>;
133
+ helpers: {
134
+ isSelected: import("svelte/store").Readable<(value: unknown) => boolean>;
135
+ isHighlighted: import("svelte/store").Readable<(item: unknown) => boolean>;
136
+ closeMenu: () => void;
137
+ };
138
+ options: import("@melt-ui/svelte/internal/helpers").ToWritableStores<{
139
+ multiple: M;
140
+ disabled: boolean;
141
+ forceVisible: boolean;
142
+ name: string | undefined;
143
+ required: boolean;
144
+ onOpenChange?: import("@melt-ui/svelte/internal/helpers").ChangeFn<boolean> | undefined;
145
+ preventScroll: boolean;
146
+ portal: string | HTMLElement | null | undefined;
147
+ positioning: import("@melt-ui/svelte/internal/actions").FloatingConfig | {
148
+ placement: "bottom";
149
+ sameWidth: true;
150
+ };
151
+ arrowSize?: number | undefined;
152
+ scrollAlignment: "center" | "nearest";
153
+ loop: boolean;
154
+ defaultSelected?: import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined;
155
+ selected?: Writable<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>>> | undefined;
156
+ onSelectedChange?: import("@melt-ui/svelte/internal/helpers").ChangeFn<import("@melt-ui/svelte/internal/types").WhenTrue<M, import("@melt-ui/svelte/index.js").ComboboxOption<T>[], import("@melt-ui/svelte/index.js").ComboboxOption<T>, import("@melt-ui/svelte/index.js").ComboboxOption<T>[] | import("@melt-ui/svelte/index.js").ComboboxOption<T>> | undefined> | undefined;
157
+ closeOnOutsideClick: boolean;
158
+ closeOnEscape: boolean;
159
+ onOutsideClick: ((event: PointerEvent) => void) | undefined;
160
+ typeahead: boolean;
161
+ highlightOnHover: boolean;
162
+ }>;
163
+ };
164
+ export declare function setGroupCtx(): {
165
+ group: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<import("svelte/store").Stores | undefined, import("svelte/action").Action<any, any, Record<never, any>>, () => (groupId: string) => {
166
+ role: string;
167
+ 'aria-labelledby': string;
168
+ }, string>;
169
+ id: string;
170
+ getAttrs: (part: "content" | "label" | "hidden-input" | "arrow" | "menu" | "group" | "input" | "item" | "indicator" | "group-label") => Record<string, string>;
171
+ };
172
+ export declare function setItemCtx(value: unknown): GetReturn;
173
+ export declare function getGroupLabel(): {
174
+ groupLabel: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<import("svelte/store").Stores | undefined, import("svelte/action").Action<any, any, Record<never, any>>, () => (groupId: string) => {
175
+ id: string;
176
+ }, string>;
177
+ id: string;
178
+ getAttrs: (part: "content" | "label" | "hidden-input" | "arrow" | "menu" | "group" | "input" | "item" | "indicator" | "group-label") => Record<string, string>;
179
+ };
180
+ export declare function getItemIndicator(): {
181
+ value: unknown;
182
+ isSelected: import("svelte/store").Readable<(value: unknown) => boolean>;
183
+ getAttrs: (part: "content" | "label" | "hidden-input" | "arrow" | "menu" | "group" | "input" | "item" | "indicator" | "group-label") => Record<string, string>;
184
+ };
185
+ export declare function setArrow(size?: number): GetReturn;
186
+ export declare function updatePositioning(props: FloatingProps): void;
187
+ export {};
@@ -0,0 +1,91 @@
1
+ import { createCombobox } from "@melt-ui/svelte";
2
+ import { getContext, setContext } from "svelte";
3
+ import { createBitAttrs, generateId, getOptionUpdater, removeUndefined, } from "../../internal/index.js";
4
+ import { getPositioningUpdater } from "../floating/helpers.js";
5
+ function getSelectData() {
6
+ const NAME = "combobox";
7
+ const GROUP_NAME = "combobox-group";
8
+ const ITEM_NAME = "combobox-item";
9
+ const PARTS = [
10
+ "content",
11
+ "menu",
12
+ "input",
13
+ "item",
14
+ "label",
15
+ "group",
16
+ "group-label",
17
+ "arrow",
18
+ "hidden-input",
19
+ "indicator",
20
+ ];
21
+ return {
22
+ NAME,
23
+ GROUP_NAME,
24
+ ITEM_NAME,
25
+ PARTS,
26
+ };
27
+ }
28
+ export function getCtx() {
29
+ const { NAME } = getSelectData();
30
+ return getContext(NAME);
31
+ }
32
+ export function setCtx(
33
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
34
+ props) {
35
+ const { NAME, PARTS } = getSelectData();
36
+ const getAttrs = createBitAttrs(NAME, PARTS);
37
+ const combobox = {
38
+ ...createCombobox({ ...removeUndefined(props), forceVisible: true }),
39
+ getAttrs,
40
+ };
41
+ setContext(NAME, combobox);
42
+ return {
43
+ ...combobox,
44
+ updateOption: getOptionUpdater(combobox.options),
45
+ };
46
+ }
47
+ export function setGroupCtx() {
48
+ const { GROUP_NAME } = getSelectData();
49
+ const id = generateId();
50
+ setContext(GROUP_NAME, id);
51
+ const { elements: { group }, getAttrs, } = getCtx();
52
+ return { group, id, getAttrs };
53
+ }
54
+ export function setItemCtx(value) {
55
+ const { ITEM_NAME } = getSelectData();
56
+ const combobox = getCtx();
57
+ setContext(ITEM_NAME, value);
58
+ return combobox;
59
+ }
60
+ export function getGroupLabel() {
61
+ const { GROUP_NAME } = getSelectData();
62
+ const id = getContext(GROUP_NAME);
63
+ const { elements: { groupLabel }, getAttrs, } = getCtx();
64
+ return { groupLabel, id, getAttrs };
65
+ }
66
+ export function getItemIndicator() {
67
+ const { ITEM_NAME } = getSelectData();
68
+ const { helpers: { isSelected }, getAttrs, } = getCtx();
69
+ const value = getContext(ITEM_NAME);
70
+ return {
71
+ value,
72
+ isSelected,
73
+ getAttrs,
74
+ };
75
+ }
76
+ export function setArrow(size = 8) {
77
+ const combobox = getCtx();
78
+ combobox.options.arrowSize?.set(size);
79
+ return combobox;
80
+ }
81
+ export function updatePositioning(props) {
82
+ const defaultPlacement = {
83
+ side: "bottom",
84
+ align: "center",
85
+ sameWidth: true,
86
+ };
87
+ const withDefaults = { ...defaultPlacement, ...props };
88
+ const { options: { positioning }, } = getCtx();
89
+ const updater = getPositioningUpdater(positioning);
90
+ updater(withDefaults);
91
+ }
@@ -0,0 +1,12 @@
1
+ export { default as Root } from "./components/combobox.svelte";
2
+ export { default as Content } from "./components/combobox-content.svelte";
3
+ export { default as Input } from "./components/combobox-input.svelte";
4
+ export { default as Item } from "./components/combobox-item.svelte";
5
+ export { default as Label } from "./components/combobox-label.svelte";
6
+ export { default as Group } from "./components/combobox-group.svelte";
7
+ export { default as GroupLabel } from "./components/combobox-group-label.svelte";
8
+ export { default as Arrow } from "./components/combobox-arrow.svelte";
9
+ export { default as HiddenInput } from "./components/combobox-hidden-input.svelte";
10
+ export { default as Separator } from "../separator/components/separator.svelte";
11
+ export { default as ItemIndicator } from "./components/combobox-item-indicator.svelte";
12
+ export * from "./types.js";
@@ -0,0 +1,12 @@
1
+ export { default as Root } from "./components/combobox.svelte";
2
+ export { default as Content } from "./components/combobox-content.svelte";
3
+ export { default as Input } from "./components/combobox-input.svelte";
4
+ export { default as Item } from "./components/combobox-item.svelte";
5
+ export { default as Label } from "./components/combobox-label.svelte";
6
+ export { default as Group } from "./components/combobox-group.svelte";
7
+ export { default as GroupLabel } from "./components/combobox-group-label.svelte";
8
+ export { default as Arrow } from "./components/combobox-arrow.svelte";
9
+ export { default as HiddenInput } from "./components/combobox-hidden-input.svelte";
10
+ export { default as Separator } from "../separator/components/separator.svelte";
11
+ export { default as ItemIndicator } from "./components/combobox-item-indicator.svelte";
12
+ export * from "./types.js";
@@ -0,0 +1,36 @@
1
+ import type { HTMLDivAttributes, Transition } from "../../internal/index.js";
2
+ import type { EventHandler, HTMLInputAttributes } from "svelte/elements";
3
+ import type { CustomEventHandler } from "../../index.js";
4
+ import type * as I from "./_types.js";
5
+ type Props<T, Multiple extends boolean = false> = I.Props<T, Multiple>;
6
+ type ContentProps<T extends Transition = Transition, In extends Transition = Transition, Out extends Transition = Transition> = I.ContentProps<T, In, Out> & HTMLDivAttributes;
7
+ type InputProps = I.InputProps & HTMLInputAttributes;
8
+ type LabelProps = I.LabelProps & HTMLDivAttributes;
9
+ type GroupProps = I.GroupProps & HTMLDivAttributes;
10
+ type GroupLabelProps = I.GroupLabelProps & HTMLDivAttributes;
11
+ type ItemProps = I.ItemProps & HTMLDivAttributes;
12
+ type HiddenInputProps = I.HiddenInputProps & HTMLInputAttributes;
13
+ type SeparatorProps = I.SeparatorProps & HTMLDivAttributes;
14
+ type IndicatorProps = I.IndicatorProps & HTMLDivAttributes;
15
+ type ArrowProps = I.ArrowProps & HTMLDivAttributes;
16
+ type ItemEvents<T extends Element = HTMLDivElement> = {
17
+ click: CustomEventHandler<MouseEvent, T>;
18
+ pointermove: CustomEventHandler<PointerEvent, T>;
19
+ focusin: EventHandler<FocusEvent, T>;
20
+ keydown: EventHandler<KeyboardEvent, T>;
21
+ focusout: EventHandler<FocusEvent, T>;
22
+ pointerleave: EventHandler<PointerEvent, T>;
23
+ };
24
+ type ContentEvents<T extends Element = HTMLDivElement> = {
25
+ pointerleave: CustomEventHandler<PointerEvent, T>;
26
+ keydown: EventHandler<KeyboardEvent, T>;
27
+ };
28
+ type GroupLabelEvents<T extends Element = HTMLSpanElement> = {
29
+ click: CustomEventHandler<MouseEvent, T>;
30
+ };
31
+ type InputEvents = {
32
+ keydown: CustomEventHandler<KeyboardEvent, HTMLInputElement>;
33
+ input: CustomEventHandler<InputEvent, HTMLInputElement>;
34
+ click: CustomEventHandler<ClipboardEvent, HTMLInputElement>;
35
+ };
36
+ export type { Props, ContentProps, InputProps, ItemProps, LabelProps, GroupProps, GroupLabelProps, ArrowProps, HiddenInputProps, SeparatorProps, IndicatorProps, ContentEvents, InputEvents, ItemEvents, GroupLabelEvents, };
@@ -0,0 +1 @@
1
+ export {};
@@ -1 +1 @@
1
- export type { Props as ContextMenuProps, SubProps as ContextMenuSubProps, ItemProps as ContextMenuItemProps, ArrowProps as ContextMenuArrowProps, GroupProps as ContextMenuGroupProps, LabelProps as ContextMenuLabelProps, ContentProps as ContextMenuContentProps, TriggerProps as ContextMenuTriggerProps, RadioItemProps as ContextMenuRadioItemProps, SeparatorProps as ContextMenuSeparatorProps, RadioGroupProps as ContextMenuRadioGroupProps, SubContentProps as ContextMenuSubContentProps, SubTriggerProps as ContextMenuSubTriggerProps, CheckboxItemProps as ContextMenuCheckboxItemProps, RadioIndicatorProps as ContextMenuRadioIndicatorProps, CheckboxIndicatorProps as ContextMenuCheckboxIndicatorProps, ItemEvents as ContextMenuItemEvents, TriggerEvents as ContextMenuTriggerEvents, ContentEvents as ContextMenuContentEvents, RadioItemEvents as ContextMenuRadioItemEvents, SubContentEvents as ContextMenuSubContentEvents, SubTriggerEvents as ContextMenuSubTriggerEvents, CheckboxItemEvents as ContextMenuCheckboxItemEvents } from "./types.js";
1
+ export type { Props as ContextMenuProps, SubProps as ContextMenuSubProps, ItemProps as ContextMenuItemProps, ArrowProps as ContextMenuArrowProps, GroupProps as ContextMenuGroupProps, LabelProps as ContextMenuLabelProps, ContentProps as ContextMenuContentProps, TriggerProps as ContextMenuTriggerProps, RadioItemProps as ContextMenuRadioItemProps, SeparatorProps as ContextMenuSeparatorProps, RadioGroupProps as ContextMenuRadioGroupProps, SubContentProps as ContextMenuSubContentProps, SubTriggerProps as ContextMenuSubTriggerProps, CheckboxItemProps as ContextMenuCheckboxItemProps, RadioIndicatorProps as ContextMenuRadioIndicatorProps, CheckboxIndicatorProps as ContextMenuCheckboxIndicatorProps, ItemEvents as ContextMenuItemEvents, TriggerEvents as ContextMenuTriggerEvents, ContentEvents as ContextMenuContentEvents, RadioItemEvents as ContextMenuRadioItemEvents, SubContentEvents as ContextMenuSubContentEvents, SubTriggerEvents as ContextMenuSubTriggerEvents, CheckboxItemEvents as ContextMenuCheckboxItemEvents, } from "./types.js";
@@ -89,12 +89,7 @@ $:
89
89
  <slot {builder} />
90
90
  </div>
91
91
  {:else if $open}
92
- <div
93
- bind:this={el}
94
- {...builder} use:builder.action
95
- {...$$restProps}
96
- on:m-keydown={dispatch}
97
- >
92
+ <div bind:this={el} {...builder} use:builder.action {...$$restProps} on:m-keydown={dispatch}>
98
93
  <slot {builder} />
99
94
  </div>
100
95
  {/if}
@@ -37,13 +37,10 @@ const {
37
37
  return next;
38
38
  }
39
39
  });
40
- const idValues = derived(
41
- [ids.menu, ids.trigger],
42
- ([$menuId, $triggerId]) => ({
43
- menu: $menuId,
44
- trigger: $triggerId
45
- })
46
- );
40
+ const idValues = derived([ids.menu, ids.trigger], ([$menuId, $triggerId]) => ({
41
+ menu: $menuId,
42
+ trigger: $triggerId
43
+ }));
47
44
  $:
48
45
  open !== void 0 && localOpen.set(open);
49
46
  $:
@@ -7,10 +7,10 @@ declare const __propDef: {
7
7
  onOutsideClick?: ((event: PointerEvent) => void) | undefined;
8
8
  portal?: string | HTMLElement | null | undefined;
9
9
  closeFocus?: import("@melt-ui/svelte/index.js").FocusProp | undefined;
10
+ typeahead?: boolean | undefined;
11
+ loop?: boolean | undefined;
10
12
  dir?: import("@melt-ui/svelte/internal/types").TextDirection | undefined;
11
13
  closeOnItemClick?: boolean | undefined;
12
- loop?: boolean | undefined;
13
- typeahead?: boolean | undefined;
14
14
  disableFocusFirstItem?: boolean | undefined;
15
15
  open?: boolean | undefined;
16
16
  onOpenChange?: import("../../../internal/types.js").OnChangeFn<boolean> | undefined;
@@ -9,13 +9,13 @@ export declare function getContextMenuData(): {
9
9
  type GetReturn = Omit<ReturnType<typeof setCtx>, "updateOption">;
10
10
  export declare function setCtx(props: CreateContextMenuProps): {
11
11
  updateOption: <K extends string, V extends unknown>(key: K, value: V | undefined) => void;
12
- getAttrs: (part: "content" | "checkbox-indicator" | "arrow" | "label" | "group" | "radio-group" | "separator" | "item" | "trigger" | "checkbox-item" | "radio-item" | "sub-content" | "sub-trigger") => Record<string, string>;
12
+ getAttrs: (part: "content" | "checkbox-indicator" | "label" | "arrow" | "group" | "radio-group" | "separator" | "item" | "trigger" | "checkbox-item" | "radio-item" | "sub-content" | "sub-trigger") => Record<string, string>;
13
13
  ids: import("@melt-ui/svelte/internal/helpers").ToWritableStores<{
14
14
  menu: string;
15
15
  trigger: string;
16
16
  }>;
17
17
  elements: {
18
- menu: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("svelte/store").Readable<boolean>, Writable<string | HTMLElement | null | undefined>, Writable<string>, Writable<string>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown">, ([$isVisible, $portal, $menuId, $triggerId]: [boolean, string | HTMLElement | null | undefined, string, string]) => {
18
+ menu: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("svelte/store").Readable<boolean>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string | HTMLElement | null | undefined>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown">, ([$isVisible, $portal, $menuId, $triggerId]: [boolean, string | HTMLElement | null | undefined, string, string]) => {
19
19
  readonly role: "menu";
20
20
  readonly hidden: true | undefined;
21
21
  readonly style: string;
@@ -29,7 +29,9 @@ export declare function setCtx(props: CreateContextMenuProps): {
29
29
  update: (updater: import("svelte/store").Updater<boolean>, sideEffect?: ((newValue: boolean) => void) | undefined) => void;
30
30
  set: (this: void, value: boolean) => void;
31
31
  subscribe(this: void, run: import("svelte/store").Subscriber<boolean>, invalidate?: import("svelte/store").Invalidator<boolean> | undefined): import("svelte/store").Unsubscriber;
32
- }, Writable<string>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"contextmenu" | "pointercancel" | "pointerdown" | "pointermove" | "pointerup">, ([$rootOpen, $triggerId]: [boolean, string]) => {
32
+ get: () => boolean;
33
+ destroy?: (() => void) | undefined;
34
+ }, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"contextmenu" | "pointercancel" | "pointerdown" | "pointermove" | "pointerup">, ([$rootOpen, $triggerId]: [boolean, string]) => {
33
35
  readonly 'data-state': "open" | "closed";
34
36
  readonly id: string;
35
37
  readonly style: string;
@@ -40,11 +42,11 @@ export declare function setCtx(props: CreateContextMenuProps): {
40
42
  tabindex: number;
41
43
  'data-orientation': string;
42
44
  }, string>;
43
- arrow: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<Writable<number | undefined>, import("svelte/action").Action<any, any, Record<never, any>>, ($arrowSize: number | undefined) => {
45
+ arrow: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<import("@melt-ui/svelte/internal/helpers").WithGet<Writable<number | undefined>>, import("svelte/action").Action<any, any, Record<never, any>>, ($arrowSize: number | undefined) => {
44
46
  'data-arrow': boolean;
45
47
  style: string;
46
48
  }, string>;
47
- separator: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[Writable<import("@melt-ui/svelte/internal/types").Orientation>, Writable<boolean>], import("svelte/action").Action<any, any, Record<never, any>>, ([$orientation, $decorative]: [import("@melt-ui/svelte/internal/types").Orientation, boolean]) => {
49
+ separator: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("@melt-ui/svelte/internal/helpers").WithGet<Writable<import("@melt-ui/svelte/internal/types").Orientation>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<boolean>>], import("svelte/action").Action<any, any, Record<never, any>>, ([$orientation, $decorative]: [import("@melt-ui/svelte/internal/types").Orientation, boolean]) => {
48
50
  role: string;
49
51
  'aria-orientation': "vertical" | undefined;
50
52
  'aria-hidden': boolean;
@@ -63,6 +65,8 @@ export declare function setCtx(props: CreateContextMenuProps): {
63
65
  update: (updater: import("svelte/store").Updater<boolean>, sideEffect?: ((newValue: boolean) => void) | undefined) => void;
64
66
  set: (this: void, value: boolean) => void;
65
67
  subscribe(this: void, run: import("svelte/store").Subscriber<boolean>, invalidate?: import("svelte/store").Invalidator<boolean> | undefined): import("svelte/store").Unsubscriber;
68
+ get: () => boolean;
69
+ destroy?: (() => void) | undefined;
66
70
  };
67
71
  };
68
72
  builders: {
@@ -76,7 +80,9 @@ export declare function setCtx(props: CreateContextMenuProps): {
76
80
  update: (updater: import("svelte/store").Updater<boolean>, sideEffect?: ((newValue: boolean) => void) | undefined) => void;
77
81
  set: (this: void, value: boolean) => void;
78
82
  subscribe(this: void, run: import("svelte/store").Subscriber<boolean>, invalidate?: import("svelte/store").Invalidator<boolean> | undefined): import("svelte/store").Unsubscriber;
79
- }, Writable<boolean>, Writable<string>, Writable<string>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown" | "click" | "focusin" | "focusout" | "pointerleave" | "pointermove">, ([$subOpen, $disabled, $subMenuId, $subTriggerId]: [boolean, boolean, string, string]) => {
83
+ get: () => boolean;
84
+ destroy?: (() => void) | undefined;
85
+ }, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<boolean>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown" | "click" | "focusin" | "focusout" | "pointerleave" | "pointermove">, ([$subOpen, $disabled, $subMenuId, $subTriggerId]: [boolean, boolean, string, string]) => {
80
86
  readonly role: "menuitem";
81
87
  readonly id: string;
82
88
  readonly tabindex: -1;
@@ -86,7 +92,7 @@ export declare function setCtx(props: CreateContextMenuProps): {
86
92
  readonly 'data-disabled': true | undefined;
87
93
  readonly 'aria-haspopop': "menu";
88
94
  }, string>;
89
- subMenu: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("svelte/store").Readable<boolean>, Writable<string>, Writable<string>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown" | "focusout" | "pointermove">, ([$subIsVisible, $subMenuId, $subTriggerId]: [boolean, string, string]) => {
95
+ subMenu: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<[import("svelte/store").Readable<boolean>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>, import("@melt-ui/svelte/internal/helpers").WithGet<Writable<string>>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown" | "focusout" | "pointermove">, ([$subIsVisible, $subMenuId, $subTriggerId]: [boolean, string, string]) => {
90
96
  readonly role: "menu";
91
97
  readonly hidden: true | undefined;
92
98
  readonly style: string;
@@ -96,7 +102,7 @@ export declare function setCtx(props: CreateContextMenuProps): {
96
102
  readonly 'data-id': string;
97
103
  readonly tabindex: -1;
98
104
  }, string>;
99
- subArrow: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<Writable<number>, import("svelte/action").Action<any, any, Record<never, any>>, ($arrowSize: number) => {
105
+ subArrow: import("@melt-ui/svelte/internal/helpers").ExplicitBuilderReturn<import("@melt-ui/svelte/internal/helpers").WithGet<Writable<number>>, import("svelte/action").Action<any, any, Record<never, any>>, ($arrowSize: number) => {
100
106
  'data-arrow': boolean;
101
107
  style: string;
102
108
  }, string>;
@@ -106,6 +112,8 @@ export declare function setCtx(props: CreateContextMenuProps): {
106
112
  update: (updater: import("svelte/store").Updater<boolean>, sideEffect?: ((newValue: boolean) => void) | undefined) => void;
107
113
  set: (this: void, value: boolean) => void;
108
114
  subscribe(this: void, run: import("svelte/store").Subscriber<boolean>, invalidate?: import("svelte/store").Invalidator<boolean> | undefined): import("svelte/store").Unsubscriber;
115
+ get: () => boolean;
116
+ destroy?: (() => void) | undefined;
109
117
  };
110
118
  };
111
119
  options: import("@melt-ui/svelte/internal/helpers").ToWritableStores<Omit<{
@@ -139,6 +147,8 @@ export declare function setCtx(props: CreateContextMenuProps): {
139
147
  update: (updater: import("svelte/store").Updater<boolean | "indeterminate">, sideEffect?: ((newValue: boolean | "indeterminate") => void) | undefined) => void;
140
148
  set: (this: void, value: boolean | "indeterminate") => void;
141
149
  subscribe(this: void, run: import("svelte/store").Subscriber<boolean | "indeterminate">, invalidate?: import("svelte/store").Invalidator<boolean | "indeterminate"> | undefined): import("svelte/store").Unsubscriber;
150
+ get: () => boolean | "indeterminate";
151
+ destroy?: (() => void) | undefined;
142
152
  }, Writable<boolean>], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown" | "click" | "focusin" | "focusout" | "pointerdown" | "pointerleave" | "pointermove">, ([$checked, $disabled]: [boolean | "indeterminate", boolean]) => {
143
153
  readonly role: "menuitemcheckbox";
144
154
  readonly tabindex: -1;
@@ -153,6 +163,8 @@ export declare function setCtx(props: CreateContextMenuProps): {
153
163
  update: (updater: import("svelte/store").Updater<boolean | "indeterminate">, sideEffect?: ((newValue: boolean | "indeterminate") => void) | undefined) => void;
154
164
  set: (this: void, value: boolean | "indeterminate") => void;
155
165
  subscribe(this: void, run: import("svelte/store").Subscriber<boolean | "indeterminate">, invalidate?: import("svelte/store").Invalidator<boolean | "indeterminate"> | undefined): import("svelte/store").Unsubscriber;
166
+ get: () => boolean | "indeterminate";
167
+ destroy?: (() => void) | undefined;
156
168
  };
157
169
  };
158
170
  helpers: {
@@ -172,6 +184,8 @@ export declare function setCtx(props: CreateContextMenuProps): {
172
184
  update: (updater: import("svelte/store").Updater<string | null>, sideEffect?: ((newValue: string | null) => void) | undefined) => void;
173
185
  set: (this: void, value: string | null) => void;
174
186
  subscribe(this: void, run: import("svelte/store").Subscriber<string | null>, invalidate?: import("svelte/store").Invalidator<string | null> | undefined): import("svelte/store").Unsubscriber;
187
+ get: () => string | null;
188
+ destroy?: (() => void) | undefined;
175
189
  }], (node: HTMLElement) => import("@melt-ui/svelte/internal/types").MeltActionReturn<"keydown" | "click" | "focusin" | "focusout" | "pointerdown" | "pointerleave" | "pointermove">, ([$value]: [string | null]) => (itemProps: import("@melt-ui/svelte/dist/builders/menu")._RadioItemProps) => {
176
190
  disabled: boolean;
177
191
  role: string;
@@ -188,6 +202,8 @@ export declare function setCtx(props: CreateContextMenuProps): {
188
202
  update: (updater: import("svelte/store").Updater<string | null>, sideEffect?: ((newValue: string | null) => void) | undefined) => void;
189
203
  set: (this: void, value: string | null) => void;
190
204
  subscribe(this: void, run: import("svelte/store").Subscriber<string | null>, invalidate?: import("svelte/store").Invalidator<string | null> | undefined): import("svelte/store").Unsubscriber;
205
+ get: () => string | null;
206
+ destroy?: (() => void) | undefined;
191
207
  };
192
208
  };
193
209
  helpers: {
@@ -17,11 +17,11 @@ export function getContextMenuData() {
17
17
  "separator",
18
18
  "sub-content",
19
19
  "sub-trigger",
20
- "trigger"
20
+ "trigger",
21
21
  ];
22
22
  return {
23
23
  NAME,
24
- PARTS
24
+ PARTS,
25
25
  };
26
26
  }
27
27
  export function setCtx(props) {
@@ -31,7 +31,7 @@ export function setCtx(props) {
31
31
  setContext(NAME, contextMenu);
32
32
  return {
33
33
  ...contextMenu,
34
- updateOption: getOptionUpdater(contextMenu.options)
34
+ updateOption: getOptionUpdater(contextMenu.options),
35
35
  };
36
36
  }
37
37
  export function getCtx() {
@@ -41,10 +41,10 @@ export function getCtx() {
41
41
  export function updatePositioning(props) {
42
42
  const defaultPlacement = {
43
43
  side: "bottom",
44
- align: "start"
44
+ align: "start",
45
45
  };
46
46
  const withDefaults = { ...defaultPlacement, ...props };
47
- const { options: { positioning } } = getCtx();
47
+ const { options: { positioning }, } = getCtx();
48
48
  const updater = getPositioningUpdater(positioning);
49
49
  updater(withDefaults);
50
50
  }
@@ -2,4 +2,4 @@ import type { ArrowProps, CheckboxItemProps, RadioGroupProps, RadioItemProps, Gr
2
2
  import type { HTMLDivAttributes, Transition } from "../../internal";
3
3
  import type * as I from "./_types.js";
4
4
  type ContentProps<T extends Transition = Transition, In extends Transition = Transition, Out extends Transition = Transition> = I.ContentProps<T, In, Out> & HTMLDivAttributes;
5
- export type { Props, SubProps, ItemProps, ArrowProps, GroupProps, LabelProps, ContentProps, TriggerProps, RadioItemProps, SeparatorProps, RadioGroupProps, SubContentProps, SubTriggerProps, CheckboxItemProps, CheckboxIndicatorProps, RadioIndicatorProps, ItemEvents, TriggerEvents, ContentEvents, RadioItemEvents, SubContentEvents, SubTriggerEvents, CheckboxItemEvents };
5
+ export type { Props, SubProps, ItemProps, ArrowProps, GroupProps, LabelProps, ContentProps, TriggerProps, RadioItemProps, SeparatorProps, RadioGroupProps, SubContentProps, SubTriggerProps, CheckboxItemProps, CheckboxIndicatorProps, RadioIndicatorProps, ItemEvents, TriggerEvents, ContentEvents, RadioItemEvents, SubContentEvents, SubTriggerEvents, CheckboxItemEvents, };
@@ -1 +1 @@
1
- export type { Props as DateFieldProps, LabelProps as DateFieldLabelProps, DescriptionProps as DateFieldDescriptionProps, InputProps as DateFieldInputProps, SegmentProps as DateFieldSegmentProps, SegmentEvents as DateFieldSegmentEvents } from "./types.js";
1
+ export type { Props as DateFieldProps, LabelProps as DateFieldLabelProps, DescriptionProps as DateFieldDescriptionProps, InputProps as DateFieldInputProps, SegmentProps as DateFieldSegmentProps, SegmentEvents as DateFieldSegmentEvents, } from "./types.js";
@@ -17,11 +17,7 @@ export let validationId = void 0;
17
17
  export let descriptionId = void 0;
18
18
  export let readonlySegments = void 0;
19
19
  const {
20
- states: {
21
- value: localValue,
22
- placeholder: localPlaceholder,
23
- isInvalid: localIsInvalid
24
- },
20
+ states: { value: localValue, placeholder: localPlaceholder, isInvalid: localIsInvalid },
25
21
  updateOption,
26
22
  ids
27
23
  } = setCtx({