@ngez/core
Version:
A collection of minimalistic, easy-to-use and fully customizable Angular components, directives and services
183 lines • 15.2 kB
JavaScript
/**
* @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":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,eAAe,EAAE,SAAS,EAAkD,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAChJ,OAAO,EAAE,SAAS,EAAE,WAAW,EAAkB,MAAM,mCAAmC,CAAC;AAC3F,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAExF,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAExC;IAgCI,8BAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAtBzB,4BAAuB,GAAuB,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;QAQxE,cAAS,GAAmB,SAAS,CAAC;QAEtC,gBAAW,GAAmB,WAAW,CAAC;QAE1C,SAAI,GAAY,KAAK,CAAC;QAEtB,WAAM,GAAY,KAAK,CAAC;IAQc,CAAC;;;;IAEvC,0CAAW;;;IAAX;QACI,IAAI,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC;;;;IAED,uCAAQ;;;IAAR;QAAA,iBAIC;QAHG,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM;aAC3C,IAAI,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,YAAY,aAAa,EAA1B,CAA0B,CAAC,CAAC;aAC7C,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,MAAM,EAAE,EAAb,CAAa,CAAC,CAAA;IACtC,CAAC;;;;IAED,iDAAkB;;;IAAlB;QAAA,iBAMC;QALG,IAAI,CAAC,iCAAiC;YAClC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,UAAC,CAAC,IAAK,OAAA,KAAI,CAAC,MAAM,EAAE,EAAb,CAAa,CAAC,CAAC;QACvD,IAAI,CAAC,0CAA0C;YAC3C,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,SAAS,CAAC,UAAC,CAAC,IAAK,OAAA,KAAI,CAAC,MAAM,EAAE,EAAb,CAAa,CAAC,CAAC;QAChE,IAAI,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC;;;;IAED,0CAAW;;;IAAX;QACI,IAAG,IAAI,CAAC,sBAAsB;YAC1B,IAAI,CAAC,sBAAsB,CAAC,WAAW,EAAE,CAAC;QAC9C,IAAG,IAAI,CAAC,iCAAiC;YACrC,IAAI,CAAC,iCAAiC,CAAC,WAAW,EAAE,CAAC;QACzD,IAAG,IAAI,CAAC,0CAA0C;YAC9C,IAAI,CAAC,0CAA0C,CAAC,WAAW,EAAE,CAAC;IACtE,CAAC;;;;IAED,uCAAQ;;;IAAR;QACI,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;IAC3B,CAAC;;;;;IAEO,qCAAM;;;;IAAd;QACI,IAAG,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS;YAC5D,OAAO;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAEpC,IAAG,CAAC,IAAI,CAAC,IAAI;YACT,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC;IAChC,CAAC;;;;;;IAEO,2CAAY;;;;;IAApB,UAAqB,MAAc;QAAnC,iBAGC;QAFG,OAAO,UAAC,IAAqC;YACzC,OAAA,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,KAAI,CAAC,KAAK,CAAC;QAAzC,CAAyC,CAAC;IAClD,CAAC;;;;;IAEO,6CAAc;;;;IAAtB;QACI,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IACjE,CAAC;IAED,sBAAY,uCAAK;;;;;QAAjB;YACI,OAAO,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QACrF,CAAC;;;OAAA;;gBAtFJ,SAAS,SAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,8XAAwC;oBAExC,aAAa,EAAE,iBAAiB,CAAC,IAAI;;iBACxC;;;;gBATwC,MAAM;;;wBAY1C,KAAK;0CAEL,KAAK;wBAEL,eAAe,SAAC,oBAAoB;wBAEpC,eAAe,SAAC,UAAU;iCAE1B,eAAe,SAAC,kBAAkB;;IAuEvC,2BAAC;CAAA,AAvFD,IAuFC;SAjFY,oBAAoB;;;IAE7B,qCAAuB;;IAEvB,uDAAwE;;IAExE,qCAA8E;;IAE9E,qCAA0D;;IAE1D,8CAAmF;;IAEnF,yCAAsC;;IAEtC,2CAA0C;;IAE1C,oCAAsB;;IAEtB,sCAAwB;;IAExB,sDAAqC;;IAErC,iEAAgD;;IAEhD,0EAAyD;;;;;IAE7C,sCAAsB","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}"]}