/// import type { MeltActionReturn } from '../../internal/types.js'; import { type Writable } from 'svelte/store'; import type { TooltipEvents } from './events.js'; import type { CreateTooltipProps } from './types.js'; export declare const tooltipIdParts: readonly ["trigger", "content"]; export type TooltipIdParts = typeof tooltipIdParts; export declare function createTooltip(props?: CreateTooltipProps): { ids: import("../../internal/helpers/index.js").ToWritableStores<{ content: string; trigger: string; }>; elements: { trigger: import("../../internal/helpers/index.js").MeltElement<[import("../../internal/helpers/index.js").WithGet>, import("../../internal/helpers/index.js").WithGet>, { update: (updater: import("svelte/store").Updater, sideEffect?: ((newValue: boolean) => void) | undefined) => void; set: (this: void, value: boolean) => void; subscribe(this: void, run: import("svelte/store").Subscriber, invalidate?: import("svelte/store").Invalidator | undefined): import("svelte/store").Unsubscriber; get: () => boolean; destroy?: (() => void) | undefined; }], (node: HTMLElement) => MeltActionReturn, ([$contentId, $triggerId, $open]: [string, string, boolean]) => { readonly 'aria-describedby': string; readonly id: string; readonly 'data-state': "open" | "closed"; }, string>; content: import("../../internal/helpers/index.js").MeltElement<[import("svelte/store").Readable, { update: (updater: import("svelte/store").Updater, sideEffect?: ((newValue: boolean) => void) | undefined) => void; set: (this: void, value: boolean) => void; subscribe(this: void, run: import("svelte/store").Subscriber, invalidate?: import("svelte/store").Invalidator | undefined): import("svelte/store").Unsubscriber; get: () => boolean; destroy?: (() => void) | undefined; }, import("../../internal/helpers/index.js").WithGet>, import("../../internal/helpers/index.js").WithGet>], (node: HTMLElement) => MeltActionReturn, ([$isVisible, $open, $portal, $contentId]: [boolean, boolean, string | HTMLElement | null, string]) => { readonly role: "tooltip"; readonly hidden: true | undefined; readonly tabindex: -1; readonly style: string | undefined; readonly id: string; readonly 'data-portal': "" | undefined; readonly 'data-state': "open" | "closed"; }, string>; arrow: import("../../internal/helpers/index.js").MeltElement>, import("svelte/action").Action>, ($arrowSize: number) => { readonly 'data-arrow': true; readonly style: string; }, string>; }; states: { open: { update: (updater: import("svelte/store").Updater, sideEffect?: ((newValue: boolean) => void) | undefined) => void; set: (this: void, value: boolean) => void; subscribe(this: void, run: import("svelte/store").Subscriber, invalidate?: import("svelte/store").Invalidator | undefined): import("svelte/store").Unsubscriber; get: () => boolean; destroy?: (() => void) | undefined; }; }; options: import("../../internal/helpers/index.js").ToWritableStores | undefined; onOpenChange?: import("../../internal/helpers/index.js").ChangeFn | undefined; closeOnPointerDown: boolean; openDelay: number; closeDelay: number; forceVisible: boolean; escapeBehavior: import("../../internal/actions/index.js").EscapeBehaviorType; disableHoverableContent: boolean; group: string | boolean | undefined; portal: string | HTMLElement | null; ids?: Partial<{ content: string; trigger: string; }> | undefined; }, "open" | "ids">>; };