import { MenuPassThrough, MenuItemTemplateContext, MenuSubmenuHeaderTemplateContext } from 'primeng/types/menu'; export * from 'primeng/types/menu'; import * as i0 from '@angular/core'; import { PipeTransform, EventEmitter, ElementRef, TemplateRef, QueryList } from '@angular/core'; import { DomSanitizer, SafeHtml } from '@angular/platform-browser'; import { MotionOptions, MotionEvent } from '@primeuix/motion'; import * as i2 from 'primeng/api'; import { MenuItem, OverlayService, PrimeTemplate } from 'primeng/api'; import { BaseComponent } from 'primeng/basecomponent'; import * as i1 from 'primeng/bind'; import { Bind } from 'primeng/bind'; import { ConnectedOverlayScrollHandler } from 'primeng/dom'; import { Nullable, VoidListener } from 'primeng/ts-helpers'; import * as _primeuix_styled from '@primeuix/styled'; import { BaseStyle } from 'primeng/base'; /** * * Menu is a navigation / command component that supports dynamic and static positioning. * * [Live Demo](https://www.primeng.org/menu/) * * @module menustyle * */ declare enum MenuClasses { /** * Class name of the root element */ root = "p-menu", /** * Class name of the start element */ start = "p-menu-start", /** * Class name of the list element */ list = "p-menu-list", /** * Class name of the submenu item element */ submenuItem = "p-menu-submenu-item", /** * Class name of the separator element */ separator = "p-menu-separator", /** * Class name of the end element */ end = "p-menu-end", /** * Class name of the item element */ item = "p-menu-item", /** * Class name of the item content element */ itemContent = "p-menu-item-content", /** * Class name of the item link element */ itemLink = "p-menu-item-link", /** * Class name of the item icon element */ itemIcon = "p-menu-item-icon", /** * Class name of the item label element */ itemLabel = "p-menu-item-label" } declare class MenuStyle extends BaseStyle { name: string; style: _primeuix_styled.StyleType; classes: { root: ({ instance }: { instance: any; }) => (string | { 'p-menu-overlay': any; })[]; start: string; list: string; submenuLabel: string; separator: string; end: string; item: ({ instance, item, id }: { instance: any; item: any; id: any; }) => any[]; itemContent: string; itemLink: string; itemIcon: ({ item }: { item: any; }) => any[]; itemLabel: string; }; inlineStyles: { root: ({ instance }: { instance: any; }) => { position: string; }; }; static ɵfac: i0.ɵɵFactoryDeclaration; static ɵprov: i0.ɵɵInjectableDeclaration; } interface MenuStyle extends BaseStyle { } declare class SafeHtmlPipe implements PipeTransform { private readonly platformId; private readonly sanitizer; constructor(platformId: any, sanitizer: DomSanitizer); transform(value: string): SafeHtml; static ɵfac: i0.ɵɵFactoryDeclaration; static ɵpipe: i0.ɵɵPipeDeclaration; } declare class MenuItemContent extends BaseComponent { item: MenuItem | undefined; itemTemplate: any | undefined; menuitemId: i0.InputSignal; idx: i0.InputSignal; onMenuItemClick: EventEmitter; menu: Menu; _componentStyle: MenuStyle; hostName: string; constructor(menu: Menu); onItemClick(event: any, item: any): void; getPTOptions(key: string): any; static ɵfac: i0.ɵɵFactoryDeclaration; static ɵcmp: i0.ɵɵComponentDeclaration; } /** * Menu is a navigation / command component that supports dynamic and static positioning. * @group Components */ declare class Menu extends BaseComponent { overlayService: OverlayService; /** * An array of menuitems. * @group Props */ model: MenuItem[] | undefined; /** * Defines if menu would displayed as a popup. * @group Props */ popup: boolean | undefined; /** * Inline style of the component. * @group Props */ style: { [klass: string]: any; } | null | undefined; /** * Style class of the component. * @group Props */ styleClass: string | undefined; /** * Whether to automatically manage layering. * @group Props */ autoZIndex: boolean; /** * Base zIndex value to use in layering. * @group Props */ baseZIndex: number; /** * Transition options of the show animation. * @deprecated since v21.0.0, use `motionOptions` instead. * @group Props */ showTransitionOptions: string; /** * Transition options of the hide animation. * @deprecated since v21.0.0, use `motionOptions` instead. * @group Props */ hideTransitionOptions: string; /** * Defines a string value that labels an interactive element. * @group Props */ ariaLabel: string | undefined; /** * Identifier of the underlying input element. * @group Props */ ariaLabelledBy: string | undefined; /** * Current id state as a string. * @group Props */ id: string | undefined; /** * Index of the element in tabbing order. * @group Props */ tabindex: number; /** * Target element to attach the overlay, valid values are "body" or a local ng-template variable of another element (note: use binding with brackets for template variables, e.g. [appendTo]="mydiv" for a div element having #mydiv as variable name). * @defaultValue 'self' * @group Props */ appendTo: i0.InputSignal; /** * The motion options. * @group Props */ motionOptions: i0.InputSignal; computedMotionOptions: i0.Signal; /** * Callback to invoke when overlay menu is shown. * @group Emits */ onShow: EventEmitter; /** * Callback to invoke when overlay menu is hidden. * @group Emits */ onHide: EventEmitter; /** * Callback to invoke when the list loses focus. * @param {Event} event - blur event. * @group Emits */ onBlur: EventEmitter; /** * Callback to invoke when the list receives focus. * @param {Event} event - focus event. * @group Emits */ onFocus: EventEmitter; listViewChild: Nullable; containerViewChild: Nullable; $appendTo: i0.Signal; container: any; scrollHandler: ConnectedOverlayScrollHandler | null | undefined; documentClickListener: VoidListener; documentResizeListener: VoidListener; preventDocumentDefault: boolean | undefined; target: any; visible: boolean | undefined; focusedOptionId: i0.Signal; focusedOptionIndex: any; selectedOptionIndex: any; focused: boolean | undefined; overlayVisible: boolean | undefined; $pcMenu: Menu | undefined; _componentStyle: MenuStyle; bindDirectiveInstance: Bind; onAfterViewChecked(): void; constructor(overlayService: OverlayService); getPTOptions(key: string, item: any, index: number, id: string): any; /** * Toggles the visibility of the popup menu. * @param {Event} event - Browser event. * @group Method */ toggle(event: Event): void; /** * Displays the popup menu. * @param {Event} event - Browser event. * @group Method */ show(event: any): void; onInit(): void; /** * Defines template option for start. * @group Templates */ startTemplate: TemplateRef | undefined; _startTemplate: TemplateRef | undefined; /** * Defines template option for end. * @group Templates */ endTemplate: TemplateRef | undefined; _endTemplate: TemplateRef | undefined; /** * Defines template option for header. * @group Templates */ headerTemplate: TemplateRef | undefined; _headerTemplate: TemplateRef | undefined; /** * Custom item template. * @param {MenuItemTemplateContext} context - item context. * @see {@link MenuItemTemplateContext} * @group Templates */ itemTemplate: TemplateRef | undefined; _itemTemplate: TemplateRef | undefined; /** * Custom submenu header template. * @param {MenuSubmenuHeaderTemplateContext} context - submenu header context. * @see {@link MenuSubmenuHeaderTemplateContext} * @group Templates */ submenuHeaderTemplate: TemplateRef | undefined; _submenuHeaderTemplate: TemplateRef | undefined; templates: QueryList; onAfterContentInit(): void; getTabIndexValue(): string | null; onOverlayBeforeEnter(event: MotionEvent): void; onOverlayAfterLeave(): void; appendOverlay(): void; restoreOverlayAppend(): void; moveOnTop(): void; /** * Hides the popup menu. * @group Method */ hide(): void; onWindowResize(): void; menuitemId(item: MenuItem, id: string | any, index?: string | number, childIndex?: string | number): string; isItemFocused(id: any): boolean; label(label: any): any; disabled(disabled: any): any; activedescendant(): any; onListFocus(event: Event): void; onListBlur(event: FocusEvent | MouseEvent): void; onListKeyDown(event: any): void; onArrowDownKey(event: any): void; onArrowUpKey(event: any): void; onHomeKey(event: any): void; onEndKey(event: any): void; onEnterKey(event: any): void; onSpaceKey(event: any): void; findNextOptionIndex(index: any): number; findPrevOptionIndex(index: any): number; changeFocusedOptionIndex(index: any): void; itemClick(event: any, id: string): void; onOverlayClick(event: Event): void; bindDocumentClickListener(): void; unbindDocumentClickListener(): void; bindDocumentResizeListener(): void; unbindDocumentResizeListener(): void; bindScrollListener(): void; unbindScrollListener(): void; onOverlayHide(): void; onDestroy(): void; hasSubMenu(): boolean; isItemHidden(item: any): boolean; get dataP(): string | undefined; static ɵfac: i0.ɵɵFactoryDeclaration; static ɵcmp: i0.ɵɵComponentDeclaration; static ngAcceptInputType_popup: unknown; static ngAcceptInputType_autoZIndex: unknown; static ngAcceptInputType_baseZIndex: unknown; static ngAcceptInputType_tabindex: unknown; } declare class MenuModule { static ɵfac: i0.ɵɵFactoryDeclaration; static ɵmod: i0.ɵɵNgModuleDeclaration; static ɵinj: i0.ɵɵInjectorDeclaration; } export { Menu, MenuClasses, MenuItemContent, MenuModule, MenuStyle, SafeHtmlPipe };