@tilde-nlp/ngx-menu 2.0.4 → 4.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/esm2022/lib/components/menu-columns/menu-columns.component.mjs +163 -0
- package/{esm2020 → esm2022}/lib/components/menu-icon/menu-icon.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/menu-item-icon/menu-item-icon.component.mjs +5 -5
- package/esm2022/lib/components/menu-item-link/menu-item-link.component.mjs +52 -0
- package/{esm2020 → esm2022}/lib/components/menu-item-list/menu-item-list.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/modal-nav-menu/modal-nav-menu.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/nav-base/nav-base.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/side-nav-menu/side-nav-menu.component.mjs +13 -13
- package/{esm2020 → esm2022}/lib/menu.module.mjs +41 -41
- package/{esm2020 → esm2022}/lib/services/strapi.service.mjs +4 -4
- package/{fesm2020 → fesm2022}/tilde-nlp-ngx-menu.mjs +98 -98
- package/{fesm2020 → fesm2022}/tilde-nlp-ngx-menu.mjs.map +1 -1
- package/lib/components/menu-columns/menu-columns.component.d.ts +1 -1
- package/lib/components/menu-icon/menu-icon.component.d.ts +1 -1
- package/lib/components/menu-item-icon/menu-item-icon.component.d.ts +1 -1
- package/lib/components/menu-item-link/menu-item-link.component.d.ts +1 -1
- package/lib/components/menu-item-list/menu-item-list.component.d.ts +1 -1
- package/lib/components/modal-nav-menu/modal-nav-menu.component.d.ts +1 -1
- package/lib/components/nav-base/nav-base.component.d.ts +1 -1
- package/lib/components/side-nav-menu/side-nav-menu.component.d.ts +1 -1
- package/package.json +13 -19
- package/esm2020/lib/components/menu-columns/menu-columns.component.mjs +0 -163
- package/esm2020/lib/components/menu-item-link/menu-item-link.component.mjs +0 -52
- package/fesm2015/tilde-nlp-ngx-menu.mjs +0 -712
- package/fesm2015/tilde-nlp-ngx-menu.mjs.map +0 -1
- /package/{esm2020 → esm2022}/lib/assets/menu-logo.svg.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/menu-item-icon/menu.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/menu-item-icon/models/menu-dialog-settings.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/menu-item-icon/models/menu-item-settings.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/menu-item-icon/models/menu-title-placement.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/nav-base/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/nav-base/models/strapi-data-location.enum.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/side-nav-menu/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/side-nav-menu/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/side-nav-menu/models/side-nav-settings.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/injection-tokens/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/injection-tokens/menu-shared-config.token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/custom-menu-item.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/menu-icon-strapi-extension.const.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/menu-item-group.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/menu-layout-direction.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/menu-shared-config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/tilde-nlp-ngx-menu.mjs +0 -0
|
@@ -1,163 +0,0 @@
|
|
|
1
|
-
import { Component, Inject, Input, Optional } from '@angular/core';
|
|
2
|
-
import { NavigationEnd } from '@angular/router';
|
|
3
|
-
import { filter } from 'rxjs';
|
|
4
|
-
import { MENU_SHARED_CONFIG } from '../../injection-tokens';
|
|
5
|
-
import { MenuLayoutDirection } from '../../models/menu-layout-direction.model';
|
|
6
|
-
import { StrapiDataLocation } from '../nav-base/models/strapi-data-location.enum';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "../../services/strapi.service";
|
|
9
|
-
import * as i2 from "@angular/router";
|
|
10
|
-
import * as i3 from "@angular/common";
|
|
11
|
-
import * as i4 from "@angular/material/divider";
|
|
12
|
-
import * as i5 from "../menu-item-list/menu-item-list.component";
|
|
13
|
-
export class MenuColumnsComponent {
|
|
14
|
-
constructor(strapiService, router, menuSharedConfig) {
|
|
15
|
-
this.strapiService = strapiService;
|
|
16
|
-
this.router = router;
|
|
17
|
-
this.menuSharedConfig = menuSharedConfig;
|
|
18
|
-
this.direction = MenuLayoutDirection.column;
|
|
19
|
-
this.hideSelectedCustomId = false;
|
|
20
|
-
this.strapiGroupBase = {};
|
|
21
|
-
this.strapiDataLocation = StrapiDataLocation.END;
|
|
22
|
-
this.labelsVisible = true;
|
|
23
|
-
this._menuItemGroups = [];
|
|
24
|
-
this.subscribedToStrapi = false;
|
|
25
|
-
this.strapiItems = [];
|
|
26
|
-
this._mergedGroups = [];
|
|
27
|
-
this.subscriptions = [];
|
|
28
|
-
this.isActiveMatchOptions = {
|
|
29
|
-
matrixParams: 'exact',
|
|
30
|
-
queryParams: 'exact',
|
|
31
|
-
paths: 'exact',
|
|
32
|
-
fragment: 'exact'
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
get customId() {
|
|
36
|
-
return this.menuSharedConfig?.customId;
|
|
37
|
-
}
|
|
38
|
-
get strapiGroup() { return this._strapiGroup; }
|
|
39
|
-
get menuItemGroups() { return this._menuItemGroups; }
|
|
40
|
-
set menuItemGroups(groups) {
|
|
41
|
-
this._menuItemGroups = groups ?? [];
|
|
42
|
-
}
|
|
43
|
-
get mergedGroups() { return this._mergedGroups; }
|
|
44
|
-
get allRootItems() {
|
|
45
|
-
const allItems = this.mergedGroups.map(map => map.items);
|
|
46
|
-
let newArray = [];
|
|
47
|
-
allItems.forEach((array) => { newArray = newArray.concat(array); });
|
|
48
|
-
return newArray;
|
|
49
|
-
}
|
|
50
|
-
ngOnInit() {
|
|
51
|
-
this.subscribeOnRouteChange();
|
|
52
|
-
this.getStrapiData();
|
|
53
|
-
}
|
|
54
|
-
ngOnDestroy() {
|
|
55
|
-
this.subscriptions.forEach(sub => sub.unsubscribe());
|
|
56
|
-
if (this.subscribedToStrapi) {
|
|
57
|
-
this.strapiService.unsubscribe();
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
elementExpanded(element) {
|
|
61
|
-
if (!this.activeItem) {
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
// if active item is expanded, most likely some of his child should be active, or if it is collapsed, most likely parent should be active if no route change.
|
|
65
|
-
if (element !== this.activeItem && !element.children?.includes(this.activeItem)) {
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
this.changeActiveElement();
|
|
69
|
-
}
|
|
70
|
-
getStrapiData() {
|
|
71
|
-
if (!this.menuSharedConfig?.disableStrapi) {
|
|
72
|
-
this.subscribedToStrapi = true;
|
|
73
|
-
this.strapiService.getMenuItems().subscribe(this.loadData.bind(this));
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
loadData(data) {
|
|
77
|
-
// hide custom id based on input param
|
|
78
|
-
this.strapiItems = (this.hideSelectedCustomId && this.customId) ? data.filter(item => item.customId !== this.customId) : data;
|
|
79
|
-
this._strapiGroup = {
|
|
80
|
-
...this.strapiGroupBase,
|
|
81
|
-
items: this.strapiItems
|
|
82
|
-
};
|
|
83
|
-
if (this.strapiDataLocation === StrapiDataLocation.START) {
|
|
84
|
-
this._mergedGroups = [this.strapiGroup, ...this.menuItemGroups];
|
|
85
|
-
}
|
|
86
|
-
else if (this.strapiDataLocation === StrapiDataLocation.END) {
|
|
87
|
-
this._mergedGroups = [...this.menuItemGroups, this.strapiGroup];
|
|
88
|
-
}
|
|
89
|
-
this.changeActiveElement();
|
|
90
|
-
}
|
|
91
|
-
subscribeOnRouteChange() {
|
|
92
|
-
const subscription = this.router.events
|
|
93
|
-
.pipe(filter(e => e instanceof NavigationEnd))
|
|
94
|
-
.subscribe(() => { this.changeActiveElement(); });
|
|
95
|
-
this.subscriptions.push(subscription);
|
|
96
|
-
}
|
|
97
|
-
changeActiveElement() {
|
|
98
|
-
this.activeItem = this.findActiveElement(this.allRootItems);
|
|
99
|
-
}
|
|
100
|
-
/** Finds active element from whole list. RouterLink has priority over custom Id. */
|
|
101
|
-
// at this version, child elements should not have customId, since that property comes from strapi and strapi provides only one level structure
|
|
102
|
-
findActiveElement(list) {
|
|
103
|
-
if (!list) {
|
|
104
|
-
return null;
|
|
105
|
-
}
|
|
106
|
-
let customIdElement = null;
|
|
107
|
-
for (const item of list) {
|
|
108
|
-
// Child element has priority over parent, so need to check if any child is active
|
|
109
|
-
if (this.isElementRouterLinkActive(item)) {
|
|
110
|
-
// If has children and they are visible, return active child or current item
|
|
111
|
-
return this.showChildren && item.expanded ? this.findActiveElement(item.children) ?? item : item;
|
|
112
|
-
}
|
|
113
|
-
// if selected custom id element is hidden, no need to look for it and set it to active;
|
|
114
|
-
else if (!this.hideSelectedCustomId && this.isElementCustomIdActive(item)) {
|
|
115
|
-
customIdElement = item;
|
|
116
|
-
}
|
|
117
|
-
else if (this.showChildren && item.children?.length) {
|
|
118
|
-
const activeChild = this.findActiveElement(item.children);
|
|
119
|
-
if (activeChild) {
|
|
120
|
-
return activeChild;
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
return customIdElement;
|
|
125
|
-
}
|
|
126
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
127
|
-
// private isMenuItem(item: any): item is MenuItems {
|
|
128
|
-
// return item.customId;
|
|
129
|
-
// }
|
|
130
|
-
isElementCustomIdActive(element) {
|
|
131
|
-
return this.customId && element.customId === this.customId;
|
|
132
|
-
}
|
|
133
|
-
isElementRouterLinkActive(element) {
|
|
134
|
-
const routerLinkActiveOptions = element.routerLinkActiveOptions ?? this.menuSharedConfig.activeMatchOptions ?? this.isActiveMatchOptions;
|
|
135
|
-
return this.router.isActive(element.link, routerLinkActiveOptions);
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
MenuColumnsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MenuColumnsComponent, deps: [{ token: i1.StarpiMenuService }, { token: i2.Router }, { token: MENU_SHARED_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
139
|
-
MenuColumnsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: MenuColumnsComponent, selector: "menu-columns", inputs: { direction: "direction", hideSelectedCustomId: "hideSelectedCustomId", strapiGroupBase: "strapiGroupBase", strapiDataLocation: "strapiDataLocation", labelsVisible: "labelsVisible", showChildren: "showChildren", menuItemGroups: "menuItemGroups" }, ngImport: i0, template: "<ng-container *ngFor=\"let group of mergedGroups\">\r\n <menu-item-list *ngIf=\"group.items.length\" [activeItem]=\"activeItem\" [direction]=\"direction\" (toggleExpand)=\"elementExpanded($event)\"\r\n [labelsVisible]=\"labelsVisible\" [menuItemGroup]=\"group\" [items]=\"group.items\" [showChildren]=\"showChildren\">\r\n </menu-item-list>\r\n <div class=\"divider\" *ngIf=\"group.bottomDivider\">\r\n <mat-divider></mat-divider>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{display:inline-block}:host menu-item-list{display:block}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i5.MenuItemListComponent, selector: "menu-item-list", inputs: ["direction", "labelsVisible", "activeItem", "showIcons", "showChildren", "items", "menuItemGroup"], outputs: ["toggleExpand"] }] });
|
|
140
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MenuColumnsComponent, decorators: [{
|
|
141
|
-
type: Component,
|
|
142
|
-
args: [{ selector: 'menu-columns', template: "<ng-container *ngFor=\"let group of mergedGroups\">\r\n <menu-item-list *ngIf=\"group.items.length\" [activeItem]=\"activeItem\" [direction]=\"direction\" (toggleExpand)=\"elementExpanded($event)\"\r\n [labelsVisible]=\"labelsVisible\" [menuItemGroup]=\"group\" [items]=\"group.items\" [showChildren]=\"showChildren\">\r\n </menu-item-list>\r\n <div class=\"divider\" *ngIf=\"group.bottomDivider\">\r\n <mat-divider></mat-divider>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{display:inline-block}:host menu-item-list{display:block}\n"] }]
|
|
143
|
-
}], ctorParameters: function () { return [{ type: i1.StarpiMenuService }, { type: i2.Router }, { type: undefined, decorators: [{
|
|
144
|
-
type: Optional
|
|
145
|
-
}, {
|
|
146
|
-
type: Inject,
|
|
147
|
-
args: [MENU_SHARED_CONFIG]
|
|
148
|
-
}] }]; }, propDecorators: { direction: [{
|
|
149
|
-
type: Input
|
|
150
|
-
}], hideSelectedCustomId: [{
|
|
151
|
-
type: Input
|
|
152
|
-
}], strapiGroupBase: [{
|
|
153
|
-
type: Input
|
|
154
|
-
}], strapiDataLocation: [{
|
|
155
|
-
type: Input
|
|
156
|
-
}], labelsVisible: [{
|
|
157
|
-
type: Input
|
|
158
|
-
}], showChildren: [{
|
|
159
|
-
type: Input
|
|
160
|
-
}], menuItemGroups: [{
|
|
161
|
-
type: Input
|
|
162
|
-
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-columns.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-menu/src/lib/components/menu-columns/menu-columns.component.ts","../../../../../../projects/ngx-menu/src/lib/components/menu-columns/menu-columns.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnDestroy, OnInit, Optional } from '@angular/core';\r\nimport { IsActiveMatchOptions, NavigationEnd, Router } from '@angular/router';\r\nimport { filter, Subscription } from 'rxjs';\r\nimport { MENU_SHARED_CONFIG } from '../../injection-tokens';\r\nimport { CustomMenuItem } from '../../models/custom-menu-item';\r\nimport { MenuItemGroup, MenuItemGroupBase } from '../../models/menu-item-group.model';\r\nimport { MenuSharedConfig } from '../../models/menu-shared-config.model';\r\nimport { MenuLayoutDirection } from '../../models/menu-layout-direction.model';\r\nimport { StarpiMenuService } from '../../services/strapi.service';\r\nimport { StrapiDataLocation } from '../nav-base/models/strapi-data-location.enum';\r\n\r\n@Component({\r\n  selector: 'menu-columns',\r\n  templateUrl: './menu-columns.component.html',\r\n  styleUrls: ['./menu-columns.component.scss']\r\n})\r\nexport class MenuColumnsComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() direction: MenuLayoutDirection = MenuLayoutDirection.column;\r\n  @Input() hideSelectedCustomId = false;\r\n  @Input() strapiGroupBase: MenuItemGroupBase = {};\r\n  @Input() strapiDataLocation: StrapiDataLocation = StrapiDataLocation.END;\r\n  @Input() labelsVisible = true;\r\n  @Input() showChildren!: boolean;\r\n\r\n  activeItem!: CustomMenuItem | null;\r\n\r\n  get customId() {\r\n    return this.menuSharedConfig?.customId;\r\n  }\r\n\r\n  private _strapiGroup!: MenuItemGroup;\r\n  get strapiGroup() { return this._strapiGroup; }\r\n\r\n  private _menuItemGroups: MenuItemGroup[] = [];\r\n  get menuItemGroups() { return this._menuItemGroups; }\r\n  @Input() set menuItemGroups(groups: MenuItemGroup[]) {\r\n    this._menuItemGroups = groups ?? [];\r\n  }\r\n\r\n  private subscribedToStrapi = false;\r\n  private strapiItems: CustomMenuItem[] = [];\r\n  private _mergedGroups: MenuItemGroup[] = [];\r\n  get mergedGroups() { return this._mergedGroups; }\r\n\r\n  get allRootItems(): CustomMenuItem[] {\r\n    const allItems = this.mergedGroups.map(map => map.items);\r\n    let newArray: CustomMenuItem[] = [];\r\n    allItems.forEach((array) => { newArray = newArray.concat(array) });\r\n    return newArray;\r\n  }\r\n\r\n  private readonly subscriptions: Subscription[] = [];\r\n  private readonly isActiveMatchOptions: IsActiveMatchOptions = {\r\n    matrixParams: 'exact',\r\n    queryParams: 'exact',\r\n    paths: 'exact',\r\n    fragment: 'exact'\r\n  };\r\n\r\n  constructor(protected readonly strapiService: StarpiMenuService,\r\n    protected readonly router: Router,\r\n    @Optional() @Inject(MENU_SHARED_CONFIG) protected readonly menuSharedConfig: MenuSharedConfig) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.subscribeOnRouteChange();\r\n    this.getStrapiData();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.forEach(sub => sub.unsubscribe());\r\n\r\n    if (this.subscribedToStrapi) {\r\n      this.strapiService.unsubscribe();\r\n    }\r\n  }\r\n\r\n  elementExpanded(element: CustomMenuItem) {\r\n    if (!this.activeItem) {\r\n      return;\r\n    }\r\n    // if active item is expanded, most likely some of his child should be active, or if it is collapsed, most likely parent should be active if no route change.\r\n    if (element !== this.activeItem && !element.children?.includes(this.activeItem)) {\r\n      return;\r\n    }\r\n    this.changeActiveElement();\r\n  }\r\n\r\n  private getStrapiData() {\r\n    if (!this.menuSharedConfig?.disableStrapi) {\r\n      this.subscribedToStrapi = true;\r\n      this.strapiService.getMenuItems().subscribe(this.loadData.bind(this));\r\n    }\r\n  }\r\n\r\n  private loadData(data: CustomMenuItem[]) {\r\n    // hide custom id based on input param\r\n    this.strapiItems = (this.hideSelectedCustomId && this.customId) ? data.filter(item => item.customId !== this.customId) : data;\r\n    this._strapiGroup = {\r\n      ...this.strapiGroupBase,\r\n      items: this.strapiItems\r\n    }\r\n\r\n    if (this.strapiDataLocation === StrapiDataLocation.START) {\r\n      this._mergedGroups = [this.strapiGroup, ...this.menuItemGroups];\r\n    }\r\n    else if (this.strapiDataLocation === StrapiDataLocation.END) {\r\n      this._mergedGroups = [...this.menuItemGroups, this.strapiGroup];\r\n    }\r\n\r\n    this.changeActiveElement();\r\n  }\r\n\r\n  private subscribeOnRouteChange() {\r\n    const subscription = this.router.events\r\n      .pipe(filter(e => e instanceof NavigationEnd))\r\n      .subscribe(() => { this.changeActiveElement(); });\r\n    this.subscriptions.push(subscription);\r\n  }\r\n\r\n  private changeActiveElement() {\r\n    this.activeItem = this.findActiveElement(this.allRootItems);\r\n  }\r\n\r\n\r\n  /** Finds active element from whole list. RouterLink has priority over custom Id. */\r\n  // at this version, child elements should not have customId, since that property comes from strapi and strapi provides only one level structure\r\n  private findActiveElement(list?: (CustomMenuItem)[]): CustomMenuItem | null {\r\n    if (!list) {\r\n      return null;\r\n    }\r\n\r\n    let customIdElement: CustomMenuItem | null = null;\r\n    for (const item of list) {\r\n      // Child element has priority over parent, so need to check if any child is active\r\n      if (this.isElementRouterLinkActive(item)) {\r\n        // If has children and they are visible, return active child or current item\r\n        return this.showChildren && item.expanded ? this.findActiveElement(item.children) ?? item : item;\r\n      }\r\n      // if selected custom id element is hidden, no need to look for it and set it to active;\r\n      else if (!this.hideSelectedCustomId && this.isElementCustomIdActive(item)) {\r\n        customIdElement = item;\r\n      }\r\n      else if (this.showChildren && item.children?.length) {\r\n        const activeChild = this.findActiveElement(item.children);\r\n        if (activeChild) {\r\n          return activeChild;\r\n        }\r\n      }\r\n    }\r\n    return customIdElement;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  // private isMenuItem(item: any): item is MenuItems {\r\n  //   return item.customId;\r\n  // }\r\n\r\n  private isElementCustomIdActive(element: CustomMenuItem) {\r\n    return this.customId && element.customId === this.customId;\r\n  }\r\n\r\n  private isElementRouterLinkActive(element: CustomMenuItem) {\r\n    const routerLinkActiveOptions: IsActiveMatchOptions = (element as CustomMenuItem).routerLinkActiveOptions ?? this.menuSharedConfig.activeMatchOptions ?? this.isActiveMatchOptions;\r\n\r\n    return this.router.isActive(element.link, routerLinkActiveOptions);\r\n  }\r\n}\r\n","<ng-container *ngFor=\"let group of mergedGroups\">\r\n    <menu-item-list *ngIf=\"group.items.length\" [activeItem]=\"activeItem\" [direction]=\"direction\" (toggleExpand)=\"elementExpanded($event)\"\r\n        [labelsVisible]=\"labelsVisible\" [menuItemGroup]=\"group\" [items]=\"group.items\" [showChildren]=\"showChildren\">\r\n    </menu-item-list>\r\n    <div class=\"divider\" *ngIf=\"group.bottomDivider\">\r\n        <mat-divider></mat-divider>\r\n    </div>\r\n</ng-container>\r\n"]}
|
|
@@ -1,52 +0,0 @@
|
|
|
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 "@angular/flex-layout/flex";
|
|
6
|
-
import * as i3 from "@angular/common";
|
|
7
|
-
import * as i4 from "@angular/material/tooltip";
|
|
8
|
-
import * as i5 from "@tilde-nlp/ngx-common";
|
|
9
|
-
import * as i6 from "../menu-icon/menu-icon.component";
|
|
10
|
-
import * as i7 from "@ngx-translate/core";
|
|
11
|
-
export class MenuItemLinkComponent {
|
|
12
|
-
constructor(strapiLinkService, placeholderService) {
|
|
13
|
-
this.strapiLinkService = strapiLinkService;
|
|
14
|
-
this.placeholderService = placeholderService;
|
|
15
|
-
this.showIcons = true;
|
|
16
|
-
this.updateTextWithPlaceholders = (textWithReplacedPlaceholders) => this.href = textWithReplacedPlaceholders;
|
|
17
|
-
}
|
|
18
|
-
get menuItemLayout() {
|
|
19
|
-
return this.direction === MenuLayoutDirection.column ? 'column' : 'row';
|
|
20
|
-
}
|
|
21
|
-
get menuLayoutDirection() {
|
|
22
|
-
return (this.direction === MenuLayoutDirection.column || !this.labelsVisible)
|
|
23
|
-
? 'start center' : 'start start';
|
|
24
|
-
}
|
|
25
|
-
ngOnInit() {
|
|
26
|
-
this.textWithPlaceholders = this.menuItem.link;
|
|
27
|
-
this.placeholderServiceId = this.placeholderService.register(this);
|
|
28
|
-
}
|
|
29
|
-
linkClick(event, item) {
|
|
30
|
-
this.strapiLinkService.strapiLinkClick(event, item.externalLink);
|
|
31
|
-
}
|
|
32
|
-
ngOnDestroy() {
|
|
33
|
-
this.placeholderService.unregister(this.placeholderServiceId);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
MenuItemLinkComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MenuItemLinkComponent, deps: [{ token: i1.StrapiLinkService }, { token: i1.StrapiVariablesService }], target: i0.ɵɵFactoryTarget.Component });
|
|
37
|
-
MenuItemLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: MenuItemLinkComponent, selector: "tld-menu-item-link", inputs: { direction: "direction", labelsVisible: "labelsVisible", activeItem: "activeItem", showIcons: "showIcons", menuItem: "menuItem" }, ngImport: i0, template: "<a [libPlausibleEvent]=\"menuItem.plausibleEvent\" [fxLayout]=\"menuItemLayout\"\r\n [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", styles: [""], dependencies: [{ kind: "directive", type: i2.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i5.PlausibleEventDirective, selector: "[libPlausibleEvent]", inputs: ["libPlausibleEvent"] }, { kind: "component", type: i6.MenuIconComponent, selector: "tld-menu-icon", inputs: ["menuItem"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] });
|
|
38
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: MenuItemLinkComponent, decorators: [{
|
|
39
|
-
type: Component,
|
|
40
|
-
args: [{ selector: 'tld-menu-item-link', template: "<a [libPlausibleEvent]=\"menuItem.plausibleEvent\" [fxLayout]=\"menuItemLayout\"\r\n [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" }]
|
|
41
|
-
}], ctorParameters: function () { return [{ type: i1.StrapiLinkService }, { type: i1.StrapiVariablesService }]; }, propDecorators: { direction: [{
|
|
42
|
-
type: Input
|
|
43
|
-
}], labelsVisible: [{
|
|
44
|
-
type: Input
|
|
45
|
-
}], activeItem: [{
|
|
46
|
-
type: Input
|
|
47
|
-
}], showIcons: [{
|
|
48
|
-
type: Input
|
|
49
|
-
}], menuItem: [{
|
|
50
|
-
type: Input
|
|
51
|
-
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1pdGVtLWxpbmsuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL2xpYi9jb21wb25lbnRzL21lbnUtaXRlbS1saW5rL21lbnUtaXRlbS1saW5rLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tZW51L3NyYy9saWIvY29tcG9uZW50cy9tZW51LWl0ZW0tbGluay9tZW51LWl0ZW0tbGluay5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFFcEUsT0FBTyxFQUFrQixtQkFBbUIsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7Ozs7Ozs7O0FBT25FLE1BQU0sT0FBTyxxQkFBcUI7SUFvQmhDLFlBQTZCLGlCQUFvQyxFQUM5QyxrQkFBMEM7UUFEaEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUM5Qyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQXdCO1FBakJwRCxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBNEIxQiwrQkFBMEIsR0FBRyxDQUFDLDRCQUFvQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLDRCQUE0QixDQUFDO0lBWC9DLENBQUM7SUFWbEUsSUFBSSxjQUFjO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLFNBQVMsS0FBSyxtQkFBbUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQzFFLENBQUM7SUFFRCxJQUFJLG1CQUFtQjtRQUNyQixPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsS0FBSyxtQkFBbUIsQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDO1lBQzNFLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQztJQUNyQyxDQUFDO0lBS0QsUUFBUTtRQUNOLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQztRQUMvQyxJQUFJLENBQUMsb0JBQW9CLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQsU0FBUyxDQUFDLEtBQWlCLEVBQUUsSUFBb0I7UUFDL0MsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ25FLENBQUM7SUFJRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUNoRSxDQUFDOztrSEFwQ1UscUJBQXFCO3NHQUFyQixxQkFBcUIsc01DVGxDLGk2QkFlQTsyRkROYSxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0Usb0JBQW9COzZJQUtyQixTQUFTO3NCQUFqQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBQbGFjZWhvbGRlckNvbXBvbmVudEJhc2UsIFN0cmFwaUxpbmtTZXJ2aWNlLCBTdHJhcGlWYXJpYWJsZXNTZXJ2aWNlIH0gZnJvbSAnQHRpbGRlLW5scC9uZ3gtc3RyYXBpJztcclxuaW1wb3J0IHsgQ3VzdG9tTWVudUl0ZW0sIE1lbnVMYXlvdXREaXJlY3Rpb24gfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0bGQtbWVudS1pdGVtLWxpbmsnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9tZW51LWl0ZW0tbGluay5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbWVudS1pdGVtLWxpbmsuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTWVudUl0ZW1MaW5rQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3ksIFBsYWNlaG9sZGVyQ29tcG9uZW50QmFzZSB7XHJcbiAgQElucHV0KCkgZGlyZWN0aW9uITogTWVudUxheW91dERpcmVjdGlvbjtcclxuICBASW5wdXQoKSBsYWJlbHNWaXNpYmxlITogYm9vbGVhbjtcclxuICBASW5wdXQoKSBhY3RpdmVJdGVtITogQ3VzdG9tTWVudUl0ZW0gfCBudWxsO1xyXG4gIEBJbnB1dCgpIHNob3dJY29ucyA9IHRydWU7XHJcbiAgQElucHV0KCkgbWVudUl0ZW0hOiBDdXN0b21NZW51SXRlbTtcclxuXHJcbiAgdGV4dFdpdGhQbGFjZWhvbGRlcnMhOiBzdHJpbmc7XHJcbiAgaHJlZiE6IHN0cmluZztcclxuXHJcbiAgcHJpdmF0ZSBwbGFjZWhvbGRlclNlcnZpY2VJZCE6IG51bWJlcjtcclxuICBnZXQgbWVudUl0ZW1MYXlvdXQoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLmRpcmVjdGlvbiA9PT0gTWVudUxheW91dERpcmVjdGlvbi5jb2x1bW4gPyAnY29sdW1uJyA6ICdyb3cnO1xyXG4gIH1cclxuXHJcbiAgZ2V0IG1lbnVMYXlvdXREaXJlY3Rpb24oKTogc3RyaW5nIHtcclxuICAgIHJldHVybiAodGhpcy5kaXJlY3Rpb24gPT09IE1lbnVMYXlvdXREaXJlY3Rpb24uY29sdW1uIHx8ICF0aGlzLmxhYmVsc1Zpc2libGUpXHJcbiAgICAgID8gJ3N0YXJ0IGNlbnRlcicgOiAnc3RhcnQgc3RhcnQnO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBzdHJhcGlMaW5rU2VydmljZTogU3RyYXBpTGlua1NlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IHBsYWNlaG9sZGVyU2VydmljZTogU3RyYXBpVmFyaWFibGVzU2VydmljZSkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy50ZXh0V2l0aFBsYWNlaG9sZGVycyA9IHRoaXMubWVudUl0ZW0ubGluaztcclxuICAgIHRoaXMucGxhY2Vob2xkZXJTZXJ2aWNlSWQgPSB0aGlzLnBsYWNlaG9sZGVyU2VydmljZS5yZWdpc3Rlcih0aGlzKTtcclxuICB9XHJcblxyXG4gIGxpbmtDbGljayhldmVudDogTW91c2VFdmVudCwgaXRlbTogQ3VzdG9tTWVudUl0ZW0pIHtcclxuICAgIHRoaXMuc3RyYXBpTGlua1NlcnZpY2Uuc3RyYXBpTGlua0NsaWNrKGV2ZW50LCBpdGVtLmV4dGVybmFsTGluayk7XHJcbiAgfVxyXG5cclxuICB1cGRhdGVUZXh0V2l0aFBsYWNlaG9sZGVycyA9ICh0ZXh0V2l0aFJlcGxhY2VkUGxhY2Vob2xkZXJzOiBzdHJpbmcpID0+IHRoaXMuaHJlZiA9IHRleHRXaXRoUmVwbGFjZWRQbGFjZWhvbGRlcnM7XHJcblxyXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy5wbGFjZWhvbGRlclNlcnZpY2UudW5yZWdpc3Rlcih0aGlzLnBsYWNlaG9sZGVyU2VydmljZUlkKTtcclxuICB9XHJcbn1cclxuIiwiPGEgW2xpYlBsYXVzaWJsZUV2ZW50XT1cIm1lbnVJdGVtLnBsYXVzaWJsZUV2ZW50XCIgW2Z4TGF5b3V0XT1cIm1lbnVJdGVtTGF5b3V0XCJcclxuICBbY2xhc3MudGV4dC1jZW50ZXJdPVwibWVudUl0ZW1MYXlvdXQgPT09ICdjb2x1bW4nXCIgY2xhc3M9XCJ0ZXh0LW0gbWVudS1pdGVtXCJcclxuICBbbWF0VG9vbHRpcF09XCIhbGFiZWxzVmlzaWJsZSA/IChtZW51SXRlbS50aXRsZSB8IHRyYW5zbGF0ZSkgOiAnJ1wiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImFmdGVyXCJcclxuICBbZnhMYXlvdXRBbGlnbl09XCJtZW51TGF5b3V0RGlyZWN0aW9uXCIgbWF0VG9vbHRpcENsYXNzPVwibWVudS10b29sdGlwXCIgKGNsaWNrKT1cImxpbmtDbGljaygkZXZlbnQsIG1lbnVJdGVtKVwiXHJcbiAgW2hyZWZdPVwiaHJlZiB8IHRyYW5zbGF0ZVwiIFthdHRyLnRhcmdldF09XCJtZW51SXRlbS5leHRlcm5hbExpbms/J19ibGFuayc6ICdfc2VsZidcIiBmeExheW91dEdhcD1cIjAuMzc1cmVtXCJcclxuICBbY2xhc3MuYWN0aXZlLW1lbnUtaXRlbV09XCJtZW51SXRlbSA9PT0gYWN0aXZlSXRlbVwiPlxyXG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJzaG93SWNvbnMgJiYgbWVudUl0ZW0uaWNvblwiPlxyXG4gICAgPHRsZC1tZW51LWljb24gW21lbnVJdGVtXT1cIm1lbnVJdGVtXCI+PC90bGQtbWVudS1pY29uPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG4gIDxzcGFuICpuZ0lmPVwibGFiZWxzVmlzaWJsZVwiIGNsYXNzPVwibWVudS1pdGVtLXRpdGxlXCI+XHJcbiAgICA8c3BhbiBjbGFzcz1cInRpdGxlLWNvbnRlbnRcIiBbYXR0ci5jb250ZW50XT1cIm1lbnVJdGVtLnRpdGxlIHwgdHJhbnNsYXRlXCI+XHJcbiAgICAgIHt7IG1lbnVJdGVtLnRpdGxlIHwgdHJhbnNsYXRlfX1cclxuICAgIDwvc3Bhbj5cclxuICA8L3NwYW4+XHJcbjwvYT5cclxuIl19
|