@tilde-nlp/ngx-menu 4.1.10 → 5.0.2
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/esm2022/lib/assets/menu-logo.svg.mjs +1 -1
- package/esm2022/lib/components/menu-columns/menu-columns.component.mjs +103 -72
- package/esm2022/lib/components/menu-icon/menu-icon.component.mjs +53 -23
- package/esm2022/lib/components/menu-item-icon/menu-item-icon.component.mjs +115 -71
- package/esm2022/lib/components/menu-item-icon/menu.model.mjs +3 -3
- package/esm2022/lib/components/menu-item-icon/models/menu-dialog-settings.model.mjs +1 -1
- package/esm2022/lib/components/menu-item-icon/models/menu-item-settings.model.mjs +1 -1
- package/esm2022/lib/components/menu-item-icon/models/menu-title-placement.model.mjs +6 -6
- package/esm2022/lib/components/menu-item-link/menu-item-link.component.mjs +91 -53
- package/esm2022/lib/components/menu-item-list/menu-item-list.component.mjs +178 -61
- package/esm2022/lib/components/modal-nav-menu/modal-nav-menu.component.mjs +82 -36
- package/esm2022/lib/components/nav-base/models/index.mjs +1 -1
- package/esm2022/lib/components/nav-base/models/strapi-data-location.enum.mjs +6 -6
- package/esm2022/lib/components/nav-base/nav-base.component.mjs +37 -32
- package/esm2022/lib/components/side-nav-menu/index.mjs +2 -2
- package/esm2022/lib/components/side-nav-menu/models/index.mjs +1 -1
- package/esm2022/lib/components/side-nav-menu/models/side-nav-settings.model.mjs +1 -1
- package/esm2022/lib/components/side-nav-menu/side-nav-menu.component.mjs +130 -93
- package/esm2022/lib/injection-tokens/index.mjs +1 -1
- package/esm2022/lib/injection-tokens/menu-shared-config.token.mjs +1 -1
- package/esm2022/lib/menu.module.mjs +114 -113
- package/esm2022/lib/models/active-menu-item-config.model.mjs +1 -1
- package/esm2022/lib/models/active-menu-items.model.mjs +1 -1
- package/esm2022/lib/models/custom-menu-item.mjs +1 -1
- package/esm2022/lib/models/index.mjs +7 -7
- package/esm2022/lib/models/menu-icon-strapi-extension.const.mjs +1 -1
- package/esm2022/lib/models/menu-item-group.model.mjs +1 -1
- package/esm2022/lib/models/menu-layout-direction.model.mjs +5 -5
- package/esm2022/lib/models/menu-shared-config.model.mjs +1 -1
- package/esm2022/lib/services/index.mjs +2 -2
- package/esm2022/lib/services/menu-items.service.mjs +125 -125
- package/esm2022/lib/services/strapi.service.mjs +93 -93
- package/esm2022/public-api.mjs +15 -15
- package/esm2022/tilde-nlp-ngx-menu.mjs +4 -4
- package/fesm2022/tilde-nlp-ngx-menu.mjs +1016 -667
- package/fesm2022/tilde-nlp-ngx-menu.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/assets/menu-logo.svg.d.ts +1 -1
- package/lib/components/menu-columns/menu-columns.component.d.ts +28 -28
- package/lib/components/menu-icon/menu-icon.component.d.ts +10 -10
- package/lib/components/menu-item-icon/menu-item-icon.component.d.ts +28 -28
- package/lib/components/menu-item-icon/menu.model.d.ts +3 -3
- package/lib/components/menu-item-icon/models/menu-dialog-settings.model.d.ts +8 -8
- package/lib/components/menu-item-icon/models/menu-item-settings.model.d.ts +6 -6
- package/lib/components/menu-item-icon/models/menu-title-placement.model.d.ts +5 -5
- package/lib/components/menu-item-link/menu-item-link.component.d.ts +25 -25
- package/lib/components/menu-item-list/menu-item-list.component.d.ts +21 -21
- package/lib/components/modal-nav-menu/modal-nav-menu.component.d.ts +14 -14
- package/lib/components/nav-base/models/index.d.ts +1 -1
- package/lib/components/nav-base/models/strapi-data-location.enum.d.ts +5 -5
- package/lib/components/nav-base/nav-base.component.d.ts +19 -19
- package/lib/components/side-nav-menu/index.d.ts +2 -2
- package/lib/components/side-nav-menu/models/index.d.ts +1 -1
- package/lib/components/side-nav-menu/models/side-nav-settings.model.d.ts +7 -7
- package/lib/components/side-nav-menu/side-nav-menu.component.d.ts +33 -33
- package/lib/injection-tokens/index.d.ts +1 -1
- package/lib/injection-tokens/menu-shared-config.token.d.ts +1 -1
- package/lib/menu.module.d.ts +29 -29
- package/lib/models/active-menu-item-config.model.d.ts +4 -4
- package/lib/models/active-menu-items.model.d.ts +6 -6
- package/lib/models/custom-menu-item.d.ts +21 -21
- package/lib/models/index.d.ts +7 -7
- package/lib/models/menu-icon-strapi-extension.const.d.ts +1 -1
- package/lib/models/menu-item-group.model.d.ts +9 -9
- package/lib/models/menu-layout-direction.model.d.ts +4 -4
- package/lib/models/menu-shared-config.model.d.ts +21 -21
- package/lib/services/index.d.ts +2 -2
- package/lib/services/menu-items.service.d.ts +38 -38
- package/lib/services/strapi.service.d.ts +20 -20
- package/package.json +12 -9
- package/public-api.d.ts +12 -12
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
export var TitlePlacement;
|
|
2
|
-
(function (TitlePlacement) {
|
|
3
|
-
TitlePlacement["none"] = "none";
|
|
4
|
-
TitlePlacement["left"] = "left";
|
|
5
|
-
TitlePlacement["right"] = "right";
|
|
6
|
-
})(TitlePlacement || (TitlePlacement = {}));
|
|
1
|
+
export var TitlePlacement;
|
|
2
|
+
(function (TitlePlacement) {
|
|
3
|
+
TitlePlacement["none"] = "none";
|
|
4
|
+
TitlePlacement["left"] = "left";
|
|
5
|
+
TitlePlacement["right"] = "right";
|
|
6
|
+
})(TitlePlacement || (TitlePlacement = {}));
|
|
7
7
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS10aXRsZS1wbGFjZW1lbnQubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL2NvbXBvbmVudHMvbWVudS1pdGVtLWljb24vbW9kZWxzL21lbnUtdGl0bGUtcGxhY2VtZW50Lm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGNBSVg7QUFKRCxXQUFZLGNBQWM7SUFDeEIsK0JBQWEsQ0FBQTtJQUNiLCtCQUFhLENBQUE7SUFDYixpQ0FBZSxDQUFBO0FBQ2pCLENBQUMsRUFKVyxjQUFjLEtBQWQsY0FBYyxRQUl6QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFRpdGxlUGxhY2VtZW50IHtcclxuICBub25lID0gJ25vbmUnLFxyXG4gIGxlZnQgPSAnbGVmdCcsXHJcbiAgcmlnaHQgPSAncmlnaHQnXHJcbn1cclxuIl19
|
|
@@ -1,53 +1,91 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { MenuLayoutDirection } from '../../models';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@tilde-nlp/ngx-strapi";
|
|
5
|
-
import * as i2 from "@
|
|
6
|
-
import * as i3 from "@
|
|
7
|
-
import * as i4 from "@angular/common";
|
|
8
|
-
import * as i5 from "@angular/material/tooltip";
|
|
9
|
-
import * as i6 from "@tilde-nlp/ngx-common";
|
|
10
|
-
import * as i7 from "../menu-icon/menu-icon.component";
|
|
11
|
-
import * as i8 from "@ngx-translate/core";
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { MenuLayoutDirection } from '../../models';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@tilde-nlp/ngx-strapi";
|
|
5
|
+
import * as i2 from "@ngbracket/ngx-layout/flex";
|
|
6
|
+
import * as i3 from "@ngbracket/ngx-layout/extended";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
import * as i5 from "@angular/material/tooltip";
|
|
9
|
+
import * as i6 from "@tilde-nlp/ngx-common";
|
|
10
|
+
import * as i7 from "../menu-icon/menu-icon.component";
|
|
11
|
+
import * as i8 from "@ngx-translate/core";
|
|
12
|
+
function MenuItemLinkComponent_ng_container_3_Template(rf, ctx) { if (rf & 1) {
|
|
13
|
+
i0.ɵɵelementContainerStart(0);
|
|
14
|
+
i0.ɵɵelement(1, "tld-menu-icon", 3);
|
|
15
|
+
i0.ɵɵelementContainerEnd();
|
|
16
|
+
} if (rf & 2) {
|
|
17
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
18
|
+
i0.ɵɵadvance();
|
|
19
|
+
i0.ɵɵproperty("menuItem", ctx_r0.menuItem);
|
|
20
|
+
} }
|
|
21
|
+
function MenuItemLinkComponent_span_4_Template(rf, ctx) { if (rf & 1) {
|
|
22
|
+
i0.ɵɵelementStart(0, "span", 4)(1, "span", 5);
|
|
23
|
+
i0.ɵɵpipe(2, "translate");
|
|
24
|
+
i0.ɵɵtext(3);
|
|
25
|
+
i0.ɵɵpipe(4, "translate");
|
|
26
|
+
i0.ɵɵelementEnd()();
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
29
|
+
i0.ɵɵadvance();
|
|
30
|
+
i0.ɵɵattribute("content", i0.ɵɵpipeBind1(2, 2, ctx_r0.menuItem.title));
|
|
31
|
+
i0.ɵɵadvance(2);
|
|
32
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 4, ctx_r0.menuItem.title), " ");
|
|
33
|
+
} }
|
|
34
|
+
export class MenuItemLinkComponent {
|
|
35
|
+
get menuItemLayout() {
|
|
36
|
+
return this.direction === MenuLayoutDirection.column ? 'column' : 'row';
|
|
37
|
+
}
|
|
38
|
+
get menuLayoutDirection() {
|
|
39
|
+
return (this.direction === MenuLayoutDirection.column || !this.labelsVisible)
|
|
40
|
+
? 'start center' : 'start start';
|
|
41
|
+
}
|
|
42
|
+
constructor(strapiLinkService, placeholderService) {
|
|
43
|
+
this.strapiLinkService = strapiLinkService;
|
|
44
|
+
this.placeholderService = placeholderService;
|
|
45
|
+
this.showIcons = true;
|
|
46
|
+
this.updateTextWithPlaceholders = (textWithReplacedPlaceholders) => this.href = textWithReplacedPlaceholders;
|
|
47
|
+
}
|
|
48
|
+
ngOnInit() {
|
|
49
|
+
this.textWithPlaceholders = this.menuItem.link;
|
|
50
|
+
this.placeholderServiceId = this.placeholderService.register(this);
|
|
51
|
+
}
|
|
52
|
+
linkClick(event, item) {
|
|
53
|
+
this.strapiLinkService.strapiLinkClick(event, item.externalLink);
|
|
54
|
+
}
|
|
55
|
+
ngOnDestroy() {
|
|
56
|
+
this.placeholderService.unregister(this.placeholderServiceId);
|
|
57
|
+
}
|
|
58
|
+
static { this.ɵfac = function MenuItemLinkComponent_Factory(t) { return new (t || MenuItemLinkComponent)(i0.ɵɵdirectiveInject(i1.StrapiLinkService), i0.ɵɵdirectiveInject(i1.StrapiVariablesService)); }; }
|
|
59
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: MenuItemLinkComponent, selectors: [["tld-menu-item-link"]], inputs: { direction: "direction", labelsVisible: "labelsVisible", activeItem: "activeItem", showIcons: "showIcons", menuItem: "menuItem" }, decls: 5, vars: 17, consts: [["matTooltipPosition", "after", "matTooltipClass", "menu-tooltip", "fxLayoutGap", "0.375rem", 1, "text-m", "menu-item", 3, "click", "libPlausibleEvent", "fxLayout", "ngClass.lt-md", "matTooltip", "fxLayoutAlign", "href"], [4, "ngIf"], ["class", "menu-item-title", 4, "ngIf"], [3, "menuItem"], [1, "menu-item-title"], [1, "title-content"]], template: function MenuItemLinkComponent_Template(rf, ctx) { if (rf & 1) {
|
|
60
|
+
i0.ɵɵelementStart(0, "a", 0);
|
|
61
|
+
i0.ɵɵpipe(1, "translate");
|
|
62
|
+
i0.ɵɵpipe(2, "translate");
|
|
63
|
+
i0.ɵɵlistener("click", function MenuItemLinkComponent_Template_a_click_0_listener($event) { return ctx.linkClick($event, ctx.menuItem); });
|
|
64
|
+
i0.ɵɵtemplate(3, MenuItemLinkComponent_ng_container_3_Template, 2, 1, "ng-container", 1)(4, MenuItemLinkComponent_span_4_Template, 5, 6, "span", 2);
|
|
65
|
+
i0.ɵɵelementEnd();
|
|
66
|
+
} if (rf & 2) {
|
|
67
|
+
i0.ɵɵclassProp("text-center", ctx.menuItemLayout === "column")("active-menu-item", ctx.menuItem === ctx.activeItem);
|
|
68
|
+
i0.ɵɵproperty("libPlausibleEvent", ctx.menuItem.plausibleEvent)("fxLayout", ctx.menuItemLayout)("ngClass.lt-md", "mobile")("matTooltip", !ctx.labelsVisible ? i0.ɵɵpipeBind1(1, 13, ctx.menuItem.title) : "")("fxLayoutAlign", ctx.menuLayoutDirection)("href", i0.ɵɵpipeBind1(2, 15, ctx.href), i0.ɵɵsanitizeUrl);
|
|
69
|
+
i0.ɵɵattribute("target", ctx.menuItem.externalLink ? "_blank" : "_self");
|
|
70
|
+
i0.ɵɵadvance(3);
|
|
71
|
+
i0.ɵɵproperty("ngIf", ctx.showIcons && ctx.menuItem.icon);
|
|
72
|
+
i0.ɵɵadvance();
|
|
73
|
+
i0.ɵɵproperty("ngIf", ctx.labelsVisible);
|
|
74
|
+
} }, dependencies: [i2.DefaultLayoutDirective, i2.DefaultLayoutGapDirective, i2.DefaultLayoutAlignDirective, i3.DefaultClassDirective, i4.NgIf, i5.MatTooltip, i6.PlausibleEventDirective, i7.MenuIconComponent, i8.TranslatePipe] }); }
|
|
75
|
+
}
|
|
76
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MenuItemLinkComponent, [{
|
|
77
|
+
type: Component,
|
|
78
|
+
args: [{ selector: 'tld-menu-item-link', template: "<a [libPlausibleEvent]=\"menuItem.plausibleEvent\" [fxLayout]=\"menuItemLayout\"\r\n [ngClass.lt-md]=\"'mobile'\" [class.text-center]=\"menuItemLayout === 'column'\" class=\"text-m menu-item\"\r\n [matTooltip]=\"!labelsVisible ? (menuItem.title | translate) : ''\" matTooltipPosition=\"after\"\r\n [fxLayoutAlign]=\"menuLayoutDirection\" matTooltipClass=\"menu-tooltip\" (click)=\"linkClick($event, menuItem)\"\r\n [href]=\"href | translate\" [attr.target]=\"menuItem.externalLink?'_blank': '_self'\" fxLayoutGap=\"0.375rem\"\r\n [class.active-menu-item]=\"menuItem === activeItem\">\r\n <ng-container *ngIf=\"showIcons && menuItem.icon\">\r\n <tld-menu-icon [menuItem]=\"menuItem\"></tld-menu-icon>\r\n </ng-container>\r\n <span *ngIf=\"labelsVisible\" class=\"menu-item-title\">\r\n <span class=\"title-content\" [attr.content]=\"menuItem.title | translate\">\r\n {{ menuItem.title | translate}}\r\n </span>\r\n </span>\r\n</a>\r\n" }]
|
|
79
|
+
}], () => [{ type: i1.StrapiLinkService }, { type: i1.StrapiVariablesService }], { direction: [{
|
|
80
|
+
type: Input
|
|
81
|
+
}], labelsVisible: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], activeItem: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], showIcons: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], menuItem: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}] }); })();
|
|
90
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MenuItemLinkComponent, { className: "MenuItemLinkComponent", filePath: "lib\\components\\menu-item-link\\menu-item-link.component.ts", lineNumber: 10 }); })();
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1pdGVtLWxpbmsuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL2xpYi9jb21wb25lbnRzL21lbnUtaXRlbS1saW5rL21lbnUtaXRlbS1saW5rLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tZW51L3NyYy9saWIvY29tcG9uZW50cy9tZW51LWl0ZW0tbGluay9tZW51LWl0ZW0tbGluay5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFFcEUsT0FBTyxFQUFrQixtQkFBbUIsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7Ozs7Ozs7Ozs7SUNJakUsNkJBQWlEO0lBQy9DLG1DQUFxRDs7OztJQUF0QyxjQUFxQjtJQUFyQiwwQ0FBcUI7OztJQUdwQyxBQURGLCtCQUFvRCxjQUNzQjs7SUFDdEUsWUFDRjs7SUFDRixBQURFLGlCQUFPLEVBQ0Y7OztJQUh1QixjQUEyQzs7SUFDckUsZUFDRjtJQURFLDRFQUNGOztBREhKLE1BQU0sT0FBTyxxQkFBcUI7SUFXaEMsSUFBSSxjQUFjO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLFNBQVMsS0FBSyxtQkFBbUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQzFFLENBQUM7SUFFRCxJQUFJLG1CQUFtQjtRQUNyQixPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsS0FBSyxtQkFBbUIsQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDO1lBQzNFLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQztJQUNyQyxDQUFDO0lBRUQsWUFBNkIsaUJBQW9DLEVBQzlDLGtCQUEwQztRQURoQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO1FBQzlDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBd0I7UUFqQnBELGNBQVMsR0FBRyxJQUFJLENBQUM7UUE0QjFCLCtCQUEwQixHQUFHLENBQUMsNEJBQW9DLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLEdBQUcsNEJBQTRCLENBQUM7SUFYL0MsQ0FBQztJQUVsRSxRQUFRO1FBQ04sSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQy9DLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3JFLENBQUM7SUFFRCxTQUFTLENBQUMsS0FBaUIsRUFBRSxJQUFvQjtRQUMvQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDbkUsQ0FBQztJQUlELFdBQVc7UUFDVCxJQUFJLENBQUMsa0JBQWtCLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBQ2hFLENBQUM7c0ZBcENVLHFCQUFxQjtvRUFBckIscUJBQXFCO1lDVGxDLDRCQUtxRDs7O1lBRmtCLG1HQUFTLG1DQUEyQixJQUFDO1lBTTFHLEFBSEEsd0ZBQWlELDJEQUdHO1lBS3RELGlCQUFJOztZQVRGLEFBSjJCLDhEQUFpRCxxREFJMUI7WUFEbEQsQUFEQSxBQURBLEFBREEsQUFEK0MsQUFBOUMsK0RBQTZDLGdDQUE0QiwyQkFDaEQsbUZBQ3VDLDBDQUM1QiwyREFDWjs7WUFFVixlQUFnQztZQUFoQyx5REFBZ0M7WUFHeEMsY0FBbUI7WUFBbkIsd0NBQW1COzs7aUZEQWYscUJBQXFCO2NBTGpDLFNBQVM7MkJBQ0Usb0JBQW9CO3VGQUtyQixTQUFTO2tCQUFqQixLQUFLO1lBQ0csYUFBYTtrQkFBckIsS0FBSztZQUNHLFVBQVU7a0JBQWxCLEtBQUs7WUFDRyxTQUFTO2tCQUFqQixLQUFLO1lBQ0csUUFBUTtrQkFBaEIsS0FBSzs7a0ZBTEsscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUGxhY2Vob2xkZXJDb21wb25lbnRCYXNlLCBTdHJhcGlMaW5rU2VydmljZSwgU3RyYXBpVmFyaWFibGVzU2VydmljZSB9IGZyb20gJ0B0aWxkZS1ubHAvbmd4LXN0cmFwaSc7XHJcbmltcG9ydCB7IEN1c3RvbU1lbnVJdGVtLCBNZW51TGF5b3V0RGlyZWN0aW9uIH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndGxkLW1lbnUtaXRlbS1saW5rJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbWVudS1pdGVtLWxpbmsuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL21lbnUtaXRlbS1saW5rLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIE1lbnVJdGVtTGlua0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95LCBQbGFjZWhvbGRlckNvbXBvbmVudEJhc2Uge1xyXG4gIEBJbnB1dCgpIGRpcmVjdGlvbiE6IE1lbnVMYXlvdXREaXJlY3Rpb247XHJcbiAgQElucHV0KCkgbGFiZWxzVmlzaWJsZSE6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgYWN0aXZlSXRlbSE6IEN1c3RvbU1lbnVJdGVtIHwgdW5kZWZpbmVkO1xyXG4gIEBJbnB1dCgpIHNob3dJY29ucyA9IHRydWU7XHJcbiAgQElucHV0KCkgbWVudUl0ZW0hOiBDdXN0b21NZW51SXRlbTtcclxuXHJcbiAgdGV4dFdpdGhQbGFjZWhvbGRlcnMhOiBzdHJpbmc7XHJcbiAgaHJlZiE6IHN0cmluZztcclxuXHJcbiAgcHJpdmF0ZSBwbGFjZWhvbGRlclNlcnZpY2VJZCE6IG51bWJlcjtcclxuICBnZXQgbWVudUl0ZW1MYXlvdXQoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLmRpcmVjdGlvbiA9PT0gTWVudUxheW91dERpcmVjdGlvbi5jb2x1bW4gPyAnY29sdW1uJyA6ICdyb3cnO1xyXG4gIH1cclxuXHJcbiAgZ2V0IG1lbnVMYXlvdXREaXJlY3Rpb24oKTogc3RyaW5nIHtcclxuICAgIHJldHVybiAodGhpcy5kaXJlY3Rpb24gPT09IE1lbnVMYXlvdXREaXJlY3Rpb24uY29sdW1uIHx8ICF0aGlzLmxhYmVsc1Zpc2libGUpXHJcbiAgICAgID8gJ3N0YXJ0IGNlbnRlcicgOiAnc3RhcnQgc3RhcnQnO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBzdHJhcGlMaW5rU2VydmljZTogU3RyYXBpTGlua1NlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IHBsYWNlaG9sZGVyU2VydmljZTogU3RyYXBpVmFyaWFibGVzU2VydmljZSkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy50ZXh0V2l0aFBsYWNlaG9sZGVycyA9IHRoaXMubWVudUl0ZW0ubGluaztcclxuICAgIHRoaXMucGxhY2Vob2xkZXJTZXJ2aWNlSWQgPSB0aGlzLnBsYWNlaG9sZGVyU2VydmljZS5yZWdpc3Rlcih0aGlzKTtcclxuICB9XHJcblxyXG4gIGxpbmtDbGljayhldmVudDogTW91c2VFdmVudCwgaXRlbTogQ3VzdG9tTWVudUl0ZW0pIHtcclxuICAgIHRoaXMuc3RyYXBpTGlua1NlcnZpY2Uuc3RyYXBpTGlua0NsaWNrKGV2ZW50LCBpdGVtLmV4dGVybmFsTGluayk7XHJcbiAgfVxyXG5cclxuICB1cGRhdGVUZXh0V2l0aFBsYWNlaG9sZGVycyA9ICh0ZXh0V2l0aFJlcGxhY2VkUGxhY2Vob2xkZXJzOiBzdHJpbmcpID0+IHRoaXMuaHJlZiA9IHRleHRXaXRoUmVwbGFjZWRQbGFjZWhvbGRlcnM7XHJcblxyXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy5wbGFjZWhvbGRlclNlcnZpY2UudW5yZWdpc3Rlcih0aGlzLnBsYWNlaG9sZGVyU2VydmljZUlkKTtcclxuICB9XHJcbn1cclxuIiwiPGEgW2xpYlBsYXVzaWJsZUV2ZW50XT1cIm1lbnVJdGVtLnBsYXVzaWJsZUV2ZW50XCIgW2Z4TGF5b3V0XT1cIm1lbnVJdGVtTGF5b3V0XCJcclxuICBbbmdDbGFzcy5sdC1tZF09XCInbW9iaWxlJ1wiIFtjbGFzcy50ZXh0LWNlbnRlcl09XCJtZW51SXRlbUxheW91dCA9PT0gJ2NvbHVtbidcIiBjbGFzcz1cInRleHQtbSBtZW51LWl0ZW1cIlxyXG4gIFttYXRUb29sdGlwXT1cIiFsYWJlbHNWaXNpYmxlID8gKG1lbnVJdGVtLnRpdGxlIHwgdHJhbnNsYXRlKSA6ICcnXCIgbWF0VG9vbHRpcFBvc2l0aW9uPVwiYWZ0ZXJcIlxyXG4gIFtmeExheW91dEFsaWduXT1cIm1lbnVMYXlvdXREaXJlY3Rpb25cIiBtYXRUb29sdGlwQ2xhc3M9XCJtZW51LXRvb2x0aXBcIiAoY2xpY2spPVwibGlua0NsaWNrKCRldmVudCwgbWVudUl0ZW0pXCJcclxuICBbaHJlZl09XCJocmVmIHwgdHJhbnNsYXRlXCIgW2F0dHIudGFyZ2V0XT1cIm1lbnVJdGVtLmV4dGVybmFsTGluaz8nX2JsYW5rJzogJ19zZWxmJ1wiIGZ4TGF5b3V0R2FwPVwiMC4zNzVyZW1cIlxyXG4gIFtjbGFzcy5hY3RpdmUtbWVudS1pdGVtXT1cIm1lbnVJdGVtID09PSBhY3RpdmVJdGVtXCI+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInNob3dJY29ucyAmJiBtZW51SXRlbS5pY29uXCI+XHJcbiAgICA8dGxkLW1lbnUtaWNvbiBbbWVudUl0ZW1dPVwibWVudUl0ZW1cIj48L3RsZC1tZW51LWljb24+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbiAgPHNwYW4gKm5nSWY9XCJsYWJlbHNWaXNpYmxlXCIgY2xhc3M9XCJtZW51LWl0ZW0tdGl0bGVcIj5cclxuICAgIDxzcGFuIGNsYXNzPVwidGl0bGUtY29udGVudFwiIFthdHRyLmNvbnRlbnRdPVwibWVudUl0ZW0udGl0bGUgfCB0cmFuc2xhdGVcIj5cclxuICAgICAge3sgbWVudUl0ZW0udGl0bGUgfCB0cmFuc2xhdGV9fVxyXG4gICAgPC9zcGFuPlxyXG4gIDwvc3Bhbj5cclxuPC9hPlxyXG4iXX0=
|
|
@@ -1,61 +1,178 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { MenuLayoutDirection } from '../../models/menu-layout-direction.model';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@
|
|
5
|
-
import * as i2 from "@
|
|
6
|
-
import * as i3 from "@angular/common";
|
|
7
|
-
import * as i4 from "@angular/material/tooltip";
|
|
8
|
-
import * as i5 from "../menu-icon/menu-icon.component";
|
|
9
|
-
import * as i6 from "../menu-item-link/menu-item-link.component";
|
|
10
|
-
import * as i7 from "@ngx-translate/core";
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
i0.ɵɵ
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { MenuLayoutDirection } from '../../models/menu-layout-direction.model';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@ngbracket/ngx-layout/flex";
|
|
5
|
+
import * as i2 from "@ngbracket/ngx-layout/extended";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "@angular/material/tooltip";
|
|
8
|
+
import * as i5 from "../menu-icon/menu-icon.component";
|
|
9
|
+
import * as i6 from "../menu-item-link/menu-item-link.component";
|
|
10
|
+
import * as i7 from "@ngx-translate/core";
|
|
11
|
+
const _c0 = a0 => ({ menuItem: a0 });
|
|
12
|
+
function MenuItemListComponent_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
13
|
+
i0.ɵɵelementStart(0, "div", 6);
|
|
14
|
+
i0.ɵɵtext(1);
|
|
15
|
+
i0.ɵɵpipe(2, "translate");
|
|
16
|
+
i0.ɵɵelementEnd();
|
|
17
|
+
} if (rf & 2) {
|
|
18
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
19
|
+
i0.ɵɵadvance();
|
|
20
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, ctx_r0.titleKey), " ");
|
|
21
|
+
} }
|
|
22
|
+
function MenuItemListComponent_ng_container_3_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
+
i0.ɵɵelementContainer(0);
|
|
24
|
+
} }
|
|
25
|
+
function MenuItemListComponent_ng_container_3_Template(rf, ctx) { if (rf & 1) {
|
|
26
|
+
i0.ɵɵelementContainerStart(0);
|
|
27
|
+
i0.ɵɵtemplate(1, MenuItemListComponent_ng_container_3_ng_container_1_Template, 1, 0, "ng-container", 7);
|
|
28
|
+
i0.ɵɵelementContainerEnd();
|
|
29
|
+
} if (rf & 2) {
|
|
30
|
+
const menuItem_r2 = ctx.$implicit;
|
|
31
|
+
i0.ɵɵnextContext();
|
|
32
|
+
const itemWithChildren_r3 = i0.ɵɵreference(5);
|
|
33
|
+
const menuItemLink_r4 = i0.ɵɵreference(7);
|
|
34
|
+
i0.ɵɵadvance();
|
|
35
|
+
i0.ɵɵproperty("ngTemplateOutlet", !menuItem_r2.showChildren || !menuItem_r2.children || (menuItem_r2 == null ? null : menuItem_r2.children == null ? null : menuItem_r2.children.length) === 0 ? menuItemLink_r4 : itemWithChildren_r3)("ngTemplateOutletContext", i0.ɵɵpureFunction1(2, _c0, menuItem_r2));
|
|
36
|
+
} }
|
|
37
|
+
function MenuItemListComponent_ng_template_4_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
38
|
+
i0.ɵɵelementContainerStart(0);
|
|
39
|
+
i0.ɵɵelement(1, "tld-menu-icon", 10);
|
|
40
|
+
i0.ɵɵelementContainerEnd();
|
|
41
|
+
} if (rf & 2) {
|
|
42
|
+
const menuItem_r6 = i0.ɵɵnextContext().menuItem;
|
|
43
|
+
i0.ɵɵadvance();
|
|
44
|
+
i0.ɵɵproperty("menuItem", menuItem_r6);
|
|
45
|
+
} }
|
|
46
|
+
function MenuItemListComponent_ng_template_4_ng_container_3_span_5_Template(rf, ctx) { if (rf & 1) {
|
|
47
|
+
i0.ɵɵelementStart(0, "span", 14);
|
|
48
|
+
i0.ɵɵtext(1);
|
|
49
|
+
i0.ɵɵelementEnd();
|
|
50
|
+
} if (rf & 2) {
|
|
51
|
+
const menuItem_r6 = i0.ɵɵnextContext(2).menuItem;
|
|
52
|
+
i0.ɵɵadvance();
|
|
53
|
+
i0.ɵɵtextInterpolate1(" ", menuItem_r6.expanded ? "arrow_drop_up" : "arrow_drop_down", " ");
|
|
54
|
+
} }
|
|
55
|
+
function MenuItemListComponent_ng_template_4_ng_container_3_Template(rf, ctx) { if (rf & 1) {
|
|
56
|
+
i0.ɵɵelementContainerStart(0);
|
|
57
|
+
i0.ɵɵelementStart(1, "span", 11)(2, "span", 12);
|
|
58
|
+
i0.ɵɵtext(3);
|
|
59
|
+
i0.ɵɵpipe(4, "translate");
|
|
60
|
+
i0.ɵɵelementEnd()();
|
|
61
|
+
i0.ɵɵtemplate(5, MenuItemListComponent_ng_template_4_ng_container_3_span_5_Template, 2, 1, "span", 13);
|
|
62
|
+
i0.ɵɵelementContainerEnd();
|
|
63
|
+
} if (rf & 2) {
|
|
64
|
+
const menuItem_r6 = i0.ɵɵnextContext().menuItem;
|
|
65
|
+
i0.ɵɵadvance(3);
|
|
66
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(4, 2, menuItem_r6.title));
|
|
67
|
+
i0.ɵɵadvance(2);
|
|
68
|
+
i0.ɵɵproperty("ngIf", menuItem_r6.showChildren && menuItem_r6.children);
|
|
69
|
+
} }
|
|
70
|
+
function MenuItemListComponent_ng_template_4_ng_container_4_menu_item_list_1_Template(rf, ctx) { if (rf & 1) {
|
|
71
|
+
i0.ɵɵelement(0, "menu-item-list", 16);
|
|
72
|
+
} if (rf & 2) {
|
|
73
|
+
const menuItem_r6 = i0.ɵɵnextContext(2).menuItem;
|
|
74
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
75
|
+
i0.ɵɵproperty("items", menuItem_r6.children)("direction", ctx_r0.direction)("labelsVisible", ctx_r0.labelsVisible)("activeItem", ctx_r0.activeItem);
|
|
76
|
+
} }
|
|
77
|
+
function MenuItemListComponent_ng_template_4_ng_container_4_Template(rf, ctx) { if (rf & 1) {
|
|
78
|
+
i0.ɵɵelementContainerStart(0);
|
|
79
|
+
i0.ɵɵtemplate(1, MenuItemListComponent_ng_template_4_ng_container_4_menu_item_list_1_Template, 1, 4, "menu-item-list", 15);
|
|
80
|
+
i0.ɵɵelementContainerEnd();
|
|
81
|
+
} if (rf & 2) {
|
|
82
|
+
const menuItem_r6 = i0.ɵɵnextContext().menuItem;
|
|
83
|
+
i0.ɵɵadvance();
|
|
84
|
+
i0.ɵɵproperty("ngIf", menuItem_r6.children && menuItem_r6.children.length);
|
|
85
|
+
} }
|
|
86
|
+
function MenuItemListComponent_ng_template_4_Template(rf, ctx) { if (rf & 1) {
|
|
87
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
88
|
+
i0.ɵɵelementStart(0, "button", 8);
|
|
89
|
+
i0.ɵɵpipe(1, "translate");
|
|
90
|
+
i0.ɵɵlistener("click", function MenuItemListComponent_ng_template_4_Template_button_click_0_listener($event) { const menuItem_r6 = i0.ɵɵrestoreView(_r5).menuItem; const ctx_r0 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r0.toggleItemExpand($event, menuItem_r6)); });
|
|
91
|
+
i0.ɵɵtemplate(2, MenuItemListComponent_ng_template_4_ng_container_2_Template, 2, 1, "ng-container", 9)(3, MenuItemListComponent_ng_template_4_ng_container_3_Template, 6, 4, "ng-container", 9);
|
|
92
|
+
i0.ɵɵelementEnd();
|
|
93
|
+
i0.ɵɵtemplate(4, MenuItemListComponent_ng_template_4_ng_container_4_Template, 2, 1, "ng-container", 9);
|
|
94
|
+
} if (rf & 2) {
|
|
95
|
+
const menuItem_r6 = ctx.menuItem;
|
|
96
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
97
|
+
i0.ɵɵclassProp("text-center", ctx_r0.menuItemLayout === "column")("menu-labels-visible", ctx_r0.labelsVisible)("active-menu-item", (ctx_r0.activeItem == null ? null : ctx_r0.activeItem.link) && menuItem_r6 === ctx_r0.activeItem);
|
|
98
|
+
i0.ɵɵproperty("fxLayout", ctx_r0.menuItemLayout)("matTooltip", !ctx_r0.labelsVisible ? i0.ɵɵpipeBind1(1, 12, menuItem_r6.title) : "")("fxLayoutAlign", ctx_r0.menuLayoutDirection);
|
|
99
|
+
i0.ɵɵadvance(2);
|
|
100
|
+
i0.ɵɵproperty("ngIf", ctx_r0.showIcons && menuItem_r6.icon);
|
|
101
|
+
i0.ɵɵadvance();
|
|
102
|
+
i0.ɵɵproperty("ngIf", ctx_r0.labelsVisible);
|
|
103
|
+
i0.ɵɵadvance();
|
|
104
|
+
i0.ɵɵproperty("ngIf", menuItem_r6.showChildren && menuItem_r6.expanded && ctx_r0.labelsVisible);
|
|
105
|
+
} }
|
|
106
|
+
function MenuItemListComponent_ng_template_6_Template(rf, ctx) { if (rf & 1) {
|
|
107
|
+
i0.ɵɵelement(0, "tld-menu-item-link", 17);
|
|
108
|
+
} if (rf & 2) {
|
|
109
|
+
const menuItem_r7 = ctx.menuItem;
|
|
110
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
111
|
+
i0.ɵɵproperty("ngClass.lt-md", "mob-menu-item")("menuItem", menuItem_r7)("direction", ctx_r0.direction)("labelsVisible", ctx_r0.labelsVisible)("activeItem", ctx_r0.activeItem)("showIcons", ctx_r0.showIcons);
|
|
112
|
+
} }
|
|
113
|
+
export class MenuItemListComponent {
|
|
114
|
+
constructor() {
|
|
115
|
+
this.direction = MenuLayoutDirection.column;
|
|
116
|
+
this.labelsVisible = true;
|
|
117
|
+
this.showIcons = true;
|
|
118
|
+
this.items = [];
|
|
119
|
+
this.toggleExpand = new EventEmitter();
|
|
120
|
+
}
|
|
121
|
+
get titleKey() {
|
|
122
|
+
return this.menuItemGroup?.title;
|
|
123
|
+
}
|
|
124
|
+
get showTitle() {
|
|
125
|
+
return this.menuItemGroup?.showTitle;
|
|
126
|
+
}
|
|
127
|
+
get menuLayoutDirection() {
|
|
128
|
+
return (this.direction === MenuLayoutDirection.column || !this.labelsVisible)
|
|
129
|
+
? 'start center' : 'start start';
|
|
130
|
+
}
|
|
131
|
+
get menuItemLayout() {
|
|
132
|
+
return this.direction === MenuLayoutDirection.column ? 'column' : 'row';
|
|
133
|
+
}
|
|
134
|
+
toggleItemExpand(event, menuItem) {
|
|
135
|
+
// so menu doesnt get closed.
|
|
136
|
+
event.stopPropagation();
|
|
137
|
+
if (this.labelsVisible || !menuItem.expanded) {
|
|
138
|
+
menuItem.expanded = !menuItem.expanded;
|
|
139
|
+
}
|
|
140
|
+
this.toggleExpand.next(menuItem);
|
|
141
|
+
}
|
|
142
|
+
static { this.ɵfac = function MenuItemListComponent_Factory(t) { return new (t || MenuItemListComponent)(); }; }
|
|
143
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: MenuItemListComponent, selectors: [["menu-item-list"]], inputs: { direction: "direction", labelsVisible: "labelsVisible", activeItem: "activeItem", showIcons: "showIcons", items: "items", menuItemGroup: "menuItemGroup" }, outputs: { toggleExpand: "toggleExpand" }, decls: 8, vars: 3, consts: [["itemWithChildren", ""], ["menuItemLink", ""], [1, "menu-list-wrapper"], ["fxLayoutAlign", "start center", "class", "menu-item-list-title", 4, "ngIf"], ["fxLayout", "column", 1, "menu-item-list", 3, "fxLayoutAlign"], [4, "ngFor", "ngForOf"], ["fxLayoutAlign", "start center", 1, "menu-item-list-title"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], ["matTooltipPosition", "after", "matTooltipClass", "menu-tooltip", "fxLayoutGap", "0.375rem", 1, "text-m", "menu-item", 3, "click", "fxLayout", "matTooltip", "fxLayoutAlign"], [4, "ngIf"], [3, "menuItem"], [1, "menu-item-title"], [1, "title-content"], ["class", "material-icons", 4, "ngIf"], [1, "material-icons"], ["class", "child-list", 3, "items", "direction", "labelsVisible", "activeItem", 4, "ngIf"], [1, "child-list", 3, "items", "direction", "labelsVisible", "activeItem"], [3, "ngClass.lt-md", "menuItem", "direction", "labelsVisible", "activeItem", "showIcons"]], template: function MenuItemListComponent_Template(rf, ctx) { if (rf & 1) {
|
|
144
|
+
i0.ɵɵelementStart(0, "div", 2);
|
|
145
|
+
i0.ɵɵtemplate(1, MenuItemListComponent_div_1_Template, 3, 3, "div", 3);
|
|
146
|
+
i0.ɵɵelementStart(2, "div", 4);
|
|
147
|
+
i0.ɵɵtemplate(3, MenuItemListComponent_ng_container_3_Template, 2, 4, "ng-container", 5);
|
|
148
|
+
i0.ɵɵelementEnd()();
|
|
149
|
+
i0.ɵɵtemplate(4, MenuItemListComponent_ng_template_4_Template, 5, 14, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor)(6, MenuItemListComponent_ng_template_6_Template, 1, 6, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
|
|
150
|
+
} if (rf & 2) {
|
|
151
|
+
i0.ɵɵadvance();
|
|
152
|
+
i0.ɵɵproperty("ngIf", ctx.titleKey && ctx.showTitle && ctx.labelsVisible);
|
|
153
|
+
i0.ɵɵadvance();
|
|
154
|
+
i0.ɵɵproperty("fxLayoutAlign", ctx.menuLayoutDirection);
|
|
155
|
+
i0.ɵɵadvance();
|
|
156
|
+
i0.ɵɵproperty("ngForOf", ctx.items);
|
|
157
|
+
} }, dependencies: [i1.DefaultLayoutDirective, i1.DefaultLayoutGapDirective, i1.DefaultLayoutAlignDirective, i2.DefaultClassDirective, i3.NgForOf, i3.NgIf, i3.NgTemplateOutlet, i4.MatTooltip, MenuItemListComponent, i5.MenuIconComponent, i6.MenuItemLinkComponent, i7.TranslatePipe], styles: ["[_nghost-%COMP%]{margin:1em 0;display:inline-block}[_nghost-%COMP%] .menu-list-wrapper .menu-item-list-title{margin-bottom:1em;font-size:1rem;font-weight:500;line-height:1.5rem}[_nghost-%COMP%] .menu-list-wrapper .text-center{text-align:center}[_nghost-%COMP%] .menu-list-wrapper tld-menu-item-link+tld-menu-item-link, [_nghost-%COMP%] .menu-list-wrapper tld-menu-item-link+.menu-item, [_nghost-%COMP%] .menu-list-wrapper .menu-item+tld-menu-item-link, [_nghost-%COMP%] .menu-list-wrapper .menu-item+.menu-item{margin-top:1.5625em}[_nghost-%COMP%] .menu-list-wrapper .child-list tld-menu-item-link{margin-top:1em}[_nghost-%COMP%] .menu-list-wrapper .menu-labels-visible{width:100%}[_nghost-%COMP%] .menu-list-wrapper .menu-item{cursor:pointer;font-style:normal;color:var(--base-30);text-decoration:none;align-items:center!important;font-weight:400;background:none;border:none}[_nghost-%COMP%] .menu-list-wrapper .menu-item:focus-visible{outline:black solid 2px}[_nghost-%COMP%] .menu-list-wrapper .menu-item:not(button):hover{font-weight:600}[_nghost-%COMP%] .menu-list-wrapper .menu-item.active-menu-item, [_nghost-%COMP%] .menu-list-wrapper .menu-item.active-menu-item mat-icon, [_nghost-%COMP%] .menu-list-wrapper .menu-item.active-menu-item:hover{color:var(--primary-accent)!important;font-weight:600}[_nghost-%COMP%] .menu-list-wrapper .menu-item span{display:inline-block}[_nghost-%COMP%] .menu-list-wrapper .menu-item .menu-item-title{display:flex;flex-direction:row;align-items:start;width:100%}[_nghost-%COMP%] .menu-list-wrapper .menu-item .menu-item-title .title-content{display:block}[_nghost-%COMP%] .menu-list-wrapper .menu-item .menu-item-title .title-content:before{display:block;content:attr(content);font-weight:600;height:0;overflow:hidden;visibility:hidden}.child-list[_nghost-%COMP%]{margin-bottom:1rem}.child-list[_nghost-%COMP%] .menu-item[_ngcontent-%COMP%] + .menu-item[_ngcontent-%COMP%]{margin-top:.5rem} .menu-tooltip{left:.625rem;font-family:Roboto;font-style:normal;font-weight:400;font-size:.75rem;line-height:1.25rem;color:var(--base-70);border-radius:.25rem;position:relative} .menu-tooltip:after{width:0;height:0;content:\"\";position:absolute;border-left:.5rem solid transparent;border-right:.5rem solid transparent;border-bottom:.5rem solid var(--menu-border-dark-color);left:-.75rem;top:calc(50% - .25rem);transform:rotate(270deg);overflow:initial}menu-item-list[_ngcontent-%COMP%]{padding-left:30px;margin:0}.mob-menu-item[_ngcontent-%COMP%]{width:100%}"] }); }
|
|
158
|
+
}
|
|
159
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MenuItemListComponent, [{
|
|
160
|
+
type: Component,
|
|
161
|
+
args: [{ selector: 'menu-item-list', template: "<div class=\"menu-list-wrapper\">\r\n <div *ngIf=\"titleKey && showTitle && labelsVisible\" fxLayoutAlign=\"start center\" class=\"menu-item-list-title\">\r\n {{ titleKey | translate }}\r\n </div>\r\n <div fxLayout=\"column\" [fxLayoutAlign]=\"menuLayoutDirection\" class=\"menu-item-list\">\r\n <ng-container *ngFor=\"let menuItem of items\">\r\n <ng-container\r\n *ngTemplateOutlet=\"!menuItem.showChildren || !menuItem.children || menuItem?.children?.length === 0 ? menuItemLink : itemWithChildren; context: {menuItem: menuItem}\">\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n</div>\r\n\r\n<ng-template #itemWithChildren let-menuItem=\"menuItem\">\r\n <button [fxLayout]=\"menuItemLayout\" [class.text-center]=\"menuItemLayout === 'column'\" class=\"text-m menu-item\"\r\n [matTooltip]=\"!labelsVisible ? (menuItem.title | translate) : ''\" matTooltipPosition=\"after\" [class.menu-labels-visible]=\"labelsVisible\"\r\n [fxLayoutAlign]=\"menuLayoutDirection\" matTooltipClass=\"menu-tooltip\" fxLayoutGap=\"0.375rem\"\r\n [class.active-menu-item]=\"activeItem?.link && menuItem === activeItem\" (click)=\"toggleItemExpand($event,menuItem)\">\r\n <ng-container *ngIf=\"showIcons && menuItem.icon\">\r\n <tld-menu-icon [menuItem]=\"menuItem\"></tld-menu-icon>\r\n </ng-container>\r\n <ng-container *ngIf=\"labelsVisible\">\r\n <span class=\"menu-item-title\">\r\n <span class=\"title-content\">{{ menuItem.title | translate }}</span></span>\r\n <span class=\"material-icons\" *ngIf=\"menuItem.showChildren && menuItem.children\">\r\n {{ menuItem.expanded ? 'arrow_drop_up' : 'arrow_drop_down' }}\r\n </span>\r\n </ng-container>\r\n </button>\r\n <ng-container *ngIf=\"menuItem.showChildren && menuItem.expanded && labelsVisible\">\r\n <menu-item-list class=\"child-list\" *ngIf=\"menuItem.children && menuItem.children.length\" [items]=\"menuItem.children\"\r\n [direction]=\"direction\" [labelsVisible]=\"labelsVisible\" [activeItem]=\"activeItem\">\r\n </menu-item-list>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #menuItemLink let-menuItem=\"menuItem\">\r\n <tld-menu-item-link [ngClass.lt-md]=\"'mob-menu-item'\" [menuItem]=\"menuItem\" [direction]=\"direction\" [labelsVisible]=\"labelsVisible\"\r\n [activeItem]=\"activeItem\" [showIcons]=\"showIcons\"></tld-menu-item-link>\r\n</ng-template>", styles: [":host{margin:1em 0;display:inline-block}:host::ng-deep .menu-list-wrapper .menu-item-list-title{margin-bottom:1em;font-size:1rem;font-weight:500;line-height:1.5rem}:host::ng-deep .menu-list-wrapper .text-center{text-align:center}:host::ng-deep .menu-list-wrapper tld-menu-item-link+tld-menu-item-link,:host::ng-deep .menu-list-wrapper tld-menu-item-link+.menu-item,:host::ng-deep .menu-list-wrapper .menu-item+tld-menu-item-link,:host::ng-deep .menu-list-wrapper .menu-item+.menu-item{margin-top:1.5625em}:host::ng-deep .menu-list-wrapper .child-list tld-menu-item-link{margin-top:1em}:host::ng-deep .menu-list-wrapper .menu-labels-visible{width:100%}:host::ng-deep .menu-list-wrapper .menu-item{cursor:pointer;font-style:normal;color:var(--base-30);text-decoration:none;align-items:center!important;font-weight:400;background:none;border:none}:host::ng-deep .menu-list-wrapper .menu-item:focus-visible{outline:black solid 2px}:host::ng-deep .menu-list-wrapper .menu-item:not(button):hover{font-weight:600}:host::ng-deep .menu-list-wrapper .menu-item.active-menu-item,:host::ng-deep .menu-list-wrapper .menu-item.active-menu-item mat-icon,:host::ng-deep .menu-list-wrapper .menu-item.active-menu-item:hover{color:var(--primary-accent)!important;font-weight:600}:host::ng-deep .menu-list-wrapper .menu-item span{display:inline-block}:host::ng-deep .menu-list-wrapper .menu-item .menu-item-title{display:flex;flex-direction:row;align-items:start;width:100%}:host::ng-deep .menu-list-wrapper .menu-item .menu-item-title .title-content{display:block}:host::ng-deep .menu-list-wrapper .menu-item .menu-item-title .title-content:before{display:block;content:attr(content);font-weight:600;height:0;overflow:hidden;visibility:hidden}:host.child-list{margin-bottom:1rem}:host.child-list .menu-item+.menu-item{margin-top:.5rem}::ng-deep .menu-tooltip{left:.625rem;font-family:Roboto;font-style:normal;font-weight:400;font-size:.75rem;line-height:1.25rem;color:var(--base-70);border-radius:.25rem;position:relative}::ng-deep .menu-tooltip:after{width:0;height:0;content:\"\";position:absolute;border-left:.5rem solid transparent;border-right:.5rem solid transparent;border-bottom:.5rem solid var(--menu-border-dark-color);left:-.75rem;top:calc(50% - .25rem);transform:rotate(270deg);overflow:initial}menu-item-list{padding-left:30px;margin:0}.mob-menu-item{width:100%}\n"] }]
|
|
162
|
+
}], null, { direction: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], labelsVisible: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], activeItem: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], showIcons: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], items: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], menuItemGroup: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], toggleExpand: [{
|
|
175
|
+
type: Output
|
|
176
|
+
}] }); })();
|
|
177
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MenuItemListComponent, { className: "MenuItemListComponent", filePath: "lib\\components\\menu-item-list\\menu-item-list.component.ts", lineNumber: 11 }); })();
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-item-list.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-menu/src/lib/components/menu-item-list/menu-item-list.component.ts","../../../../../../projects/ngx-menu/src/lib/components/menu-item-list/menu-item-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { CustomMenuItem } from '../../models/custom-menu-item';\r\nimport { MenuItemGroupBase } from '../../models/menu-item-group.model';\r\nimport { MenuLayoutDirection } from '../../models/menu-layout-direction.model';\r\n\r\n@Component({\r\n  selector: 'menu-item-list',\r\n  templateUrl: './menu-item-list.component.html',\r\n  styleUrls: ['./menu-item-list.component.scss']\r\n})\r\nexport class MenuItemListComponent {\r\n  @Input() direction: MenuLayoutDirection = MenuLayoutDirection.column;\r\n  @Input() labelsVisible = true;\r\n  @Input() activeItem!: CustomMenuItem | undefined;\r\n  @Input() showIcons = true;\r\n\r\n  @Input() items: CustomMenuItem[] = [];\r\n  @Input() menuItemGroup!: MenuItemGroupBase;\r\n\r\n  @Output() toggleExpand: EventEmitter<CustomMenuItem> = new EventEmitter<CustomMenuItem>();\r\n\r\n  get titleKey() {\r\n    return this.menuItemGroup?.title;\r\n  }\r\n\r\n  get showTitle() {\r\n    return this.menuItemGroup?.showTitle;\r\n  }\r\n\r\n\r\n  get menuLayoutDirection(): string {\r\n    return (this.direction === MenuLayoutDirection.column || !this.labelsVisible)\r\n      ? 'start center' : 'start start';\r\n  }\r\n\r\n  get menuItemLayout(): string {\r\n    return this.direction === MenuLayoutDirection.column ? 'column' : 'row';\r\n  }\r\n\r\n  toggleItemExpand(event: MouseEvent, menuItem: CustomMenuItem) {\r\n    // so menu doesnt get closed.\r\n    event.stopPropagation();\r\n\r\n    if (this.labelsVisible || !menuItem.expanded) {\r\n      menuItem.expanded = !menuItem.expanded;\r\n    }\r\n\r\n    this.toggleExpand.next(menuItem);\r\n  }\r\n}\r\n","<div class=\"menu-list-wrapper\">\r\n  <div *ngIf=\"titleKey && showTitle && labelsVisible\" fxLayoutAlign=\"start center\" class=\"menu-item-list-title\">\r\n    {{ titleKey | translate }}\r\n  </div>\r\n  <div fxLayout=\"column\" [fxLayoutAlign]=\"menuLayoutDirection\" class=\"menu-item-list\">\r\n    <ng-container *ngFor=\"let menuItem of items\">\r\n      <ng-container\r\n        *ngTemplateOutlet=\"!menuItem.showChildren || !menuItem.children || menuItem?.children?.length === 0 ? menuItemLink : itemWithChildren; context: {menuItem: menuItem}\">\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #itemWithChildren let-menuItem=\"menuItem\">\r\n  <button [fxLayout]=\"menuItemLayout\" [class.text-center]=\"menuItemLayout === 'column'\" class=\"text-m menu-item\"\r\n    [matTooltip]=\"!labelsVisible ? (menuItem.title | translate) : ''\" matTooltipPosition=\"after\" [class.menu-labels-visible]=\"labelsVisible\"\r\n    [fxLayoutAlign]=\"menuLayoutDirection\" matTooltipClass=\"menu-tooltip\" fxLayoutGap=\"0.375rem\"\r\n    [class.active-menu-item]=\"activeItem?.link && menuItem === activeItem\" (click)=\"toggleItemExpand($event,menuItem)\">\r\n    <ng-container *ngIf=\"showIcons && menuItem.icon\">\r\n      <tld-menu-icon [menuItem]=\"menuItem\"></tld-menu-icon>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"labelsVisible\">\r\n      <span class=\"menu-item-title\">\r\n        <span class=\"title-content\">{{ menuItem.title | translate }}</span></span>\r\n      <span class=\"material-icons\" *ngIf=\"menuItem.showChildren && menuItem.children\">\r\n        {{ menuItem.expanded ? 'arrow_drop_up' : 'arrow_drop_down' }}\r\n      </span>\r\n    </ng-container>\r\n  </button>\r\n  <ng-container *ngIf=\"menuItem.showChildren && menuItem.expanded && labelsVisible\">\r\n    <menu-item-list class=\"child-list\" *ngIf=\"menuItem.children && menuItem.children.length\" [items]=\"menuItem.children\"\r\n      [direction]=\"direction\" [labelsVisible]=\"labelsVisible\" [activeItem]=\"activeItem\">\r\n    </menu-item-list>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #menuItemLink let-menuItem=\"menuItem\">\r\n  <tld-menu-item-link [ngClass.lt-md]=\"'mob-menu-item'\" [menuItem]=\"menuItem\" [direction]=\"direction\" [labelsVisible]=\"labelsVisible\"\r\n    [activeItem]=\"activeItem\" [showIcons]=\"showIcons\"></tld-menu-item-link>\r\n</ng-template>"]}
|