UNPKG

@bitrix24/b24ui-nuxt

Version:

Bitrix24 UI-Kit for developing web applications REST API for NUXT & VUE

57 lines (56 loc) 3.61 kB
import { DropdownMenu } from 'reka-ui/namespaced'; import type { DropdownMenuContentProps as RekaDropdownMenuContentProps, DropdownMenuArrowProps } from 'reka-ui'; import type { AppConfig } from '@nuxt/schema'; import type theme from '#build/b24ui/dropdown-menu'; import type { DropdownMenuItem, DropdownMenuSlots, DynamicSlots, MergeTypes, IconComponent } from '../types'; import type { ArrayOrNested, NestedItem, ComponentConfig } from '../types/utils'; type DropdownMenu = ComponentConfig<typeof theme, AppConfig, 'dropdownMenu'>; interface DropdownMenuContentProps<T extends ArrayOrNested<DropdownMenuItem>> extends Omit<RekaDropdownMenuContentProps, 'as' | 'asChild' | 'forceMount'> { items?: T; /** * Display an arrow alongside the menu. * @defaultValue false */ arrow?: boolean | Omit<DropdownMenuArrowProps, 'as' | 'asChild'>; portal?: boolean | string | HTMLElement; sub?: boolean; labelKey: keyof NestedItem<T>; /** * @IconComponent */ checkedIcon?: IconComponent; /** * @IconComponent */ externalIcon?: boolean | IconComponent; class?: any; b24ui: { [K in keyof Required<DropdownMenu['slots']>]: (props?: Record<string, any>) => string; }; b24uiOverride?: DropdownMenu['slots']; } type DropdownMenuContentSlots<A extends ArrayOrNested<DropdownMenuItem> = ArrayOrNested<DropdownMenuItem>, T extends NestedItem<A> = NestedItem<A>> = Pick<DropdownMenuSlots<A>, 'item' | 'item-leading' | 'item-label' | 'item-trailing' | 'content-top' | 'content-bottom'> & { default(props?: {}): any; } & DynamicSlots<MergeTypes<T>, 'leading' | 'label' | 'trailing', { active?: boolean; index: number; }>; declare const _default: <T extends ArrayOrNested<DropdownMenuItem>>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{ props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{ readonly onEscapeKeyDown?: ((event: KeyboardEvent) => any) | undefined; readonly onPointerDownOutside?: ((event: import("reka-ui").PointerDownOutsideEvent) => any) | undefined; readonly onFocusOutside?: ((event: import("reka-ui").FocusOutsideEvent) => any) | undefined; readonly onInteractOutside?: ((event: import("reka-ui").PointerDownOutsideEvent | import("reka-ui").FocusOutsideEvent) => any) | undefined; readonly onCloseAutoFocus?: ((event: Event) => any) | undefined; } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onEscapeKeyDown" | "onPointerDownOutside" | "onFocusOutside" | "onInteractOutside" | "onCloseAutoFocus"> & DropdownMenuContentProps<T> & {}> & import("vue").PublicProps; expose(exposed: import("vue").ShallowUnwrapRef<{}>): void; attrs: any; slots: DropdownMenuContentSlots<T, NestedItem<T>>; emit: ((evt: "escapeKeyDown", event: KeyboardEvent) => void) & ((evt: "pointerDownOutside", event: import("reka-ui").PointerDownOutsideEvent) => void) & ((evt: "focusOutside", event: import("reka-ui").FocusOutsideEvent) => void) & ((evt: "interactOutside", event: import("reka-ui").PointerDownOutsideEvent | import("reka-ui").FocusOutsideEvent) => void) & ((evt: "closeAutoFocus", event: Event) => void); }>) => import("vue").VNode & { __ctx?: Awaited<typeof __VLS_setup>; }; export default _default; type __VLS_PrettifyLocal<T> = { [K in keyof T as K]: T[K]; } & {};