import { type PartialWithUndefined } from '@augment-vir/common'; import { type AttributeValues, type CSSResult } from 'element-vir'; import { type SpaRoute, type SpaRouter } from 'spa-router-vir'; /** * The route properties required for using {@link ViraLink} with a route. * * @category Internal */ export type ViraLinkRoute = Readonly<{ route: SpaRoute; router: Pick, 'createRouteUrl' | 'setRouteOnDirectNavigation'>; scrollToTop?: boolean; }>; /** * A hyperlink wrapper element that can be configured to emit route change events rather than just * being a raw link. * * @category Link * @category Elements * @see https://electrovir.github.io/vira/book/elements/vira-link */ export declare const ViraLink: import("element-vir").DeclarativeElementDefinition<"vira-link", (((Required> & Partial>) | (Required> & Partial>)) & Omit<{ /** * A full raw URL link that will navigate the current window away or open a new tab. If this * property is provided for the inputs, don't provide a route property. */ link: { url: string; newTab: boolean; }; /** * A route that'll change that current page without navigating the window. If this property * is provided for the inputs, don't provide a link property. */ route: ViraLinkRoute; }, "link" | "route">) & PartialWithUndefined<{ /** Styles that will be applied directly to the inner elements. */ stylePassthrough: Readonly>; /** Attributes that will be applied directly to the inner elements. */ attributePassthrough: Readonly>; /** If set to true, internal link styles are not applied. */ disableLinkStyles: boolean; }>, { /** Removes event listeners registered during init. */ cleanupListeners: undefined | (() => void); }, {}, "vira-link-link-styles", "vira-link-", readonly [], readonly []>;