@ctrl/ngx-rightclick 1.1.3 → 3.0.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.
- package/LICENSE +1 -1
- package/README.md +5 -16
- package/bundles/ctrl-ngx-rightclick.umd.js +622 -658
- package/bundles/ctrl-ngx-rightclick.umd.js.map +1 -1
- package/bundles/ctrl-ngx-rightclick.umd.min.js +15 -1
- package/bundles/ctrl-ngx-rightclick.umd.min.js.map +1 -1
- package/context-menu-injector.d.ts +4 -4
- package/context-menu-trigger.directive.d.ts +1 -0
- package/context-menu.service.d.ts +2 -2
- package/context-submenu-trigger.directive.d.ts +3 -3
- package/ctrl-ngx-rightclick.metadata.json +1 -1
- package/esm2015/context-menu-injector.js +7 -52
- package/esm2015/context-menu-trigger.directive.js +52 -77
- package/esm2015/context-menu.module.js +16 -18
- package/esm2015/context-menu.service.js +19 -121
- package/esm2015/context-submenu-trigger.directive.js +38 -67
- package/esm2015/ctrl-ngx-rightclick.js +2 -6
- package/esm2015/menu.component.js +26 -64
- package/esm2015/public_api.js +7 -11
- package/esm5/context-menu-injector.js +8 -51
- package/esm5/context-menu-trigger.directive.js +54 -94
- package/esm5/context-menu.module.js +13 -16
- package/esm5/context-menu.service.js +20 -164
- package/esm5/context-submenu-trigger.directive.js +39 -88
- package/esm5/ctrl-ngx-rightclick.js +2 -6
- package/esm5/menu.component.js +26 -77
- package/esm5/public_api.js +7 -11
- package/fesm2015/ctrl-ngx-rightclick.js +143 -246
- package/fesm2015/ctrl-ngx-rightclick.js.map +1 -1
- package/fesm5/ctrl-ngx-rightclick.js +149 -336
- package/fesm5/ctrl-ngx-rightclick.js.map +1 -1
- package/menu.component.d.ts +1 -1
- package/package.json +5 -9
@@ -1,14 +1,10 @@
|
|
1
|
-
import { __assign, __values } from 'tslib';
|
1
|
+
import { __assign, __values, __decorate } from 'tslib';
|
2
|
+
import { ElementRef, Injector, ɵɵdefineInjectable, ɵɵinject, INJECTOR, Injectable, EventEmitter, Input, Output, HostListener, Directive, Component, NgModule } from '@angular/core';
|
2
3
|
import { Overlay, ScrollStrategyOptions, OverlayModule } from '@angular/cdk/overlay';
|
3
4
|
import { ComponentPortal, PortalModule } from '@angular/cdk/portal';
|
4
|
-
import { ElementRef, Injectable, Injector, NgModule, Component, HostListener, Directive, Input, Output, EventEmitter, defineInjectable, inject, INJECTOR } from '@angular/core';
|
5
5
|
import { BehaviorSubject, Subject } from 'rxjs';
|
6
6
|
import { filter, take } from 'rxjs/operators';
|
7
7
|
|
8
|
-
/**
|
9
|
-
* @fileoverview added by tsickle
|
10
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
11
|
-
*/
|
12
8
|
var MenuPackage = /** @class */ (function () {
|
13
9
|
function MenuPackage(menu, context) {
|
14
10
|
this.menu = menu;
|
@@ -17,44 +13,26 @@ var MenuPackage = /** @class */ (function () {
|
|
17
13
|
return MenuPackage;
|
18
14
|
}());
|
19
15
|
var MenuInjector = /** @class */ (function () {
|
20
|
-
function MenuInjector(
|
21
|
-
this.
|
22
|
-
this.
|
16
|
+
function MenuInjector(activeContextMenu, parentInjector, context) {
|
17
|
+
this.activeContextMenu = activeContextMenu;
|
18
|
+
this.parentInjector = parentInjector;
|
23
19
|
this.context = context;
|
24
|
-
this.
|
20
|
+
this.menuContext = new MenuPackage(activeContextMenu, context);
|
25
21
|
}
|
26
|
-
|
27
|
-
* @template T
|
28
|
-
* @param {?} token
|
29
|
-
* @param {?=} notFoundValue
|
30
|
-
* @param {?=} flags
|
31
|
-
* @return {?}
|
32
|
-
*/
|
33
|
-
MenuInjector.prototype.get = /**
|
34
|
-
* @template T
|
35
|
-
* @param {?} token
|
36
|
-
* @param {?=} notFoundValue
|
37
|
-
* @param {?=} flags
|
38
|
-
* @return {?}
|
39
|
-
*/
|
40
|
-
function (token, notFoundValue, flags) {
|
22
|
+
MenuInjector.prototype.get = function (token, notFoundValue, flags) {
|
41
23
|
if (token === MenuPackage) {
|
42
|
-
return this.
|
24
|
+
return this.menuContext;
|
43
25
|
}
|
44
|
-
return this.
|
26
|
+
return this.parentInjector.get(token, notFoundValue, flags);
|
45
27
|
};
|
46
28
|
return MenuInjector;
|
47
29
|
}());
|
48
30
|
|
49
|
-
/**
|
50
|
-
* @fileoverview added by tsickle
|
51
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
52
|
-
*/
|
53
31
|
var ContextMenuService = /** @class */ (function () {
|
54
|
-
function ContextMenuService(overlay, scrollStrategy,
|
32
|
+
function ContextMenuService(overlay, scrollStrategy, injector) {
|
55
33
|
this.overlay = overlay;
|
56
34
|
this.scrollStrategy = scrollStrategy;
|
57
|
-
this.
|
35
|
+
this.injector = injector;
|
58
36
|
this.menus = [];
|
59
37
|
this.id = 0;
|
60
38
|
}
|
@@ -65,31 +43,8 @@ var ContextMenuService = /** @class */ (function () {
|
|
65
43
|
* @param submenu is a menu within a menu
|
66
44
|
* @param level if submenu, what level
|
67
45
|
*/
|
68
|
-
|
69
|
-
*
|
70
|
-
* @param {?} $event triggering event
|
71
|
-
* @param {?} menuComponent the component to be shown
|
72
|
-
* @param {?} context
|
73
|
-
* @param {?} menuClose
|
74
|
-
* @param {?} menuAction
|
75
|
-
* @param {?=} submenu is a menu within a menu
|
76
|
-
* @param {?=} level if submenu, what level
|
77
|
-
* @return {?}
|
78
|
-
*/
|
79
|
-
ContextMenuService.prototype.show = /**
|
80
|
-
*
|
81
|
-
* @param {?} $event triggering event
|
82
|
-
* @param {?} menuComponent the component to be shown
|
83
|
-
* @param {?} context
|
84
|
-
* @param {?} menuClose
|
85
|
-
* @param {?} menuAction
|
86
|
-
* @param {?=} submenu is a menu within a menu
|
87
|
-
* @param {?=} level if submenu, what level
|
88
|
-
* @return {?}
|
89
|
-
*/
|
90
|
-
function ($event, menuComponent, context, menuClose, menuAction, submenu, level) {
|
46
|
+
ContextMenuService.prototype.show = function ($event, menuComponent, context, menuClose, menuAction, submenu, level) {
|
91
47
|
if (submenu === void 0) { submenu = false; }
|
92
|
-
/** @type {?} */
|
93
48
|
var target;
|
94
49
|
if (!submenu) {
|
95
50
|
this.closeAll();
|
@@ -109,9 +64,7 @@ var ContextMenuService = /** @class */ (function () {
|
|
109
64
|
this.closeAll(undefined, level);
|
110
65
|
target = $event.target;
|
111
66
|
}
|
112
|
-
/** @type {?} */
|
113
67
|
var el = new ElementRef(target);
|
114
|
-
/** @type {?} */
|
115
68
|
var positionStrategy = this.overlay
|
116
69
|
.position()
|
117
70
|
.flexibleConnectedTo(el)
|
@@ -184,69 +137,36 @@ var ContextMenuService = /** @class */ (function () {
|
|
184
137
|
},
|
185
138
|
]);
|
186
139
|
}
|
187
|
-
/** @type {?} */
|
188
140
|
var t = {
|
189
141
|
submenu: submenu,
|
190
142
|
id: this.id++,
|
191
143
|
isMenuHovered: new BehaviorSubject(false),
|
192
144
|
isTriggerHovered: new BehaviorSubject(false),
|
193
145
|
};
|
194
|
-
|
195
|
-
var menuInjector = new MenuInjector(t, this._injector, context);
|
196
|
-
/** @type {?} */
|
146
|
+
var menuInjector = new MenuInjector(t, this.injector, context);
|
197
147
|
var componentPortal = new ComponentPortal(menuComponent, undefined, menuInjector);
|
198
|
-
/** @type {?} */
|
199
148
|
var overlayRef = this.overlay.create({
|
200
149
|
positionStrategy: positionStrategy,
|
201
150
|
panelClass: 'ngx-contextmenu',
|
202
151
|
scrollStrategy: this.scrollStrategy.close(),
|
203
152
|
});
|
204
|
-
/** @type {?} */
|
205
153
|
var component = overlayRef.attach(componentPortal);
|
206
|
-
|
207
|
-
var res = __assign({ overlayRef: overlayRef, component: component }, t, { menuClose: menuClose, menuAction: menuAction });
|
154
|
+
var res = __assign(__assign({ overlayRef: overlayRef, component: component }, t), { menuClose: menuClose, menuAction: menuAction });
|
208
155
|
this.menus.push(res);
|
209
156
|
return res;
|
210
157
|
};
|
211
|
-
|
212
|
-
* @return {?}
|
213
|
-
*/
|
214
|
-
ContextMenuService.prototype.getCurrentLevel = /**
|
215
|
-
* @return {?}
|
216
|
-
*/
|
217
|
-
function () {
|
158
|
+
ContextMenuService.prototype.getCurrentLevel = function () {
|
218
159
|
return this.menus.length;
|
219
160
|
};
|
220
|
-
|
221
|
-
* @param {?=} context
|
222
|
-
* @param {?=} idx
|
223
|
-
* @return {?}
|
224
|
-
*/
|
225
|
-
ContextMenuService.prototype.closeAll = /**
|
226
|
-
* @param {?=} context
|
227
|
-
* @param {?=} idx
|
228
|
-
* @return {?}
|
229
|
-
*/
|
230
|
-
function (context, idx) {
|
161
|
+
ContextMenuService.prototype.closeAll = function (context, idx) {
|
231
162
|
if (idx === void 0) { idx = 0; }
|
232
163
|
for (var index = idx; index < this.menus.length; index++) {
|
233
|
-
/** @type {?} */
|
234
164
|
var menu = this.menus[index];
|
235
165
|
this.destroyMenu(menu, context);
|
236
166
|
}
|
237
167
|
this.menus.splice(idx, this.menus.length);
|
238
168
|
};
|
239
|
-
|
240
|
-
* @param {?} menu
|
241
|
-
* @param {?=} context
|
242
|
-
* @return {?}
|
243
|
-
*/
|
244
|
-
ContextMenuService.prototype.destroyMenu = /**
|
245
|
-
* @param {?} menu
|
246
|
-
* @param {?=} context
|
247
|
-
* @return {?}
|
248
|
-
*/
|
249
|
-
function (menu, context) {
|
169
|
+
ContextMenuService.prototype.destroyMenu = function (menu, context) {
|
250
170
|
menu.component.instance._state = 'exit';
|
251
171
|
if (menu.component.instance.lazy) {
|
252
172
|
menu.component.instance._animationDone
|
@@ -265,36 +185,15 @@ var ContextMenuService = /** @class */ (function () {
|
|
265
185
|
}
|
266
186
|
menu.menuClose.next();
|
267
187
|
};
|
268
|
-
|
269
|
-
* @param {?} menu
|
270
|
-
* @param {?} menuIndex
|
271
|
-
* @param {?=} context
|
272
|
-
* @return {?}
|
273
|
-
*/
|
274
|
-
ContextMenuService.prototype.close = /**
|
275
|
-
* @param {?} menu
|
276
|
-
* @param {?} menuIndex
|
277
|
-
* @param {?=} context
|
278
|
-
* @return {?}
|
279
|
-
*/
|
280
|
-
function (menu, menuIndex, context) {
|
188
|
+
ContextMenuService.prototype.close = function (menu, menuIndex, context) {
|
281
189
|
this.destroyMenu(menu, context);
|
282
190
|
this.menus.splice(menuIndex, 1);
|
283
191
|
};
|
284
|
-
|
285
|
-
* @param {?} $event
|
286
|
-
* @return {?}
|
287
|
-
*/
|
288
|
-
ContextMenuService.prototype.checkOutsideClick = /**
|
289
|
-
* @param {?} $event
|
290
|
-
* @return {?}
|
291
|
-
*/
|
292
|
-
function ($event) {
|
192
|
+
ContextMenuService.prototype.checkOutsideClick = function ($event) {
|
293
193
|
var e_1, _a;
|
294
194
|
try {
|
295
195
|
for (var _b = __values(this.menus), _c = _b.next(); !_c.done; _c = _b.next()) {
|
296
196
|
var m = _c.value;
|
297
|
-
/** @type {?} */
|
298
197
|
var clickedInside = m.component.location.nativeElement.contains($event.target);
|
299
198
|
if (clickedInside) {
|
300
199
|
$event.preventDefault();
|
@@ -312,29 +211,18 @@ var ContextMenuService = /** @class */ (function () {
|
|
312
211
|
}
|
313
212
|
this.closeAll();
|
314
213
|
};
|
315
|
-
|
316
|
-
* @param {?} id
|
317
|
-
* @return {?}
|
318
|
-
*/
|
319
|
-
ContextMenuService.prototype.closeSubMenu = /**
|
320
|
-
* @param {?} id
|
321
|
-
* @return {?}
|
322
|
-
*/
|
323
|
-
function (id) {
|
324
|
-
/** @type {?} */
|
214
|
+
ContextMenuService.prototype.closeSubMenu = function (id) {
|
325
215
|
var menuIndex = this.menus.findIndex(function (n) { return n.id === id; });
|
326
216
|
if (menuIndex === -1 || menuIndex !== this.menus.length - 1) {
|
327
217
|
return;
|
328
218
|
}
|
329
219
|
// make sure we can close the current menu
|
330
|
-
/** @type {?} */
|
331
220
|
var menu = this.menus[menuIndex];
|
332
221
|
if (menu.isMenuHovered.getValue() || menu.isTriggerHovered.getValue()) {
|
333
222
|
return;
|
334
223
|
}
|
335
224
|
// close all menus up if possible
|
336
225
|
for (var index = this.menus.length - 1; index >= 1; index--) {
|
337
|
-
/** @type {?} */
|
338
226
|
var m = this.menus[index];
|
339
227
|
if (!m.isMenuHovered.getValue() && !m.isTriggerHovered.getValue()) {
|
340
228
|
this.close(m, index);
|
@@ -344,53 +232,44 @@ var ContextMenuService = /** @class */ (function () {
|
|
344
232
|
}
|
345
233
|
}
|
346
234
|
};
|
347
|
-
ContextMenuService.decorators = [
|
348
|
-
{ type: Injectable, args: [{ providedIn: 'root' },] }
|
349
|
-
];
|
350
|
-
/** @nocollapse */
|
351
235
|
ContextMenuService.ctorParameters = function () { return [
|
352
236
|
{ type: Overlay },
|
353
237
|
{ type: ScrollStrategyOptions },
|
354
238
|
{ type: Injector }
|
355
239
|
]; };
|
356
|
-
|
240
|
+
ContextMenuService.ɵprov = ɵɵdefineInjectable({ factory: function ContextMenuService_Factory() { return new ContextMenuService(ɵɵinject(Overlay), ɵɵinject(ScrollStrategyOptions), ɵɵinject(INJECTOR)); }, token: ContextMenuService, providedIn: "root" });
|
241
|
+
ContextMenuService = __decorate([
|
242
|
+
Injectable({ providedIn: 'root' })
|
243
|
+
], ContextMenuService);
|
357
244
|
return ContextMenuService;
|
358
245
|
}());
|
359
246
|
|
360
|
-
/**
|
361
|
-
* @fileoverview added by tsickle
|
362
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
363
|
-
*/
|
364
247
|
var ContextMenuTriggerDirective = /** @class */ (function () {
|
365
248
|
function ContextMenuTriggerDirective(contextMenuService) {
|
366
249
|
this.contextMenuService = contextMenuService;
|
367
250
|
this.holdToDisplay = 1000;
|
368
251
|
this.menuAction = new EventEmitter();
|
369
252
|
this.menuClose = new EventEmitter();
|
253
|
+
this.beforeOpen = new EventEmitter();
|
370
254
|
this.visible = false;
|
371
255
|
}
|
372
|
-
|
373
|
-
|
374
|
-
|
375
|
-
|
376
|
-
|
377
|
-
|
378
|
-
|
379
|
-
|
380
|
-
|
256
|
+
ContextMenuTriggerDirective.prototype.handleMenu = function ($event) {
|
257
|
+
var preventOpen = false;
|
258
|
+
this.beforeOpen.emit({
|
259
|
+
menuContext: this.menuContext,
|
260
|
+
event: $event,
|
261
|
+
preventOpen: function () {
|
262
|
+
preventOpen = true;
|
263
|
+
},
|
264
|
+
});
|
265
|
+
if (preventOpen) {
|
266
|
+
return;
|
267
|
+
}
|
381
268
|
$event.preventDefault();
|
382
269
|
this.menu = this.contextMenuService.show($event, this.contextMenuTrigger, this.menuContext, this.menuClose, this.menuAction);
|
383
270
|
this.visible = true;
|
384
271
|
};
|
385
|
-
|
386
|
-
* @param {?} $event
|
387
|
-
* @return {?}
|
388
|
-
*/
|
389
|
-
ContextMenuTriggerDirective.prototype.handleMouseDown = /**
|
390
|
-
* @param {?} $event
|
391
|
-
* @return {?}
|
392
|
-
*/
|
393
|
-
function ($event) {
|
272
|
+
ContextMenuTriggerDirective.prototype.handleMouseDown = function ($event) {
|
394
273
|
var _this = this;
|
395
274
|
if (this.holdToDisplay >= 0) {
|
396
275
|
$event.stopPropagation();
|
@@ -399,61 +278,55 @@ var ContextMenuTriggerDirective = /** @class */ (function () {
|
|
399
278
|
this.mouseDownTimeoutId = setTimeout(function () { return _this.handleMenu($event); }, this.holdToDisplay);
|
400
279
|
}
|
401
280
|
};
|
402
|
-
|
403
|
-
* @return {?}
|
404
|
-
*/
|
405
|
-
ContextMenuTriggerDirective.prototype.handleMouseUp = /**
|
406
|
-
* @return {?}
|
407
|
-
*/
|
408
|
-
function () {
|
281
|
+
ContextMenuTriggerDirective.prototype.handleMouseUp = function () {
|
409
282
|
clearTimeout(this.mouseDownTimeoutId);
|
410
283
|
};
|
411
|
-
|
412
|
-
* @return {?}
|
413
|
-
*/
|
414
|
-
ContextMenuTriggerDirective.prototype.ngOnInit = /**
|
415
|
-
* @return {?}
|
416
|
-
*/
|
417
|
-
function () {
|
284
|
+
ContextMenuTriggerDirective.prototype.ngOnInit = function () {
|
418
285
|
var _this = this;
|
419
|
-
this.sub = this.menuClose.subscribe(function () { return _this.visible = false; });
|
286
|
+
this.sub = this.menuClose.subscribe(function () { return (_this.visible = false); });
|
420
287
|
};
|
421
|
-
|
422
|
-
* @return {?}
|
423
|
-
*/
|
424
|
-
ContextMenuTriggerDirective.prototype.ngOnDestroy = /**
|
425
|
-
* @return {?}
|
426
|
-
*/
|
427
|
-
function () {
|
288
|
+
ContextMenuTriggerDirective.prototype.ngOnDestroy = function () {
|
428
289
|
this.sub.unsubscribe();
|
429
290
|
};
|
430
|
-
ContextMenuTriggerDirective.decorators = [
|
431
|
-
{ type: Directive, args: [{
|
432
|
-
selector: '[contextMenuTrigger]',
|
433
|
-
exportAs: 'contextMenuTrigger',
|
434
|
-
},] }
|
435
|
-
];
|
436
|
-
/** @nocollapse */
|
437
291
|
ContextMenuTriggerDirective.ctorParameters = function () { return [
|
438
292
|
{ type: ContextMenuService }
|
439
293
|
]; };
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
294
|
+
__decorate([
|
295
|
+
Input()
|
296
|
+
], ContextMenuTriggerDirective.prototype, "contextMenuTrigger", void 0);
|
297
|
+
__decorate([
|
298
|
+
Input()
|
299
|
+
], ContextMenuTriggerDirective.prototype, "menuContext", void 0);
|
300
|
+
__decorate([
|
301
|
+
Input()
|
302
|
+
], ContextMenuTriggerDirective.prototype, "holdToDisplay", void 0);
|
303
|
+
__decorate([
|
304
|
+
Output()
|
305
|
+
], ContextMenuTriggerDirective.prototype, "menuAction", void 0);
|
306
|
+
__decorate([
|
307
|
+
Output()
|
308
|
+
], ContextMenuTriggerDirective.prototype, "menuClose", void 0);
|
309
|
+
__decorate([
|
310
|
+
Output()
|
311
|
+
], ContextMenuTriggerDirective.prototype, "beforeOpen", void 0);
|
312
|
+
__decorate([
|
313
|
+
HostListener('contextmenu', ['$event'])
|
314
|
+
], ContextMenuTriggerDirective.prototype, "handleMenu", null);
|
315
|
+
__decorate([
|
316
|
+
HostListener('touchstart', ['$event'])
|
317
|
+
], ContextMenuTriggerDirective.prototype, "handleMouseDown", null);
|
318
|
+
__decorate([
|
319
|
+
HostListener('touchend')
|
320
|
+
], ContextMenuTriggerDirective.prototype, "handleMouseUp", null);
|
321
|
+
ContextMenuTriggerDirective = __decorate([
|
322
|
+
Directive({
|
323
|
+
selector: '[contextMenuTrigger]',
|
324
|
+
exportAs: 'contextMenuTrigger',
|
325
|
+
})
|
326
|
+
], ContextMenuTriggerDirective);
|
450
327
|
return ContextMenuTriggerDirective;
|
451
328
|
}());
|
452
329
|
|
453
|
-
/**
|
454
|
-
* @fileoverview added by tsickle
|
455
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
456
|
-
*/
|
457
330
|
var ContextSubmenuTriggerDirective = /** @class */ (function () {
|
458
331
|
function ContextSubmenuTriggerDirective(contextMenuService) {
|
459
332
|
var _this = this;
|
@@ -467,31 +340,15 @@ var ContextSubmenuTriggerDirective = /** @class */ (function () {
|
|
467
340
|
// get current level
|
468
341
|
setTimeout(function () { return (_this.level = _this.contextMenuService.getCurrentLevel()); });
|
469
342
|
}
|
470
|
-
|
471
|
-
|
472
|
-
|
473
|
-
*/
|
474
|
-
ContextSubmenuTriggerDirective.prototype.handleSubMenuClick = /**
|
475
|
-
* @param {?} $event
|
476
|
-
* @return {?}
|
477
|
-
*/
|
478
|
-
function ($event) {
|
479
|
-
event.preventDefault();
|
480
|
-
event.stopPropagation();
|
343
|
+
ContextSubmenuTriggerDirective.prototype.handleSubMenuClick = function ($event) {
|
344
|
+
$event.preventDefault();
|
345
|
+
$event.stopPropagation();
|
481
346
|
clearTimeout(this.opentimer);
|
482
347
|
clearTimeout(this.closetimer);
|
483
348
|
this.menu = this.contextMenuService.show($event, this.contextSubmenuTrigger, this.menuContext, this.menuClose, this.menuAction, true, this.level);
|
484
349
|
this.visible = true;
|
485
350
|
};
|
486
|
-
|
487
|
-
* @param {?} $event
|
488
|
-
* @return {?}
|
489
|
-
*/
|
490
|
-
ContextSubmenuTriggerDirective.prototype.handleSubMenuEnter = /**
|
491
|
-
* @param {?} $event
|
492
|
-
* @return {?}
|
493
|
-
*/
|
494
|
-
function ($event) {
|
351
|
+
ContextSubmenuTriggerDirective.prototype.handleSubMenuEnter = function ($event) {
|
495
352
|
var _this = this;
|
496
353
|
if (this.menu) {
|
497
354
|
this.menu.isTriggerHovered.next(true);
|
@@ -506,15 +363,7 @@ var ContextSubmenuTriggerDirective = /** @class */ (function () {
|
|
506
363
|
/**
|
507
364
|
* submenu hides after cursor has exited for a period of time
|
508
365
|
*/
|
509
|
-
|
510
|
-
* submenu hides after cursor has exited for a period of time
|
511
|
-
* @return {?}
|
512
|
-
*/
|
513
|
-
ContextSubmenuTriggerDirective.prototype.handleSubMenuExit = /**
|
514
|
-
* submenu hides after cursor has exited for a period of time
|
515
|
-
* @return {?}
|
516
|
-
*/
|
517
|
-
function () {
|
366
|
+
ContextSubmenuTriggerDirective.prototype.handleSubMenuExit = function () {
|
518
367
|
var _this = this;
|
519
368
|
clearTimeout(this.opentimer);
|
520
369
|
if (this.menu) {
|
@@ -532,77 +381,64 @@ var ContextSubmenuTriggerDirective = /** @class */ (function () {
|
|
532
381
|
/**
|
533
382
|
* if overwritten make sure to clear timeouts
|
534
383
|
*/
|
535
|
-
|
536
|
-
* if overwritten make sure to clear timeouts
|
537
|
-
* @return {?}
|
538
|
-
*/
|
539
|
-
ContextSubmenuTriggerDirective.prototype.ngOnDestroy = /**
|
540
|
-
* if overwritten make sure to clear timeouts
|
541
|
-
* @return {?}
|
542
|
-
*/
|
543
|
-
function () {
|
384
|
+
ContextSubmenuTriggerDirective.prototype.ngOnDestroy = function () {
|
544
385
|
clearTimeout(this.opentimer);
|
545
386
|
clearTimeout(this.closetimer);
|
546
387
|
};
|
547
|
-
ContextSubmenuTriggerDirective.decorators = [
|
548
|
-
{ type: Directive, args: [{ selector: '[contextSubmenuTrigger]' },] }
|
549
|
-
];
|
550
|
-
/** @nocollapse */
|
551
388
|
ContextSubmenuTriggerDirective.ctorParameters = function () { return [
|
552
389
|
{ type: ContextMenuService }
|
553
390
|
]; };
|
554
|
-
|
555
|
-
|
556
|
-
|
557
|
-
|
558
|
-
|
559
|
-
|
560
|
-
|
561
|
-
|
562
|
-
|
563
|
-
|
564
|
-
|
391
|
+
__decorate([
|
392
|
+
Input()
|
393
|
+
], ContextSubmenuTriggerDirective.prototype, "hoverDelay", void 0);
|
394
|
+
__decorate([
|
395
|
+
Input()
|
396
|
+
], ContextSubmenuTriggerDirective.prototype, "openDelay", void 0);
|
397
|
+
__decorate([
|
398
|
+
Input()
|
399
|
+
], ContextSubmenuTriggerDirective.prototype, "contextSubmenuTrigger", void 0);
|
400
|
+
__decorate([
|
401
|
+
Input()
|
402
|
+
], ContextSubmenuTriggerDirective.prototype, "menuContext", void 0);
|
403
|
+
__decorate([
|
404
|
+
Output()
|
405
|
+
], ContextSubmenuTriggerDirective.prototype, "menuAction", void 0);
|
406
|
+
__decorate([
|
407
|
+
Output()
|
408
|
+
], ContextSubmenuTriggerDirective.prototype, "menuClose", void 0);
|
409
|
+
__decorate([
|
410
|
+
HostListener('click', ['$event'])
|
411
|
+
], ContextSubmenuTriggerDirective.prototype, "handleSubMenuClick", null);
|
412
|
+
__decorate([
|
413
|
+
HostListener('mouseover', ['$event'])
|
414
|
+
], ContextSubmenuTriggerDirective.prototype, "handleSubMenuEnter", null);
|
415
|
+
__decorate([
|
416
|
+
HostListener('mouseout')
|
417
|
+
], ContextSubmenuTriggerDirective.prototype, "handleSubMenuExit", null);
|
418
|
+
ContextSubmenuTriggerDirective = __decorate([
|
419
|
+
Directive({ selector: '[contextSubmenuTrigger]' })
|
420
|
+
], ContextSubmenuTriggerDirective);
|
565
421
|
return ContextSubmenuTriggerDirective;
|
566
422
|
}());
|
567
423
|
|
568
|
-
/**
|
569
|
-
* @fileoverview added by tsickle
|
570
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
571
|
-
*/
|
572
424
|
var MenuComponent = /** @class */ (function () {
|
573
425
|
function MenuComponent(menuPackage, contextMenuService) {
|
574
426
|
this.menuPackage = menuPackage;
|
575
427
|
this.contextMenuService = contextMenuService;
|
576
|
-
/**
|
577
|
-
* State of the dialog animation.
|
578
|
-
*/
|
428
|
+
/** State of the dialog animation. */
|
579
429
|
this._state = 'enter';
|
580
430
|
this._animationDone = new Subject();
|
581
|
-
/**
|
582
|
-
* set lazy to False if you do not have animations
|
583
|
-
*/
|
431
|
+
/** set lazy to False if you do not have animations */
|
584
432
|
this.lazy = true;
|
585
433
|
}
|
586
|
-
|
587
|
-
* @return {?}
|
588
|
-
*/
|
589
|
-
MenuComponent.prototype.handleMouseover = /**
|
590
|
-
* @return {?}
|
591
|
-
*/
|
592
|
-
function () {
|
434
|
+
MenuComponent.prototype.handleMouseover = function () {
|
593
435
|
if (!this.menuPackage.menu.submenu) {
|
594
436
|
return;
|
595
437
|
}
|
596
438
|
this.menuPackage.menu.isMenuHovered.next(true);
|
597
439
|
clearTimeout(this.closetimer);
|
598
440
|
};
|
599
|
-
|
600
|
-
* @return {?}
|
601
|
-
*/
|
602
|
-
MenuComponent.prototype.handleMouseleave = /**
|
603
|
-
* @return {?}
|
604
|
-
*/
|
605
|
-
function () {
|
441
|
+
MenuComponent.prototype.handleMouseleave = function () {
|
606
442
|
var _this = this;
|
607
443
|
if (!this.menuPackage.menu.submenu) {
|
608
444
|
return;
|
@@ -612,81 +448,58 @@ var MenuComponent = /** @class */ (function () {
|
|
612
448
|
_this.contextMenuService.closeSubMenu(_this.menuPackage.menu.id);
|
613
449
|
}, 500);
|
614
450
|
};
|
615
|
-
|
616
|
-
* @param {?} $event
|
617
|
-
* @return {?}
|
618
|
-
*/
|
619
|
-
MenuComponent.prototype.handleWindowClick = /**
|
620
|
-
* @param {?} $event
|
621
|
-
* @return {?}
|
622
|
-
*/
|
623
|
-
function ($event) {
|
451
|
+
MenuComponent.prototype.handleWindowClick = function ($event) {
|
624
452
|
this.contextMenuService.checkOutsideClick($event);
|
625
453
|
};
|
626
454
|
/** Callback that is invoked when the menu animation completes. */
|
627
|
-
|
628
|
-
* Callback that is invoked when the menu animation completes.
|
629
|
-
* @param {?} event
|
630
|
-
* @return {?}
|
631
|
-
*/
|
632
|
-
MenuComponent.prototype._onAnimationDone = /**
|
633
|
-
* Callback that is invoked when the menu animation completes.
|
634
|
-
* @param {?} event
|
635
|
-
* @return {?}
|
636
|
-
*/
|
637
|
-
function (event) {
|
455
|
+
MenuComponent.prototype._onAnimationDone = function (event) {
|
638
456
|
this._animationDone.next(event);
|
639
457
|
};
|
640
|
-
MenuComponent.decorators = [
|
641
|
-
{ type: Component, args: [{
|
642
|
-
selector: 'app-menu',
|
643
|
-
template: ""
|
644
|
-
}] }
|
645
|
-
];
|
646
|
-
/** @nocollapse */
|
647
458
|
MenuComponent.ctorParameters = function () { return [
|
648
459
|
{ type: MenuPackage },
|
649
460
|
{ type: ContextMenuService }
|
650
461
|
]; };
|
651
|
-
|
652
|
-
|
653
|
-
|
654
|
-
|
655
|
-
|
462
|
+
__decorate([
|
463
|
+
HostListener('mouseover')
|
464
|
+
], MenuComponent.prototype, "handleMouseover", null);
|
465
|
+
__decorate([
|
466
|
+
HostListener('mouseleave')
|
467
|
+
], MenuComponent.prototype, "handleMouseleave", null);
|
468
|
+
__decorate([
|
469
|
+
HostListener('document:click', ['$event'])
|
470
|
+
], MenuComponent.prototype, "handleWindowClick", null);
|
471
|
+
__decorate([
|
472
|
+
HostListener('@menu.done', ['$event'])
|
473
|
+
], MenuComponent.prototype, "_onAnimationDone", null);
|
474
|
+
MenuComponent = __decorate([
|
475
|
+
Component({
|
476
|
+
selector: 'app-menu',
|
477
|
+
template: ""
|
478
|
+
})
|
479
|
+
], MenuComponent);
|
656
480
|
return MenuComponent;
|
657
481
|
}());
|
658
482
|
|
659
|
-
/**
|
660
|
-
* @fileoverview added by tsickle
|
661
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
662
|
-
*/
|
663
483
|
var ContextMenuModule = /** @class */ (function () {
|
664
484
|
function ContextMenuModule() {
|
665
485
|
}
|
666
|
-
ContextMenuModule
|
667
|
-
|
668
|
-
|
669
|
-
|
670
|
-
|
671
|
-
|
672
|
-
|
673
|
-
|
674
|
-
|
675
|
-
|
676
|
-
];
|
486
|
+
ContextMenuModule = __decorate([
|
487
|
+
NgModule({
|
488
|
+
declarations: [
|
489
|
+
ContextMenuTriggerDirective,
|
490
|
+
ContextSubmenuTriggerDirective,
|
491
|
+
MenuComponent,
|
492
|
+
],
|
493
|
+
exports: [ContextMenuTriggerDirective, ContextSubmenuTriggerDirective],
|
494
|
+
imports: [PortalModule, OverlayModule],
|
495
|
+
})
|
496
|
+
], ContextMenuModule);
|
677
497
|
return ContextMenuModule;
|
678
498
|
}());
|
679
499
|
|
680
500
|
/**
|
681
|
-
*
|
682
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
501
|
+
* Generated bundle index. Do not edit.
|
683
502
|
*/
|
684
503
|
|
685
|
-
|
686
|
-
|
687
|
-
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
688
|
-
*/
|
689
|
-
|
690
|
-
export { ContextMenuModule, MenuPackage, MenuInjector, MenuComponent, ContextSubmenuTriggerDirective, ContextMenuTriggerDirective, ContextMenuService };
|
691
|
-
|
692
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ctrl-ngx-rightclick.js.map","sources":["ng://@ctrl/ngx-rightclick/context-menu-injector.ts","ng://@ctrl/ngx-rightclick/context-menu.service.ts","ng://@ctrl/ngx-rightclick/context-menu-trigger.directive.ts","ng://@ctrl/ngx-rightclick/context-submenu-trigger.directive.ts","ng://@ctrl/ngx-rightclick/menu.component.ts","ng://@ctrl/ngx-rightclick/context-menu.module.ts"],"sourcesContent":["import { Injector, Type, InjectionToken, InjectFlags } from '@angular/core';\n\nimport { ActiveContextMenuSub } from './context-menu.service';\n\nexport class MenuPackage {\n  constructor(public menu: ActiveContextMenuSub, public context: any) {}\n}\n\nexport class MenuInjector implements Injector {\n  _menuContext: MenuPackage;\n  constructor(\n    private _activeContextMenu: ActiveContextMenuSub,\n    private _parentInjector: Injector,\n    private context: any,\n  ) {\n    this._menuContext = new MenuPackage(_activeContextMenu, context);\n  }\n\n  get<T>(token: any, notFoundValue?: T, flags?: InjectFlags): T | MenuPackage {\n    if (token === MenuPackage) {\n      return this._menuContext;\n    }\n    return this._parentInjector.get<T>(token, notFoundValue, flags);\n  }\n}\n","import {\n  Overlay,\n  OverlayRef,\n  ScrollStrategyOptions,\n} from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ElementRef, Injectable, Injector, EventEmitter } from '@angular/core';\n\nimport { BehaviorSubject } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\n\nimport { MenuInjector } from './context-menu-injector';\n\nexport interface ActiveContextMenuSub {\n  id: number;\n  isTriggerHovered: BehaviorSubject<boolean>;\n  isMenuHovered: BehaviorSubject<boolean>;\n  submenu: boolean;\n}\nexport interface ActiveContextMenu extends ActiveContextMenuSub {\n  overlayRef: OverlayRef;\n  component: any;\n  menuClose: EventEmitter<void>;\n  menuAction: EventEmitter<any>;\n}\n\n@Injectable({ providedIn: 'root' })\nexport class ContextMenuService {\n  menus: ActiveContextMenu[] = [];\n  id = 0;\n\n  constructor(\n    private overlay: Overlay,\n    private scrollStrategy: ScrollStrategyOptions,\n    private _injector: Injector,\n  ) {}\n\n  /**\n   *\n   * @param $event triggering event\n   * @param menuComponent the component to be shown\n   * @param submenu is a menu within a menu\n   * @param level if submenu, what level\n   */\n  show(\n    $event: MouseEvent,\n    menuComponent,\n    context: any,\n    menuClose: EventEmitter<any>,\n    menuAction: EventEmitter<any>,\n    submenu = false,\n    level?: number,\n  ): ActiveContextMenu {\n    let target: any;\n    if (!submenu) {\n      this.closeAll();\n      target = {\n        getBoundingClientRect: (): ClientRect => ({\n          bottom: $event.clientY,\n          height: 0,\n          left: $event.clientX,\n          right: $event.clientX,\n          top: $event.clientY,\n          width: 0,\n        }),\n      };\n    } else {\n      // close other submenus\n      this.closeAll(undefined, level);\n      target = $event.target;\n    }\n    const el = new ElementRef(target);\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(el)\n      .withFlexibleDimensions(false);\n\n    if (!submenu) {\n      positionStrategy.withPositions([\n        {\n          originX: 'start',\n          originY: 'bottom',\n          overlayX: 'start',\n          overlayY: 'top',\n        },\n        {\n          originX: 'start',\n          originY: 'top',\n          overlayX: 'start',\n          overlayY: 'bottom',\n        },\n        {\n          originX: 'end',\n          originY: 'top',\n          overlayX: 'start',\n          overlayY: 'top',\n        },\n        {\n          originX: 'start',\n          originY: 'top',\n          overlayX: 'end',\n          overlayY: 'top',\n        },\n        {\n          originX: 'end',\n          originY: 'center',\n          overlayX: 'start',\n          overlayY: 'center',\n        },\n        {\n          originX: 'start',\n          originY: 'center',\n          overlayX: 'end',\n          overlayY: 'center',\n        },\n      ]);\n    } else {\n      positionStrategy.withPositions([\n        {\n          originX: 'end',\n          originY: 'top',\n          overlayX: 'start',\n          overlayY: 'top',\n        },\n        {\n          originX: 'start',\n          originY: 'top',\n          overlayX: 'end',\n          overlayY: 'top',\n        },\n        {\n          originX: 'end',\n          originY: 'bottom',\n          overlayX: 'start',\n          overlayY: 'bottom',\n        },\n        {\n          originX: 'start',\n          originY: 'bottom',\n          overlayX: 'end',\n          overlayY: 'bottom',\n        },\n      ]);\n    }\n    const t: ActiveContextMenuSub = {\n      submenu,\n      id: this.id++,\n      isMenuHovered: new BehaviorSubject(false),\n      isTriggerHovered: new BehaviorSubject(false),\n    };\n    const menuInjector = new MenuInjector(t, this._injector, context);\n    const componentPortal = new ComponentPortal(\n      menuComponent,\n      undefined,\n      menuInjector,\n    );\n    const overlayRef = this.overlay.create({\n      positionStrategy,\n      panelClass: 'ngx-contextmenu',\n      scrollStrategy: this.scrollStrategy.close(),\n    });\n    const component = overlayRef.attach<any>(componentPortal);\n    const res = { overlayRef, component, ...t, menuClose, menuAction };\n    this.menus.push(res);\n    return res;\n  }\n  getCurrentLevel() {\n    return this.menus.length;\n  }\n  closeAll(context?: any, idx = 0) {\n    for (let index = idx; index < this.menus.length; index++) {\n      const menu = this.menus[index];\n      this.destroyMenu(menu, context);\n    }\n    this.menus.splice(idx, this.menus.length);\n  }\n  destroyMenu(menu: ActiveContextMenu, context?: any) {\n    menu.component.instance._state = 'exit';\n    if (menu.component.instance.lazy) {\n      menu.component.instance._animationDone\n        .pipe(\n          filter((event: any) => event.toState === 'exit'),\n          take(1),\n        )\n        .subscribe(() => {\n          menu.overlayRef.detach();\n          menu.overlayRef.dispose();\n        });\n    } else {\n      menu.overlayRef.detach();\n      menu.overlayRef.dispose();\n    }\n    if (context) {\n      menu.menuAction.next(context);\n    }\n    menu.menuClose.next();\n  }\n  close(menu: ActiveContextMenu, menuIndex: number, context?: any) {\n    this.destroyMenu(menu, context);\n    this.menus.splice(menuIndex, 1);\n  }\n  checkOutsideClick($event: MouseEvent) {\n    for (const m of this.menus) {\n      const clickedInside = m.component.location.nativeElement.contains(\n        $event.target,\n      );\n      if (clickedInside) {\n        $event.preventDefault();\n        $event.stopPropagation();\n        return;\n      }\n    }\n    this.closeAll();\n  }\n  closeSubMenu(id: number): void {\n    const menuIndex = this.menus.findIndex(n => n.id === id);\n    if (menuIndex === -1 || menuIndex !== this.menus.length - 1) {\n      return;\n    }\n    // make sure we can close the current menu\n    const menu = this.menus[menuIndex];\n    if (menu.isMenuHovered.getValue() || menu.isTriggerHovered.getValue()) {\n      return;\n    }\n    // close all menus up if possible\n    for (let index = this.menus.length - 1; index >= 1; index--) {\n      const m = this.menus[index];\n      if (!m.isMenuHovered.getValue() && !m.isTriggerHovered.getValue()) {\n        this.close(m, index);\n      } else {\n        return;\n      }\n    }\n  }\n}\n","import {\n  Directive,\n  HostListener,\n  Input,\n  Output,\n  EventEmitter,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\n\nimport { Subscription } from 'rxjs';\n\nimport { ContextMenuService, ActiveContextMenu } from './context-menu.service';\n\n@Directive({\n  selector: '[contextMenuTrigger]',\n  exportAs: 'contextMenuTrigger',\n})\nexport class ContextMenuTriggerDirective implements OnDestroy, OnInit {\n  @Input() contextMenuTrigger: any;\n  @Input() menuContext: any;\n  @Input() holdToDisplay = 1000;\n  @Output() menuAction = new EventEmitter<any>();\n  @Output() menuClose = new EventEmitter<void>();\n  menu: ActiveContextMenu;\n  visible = false;\n  private mouseDownTimeoutId: any;\n  private sub: Subscription;\n\n  @HostListener('contextmenu', ['$event'])\n  handleMenu($event: MouseEvent) {\n    $event.preventDefault();\n    this.menu = this.contextMenuService.show(\n      $event,\n      this.contextMenuTrigger,\n      this.menuContext,\n      this.menuClose,\n      this.menuAction,\n    );\n    this.visible = true;\n  }\n\n  @HostListener('touchstart', ['$event'])\n  handleMouseDown($event: any) {\n    if (this.holdToDisplay >= 0) {\n      $event.stopPropagation();\n      $event.clientY = $event.touches[0].clientY;\n      $event.clientX = $event.touches[0].clientX;\n\n      this.mouseDownTimeoutId = setTimeout(\n        () => this.handleMenu($event),\n        this.holdToDisplay,\n      );\n    }\n  }\n\n  @HostListener('touchend')\n  handleMouseUp() {\n    clearTimeout(this.mouseDownTimeoutId);\n  }\n\n  constructor(private contextMenuService: ContextMenuService) {}\n\n  ngOnInit() {\n    this.sub = this.menuClose.subscribe(() => this.visible = false);\n  }\n  ngOnDestroy() {\n    this.sub.unsubscribe();\n  }\n}\n","import {\n  Directive,\n  HostListener,\n  Input,\n  OnDestroy,\n  Output,\n  EventEmitter,\n} from '@angular/core';\n\nimport {\n  ActiveContextMenu,\n  ContextMenuService,\n} from './context-menu.service';\n\n@Directive({ selector: '[contextSubmenuTrigger]' })\nexport class ContextSubmenuTriggerDirective implements OnDestroy {\n  @Input() hoverDelay = 500;\n  @Input() openDelay = 200;\n  @Input() contextSubmenuTrigger: any;\n  @Input() menuContext: any;\n  @Output() menuAction = new EventEmitter<any>();\n  @Output() menuClose = new EventEmitter<void>();\n  menu: ActiveContextMenu;\n  opentimer: any;\n  closetimer: any;\n  visible = false;\n  level = 1;\n\n  @HostListener('click', ['$event', 'true'])\n  handleSubMenuClick($event: MouseEvent) {\n    event.preventDefault();\n    event.stopPropagation();\n    clearTimeout(this.opentimer);\n    clearTimeout(this.closetimer);\n    this.menu = this.contextMenuService.show(\n      $event,\n      this.contextSubmenuTrigger,\n      this.menuContext,\n      this.menuClose,\n      this.menuAction,\n      true,\n      this.level,\n    );\n    this.visible = true;\n  }\n\n  @HostListener('mouseover', ['$event'])\n  handleSubMenuEnter($event: MouseEvent) {\n    if (this.menu) {\n      this.menu.isTriggerHovered.next(true);\n    }\n    clearTimeout(this.closetimer);\n    this.opentimer = setTimeout(() => {\n      this.menu = this.contextMenuService.show(\n        $event,\n        this.contextSubmenuTrigger,\n        this.menuContext,\n        this.menuClose,\n        this.menuAction,\n        true,\n        this.level,\n      );\n      this.visible = true;\n      this.opentimer = null;\n    }, this.openDelay);\n  }\n\n  /**\n   * submenu hides after cursor has exited for a period of time\n   */\n  @HostListener('mouseout', ['$event'])\n  handleSubMenuExit() {\n    clearTimeout(this.opentimer);\n    if (this.menu) {\n      this.menu.isTriggerHovered.next(false);\n    }\n    this.closetimer = setTimeout(() => {\n      if (this.menu) {\n        this.menu.isTriggerHovered.next(false);\n        this.contextMenuService.closeSubMenu(this.menu.id);\n        this.menu = undefined;\n      }\n      this.visible = false;\n    }, this.hoverDelay);\n  }\n\n  constructor(private contextMenuService: ContextMenuService) {\n    // get current level\n    setTimeout(() => (this.level = this.contextMenuService.getCurrentLevel()));\n  }\n\n  /**\n   * if overwritten make sure to clear timeouts\n   */\n  ngOnDestroy() {\n    clearTimeout(this.opentimer);\n    clearTimeout(this.closetimer);\n  }\n}\n","import { Component, HostListener } from '@angular/core';\nimport { AnimationEvent } from '@angular/animations';\n\nimport { ContextMenuService } from './context-menu.service';\nimport { MenuPackage } from './context-menu-injector';\nimport { Subject } from 'rxjs';\n\n@Component({\n  selector: 'app-menu',\n  template: ``,\n})\nexport class MenuComponent {\n  /** State of the dialog animation. */\n  _state: 'void' | 'enter' | 'exit' = 'enter';\n  _animationDone = new Subject<AnimationEvent>();\n  /** set lazy to False if you do not have animations */\n  lazy = true;\n  closetimer: any;\n\n  @HostListener('mouseover')\n  handleMouseover() {\n    if (!this.menuPackage.menu.submenu) {\n      return;\n    }\n    this.menuPackage.menu.isMenuHovered.next(true);\n    clearTimeout(this.closetimer);\n  }\n\n  @HostListener('mouseleave')\n  handleMouseleave() {\n    if (!this.menuPackage.menu.submenu) {\n      return;\n    }\n    this.menuPackage.menu.isMenuHovered.next(false);\n    this.closetimer = setTimeout(() => {\n      this.contextMenuService.closeSubMenu(this.menuPackage.menu.id);\n    }, 500);\n  }\n\n  @HostListener('document:click', ['$event'])\n  handleWindowClick($event: MouseEvent) {\n    this.contextMenuService.checkOutsideClick($event);\n  }\n\n  constructor(\n    public menuPackage: MenuPackage,\n    public contextMenuService: ContextMenuService,\n  ) {}\n\n  /** Callback that is invoked when the menu animation completes. */\n  _onAnimationDone(event: AnimationEvent) {\n    this._animationDone.next(event);\n  }\n}\n","import { NgModule } from '@angular/core';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { PortalModule } from '@angular/cdk/portal';\n\nimport { ContextMenuTriggerDirective } from './context-menu-trigger.directive';\nimport { ContextSubmenuTriggerDirective } from './context-submenu-trigger.directive';\nimport { MenuComponent } from './menu.component';\n\n@NgModule({\n  declarations: [\n    ContextMenuTriggerDirective,\n    ContextSubmenuTriggerDirective,\n    MenuComponent,\n  ],\n  exports: [ContextMenuTriggerDirective, ContextSubmenuTriggerDirective],\n  imports: [PortalModule, OverlayModule],\n})\nexport class ContextMenuModule {}\n"],"names":["tslib_1.__values"],"mappings":"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"}
|
504
|
+
export { ContextMenuModule, ContextMenuService, ContextMenuTriggerDirective, ContextSubmenuTriggerDirective, MenuComponent, MenuInjector, MenuPackage };
|
505
|
+
//# sourceMappingURL=ctrl-ngx-rightclick.js.map
|