@ethlete/cdk 2.8.1 → 2.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/esm2022/lib/components/overlay/components/menu/context-menu-trigger.mjs +163 -0
  3. package/esm2022/lib/components/overlay/components/menu/menu-aim.mjs +140 -0
  4. package/esm2022/lib/components/overlay/components/menu/menu-bar.mjs +113 -0
  5. package/esm2022/lib/components/overlay/components/menu/menu-base.mjs +154 -0
  6. package/esm2022/lib/components/overlay/components/menu/menu-errors.mjs +7 -0
  7. package/esm2022/lib/components/overlay/components/menu/menu-group.mjs +26 -0
  8. package/esm2022/lib/components/overlay/components/menu/menu-interface.mjs +3 -0
  9. package/esm2022/lib/components/overlay/components/menu/menu-item-checkbox.mjs +39 -0
  10. package/esm2022/lib/components/overlay/components/menu/menu-item-radio.mjs +56 -0
  11. package/esm2022/lib/components/overlay/components/menu/menu-item-selectable.mjs +32 -0
  12. package/esm2022/lib/components/overlay/components/menu/menu-item.mjs +210 -0
  13. package/esm2022/lib/components/overlay/components/menu/menu-module.mjs +52 -0
  14. package/esm2022/lib/components/overlay/components/menu/menu-stack.mjs +101 -0
  15. package/esm2022/lib/components/overlay/components/menu/menu-trigger-base.mjs +77 -0
  16. package/esm2022/lib/components/overlay/components/menu/menu-trigger.mjs +240 -0
  17. package/esm2022/lib/components/overlay/components/menu/menu.mjs +116 -0
  18. package/esm2022/lib/components/overlay/components/menu/pointer-focus-tracker.mjs +26 -0
  19. package/esm2022/lib/components/overlay/components/menu/public-api.mjs +17 -0
  20. package/esm2022/lib/components/overlay/components/public-api.mjs +2 -1
  21. package/esm2022/lib/components/scrollable/components/scrollable/scrollable.component.mjs +3 -3
  22. package/fesm2022/ethlete-cdk.mjs +1561 -157
  23. package/fesm2022/ethlete-cdk.mjs.map +1 -1
  24. package/lib/components/overlay/components/menu/context-menu-trigger.d.ts +33 -0
  25. package/lib/components/overlay/components/menu/menu-aim.d.ts +34 -0
  26. package/lib/components/overlay/components/menu/menu-bar.d.ts +13 -0
  27. package/lib/components/overlay/components/menu/menu-base.d.ts +41 -0
  28. package/lib/components/overlay/components/menu/menu-errors.d.ts +2 -0
  29. package/lib/components/overlay/components/menu/menu-group.d.ts +5 -0
  30. package/lib/components/overlay/components/menu/menu-interface.d.ts +11 -0
  31. package/lib/components/overlay/components/menu/menu-item-checkbox.d.ts +9 -0
  32. package/lib/components/overlay/components/menu/menu-item-radio.d.ts +16 -0
  33. package/lib/components/overlay/components/menu/menu-item-selectable.d.ts +11 -0
  34. package/lib/components/overlay/components/menu/menu-item.d.ts +52 -0
  35. package/lib/components/overlay/components/menu/menu-module.d.ts +16 -0
  36. package/lib/components/overlay/components/menu/menu-stack.d.ts +54 -0
  37. package/lib/components/overlay/components/menu/menu-trigger-base.d.ts +33 -0
  38. package/lib/components/overlay/components/menu/menu-trigger.d.ts +34 -0
  39. package/lib/components/overlay/components/menu/menu.d.ts +17 -0
  40. package/lib/components/overlay/components/menu/pointer-focus-tracker.d.ts +17 -0
  41. package/lib/components/overlay/components/menu/public-api.d.ts +16 -0
  42. package/lib/components/overlay/components/public-api.d.ts +1 -0
  43. package/package.json +2 -2
@@ -0,0 +1,52 @@
1
+ import { OverlayModule } from '@angular/cdk/overlay';
2
+ import { NgModule } from '@angular/core';
3
+ import { CdkContextMenuTrigger } from './context-menu-trigger';
4
+ import { CdkMenu } from './menu';
5
+ import { CdkTargetMenuAim } from './menu-aim';
6
+ import { CdkMenuBar } from './menu-bar';
7
+ import { CdkMenuGroup } from './menu-group';
8
+ import { CdkMenuItem } from './menu-item';
9
+ import { CdkMenuItemCheckbox } from './menu-item-checkbox';
10
+ import { CdkMenuItemRadio } from './menu-item-radio';
11
+ import { CdkMenuTrigger } from './menu-trigger';
12
+ import * as i0 from "@angular/core";
13
+ const MENU_DIRECTIVES = [
14
+ CdkMenuBar,
15
+ CdkMenu,
16
+ CdkMenuItem,
17
+ CdkMenuItemRadio,
18
+ CdkMenuItemCheckbox,
19
+ CdkMenuTrigger,
20
+ CdkMenuGroup,
21
+ CdkContextMenuTrigger,
22
+ CdkTargetMenuAim,
23
+ ];
24
+ export class CdkMenuModule {
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
26
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuModule, imports: [OverlayModule, CdkMenuBar,
27
+ CdkMenu,
28
+ CdkMenuItem,
29
+ CdkMenuItemRadio,
30
+ CdkMenuItemCheckbox,
31
+ CdkMenuTrigger,
32
+ CdkMenuGroup,
33
+ CdkContextMenuTrigger,
34
+ CdkTargetMenuAim], exports: [CdkMenuBar,
35
+ CdkMenu,
36
+ CdkMenuItem,
37
+ CdkMenuItemRadio,
38
+ CdkMenuItemCheckbox,
39
+ CdkMenuTrigger,
40
+ CdkMenuGroup,
41
+ CdkContextMenuTrigger,
42
+ CdkTargetMenuAim] }); }
43
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuModule, imports: [OverlayModule] }); }
44
+ }
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuModule, decorators: [{
46
+ type: NgModule,
47
+ args: [{
48
+ imports: [OverlayModule, ...MENU_DIRECTIVES],
49
+ exports: MENU_DIRECTIVES,
50
+ }]
51
+ }] });
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvb3ZlcmxheS9jb21wb25lbnRzL21lbnUvbWVudS1tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDL0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUNqQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDOUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUN4QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzVDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDMUMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDckQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQUVoRCxNQUFNLGVBQWUsR0FBRztJQUN0QixVQUFVO0lBQ1YsT0FBTztJQUNQLFdBQVc7SUFDWCxnQkFBZ0I7SUFDaEIsbUJBQW1CO0lBQ25CLGNBQWM7SUFDZCxZQUFZO0lBQ1oscUJBQXFCO0lBQ3JCLGdCQUFnQjtDQUNqQixDQUFDO0FBTUYsTUFBTSxPQUFPLGFBQWE7OEdBQWIsYUFBYTsrR0FBYixhQUFhLFlBSGQsYUFBYSxFQVp2QixVQUFVO1lBQ1YsT0FBTztZQUNQLFdBQVc7WUFDWCxnQkFBZ0I7WUFDaEIsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCxZQUFZO1lBQ1oscUJBQXFCO1lBQ3JCLGdCQUFnQixhQVJoQixVQUFVO1lBQ1YsT0FBTztZQUNQLFdBQVc7WUFDWCxnQkFBZ0I7WUFDaEIsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCxZQUFZO1lBQ1oscUJBQXFCO1lBQ3JCLGdCQUFnQjsrR0FPTCxhQUFhLFlBSGQsYUFBYTs7MkZBR1osYUFBYTtrQkFKekIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxhQUFhLEVBQUUsR0FBRyxlQUFlLENBQUM7b0JBQzVDLE9BQU8sRUFBRSxlQUFlO2lCQUN6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2RrQ29udGV4dE1lbnVUcmlnZ2VyIH0gZnJvbSAnLi9jb250ZXh0LW1lbnUtdHJpZ2dlcic7XG5pbXBvcnQgeyBDZGtNZW51IH0gZnJvbSAnLi9tZW51JztcbmltcG9ydCB7IENka1RhcmdldE1lbnVBaW0gfSBmcm9tICcuL21lbnUtYWltJztcbmltcG9ydCB7IENka01lbnVCYXIgfSBmcm9tICcuL21lbnUtYmFyJztcbmltcG9ydCB7IENka01lbnVHcm91cCB9IGZyb20gJy4vbWVudS1ncm91cCc7XG5pbXBvcnQgeyBDZGtNZW51SXRlbSB9IGZyb20gJy4vbWVudS1pdGVtJztcbmltcG9ydCB7IENka01lbnVJdGVtQ2hlY2tib3ggfSBmcm9tICcuL21lbnUtaXRlbS1jaGVja2JveCc7XG5pbXBvcnQgeyBDZGtNZW51SXRlbVJhZGlvIH0gZnJvbSAnLi9tZW51LWl0ZW0tcmFkaW8nO1xuaW1wb3J0IHsgQ2RrTWVudVRyaWdnZXIgfSBmcm9tICcuL21lbnUtdHJpZ2dlcic7XG5cbmNvbnN0IE1FTlVfRElSRUNUSVZFUyA9IFtcbiAgQ2RrTWVudUJhcixcbiAgQ2RrTWVudSxcbiAgQ2RrTWVudUl0ZW0sXG4gIENka01lbnVJdGVtUmFkaW8sXG4gIENka01lbnVJdGVtQ2hlY2tib3gsXG4gIENka01lbnVUcmlnZ2VyLFxuICBDZGtNZW51R3JvdXAsXG4gIENka0NvbnRleHRNZW51VHJpZ2dlcixcbiAgQ2RrVGFyZ2V0TWVudUFpbSxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtPdmVybGF5TW9kdWxlLCAuLi5NRU5VX0RJUkVDVElWRVNdLFxuICBleHBvcnRzOiBNRU5VX0RJUkVDVElWRVMsXG59KVxuZXhwb3J0IGNsYXNzIENka01lbnVNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,101 @@
1
+ /* eslint-disable @angular-eslint/directive-class-suffix */
2
+ /* eslint-disable @angular-eslint/no-output-rename */
3
+ /* eslint-disable @angular-eslint/no-outputs-metadata-property */
4
+ /* eslint-disable @angular-eslint/no-input-rename */
5
+ /* eslint-disable @angular-eslint/no-inputs-metadata-property */
6
+ import { Inject, Injectable, InjectionToken, Optional, SkipSelf } from '@angular/core';
7
+ import { Subject } from 'rxjs';
8
+ import { debounceTime, distinctUntilChanged, startWith } from 'rxjs/operators';
9
+ import * as i0 from "@angular/core";
10
+ export const MENU_STACK = new InjectionToken('cdk-menu-stack');
11
+ export const PARENT_OR_NEW_MENU_STACK_PROVIDER = {
12
+ provide: MENU_STACK,
13
+ deps: [[new Optional(), new SkipSelf(), new Inject(MENU_STACK)]],
14
+ useFactory: (parentMenuStack) => parentMenuStack || new MenuStack(),
15
+ };
16
+ export const PARENT_OR_NEW_INLINE_MENU_STACK_PROVIDER = (orientation) => ({
17
+ provide: MENU_STACK,
18
+ deps: [[new Optional(), new SkipSelf(), new Inject(MENU_STACK)]],
19
+ useFactory: (parentMenuStack) => parentMenuStack || MenuStack.inline(orientation),
20
+ });
21
+ let nextId = 0;
22
+ export class MenuStack {
23
+ constructor() {
24
+ this.id = `${nextId++}`;
25
+ this._elements = [];
26
+ this._close = new Subject();
27
+ this._empty = new Subject();
28
+ this._hasFocus = new Subject();
29
+ this.closed = this._close;
30
+ this.hasFocus = this._hasFocus.pipe(startWith(false), debounceTime(0), distinctUntilChanged());
31
+ this.emptied = this._empty;
32
+ this._inlineMenuOrientation = null;
33
+ }
34
+ static inline(orientation) {
35
+ const stack = new MenuStack();
36
+ stack._inlineMenuOrientation = orientation;
37
+ return stack;
38
+ }
39
+ push(menu) {
40
+ this._elements.push(menu);
41
+ }
42
+ close(lastItem, options) {
43
+ const { focusNextOnEmpty, focusParentTrigger } = { ...options };
44
+ if (this._elements.indexOf(lastItem) >= 0) {
45
+ let poppedElement;
46
+ do {
47
+ poppedElement = this._elements.pop();
48
+ this._close.next({ item: poppedElement, focusParentTrigger });
49
+ } while (poppedElement !== lastItem);
50
+ if (this.isEmpty()) {
51
+ this._empty.next(focusNextOnEmpty);
52
+ }
53
+ }
54
+ }
55
+ closeSubMenuOf(lastItem) {
56
+ let removed = false;
57
+ if (this._elements.indexOf(lastItem) >= 0) {
58
+ removed = this.peek() !== lastItem;
59
+ while (this.peek() !== lastItem) {
60
+ this._close.next({ item: this._elements.pop() });
61
+ }
62
+ }
63
+ return removed;
64
+ }
65
+ closeAll(options) {
66
+ const { focusNextOnEmpty, focusParentTrigger } = { ...options };
67
+ if (!this.isEmpty()) {
68
+ while (!this.isEmpty()) {
69
+ const menuStackItem = this._elements.pop();
70
+ if (menuStackItem) {
71
+ this._close.next({ item: menuStackItem, focusParentTrigger });
72
+ }
73
+ }
74
+ this._empty.next(focusNextOnEmpty);
75
+ }
76
+ }
77
+ isEmpty() {
78
+ return !this._elements.length;
79
+ }
80
+ length() {
81
+ return this._elements.length;
82
+ }
83
+ peek() {
84
+ return this._elements[this._elements.length - 1];
85
+ }
86
+ hasInlineMenu() {
87
+ return this._inlineMenuOrientation != null;
88
+ }
89
+ inlineMenuOrientation() {
90
+ return this._inlineMenuOrientation;
91
+ }
92
+ setHasFocus(hasFocus) {
93
+ this._hasFocus.next(hasFocus);
94
+ }
95
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: MenuStack, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
96
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: MenuStack }); }
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: MenuStack, decorators: [{
99
+ type: Injectable
100
+ }] });
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-stack.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/overlay/components/menu/menu-stack.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/directive-class-suffix */\n/* eslint-disable @angular-eslint/no-output-rename */\n/* eslint-disable @angular-eslint/no-outputs-metadata-property */\n/* eslint-disable @angular-eslint/no-input-rename */\n/* eslint-disable @angular-eslint/no-inputs-metadata-property */\n\nimport { Inject, Injectable, InjectionToken, Optional, SkipSelf } from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, startWith } from 'rxjs/operators';\n\nexport const enum FocusNext {\n  nextItem,\n  previousItem,\n  currentItem,\n}\n\nexport interface MenuStackItem {\n  menuStack?: MenuStack;\n}\n\nexport const MENU_STACK = new InjectionToken<MenuStack>('cdk-menu-stack');\n\nexport const PARENT_OR_NEW_MENU_STACK_PROVIDER = {\n  provide: MENU_STACK,\n  deps: [[new Optional(), new SkipSelf(), new Inject(MENU_STACK)]],\n  useFactory: (parentMenuStack?: MenuStack) => parentMenuStack || new MenuStack(),\n};\n\nexport const PARENT_OR_NEW_INLINE_MENU_STACK_PROVIDER = (orientation: 'vertical' | 'horizontal') => ({\n  provide: MENU_STACK,\n  deps: [[new Optional(), new SkipSelf(), new Inject(MENU_STACK)]],\n  useFactory: (parentMenuStack?: MenuStack) => parentMenuStack || MenuStack.inline(orientation),\n});\n\nexport interface CloseOptions {\n  focusNextOnEmpty?: FocusNext;\n  focusParentTrigger?: boolean;\n}\n\nexport interface MenuStackCloseEvent {\n  item: MenuStackItem;\n  focusParentTrigger?: boolean;\n}\n\nlet nextId = 0;\n\n@Injectable()\nexport class MenuStack {\n  readonly id = `${nextId++}`;\n\n  private readonly _elements: MenuStackItem[] = [];\n\n  private readonly _close = new Subject<MenuStackCloseEvent>();\n\n  private readonly _empty = new Subject<FocusNext | undefined>();\n\n  private readonly _hasFocus = new Subject<boolean>();\n\n  readonly closed: Observable<MenuStackCloseEvent> = this._close;\n\n  readonly hasFocus: Observable<boolean> = this._hasFocus.pipe(\n    startWith(false),\n    debounceTime(0),\n    distinctUntilChanged(),\n  );\n\n  readonly emptied: Observable<FocusNext | undefined> = this._empty;\n\n  private _inlineMenuOrientation: 'vertical' | 'horizontal' | null = null;\n\n  static inline(orientation: 'vertical' | 'horizontal') {\n    const stack = new MenuStack();\n    stack._inlineMenuOrientation = orientation;\n    return stack;\n  }\n\n  push(menu: MenuStackItem) {\n    this._elements.push(menu);\n  }\n\n  close(lastItem: MenuStackItem, options?: CloseOptions) {\n    const { focusNextOnEmpty, focusParentTrigger } = { ...options };\n    if (this._elements.indexOf(lastItem) >= 0) {\n      let poppedElement;\n      do {\n        poppedElement = this._elements.pop()!;\n        this._close.next({ item: poppedElement, focusParentTrigger });\n      } while (poppedElement !== lastItem);\n\n      if (this.isEmpty()) {\n        this._empty.next(focusNextOnEmpty);\n      }\n    }\n  }\n\n  closeSubMenuOf(lastItem: MenuStackItem) {\n    let removed = false;\n    if (this._elements.indexOf(lastItem) >= 0) {\n      removed = this.peek() !== lastItem;\n      while (this.peek() !== lastItem) {\n        this._close.next({ item: this._elements.pop()! });\n      }\n    }\n    return removed;\n  }\n\n  closeAll(options?: CloseOptions) {\n    const { focusNextOnEmpty, focusParentTrigger } = { ...options };\n    if (!this.isEmpty()) {\n      while (!this.isEmpty()) {\n        const menuStackItem = this._elements.pop();\n        if (menuStackItem) {\n          this._close.next({ item: menuStackItem, focusParentTrigger });\n        }\n      }\n      this._empty.next(focusNextOnEmpty);\n    }\n  }\n\n  isEmpty() {\n    return !this._elements.length;\n  }\n\n  length() {\n    return this._elements.length;\n  }\n\n  peek(): MenuStackItem | undefined {\n    return this._elements[this._elements.length - 1];\n  }\n\n  hasInlineMenu() {\n    return this._inlineMenuOrientation != null;\n  }\n\n  inlineMenuOrientation() {\n    return this._inlineMenuOrientation;\n  }\n\n  setHasFocus(hasFocus: boolean) {\n    this._hasFocus.next(hasFocus);\n  }\n}\n"]}
@@ -0,0 +1,77 @@
1
+ import { TemplatePortal } from '@angular/cdk/portal';
2
+ import { Directive, EventEmitter, InjectionToken, Injector, ViewContainerRef, inject, } from '@angular/core';
3
+ import { Subject, merge } from 'rxjs';
4
+ import { MENU_STACK } from './menu-stack';
5
+ import * as i0 from "@angular/core";
6
+ export const MENU_TRIGGER = new InjectionToken('cdk-menu-trigger');
7
+ export class CdkMenuTriggerBase {
8
+ constructor() {
9
+ this.injector = inject(Injector);
10
+ this.viewContainerRef = inject(ViewContainerRef);
11
+ this.menuStack = inject(MENU_STACK);
12
+ this.menuPosition = null;
13
+ this.opened = new EventEmitter();
14
+ this.closed = new EventEmitter();
15
+ this.menuTemplateRef = null;
16
+ this.overlayRef = null;
17
+ this.destroyed = new Subject();
18
+ this.stopOutsideClicksListener = merge(this.closed, this.destroyed);
19
+ this._menuPortal = null;
20
+ }
21
+ ngOnDestroy() {
22
+ this._destroyOverlay();
23
+ this.destroyed.next();
24
+ this.destroyed.complete();
25
+ }
26
+ isOpen() {
27
+ return !!this.overlayRef?.hasAttached();
28
+ }
29
+ registerChildMenu(child) {
30
+ this.childMenu = child;
31
+ }
32
+ getMenuContentPortal() {
33
+ const hasMenuContentChanged = this.menuTemplateRef !== this._menuPortal?.templateRef;
34
+ if (this.menuTemplateRef && (!this._menuPortal || hasMenuContentChanged)) {
35
+ this._menuPortal = new TemplatePortal(this.menuTemplateRef, this.viewContainerRef, this.menuData, this._getChildMenuInjector());
36
+ }
37
+ return this._menuPortal;
38
+ }
39
+ isElementInsideMenuStack(element) {
40
+ for (let el = element; el; el = el?.parentElement ?? null) {
41
+ if (el.getAttribute('data-cdk-menu-stack-id') === this.menuStack.id) {
42
+ return true;
43
+ }
44
+ }
45
+ return false;
46
+ }
47
+ _destroyOverlay() {
48
+ if (this.overlayRef) {
49
+ this.overlayRef.dispose();
50
+ this.overlayRef = null;
51
+ }
52
+ }
53
+ _getChildMenuInjector() {
54
+ this._childMenuInjector =
55
+ this._childMenuInjector ||
56
+ Injector.create({
57
+ providers: [
58
+ { provide: MENU_TRIGGER, useValue: this },
59
+ { provide: MENU_STACK, useValue: this.menuStack },
60
+ ],
61
+ parent: this.injector,
62
+ });
63
+ return this._childMenuInjector;
64
+ }
65
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuTriggerBase, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
66
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.1", type: CdkMenuTriggerBase, host: { properties: { "attr.aria-controls": "childMenu?.id", "attr.data-cdk-menu-stack-id": "menuStack.id" } }, ngImport: i0 }); }
67
+ }
68
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuTriggerBase, decorators: [{
69
+ type: Directive,
70
+ args: [{
71
+ host: {
72
+ '[attr.aria-controls]': 'childMenu?.id',
73
+ '[attr.data-cdk-menu-stack-id]': 'menuStack.id',
74
+ },
75
+ }]
76
+ }] });
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS10cmlnZ2VyLWJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvb3ZlcmxheS9jb21wb25lbnRzL21lbnUvbWVudS10cmlnZ2VyLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3JELE9BQU8sRUFDTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLGNBQWMsRUFDZCxRQUFRLEVBR1IsZ0JBQWdCLEVBQ2hCLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUV0QyxPQUFPLEVBQUUsVUFBVSxFQUFhLE1BQU0sY0FBYyxDQUFDOztBQUVyRCxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsSUFBSSxjQUFjLENBQXFCLGtCQUFrQixDQUFDLENBQUM7QUFRdkYsTUFBTSxPQUFnQixrQkFBa0I7SUFOeEM7UUFPVyxhQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRWxCLHFCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBRTVDLGNBQVMsR0FBYyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFN0QsaUJBQVksR0FBK0IsSUFBSSxDQUFDO1FBRXZDLFdBQU0sR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUVoRCxXQUFNLEdBQXVCLElBQUksWUFBWSxFQUFFLENBQUM7UUFFekQsb0JBQWUsR0FBZ0MsSUFBSSxDQUFDO1FBSTFDLGVBQVUsR0FBc0IsSUFBSSxDQUFDO1FBRTVCLGNBQVMsR0FBa0IsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUV6Qyw4QkFBeUIsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFJMUUsZ0JBQVcsR0FBMEIsSUFBSSxDQUFDO0tBNkRuRDtJQXpEQyxXQUFXO1FBQ1QsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBRXZCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDdEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsTUFBTTtRQUNKLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsV0FBVyxFQUFFLENBQUM7SUFDMUMsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQVc7UUFDM0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDekIsQ0FBQztJQUVTLG9CQUFvQjtRQUM1QixNQUFNLHFCQUFxQixHQUFHLElBQUksQ0FBQyxlQUFlLEtBQUssSUFBSSxDQUFDLFdBQVcsRUFBRSxXQUFXLENBQUM7UUFDckYsSUFBSSxJQUFJLENBQUMsZUFBZSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxJQUFJLHFCQUFxQixDQUFDLEVBQUU7WUFDeEUsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLGNBQWMsQ0FDbkMsSUFBSSxDQUFDLGVBQWUsRUFDcEIsSUFBSSxDQUFDLGdCQUFnQixFQUNyQixJQUFJLENBQUMsUUFBUSxFQUNiLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUM3QixDQUFDO1NBQ0g7UUFFRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDMUIsQ0FBQztJQUVTLHdCQUF3QixDQUFDLE9BQWdCO1FBQ2pELEtBQUssSUFBSSxFQUFFLEdBQW1CLE9BQU8sRUFBRSxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxhQUFhLElBQUksSUFBSSxFQUFFO1lBQ3pFLElBQUksRUFBRSxDQUFDLFlBQVksQ0FBQyx3QkFBd0IsQ0FBQyxLQUFLLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxFQUFFO2dCQUNuRSxPQUFPLElBQUksQ0FBQzthQUNiO1NBQ0Y7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFTyxlQUFlO1FBQ3JCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNuQixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQzFCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1NBQ3hCO0lBQ0gsQ0FBQztJQUVPLHFCQUFxQjtRQUMzQixJQUFJLENBQUMsa0JBQWtCO1lBQ3JCLElBQUksQ0FBQyxrQkFBa0I7Z0JBQ3ZCLFFBQVEsQ0FBQyxNQUFNLENBQUM7b0JBQ2QsU0FBUyxFQUFFO3dCQUNULEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO3dCQUN6QyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUU7cUJBQ2xEO29CQUNELE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUTtpQkFDdEIsQ0FBQyxDQUFDO1FBQ0wsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUM7SUFDakMsQ0FBQzs4R0FyRm1CLGtCQUFrQjtrR0FBbEIsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQU52QyxTQUFTO21CQUFDO29CQUNULElBQUksRUFBRTt3QkFDSixzQkFBc0IsRUFBRSxlQUFlO3dCQUN2QywrQkFBK0IsRUFBRSxjQUFjO3FCQUNoRDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEBhbmd1bGFyLWVzbGludC9kaXJlY3RpdmUtY2xhc3Mtc3VmZml4ICovXG4vKiBlc2xpbnQtZGlzYWJsZSBAYW5ndWxhci1lc2xpbnQvbm8tb3V0cHV0LXJlbmFtZSAqL1xuLyogZXNsaW50LWRpc2FibGUgQGFuZ3VsYXItZXNsaW50L25vLW91dHB1dHMtbWV0YWRhdGEtcHJvcGVydHkgKi9cbi8qIGVzbGludC1kaXNhYmxlIEBhbmd1bGFyLWVzbGludC9uby1pbnB1dC1yZW5hbWUgKi9cbi8qIGVzbGludC1kaXNhYmxlIEBhbmd1bGFyLWVzbGludC9uby1pbnB1dHMtbWV0YWRhdGEtcHJvcGVydHkgKi9cblxuaW1wb3J0IHsgQ29ubmVjdGVkUG9zaXRpb24sIE92ZXJsYXlSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBUZW1wbGF0ZVBvcnRhbCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHtcbiAgRGlyZWN0aXZlLFxuICBFdmVudEVtaXR0ZXIsXG4gIEluamVjdGlvblRva2VuLFxuICBJbmplY3RvcixcbiAgT25EZXN0cm95LFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NvbnRhaW5lclJlZixcbiAgaW5qZWN0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QsIG1lcmdlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBNZW51IH0gZnJvbSAnLi9tZW51LWludGVyZmFjZSc7XG5pbXBvcnQgeyBNRU5VX1NUQUNLLCBNZW51U3RhY2sgfSBmcm9tICcuL21lbnUtc3RhY2snO1xuXG5leHBvcnQgY29uc3QgTUVOVV9UUklHR0VSID0gbmV3IEluamVjdGlvblRva2VuPENka01lbnVUcmlnZ2VyQmFzZT4oJ2Nkay1tZW51LXRyaWdnZXInKTtcblxuQERpcmVjdGl2ZSh7XG4gIGhvc3Q6IHtcbiAgICAnW2F0dHIuYXJpYS1jb250cm9sc10nOiAnY2hpbGRNZW51Py5pZCcsXG4gICAgJ1thdHRyLmRhdGEtY2RrLW1lbnUtc3RhY2staWRdJzogJ21lbnVTdGFjay5pZCcsXG4gIH0sXG59KVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIENka01lbnVUcmlnZ2VyQmFzZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIHJlYWRvbmx5IGluamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgdmlld0NvbnRhaW5lclJlZiA9IGluamVjdChWaWV3Q29udGFpbmVyUmVmKTtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgbWVudVN0YWNrOiBNZW51U3RhY2sgPSBpbmplY3QoTUVOVV9TVEFDSyk7XG5cbiAgbWVudVBvc2l0aW9uOiBDb25uZWN0ZWRQb3NpdGlvbltdIHwgbnVsbCA9IG51bGw7XG5cbiAgcmVhZG9ubHkgb3BlbmVkOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgcmVhZG9ubHkgY2xvc2VkOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgbWVudVRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjx1bmtub3duPiB8IG51bGwgPSBudWxsO1xuXG4gIG1lbnVEYXRhOiB1bmtub3duO1xuXG4gIHByb3RlY3RlZCBvdmVybGF5UmVmOiBPdmVybGF5UmVmIHwgbnVsbCA9IG51bGw7XG5cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGRlc3Ryb3llZDogU3ViamVjdDx2b2lkPiA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHN0b3BPdXRzaWRlQ2xpY2tzTGlzdGVuZXIgPSBtZXJnZSh0aGlzLmNsb3NlZCwgdGhpcy5kZXN0cm95ZWQpO1xuXG4gIHByb3RlY3RlZCBjaGlsZE1lbnU/OiBNZW51O1xuXG4gIHByaXZhdGUgX21lbnVQb3J0YWw6IFRlbXBsYXRlUG9ydGFsIHwgbnVsbCA9IG51bGw7XG5cbiAgcHJpdmF0ZSBfY2hpbGRNZW51SW5qZWN0b3I/OiBJbmplY3RvcjtcblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLl9kZXN0cm95T3ZlcmxheSgpO1xuXG4gICAgdGhpcy5kZXN0cm95ZWQubmV4dCgpO1xuICAgIHRoaXMuZGVzdHJveWVkLmNvbXBsZXRlKCk7XG4gIH1cblxuICBpc09wZW4oKSB7XG4gICAgcmV0dXJuICEhdGhpcy5vdmVybGF5UmVmPy5oYXNBdHRhY2hlZCgpO1xuICB9XG5cbiAgcmVnaXN0ZXJDaGlsZE1lbnUoY2hpbGQ6IE1lbnUpIHtcbiAgICB0aGlzLmNoaWxkTWVudSA9IGNoaWxkO1xuICB9XG5cbiAgcHJvdGVjdGVkIGdldE1lbnVDb250ZW50UG9ydGFsKCkge1xuICAgIGNvbnN0IGhhc01lbnVDb250ZW50Q2hhbmdlZCA9IHRoaXMubWVudVRlbXBsYXRlUmVmICE9PSB0aGlzLl9tZW51UG9ydGFsPy50ZW1wbGF0ZVJlZjtcbiAgICBpZiAodGhpcy5tZW51VGVtcGxhdGVSZWYgJiYgKCF0aGlzLl9tZW51UG9ydGFsIHx8IGhhc01lbnVDb250ZW50Q2hhbmdlZCkpIHtcbiAgICAgIHRoaXMuX21lbnVQb3J0YWwgPSBuZXcgVGVtcGxhdGVQb3J0YWwoXG4gICAgICAgIHRoaXMubWVudVRlbXBsYXRlUmVmLFxuICAgICAgICB0aGlzLnZpZXdDb250YWluZXJSZWYsXG4gICAgICAgIHRoaXMubWVudURhdGEsXG4gICAgICAgIHRoaXMuX2dldENoaWxkTWVudUluamVjdG9yKCksXG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLl9tZW51UG9ydGFsO1xuICB9XG5cbiAgcHJvdGVjdGVkIGlzRWxlbWVudEluc2lkZU1lbnVTdGFjayhlbGVtZW50OiBFbGVtZW50KSB7XG4gICAgZm9yIChsZXQgZWw6IEVsZW1lbnQgfCBudWxsID0gZWxlbWVudDsgZWw7IGVsID0gZWw/LnBhcmVudEVsZW1lbnQgPz8gbnVsbCkge1xuICAgICAgaWYgKGVsLmdldEF0dHJpYnV0ZSgnZGF0YS1jZGstbWVudS1zdGFjay1pZCcpID09PSB0aGlzLm1lbnVTdGFjay5pZCkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcHJpdmF0ZSBfZGVzdHJveU92ZXJsYXkoKSB7XG4gICAgaWYgKHRoaXMub3ZlcmxheVJlZikge1xuICAgICAgdGhpcy5vdmVybGF5UmVmLmRpc3Bvc2UoKTtcbiAgICAgIHRoaXMub3ZlcmxheVJlZiA9IG51bGw7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfZ2V0Q2hpbGRNZW51SW5qZWN0b3IoKSB7XG4gICAgdGhpcy5fY2hpbGRNZW51SW5qZWN0b3IgPVxuICAgICAgdGhpcy5fY2hpbGRNZW51SW5qZWN0b3IgfHxcbiAgICAgIEluamVjdG9yLmNyZWF0ZSh7XG4gICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgIHsgcHJvdmlkZTogTUVOVV9UUklHR0VSLCB1c2VWYWx1ZTogdGhpcyB9LFxuICAgICAgICAgIHsgcHJvdmlkZTogTUVOVV9TVEFDSywgdXNlVmFsdWU6IHRoaXMubWVudVN0YWNrIH0sXG4gICAgICAgIF0sXG4gICAgICAgIHBhcmVudDogdGhpcy5pbmplY3RvcixcbiAgICAgIH0pO1xuICAgIHJldHVybiB0aGlzLl9jaGlsZE1lbnVJbmplY3RvcjtcbiAgfVxufVxuIl19
@@ -0,0 +1,240 @@
1
+ /* eslint-disable @angular-eslint/directive-class-suffix */
2
+ /* eslint-disable @angular-eslint/no-output-rename */
3
+ /* eslint-disable @angular-eslint/no-outputs-metadata-property */
4
+ /* eslint-disable @angular-eslint/no-input-rename */
5
+ /* eslint-disable @angular-eslint/no-inputs-metadata-property */
6
+ import { InputModalityDetector } from '@angular/cdk/a11y';
7
+ import { Directionality } from '@angular/cdk/bidi';
8
+ import { DOWN_ARROW, ENTER, hasModifierKey, LEFT_ARROW, RIGHT_ARROW, SPACE, UP_ARROW } from '@angular/cdk/keycodes';
9
+ import { Overlay, OverlayConfig, STANDARD_DROPDOWN_ADJACENT_POSITIONS, STANDARD_DROPDOWN_BELOW_POSITIONS, } from '@angular/cdk/overlay';
10
+ import { _getEventTarget } from '@angular/cdk/platform';
11
+ import { Directive, ElementRef, inject, NgZone } from '@angular/core';
12
+ import { fromEvent } from 'rxjs';
13
+ import { filter, takeUntil } from 'rxjs/operators';
14
+ import { MENU_AIM } from './menu-aim';
15
+ import { CDK_MENU } from './menu-interface';
16
+ import { PARENT_OR_NEW_MENU_STACK_PROVIDER } from './menu-stack';
17
+ import { CdkMenuTriggerBase, MENU_TRIGGER } from './menu-trigger-base';
18
+ import * as i0 from "@angular/core";
19
+ export class CdkMenuTrigger extends CdkMenuTriggerBase {
20
+ constructor() {
21
+ super();
22
+ this._elementRef = inject(ElementRef);
23
+ this._overlay = inject(Overlay);
24
+ this._ngZone = inject(NgZone);
25
+ this._directionality = inject(Directionality, { optional: true });
26
+ this._inputModalityDetector = inject(InputModalityDetector);
27
+ this._parentMenu = inject(CDK_MENU, { optional: true });
28
+ this._menuAim = inject(MENU_AIM, { optional: true });
29
+ this._setRole();
30
+ this._registerCloseHandler();
31
+ this._subscribeToMenuStackClosed();
32
+ this._subscribeToMouseEnter();
33
+ this._subscribeToMenuStackHasFocus();
34
+ this._setType();
35
+ }
36
+ toggle() {
37
+ this.isOpen() ? this.close() : this.open();
38
+ }
39
+ open() {
40
+ if (!this.isOpen() && this.menuTemplateRef != null) {
41
+ this.opened.next();
42
+ this.overlayRef = this.overlayRef || this._overlay.create(this._getOverlayConfig());
43
+ this.overlayRef.attach(this.getMenuContentPortal());
44
+ this._subscribeToOutsideClicks();
45
+ }
46
+ }
47
+ close() {
48
+ if (this.isOpen()) {
49
+ this.closed.next();
50
+ this.overlayRef.detach();
51
+ }
52
+ this._closeSiblingTriggers();
53
+ }
54
+ getMenu() {
55
+ return this.childMenu;
56
+ }
57
+ _toggleOnKeydown(event) {
58
+ const isParentVertical = this._parentMenu?.orientation === 'vertical';
59
+ switch (event.keyCode) {
60
+ case SPACE:
61
+ case ENTER:
62
+ if (!hasModifierKey(event)) {
63
+ this.toggle();
64
+ this.childMenu?.focusFirstItem('keyboard');
65
+ }
66
+ break;
67
+ case RIGHT_ARROW:
68
+ if (!hasModifierKey(event)) {
69
+ if (this._parentMenu && isParentVertical && this._directionality?.value !== 'rtl') {
70
+ event.preventDefault();
71
+ this.open();
72
+ this.childMenu?.focusFirstItem('keyboard');
73
+ }
74
+ }
75
+ break;
76
+ case LEFT_ARROW:
77
+ if (!hasModifierKey(event)) {
78
+ if (this._parentMenu && isParentVertical && this._directionality?.value === 'rtl') {
79
+ event.preventDefault();
80
+ this.open();
81
+ this.childMenu?.focusFirstItem('keyboard');
82
+ }
83
+ }
84
+ break;
85
+ case DOWN_ARROW:
86
+ case UP_ARROW:
87
+ if (!hasModifierKey(event)) {
88
+ if (!isParentVertical) {
89
+ event.preventDefault();
90
+ this.open();
91
+ event.keyCode === DOWN_ARROW
92
+ ? this.childMenu?.focusFirstItem('keyboard')
93
+ : this.childMenu?.focusLastItem('keyboard');
94
+ }
95
+ }
96
+ break;
97
+ }
98
+ }
99
+ _handleClick() {
100
+ if (this._inputModalityDetector.mostRecentModality !== 'keyboard') {
101
+ this.toggle();
102
+ this.childMenu?.focusFirstItem('mouse');
103
+ }
104
+ }
105
+ _setHasFocus(hasFocus) {
106
+ if (!this._parentMenu) {
107
+ this.menuStack.setHasFocus(hasFocus);
108
+ }
109
+ }
110
+ _subscribeToMouseEnter() {
111
+ this._ngZone.runOutsideAngular(() => {
112
+ fromEvent(this._elementRef.nativeElement, 'mouseenter')
113
+ .pipe(filter(() => !this.menuStack.isEmpty() && !this.isOpen()), takeUntil(this.destroyed))
114
+ .subscribe(() => {
115
+ const toggleMenus = () => this._ngZone.run(() => {
116
+ this._closeSiblingTriggers();
117
+ this.open();
118
+ });
119
+ if (this._menuAim) {
120
+ this._menuAim.toggle(toggleMenus);
121
+ }
122
+ else {
123
+ toggleMenus();
124
+ }
125
+ });
126
+ });
127
+ }
128
+ _closeSiblingTriggers() {
129
+ if (this._parentMenu) {
130
+ const isParentMenuBar = !this.menuStack.closeSubMenuOf(this._parentMenu) && this.menuStack.peek() !== this._parentMenu;
131
+ if (isParentMenuBar) {
132
+ this.menuStack.closeAll();
133
+ }
134
+ }
135
+ else {
136
+ this.menuStack.closeAll();
137
+ }
138
+ }
139
+ _getOverlayConfig() {
140
+ return new OverlayConfig({
141
+ positionStrategy: this._getOverlayPositionStrategy(),
142
+ scrollStrategy: this._overlay.scrollStrategies.reposition(),
143
+ direction: this._directionality || undefined,
144
+ });
145
+ }
146
+ _getOverlayPositionStrategy() {
147
+ return this._overlay
148
+ .position()
149
+ .flexibleConnectedTo(this._elementRef)
150
+ .withLockedPosition()
151
+ .withGrowAfterOpen()
152
+ .withPositions(this._getOverlayPositions());
153
+ }
154
+ _getOverlayPositions() {
155
+ return (this.menuPosition ??
156
+ (!this._parentMenu || this._parentMenu.orientation === 'horizontal'
157
+ ? STANDARD_DROPDOWN_BELOW_POSITIONS
158
+ : STANDARD_DROPDOWN_ADJACENT_POSITIONS));
159
+ }
160
+ _registerCloseHandler() {
161
+ if (!this._parentMenu) {
162
+ this.menuStack.closed.pipe(takeUntil(this.destroyed)).subscribe(({ item }) => {
163
+ if (item === this.childMenu) {
164
+ this.close();
165
+ }
166
+ });
167
+ }
168
+ }
169
+ _subscribeToOutsideClicks() {
170
+ if (this.overlayRef) {
171
+ this.overlayRef
172
+ .outsidePointerEvents()
173
+ .pipe(takeUntil(this.stopOutsideClicksListener))
174
+ .subscribe((event) => {
175
+ const target = _getEventTarget(event);
176
+ const element = this._elementRef.nativeElement;
177
+ if (target !== element && !element.contains(target)) {
178
+ if (!this.isElementInsideMenuStack(target)) {
179
+ this.menuStack.closeAll();
180
+ }
181
+ else {
182
+ this._closeSiblingTriggers();
183
+ }
184
+ }
185
+ });
186
+ }
187
+ }
188
+ _subscribeToMenuStackHasFocus() {
189
+ if (!this._parentMenu) {
190
+ this.menuStack.hasFocus.pipe(takeUntil(this.destroyed)).subscribe((hasFocus) => {
191
+ if (!hasFocus) {
192
+ this.menuStack.closeAll();
193
+ }
194
+ });
195
+ }
196
+ }
197
+ _subscribeToMenuStackClosed() {
198
+ if (!this._parentMenu) {
199
+ this.menuStack.closed.subscribe(({ focusParentTrigger }) => {
200
+ if (focusParentTrigger && !this.menuStack.length()) {
201
+ this._elementRef.nativeElement.focus();
202
+ }
203
+ });
204
+ }
205
+ }
206
+ _setRole() {
207
+ if (!this._parentMenu) {
208
+ this._elementRef.nativeElement.setAttribute('role', 'button');
209
+ }
210
+ }
211
+ _setType() {
212
+ const element = this._elementRef.nativeElement;
213
+ if (element.nodeName === 'BUTTON' && !element.getAttribute('type')) {
214
+ element.setAttribute('type', 'button');
215
+ }
216
+ }
217
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuTrigger, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
218
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.1", type: CdkMenuTrigger, isStandalone: true, selector: "[cdkMenuTriggerFor]", inputs: { menuTemplateRef: ["cdkMenuTriggerFor", "menuTemplateRef"], menuPosition: ["cdkMenuPosition", "menuPosition"], menuData: ["cdkMenuTriggerData", "menuData"] }, outputs: { opened: "cdkMenuOpened", closed: "cdkMenuClosed" }, host: { listeners: { "focusin": "_setHasFocus(true)", "focusout": "_setHasFocus(false)", "keydown": "_toggleOnKeydown($event)", "click": "_handleClick()" }, properties: { "attr.aria-haspopup": "menuTemplateRef ? \"menu\" : null", "attr.aria-expanded": "menuTemplateRef == null ? null : isOpen()" }, classAttribute: "cdk-menu-trigger" }, providers: [{ provide: MENU_TRIGGER, useExisting: CdkMenuTrigger }, PARENT_OR_NEW_MENU_STACK_PROVIDER], exportAs: ["cdkMenuTriggerFor"], usesInheritance: true, ngImport: i0 }); }
219
+ }
220
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenuTrigger, decorators: [{
221
+ type: Directive,
222
+ args: [{
223
+ selector: '[cdkMenuTriggerFor]',
224
+ exportAs: 'cdkMenuTriggerFor',
225
+ standalone: true,
226
+ host: {
227
+ class: 'cdk-menu-trigger',
228
+ '[attr.aria-haspopup]': 'menuTemplateRef ? "menu" : null',
229
+ '[attr.aria-expanded]': 'menuTemplateRef == null ? null : isOpen()',
230
+ '(focusin)': '_setHasFocus(true)',
231
+ '(focusout)': '_setHasFocus(false)',
232
+ '(keydown)': '_toggleOnKeydown($event)',
233
+ '(click)': '_handleClick()',
234
+ },
235
+ inputs: ['menuTemplateRef: cdkMenuTriggerFor', 'menuPosition: cdkMenuPosition', 'menuData: cdkMenuTriggerData'],
236
+ outputs: ['opened: cdkMenuOpened', 'closed: cdkMenuClosed'],
237
+ providers: [{ provide: MENU_TRIGGER, useExisting: CdkMenuTrigger }, PARENT_OR_NEW_MENU_STACK_PROVIDER],
238
+ }]
239
+ }], ctorParameters: function () { return []; } });
240
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-trigger.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/overlay/components/menu/menu-trigger.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/directive-class-suffix */\n/* eslint-disable @angular-eslint/no-output-rename */\n/* eslint-disable @angular-eslint/no-outputs-metadata-property */\n/* eslint-disable @angular-eslint/no-input-rename */\n/* eslint-disable @angular-eslint/no-inputs-metadata-property */\n\nimport { InputModalityDetector } from '@angular/cdk/a11y';\nimport { Directionality } from '@angular/cdk/bidi';\nimport { DOWN_ARROW, ENTER, hasModifierKey, LEFT_ARROW, RIGHT_ARROW, SPACE, UP_ARROW } from '@angular/cdk/keycodes';\nimport {\n  ConnectedPosition,\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  STANDARD_DROPDOWN_ADJACENT_POSITIONS,\n  STANDARD_DROPDOWN_BELOW_POSITIONS,\n} from '@angular/cdk/overlay';\nimport { _getEventTarget } from '@angular/cdk/platform';\nimport { Directive, ElementRef, inject, NgZone, OnDestroy } from '@angular/core';\nimport { fromEvent } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { MENU_AIM } from './menu-aim';\nimport { CDK_MENU, Menu } from './menu-interface';\nimport { PARENT_OR_NEW_MENU_STACK_PROVIDER } from './menu-stack';\nimport { CdkMenuTriggerBase, MENU_TRIGGER } from './menu-trigger-base';\n\n@Directive({\n  selector: '[cdkMenuTriggerFor]',\n  exportAs: 'cdkMenuTriggerFor',\n  standalone: true,\n  host: {\n    class: 'cdk-menu-trigger',\n    '[attr.aria-haspopup]': 'menuTemplateRef ? \"menu\" : null',\n    '[attr.aria-expanded]': 'menuTemplateRef == null ? null : isOpen()',\n    '(focusin)': '_setHasFocus(true)',\n    '(focusout)': '_setHasFocus(false)',\n    '(keydown)': '_toggleOnKeydown($event)',\n    '(click)': '_handleClick()',\n  },\n  inputs: ['menuTemplateRef: cdkMenuTriggerFor', 'menuPosition: cdkMenuPosition', 'menuData: cdkMenuTriggerData'],\n  outputs: ['opened: cdkMenuOpened', 'closed: cdkMenuClosed'],\n  providers: [{ provide: MENU_TRIGGER, useExisting: CdkMenuTrigger }, PARENT_OR_NEW_MENU_STACK_PROVIDER],\n})\nexport class CdkMenuTrigger extends CdkMenuTriggerBase implements OnDestroy {\n  private readonly _elementRef: ElementRef<HTMLElement> = inject(ElementRef);\n  private readonly _overlay = inject(Overlay);\n  private readonly _ngZone = inject(NgZone);\n  private readonly _directionality = inject(Directionality, { optional: true });\n  private readonly _inputModalityDetector = inject(InputModalityDetector);\n\n  private readonly _parentMenu = inject(CDK_MENU, { optional: true });\n\n  private readonly _menuAim = inject(MENU_AIM, { optional: true });\n\n  constructor() {\n    super();\n    this._setRole();\n    this._registerCloseHandler();\n    this._subscribeToMenuStackClosed();\n    this._subscribeToMouseEnter();\n    this._subscribeToMenuStackHasFocus();\n    this._setType();\n  }\n\n  toggle() {\n    this.isOpen() ? this.close() : this.open();\n  }\n\n  open() {\n    if (!this.isOpen() && this.menuTemplateRef != null) {\n      this.opened.next();\n\n      this.overlayRef = this.overlayRef || this._overlay.create(this._getOverlayConfig());\n      this.overlayRef.attach(this.getMenuContentPortal());\n      this._subscribeToOutsideClicks();\n    }\n  }\n\n  close() {\n    if (this.isOpen()) {\n      this.closed.next();\n\n      this.overlayRef!.detach();\n    }\n    this._closeSiblingTriggers();\n  }\n\n  getMenu(): Menu | undefined {\n    return this.childMenu;\n  }\n\n  _toggleOnKeydown(event: KeyboardEvent) {\n    const isParentVertical = this._parentMenu?.orientation === 'vertical';\n    switch (event.keyCode) {\n      case SPACE:\n      case ENTER:\n        if (!hasModifierKey(event)) {\n          this.toggle();\n          this.childMenu?.focusFirstItem('keyboard');\n        }\n        break;\n\n      case RIGHT_ARROW:\n        if (!hasModifierKey(event)) {\n          if (this._parentMenu && isParentVertical && this._directionality?.value !== 'rtl') {\n            event.preventDefault();\n            this.open();\n            this.childMenu?.focusFirstItem('keyboard');\n          }\n        }\n        break;\n\n      case LEFT_ARROW:\n        if (!hasModifierKey(event)) {\n          if (this._parentMenu && isParentVertical && this._directionality?.value === 'rtl') {\n            event.preventDefault();\n            this.open();\n            this.childMenu?.focusFirstItem('keyboard');\n          }\n        }\n        break;\n\n      case DOWN_ARROW:\n      case UP_ARROW:\n        if (!hasModifierKey(event)) {\n          if (!isParentVertical) {\n            event.preventDefault();\n            this.open();\n            event.keyCode === DOWN_ARROW\n              ? this.childMenu?.focusFirstItem('keyboard')\n              : this.childMenu?.focusLastItem('keyboard');\n          }\n        }\n        break;\n    }\n  }\n\n  _handleClick() {\n    if (this._inputModalityDetector.mostRecentModality !== 'keyboard') {\n      this.toggle();\n      this.childMenu?.focusFirstItem('mouse');\n    }\n  }\n\n  _setHasFocus(hasFocus: boolean) {\n    if (!this._parentMenu) {\n      this.menuStack.setHasFocus(hasFocus);\n    }\n  }\n\n  private _subscribeToMouseEnter() {\n    this._ngZone.runOutsideAngular(() => {\n      fromEvent(this._elementRef.nativeElement, 'mouseenter')\n        .pipe(\n          filter(() => !this.menuStack.isEmpty() && !this.isOpen()),\n          takeUntil(this.destroyed),\n        )\n        .subscribe(() => {\n          const toggleMenus = () =>\n            this._ngZone.run(() => {\n              this._closeSiblingTriggers();\n              this.open();\n            });\n\n          if (this._menuAim) {\n            this._menuAim.toggle(toggleMenus);\n          } else {\n            toggleMenus();\n          }\n        });\n    });\n  }\n\n  private _closeSiblingTriggers() {\n    if (this._parentMenu) {\n      const isParentMenuBar =\n        !this.menuStack.closeSubMenuOf(this._parentMenu) && this.menuStack.peek() !== this._parentMenu;\n\n      if (isParentMenuBar) {\n        this.menuStack.closeAll();\n      }\n    } else {\n      this.menuStack.closeAll();\n    }\n  }\n\n  private _getOverlayConfig() {\n    return new OverlayConfig({\n      positionStrategy: this._getOverlayPositionStrategy(),\n      scrollStrategy: this._overlay.scrollStrategies.reposition(),\n      direction: this._directionality || undefined,\n    });\n  }\n\n  private _getOverlayPositionStrategy(): FlexibleConnectedPositionStrategy {\n    return this._overlay\n      .position()\n      .flexibleConnectedTo(this._elementRef)\n      .withLockedPosition()\n      .withGrowAfterOpen()\n      .withPositions(this._getOverlayPositions());\n  }\n\n  private _getOverlayPositions(): ConnectedPosition[] {\n    return (\n      this.menuPosition ??\n      (!this._parentMenu || this._parentMenu.orientation === 'horizontal'\n        ? STANDARD_DROPDOWN_BELOW_POSITIONS\n        : STANDARD_DROPDOWN_ADJACENT_POSITIONS)\n    );\n  }\n\n  private _registerCloseHandler() {\n    if (!this._parentMenu) {\n      this.menuStack.closed.pipe(takeUntil(this.destroyed)).subscribe(({ item }) => {\n        if (item === this.childMenu) {\n          this.close();\n        }\n      });\n    }\n  }\n\n  private _subscribeToOutsideClicks() {\n    if (this.overlayRef) {\n      this.overlayRef\n        .outsidePointerEvents()\n        .pipe(takeUntil(this.stopOutsideClicksListener))\n        .subscribe((event) => {\n          const target = _getEventTarget(event) as Element;\n          const element = this._elementRef.nativeElement;\n\n          if (target !== element && !element.contains(target)) {\n            if (!this.isElementInsideMenuStack(target)) {\n              this.menuStack.closeAll();\n            } else {\n              this._closeSiblingTriggers();\n            }\n          }\n        });\n    }\n  }\n\n  private _subscribeToMenuStackHasFocus() {\n    if (!this._parentMenu) {\n      this.menuStack.hasFocus.pipe(takeUntil(this.destroyed)).subscribe((hasFocus) => {\n        if (!hasFocus) {\n          this.menuStack.closeAll();\n        }\n      });\n    }\n  }\n\n  private _subscribeToMenuStackClosed() {\n    if (!this._parentMenu) {\n      this.menuStack.closed.subscribe(({ focusParentTrigger }) => {\n        if (focusParentTrigger && !this.menuStack.length()) {\n          this._elementRef.nativeElement.focus();\n        }\n      });\n    }\n  }\n\n  private _setRole() {\n    if (!this._parentMenu) {\n      this._elementRef.nativeElement.setAttribute('role', 'button');\n    }\n  }\n\n  private _setType() {\n    const element = this._elementRef.nativeElement;\n\n    if (element.nodeName === 'BUTTON' && !element.getAttribute('type')) {\n      element.setAttribute('type', 'button');\n    }\n  }\n}\n"]}