/// import { type WithGet } from '../../internal/helpers/withGet.js'; import type { MeltActionReturn } from '../../internal/types.js'; import { type Readable } from 'svelte/store'; import type { LinkPreviewEvents } from './events.js'; import type { CreateLinkPreviewProps } from './types.js'; export declare const linkPreviewIdParts: readonly ["trigger", "content"]; export type LinkPreviewIdParts = typeof linkPreviewIdParts; export declare function createLinkPreview(props?: CreateLinkPreviewProps): { ids: import("../../internal/helpers/index.js").ToWritableStores<{ content: string; trigger: string; }>; elements: { trigger: import("../../internal/helpers/index.js").MeltElement<[{ 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; }, WithGet>, WithGet>], (node: HTMLElement) => MeltActionReturn, ([$open, $triggerId, $contentId]: [boolean, string, string]) => { readonly role: "button"; readonly 'aria-haspopup': "dialog"; readonly 'aria-expanded': boolean; readonly 'data-state': "open" | "closed"; readonly 'aria-controls': string; readonly id: string; }, string>; content: import("../../internal/helpers/index.js").MeltElement<[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("svelte/store").Writable, WithGet>, WithGet>], (node: HTMLElement) => MeltActionReturn, ([$isVisible, $open, $activeTrigger, $portal, $contentId]: [boolean, boolean, HTMLElement | null, string | HTMLElement | null, string]) => { readonly hidden: true | undefined; readonly tabindex: -1; readonly style: string | undefined; readonly id: string; readonly 'data-state': "open" | "closed"; readonly 'data-portal': "" | undefined; }, 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; openDelay: number; closeDelay: number; closeOnOutsideClick: boolean; onOutsideClick: ((event: import("../../internal/actions/index.js").InteractOutsideEvent) => void) | undefined; escapeBehavior: import("../../internal/actions/index.js").EscapeBehaviorType; preventTextSelectionOverflow: boolean; arrowSize: number; forceVisible: boolean; portal: string | HTMLElement | null; ids?: Partial<{ content: string; trigger: string; }> | undefined; }, "ids">>; };