@dotglitch/ngx-common 1.1.48 → 1.1.49
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.
|
@@ -22,9 +22,15 @@ export declare class MenuDirective {
|
|
|
22
22
|
* Configuration for opening the app menu
|
|
23
23
|
*/
|
|
24
24
|
config: MenuOptions;
|
|
25
|
+
private triggers;
|
|
25
26
|
constructor(dialog: MatDialog, viewContainer: ViewContainerRef);
|
|
27
|
+
ngOnInit(): void;
|
|
28
|
+
ngOnChanges(): void;
|
|
26
29
|
ngAfterViewInit(): void;
|
|
27
30
|
openMenu(evt: PointerEvent, items?: MenuItem[], keepOpen?: boolean): Promise<[value: any]>;
|
|
31
|
+
onCtxMenu(e: any): void;
|
|
32
|
+
onClick(e: any): void;
|
|
33
|
+
onDblClick(e: any): void;
|
|
28
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<MenuDirective, never>;
|
|
29
35
|
static ɵdir: i0.ɵɵDirectiveDeclaration<MenuDirective, "[ngx-contextmenu],[ngx-menu]", never, { "data": { "alias": "ngx-menu-context"; "required": false; }; "ctxMenuItems": { "alias": "ngx-contextmenu"; "required": false; }; "menuItems": { "alias": "ngx-menu"; "required": false; }; "config": { "alias": "ngx-menu-config"; "required": false; }; }, {}, never, never, true, never>;
|
|
30
36
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive, Input } from '@angular/core';
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
2
|
import { MatDialog } from '@angular/material/dialog';
|
|
3
3
|
import { getPosition } from './utils';
|
|
4
4
|
import { MenuComponent, calcMenuItemBounds } from '../components/menu/menu.component';
|
|
@@ -14,39 +14,47 @@ export class MenuDirective {
|
|
|
14
14
|
* Configuration for opening the app menu
|
|
15
15
|
*/
|
|
16
16
|
this.config = {};
|
|
17
|
+
this.triggers = [];
|
|
17
18
|
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
if (this.
|
|
23
|
-
|
|
24
|
-
e.preventDefault();
|
|
25
|
-
this.openMenu(e, this.ctxMenuItems, true);
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
if (this.menuItems?.length > 0) {
|
|
29
|
-
if (!this.config?.trigger) {
|
|
30
|
-
el.addEventListener('click', (e) => {
|
|
31
|
-
this.openMenu(e, this.menuItems, true);
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
const triggers = Array.isArray(this.config.trigger) ? this.config.trigger : [this.config.trigger];
|
|
36
|
-
triggers.forEach(t => {
|
|
37
|
-
if (["contextmenu", "click"].includes(t)) {
|
|
38
|
-
el.addEventListener(t, (e) => {
|
|
39
|
-
e.preventDefault();
|
|
40
|
-
this.openMenu(e, this.ctxMenuItems, true);
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
else {
|
|
44
|
-
el.addEventListener(t, this.openMenu.bind(this));
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this.ngOnChanges();
|
|
21
|
+
}
|
|
22
|
+
ngOnChanges() {
|
|
23
|
+
if (this.config.trigger) {
|
|
24
|
+
this.triggers = Array.isArray(this.config.trigger) ? this.config.trigger : [this.config.trigger];
|
|
48
25
|
}
|
|
49
26
|
}
|
|
27
|
+
ngAfterViewInit() {
|
|
28
|
+
// const el = this.viewContainer.element.nativeElement as HTMLElement;
|
|
29
|
+
// // Automatically attach context menu items to
|
|
30
|
+
// // the contextmenu event
|
|
31
|
+
// if (this.ctxMenuItems) {
|
|
32
|
+
// el.addEventListener('contextmenu', (e) => {
|
|
33
|
+
// e.preventDefault();
|
|
34
|
+
// this.openMenu(e as any, this.ctxMenuItems, true);
|
|
35
|
+
// });
|
|
36
|
+
// }
|
|
37
|
+
// if (this.menuItems?.length > 0) {
|
|
38
|
+
// if (!this.config?.trigger) {
|
|
39
|
+
// el.addEventListener('click', (e) => {
|
|
40
|
+
// this.openMenu(e as any, this.menuItems, true);
|
|
41
|
+
// });
|
|
42
|
+
// }
|
|
43
|
+
// else {
|
|
44
|
+
// triggers.forEach(t => {
|
|
45
|
+
// if (["contextmenu", "click"].includes(t)) {
|
|
46
|
+
// el.addEventListener(t, (e) => {
|
|
47
|
+
// e.preventDefault();
|
|
48
|
+
// this.openMenu(e as any, this.ctxMenuItems, true);
|
|
49
|
+
// });
|
|
50
|
+
// }
|
|
51
|
+
// else {
|
|
52
|
+
// el.addEventListener(t, this.openMenu.bind(this));
|
|
53
|
+
// }
|
|
54
|
+
// });
|
|
55
|
+
// }
|
|
56
|
+
// }
|
|
57
|
+
}
|
|
50
58
|
async openMenu(evt, items = this.menuItems, keepOpen = false) {
|
|
51
59
|
const el = this.viewContainer.element.nativeElement;
|
|
52
60
|
el.classList.add("ngx-menu-open");
|
|
@@ -63,10 +71,31 @@ export class MenuDirective {
|
|
|
63
71
|
throw ex;
|
|
64
72
|
});
|
|
65
73
|
}
|
|
74
|
+
onCtxMenu(e) {
|
|
75
|
+
if (this.ctxMenuItems || this.triggers.includes("contextmenu")) {
|
|
76
|
+
e.preventDefault();
|
|
77
|
+
this.openMenu(e, this.ctxMenuItems, true);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
onClick(e) {
|
|
81
|
+
if (this.menuItems &&
|
|
82
|
+
(this.triggers.length == 0 ||
|
|
83
|
+
this.triggers.includes("click"))) {
|
|
84
|
+
e.preventDefault();
|
|
85
|
+
this.openMenu(e, this.menuItems, true);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
onDblClick(e) {
|
|
89
|
+
if (this.menuItems && this.triggers.length == 0 ||
|
|
90
|
+
this.menuItems && this.triggers.includes("dblclick")) {
|
|
91
|
+
e.preventDefault();
|
|
92
|
+
this.openMenu(e, this.menuItems, true);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
66
95
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MenuDirective, deps: [{ token: i1.MatDialog }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
67
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.2", type: MenuDirective, isStandalone: true, selector: "[ngx-contextmenu],[ngx-menu]", inputs: { data: ["ngx-menu-context", "data"], ctxMenuItems: ["ngx-contextmenu", "ctxMenuItems"], menuItems: ["ngx-menu", "menuItems"], config: ["ngx-menu-config", "config"] }, providers: [
|
|
96
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.2", type: MenuDirective, isStandalone: true, selector: "[ngx-contextmenu],[ngx-menu]", inputs: { data: ["ngx-menu-context", "data"], ctxMenuItems: ["ngx-contextmenu", "ctxMenuItems"], menuItems: ["ngx-menu", "menuItems"], config: ["ngx-menu-config", "config"] }, host: { listeners: { "contextmenu": "onCtxMenu($event)", "click": "onClick($event)", "dblclick": "onDblClick($event)" } }, providers: [
|
|
68
97
|
MatDialog
|
|
69
|
-
], ngImport: i0 }); }
|
|
98
|
+
], usesOnChanges: true, ngImport: i0 }); }
|
|
70
99
|
}
|
|
71
100
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MenuDirective, decorators: [{
|
|
72
101
|
type: Directive,
|
|
@@ -89,6 +118,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
89
118
|
}], config: [{
|
|
90
119
|
type: Input,
|
|
91
120
|
args: ["ngx-menu-config"]
|
|
121
|
+
}], onCtxMenu: [{
|
|
122
|
+
type: HostListener,
|
|
123
|
+
args: ["contextmenu", ['$event']]
|
|
124
|
+
}], onClick: [{
|
|
125
|
+
type: HostListener,
|
|
126
|
+
args: ["click", ['$event']]
|
|
127
|
+
}], onDblClick: [{
|
|
128
|
+
type: HostListener,
|
|
129
|
+
args: ["dblclick", ['$event']]
|
|
92
130
|
}] } });
|
|
93
131
|
// Helper to open the menu without using the directive.
|
|
94
132
|
export const openMenu = async (dialog, menuItems, data, evt, config = {}, el) => {
|
|
@@ -118,4 +156,4 @@ export const openMenu = async (dialog, menuItems, data, evt, config = {}, el) =>
|
|
|
118
156
|
})
|
|
119
157
|
.afterClosed());
|
|
120
158
|
};
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.directive.js","sourceRoot":"","sources":["../../../../packages/common/src/directives/menu.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ViewContainerRef, SecurityContext } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { getPosition } from './utils';\nimport { MenuItem, MenuOptions } from '../types/menu';\nimport { MenuComponent, calcMenuItemBounds } from '../components/menu/menu.component';\nimport { ulid } from 'ulidx';\nimport { firstValueFrom } from 'rxjs';\n\n@Directive({\n    selector: '[ngx-contextmenu],[ngx-menu]',\n    providers: [\n        MatDialog\n    ],\n    standalone: true\n})\nexport class MenuDirective {\n\n    /**\n     * The data representing the item the menu was opened for.\n     */\n    @Input(\"ngx-menu-context\") data: any;\n\n    /**\n     * The items that will be bound to the context menu.\n     */\n    @Input(\"ngx-contextmenu\") ctxMenuItems: MenuItem[];\n\n    /**\n     * The items that will be bound to the menu that pops\n     * up when the user clicks the element.\n     */\n    @Input(\"ngx-menu\") menuItems: MenuItem[];\n\n    /**\n     * Configuration for opening the app menu\n     */\n    @Input(\"ngx-menu-config\") config: MenuOptions = {};\n\n    constructor(\n        private dialog: MatDialog,\n        private viewContainer: ViewContainerRef\n    ) { }\n\n    ngAfterViewInit() {\n        const el = this.viewContainer.element.nativeElement as HTMLElement;\n\n        // Automatically attach context menu items to\n        // the contextmenu event\n        if (this.ctxMenuItems) {\n            el.addEventListener('contextmenu', (e) => {\n                e.preventDefault();\n                this.openMenu(e as any, this.ctxMenuItems, true);\n            });\n        }\n\n        if (this.menuItems?.length > 0) {\n            if (!this.config?.trigger) {\n                el.addEventListener('click', (e) => {\n                    this.openMenu(e as any, this.menuItems, true);\n                });\n            }\n            else {\n                const triggers = Array.isArray(this.config.trigger) ? this.config.trigger : [this.config.trigger];\n\n                triggers.forEach(t => {\n                    if ([\"contextmenu\", \"click\"].includes(t)) {\n                        el.addEventListener(t, (e) => {\n                            e.preventDefault();\n                            this.openMenu(e as any, this.ctxMenuItems, true);\n                        });\n                    }\n                    else {\n                        el.addEventListener(t, this.openMenu.bind(this));\n                    }\n                });\n            }\n        }\n    }\n\n    async openMenu(evt: PointerEvent, items = this.menuItems, keepOpen = false) {\n        const el = this.viewContainer.element.nativeElement as HTMLElement;\n\n        el.classList.add(\"ngx-menu-open\");\n\n        const isCtxEvent = evt.button == 2;\n\n        const config = structuredClone(this.config);\n        config['_isLockedOpen'] = keepOpen;\n\n        return openMenu(\n            this.dialog,\n            items,\n            this.data,\n            evt,\n            this.config,\n            isCtxEvent ? null : el\n        )\n            .then((...res) => {\n                el.classList.remove(\"ngx-menu-open\");\n                return res;\n            })\n            .catch((ex) => {\n                el.classList.remove(\"ngx-menu-open\");\n                throw ex;\n            });\n    }\n}\n\n// Helper to open the menu without using the directive.\nexport const openMenu = async (\n    dialog: MatDialog,\n    menuItems: MenuItem[],\n    data: any,\n    evt: PointerEvent,\n    config: MenuOptions = {},\n    el?: HTMLElement\n) => {\n    // console.log({ dialog, menuItems, data, evt, config, el });\n\n    evt.preventDefault();\n    evt.stopPropagation();\n\n    // Apply defaults.\n    if (!config.alignment)\n        config.alignment = \"start\";\n\n    const initialBounds = await calcMenuItemBounds(menuItems, data);\n    const cords = getPosition(el || evt, config, initialBounds);\n    const specificId = ulid();\n\n    return firstValueFrom(\n        dialog.open(MenuComponent, {\n            data: {\n                dialog,\n                data: data,\n                ownerCords: el?.getBoundingClientRect(),\n                selfCords: cords,\n                items: menuItems,\n                config: config,\n                id: specificId,\n                targetBounds: initialBounds\n            },\n            panelClass: [\"ngx-menu\", 'ngx-' + specificId].concat(config?.customClass || []),\n            position: cords,\n            backdropClass: \"ngx-menu-backdrop\"\n        })\n        .afterClosed());\n};\n"]}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.directive.js","sourceRoot":"","sources":["../../../../packages/common/src/directives/menu.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, HostListener, Input, ViewContainerRef } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { getPosition } from './utils';\nimport { MenuItem, MenuOptions } from '../types/menu';\nimport { MenuComponent, calcMenuItemBounds } from '../components/menu/menu.component';\nimport { ulid } from 'ulidx';\nimport { firstValueFrom } from 'rxjs';\n\n@Directive({\n    selector: '[ngx-contextmenu],[ngx-menu]',\n    providers: [\n        MatDialog\n    ],\n    standalone: true\n})\nexport class MenuDirective {\n\n    /**\n     * The data representing the item the menu was opened for.\n     */\n    @Input(\"ngx-menu-context\") data: any;\n\n    /**\n     * The items that will be bound to the context menu.\n     */\n    @Input(\"ngx-contextmenu\") ctxMenuItems: MenuItem[];\n\n    /**\n     * The items that will be bound to the menu that pops\n     * up when the user clicks the element.\n     */\n    @Input(\"ngx-menu\") menuItems: MenuItem[];\n\n    /**\n     * Configuration for opening the app menu\n     */\n    @Input(\"ngx-menu-config\") config: MenuOptions = {};\n\n    private triggers: string[] = [];\n\n    constructor(\n        private dialog: MatDialog,\n        private viewContainer: ViewContainerRef\n    ) { }\n\n    ngOnInit() {\n        this.ngOnChanges();\n    }\n\n    ngOnChanges() {\n\n        if (this.config.trigger) {\n            this.triggers = Array.isArray(this.config.trigger) ? this.config.trigger : [this.config.trigger];\n        }\n    }\n\n    ngAfterViewInit() {\n        // const el = this.viewContainer.element.nativeElement as HTMLElement;\n\n        // // Automatically attach context menu items to\n        // // the contextmenu event\n        // if (this.ctxMenuItems) {\n        //     el.addEventListener('contextmenu', (e) => {\n        //         e.preventDefault();\n        //         this.openMenu(e as any, this.ctxMenuItems, true);\n        //     });\n        // }\n\n        // if (this.menuItems?.length > 0) {\n        //     if (!this.config?.trigger) {\n        //         el.addEventListener('click', (e) => {\n        //             this.openMenu(e as any, this.menuItems, true);\n        //         });\n        //     }\n        //     else {\n\n        //         triggers.forEach(t => {\n        //             if ([\"contextmenu\", \"click\"].includes(t)) {\n        //                 el.addEventListener(t, (e) => {\n        //                     e.preventDefault();\n        //                     this.openMenu(e as any, this.ctxMenuItems, true);\n        //                 });\n        //             }\n        //             else {\n        //                 el.addEventListener(t, this.openMenu.bind(this));\n        //             }\n        //         });\n        //     }\n        // }\n    }\n\n    async openMenu(evt: PointerEvent, items = this.menuItems, keepOpen = false) {\n        const el = this.viewContainer.element.nativeElement as HTMLElement;\n\n        el.classList.add(\"ngx-menu-open\");\n\n        const isCtxEvent = evt.button == 2;\n\n        const config = structuredClone(this.config);\n        config['_isLockedOpen'] = keepOpen;\n\n        return openMenu(\n            this.dialog,\n            items,\n            this.data,\n            evt,\n            this.config,\n            isCtxEvent ? null : el\n        )\n            .then((...res) => {\n                el.classList.remove(\"ngx-menu-open\");\n                return res;\n            })\n            .catch((ex) => {\n                el.classList.remove(\"ngx-menu-open\");\n                throw ex;\n            });\n    }\n\n    @HostListener(\"contextmenu\", ['$event'])\n    onCtxMenu(e) {\n        if (this.ctxMenuItems || this.triggers.includes(\"contextmenu\")) {\n            e.preventDefault();\n            this.openMenu(e as any, this.ctxMenuItems, true);\n        }\n    }\n\n    @HostListener(\"click\", ['$event'])\n    onClick(e) {\n        if (\n            this.menuItems &&\n            (\n                this.triggers.length == 0 ||\n                this.triggers.includes(\"click\")\n            )\n        ) {\n            e.preventDefault();\n            this.openMenu(e as any, this.menuItems, true);\n        }\n    }\n\n    @HostListener(\"dblclick\", ['$event'])\n    onDblClick(e) {\n        if (\n            this.menuItems && this.triggers.length == 0 ||\n            this.menuItems && this.triggers.includes(\"dblclick\")\n        ) {\n            e.preventDefault();\n            this.openMenu(e as any, this.menuItems, true);\n        }\n    }\n}\n\n// Helper to open the menu without using the directive.\nexport const openMenu = async (\n    dialog: MatDialog,\n    menuItems: MenuItem[],\n    data: any,\n    evt: PointerEvent,\n    config: MenuOptions = {},\n    el?: HTMLElement\n) => {\n    // console.log({ dialog, menuItems, data, evt, config, el });\n\n    evt.preventDefault();\n    evt.stopPropagation();\n\n    // Apply defaults.\n    if (!config.alignment)\n        config.alignment = \"start\";\n\n    const initialBounds = await calcMenuItemBounds(menuItems, data);\n    const cords = getPosition(el || evt, config, initialBounds);\n    const specificId = ulid();\n\n    return firstValueFrom(\n        dialog.open(MenuComponent, {\n            data: {\n                dialog,\n                data: data,\n                ownerCords: el?.getBoundingClientRect(),\n                selfCords: cords,\n                items: menuItems,\n                config: config,\n                id: specificId,\n                targetBounds: initialBounds\n            },\n            panelClass: [\"ngx-menu\", 'ngx-' + specificId].concat(config?.customClass || []),\n            position: cords,\n            backdropClass: \"ngx-menu-backdrop\"\n        })\n        .afterClosed());\n};\n"]}
|
|
@@ -933,39 +933,47 @@ class MenuDirective {
|
|
|
933
933
|
* Configuration for opening the app menu
|
|
934
934
|
*/
|
|
935
935
|
this.config = {};
|
|
936
|
+
this.triggers = [];
|
|
936
937
|
}
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
if (this.
|
|
942
|
-
|
|
943
|
-
e.preventDefault();
|
|
944
|
-
this.openMenu(e, this.ctxMenuItems, true);
|
|
945
|
-
});
|
|
946
|
-
}
|
|
947
|
-
if (this.menuItems?.length > 0) {
|
|
948
|
-
if (!this.config?.trigger) {
|
|
949
|
-
el.addEventListener('click', (e) => {
|
|
950
|
-
this.openMenu(e, this.menuItems, true);
|
|
951
|
-
});
|
|
952
|
-
}
|
|
953
|
-
else {
|
|
954
|
-
const triggers = Array.isArray(this.config.trigger) ? this.config.trigger : [this.config.trigger];
|
|
955
|
-
triggers.forEach(t => {
|
|
956
|
-
if (["contextmenu", "click"].includes(t)) {
|
|
957
|
-
el.addEventListener(t, (e) => {
|
|
958
|
-
e.preventDefault();
|
|
959
|
-
this.openMenu(e, this.ctxMenuItems, true);
|
|
960
|
-
});
|
|
961
|
-
}
|
|
962
|
-
else {
|
|
963
|
-
el.addEventListener(t, this.openMenu.bind(this));
|
|
964
|
-
}
|
|
965
|
-
});
|
|
966
|
-
}
|
|
938
|
+
ngOnInit() {
|
|
939
|
+
this.ngOnChanges();
|
|
940
|
+
}
|
|
941
|
+
ngOnChanges() {
|
|
942
|
+
if (this.config.trigger) {
|
|
943
|
+
this.triggers = Array.isArray(this.config.trigger) ? this.config.trigger : [this.config.trigger];
|
|
967
944
|
}
|
|
968
945
|
}
|
|
946
|
+
ngAfterViewInit() {
|
|
947
|
+
// const el = this.viewContainer.element.nativeElement as HTMLElement;
|
|
948
|
+
// // Automatically attach context menu items to
|
|
949
|
+
// // the contextmenu event
|
|
950
|
+
// if (this.ctxMenuItems) {
|
|
951
|
+
// el.addEventListener('contextmenu', (e) => {
|
|
952
|
+
// e.preventDefault();
|
|
953
|
+
// this.openMenu(e as any, this.ctxMenuItems, true);
|
|
954
|
+
// });
|
|
955
|
+
// }
|
|
956
|
+
// if (this.menuItems?.length > 0) {
|
|
957
|
+
// if (!this.config?.trigger) {
|
|
958
|
+
// el.addEventListener('click', (e) => {
|
|
959
|
+
// this.openMenu(e as any, this.menuItems, true);
|
|
960
|
+
// });
|
|
961
|
+
// }
|
|
962
|
+
// else {
|
|
963
|
+
// triggers.forEach(t => {
|
|
964
|
+
// if (["contextmenu", "click"].includes(t)) {
|
|
965
|
+
// el.addEventListener(t, (e) => {
|
|
966
|
+
// e.preventDefault();
|
|
967
|
+
// this.openMenu(e as any, this.ctxMenuItems, true);
|
|
968
|
+
// });
|
|
969
|
+
// }
|
|
970
|
+
// else {
|
|
971
|
+
// el.addEventListener(t, this.openMenu.bind(this));
|
|
972
|
+
// }
|
|
973
|
+
// });
|
|
974
|
+
// }
|
|
975
|
+
// }
|
|
976
|
+
}
|
|
969
977
|
async openMenu(evt, items = this.menuItems, keepOpen = false) {
|
|
970
978
|
const el = this.viewContainer.element.nativeElement;
|
|
971
979
|
el.classList.add("ngx-menu-open");
|
|
@@ -982,10 +990,31 @@ class MenuDirective {
|
|
|
982
990
|
throw ex;
|
|
983
991
|
});
|
|
984
992
|
}
|
|
993
|
+
onCtxMenu(e) {
|
|
994
|
+
if (this.ctxMenuItems || this.triggers.includes("contextmenu")) {
|
|
995
|
+
e.preventDefault();
|
|
996
|
+
this.openMenu(e, this.ctxMenuItems, true);
|
|
997
|
+
}
|
|
998
|
+
}
|
|
999
|
+
onClick(e) {
|
|
1000
|
+
if (this.menuItems &&
|
|
1001
|
+
(this.triggers.length == 0 ||
|
|
1002
|
+
this.triggers.includes("click"))) {
|
|
1003
|
+
e.preventDefault();
|
|
1004
|
+
this.openMenu(e, this.menuItems, true);
|
|
1005
|
+
}
|
|
1006
|
+
}
|
|
1007
|
+
onDblClick(e) {
|
|
1008
|
+
if (this.menuItems && this.triggers.length == 0 ||
|
|
1009
|
+
this.menuItems && this.triggers.includes("dblclick")) {
|
|
1010
|
+
e.preventDefault();
|
|
1011
|
+
this.openMenu(e, this.menuItems, true);
|
|
1012
|
+
}
|
|
1013
|
+
}
|
|
985
1014
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MenuDirective, deps: [{ token: i1$1.MatDialog }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
986
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.2", type: MenuDirective, isStandalone: true, selector: "[ngx-contextmenu],[ngx-menu]", inputs: { data: ["ngx-menu-context", "data"], ctxMenuItems: ["ngx-contextmenu", "ctxMenuItems"], menuItems: ["ngx-menu", "menuItems"], config: ["ngx-menu-config", "config"] }, providers: [
|
|
1015
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.2", type: MenuDirective, isStandalone: true, selector: "[ngx-contextmenu],[ngx-menu]", inputs: { data: ["ngx-menu-context", "data"], ctxMenuItems: ["ngx-contextmenu", "ctxMenuItems"], menuItems: ["ngx-menu", "menuItems"], config: ["ngx-menu-config", "config"] }, host: { listeners: { "contextmenu": "onCtxMenu($event)", "click": "onClick($event)", "dblclick": "onDblClick($event)" } }, providers: [
|
|
987
1016
|
MatDialog
|
|
988
|
-
], ngImport: i0 }); }
|
|
1017
|
+
], usesOnChanges: true, ngImport: i0 }); }
|
|
989
1018
|
}
|
|
990
1019
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: MenuDirective, decorators: [{
|
|
991
1020
|
type: Directive,
|
|
@@ -1008,6 +1037,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
1008
1037
|
}], config: [{
|
|
1009
1038
|
type: Input,
|
|
1010
1039
|
args: ["ngx-menu-config"]
|
|
1040
|
+
}], onCtxMenu: [{
|
|
1041
|
+
type: HostListener,
|
|
1042
|
+
args: ["contextmenu", ['$event']]
|
|
1043
|
+
}], onClick: [{
|
|
1044
|
+
type: HostListener,
|
|
1045
|
+
args: ["click", ['$event']]
|
|
1046
|
+
}], onDblClick: [{
|
|
1047
|
+
type: HostListener,
|
|
1048
|
+
args: ["dblclick", ['$event']]
|
|
1011
1049
|
}] } });
|
|
1012
1050
|
// Helper to open the menu without using the directive.
|
|
1013
1051
|
const openMenu = async (dialog, menuItems, data, evt, config = {}, el) => {
|