import { SvelteComponentTyped } from "svelte"; import type { SvelteHTMLElements } from "svelte/elements"; type $RestProps = SvelteHTMLElements["a"]; type $Props = { /** * Specify the size of the link. * @default undefined */ size?: "sm" | "lg"; /** * Specify the href value. * @default undefined */ href?: string; /** * Set to `true` to use the inline variant * @default false */ inline?: boolean; /** * Specify the icon to render. * `inline` must be `false`. * @default undefined */ icon?: Icon; /** * Set to `true` to disable the checkbox * @default false */ disabled?: boolean; /** * Set to `true` to allow visited styles * @default false */ visited?: boolean; /** * Obtain a reference to the top-level HTML element. * @default null */ ref?: null | HTMLAnchorElement; children?: (this: void) => void; [key: `data-${string}`]: unknown; }; export type LinkProps = Omit<$RestProps, keyof $Props> & $Props; export default class Link extends SvelteComponentTyped< LinkProps, { blur: WindowEventMap["blur"]; click: WindowEventMap["click"]; focus: WindowEventMap["focus"]; keydown: WindowEventMap["keydown"]; keyup: WindowEventMap["keyup"]; mouseenter: WindowEventMap["mouseenter"]; mouseleave: WindowEventMap["mouseleave"]; mouseover: WindowEventMap["mouseover"]; }, { default: Record; icon: Record } > {}