UNPKG

@ngez/core

Version:

A collection of minimalistic, easy-to-use and fully customizable Angular components, directives and services

183 lines 15.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, ContentChildren, QueryList, ViewEncapsulation } from "@angular/core"; import { faAngleUp, faAngleDown } from '@fortawesome/free-solid-svg-icons'; import { RouterLink, RouterLinkWithHref, Router, NavigationEnd } from "@angular/router"; import { filter } from "rxjs/operators"; var NgEzNavListComponent = /** @class */ (function () { function NgEzNavListComponent(router) { this.router = router; this.routerLinkActiveOptions = { exact: false }; this.faAngleUp = faAngleUp; this.faAngleDown = faAngleDown; this.open = false; this.active = false; } /** * @return {?} */ NgEzNavListComponent.prototype.ngOnChanges = /** * @return {?} */ function () { this.update(); }; /** * @return {?} */ NgEzNavListComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.navigationSubscription = this.router.events .pipe(filter(function (e) { return e instanceof NavigationEnd; })) .subscribe(function (e) { return _this.update(); }); }; /** * @return {?} */ NgEzNavListComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { var _this = this; this.linksQueryListChangesSubscription = this.links.changes.subscribe(function (c) { return _this.update(); }); this.linksWithHrefsQueryListChangesSubscription = this.linksWithHrefs.changes.subscribe(function (c) { return _this.update(); }); this.update(); }; /** * @return {?} */ NgEzNavListComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this.navigationSubscription) this.navigationSubscription.unsubscribe(); if (this.linksQueryListChangesSubscription) this.linksQueryListChangesSubscription.unsubscribe(); if (this.linksWithHrefsQueryListChangesSubscription) this.linksWithHrefsQueryListChangesSubscription.unsubscribe(); }; /** * @return {?} */ NgEzNavListComponent.prototype.onToggle = /** * @return {?} */ function () { this.open = !this.open; }; /** * @private * @return {?} */ NgEzNavListComponent.prototype.update = /** * @private * @return {?} */ function () { if (!this.links || !this.linksWithHrefs || !this.router.navigated) return; this.active = this.hasActiveLinks(); if (!this.open) this.open = this.active; }; /** * @private * @param {?} router * @return {?} */ NgEzNavListComponent.prototype.isLinkActive = /** * @private * @param {?} router * @return {?} */ function (router) { var _this = this; return function (link) { return router.isActive(link.urlTree, _this.exact); }; }; /** * @private * @return {?} */ NgEzNavListComponent.prototype.hasActiveLinks = /** * @private * @return {?} */ function () { return this.links.some(this.isLinkActive(this.router)) || this.linksWithHrefs.some(this.isLinkActive(this.router)); }; Object.defineProperty(NgEzNavListComponent.prototype, "exact", { get: /** * @private * @return {?} */ function () { return this.routerLinkActiveOptions ? this.routerLinkActiveOptions.exact : false; }, enumerable: true, configurable: true }); NgEzNavListComponent.decorators = [ { type: Component, args: [{ selector: 'ngez-nav-list', template: "<div class=\"ngez-nav-list\">\r\n <button (click)=\"onToggle()\" class=\"ngez-nav-list-header\" [class.active]=\"active\">\r\n <span>{{title}}</span>\r\n <fa-icon [icon]=\"open ? faAngleUp : faAngleDown\"></fa-icon>\r\n </button>\r\n <div *ngIf=\"open\" class=\"ngez-nav-list-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n</div>", encapsulation: ViewEncapsulation.None, styles: [".ngez-nav-list{display:flex;flex-direction:column}.ngez-nav-list-header{display:flex;flex-direction:row;justify-content:space-between;border:none;background-color:transparent;margin-right:0;padding-left:6px;padding-top:8px;padding-bottom:10px;cursor:pointer;outline:0}.ngez-nav-list-header.active{color:#d70026}.ngez-nav-list-header:hover{color:#d70026;background-color:#f2f2f2}.ngez-nav-list-content{padding-left:18px}.ngez-nav-list-content a{display:flex;flex-direction:row;justify-content:space-between;border:none;background-color:transparent;padding:6px;text-decoration:none;cursor:pointer}.ngez-nav-list-content a.active{color:#d70026}.ngez-nav-list-content a:hover{background-color:#f2f2f2;color:#d70026}"] }] } ]; /** @nocollapse */ NgEzNavListComponent.ctorParameters = function () { return [ { type: Router } ]; }; NgEzNavListComponent.propDecorators = { title: [{ type: Input }], routerLinkActiveOptions: [{ type: Input }], lists: [{ type: ContentChildren, args: [NgEzNavListComponent,] }], links: [{ type: ContentChildren, args: [RouterLink,] }], linksWithHrefs: [{ type: ContentChildren, args: [RouterLinkWithHref,] }] }; return NgEzNavListComponent; }()); export { NgEzNavListComponent }; if (false) { /** @type {?} */ NgEzNavListComponent.prototype.title; /** @type {?} */ NgEzNavListComponent.prototype.routerLinkActiveOptions; /** @type {?} */ NgEzNavListComponent.prototype.lists; /** @type {?} */ NgEzNavListComponent.prototype.links; /** @type {?} */ NgEzNavListComponent.prototype.linksWithHrefs; /** @type {?} */ NgEzNavListComponent.prototype.faAngleUp; /** @type {?} */ NgEzNavListComponent.prototype.faAngleDown; /** @type {?} */ NgEzNavListComponent.prototype.open; /** @type {?} */ NgEzNavListComponent.prototype.active; /** @type {?} */ NgEzNavListComponent.prototype.navigationSubscription; /** @type {?} */ NgEzNavListComponent.prototype.linksQueryListChangesSubscription; /** @type {?} */ NgEzNavListComponent.prototype.linksWithHrefsQueryListChangesSubscription; /** * @type {?} * @private */ NgEzNavListComponent.prototype.router; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-list.component.js","sourceRoot":"ng://@ngez/core/","sources":["nested-nav/nav-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ContentChildren, QueryList, AfterContentInit, OnInit, OnDestroy, OnChanges, ViewEncapsulation } from \"@angular/core\";\r\nimport { faAngleUp, faAngleDown, IconDefinition } from '@fortawesome/free-solid-svg-icons';\r\nimport { RouterLink, RouterLinkWithHref, Router, NavigationEnd } from \"@angular/router\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { filter } from \"rxjs/operators\";\r\n\r\n@Component({\r\n    selector: 'ngez-nav-list',\r\n    templateUrl: './nav-list.component.html',\r\n    styleUrls: ['./nav-list.component.scss'],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class NgEzNavListComponent implements OnChanges, OnInit, AfterContentInit, OnDestroy {\r\n\r\n    @Input() title: string;\r\n\r\n    @Input() routerLinkActiveOptions: { exact: boolean } = { exact: false };\r\n\r\n    @ContentChildren(NgEzNavListComponent) lists: QueryList<NgEzNavListComponent>;\r\n\r\n    @ContentChildren(RouterLink) links: QueryList<RouterLink>;\r\n\r\n    @ContentChildren(RouterLinkWithHref) linksWithHrefs: QueryList<RouterLinkWithHref>;\r\n\r\n    faAngleUp: IconDefinition = faAngleUp;\r\n\r\n    faAngleDown: IconDefinition = faAngleDown;\r\n\r\n    open: boolean = false;\r\n\r\n    active: boolean = false;\r\n\r\n    navigationSubscription: Subscription;\r\n\r\n    linksQueryListChangesSubscription: Subscription;\r\n\r\n    linksWithHrefsQueryListChangesSubscription: Subscription;\r\n\r\n    constructor(private router: Router) { }\r\n\r\n    ngOnChanges() {\r\n        this.update();\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.navigationSubscription = this.router.events\r\n            .pipe(filter(e => e instanceof NavigationEnd))\r\n            .subscribe(e => this.update())\r\n    }\r\n\r\n    ngAfterContentInit() {\r\n        this.linksQueryListChangesSubscription = \r\n            this.links.changes.subscribe((c) => this.update());\r\n        this.linksWithHrefsQueryListChangesSubscription = \r\n            this.linksWithHrefs.changes.subscribe((c) => this.update());\r\n        this.update();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if(this.navigationSubscription)\r\n            this.navigationSubscription.unsubscribe();\r\n        if(this.linksQueryListChangesSubscription)\r\n            this.linksQueryListChangesSubscription.unsubscribe();\r\n        if(this.linksWithHrefsQueryListChangesSubscription)\r\n            this.linksWithHrefsQueryListChangesSubscription.unsubscribe();\r\n    }\r\n\r\n    onToggle() {\r\n        this.open = !this.open;\r\n    }\r\n\r\n    private update(){\r\n        if(!this.links || !this.linksWithHrefs || !this.router.navigated)\r\n            return;\r\n        this.active = this.hasActiveLinks();\r\n\r\n        if(!this.open)\r\n            this.open = this.active;\r\n    }\r\n\r\n    private isLinkActive(router: Router): (link: (RouterLink | RouterLinkWithHref)) => boolean {\r\n        return (link: RouterLink | RouterLinkWithHref) =>\r\n            router.isActive(link.urlTree, this.exact);\r\n    }\r\n\r\n    private hasActiveLinks(): boolean {\r\n        return this.links.some(this.isLinkActive(this.router)) ||\r\n            this.linksWithHrefs.some(this.isLinkActive(this.router));\r\n    }\r\n\r\n    private get exact(): boolean {\r\n        return this.routerLinkActiveOptions ? this.routerLinkActiveOptions.exact : false;\r\n    }\r\n}"]}