@tilde-nlp/ngx-menu 1.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/README.md +4 -0
- package/esm2020/lib/assets/menu-logo.svg.mjs +7 -0
- package/esm2020/lib/components/menu-columns/menu-columns.component.mjs +163 -0
- package/esm2020/lib/components/menu-item-icon/menu-item-icon.component.mjs +76 -0
- package/esm2020/lib/components/menu-item-icon/menu.model.mjs +4 -0
- package/esm2020/lib/components/menu-item-icon/models/menu-dialog-settings.model.mjs +2 -0
- package/esm2020/lib/components/menu-item-icon/models/menu-item-settings.model.mjs +2 -0
- package/esm2020/lib/components/menu-item-icon/models/menu-title-placement.model.mjs +7 -0
- package/esm2020/lib/components/menu-item-list/menu-item-list.component.mjs +73 -0
- package/esm2020/lib/components/menu-strapi-item-list/menu-strapi-item-list.component.mjs +15 -0
- package/esm2020/lib/components/modal-nav-menu/modal-nav-menu.component.mjs +37 -0
- package/esm2020/lib/components/nav-base/models/index.mjs +2 -0
- package/esm2020/lib/components/nav-base/models/strapi-data-location.enum.mjs +7 -0
- package/esm2020/lib/components/nav-base/nav-base.component.mjs +28 -0
- package/esm2020/lib/components/side-nav-menu/index.mjs +3 -0
- package/esm2020/lib/components/side-nav-menu/models/index.mjs +2 -0
- package/esm2020/lib/components/side-nav-menu/models/side-nav-settings.model.mjs +2 -0
- package/esm2020/lib/components/side-nav-menu/side-nav-menu.component.mjs +90 -0
- package/esm2020/lib/injection-tokens/index.mjs +2 -0
- package/esm2020/lib/injection-tokens/menu-shared-config.token.mjs +2 -0
- package/esm2020/lib/menu.module.mjs +111 -0
- package/esm2020/lib/models/custom-menu-item.mjs +2 -0
- package/esm2020/lib/models/index.mjs +6 -0
- package/esm2020/lib/models/menu-icon-strapi-extension.const.mjs +2 -0
- package/esm2020/lib/models/menu-item-group.model.mjs +2 -0
- package/esm2020/lib/models/menu-layout-direction.model.mjs +6 -0
- package/esm2020/lib/models/menu-shared-config.model.mjs +2 -0
- package/esm2020/lib/services/strapi.service.mjs +93 -0
- package/esm2020/public-api.mjs +17 -0
- package/esm2020/tilde-nlp-ngx-menu.mjs +5 -0
- package/fesm2015/tilde-nlp-ngx-menu.mjs +673 -0
- package/fesm2015/tilde-nlp-ngx-menu.mjs.map +1 -0
- package/fesm2020/tilde-nlp-ngx-menu.mjs +660 -0
- package/fesm2020/tilde-nlp-ngx-menu.mjs.map +1 -0
- package/lib/assets/menu-logo.svg.d.ts +1 -0
- package/lib/components/menu-columns/menu-columns.component.d.ts +48 -0
- package/lib/components/menu-item-icon/menu-item-icon.component.d.ts +30 -0
- package/lib/components/menu-item-icon/menu.model.d.ts +3 -0
- package/lib/components/menu-item-icon/models/menu-dialog-settings.model.d.ts +8 -0
- package/lib/components/menu-item-icon/models/menu-item-settings.model.d.ts +6 -0
- package/lib/components/menu-item-icon/models/menu-title-placement.model.d.ts +5 -0
- package/lib/components/menu-item-list/menu-item-list.component.d.ts +29 -0
- package/lib/components/menu-strapi-item-list/menu-strapi-item-list.component.d.ts +7 -0
- package/lib/components/modal-nav-menu/modal-nav-menu.component.d.ts +13 -0
- package/lib/components/nav-base/models/index.d.ts +1 -0
- package/lib/components/nav-base/models/strapi-data-location.enum.d.ts +5 -0
- package/lib/components/nav-base/nav-base.component.d.ts +13 -0
- package/lib/components/side-nav-menu/index.d.ts +2 -0
- package/lib/components/side-nav-menu/models/index.d.ts +1 -0
- package/lib/components/side-nav-menu/models/side-nav-settings.model.d.ts +7 -0
- package/lib/components/side-nav-menu/side-nav-menu.component.d.ts +31 -0
- package/lib/injection-tokens/index.d.ts +1 -0
- package/lib/injection-tokens/menu-shared-config.token.d.ts +1 -0
- package/lib/menu.module.d.ts +28 -0
- package/lib/models/custom-menu-item.d.ts +20 -0
- package/lib/models/index.d.ts +5 -0
- package/lib/models/menu-icon-strapi-extension.const.d.ts +1 -0
- package/lib/models/menu-item-group.model.d.ts +9 -0
- package/lib/models/menu-layout-direction.model.d.ts +4 -0
- package/lib/models/menu-shared-config.model.d.ts +11 -0
- package/lib/services/strapi.service.d.ts +20 -0
- package/package.json +41 -0
- package/public-api.d.ts +13 -0
- package/src/styles.scss +15 -0
- package/tilde-nlp-ngx-menu.d.ts +5 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { StrapiDataLocation } from './models/strapi-data-location.enum';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/** This component is created to help nest some common input params through nav components. */
|
|
5
|
+
export class NavBaseComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.hideSelectedCustomId = false;
|
|
8
|
+
this.strapiGroupBase = {};
|
|
9
|
+
this.strapiDataLocation = StrapiDataLocation.END;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
NavBaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: NavBaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
+
NavBaseComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.3", type: NavBaseComponent, selector: "nav-base", inputs: { hideSelectedCustomId: "hideSelectedCustomId", direction: "direction", menuItemGroups: "menuItemGroups", strapiGroupBase: "strapiGroupBase", strapiDataLocation: "strapiDataLocation" }, ngImport: i0, template: "<p>nav-base works!</p>\r\n", styles: [""] });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: NavBaseComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'nav-base', template: "<p>nav-base works!</p>\r\n", styles: [""] }]
|
|
17
|
+
}], propDecorators: { hideSelectedCustomId: [{
|
|
18
|
+
type: Input
|
|
19
|
+
}], direction: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], menuItemGroups: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}], strapiGroupBase: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], strapiDataLocation: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}] } });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWJhc2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL2xpYi9jb21wb25lbnRzL25hdi1iYXNlL25hdi1iYXNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tZW51L3NyYy9saWIvY29tcG9uZW50cy9uYXYtYmFzZS9uYXYtYmFzZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdqRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7QUFPeEUsOEZBQThGO0FBQzlGLE1BQU0sT0FBTyxnQkFBZ0I7SUFON0I7UUFPVyx5QkFBb0IsR0FBRyxLQUFLLENBQUM7UUFJN0Isb0JBQWUsR0FBc0IsRUFBRSxDQUFDO1FBQ3hDLHVCQUFrQixHQUF1QixrQkFBa0IsQ0FBQyxHQUFHLENBQUM7S0FDMUU7OzZHQVBZLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLGtQQ1g3Qiw0QkFDQTsyRkRVYSxnQkFBZ0I7a0JBTjVCLFNBQVM7K0JBQ0UsVUFBVTs4QkFNWCxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFFRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csa0JBQWtCO3NCQUExQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNZW51SXRlbUdyb3VwLCBNZW51SXRlbUdyb3VwQmFzZSB9IGZyb20gJy4uLy4uL21vZGVscy9tZW51LWl0ZW0tZ3JvdXAubW9kZWwnO1xyXG5pbXBvcnQgeyBNZW51TGF5b3V0RGlyZWN0aW9uIH0gZnJvbSAnLi4vLi4vbW9kZWxzL21lbnUtbGF5b3V0LWRpcmVjdGlvbi5tb2RlbCc7XHJcbmltcG9ydCB7IFN0cmFwaURhdGFMb2NhdGlvbiB9IGZyb20gJy4vbW9kZWxzL3N0cmFwaS1kYXRhLWxvY2F0aW9uLmVudW0nO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICduYXYtYmFzZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL25hdi1iYXNlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9uYXYtYmFzZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbi8qKiBUaGlzIGNvbXBvbmVudCBpcyBjcmVhdGVkIHRvIGhlbHAgbmVzdCBzb21lIGNvbW1vbiBpbnB1dCBwYXJhbXMgdGhyb3VnaCBuYXYgY29tcG9uZW50cy4gKi9cclxuZXhwb3J0IGNsYXNzIE5hdkJhc2VDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIGhpZGVTZWxlY3RlZEN1c3RvbUlkID0gZmFsc2U7XHJcbiAgQElucHV0KCkgZGlyZWN0aW9uITogTWVudUxheW91dERpcmVjdGlvbjtcclxuXHJcbiAgQElucHV0KCkgbWVudUl0ZW1Hcm91cHMhOiBNZW51SXRlbUdyb3VwW107XHJcbiAgQElucHV0KCkgc3RyYXBpR3JvdXBCYXNlOiBNZW51SXRlbUdyb3VwQmFzZSA9IHt9O1xyXG4gIEBJbnB1dCgpIHN0cmFwaURhdGFMb2NhdGlvbjogU3RyYXBpRGF0YUxvY2F0aW9uID0gU3RyYXBpRGF0YUxvY2F0aW9uLkVORDtcclxufVxyXG4iLCI8cD5uYXYtYmFzZSB3b3JrcyE8L3A+XHJcbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './models';
|
|
2
|
+
export * from './side-nav-menu.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL2NvbXBvbmVudHMvc2lkZS1uYXYtbWVudS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NpZGUtbmF2LW1lbnUuY29tcG9uZW50JzsiXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './side-nav-settings.model';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL2NvbXBvbmVudHMvc2lkZS1uYXYtbWVudS9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2lkZS1uYXYtc2V0dGluZ3MubW9kZWwnO1xyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1uYXYtc2V0dGluZ3MubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL2NvbXBvbmVudHMvc2lkZS1uYXYtbWVudS9tb2RlbHMvc2lkZS1uYXYtc2V0dGluZ3MubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIlxyXG5leHBvcnQgaW50ZXJmYWNlIFNpZGVOYXZTZXR0aW5ncyB7XHJcbiAgZXhwYW5kZWRXaWR0aD86IHN0cmluZyxcclxuICBjb2xsYXBzZWRXaWR0aD86IHN0cmluZyxcclxuICBtZW51TG9nbzogc3RyaW5nLFxyXG4gIG1lbnVMb2dvQ29sbGFwc2VkPzogc3RyaW5nIHwgbnVsbDtcclxuICBkaXNhYmxlU3RyYXBpPzogYm9vbGVhbjtcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { Component, Inject, Input, Optional } from '@angular/core';
|
|
2
|
+
import { MENU_SHARED_CONFIG } from '../../injection-tokens';
|
|
3
|
+
import { NavBaseComponent } from '../nav-base/nav-base.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@tilde-nlp/ngx-strapi";
|
|
6
|
+
import * as i2 from "@tilde-nlp/ngx-common";
|
|
7
|
+
import * as i3 from "../menu-columns/menu-columns.component";
|
|
8
|
+
import * as i4 from "@angular/material/button";
|
|
9
|
+
import * as i5 from "@angular/material/icon";
|
|
10
|
+
import * as i6 from "@angular/flex-layout/flex";
|
|
11
|
+
import * as i7 from "@angular/common";
|
|
12
|
+
import * as i8 from "@ngx-translate/core";
|
|
13
|
+
export class SideNavMenuComponent extends NavBaseComponent {
|
|
14
|
+
constructor(strapiLinkService, domService, menuSharedConfig) {
|
|
15
|
+
super();
|
|
16
|
+
this.strapiLinkService = strapiLinkService;
|
|
17
|
+
this.domService = domService;
|
|
18
|
+
this.COLLAPSED_LOCAL_STORAGE_KEY = "TLD_MENU_SIDE_NAV_COLLAPSED";
|
|
19
|
+
//#region Plausible event variables for collapse button
|
|
20
|
+
this.COLLAPSE_PLAUSIBLE_EVENT_ID = "collapseMenu";
|
|
21
|
+
this.COLLAPSE_PLAUSIBLE_ACTION_KEY = "action";
|
|
22
|
+
this.LOGOCLICK_PLAUSIBLE_ACTION_ID = "tilde_logo_click";
|
|
23
|
+
this.LOGOCLICK_PLAUSIBLE_EVENT = {
|
|
24
|
+
eventId: this.LOGOCLICK_PLAUSIBLE_ACTION_ID,
|
|
25
|
+
properties: []
|
|
26
|
+
};
|
|
27
|
+
this.EXPAND_PLAUSIBLE_EVENT = {
|
|
28
|
+
eventId: this.COLLAPSE_PLAUSIBLE_EVENT_ID,
|
|
29
|
+
properties: [{ key: this.COLLAPSE_PLAUSIBLE_ACTION_KEY, value: "expand" }]
|
|
30
|
+
};
|
|
31
|
+
this.COLLAPSE_PLAUSIBLE_EVENT = {
|
|
32
|
+
eventId: this.COLLAPSE_PLAUSIBLE_EVENT_ID,
|
|
33
|
+
properties: [{ key: this.COLLAPSE_PLAUSIBLE_ACTION_KEY, value: "collapse" }]
|
|
34
|
+
};
|
|
35
|
+
//#endregion
|
|
36
|
+
this.menuSettings = {
|
|
37
|
+
expandedWidth: '9.375em',
|
|
38
|
+
collapsedWidth: '5em',
|
|
39
|
+
menuLogo: '',
|
|
40
|
+
menuLogoCollapsed: '',
|
|
41
|
+
disableStrapi: false
|
|
42
|
+
};
|
|
43
|
+
this.collapsed = false;
|
|
44
|
+
this.baseUrl = menuSharedConfig.baseUrl || '';
|
|
45
|
+
}
|
|
46
|
+
get menuLogoImage() {
|
|
47
|
+
return this.collapsed
|
|
48
|
+
? this.menuSettings.menuLogoCollapsed ?? this.menuSettings.menuLogo
|
|
49
|
+
: this.menuSettings.menuLogo;
|
|
50
|
+
}
|
|
51
|
+
get sideNavWidth() {
|
|
52
|
+
return this.collapsed ? this.menuSettings.collapsedWidth : this.menuSettings.expandedWidth;
|
|
53
|
+
}
|
|
54
|
+
ngOnInit() {
|
|
55
|
+
this.getColapsedFromLocalStorage();
|
|
56
|
+
}
|
|
57
|
+
logoClick(event) {
|
|
58
|
+
this.strapiLinkService.strapiLinkClick(event);
|
|
59
|
+
}
|
|
60
|
+
toggleCollapse() {
|
|
61
|
+
this.collapsed = !this.collapsed;
|
|
62
|
+
this.setColapsedFromLocalStorage();
|
|
63
|
+
}
|
|
64
|
+
getColapsedFromLocalStorage() {
|
|
65
|
+
if (!this.domService.localStorage) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
this.collapsed = this.domService.localStorage.getItem(this.COLLAPSED_LOCAL_STORAGE_KEY) == 'true' ? true : false;
|
|
69
|
+
}
|
|
70
|
+
setColapsedFromLocalStorage() {
|
|
71
|
+
if (!this.domService.localStorage) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
this.domService.localStorage.setItem(this.COLLAPSED_LOCAL_STORAGE_KEY, this.collapsed.toString());
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
SideNavMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SideNavMenuComponent, deps: [{ token: i1.StrapiLinkService }, { token: i2.DOMService }, { token: MENU_SHARED_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
78
|
+
SideNavMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.3", type: SideNavMenuComponent, selector: "lib-side-nav-menu", inputs: { menuSettings: "menuSettings" }, usesInheritance: true, ngImport: i0, template: "<div class=\"menu-container\" [style.width]=\"sideNavWidth\" fxLayout=\"column\" [class.collapsed]=\"collapsed\">\r\n <div class=\"content\" fxLayout=\"column\" fxFlexFill>\r\n <a [libPlausibleEvent]=\"LOGOCLICK_PLAUSIBLE_EVENT\" fxFlex=\"3.125em\" [href]=\"baseUrl\" [attr.aria-label]=\"'MENU.ARIA_LABELS.LOGO' | translate\" (click)=\"logoClick($event)\"\r\n fxLayoutAlign=\"center center\" fxFlexOffset=\"1em\">\r\n <img class=\"menu-logo\" [src]=\"menuLogoImage\" alt=\"\" />\r\n </a>\r\n <div class=\"menu-wrapper\" fxLayout=\"column\" fxFlex>\r\n <menu-columns role=\"navigation\" fxFlex [labelsVisible]=\"!collapsed\" [direction]=\"direction\"\r\n [hideSelectedCustomId]=\"hideSelectedCustomId\" [showChildren]=\"false\" [strapiGroupBase]=\"strapiGroupBase\"\r\n [strapiDataLocation]=\"strapiDataLocation\" [menuItemGroups]=\"menuItemGroups\"></menu-columns>\r\n <div fxLayoutAlign=\"center center\">\r\n <button [libPlausibleEvent]=\"COLLAPSE_PLAUSIBLE_EVENT\" class=\"collapse-btn\" [disableRipple]=\"true\"\r\n *ngIf=\"!collapsed; else expandButton\" (click)=\"toggleCollapse()\" mat-button>\r\n <mat-icon>keyboard_arrow_left</mat-icon>\r\n <span> {{ \"MENU.COLLAPSE\" | translate }} </span>\r\n </button>\r\n <ng-template #expandButton>\r\n <button class=\"toggler\" [libPlausibleEvent]=\"EXPAND_PLAUSIBLE_EVENT\" mat-icon-button\r\n (click)=\"toggleCollapse()\">\r\n <mat-icon>keyboard_arrow_right</mat-icon>\r\n </button>\r\n </ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n", styles: [".menu-container{height:100%;overflow:auto;background:var(--base-100);border-right:1px solid var(--base-70)}.menu-container .content{padding:0 .8em}.menu-container .content .menu-logo{margin:auto;max-width:100%}.menu-container .divider{width:100%;margin:0}:host ::ng-deep .collapsed .menu-item{padding:calc(.125em + 1px)}:host ::ng-deep .collapsed .menu-item.active-menu-item{padding:.125em;border:1px solid var(--primary-accent);border-radius:var(--default-border-radius)}:host ::ng-deep button.collapse-btn{background-color:transparent;font-size:.8125rem;font-weight:400;line-height:1.25rem;letter-spacing:0px;text-align:left;padding:0!important}:host::ng-deep .toggler span.mat-button-focus-overlay{opacity:0!important}:host::ng-deep button.collapse-btn,:host::ng-deep button.toggler{margin-bottom:1em}:host::ng-deep button.collapse-btn .mat-button-focus-overlay,:host::ng-deep button.toggler .mat-button-focus-overlay{display:none}\n"], components: [{ type: i3.MenuColumnsComponent, selector: "menu-columns", inputs: ["direction", "hideSelectedCustomId", "strapiGroupBase", "strapiDataLocation", "labelsVisible", "showChildren", "menuItemGroups"] }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.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"] }, { type: i6.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { type: i6.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { type: i6.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"] }, { type: i6.DefaultFlexOffsetDirective, selector: " [fxFlexOffset], [fxFlexOffset.xs], [fxFlexOffset.sm], [fxFlexOffset.md], [fxFlexOffset.lg], [fxFlexOffset.xl], [fxFlexOffset.lt-sm], [fxFlexOffset.lt-md], [fxFlexOffset.lt-lg], [fxFlexOffset.lt-xl], [fxFlexOffset.gt-xs], [fxFlexOffset.gt-sm], [fxFlexOffset.gt-md], [fxFlexOffset.gt-lg]", inputs: ["fxFlexOffset", "fxFlexOffset.xs", "fxFlexOffset.sm", "fxFlexOffset.md", "fxFlexOffset.lg", "fxFlexOffset.xl", "fxFlexOffset.lt-sm", "fxFlexOffset.lt-md", "fxFlexOffset.lt-lg", "fxFlexOffset.lt-xl", "fxFlexOffset.gt-xs", "fxFlexOffset.gt-sm", "fxFlexOffset.gt-md", "fxFlexOffset.gt-lg"] }, { type: i2.PlausibleEventDirective, selector: "[libPlausibleEvent]", inputs: ["libPlausibleEvent"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i8.TranslatePipe } });
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SideNavMenuComponent, decorators: [{
|
|
80
|
+
type: Component,
|
|
81
|
+
args: [{ selector: 'lib-side-nav-menu', template: "<div class=\"menu-container\" [style.width]=\"sideNavWidth\" fxLayout=\"column\" [class.collapsed]=\"collapsed\">\r\n <div class=\"content\" fxLayout=\"column\" fxFlexFill>\r\n <a [libPlausibleEvent]=\"LOGOCLICK_PLAUSIBLE_EVENT\" fxFlex=\"3.125em\" [href]=\"baseUrl\" [attr.aria-label]=\"'MENU.ARIA_LABELS.LOGO' | translate\" (click)=\"logoClick($event)\"\r\n fxLayoutAlign=\"center center\" fxFlexOffset=\"1em\">\r\n <img class=\"menu-logo\" [src]=\"menuLogoImage\" alt=\"\" />\r\n </a>\r\n <div class=\"menu-wrapper\" fxLayout=\"column\" fxFlex>\r\n <menu-columns role=\"navigation\" fxFlex [labelsVisible]=\"!collapsed\" [direction]=\"direction\"\r\n [hideSelectedCustomId]=\"hideSelectedCustomId\" [showChildren]=\"false\" [strapiGroupBase]=\"strapiGroupBase\"\r\n [strapiDataLocation]=\"strapiDataLocation\" [menuItemGroups]=\"menuItemGroups\"></menu-columns>\r\n <div fxLayoutAlign=\"center center\">\r\n <button [libPlausibleEvent]=\"COLLAPSE_PLAUSIBLE_EVENT\" class=\"collapse-btn\" [disableRipple]=\"true\"\r\n *ngIf=\"!collapsed; else expandButton\" (click)=\"toggleCollapse()\" mat-button>\r\n <mat-icon>keyboard_arrow_left</mat-icon>\r\n <span> {{ \"MENU.COLLAPSE\" | translate }} </span>\r\n </button>\r\n <ng-template #expandButton>\r\n <button class=\"toggler\" [libPlausibleEvent]=\"EXPAND_PLAUSIBLE_EVENT\" mat-icon-button\r\n (click)=\"toggleCollapse()\">\r\n <mat-icon>keyboard_arrow_right</mat-icon>\r\n </button>\r\n </ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n", styles: [".menu-container{height:100%;overflow:auto;background:var(--base-100);border-right:1px solid var(--base-70)}.menu-container .content{padding:0 .8em}.menu-container .content .menu-logo{margin:auto;max-width:100%}.menu-container .divider{width:100%;margin:0}:host ::ng-deep .collapsed .menu-item{padding:calc(.125em + 1px)}:host ::ng-deep .collapsed .menu-item.active-menu-item{padding:.125em;border:1px solid var(--primary-accent);border-radius:var(--default-border-radius)}:host ::ng-deep button.collapse-btn{background-color:transparent;font-size:.8125rem;font-weight:400;line-height:1.25rem;letter-spacing:0px;text-align:left;padding:0!important}:host::ng-deep .toggler span.mat-button-focus-overlay{opacity:0!important}:host::ng-deep button.collapse-btn,:host::ng-deep button.toggler{margin-bottom:1em}:host::ng-deep button.collapse-btn .mat-button-focus-overlay,:host::ng-deep button.toggler .mat-button-focus-overlay{display:none}\n"] }]
|
|
82
|
+
}], ctorParameters: function () { return [{ type: i1.StrapiLinkService }, { type: i2.DOMService }, { type: undefined, decorators: [{
|
|
83
|
+
type: Optional
|
|
84
|
+
}, {
|
|
85
|
+
type: Inject,
|
|
86
|
+
args: [MENU_SHARED_CONFIG]
|
|
87
|
+
}] }]; }, propDecorators: { menuSettings: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}] } });
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-menu/src/lib/components/side-nav-menu/side-nav-menu.component.ts","../../../../../../projects/ngx-menu/src/lib/components/side-nav-menu/side-nav-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnInit, Optional } from '@angular/core';\r\nimport { DOMService, PlausibleEvent } from '@tilde-nlp/ngx-common';\r\nimport { StrapiLinkService } from '@tilde-nlp/ngx-strapi';\r\nimport { MENU_SHARED_CONFIG } from '../../injection-tokens';\r\nimport { MenuSharedConfig } from '../../models/menu-shared-config.model';\r\nimport { NavBaseComponent } from '../nav-base/nav-base.component';\r\nimport { SideNavSettings } from './models/side-nav-settings.model';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-side-nav-menu',\r\n  templateUrl: './side-nav-menu.component.html',\r\n  styleUrls: ['./side-nav-menu.component.scss']\r\n})\r\nexport class SideNavMenuComponent extends NavBaseComponent implements OnInit {\r\n  readonly COLLAPSED_LOCAL_STORAGE_KEY = \"TLD_MENU_SIDE_NAV_COLLAPSED\";\r\n\r\n  //#region Plausible event variables for collapse button\r\n  private readonly COLLAPSE_PLAUSIBLE_EVENT_ID = \"collapseMenu\";\r\n  private readonly COLLAPSE_PLAUSIBLE_ACTION_KEY = \"action\";\r\n  private readonly LOGOCLICK_PLAUSIBLE_ACTION_ID = \"tilde_logo_click\"\r\n\r\n  readonly LOGOCLICK_PLAUSIBLE_EVENT: PlausibleEvent = {\r\n    eventId: this.LOGOCLICK_PLAUSIBLE_ACTION_ID,\r\n    properties: []\r\n  }\r\n\r\n  readonly EXPAND_PLAUSIBLE_EVENT: PlausibleEvent = {\r\n    eventId: this.COLLAPSE_PLAUSIBLE_EVENT_ID,\r\n    properties: [{ key: this.COLLAPSE_PLAUSIBLE_ACTION_KEY, value: \"expand\" }]\r\n  }\r\n\r\n  readonly COLLAPSE_PLAUSIBLE_EVENT: PlausibleEvent = {\r\n    eventId: this.COLLAPSE_PLAUSIBLE_EVENT_ID,\r\n    properties: [{ key: this.COLLAPSE_PLAUSIBLE_ACTION_KEY, value: \"collapse\" }]\r\n  }\r\n  //#endregion\r\n\r\n  @Input() menuSettings: SideNavSettings = {\r\n    expandedWidth: '9.375em',\r\n    collapsedWidth: '5em',\r\n    menuLogo: '',\r\n    menuLogoCollapsed: '',\r\n    disableStrapi: false\r\n  }\r\n\r\n  collapsed = false;\r\n  readonly baseUrl: string | undefined;\r\n  get menuLogoImage(): string {\r\n    return this.collapsed\r\n      ? this.menuSettings.menuLogoCollapsed ?? this.menuSettings.menuLogo\r\n      : this.menuSettings.menuLogo;\r\n  }\r\n\r\n  get sideNavWidth(): string | undefined {\r\n    return this.collapsed ? this.menuSettings.collapsedWidth : this.menuSettings.expandedWidth;\r\n  }\r\n\r\n  constructor(public strapiLinkService: StrapiLinkService,\r\n    readonly domService: DOMService,\r\n    @Optional() @Inject(MENU_SHARED_CONFIG) menuSharedConfig: MenuSharedConfig) {\r\n    super();\r\n    this.baseUrl = menuSharedConfig.baseUrl || '';\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.getColapsedFromLocalStorage();\r\n  }\r\n\r\n  logoClick(event: MouseEvent): void {\r\n    this.strapiLinkService.strapiLinkClick(event);\r\n  }\r\n\r\n  toggleCollapse() {\r\n    this.collapsed = !this.collapsed;\r\n    this.setColapsedFromLocalStorage();\r\n  }\r\n\r\n  private getColapsedFromLocalStorage() {\r\n    if (!this.domService.localStorage) {\r\n      return;\r\n    }\r\n\r\n    this.collapsed = this.domService.localStorage.getItem(this.COLLAPSED_LOCAL_STORAGE_KEY) == 'true' ? true : false;\r\n  }\r\n\r\n  private setColapsedFromLocalStorage() {\r\n    if (!this.domService.localStorage) {\r\n      return;\r\n    }\r\n    this.domService.localStorage.setItem(this.COLLAPSED_LOCAL_STORAGE_KEY, this.collapsed.toString());\r\n  }\r\n}\r\n","<div class=\"menu-container\" [style.width]=\"sideNavWidth\" fxLayout=\"column\" [class.collapsed]=\"collapsed\">\r\n  <div class=\"content\" fxLayout=\"column\" fxFlexFill>\r\n    <a [libPlausibleEvent]=\"LOGOCLICK_PLAUSIBLE_EVENT\" fxFlex=\"3.125em\" [href]=\"baseUrl\" [attr.aria-label]=\"'MENU.ARIA_LABELS.LOGO' | translate\" (click)=\"logoClick($event)\"\r\n      fxLayoutAlign=\"center center\" fxFlexOffset=\"1em\">\r\n      <img class=\"menu-logo\" [src]=\"menuLogoImage\" alt=\"\" />\r\n    </a>\r\n    <div class=\"menu-wrapper\" fxLayout=\"column\" fxFlex>\r\n      <menu-columns role=\"navigation\" fxFlex [labelsVisible]=\"!collapsed\" [direction]=\"direction\"\r\n        [hideSelectedCustomId]=\"hideSelectedCustomId\" [showChildren]=\"false\" [strapiGroupBase]=\"strapiGroupBase\"\r\n        [strapiDataLocation]=\"strapiDataLocation\" [menuItemGroups]=\"menuItemGroups\"></menu-columns>\r\n      <div fxLayoutAlign=\"center center\">\r\n        <button [libPlausibleEvent]=\"COLLAPSE_PLAUSIBLE_EVENT\" class=\"collapse-btn\" [disableRipple]=\"true\"\r\n          *ngIf=\"!collapsed; else expandButton\" (click)=\"toggleCollapse()\" mat-button>\r\n          <mat-icon>keyboard_arrow_left</mat-icon>\r\n          <span> {{ \"MENU.COLLAPSE\" | translate }} </span>\r\n        </button>\r\n        <ng-template #expandButton>\r\n          <button class=\"toggler\" [libPlausibleEvent]=\"EXPAND_PLAUSIBLE_EVENT\" mat-icon-button\r\n            (click)=\"toggleCollapse()\">\r\n            <mat-icon>keyboard_arrow_right</mat-icon>\r\n          </button>\r\n        </ng-template>\r\n      </div>\r\n    </div>\r\n  </div>\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from "./menu-shared-config.token";
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL2luamVjdGlvbi10b2tlbnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0QkFBNEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL21lbnUtc2hhcmVkLWNvbmZpZy50b2tlblwiO1xyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const MENU_SHARED_CONFIG = "menu-shared-config";
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1zaGFyZWQtY29uZmlnLnRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL2xpYi9pbmplY3Rpb24tdG9rZW5zL21lbnUtc2hhcmVkLWNvbmZpZy50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBNRU5VX1NIQVJFRF9DT05GSUcgPSBcIm1lbnUtc2hhcmVkLWNvbmZpZ1wiO1xyXG4iXX0=
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { SideNavMenuComponent } from './components/side-nav-menu/side-nav-menu.component';
|
|
4
|
+
import { FlexLayoutModule } from '@angular/flex-layout';
|
|
5
|
+
import { RouterModule } from '@angular/router';
|
|
6
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
7
|
+
import { ModalNavMenuComponent } from './components/modal-nav-menu/modal-nav-menu.component';
|
|
8
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
9
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
10
|
+
import { MatListModule } from '@angular/material/list';
|
|
11
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
12
|
+
import { MenuItemIconComponent } from './components/menu-item-icon/menu-item-icon.component';
|
|
13
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
14
|
+
import { StarpiMenuService } from './services/strapi.service';
|
|
15
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
16
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
17
|
+
import { MENU_SHARED_CONFIG } from './injection-tokens/menu-shared-config.token';
|
|
18
|
+
import { NavBaseComponent } from './components/nav-base/nav-base.component';
|
|
19
|
+
import { MenuItemListComponent } from './components/menu-item-list/menu-item-list.component';
|
|
20
|
+
import { MenuStrapiItemListComponent } from './components/menu-strapi-item-list/menu-strapi-item-list.component';
|
|
21
|
+
import { PlausibleModule } from '@tilde-nlp/ngx-common';
|
|
22
|
+
import { MenuColumnsComponent } from './components/menu-columns/menu-columns.component';
|
|
23
|
+
import * as i0 from "@angular/core";
|
|
24
|
+
export class MenuModule {
|
|
25
|
+
static forRoot(config) {
|
|
26
|
+
return {
|
|
27
|
+
ngModule: MenuModule,
|
|
28
|
+
providers: [
|
|
29
|
+
{ provide: MENU_SHARED_CONFIG, useValue: config }
|
|
30
|
+
]
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
MenuModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: MenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
35
|
+
MenuModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: MenuModule, declarations: [SideNavMenuComponent,
|
|
36
|
+
ModalNavMenuComponent,
|
|
37
|
+
MenuItemIconComponent,
|
|
38
|
+
NavBaseComponent,
|
|
39
|
+
MenuItemListComponent,
|
|
40
|
+
MenuStrapiItemListComponent,
|
|
41
|
+
MenuColumnsComponent], imports: [HttpClientModule,
|
|
42
|
+
FlexLayoutModule,
|
|
43
|
+
RouterModule,
|
|
44
|
+
CommonModule,
|
|
45
|
+
MatTooltipModule,
|
|
46
|
+
MatDialogModule,
|
|
47
|
+
MatButtonModule,
|
|
48
|
+
MatListModule,
|
|
49
|
+
MatMenuModule,
|
|
50
|
+
MatIconModule,
|
|
51
|
+
TranslateModule,
|
|
52
|
+
PlausibleModule], exports: [SideNavMenuComponent,
|
|
53
|
+
ModalNavMenuComponent,
|
|
54
|
+
MenuItemIconComponent,
|
|
55
|
+
MenuStrapiItemListComponent,
|
|
56
|
+
MenuColumnsComponent] });
|
|
57
|
+
MenuModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: MenuModule, providers: [
|
|
58
|
+
StarpiMenuService
|
|
59
|
+
], imports: [[
|
|
60
|
+
HttpClientModule,
|
|
61
|
+
FlexLayoutModule,
|
|
62
|
+
RouterModule,
|
|
63
|
+
CommonModule,
|
|
64
|
+
MatTooltipModule,
|
|
65
|
+
MatDialogModule,
|
|
66
|
+
MatButtonModule,
|
|
67
|
+
MatListModule,
|
|
68
|
+
MatMenuModule,
|
|
69
|
+
MatIconModule,
|
|
70
|
+
TranslateModule,
|
|
71
|
+
PlausibleModule
|
|
72
|
+
]] });
|
|
73
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: MenuModule, decorators: [{
|
|
74
|
+
type: NgModule,
|
|
75
|
+
args: [{
|
|
76
|
+
declarations: [
|
|
77
|
+
SideNavMenuComponent,
|
|
78
|
+
ModalNavMenuComponent,
|
|
79
|
+
MenuItemIconComponent,
|
|
80
|
+
NavBaseComponent,
|
|
81
|
+
MenuItemListComponent,
|
|
82
|
+
MenuStrapiItemListComponent,
|
|
83
|
+
MenuColumnsComponent
|
|
84
|
+
],
|
|
85
|
+
providers: [
|
|
86
|
+
StarpiMenuService
|
|
87
|
+
],
|
|
88
|
+
imports: [
|
|
89
|
+
HttpClientModule,
|
|
90
|
+
FlexLayoutModule,
|
|
91
|
+
RouterModule,
|
|
92
|
+
CommonModule,
|
|
93
|
+
MatTooltipModule,
|
|
94
|
+
MatDialogModule,
|
|
95
|
+
MatButtonModule,
|
|
96
|
+
MatListModule,
|
|
97
|
+
MatMenuModule,
|
|
98
|
+
MatIconModule,
|
|
99
|
+
TranslateModule,
|
|
100
|
+
PlausibleModule
|
|
101
|
+
],
|
|
102
|
+
exports: [
|
|
103
|
+
SideNavMenuComponent,
|
|
104
|
+
ModalNavMenuComponent,
|
|
105
|
+
MenuItemIconComponent,
|
|
106
|
+
MenuStrapiItemListComponent,
|
|
107
|
+
MenuColumnsComponent
|
|
108
|
+
]
|
|
109
|
+
}]
|
|
110
|
+
}] });
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL21lbnUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvREFBb0QsQ0FBQztBQUMxRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDN0YsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzdGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFeEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDNUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDN0YsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDakgsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtEQUFrRCxDQUFDOztBQXFDeEYsTUFBTSxPQUFPLFVBQVU7SUFDckIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUF3QjtRQUNyQyxPQUFPO1lBQ0wsUUFBUSxFQUFFLFVBQVU7WUFDcEIsU0FBUyxFQUFFO2dCQUNULEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUU7YUFDbEQ7U0FDRixDQUFDO0lBQ0osQ0FBQzs7dUdBUlUsVUFBVTt3R0FBVixVQUFVLGlCQWpDbkIsb0JBQW9CO1FBQ3BCLHFCQUFxQjtRQUNyQixxQkFBcUI7UUFDckIsZ0JBQWdCO1FBQ2hCLHFCQUFxQjtRQUNyQiwyQkFBMkI7UUFDM0Isb0JBQW9CLGFBTXBCLGdCQUFnQjtRQUNoQixnQkFBZ0I7UUFDaEIsWUFBWTtRQUNaLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsZUFBZTtRQUNmLGVBQWU7UUFDZixhQUFhO1FBQ2IsYUFBYTtRQUNiLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZSxhQUdmLG9CQUFvQjtRQUNwQixxQkFBcUI7UUFDckIscUJBQXFCO1FBQ3JCLDJCQUEyQjtRQUMzQixvQkFBb0I7d0dBR1gsVUFBVSxhQXpCVjtRQUNULGlCQUFpQjtLQUNsQixZQUNRO1lBQ1AsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixlQUFlO1lBQ2YsZUFBZTtZQUNmLGFBQWE7WUFDYixhQUFhO1lBQ2IsYUFBYTtZQUNiLGVBQWU7WUFDZixlQUFlO1NBQ2hCOzJGQVNVLFVBQVU7a0JBbkN0QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixvQkFBb0I7d0JBQ3BCLHFCQUFxQjt3QkFDckIscUJBQXFCO3dCQUNyQixnQkFBZ0I7d0JBQ2hCLHFCQUFxQjt3QkFDckIsMkJBQTJCO3dCQUMzQixvQkFBb0I7cUJBQ3JCO29CQUNELFNBQVMsRUFBRTt3QkFDVCxpQkFBaUI7cUJBQ2xCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsWUFBWTt3QkFDWixZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTtxQkFDaEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG9CQUFvQjt3QkFDcEIscUJBQXFCO3dCQUNyQixxQkFBcUI7d0JBQ3JCLDJCQUEyQjt3QkFDM0Isb0JBQW9CO3FCQUNyQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcclxuaW1wb3J0IHsgU2lkZU5hdk1lbnVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvc2lkZS1uYXYtbWVudS9zaWRlLW5hdi1tZW51LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZsZXhMYXlvdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mbGV4LWxheW91dCc7XHJcbmltcG9ydCB7IFJvdXRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcclxuaW1wb3J0IHsgTW9kYWxOYXZNZW51Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL21vZGFsLW5hdi1tZW51L21vZGFsLW5hdi1tZW51LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdExpc3RNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9saXN0JztcclxuaW1wb3J0IHsgTWF0TWVudU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL21lbnUnO1xyXG5pbXBvcnQgeyBNZW51SXRlbUljb25Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvbWVudS1pdGVtLWljb24vbWVudS1pdGVtLWljb24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBTdGFycGlNZW51U2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvc3RyYXBpLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcclxuaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgTWVudVNoYXJlZENvbmZpZyB9IGZyb20gJy4vbW9kZWxzL21lbnUtc2hhcmVkLWNvbmZpZy5tb2RlbCc7XHJcbmltcG9ydCB7IE1FTlVfU0hBUkVEX0NPTkZJRyB9IGZyb20gJy4vaW5qZWN0aW9uLXRva2Vucy9tZW51LXNoYXJlZC1jb25maWcudG9rZW4nO1xyXG5pbXBvcnQgeyBOYXZCYXNlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL25hdi1iYXNlL25hdi1iYXNlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1lbnVJdGVtTGlzdENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9tZW51LWl0ZW0tbGlzdC9tZW51LWl0ZW0tbGlzdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBNZW51U3RyYXBpSXRlbUxpc3RDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvbWVudS1zdHJhcGktaXRlbS1saXN0L21lbnUtc3RyYXBpLWl0ZW0tbGlzdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBQbGF1c2libGVNb2R1bGUgfSBmcm9tICdAdGlsZGUtbmxwL25neC1jb21tb24nO1xyXG5pbXBvcnQgeyBNZW51Q29sdW1uc0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9tZW51LWNvbHVtbnMvbWVudS1jb2x1bW5zLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgU2lkZU5hdk1lbnVDb21wb25lbnQsXHJcbiAgICBNb2RhbE5hdk1lbnVDb21wb25lbnQsXHJcbiAgICBNZW51SXRlbUljb25Db21wb25lbnQsXHJcbiAgICBOYXZCYXNlQ29tcG9uZW50LFxyXG4gICAgTWVudUl0ZW1MaXN0Q29tcG9uZW50LFxyXG4gICAgTWVudVN0cmFwaUl0ZW1MaXN0Q29tcG9uZW50LFxyXG4gICAgTWVudUNvbHVtbnNDb21wb25lbnRcclxuICBdLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAgU3RhcnBpTWVudVNlcnZpY2VcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIEh0dHBDbGllbnRNb2R1bGUsXHJcbiAgICBGbGV4TGF5b3V0TW9kdWxlLFxyXG4gICAgUm91dGVyTW9kdWxlLFxyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcclxuICAgIE1hdERpYWxvZ01vZHVsZSxcclxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgIE1hdExpc3RNb2R1bGUsXHJcbiAgICBNYXRNZW51TW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcclxuICAgIFBsYXVzaWJsZU1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgU2lkZU5hdk1lbnVDb21wb25lbnQsXHJcbiAgICBNb2RhbE5hdk1lbnVDb21wb25lbnQsXHJcbiAgICBNZW51SXRlbUljb25Db21wb25lbnQsXHJcbiAgICBNZW51U3RyYXBpSXRlbUxpc3RDb21wb25lbnQsXHJcbiAgICBNZW51Q29sdW1uc0NvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIE1lbnVNb2R1bGUge1xyXG4gIHN0YXRpYyBmb3JSb290KGNvbmZpZzogTWVudVNoYXJlZENvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8TWVudU1vZHVsZT4ge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgbmdNb2R1bGU6IE1lbnVNb2R1bGUsXHJcbiAgICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIHsgcHJvdmlkZTogTUVOVV9TSEFSRURfQ09ORklHLCB1c2VWYWx1ZTogY29uZmlnIH1cclxuICAgICAgXVxyXG4gICAgfTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW1lbnUtaXRlbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tZW51L3NyYy9saWIvbW9kZWxzL2N1c3RvbS1tZW51LWl0ZW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElzQWN0aXZlTWF0Y2hPcHRpb25zIH0gZnJvbSBcIkBhbmd1bGFyL3JvdXRlclwiO1xyXG5pbXBvcnQgeyBQbGF1c2libGVFdmVudCB9IGZyb20gXCJAdGlsZGUtbmxwL25neC1jb21tb25cIjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ3VzdG9tTWVudUl0ZW0ge1xyXG4gIHRpdGxlOiBzdHJpbmcsXHJcbiAgaWNvbj86IHN0cmluZyxcclxuICAvKiogU2V0IHRvIHRydWUgaWYgYW5ndWxhciBtYXRlcmlhbCBpY29uLiBGYWxzZSBpZiBjdXN0b20gaWNvbi4gKiovXHJcbiAgbWF0ZXJpYWxJY29uPzogYm9vbGVhbjtcclxuICBsaW5rOiBzdHJpbmc7XHJcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xyXG4gIC8qKiBGb3Igc3RyYXBpIG1lbnUgaXRlbXMgKi9cclxuICBjdXN0b21JZD86IHN0cmluZztcclxuICByb3V0ZXJMaW5rQWN0aXZlT3B0aW9ucz86IElzQWN0aXZlTWF0Y2hPcHRpb25zO1xyXG4gIGV4dGVybmFsTGluaz86IGJvb2xlYW47XHJcbiAgLy9UeXBlIGlzIHVzZWQgZnJvbSBjb21tb24gbGliIGJlY2F1c2UgaXQgaXMgY2xvc2VyIHJlbGF0ZWQgdG8gZGlyZWN0aXZlIHdoZXJlIHRoaXMgaXMgdXNlZC5cclxuICAvKiogUGxhdXNpYmxlIGN1c3RvbSBldmVudC4qL1xyXG4gIHBsYXVzaWJsZUV2ZW50PzogUGxhdXNpYmxlRXZlbnQ7XHJcbiAgLyoqIFJlY3Vyc2l2ZSBjaGlsZCBlbGVtZW50cyAqL1xyXG4gIGNoaWxkcmVuPzogQ3VzdG9tTWVudUl0ZW1bXTtcclxuICAvKiogSWYgaGFzIGNoaWxkcmVuLCB0aGlzIHByb3BlcnR5IGlzIHJlc3BvbnNpYmxlIGZvciBjaGlsZCBlbGVtZW50IGNvbGxhcHNpbmcgKi9cclxuICBleHBhbmRlZD86IGJvb2xlYW47XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from "./menu-shared-config.model";
|
|
2
|
+
export * from "./custom-menu-item";
|
|
3
|
+
export * from "./menu-icon-strapi-extension.const";
|
|
4
|
+
export * from "./menu-item-group.model";
|
|
5
|
+
export * from "./menu-layout-direction.model";
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL21vZGVscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9tZW51LXNoYXJlZC1jb25maWcubW9kZWxcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vY3VzdG9tLW1lbnUtaXRlbVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9tZW51LWljb24tc3RyYXBpLWV4dGVuc2lvbi5jb25zdFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9tZW51LWl0ZW0tZ3JvdXAubW9kZWxcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbWVudS1sYXlvdXQtZGlyZWN0aW9uLm1vZGVsXCI7Il19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const MENU_ICON_STRAPI_EXTENSION = ".svg";
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1pY29uLXN0cmFwaS1leHRlbnNpb24uY29uc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWVudS9zcmMvbGliL21vZGVscy9tZW51LWljb24tc3RyYXBpLWV4dGVuc2lvbi5jb25zdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSwwQkFBMEIsR0FBRyxNQUFNLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgTUVOVV9JQ09OX1NUUkFQSV9FWFRFTlNJT04gPSBcIi5zdmdcIjtcclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1pdGVtLWdyb3VwLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL2xpYi9tb2RlbHMvbWVudS1pdGVtLWdyb3VwLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDdXN0b21NZW51SXRlbSB9IGZyb20gXCIuL2N1c3RvbS1tZW51LWl0ZW1cIjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTWVudUl0ZW1Hcm91cCBleHRlbmRzIE1lbnVJdGVtR3JvdXBCYXNlIHtcclxuICBpdGVtczogQ3VzdG9tTWVudUl0ZW1bXTtcclxufVxyXG5cclxuLy8gU2VwZXJhdGUgaW50ZXJmYWNlIGJlY2F1c2UgZm9yIHN0cmFwaSBncm91cCB0aGVyZSBzaG91bGQgYmUgbm8gaXRlbXMsIHNpbmNlIHRoZXkgYXJlIGxvYWRlZCB3aGVuIGNvbXBvbmVudCBpcyBpbml0aWFsaXplZC5cclxuZXhwb3J0IGludGVyZmFjZSBNZW51SXRlbUdyb3VwQmFzZSB7XHJcbiAgdGl0bGU/OiBzdHJpbmc7XHJcbiAgYm90dG9tRGl2aWRlcj86IGJvb2xlYW47XHJcbiAgc2hvd1RpdGxlPzogYm9vbGVhbjtcclxufSJdfQ==
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export var MenuLayoutDirection;
|
|
2
|
+
(function (MenuLayoutDirection) {
|
|
3
|
+
MenuLayoutDirection["column"] = "column";
|
|
4
|
+
MenuLayoutDirection["row"] = "row";
|
|
5
|
+
})(MenuLayoutDirection || (MenuLayoutDirection = {}));
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1sYXlvdXQtZGlyZWN0aW9uLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL2xpYi9tb2RlbHMvbWVudS1sYXlvdXQtZGlyZWN0aW9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE1BQU0sQ0FBTixJQUFZLG1CQUdYO0FBSEQsV0FBWSxtQkFBbUI7SUFDN0Isd0NBQWlCLENBQUE7SUFDakIsa0NBQVcsQ0FBQTtBQUNiLENBQUMsRUFIVyxtQkFBbUIsS0FBbkIsbUJBQW1CLFFBRzlCIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbmV4cG9ydCBlbnVtIE1lbnVMYXlvdXREaXJlY3Rpb24ge1xyXG4gIGNvbHVtbiA9IFwiY29sdW1uXCIsXHJcbiAgcm93ID0gXCJyb3dcIlxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1zaGFyZWQtY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL2xpYi9tb2RlbHMvbWVudS1zaGFyZWQtY29uZmlnLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJc0FjdGl2ZU1hdGNoT3B0aW9ucyB9IGZyb20gXCJAYW5ndWxhci9yb3V0ZXJcIjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTWVudVNoYXJlZENvbmZpZ3tcclxuICAvKiogYmFzZSB1cmwgZm9yIG1lbnUgaXRlbXMgd2l0aCByZWxhdGl2ZSB1cmwgKi9cclxuICBiYXNlVXJsPzogc3RyaW5nO1xyXG4gIC8qKiBDdXN0b20gYXBwIElEIHNvIHRoYXQgbWVudSBrbm93cyB3aGljaCBlbGVtZW50IGlzIGFjdGl2ZSwgaWYgbm8gcm91dGVyIGxpbmsgaXMgYWN0aXZlICovXHJcbiAgY3VzdG9tSWQ/OiBzdHJpbmc7XHJcbiAgLyoqIEZvciBzZWxlY3RpbmcgYWN0aXZlIGVsZW1lbnQsIGFjdGl2ZSBtYXRjaCBvcHRpb25zIG1pZ2h0IGRwZW5kIGZyb20gcHJvamVjdCBzcGVjaWZpY3MgKi9cclxuICBhY3RpdmVNYXRjaE9wdGlvbnM/OiBJc0FjdGl2ZU1hdGNoT3B0aW9ucztcclxuICAvKiogRGlzYWJsaW5nIHN0cmFwaSBmb3IgYWxsIG1lbnVzLiAqL1xyXG4gIGRpc2FibGVTdHJhcGk/OiBib29sZWFuO1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { Inject, Injectable, Optional } from "@angular/core";
|
|
2
|
+
import { STRAPI_API_CONFIG_TOKEN } from "@tilde-nlp/ngx-strapi";
|
|
3
|
+
import { map } from "rxjs";
|
|
4
|
+
import { CollectionTypes } from "@tilde-nlp/strapi-models";
|
|
5
|
+
import { MENU_SHARED_CONFIG } from "../injection-tokens";
|
|
6
|
+
import { MENU_ICON_STRAPI_EXTENSION } from "../models/menu-icon-strapi-extension.const";
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@tilde-nlp/ngx-strapi";
|
|
9
|
+
import * as i2 from "@tilde-nlp/ngx-common";
|
|
10
|
+
export class StarpiMenuService {
|
|
11
|
+
constructor(strapiSubscription, menuConfig, strapiConfig, iconService) {
|
|
12
|
+
this.strapiSubscription = strapiSubscription;
|
|
13
|
+
this.menuConfig = menuConfig;
|
|
14
|
+
this.iconService = iconService;
|
|
15
|
+
this.svgIconNamePrefix = "strapi-menu-icon-";
|
|
16
|
+
this.imgBaseUrl = '';
|
|
17
|
+
this.imgBaseUrl = strapiConfig.apiUrl;
|
|
18
|
+
}
|
|
19
|
+
getMenuItems() {
|
|
20
|
+
const responseObs = this.strapiSubscription.subscribeCollectionType(CollectionTypes.MENU_ITEMS)
|
|
21
|
+
.pipe(map((items) => {
|
|
22
|
+
// Remove disabled items so they are not processed later.
|
|
23
|
+
const convertedItems = [];
|
|
24
|
+
if (!items || items.length === 0) {
|
|
25
|
+
return convertedItems;
|
|
26
|
+
}
|
|
27
|
+
items = items.filter(item => !item.disabled);
|
|
28
|
+
items.forEach((menu) => {
|
|
29
|
+
menu.link = this.addBaseUrlIfNecessary(menu.link);
|
|
30
|
+
const originalMenuIcon = menu.icon.data.attributes;
|
|
31
|
+
if (originalMenuIcon.url.startsWith('/')) {
|
|
32
|
+
originalMenuIcon.url = this.imgBaseUrl + originalMenuIcon.url;
|
|
33
|
+
}
|
|
34
|
+
if (originalMenuIcon.ext === MENU_ICON_STRAPI_EXTENSION) {
|
|
35
|
+
// add custom prefix so that it is not easy to mix with other icons in registry
|
|
36
|
+
menu.icon.data.attributes.name = this.svgIconNamePrefix + originalMenuIcon.name;
|
|
37
|
+
this.iconService.registerIconFromUrl(originalMenuIcon.name, originalMenuIcon.url);
|
|
38
|
+
}
|
|
39
|
+
convertedItems.push(this.convertToCustomMenuItem(menu));
|
|
40
|
+
});
|
|
41
|
+
return convertedItems;
|
|
42
|
+
}));
|
|
43
|
+
return responseObs;
|
|
44
|
+
}
|
|
45
|
+
unsubscribe() {
|
|
46
|
+
this.strapiSubscription.unsubscribe(CollectionTypes.MENU_ITEMS);
|
|
47
|
+
}
|
|
48
|
+
addBaseUrlIfNecessary(link) {
|
|
49
|
+
if (!this.menuConfig?.baseUrl) {
|
|
50
|
+
return link;
|
|
51
|
+
}
|
|
52
|
+
try {
|
|
53
|
+
new URL(link);
|
|
54
|
+
// eslint-disable-next-line no-empty
|
|
55
|
+
}
|
|
56
|
+
catch { }
|
|
57
|
+
try {
|
|
58
|
+
return new URL(link, this.menuConfig.baseUrl).href;
|
|
59
|
+
}
|
|
60
|
+
catch {
|
|
61
|
+
return link;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
convertToCustomMenuItem(item) {
|
|
65
|
+
return {
|
|
66
|
+
icon: item.icon.data.attributes.name,
|
|
67
|
+
link: item.link,
|
|
68
|
+
title: item.title,
|
|
69
|
+
externalLink: item.externalLink,
|
|
70
|
+
// Material icons should not come from strapi
|
|
71
|
+
materialIcon: false,
|
|
72
|
+
plausibleEvent: item.plausibleEvent,
|
|
73
|
+
customId: item.customId
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
StarpiMenuService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: StarpiMenuService, deps: [{ token: i1.StrapiSubscriptionService }, { token: MENU_SHARED_CONFIG, optional: true }, { token: STRAPI_API_CONFIG_TOKEN }, { token: i2.IconService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
78
|
+
StarpiMenuService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: StarpiMenuService, providedIn: 'root' });
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: StarpiMenuService, decorators: [{
|
|
80
|
+
type: Injectable,
|
|
81
|
+
args: [{
|
|
82
|
+
providedIn: 'root'
|
|
83
|
+
}]
|
|
84
|
+
}], ctorParameters: function () { return [{ type: i1.StrapiSubscriptionService }, { type: undefined, decorators: [{
|
|
85
|
+
type: Optional
|
|
86
|
+
}, {
|
|
87
|
+
type: Inject,
|
|
88
|
+
args: [MENU_SHARED_CONFIG]
|
|
89
|
+
}] }, { type: undefined, decorators: [{
|
|
90
|
+
type: Inject,
|
|
91
|
+
args: [STRAPI_API_CONFIG_TOKEN]
|
|
92
|
+
}] }, { type: i2.IconService }]; } });
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"strapi.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-menu/src/lib/services/strapi.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional } from \"@angular/core\";\r\nimport { IconService } from \"@tilde-nlp/ngx-common\";\r\nimport { StrapiApiConfig, StrapiSubscriptionService, STRAPI_API_CONFIG_TOKEN } from \"@tilde-nlp/ngx-strapi\";\r\nimport { map, Observable } from \"rxjs\";\r\nimport { CollectionTypes, MenuItems } from \"@tilde-nlp/strapi-models\";\r\nimport { MENU_SHARED_CONFIG } from \"../injection-tokens\";\r\nimport { CustomMenuItem } from \"../models/custom-menu-item\";\r\nimport { MENU_ICON_STRAPI_EXTENSION } from \"../models/menu-icon-strapi-extension.const\";\r\nimport { MenuSharedConfig } from \"../models/menu-shared-config.model\";\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class StarpiMenuService {\r\n  readonly svgIconNamePrefix = \"strapi-menu-icon-\";\r\n  imgBaseUrl = '';\r\n\r\n  constructor(private readonly strapiSubscription: StrapiSubscriptionService,\r\n    @Optional() @Inject(MENU_SHARED_CONFIG) private readonly menuConfig: MenuSharedConfig,\r\n    @Inject(STRAPI_API_CONFIG_TOKEN) strapiConfig: StrapiApiConfig,\r\n    private readonly iconService: IconService) {\r\n    this.imgBaseUrl = strapiConfig.apiUrl;\r\n  }\r\n\r\n  getMenuItems(): Observable<CustomMenuItem[]> {\r\n    const responseObs = this.strapiSubscription.subscribeCollectionType<MenuItems>(CollectionTypes.MENU_ITEMS)\r\n      .pipe(map((items: MenuItems[] | null) => {\r\n        // Remove disabled items so they are not processed later.\r\n\r\n        const convertedItems: CustomMenuItem[] = [];\r\n        if (!items || items.length === 0) {\r\n          return convertedItems;\r\n        }\r\n        items = items.filter(item => !item.disabled);\r\n        items.forEach((menu: MenuItems) => {\r\n          menu.link = this.addBaseUrlIfNecessary(menu.link);\r\n          const originalMenuIcon = menu.icon.data.attributes;\r\n          if (originalMenuIcon.url.startsWith('/')) {\r\n            originalMenuIcon.url = this.imgBaseUrl + originalMenuIcon.url;\r\n          }\r\n\r\n          if (originalMenuIcon.ext === MENU_ICON_STRAPI_EXTENSION) {\r\n            // add custom prefix so that it is not easy to mix with other icons in registry\r\n            menu.icon.data.attributes.name = this.svgIconNamePrefix + originalMenuIcon.name;\r\n            this.iconService.registerIconFromUrl(originalMenuIcon.name, originalMenuIcon.url);\r\n          }\r\n\r\n          convertedItems.push(this.convertToCustomMenuItem(menu));\r\n        });\r\n        return convertedItems;\r\n      }));\r\n    return responseObs;\r\n  }\r\n\r\n  unsubscribe(): void {\r\n    this.strapiSubscription.unsubscribe(CollectionTypes.MENU_ITEMS);\r\n  }\r\n\r\n  private addBaseUrlIfNecessary(link: string): string {\r\n    if (!this.menuConfig?.baseUrl) {\r\n      return link;\r\n    }\r\n    try {\r\n      new URL(link);\r\n      // eslint-disable-next-line no-empty\r\n    } catch { }\r\n    try {\r\n      return new URL(link, this.menuConfig.baseUrl).href;\r\n    } catch {\r\n      return link;\r\n    }\r\n  }\r\n\r\n  private convertToCustomMenuItem(item: MenuItems): CustomMenuItem {\r\n    return {\r\n      icon: item.icon.data.attributes.name,\r\n      link: item.link,\r\n      title: item.title,\r\n      externalLink: item.externalLink,\r\n      // Material icons should not come from strapi\r\n      materialIcon: false,\r\n      plausibleEvent: item.plausibleEvent,\r\n      customId: item.customId\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of ngx-menu
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/components/side-nav-menu';
|
|
5
|
+
export * from './lib/injection-tokens';
|
|
6
|
+
export * from './lib/models';
|
|
7
|
+
export * from './lib/menu.module';
|
|
8
|
+
export * from './lib/components/menu-item-icon/menu.model';
|
|
9
|
+
export * from './lib/components/side-nav-menu/side-nav-menu.component';
|
|
10
|
+
export * from './lib/components/modal-nav-menu/modal-nav-menu.component';
|
|
11
|
+
export * from './lib/components/menu-item-icon/menu-item-icon.component';
|
|
12
|
+
export * from './lib/components/menu-columns/menu-columns.component';
|
|
13
|
+
export * from './lib/components/menu-strapi-item-list/menu-strapi-item-list.component';
|
|
14
|
+
export * from './lib/components/nav-base/nav-base.component';
|
|
15
|
+
export * from './lib/components/nav-base/models';
|
|
16
|
+
export * from './lib/services/strapi.service';
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1tZW51L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBR0gsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsd0VBQXdFLENBQUM7QUFDdkYsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygbmd4LW1lbnVcclxuICovXHJcblxyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9zaWRlLW5hdi1tZW51JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW5qZWN0aW9uLXRva2Vucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lbnUubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9tZW51LWl0ZW0taWNvbi9tZW51Lm1vZGVsJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9zaWRlLW5hdi1tZW51L3NpZGUtbmF2LW1lbnUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9tb2RhbC1uYXYtbWVudS9tb2RhbC1uYXYtbWVudS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL21lbnUtaXRlbS1pY29uL21lbnUtaXRlbS1pY29uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvbWVudS1jb2x1bW5zL21lbnUtY29sdW1ucy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL21lbnUtc3RyYXBpLWl0ZW0tbGlzdC9tZW51LXN0cmFwaS1pdGVtLWxpc3QuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9uYXYtYmFzZS9uYXYtYmFzZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL25hdi1iYXNlL21vZGVscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL3N0cmFwaS5zZXJ2aWNlJztcclxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZGUtbmxwLW5neC1tZW51LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1lbnUvc3JjL3RpbGRlLW5scC1uZ3gtbWVudS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
|