ngx-material-navigation 1.0.5 → 1.1.5
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/components/footer/footer.component.d.ts +9 -3
- package/components/navbar/navbar.component.d.ts +11 -9
- package/esm2020/components/footer/footer-element/footer-element.component.mjs +2 -2
- package/esm2020/components/footer/footer.component.mjs +23 -10
- package/esm2020/components/navbar/nav-element/nav-element.component.mjs +2 -2
- package/esm2020/components/navbar/nav-menu/nav-menu.component.mjs +2 -2
- package/esm2020/components/navbar/navbar.component.mjs +43 -34
- package/esm2020/models/footer.model.mjs +1 -1
- package/esm2020/models/nav.model.mjs +1 -1
- package/esm2020/services/nav.service.mjs +115 -0
- package/esm2020/utilities/nav.utilities.mjs +8 -143
- package/fesm2015/ngx-material-navigation.mjs +181 -182
- package/fesm2015/ngx-material-navigation.mjs.map +1 -1
- package/fesm2020/ngx-material-navigation.mjs +180 -182
- package/fesm2020/ngx-material-navigation.mjs.map +1 -1
- package/models/footer.model.d.ts +4 -0
- package/models/nav.model.d.ts +4 -0
- package/package.json +1 -1
- package/services/nav.service.d.ts +57 -0
- package/utilities/nav.utilities.d.ts +1 -66
|
@@ -1,11 +1,13 @@
|
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
1
2
|
import { FooterRow } from '../../models/footer.model';
|
|
2
|
-
import {
|
|
3
|
+
import { NgxMatNavigationService } from '../../services/nav.service';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
/**
|
|
5
6
|
* Displays a footer based on the provided input data.
|
|
6
7
|
*/
|
|
7
|
-
export declare class NgxMatNavigationFooterComponent {
|
|
8
|
-
|
|
8
|
+
export declare class NgxMatNavigationFooterComponent implements OnInit, OnDestroy {
|
|
9
|
+
navService: NgxMatNavigationService;
|
|
10
|
+
private readonly onDestroy;
|
|
9
11
|
/**
|
|
10
12
|
* The minimum height of the footer.
|
|
11
13
|
*/
|
|
@@ -14,6 +16,10 @@ export declare class NgxMatNavigationFooterComponent {
|
|
|
14
16
|
* The footer rows to build the footer from.
|
|
15
17
|
*/
|
|
16
18
|
footerRows: FooterRow[];
|
|
19
|
+
internalFooterRows: FooterRow[];
|
|
20
|
+
constructor(navService: NgxMatNavigationService);
|
|
21
|
+
ngOnInit(): void;
|
|
22
|
+
ngOnDestroy(): void;
|
|
17
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgxMatNavigationFooterComponent, never>;
|
|
18
24
|
static ɵcmp: i0.ɵɵComponentDeclaration<NgxMatNavigationFooterComponent, "ngx-mat-navigation-footer", never, { "minHeight": "minHeight"; "footerRows": "footerRows"; }, {}, never, never, false>;
|
|
19
25
|
}
|
|
@@ -1,18 +1,19 @@
|
|
|
1
|
-
import { AfterContentChecked, ElementRef, OnInit } from '@angular/core';
|
|
1
|
+
import { AfterContentChecked, ElementRef, OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { MatSidenav } from '@angular/material/sidenav';
|
|
3
3
|
import { DomSanitizer, SafeStyle } from '@angular/platform-browser';
|
|
4
4
|
import { NavElement } from '../../models/nav.model';
|
|
5
5
|
import { NavbarRow } from '../../models/navbar.model';
|
|
6
|
-
import {
|
|
6
|
+
import { NgxMatNavigationService } from '../../services/nav.service';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
/**
|
|
9
9
|
* The navbar component.
|
|
10
10
|
* Takes in your configuration and builds a toolbar as well as a sidenav accordingly.
|
|
11
11
|
* Also handles responsiveness.
|
|
12
12
|
*/
|
|
13
|
-
export declare class NgxMatNavigationNavbarComponent implements OnInit, AfterContentChecked {
|
|
13
|
+
export declare class NgxMatNavigationNavbarComponent implements OnInit, OnDestroy, AfterContentChecked {
|
|
14
14
|
private readonly sanitizer;
|
|
15
|
-
|
|
15
|
+
navService: NgxMatNavigationService;
|
|
16
|
+
private readonly onDestroy;
|
|
16
17
|
/**
|
|
17
18
|
* The navbar rows to build the navbar from.
|
|
18
19
|
*/
|
|
@@ -29,15 +30,16 @@ export declare class NgxMatNavigationNavbarComponent implements OnInit, AfterCon
|
|
|
29
30
|
* The minimum width of the sidenav.
|
|
30
31
|
*/
|
|
31
32
|
minSidenavWidth?: string;
|
|
32
|
-
sidenav
|
|
33
|
+
sidenav?: MatSidenav;
|
|
33
34
|
navbar?: ElementRef<HTMLElement>;
|
|
34
|
-
sidenavElements: NavElement[];
|
|
35
35
|
burgerMenu: NavElement;
|
|
36
36
|
sanitizedMinHeight: SafeStyle;
|
|
37
|
-
screenWidth: number;
|
|
38
37
|
screenWidthName: 'lg' | 'md' | 'sm';
|
|
39
|
-
|
|
38
|
+
internalNavbarRows: NavbarRow[];
|
|
39
|
+
internalSidenavElements: NavElement[];
|
|
40
|
+
constructor(sanitizer: DomSanitizer, navService: NgxMatNavigationService);
|
|
40
41
|
ngOnInit(): void;
|
|
42
|
+
ngOnDestroy(): void;
|
|
41
43
|
ngAfterContentChecked(): void;
|
|
42
44
|
private updateHeights;
|
|
43
45
|
/**
|
|
@@ -46,13 +48,13 @@ export declare class NgxMatNavigationNavbarComponent implements OnInit, AfterCon
|
|
|
46
48
|
* @throws When no height data is provided or the data is invalid.
|
|
47
49
|
*/
|
|
48
50
|
onResize(): void;
|
|
51
|
+
private getCurrentScreenWidthName;
|
|
49
52
|
/**
|
|
50
53
|
* Defines if the sidenav should be closed when the given element is clicked.
|
|
51
54
|
*
|
|
52
55
|
* @param element - The element that has been clicked.
|
|
53
56
|
*/
|
|
54
57
|
clickSidenavElement(element: NavElement): void;
|
|
55
|
-
private getCurrentScreenWidth;
|
|
56
58
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgxMatNavigationNavbarComponent, never>;
|
|
57
59
|
static ɵcmp: i0.ɵɵComponentDeclaration<NgxMatNavigationNavbarComponent, "ngx-mat-navigation-navbar", never, { "navbarRows": "navbarRows"; "minHeight": "minHeight"; "minHeightOtherElements": "minHeightOtherElements"; "minSidenavWidth": "minSidenavWidth"; }, {}, never, ["*"], false>;
|
|
58
60
|
}
|
|
@@ -18,7 +18,7 @@ export class FooterElementComponent {
|
|
|
18
18
|
}
|
|
19
19
|
ngOnInit() {
|
|
20
20
|
if (NavUtilities.isNavHtml(this.element)) {
|
|
21
|
-
this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(
|
|
21
|
+
this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(this.element.html));
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
24
|
ngAfterContentChecked() {
|
|
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
52
52
|
type: HostListener,
|
|
53
53
|
args: ['window:resize', ['$event']]
|
|
54
54
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"footer-element.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-navigation/src/components/footer/footer-element/footer-element.component.ts","../../../../../../projects/ngx-material-navigation/src/components/footer/footer-element/footer-element.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAuB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACvG,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAIhE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;AAEtE;;GAEG;AAMH,MAAM,OAAO,sBAAsB;IAiB/B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAfpD,iBAAY,GAAG,YAAY,CAAC;IAe2B,CAAC;IAExD,QAAQ;QACJ,IAAI,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACtC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,eAAe,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;SACjI;IACL,CAAC;IAED,qBAAqB;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAED;;OAEG;IAEH,QAAQ;QACJ,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAEO,YAAY;QAChB,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,aAA6B,CAAA,CAAC,WAAW,CAAC;IACnF,CAAC;;mHA3CQ,sBAAsB;uGAAtB,sBAAsB,iRCfnC,uwLAwGO;2FDzFM,sBAAsB;kBALlC,SAAS;+BACI,mCAAmC;mGAY7C,OAAO;sBADN,KAAK;gBAMN,UAAU;sBADT,SAAS;uBAAC,YAAY;gBAuBvB,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterContentChecked, Component, HostListener, Input, OnInit, ViewChild } from '@angular/core';\nimport { NavUtilities } from '../../../utilities/nav.utilities';\nimport { MatButton } from '@angular/material/button';\nimport { NavFooterElement } from '../../../models/footer.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { PurifyUtilities } from '../../../utilities/purify.utilities';\n\n/**\n * Displays a single Navigation Element.\n */\n@Component({\n    selector: 'ngx-mat-navigation-footer-element',\n    templateUrl: './footer-element.component.html',\n    styleUrls: ['./footer-element.component.scss']\n})\nexport class FooterElementComponent implements AfterContentChecked, OnInit {\n\n    NavUtilities = NavUtilities;\n\n    /**\n     * The element to display.\n     */\n    @Input()\n    element!: NavFooterElement;\n\n    sanitizedHtml?: SafeHtml;\n\n    @ViewChild('menuButton')\n    menuButton?: MatButton;\n\n    menuWidth!: number;\n\n    constructor(private readonly sanitizer: DomSanitizer) {}\n\n    ngOnInit(): void {\n        if (NavUtilities.isNavHtml(this.element)) {\n            this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(NavUtilities.asHtml(this.element).html));\n        }\n    }\n\n    ngAfterContentChecked(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    /**\n     * Updates the width of the menu to the value of its button.\n     */\n    @HostListener('window:resize', ['$event'])\n    onResize(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    private getMenuWidth(): number {\n        return (this.menuButton?._elementRef.nativeElement as HTMLElement).offsetWidth;\n    }\n}","<span [ngSwitch]=\"element.type\">\n    <!-- Title -->\n    <b *ngSwitchCase=\"'title'\">\n        <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n        {{NavUtilities.asTitle(element).title}}\n    </b>\n    <!-- Title with internal link -->\n    <a id=\"title-link\" *ngSwitchCase=\"'titleWithInternalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asTitleWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <b>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </b>\n    </a>\n    <!-- Title with external link -->\n    <a class=\"title-link\" *ngSwitchCase=\"'titleWithExternalLink'\"\n        [href]=\"NavUtilities.asTitleWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <h1>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </h1>\n    </a>\n    <!-- Image -->\n    <img mat-menu-item *ngSwitchCase=\"'image'\"\n        [src]=\"NavUtilities.asImage(element).url\"\n    >\n    <!-- Image with internal link -->\n    <a mat-menu-item disabled id=\"image-link\" *ngSwitchCase=\"'imageWithInternalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asImageWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <img [src]=\"NavUtilities.asImageWithInternalLink(element).url\">\n    </a>\n    <!-- Image with external link -->\n    <a mat-menu-item disabled id=\"image-link\" *ngSwitchCase=\"'imageWithExternalLink'\"\n        [href]=\"NavUtilities.asImageWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <img [src]=\"NavUtilities.asImageWithExternalLink(element).url\">\n    </a>\n    <!-- Button -->\n    <button *ngSwitchCase=\"'button'\"\n        mat-raised-button\n        (click)=\"NavUtilities.asButton(element).action()\"\n    >\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Flat Button -->\n    <button *ngSwitchCase=\"'buttonFlat'\" mat-button (click)=\"NavUtilities.asButton(element).action()\">\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Internal Link -->\n    <a mat-button *ngSwitchCase=\"'internalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n            : NavUtilities.asStringRoute(NavUtilities.asInternalLink(element).route)\"\n        [target]=\"NavUtilities.asInternalLink(element).openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asInternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <i *ngIf=\"NavUtilities.asInternalLink(element).icon\" [class]=\"NavUtilities.asInternalLink(element).icon\"></i> \n        {{NavUtilities.asInternalLink(element).name}}\n    </a>\n    <!-- External Link -->\n    <span *ngSwitchCase=\"'externalLink'\">\n        <a mat-button\n            [href]=\"NavUtilities.asExternalLink(element).url\"\n            [target]=\"NavUtilities.asExternalLink(element).openInNewTab ? '_blank' : '_self'\"\n            [rel]=\"NavUtilities.asExternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n        >\n            <i *ngIf=\"NavUtilities.asExternalLink(element).icon\" [class]=\"NavUtilities.asExternalLink(element).icon\"></i>\n            {{NavUtilities.asExternalLink(element).name}}\n        </a>\n    </span>\n    <!-- Text -->\n    <span *ngSwitchCase=\"'text'\">\n        {{NavUtilities.asText(element).text}}\n    </span>\n    <!-- Custom HTML -->\n    <span *ngSwitchCase=\"'html'\" [innerHtml]=\"sanitizedHtml\">\n    </span>\n    <!-- Menu -->\n    <button #menuButton *ngSwitchCase=\"'menu'\" mat-button [matMenuTriggerFor]=\"menu.menu\">\n        <i *ngIf=\"NavUtilities.asMenu(element).icon\" [class]=\"NavUtilities.asMenu(element).icon\"></i>\n        {{NavUtilities.asMenu(element).name}}\n    </button>\n    <ngx-mat-navigation-menu #menu [navMenu]=\"NavUtilities.asMenu(element)\" [menuWidth]=\"menuWidth\">\n    </ngx-mat-navigation-menu>\n</span>"]}
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"footer-element.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-navigation/src/components/footer/footer-element/footer-element.component.ts","../../../../../../projects/ngx-material-navigation/src/components/footer/footer-element/footer-element.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAuB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACvG,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAIhE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;AAEtE;;GAEG;AAMH,MAAM,OAAO,sBAAsB;IAiB/B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAfpD,iBAAY,GAAG,YAAY,CAAC;IAe2B,CAAC;IAExD,QAAQ;QACJ,IAAI,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACtC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;SAC5G;IACL,CAAC;IAED,qBAAqB;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAED;;OAEG;IAEH,QAAQ;QACJ,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAEO,YAAY;QAChB,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,aAA6B,CAAA,CAAC,WAAW,CAAC;IACnF,CAAC;;mHA3CQ,sBAAsB;uGAAtB,sBAAsB,iRCfnC,uwLAwGO;2FDzFM,sBAAsB;kBALlC,SAAS;+BACI,mCAAmC;mGAY7C,OAAO;sBADN,KAAK;gBAMN,UAAU;sBADT,SAAS;uBAAC,YAAY;gBAuBvB,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterContentChecked, Component, HostListener, Input, OnInit, ViewChild } from '@angular/core';\nimport { NavUtilities } from '../../../utilities/nav.utilities';\nimport { MatButton } from '@angular/material/button';\nimport { NavFooterElement } from '../../../models/footer.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { PurifyUtilities } from '../../../utilities/purify.utilities';\n\n/**\n * Displays a single Navigation Element.\n */\n@Component({\n    selector: 'ngx-mat-navigation-footer-element',\n    templateUrl: './footer-element.component.html',\n    styleUrls: ['./footer-element.component.scss']\n})\nexport class FooterElementComponent implements AfterContentChecked, OnInit {\n\n    NavUtilities = NavUtilities;\n\n    /**\n     * The element to display.\n     */\n    @Input()\n    element!: NavFooterElement;\n\n    sanitizedHtml?: SafeHtml;\n\n    @ViewChild('menuButton')\n    menuButton?: MatButton;\n\n    menuWidth!: number;\n\n    constructor(private readonly sanitizer: DomSanitizer) {}\n\n    ngOnInit(): void {\n        if (NavUtilities.isNavHtml(this.element)) {\n            this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(this.element.html));\n        }\n    }\n\n    ngAfterContentChecked(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    /**\n     * Updates the width of the menu to the value of its button.\n     */\n    @HostListener('window:resize', ['$event'])\n    onResize(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    private getMenuWidth(): number {\n        return (this.menuButton?._elementRef.nativeElement as HTMLElement).offsetWidth;\n    }\n}","<span [ngSwitch]=\"element.type\">\n    <!-- Title -->\n    <b *ngSwitchCase=\"'title'\">\n        <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n        {{NavUtilities.asTitle(element).title}}\n    </b>\n    <!-- Title with internal link -->\n    <a id=\"title-link\" *ngSwitchCase=\"'titleWithInternalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asTitleWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <b>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </b>\n    </a>\n    <!-- Title with external link -->\n    <a class=\"title-link\" *ngSwitchCase=\"'titleWithExternalLink'\"\n        [href]=\"NavUtilities.asTitleWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <h1>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </h1>\n    </a>\n    <!-- Image -->\n    <img mat-menu-item *ngSwitchCase=\"'image'\"\n        [src]=\"NavUtilities.asImage(element).url\"\n    >\n    <!-- Image with internal link -->\n    <a mat-menu-item disabled id=\"image-link\" *ngSwitchCase=\"'imageWithInternalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asImageWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <img [src]=\"NavUtilities.asImageWithInternalLink(element).url\">\n    </a>\n    <!-- Image with external link -->\n    <a mat-menu-item disabled id=\"image-link\" *ngSwitchCase=\"'imageWithExternalLink'\"\n        [href]=\"NavUtilities.asImageWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <img [src]=\"NavUtilities.asImageWithExternalLink(element).url\">\n    </a>\n    <!-- Button -->\n    <button *ngSwitchCase=\"'button'\"\n        mat-raised-button\n        (click)=\"NavUtilities.asButton(element).action()\"\n    >\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Flat Button -->\n    <button *ngSwitchCase=\"'buttonFlat'\" mat-button (click)=\"NavUtilities.asButton(element).action()\">\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Internal Link -->\n    <a mat-button *ngSwitchCase=\"'internalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n            : NavUtilities.asStringRoute(NavUtilities.asInternalLink(element).route)\"\n        [target]=\"NavUtilities.asInternalLink(element).openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asInternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n    >\n        <i *ngIf=\"NavUtilities.asInternalLink(element).icon\" [class]=\"NavUtilities.asInternalLink(element).icon\"></i> \n        {{NavUtilities.asInternalLink(element).name}}\n    </a>\n    <!-- External Link -->\n    <span *ngSwitchCase=\"'externalLink'\">\n        <a mat-button\n            [href]=\"NavUtilities.asExternalLink(element).url\"\n            [target]=\"NavUtilities.asExternalLink(element).openInNewTab ? '_blank' : '_self'\"\n            [rel]=\"NavUtilities.asExternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n        >\n            <i *ngIf=\"NavUtilities.asExternalLink(element).icon\" [class]=\"NavUtilities.asExternalLink(element).icon\"></i>\n            {{NavUtilities.asExternalLink(element).name}}\n        </a>\n    </span>\n    <!-- Text -->\n    <span *ngSwitchCase=\"'text'\">\n        {{NavUtilities.asText(element).text}}\n    </span>\n    <!-- Custom HTML -->\n    <span *ngSwitchCase=\"'html'\" [innerHtml]=\"sanitizedHtml\">\n    </span>\n    <!-- Menu -->\n    <button #menuButton *ngSwitchCase=\"'menu'\" mat-button [matMenuTriggerFor]=\"menu.menu\">\n        <i *ngIf=\"NavUtilities.asMenu(element).icon\" [class]=\"NavUtilities.asMenu(element).icon\"></i>\n        {{NavUtilities.asMenu(element).name}}\n    </button>\n    <ngx-mat-navigation-menu #menu [navMenu]=\"NavUtilities.asMenu(element)\" [menuWidth]=\"menuWidth\">\n    </ngx-mat-navigation-menu>\n</span>"]}
|
|
@@ -1,24 +1,37 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
-
import * as i2 from "
|
|
4
|
+
import * as i1 from "../../services/nav.service";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "./footer-element/footer-element.component";
|
|
6
7
|
/**
|
|
7
8
|
* Displays a footer based on the provided input data.
|
|
8
9
|
*/
|
|
9
10
|
export class NgxMatNavigationFooterComponent {
|
|
10
|
-
constructor() {
|
|
11
|
-
this.
|
|
11
|
+
constructor(navService) {
|
|
12
|
+
this.navService = navService;
|
|
13
|
+
this.onDestroy = new Subject();
|
|
14
|
+
this.internalFooterRows = [];
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.navService.footerRowsSubject.pipe(takeUntil(this.onDestroy)).subscribe(footerRows => {
|
|
18
|
+
this.internalFooterRows = footerRows;
|
|
19
|
+
});
|
|
20
|
+
this.navService.footerRowsSubject.next(this.footerRows);
|
|
21
|
+
}
|
|
22
|
+
ngOnDestroy() {
|
|
23
|
+
this.onDestroy.next(undefined);
|
|
24
|
+
this.onDestroy.complete();
|
|
12
25
|
}
|
|
13
26
|
}
|
|
14
|
-
NgxMatNavigationFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: NgxMatNavigationFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
-
NgxMatNavigationFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: NgxMatNavigationFooterComponent, selector: "ngx-mat-navigation-footer", inputs: { minHeight: "minHeight", footerRows: "footerRows" }, ngImport: i0, template: "<footer [style.minHeight.px]=\"minHeight\">\n <div class=\"container\">\n <div class=\"footer-row row gy-2\" *ngFor=\"let row of
|
|
27
|
+
NgxMatNavigationFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: NgxMatNavigationFooterComponent, deps: [{ token: i1.NgxMatNavigationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
28
|
+
NgxMatNavigationFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.1", type: NgxMatNavigationFooterComponent, selector: "ngx-mat-navigation-footer", inputs: { minHeight: "minHeight", footerRows: "footerRows" }, ngImport: i0, template: "<footer [style.minHeight.px]=\"minHeight\">\n <div class=\"container\">\n <div class=\"footer-row row gy-2\" *ngFor=\"let row of internalFooterRows\">\n <div class=\"col-md-4 col-sm-6\">\n <div *ngFor=\"let element of navService.getFooterElementsForRow('left', row)\">\n <ngx-mat-navigation-footer-element [element]=\"element\"></ngx-mat-navigation-footer-element>\n </div>\n </div>\n <div class=\"col-md-4 col-sm-6\">\n <div *ngFor=\"let element of navService.getFooterElementsForRow('center', row)\">\n <ngx-mat-navigation-footer-element [element]=\"element\"></ngx-mat-navigation-footer-element>\n </div>\n </div>\n <div class=\"col-md-4 col-sm-6\">\n <div *ngFor=\"let element of navService.getFooterElementsForRow('right', row)\">\n <ngx-mat-navigation-footer-element [element]=\"element\"></ngx-mat-navigation-footer-element>\n </div>\n </div>\n </div>\n </div>\n</footer>", styles: ["footer{box-shadow:0 0 5px -1px #0003,0 0 8px 5px #00000024,0 0 14px 8px #0000001f;padding-top:20px;padding-bottom:20px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.FooterElementComponent, selector: "ngx-mat-navigation-footer-element", inputs: ["element"] }] });
|
|
16
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImport: i0, type: NgxMatNavigationFooterComponent, decorators: [{
|
|
17
30
|
type: Component,
|
|
18
|
-
args: [{ selector: 'ngx-mat-navigation-footer', template: "<footer [style.minHeight.px]=\"minHeight\">\n <div class=\"container\">\n <div class=\"footer-row row gy-2\" *ngFor=\"let row of
|
|
19
|
-
}], propDecorators: { minHeight: [{
|
|
31
|
+
args: [{ selector: 'ngx-mat-navigation-footer', template: "<footer [style.minHeight.px]=\"minHeight\">\n <div class=\"container\">\n <div class=\"footer-row row gy-2\" *ngFor=\"let row of internalFooterRows\">\n <div class=\"col-md-4 col-sm-6\">\n <div *ngFor=\"let element of navService.getFooterElementsForRow('left', row)\">\n <ngx-mat-navigation-footer-element [element]=\"element\"></ngx-mat-navigation-footer-element>\n </div>\n </div>\n <div class=\"col-md-4 col-sm-6\">\n <div *ngFor=\"let element of navService.getFooterElementsForRow('center', row)\">\n <ngx-mat-navigation-footer-element [element]=\"element\"></ngx-mat-navigation-footer-element>\n </div>\n </div>\n <div class=\"col-md-4 col-sm-6\">\n <div *ngFor=\"let element of navService.getFooterElementsForRow('right', row)\">\n <ngx-mat-navigation-footer-element [element]=\"element\"></ngx-mat-navigation-footer-element>\n </div>\n </div>\n </div>\n </div>\n</footer>", styles: ["footer{box-shadow:0 0 5px -1px #0003,0 0 8px 5px #00000024,0 0 14px 8px #0000001f;padding-top:20px;padding-bottom:20px}\n"] }]
|
|
32
|
+
}], ctorParameters: function () { return [{ type: i1.NgxMatNavigationService }]; }, propDecorators: { minHeight: [{
|
|
20
33
|
type: Input
|
|
21
34
|
}], footerRows: [{
|
|
22
35
|
type: Input
|
|
23
36
|
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9vdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1uYXZpZ2F0aW9uL3NyYy9jb21wb25lbnRzL2Zvb3Rlci9mb290ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLW5hdmlnYXRpb24vc3JjL2NvbXBvbmVudHMvZm9vdGVyL2Zvb3Rlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDcEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBSTFDOztHQUVHO0FBTUgsTUFBTSxPQUFPLCtCQUErQjtJQWlCeEMsWUFBbUIsVUFBbUM7UUFBbkMsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFoQnJDLGNBQVMsR0FBa0IsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQWMxRCx1QkFBa0IsR0FBZ0IsRUFBRSxDQUFDO0lBRXFCLENBQUM7SUFFM0QsUUFBUTtRQUNKLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDckYsSUFBSSxDQUFDLGtCQUFrQixHQUFHLFVBQVUsQ0FBQztRQUN6QyxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQy9CLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDOUIsQ0FBQzs7NEhBN0JRLCtCQUErQjtnSEFBL0IsK0JBQStCLCtIQ2I1Qyx5bENBb0JTOzJGRFBJLCtCQUErQjtrQkFMM0MsU0FBUzsrQkFDSSwyQkFBMkI7OEdBV3JDLFNBQVM7c0JBRFIsS0FBSztnQkFPTixVQUFVO3NCQURULEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCwgdGFrZVVudGlsIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBGb290ZXJSb3cgfSBmcm9tICcuLi8uLi9tb2RlbHMvZm9vdGVyLm1vZGVsJztcbmltcG9ydCB7IE5neE1hdE5hdmlnYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbmF2LnNlcnZpY2UnO1xuXG4vKipcbiAqIERpc3BsYXlzIGEgZm9vdGVyIGJhc2VkIG9uIHRoZSBwcm92aWRlZCBpbnB1dCBkYXRhLlxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25neC1tYXQtbmF2aWdhdGlvbi1mb290ZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9mb290ZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2Zvb3Rlci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE5neE1hdE5hdmlnYXRpb25Gb290ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBvbkRlc3Ryb3k6IFN1YmplY3Q8dm9pZD4gPSBuZXcgU3ViamVjdCgpO1xuXG4gICAgLyoqXG4gICAgICogVGhlIG1pbmltdW0gaGVpZ2h0IG9mIHRoZSBmb290ZXIuXG4gICAgICovXG4gICAgQElucHV0KClcbiAgICBtaW5IZWlnaHQhOiBudW1iZXI7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgZm9vdGVyIHJvd3MgdG8gYnVpbGQgdGhlIGZvb3RlciBmcm9tLlxuICAgICAqL1xuICAgIEBJbnB1dCgpXG4gICAgZm9vdGVyUm93cyE6IEZvb3RlclJvd1tdO1xuXG4gICAgaW50ZXJuYWxGb290ZXJSb3dzOiBGb290ZXJSb3dbXSA9IFtdO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIG5hdlNlcnZpY2U6IE5neE1hdE5hdmlnYXRpb25TZXJ2aWNlKSB7IH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLm5hdlNlcnZpY2UuZm9vdGVyUm93c1N1YmplY3QucGlwZSh0YWtlVW50aWwodGhpcy5vbkRlc3Ryb3kpKS5zdWJzY3JpYmUoZm9vdGVyUm93cyA9PiB7XG4gICAgICAgICAgICB0aGlzLmludGVybmFsRm9vdGVyUm93cyA9IGZvb3RlclJvd3M7XG4gICAgICAgIH0pO1xuICAgICAgICB0aGlzLm5hdlNlcnZpY2UuZm9vdGVyUm93c1N1YmplY3QubmV4dCh0aGlzLmZvb3RlclJvd3MpO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLm9uRGVzdHJveS5uZXh0KHVuZGVmaW5lZCk7XG4gICAgICAgIHRoaXMub25EZXN0cm95LmNvbXBsZXRlKCk7XG4gICAgfVxufSIsIjxmb290ZXIgW3N0eWxlLm1pbkhlaWdodC5weF09XCJtaW5IZWlnaHRcIj5cbiAgICA8ZGl2IGNsYXNzPVwiY29udGFpbmVyXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJmb290ZXItcm93IHJvdyBneS0yXCIgKm5nRm9yPVwibGV0IHJvdyBvZiBpbnRlcm5hbEZvb3RlclJvd3NcIj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtbWQtNCBjb2wtc20tNlwiPlxuICAgICAgICAgICAgICAgIDxkaXYgKm5nRm9yPVwibGV0IGVsZW1lbnQgb2YgbmF2U2VydmljZS5nZXRGb290ZXJFbGVtZW50c0ZvclJvdygnbGVmdCcsIHJvdylcIj5cbiAgICAgICAgICAgICAgICAgICAgPG5neC1tYXQtbmF2aWdhdGlvbi1mb290ZXItZWxlbWVudCBbZWxlbWVudF09XCJlbGVtZW50XCI+PC9uZ3gtbWF0LW5hdmlnYXRpb24tZm9vdGVyLWVsZW1lbnQ+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtbWQtNCBjb2wtc20tNlwiPlxuICAgICAgICAgICAgICAgIDxkaXYgKm5nRm9yPVwibGV0IGVsZW1lbnQgb2YgbmF2U2VydmljZS5nZXRGb290ZXJFbGVtZW50c0ZvclJvdygnY2VudGVyJywgcm93KVwiPlxuICAgICAgICAgICAgICAgICAgICA8bmd4LW1hdC1uYXZpZ2F0aW9uLWZvb3Rlci1lbGVtZW50IFtlbGVtZW50XT1cImVsZW1lbnRcIj48L25neC1tYXQtbmF2aWdhdGlvbi1mb290ZXItZWxlbWVudD5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC00IGNvbC1zbS02XCI+XG4gICAgICAgICAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgZWxlbWVudCBvZiBuYXZTZXJ2aWNlLmdldEZvb3RlckVsZW1lbnRzRm9yUm93KCdyaWdodCcsIHJvdylcIj5cbiAgICAgICAgICAgICAgICAgICAgPG5neC1tYXQtbmF2aWdhdGlvbi1mb290ZXItZWxlbWVudCBbZWxlbWVudF09XCJlbGVtZW50XCI+PC9uZ3gtbWF0LW5hdmlnYXRpb24tZm9vdGVyLWVsZW1lbnQ+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG48L2Zvb3Rlcj4iXX0=
|
|
@@ -18,7 +18,7 @@ export class NavElementComponent {
|
|
|
18
18
|
}
|
|
19
19
|
ngOnInit() {
|
|
20
20
|
if (NavUtilities.isNavHtml(this.element)) {
|
|
21
|
-
this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(
|
|
21
|
+
this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(this.element.html));
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
24
|
ngAfterContentChecked() {
|
|
@@ -56,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
56
56
|
type: HostListener,
|
|
57
57
|
args: ['window:resize', ['$event']]
|
|
58
58
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-element.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-element/nav-element.component.ts","../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-element/nav-element.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAuB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AAEvG,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;AAKtE;;GAEG;AAMH,MAAM,OAAO,mBAAmB;IA8B5B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QA5BpD,iBAAY,GAAG,YAAY,CAAC;IA4B2B,CAAC;IAExD,QAAQ;QACJ,IAAI,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACtC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,eAAe,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;SACjI;IACL,CAAC;IAED,qBAAqB;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAED;;OAEG;IAEH,QAAQ;QACJ,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAEO,YAAY;QAChB,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,aAA6B,CAAA,CAAC,WAAW,CAAC;IACnF,CAAC;;gHAxDQ,mBAAmB;oGAAnB,mBAAmB,gUChBhC,41MAgHO;2FDhGM,mBAAmB;kBAL/B,SAAS;+BACI,4BAA4B;mGAYtC,OAAO;sBADN,KAAK;gBASN,OAAO;sBADN,KAAK;gBAQN,cAAc;sBADb,KAAK;gBAIN,UAAU;sBADT,SAAS;uBAAC,YAAY;gBAuBvB,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterContentChecked, Component, HostListener, Input, OnInit, ViewChild } from '@angular/core';\nimport { NavElement } from '../../../models/nav.model';\nimport { NavUtilities } from '../../../utilities/nav.utilities';\nimport { PurifyUtilities } from '../../../utilities/purify.utilities';\nimport { MatSidenav } from '@angular/material/sidenav';\nimport { MatButton } from '@angular/material/button';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n/**\n * Displays a single Navigation Element.\n */\n@Component({\n    selector: 'ngx-mat-navigation-element',\n    templateUrl: './nav-element.component.html',\n    styleUrls: ['./nav-element.component.scss']\n})\nexport class NavElementComponent implements AfterContentChecked, OnInit {\n\n    NavUtilities = NavUtilities;\n\n    /**\n     * The element to display.\n     */\n    @Input()\n    element!: NavElement;\n\n    sanitizedHtml?: SafeHtml;\n\n    /**\n     * A reference to the sidenav. Is needed for the menu to close the sidenav.\n     */\n    @Input()\n    sidenav?: MatSidenav;\n\n    /**\n     * Whether or not this element should be displayed inside the sidenav.\n     * Used to apply different styling.\n     */\n    @Input()\n    sidenavElement?: boolean;\n\n    @ViewChild('menuButton')\n    menuButton?: MatButton;\n\n    menuWidth!: number;\n\n    constructor(private readonly sanitizer: DomSanitizer) {}\n\n    ngOnInit(): void {\n        if (NavUtilities.isNavHtml(this.element)) {\n            this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(NavUtilities.asHtml(this.element).html));\n        }\n    }\n\n    ngAfterContentChecked(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    /**\n     * Updates the width of the menu to the value of its button.\n     */\n    @HostListener('window:resize', ['$event'])\n    onResize(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    private getMenuWidth(): number {\n        return (this.menuButton?._elementRef.nativeElement as HTMLElement).offsetWidth;\n    }\n}","<span [ngSwitch]=\"element.type\">\n    <!-- Title -->\n    <h1 mat-menu-item disabled *ngSwitchCase=\"'title'\" [class.sidenavElement]=\"sidenavElement\">\n        <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n        {{NavUtilities.asTitle(element).title}}\n    </h1>\n    <!-- Title with internal link -->\n    <a id=\"title-link\" disableRipple mat-menu-item *ngSwitchCase=\"'titleWithInternalLink'\"\n        [routerLink]=\"      \n            NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asTitleWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <h1>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </h1>\n    </a>\n    <!-- Title with external link -->\n    <a class=\"title-link\" disableRipple mat-menu-item *ngSwitchCase=\"'titleWithExternalLink'\"\n        [href]=\"NavUtilities.asTitleWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <h1>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </h1>\n    </a>\n    <!-- Image -->\n    <img mat-menu-item disabled *ngSwitchCase=\"'image'\"\n        [class.sidenavElement]=\"sidenavElement\"\n        [src]=\"NavUtilities.asImage(element).url\"\n    >\n    <!-- Image with internal link -->\n    <a id=\"image-link\" disableRipple mat-menu-item *ngSwitchCase=\"'imageWithInternalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asImageWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <img [src]=\"NavUtilities.asImageWithInternalLink(element).url\">\n    </a>\n    <!-- Image with external link -->\n    <a id=\"image-link\" disableRipple mat-menu-item *ngSwitchCase=\"'imageWithExternalLink'\"\n        [href]=\"NavUtilities.asImageWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <img [src]=\"NavUtilities.asImageWithExternalLink(element).url\">\n    </a>\n    <!-- Button -->\n    <button *ngSwitchCase=\"'button'\"\n        mat-raised-button\n        (click)=\"NavUtilities.asButton(element).action()\"\n        [class.sidenavElementButton]=\"sidenavElement\"\n    >\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Flat Button -->\n    <button *ngSwitchCase=\"'buttonFlat'\" mat-button (click)=\"NavUtilities.asButton(element).action()\" [class.sidenavElementButton]=\"sidenavElement\">\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Internal Link -->\n    <a mat-button *ngSwitchCase=\"'internalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n            : NavUtilities.asStringRoute(NavUtilities.asInternalLink(element).route)\"\n        [target]=\"NavUtilities.asInternalLink(element).openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asInternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <i *ngIf=\"NavUtilities.asInternalLink(element).icon\" [class]=\"NavUtilities.asInternalLink(element).icon\"></i> \n        {{NavUtilities.asInternalLink(element).name}}\n    </a>\n    <!-- External Link -->\n    <span *ngSwitchCase=\"'externalLink'\">\n        <a mat-button\n            [href]=\"NavUtilities.asExternalLink(element).url\"\n            [target]=\"NavUtilities.asExternalLink(element).openInNewTab ? '_blank' : '_self'\"\n            [rel]=\"NavUtilities.asExternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n            [class.sidenavElement]=\"sidenavElement\"\n        >\n            <i *ngIf=\"NavUtilities.asExternalLink(element).icon\" [class]=\"NavUtilities.asExternalLink(element).icon\"></i>\n            {{NavUtilities.asExternalLink(element).name}}\n        </a>\n    </span>\n    <!-- Custom HTML -->\n    <span *ngSwitchCase=\"'html'\" [innerHtml]=\"sanitizedHtml\">\n    </span>\n    <!-- Menu -->\n    <button #menuButton *ngSwitchCase=\"'menu'\" mat-button [matMenuTriggerFor]=\"menu.menu\" [class.sidenavElement]=\"sidenavElement\">\n        <i *ngIf=\"NavUtilities.asMenu(element).icon\" [class]=\"NavUtilities.asMenu(element).icon\"></i>\n        {{NavUtilities.asMenu(element).name}}\n    </button>\n    <ngx-mat-navigation-menu #menu\n        [navMenu]=\"NavUtilities.asMenu(element)\"\n        [sidenav]=\"sidenav\"\n        [menuWidth]=\"menuWidth\">\n    </ngx-mat-navigation-menu>\n    \n</span>"]}
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-element.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-element/nav-element.component.ts","../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-element/nav-element.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAuB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AAEvG,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;AAKtE;;GAEG;AAMH,MAAM,OAAO,mBAAmB;IA8B5B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QA5BpD,iBAAY,GAAG,YAAY,CAAC;IA4B2B,CAAC;IAExD,QAAQ;QACJ,IAAI,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACtC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;SAC5G;IACL,CAAC;IAED,qBAAqB;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAED;;OAEG;IAEH,QAAQ;QACJ,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SACxC;IACL,CAAC;IAEO,YAAY;QAChB,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,aAA6B,CAAA,CAAC,WAAW,CAAC;IACnF,CAAC;;gHAxDQ,mBAAmB;oGAAnB,mBAAmB,gUChBhC,41MAgHO;2FDhGM,mBAAmB;kBAL/B,SAAS;+BACI,4BAA4B;mGAYtC,OAAO;sBADN,KAAK;gBASN,OAAO;sBADN,KAAK;gBAQN,cAAc;sBADb,KAAK;gBAIN,UAAU;sBADT,SAAS;uBAAC,YAAY;gBAuBvB,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterContentChecked, Component, HostListener, Input, OnInit, ViewChild } from '@angular/core';\nimport { NavElement } from '../../../models/nav.model';\nimport { NavUtilities } from '../../../utilities/nav.utilities';\nimport { PurifyUtilities } from '../../../utilities/purify.utilities';\nimport { MatSidenav } from '@angular/material/sidenav';\nimport { MatButton } from '@angular/material/button';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n/**\n * Displays a single Navigation Element.\n */\n@Component({\n    selector: 'ngx-mat-navigation-element',\n    templateUrl: './nav-element.component.html',\n    styleUrls: ['./nav-element.component.scss']\n})\nexport class NavElementComponent implements AfterContentChecked, OnInit {\n\n    NavUtilities = NavUtilities;\n\n    /**\n     * The element to display.\n     */\n    @Input()\n    element!: NavElement;\n\n    sanitizedHtml?: SafeHtml;\n\n    /**\n     * A reference to the sidenav. Is needed for the menu to close the sidenav.\n     */\n    @Input()\n    sidenav?: MatSidenav;\n\n    /**\n     * Whether or not this element should be displayed inside the sidenav.\n     * Used to apply different styling.\n     */\n    @Input()\n    sidenavElement?: boolean;\n\n    @ViewChild('menuButton')\n    menuButton?: MatButton;\n\n    menuWidth!: number;\n\n    constructor(private readonly sanitizer: DomSanitizer) {}\n\n    ngOnInit(): void {\n        if (NavUtilities.isNavHtml(this.element)) {\n            this.sanitizedHtml = this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(this.element.html));\n        }\n    }\n\n    ngAfterContentChecked(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    /**\n     * Updates the width of the menu to the value of its button.\n     */\n    @HostListener('window:resize', ['$event'])\n    onResize(): void {\n        if (this.menuButton) {\n            this.menuWidth = this.getMenuWidth();\n        }\n    }\n\n    private getMenuWidth(): number {\n        return (this.menuButton?._elementRef.nativeElement as HTMLElement).offsetWidth;\n    }\n}","<span [ngSwitch]=\"element.type\">\n    <!-- Title -->\n    <h1 mat-menu-item disabled *ngSwitchCase=\"'title'\" [class.sidenavElement]=\"sidenavElement\">\n        <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n        {{NavUtilities.asTitle(element).title}}\n    </h1>\n    <!-- Title with internal link -->\n    <a id=\"title-link\" disableRipple mat-menu-item *ngSwitchCase=\"'titleWithInternalLink'\"\n        [routerLink]=\"      \n            NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asTitleWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asTitleWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <h1>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </h1>\n    </a>\n    <!-- Title with external link -->\n    <a class=\"title-link\" disableRipple mat-menu-item *ngSwitchCase=\"'titleWithExternalLink'\"\n        [href]=\"NavUtilities.asTitleWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asTitleWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <h1>\n            <i *ngIf=\"NavUtilities.asTitle(element).icon\" [class]=\"NavUtilities.asTitle(element).icon\"></i>\n            {{NavUtilities.asTitle(element).title}}\n        </h1>\n    </a>\n    <!-- Image -->\n    <img mat-menu-item disabled *ngSwitchCase=\"'image'\"\n        [class.sidenavElement]=\"sidenavElement\"\n        [src]=\"NavUtilities.asImage(element).url\"\n    >\n    <!-- Image with internal link -->\n    <a id=\"image-link\" disableRipple mat-menu-item *ngSwitchCase=\"'imageWithInternalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asImageWithInternalLink(element).link.route).path\n            : NavUtilities.asStringRoute(NavUtilities.asImageWithInternalLink(element).link.route)\"\n        [target]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithInternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <img [src]=\"NavUtilities.asImageWithInternalLink(element).url\">\n    </a>\n    <!-- Image with external link -->\n    <a id=\"image-link\" disableRipple mat-menu-item *ngSwitchCase=\"'imageWithExternalLink'\"\n        [href]=\"NavUtilities.asImageWithExternalLink(element).link.url\"\n        [target]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asImageWithExternalLink(element).link.openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <img [src]=\"NavUtilities.asImageWithExternalLink(element).url\">\n    </a>\n    <!-- Button -->\n    <button *ngSwitchCase=\"'button'\"\n        mat-raised-button\n        (click)=\"NavUtilities.asButton(element).action()\"\n        [class.sidenavElementButton]=\"sidenavElement\"\n    >\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Flat Button -->\n    <button *ngSwitchCase=\"'buttonFlat'\" mat-button (click)=\"NavUtilities.asButton(element).action()\" [class.sidenavElementButton]=\"sidenavElement\">\n        <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n        {{NavUtilities.asButton(element).name}}\n    </button>\n    <!-- Internal Link -->\n    <a mat-button *ngSwitchCase=\"'internalLink'\"\n        [routerLink]=\"\n            NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path !== undefined\n            ? NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n            : NavUtilities.asStringRoute(NavUtilities.asInternalLink(element).route)\"\n        [target]=\"NavUtilities.asInternalLink(element).openInNewTab ? '_blank' : '_self'\"\n        [rel]=\"NavUtilities.asInternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n        [class.sidenavElement]=\"sidenavElement\"\n    >\n        <i *ngIf=\"NavUtilities.asInternalLink(element).icon\" [class]=\"NavUtilities.asInternalLink(element).icon\"></i> \n        {{NavUtilities.asInternalLink(element).name}}\n    </a>\n    <!-- External Link -->\n    <span *ngSwitchCase=\"'externalLink'\">\n        <a mat-button\n            [href]=\"NavUtilities.asExternalLink(element).url\"\n            [target]=\"NavUtilities.asExternalLink(element).openInNewTab ? '_blank' : '_self'\"\n            [rel]=\"NavUtilities.asExternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n            [class.sidenavElement]=\"sidenavElement\"\n        >\n            <i *ngIf=\"NavUtilities.asExternalLink(element).icon\" [class]=\"NavUtilities.asExternalLink(element).icon\"></i>\n            {{NavUtilities.asExternalLink(element).name}}\n        </a>\n    </span>\n    <!-- Custom HTML -->\n    <span *ngSwitchCase=\"'html'\" [innerHtml]=\"sanitizedHtml\">\n    </span>\n    <!-- Menu -->\n    <button #menuButton *ngSwitchCase=\"'menu'\" mat-button [matMenuTriggerFor]=\"menu.menu\" [class.sidenavElement]=\"sidenavElement\">\n        <i *ngIf=\"NavUtilities.asMenu(element).icon\" [class]=\"NavUtilities.asMenu(element).icon\"></i>\n        {{NavUtilities.asMenu(element).name}}\n    </button>\n    <ngx-mat-navigation-menu #menu\n        [navMenu]=\"NavUtilities.asMenu(element)\"\n        [sidenav]=\"sidenav\"\n        [menuWidth]=\"menuWidth\">\n    </ngx-mat-navigation-menu>\n    \n</span>"]}
|
|
@@ -40,7 +40,7 @@ export class NavMenuComponent {
|
|
|
40
40
|
*/
|
|
41
41
|
getSanitizedHtmlFor(element) {
|
|
42
42
|
if (NavUtilities.isNavHtml(element)) {
|
|
43
|
-
return this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(
|
|
43
|
+
return this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(element.html));
|
|
44
44
|
}
|
|
45
45
|
else {
|
|
46
46
|
throw new Error('The passed HTML is not valid.');
|
|
@@ -87,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.1", ngImpor
|
|
|
87
87
|
type: HostListener,
|
|
88
88
|
args: ['window:resize', ['$event']]
|
|
89
89
|
}] } });
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-menu/nav-menu.component.ts","../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-menu/nav-menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAuB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/F,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAIhE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;AAEtE;;GAEG;AAMH,MAAM,OAAO,gBAAgB;IA8BzB,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAPpD,iBAAY,GAAG,YAAY,CAAC;IAO2B,CAAC;IAExD,qBAAqB;QACjB,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9C;IACL,CAAC;IAED;;OAEG;IAEH,QAAQ;QACJ,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9C;IACL,CAAC;IAEO,YAAY;QAChB,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,WAAW,CAAC,aAA6B,CAAA,CAAC,WAAW,CAAC;IACzF,CAAC;IAED;;;;;;OAMG;IACH,mBAAmB,CAAC,OAAuB;QACvC,IAAI,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;YACjC,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,eAAe,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;SAC9G;aACI;YACD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;SACpD;IACL,CAAC;IAED;;;;OAIG;IACH,mBAAmB,CAAC,OAAuB;QACvC,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,QAAQ,OAAO,CAAC,IAAI,EAAE;gBAClB,KAAK,OAAO,CAAC;gBACb,KAAK,OAAO,CAAC;gBACb,KAAK,MAAM,CAAC;gBACZ,KAAK,MAAM;oBACP,OAAO;gBACX;oBACI,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;oBAC1B,OAAO;aACd;SACJ;IACL,CAAC;;6GAtFQ,gBAAgB;iGAAhB,gBAAgB,4ZCjB7B,uwGAkDW,kvDDjCE,gBAAgB;2FAAhB,gBAAgB;kBAL5B,SAAS;+BACI,yBAAyB;mGAOnC,IAAI;sBADH,SAAS;uBAAC,MAAM,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAOjC,OAAO;sBADN,KAAK;gBAON,OAAO;sBADN,KAAK;gBAON,SAAS;sBADR,KAAK;gBAMN,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB;gBAiB7B,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterContentChecked, Component, HostListener, Input, ViewChild } from '@angular/core';\nimport { MatMenu } from '@angular/material/menu';\nimport { NavMenu, NavMenuElement } from '../../../models/nav-menu.model';\nimport { NavUtilities } from '../../../utilities/nav.utilities';\nimport { MatSidenav } from '@angular/material/sidenav';\nimport { MatButton } from '@angular/material/button';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { PurifyUtilities } from '../../../utilities/purify.utilities';\n\n/**\n * Displays a menu based on the provided NavMenu data.\n */\n@Component({\n    selector: 'ngx-mat-navigation-menu',\n    templateUrl: './nav-menu.component.html',\n    styleUrls: ['./nav-menu.component.scss']\n})\nexport class NavMenuComponent implements AfterContentChecked {\n\n    @ViewChild('menu', {static: true})\n    menu!: MatMenu;\n\n    /**\n     * The data that is used to generate the menu.\n     */\n    @Input()\n    navMenu!: NavMenu;\n\n    /**\n     * The sidenav element. Is needed so that it can be closed from within a menu.\n     */\n    @Input()\n    sidenav?: MatSidenav;\n\n    /**\n     * The width of the menu. Is set to the value of the button opening it.\n     */\n    @Input()\n    menuWidth!: number;\n\n    NavUtilities = NavUtilities;\n\n    @ViewChild('nestedMenuButton')\n    nestedMenuButton?: MatButton;\n\n    nestedMenuWidth!: number;\n\n    constructor(private readonly sanitizer: DomSanitizer) {}\n\n    ngAfterContentChecked(): void {\n        if (this.nestedMenuButton) {\n            this.nestedMenuWidth = this.getMenuWidth();\n        }\n    }\n\n    /**\n     * Updates the width of the nestedMenu.\n     */\n    @HostListener('window:resize', ['$event'])\n    onResize(): void {\n        if (this.nestedMenuButton) {\n            this.nestedMenuWidth = this.getMenuWidth();\n        }\n    }\n\n    private getMenuWidth(): number {\n        return (this.nestedMenuButton?._elementRef.nativeElement as HTMLElement).offsetWidth;\n    }\n\n    /**\n     * Gets the sanitized HTML for the given element.\n     *\n     * @param element - The NavHtml element.\n     * @returns The safe html.\n     * @throws When the given element is not html.\n     */\n    getSanitizedHtmlFor(element: NavMenuElement): SafeHtml {\n        if (NavUtilities.isNavHtml(element)) {\n            return this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(NavUtilities.asHtml(element).html));\n        }\n        else {\n            throw new Error('The passed HTML is not valid.');\n        }\n    }\n\n    /**\n     * Defines if the sidenav should be closed when the given element is clicked.\n     *\n     * @param element - The element that has been clicked.\n     */\n    clickSidenavElement(element: NavMenuElement): void {\n        if (this.sidenav) {\n            switch (element.type) {\n                case 'image':\n                case 'title':\n                case 'menu':\n                case 'html':\n                    return;\n                default:\n                    void this.sidenav.close();\n                    return;\n            }\n        }\n    }\n}","<mat-menu #menu=\"matMenu\" [overlapTrigger]=\"false\">\n    <div *ngFor=\"let element of navMenu.elements\" [style.min-width.px]=\"menuWidth\">\n        <div [ngSwitch]=\"element.type\">\n            <!-- Internal Link -->\n            <a mat-button *ngSwitchCase=\"'internalLink'\"\n                (click)=\"clickSidenavElement(element)\"\n                [routerLink]=\"\n                    NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n                    ? NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n                    : NavUtilities.asStringRoute(NavUtilities.asInternalLink(element).route)\"\n                [target]=\"NavUtilities.asInternalLink(element).openInNewTab ? '_blank' : '_self'\"\n                [rel]=\"NavUtilities.asInternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n            >\n                <i *ngIf=\"NavUtilities.asInternalLink(element).icon\" [class]=\"NavUtilities.asInternalLink(element).icon\"></i> \n                {{NavUtilities.asInternalLink(element).name}}\n            </a>\n            <!-- External Link -->\n            <span *ngSwitchCase=\"'externalLink'\">\n                <a mat-button\n                    (click)=\"clickSidenavElement(element)\"\n                    [href]=\"NavUtilities.asExternalLink(element).url\"\n                    [target]=\"NavUtilities.asExternalLink(element).openInNewTab ? '_blank' : '_self'\"\n                    [rel]=\"NavUtilities.asExternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n                >\n                    <i *ngIf=\"NavUtilities.asExternalLink(element).icon\" [class]=\"NavUtilities.asExternalLink(element).icon\"></i>\n                    {{NavUtilities.asExternalLink(element).name}}\n                </a>\n            </span>\n            <!-- Button -->\n            <button *ngSwitchCase=\"'button'\" class=\"sidenavElementButton\" mat-raised-button (click)=\"NavUtilities.asButton(element).action()\">\n                <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n                {{NavUtilities.asButton(element).name}}\n            </button>\n            <!-- Flat Button -->\n            <button *ngSwitchCase=\"'buttonFlat'\" class=\"sidenavElementButton\" mat-button (click)=\"NavUtilities.asButton(element).action()\">\n                <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n                {{NavUtilities.asButton(element).name}}\n            </button>\n            <!-- Custom HTML -->\n            <span *ngSwitchCase=\"'html'\" [innerHtml]=\"getSanitizedHtmlFor(element)\">\n            </span>\n            <!-- Nested Menu -->\n            <button #nestedMenuButton *ngSwitchCase=\"'menu'\" mat-menu-item [matMenuTriggerFor]=\"internalMenu.menu\">\n                <i *ngIf=\"NavUtilities.asMenu(element).icon\" [class]=\"NavUtilities.asMenu(element).icon\"></i>\n                {{NavUtilities.asMenu(element).name}}\n            </button>\n            <ngx-mat-navigation-menu #internalMenu [navMenu]=\"NavUtilities.asMenu(element)\" [sidenav]=\"sidenav\" [menuWidth]=\"nestedMenuWidth\">\n            </ngx-mat-navigation-menu>\n        </div>\n    </div>\n</mat-menu>"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-menu/nav-menu.component.ts","../../../../../../projects/ngx-material-navigation/src/components/navbar/nav-menu/nav-menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAuB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/F,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAIhE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;;;;;;;AAEtE;;GAEG;AAMH,MAAM,OAAO,gBAAgB;IA8BzB,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAPpD,iBAAY,GAAG,YAAY,CAAC;IAO2B,CAAC;IAExD,qBAAqB;QACjB,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9C;IACL,CAAC;IAED;;OAEG;IAEH,QAAQ;QACJ,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9C;IACL,CAAC;IAEO,YAAY;QAChB,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,WAAW,CAAC,aAA6B,CAAA,CAAC,WAAW,CAAC;IACzF,CAAC;IAED;;;;;;OAMG;IACH,mBAAmB,CAAC,OAAuB;QACvC,IAAI,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;YACjC,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,eAAe,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;SACzF;aACI;YACD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;SACpD;IACL,CAAC;IAED;;;;OAIG;IACH,mBAAmB,CAAC,OAAuB;QACvC,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,QAAQ,OAAO,CAAC,IAAI,EAAE;gBAClB,KAAK,OAAO,CAAC;gBACb,KAAK,OAAO,CAAC;gBACb,KAAK,MAAM,CAAC;gBACZ,KAAK,MAAM;oBACP,OAAO;gBACX;oBACI,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;oBAC1B,OAAO;aACd;SACJ;IACL,CAAC;;6GAtFQ,gBAAgB;iGAAhB,gBAAgB,4ZCjB7B,uwGAkDW,kvDDjCE,gBAAgB;2FAAhB,gBAAgB;kBAL5B,SAAS;+BACI,yBAAyB;mGAOnC,IAAI;sBADH,SAAS;uBAAC,MAAM,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAOjC,OAAO;sBADN,KAAK;gBAON,OAAO;sBADN,KAAK;gBAON,SAAS;sBADR,KAAK;gBAMN,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB;gBAiB7B,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterContentChecked, Component, HostListener, Input, ViewChild } from '@angular/core';\nimport { MatMenu } from '@angular/material/menu';\nimport { NavMenu, NavMenuElement } from '../../../models/nav-menu.model';\nimport { NavUtilities } from '../../../utilities/nav.utilities';\nimport { MatSidenav } from '@angular/material/sidenav';\nimport { MatButton } from '@angular/material/button';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { PurifyUtilities } from '../../../utilities/purify.utilities';\n\n/**\n * Displays a menu based on the provided NavMenu data.\n */\n@Component({\n    selector: 'ngx-mat-navigation-menu',\n    templateUrl: './nav-menu.component.html',\n    styleUrls: ['./nav-menu.component.scss']\n})\nexport class NavMenuComponent implements AfterContentChecked {\n\n    @ViewChild('menu', {static: true})\n    menu!: MatMenu;\n\n    /**\n     * The data that is used to generate the menu.\n     */\n    @Input()\n    navMenu!: NavMenu;\n\n    /**\n     * The sidenav element. Is needed so that it can be closed from within a menu.\n     */\n    @Input()\n    sidenav?: MatSidenav;\n\n    /**\n     * The width of the menu. Is set to the value of the button opening it.\n     */\n    @Input()\n    menuWidth!: number;\n\n    NavUtilities = NavUtilities;\n\n    @ViewChild('nestedMenuButton')\n    nestedMenuButton?: MatButton;\n\n    nestedMenuWidth!: number;\n\n    constructor(private readonly sanitizer: DomSanitizer) {}\n\n    ngAfterContentChecked(): void {\n        if (this.nestedMenuButton) {\n            this.nestedMenuWidth = this.getMenuWidth();\n        }\n    }\n\n    /**\n     * Updates the width of the nestedMenu.\n     */\n    @HostListener('window:resize', ['$event'])\n    onResize(): void {\n        if (this.nestedMenuButton) {\n            this.nestedMenuWidth = this.getMenuWidth();\n        }\n    }\n\n    private getMenuWidth(): number {\n        return (this.nestedMenuButton?._elementRef.nativeElement as HTMLElement).offsetWidth;\n    }\n\n    /**\n     * Gets the sanitized HTML for the given element.\n     *\n     * @param element - The NavHtml element.\n     * @returns The safe html.\n     * @throws When the given element is not html.\n     */\n    getSanitizedHtmlFor(element: NavMenuElement): SafeHtml {\n        if (NavUtilities.isNavHtml(element)) {\n            return this.sanitizer.bypassSecurityTrustHtml(PurifyUtilities.sanitize(element.html));\n        }\n        else {\n            throw new Error('The passed HTML is not valid.');\n        }\n    }\n\n    /**\n     * Defines if the sidenav should be closed when the given element is clicked.\n     *\n     * @param element - The element that has been clicked.\n     */\n    clickSidenavElement(element: NavMenuElement): void {\n        if (this.sidenav) {\n            switch (element.type) {\n                case 'image':\n                case 'title':\n                case 'menu':\n                case 'html':\n                    return;\n                default:\n                    void this.sidenav.close();\n                    return;\n            }\n        }\n    }\n}","<mat-menu #menu=\"matMenu\" [overlapTrigger]=\"false\">\n    <div *ngFor=\"let element of navMenu.elements\" [style.min-width.px]=\"menuWidth\">\n        <div [ngSwitch]=\"element.type\">\n            <!-- Internal Link -->\n            <a mat-button *ngSwitchCase=\"'internalLink'\"\n                (click)=\"clickSidenavElement(element)\"\n                [routerLink]=\"\n                    NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n                    ? NavUtilities.asAngularRoute(NavUtilities.asInternalLink(element).route).path\n                    : NavUtilities.asStringRoute(NavUtilities.asInternalLink(element).route)\"\n                [target]=\"NavUtilities.asInternalLink(element).openInNewTab ? '_blank' : '_self'\"\n                [rel]=\"NavUtilities.asInternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n            >\n                <i *ngIf=\"NavUtilities.asInternalLink(element).icon\" [class]=\"NavUtilities.asInternalLink(element).icon\"></i> \n                {{NavUtilities.asInternalLink(element).name}}\n            </a>\n            <!-- External Link -->\n            <span *ngSwitchCase=\"'externalLink'\">\n                <a mat-button\n                    (click)=\"clickSidenavElement(element)\"\n                    [href]=\"NavUtilities.asExternalLink(element).url\"\n                    [target]=\"NavUtilities.asExternalLink(element).openInNewTab ? '_blank' : '_self'\"\n                    [rel]=\"NavUtilities.asExternalLink(element).openInNewTab ? 'noreferrer noopener' : undefined\"\n                >\n                    <i *ngIf=\"NavUtilities.asExternalLink(element).icon\" [class]=\"NavUtilities.asExternalLink(element).icon\"></i>\n                    {{NavUtilities.asExternalLink(element).name}}\n                </a>\n            </span>\n            <!-- Button -->\n            <button *ngSwitchCase=\"'button'\" class=\"sidenavElementButton\" mat-raised-button (click)=\"NavUtilities.asButton(element).action()\">\n                <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n                {{NavUtilities.asButton(element).name}}\n            </button>\n            <!-- Flat Button -->\n            <button *ngSwitchCase=\"'buttonFlat'\" class=\"sidenavElementButton\" mat-button (click)=\"NavUtilities.asButton(element).action()\">\n                <i *ngIf=\"NavUtilities.asButton(element).icon\" [class]=\"NavUtilities.asButton(element).icon\"></i>\n                {{NavUtilities.asButton(element).name}}\n            </button>\n            <!-- Custom HTML -->\n            <span *ngSwitchCase=\"'html'\" [innerHtml]=\"getSanitizedHtmlFor(element)\">\n            </span>\n            <!-- Nested Menu -->\n            <button #nestedMenuButton *ngSwitchCase=\"'menu'\" mat-menu-item [matMenuTriggerFor]=\"internalMenu.menu\">\n                <i *ngIf=\"NavUtilities.asMenu(element).icon\" [class]=\"NavUtilities.asMenu(element).icon\"></i>\n                {{NavUtilities.asMenu(element).name}}\n            </button>\n            <ngx-mat-navigation-menu #internalMenu [navMenu]=\"NavUtilities.asMenu(element)\" [sidenav]=\"sidenav\" [menuWidth]=\"nestedMenuWidth\">\n            </ngx-mat-navigation-menu>\n        </div>\n    </div>\n</mat-menu>"]}
|