import type { VNode } from 'vue'; import type { AppConfig } from '@nuxt/schema'; import type { ButtonProps, DrawerProps, ModalProps, SlideoverProps, LinkPropsKeys } from '../types'; import type { ComponentConfig } from '../types/tv'; import theme from '#build/b24ui/header'; type Header = ComponentConfig; type HeaderMode = 'modal' | 'slideover' | 'drawer'; type HeaderMenu = T extends 'modal' ? ModalProps : T extends 'slideover' ? SlideoverProps : T extends 'drawer' ? DrawerProps : never; export interface HeaderProps { /** * The element or component this component should render as. * @defaultValue 'header' */ as?: any; title?: string; to?: string; /** * The mode of the header menu. * @defaultValue 'slideover' */ mode?: T; /** * The props for the header menu component. */ menu?: HeaderMenu; /** * Customize the toggle button to open the header menu displayed when the `content` slot is used. * `{ color: 'air-tertiary', size: 'md' }`{lang="ts-type"} */ toggle?: boolean | Omit; /** * The side to render the toggle button on. * @defaultValue 'left' */ toggleSide?: 'left' | 'right'; /** * Automatically close when route changes. * @defaultValue true */ autoClose?: boolean; class?: any; b24ui?: Header['slots']; } export interface HeaderSlots { title?(props?: {}): VNode[]; left?(props?: {}): VNode[]; default?(props?: {}): VNode[]; right?(props?: {}): VNode[]; toggle?(props: { open: boolean; toggle: () => void; b24ui: Header['b24ui']; }): VNode[]; top?(props?: {}): VNode[]; bottom?(props?: {}): VNode[]; body?(props?: {}): VNode[]; content?(props: { close?: () => void; }): VNode[]; } declare const _default: typeof __VLS_export; export default _default; declare const __VLS_export: (__VLS_props: NonNullable>["props"], __VLS_ctx?: __VLS_PrettifyLocal>, "attrs" | "emit" | "slots">>, __VLS_exposed?: NonNullable>["expose"], __VLS_setup?: Promise<{ props: import("vue").PublicProps & __VLS_PrettifyLocal<(HeaderProps & { open?: boolean; }) & { "onUpdate:open"?: ((value: boolean) => any) | undefined; }> & (typeof globalThis extends { __VLS_PROPS_FALLBACK: infer P; } ? P : {}); expose: (exposed: {}) => void; attrs: any; slots: HeaderSlots; emit: (event: "update:open", value: boolean) => void; }>) => import("vue").VNode & { __ctx?: Awaited; }; type __VLS_PrettifyLocal = (T extends any ? { [K in keyof T]: T[K]; } : { [K in keyof T as K]: T[K]; }) & {};