You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
abp/npm/ng-packs/dist/theme-basic/esm5/lib/components/application-layout/application-layout.componen...

316 lines
28 KiB

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { GetAppConfiguration, ConfigState, SetLanguage, SessionState, takeUntilDestroy, } from '@abp/ng.core';
import { Component, QueryList, TemplateRef, ViewChild, ViewChildren, } from '@angular/core';
import { NgbDropdown } from '@ng-bootstrap/ng-bootstrap';
import { Navigate, RouterState } from '@ngxs/router-plugin';
import { Select, Store } from '@ngxs/store';
import { OAuthService } from 'angular-oauth2-oidc';
import compare from 'just-compare';
import { fromEvent, Observable } from 'rxjs';
import { debounceTime, filter, map } from 'rxjs/operators';
import snq from 'snq';
import { AddNavigationElement } from '../../actions';
import { LayoutState } from '../../states';
var ApplicationLayoutComponent = /** @class */ (function () {
function ApplicationLayoutComponent(store, oauthService) {
this.store = store;
this.oauthService = oauthService;
this.rightPartElements = [];
this.trackByFn = (/**
* @param {?} _
* @param {?} item
* @return {?}
*/
function (_, item) { return item.name; });
this.trackElementByFn = (/**
* @param {?} _
* @param {?} element
* @return {?}
*/
function (_, element) { return element; });
}
Object.defineProperty(ApplicationLayoutComponent.prototype, "visibleRoutes$", {
get: /**
* @return {?}
*/
function () {
return this.routes$.pipe(map((/**
* @param {?} routes
* @return {?}
*/
function (routes) { return getVisibleRoutes(routes); })));
},
enumerable: true,
configurable: true
});
Object.defineProperty(ApplicationLayoutComponent.prototype, "defaultLanguage$", {
get: /**
* @return {?}
*/
function () {
var _this = this;
return this.languages$.pipe(map((/**
* @param {?} languages
* @return {?}
*/
function (languages) { return snq((/**
* @return {?}
*/
function () { return languages.find((/**
* @param {?} lang
* @return {?}
*/
function (lang) { return lang.cultureName === _this.selectedLangCulture; })).displayName; })); }), ''));
},
enumerable: true,
configurable: true
});
Object.defineProperty(ApplicationLayoutComponent.prototype, "dropdownLanguages$", {
get: /**
* @return {?}
*/
function () {
var _this = this;
return this.languages$.pipe(map((/**
* @param {?} languages
* @return {?}
*/
function (languages) { return snq((/**
* @return {?}
*/
function () { return languages.filter((/**
* @param {?} lang
* @return {?}
*/
function (lang) { return lang.cultureName !== _this.selectedLangCulture; })); })); }), []));
},
enumerable: true,
configurable: true
});
Object.defineProperty(ApplicationLayoutComponent.prototype, "selectedLangCulture", {
get: /**
* @return {?}
*/
function () {
return this.store.selectSnapshot(SessionState.getLanguage);
},
enumerable: true,
configurable: true
});
/**
* @private
* @return {?}
*/
ApplicationLayoutComponent.prototype.checkWindowWidth = /**
* @private
* @return {?}
*/
function () {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this.navbarRootDropdowns.forEach((/**
* @param {?} item
* @return {?}
*/
function (item) {
item.close();
}));
if (window.innerWidth < 768) {
_this.isDropdownChildDynamic = false;
}
else {
_this.isDropdownChildDynamic = true;
}
}), 0);
};
/**
* @return {?}
*/
ApplicationLayoutComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var navigations = this.store.selectSnapshot(LayoutState.getNavigationElements).map((/**
* @param {?} __0
* @return {?}
*/
function (_a) {
var name = _a.name;
return name;
}));
if (navigations.indexOf('LanguageRef') < 0) {
this.store.dispatch(new AddNavigationElement([
{ element: this.languageRef, order: 4, name: 'LanguageRef' },
{ element: this.currentUserRef, order: 5, name: 'CurrentUserRef' },
]));
}
this.navElements$
.pipe(map((/**
* @param {?} elements
* @return {?}
*/
function (elements) { return elements.map((/**
* @param {?} __0
* @return {?}
*/
function (_a) {
var element = _a.element;
return element;
})); })), filter((/**
* @param {?} elements
* @return {?}
*/
function (elements) { return !compare(elements, _this.rightPartElements); })), takeUntilDestroy(this))
.subscribe((/**
* @param {?} elements
* @return {?}
*/
function (elements) {
setTimeout((/**
* @return {?}
*/
function () { return (_this.rightPartElements = elements); }), 0);
}));
this.checkWindowWidth();
fromEvent(window, 'resize')
.pipe(takeUntilDestroy(this), debounceTime(250))
.subscribe((/**
* @return {?}
*/
function () {
_this.checkWindowWidth();
}));
};
/**
* @return {?}
*/
ApplicationLayoutComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () { };
/**
* @param {?} cultureName
* @return {?}
*/
ApplicationLayoutComponent.prototype.onChangeLang = /**
* @param {?} cultureName
* @return {?}
*/
function (cultureName) {
this.store.dispatch(new SetLanguage(cultureName));
};
/**
* @return {?}
*/
ApplicationLayoutComponent.prototype.logout = /**
* @return {?}
*/
function () {
this.oauthService.logOut();
this.store.dispatch(new Navigate(['/'], null, {
state: { redirectUrl: this.store.selectSnapshot(RouterState).state.url },
}));
this.store.dispatch(new GetAppConfiguration());
};
// required for dynamic component
ApplicationLayoutComponent.type = "application" /* application */;
ApplicationLayoutComponent.decorators = [
{ type: Component, args: [{
selector: 'abp-layout-application',
template: "<abp-layout>\n <ul class=\"navbar-nav mr-auto\">\n <ng-container\n *ngFor=\"let route of visibleRoutes$ | async; trackBy: trackByFn\"\n [ngTemplateOutlet]=\"route?.children?.length ? dropdownLink : defaultLink\"\n [ngTemplateOutletContext]=\"{ $implicit: route }\"\n >\n </ng-container>\n\n <ng-template #defaultLink let-route>\n <li class=\"nav-item\" [abpPermission]=\"route.requiredPolicy\">\n <a class=\"nav-link\" [routerLink]=\"[route.url]\">{{ route.name | abpLocalization }}</a>\n </li>\n </ng-template>\n\n <ng-template #dropdownLink let-route>\n <li\n #navbarRootDropdown\n ngbDropdown\n [abpPermission]=\"route.requiredPolicy\"\n [abpVisibility]=\"routeContainer\"\n class=\"nav-item dropdown pointer\"\n display=\"static\"\n >\n <a ngbDropdownToggle class=\"nav-link dropdown-toggle pointer\" data-toggle=\"dropdown\">\n {{ route.name | abpLocalization }}\n </a>\n <div #routeContainer ngbDropdownMenu class=\"dropdown-menu dropdown-menu-right\">\n <ng-template\n #forTemplate\n ngFor\n [ngForOf]=\"route.children\"\n [ngForTrackBy]=\"trackByFn\"\n [ngForTemplate]=\"childWrapper\"\n ></ng-template>\n </div>\n </li>\n </ng-template>\n\n <ng-template #childWrapper let-child>\n <ng-template\n [ngTemplateOutlet]=\"child?.children?.length ? dropdownChild : defaultChild\"\n [ngTemplateOutletContext]=\"{ $implicit: child }\"\n ></ng-template>\n </ng-template>\n\n <ng-template #defaultChild let-child>\n <div class=\"dropdown-submenu\" [abpPermission]=\"child.requiredPolicy\">\n <a class=\"dropdown-item py-2 px-2\" [routerLink]=\"[child.url]\">\n <i *ngIf=\"child.iconClass\" [ngClass]=\"child.iconClass\"></i>\n {{ child.name | abpLocalization }}</a\n >\n </div>\n </ng-template>\n\n <ng-template #dropdownChild let-child>\n <div\n [abpVisibility]=\"childrenContainer\"\n class=\"dropdown-submenu pointer\"\n ngbDropdown\n [display]=\"isDropdownChildDynamic ? 'dynamic' : 'static'\"\n placement=\"right-top\"\n [abpPermission]=\"child.requiredPolicy\"\n >\n <div ngbDropdownToggle [class.dropdown-toggle]=\"false\" class=\"pointer\">\n <a\n abpEllipsis=\"210px\"\n [abpEllipsisEnabled]=\"isDropdownChildDynamic\"\n role=\"button\"\n class=\"btn d-block text-left py-2 px-2 dropdown-toggle\"\n >\n <i *ngIf=\"child.iconClass\" [ngClass]=\"child.iconClass\"></i>\n {{ child.name | abpLocalization }}\n </a>\n </div>\n <div #childrenContainer ngbDropdownMenu class=\"dropdown-menu dropdown-menu-right\">\n <ng-template\n ngFor\n [ngForOf]=\"child.children\"\n [ngForTrackBy]=\"trackByFn\"\n [ngForTemplate]=\"childWrapper\"\n ></ng-template>\n </div>\n </div>\n </ng-template>\n </ul>\n\n <ul class=\"navbar-nav ml-auto\">\n <ng-container\n *ngFor=\"let element of rightPartElements; trackBy: trackElementByFn\"\n [ngTemplateOutlet]=\"element\"\n ></ng-container>\n </ul>\n</abp-layout>\n\n<ng-template #language>\n <li class=\"nav-item dropdown pointer\" ngbDropdown>\n <a ngbDropdownToggle class=\"nav-link dropdown-toggle text-white pointer\" data-toggle=\"dropdown\">\n {{ defaultLanguage$ | async }}\n </a>\n <div ngbDropdownMenu class=\"dropdown-menu dropdown-menu-right\">\n <a\n *ngFor=\"let lang of dropdownLanguages$ | async\"\n class=\"dropdown-item\"\n (click)=\"onChangeLang(lang.cultureName)\"\n >{{ lang?.displayName }}</a\n >\n </div>\n </li>\n</ng-template>\n\n<ng-template #currentUser>\n <li *ngIf=\"(currentUser$ | async)?.isAuthenticated\" class=\"nav-item dropdown pointer\" ngbDropdown>\n <a ngbDropdownToggle class=\"nav-link dropdown-toggle text-white pointer\" data-toggle=\"dropdown\">\n {{ (currentUser$ | async)?.userName }}\n </a>\n <div ngbDropdownMenu class=\"dropdown-menu dropdown-menu-right\">\n <a class=\"dropdown-item pointer\" routerLink=\"/account/manage-profile\">{{\n 'AbpAccount::ManageYourProfile' | abpLocalization\n }}</a>\n <a class=\"dropdown-item pointer\" (click)=\"logout()\">{{ 'AbpUi::Logout' | abpLocalization }}</a>\n </div>\n </li>\n</ng-template>\n"
}] }
];
/** @nocollapse */
ApplicationLayoutComponent.ctorParameters = function () { return [
{ type: Store },
{ type: OAuthService }
]; };
ApplicationLayoutComponent.propDecorators = {
currentUserRef: [{ type: ViewChild, args: ['currentUser', { static: false, read: TemplateRef },] }],
languageRef: [{ type: ViewChild, args: ['language', { static: false, read: TemplateRef },] }],
navbarRootDropdowns: [{ type: ViewChildren, args: ['navbarRootDropdown', { read: NgbDropdown },] }]
};
tslib_1.__decorate([
Select(ConfigState.getOne('routes')),
tslib_1.__metadata("design:type", Observable)
], ApplicationLayoutComponent.prototype, "routes$", void 0);
tslib_1.__decorate([
Select(ConfigState.getOne('currentUser')),
tslib_1.__metadata("design:type", Observable)
], ApplicationLayoutComponent.prototype, "currentUser$", void 0);
tslib_1.__decorate([
Select(ConfigState.getDeep('localization.languages')),
tslib_1.__metadata("design:type", Observable)
], ApplicationLayoutComponent.prototype, "languages$", void 0);
tslib_1.__decorate([
Select(LayoutState.getNavigationElements),
tslib_1.__metadata("design:type", Observable)
], ApplicationLayoutComponent.prototype, "navElements$", void 0);
return ApplicationLayoutComponent;
}());
export { ApplicationLayoutComponent };
if (false) {
/** @type {?} */
ApplicationLayoutComponent.type;
/** @type {?} */
ApplicationLayoutComponent.prototype.routes$;
/** @type {?} */
ApplicationLayoutComponent.prototype.currentUser$;
/** @type {?} */
ApplicationLayoutComponent.prototype.languages$;
/** @type {?} */
ApplicationLayoutComponent.prototype.navElements$;
/** @type {?} */
ApplicationLayoutComponent.prototype.currentUserRef;
/** @type {?} */
ApplicationLayoutComponent.prototype.languageRef;
/** @type {?} */
ApplicationLayoutComponent.prototype.navbarRootDropdowns;
/** @type {?} */
ApplicationLayoutComponent.prototype.isDropdownChildDynamic;
/** @type {?} */
ApplicationLayoutComponent.prototype.rightPartElements;
/** @type {?} */
ApplicationLayoutComponent.prototype.trackByFn;
/** @type {?} */
ApplicationLayoutComponent.prototype.trackElementByFn;
/**
* @type {?}
* @private
*/
ApplicationLayoutComponent.prototype.store;
/**
* @type {?}
* @private
*/
ApplicationLayoutComponent.prototype.oauthService;
}
/**
* @param {?} routes
* @return {?}
*/
function getVisibleRoutes(routes) {
return routes.reduce((/**
* @param {?} acc
* @param {?} val
* @return {?}
*/
function (acc, val) {
if (val.invisible)
return acc;
if (val.children && val.children.length) {
val.children = getVisibleRoutes(val.children);
}
return tslib_1.__spread(acc, [val]);
}), []);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"application-layout.component.js","sourceRoot":"ng://@abp/ng.theme.basic/","sources":["lib/components/application-layout/application-layout.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAGL,mBAAmB,EACnB,WAAW,EAEX,WAAW,EACX,YAAY,EACZ,gBAAgB,GACjB,MAAM,cAAc,CAAC;AACtB,OAAO,EAEL,SAAS,EAET,SAAS,EACT,WAAW,EAEX,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,OAAO,MAAM,cAAc,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C;IA4DE,oCAAoB,KAAY,EAAU,YAA0B;QAAhD,UAAK,GAAL,KAAK,CAAO;QAAU,iBAAY,GAAZ,YAAY,CAAc;QANpE,sBAAiB,GAAuB,EAAE,CAAC;QAE3C,cAAS;;;;;QAAmC,UAAC,CAAC,EAAE,IAAI,IAAK,OAAA,IAAI,CAAC,IAAI,EAAT,CAAS,EAAC;QAEnE,qBAAgB;;;;;QAAmC,UAAC,CAAC,EAAE,OAAO,IAAK,OAAA,OAAO,EAAP,CAAO,EAAC;IAEJ,CAAC;IA7BxE,sBAAI,sDAAc;;;;QAAlB;YACE,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG;;;;YAAC,UAAA,MAAM,IAAI,OAAA,gBAAgB,CAAC,MAAM,CAAC,EAAxB,CAAwB,EAAC,CAAC,CAAC;QACpE,CAAC;;;OAAA;IAED,sBAAI,wDAAgB;;;;QAApB;YAAA,iBAOC;YANC,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CACzB,GAAG;;;;YACD,UAAA,SAAS,IAAI,OAAA,GAAG;;;YAAC,cAAM,OAAA,SAAS,CAAC,IAAI;;;;YAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,WAAW,KAAK,KAAI,CAAC,mBAAmB,EAA7C,CAA6C,EAAC,CAAC,WAAW,EAAjF,CAAiF,EAAC,EAA5F,CAA4F,GACzG,EAAE,CACH,CACF,CAAC;QACJ,CAAC;;;OAAA;IAED,sBAAI,0DAAkB;;;;QAAtB;YAAA,iBAIC;YAHC,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CACzB,GAAG;;;;YAAC,UAAA,SAAS,IAAI,OAAA,GAAG;;;YAAC,cAAM,OAAA,SAAS,CAAC,MAAM;;;;YAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,WAAW,KAAK,KAAI,CAAC,mBAAmB,EAA7C,CAA6C,EAAC,EAAvE,CAAuE,EAAC,EAAlF,CAAkF,GAAE,EAAE,CAAC,CACzG,CAAC;QACJ,CAAC;;;OAAA;IAED,sBAAI,2DAAmB;;;;QAAvB;YACE,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QAC7D,CAAC;;;OAAA;;;;;IAUO,qDAAgB;;;;IAAxB;QAAA,iBAWC;QAVC,UAAU;;;QAAC;YACT,KAAI,CAAC,mBAAmB,CAAC,OAAO;;;;YAAC,UAAA,IAAI;gBACnC,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,CAAC,EAAC,CAAC;YACH,IAAI,MAAM,CAAC,UAAU,GAAG,GAAG,EAAE;gBAC3B,KAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;aACrC;iBAAM;gBACL,KAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;aACpC;QACH,CAAC,GAAE,CAAC,CAAC,CAAC;IACR,CAAC;;;;IAED,oDAAe;;;IAAf;QAAA,iBAgCC;;YA/BO,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,GAAG;;;;QAAC,UAAC,EAAQ;gBAAN,cAAI;YAAO,OAAA,IAAI;QAAJ,CAAI,EAAC;QAExG,IAAI,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE;YAC1C,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,IAAI,oBAAoB,CAAC;gBACvB,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE;gBAC5D,EAAE,OAAO,EAAE,IAAI,CAAC,cAAc,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE;aACnE,CAAC,CACH,CAAC;SACH;QAED,IAAI,CAAC,YAAY;aACd,IAAI,CACH,GAAG;;;;QAAC,UAAA,QAAQ,IAAI,OAAA,QAAQ,CAAC,GAAG;;;;QAAC,UAAC,EAAW;gBAAT,oBAAO;YAAO,OAAA,OAAO;QAAP,CAAO,EAAC,EAAtC,CAAsC,EAAC,EACvD,MAAM;;;;QAAC,UAAA,QAAQ,IAAI,OAAA,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAI,CAAC,iBAAiB,CAAC,EAA1C,CAA0C,EAAC,EAC9D,gBAAgB,CAAC,IAAI,CAAC,CACvB;aACA,SAAS;;;;QAAC,UAAA,QAAQ;YACjB,UAAU;;;YAAC,cAAM,OAAA,CAAC,KAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,EAAnC,CAAmC,GAAE,CAAC,CAAC,CAAC;QAC3D,CAAC,EAAC,CAAC;QAEL,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC;aACxB,IAAI,CACH,gBAAgB,CAAC,IAAI,CAAC,EACtB,YAAY,CAAC,GAAG,CAAC,CAClB;aACA,SAAS;;;QAAC;YACT,KAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,EAAC,CAAC;IACP,CAAC;;;;IAED,gDAAW;;;IAAX,cAAe,CAAC;;;;;IAEhB,iDAAY;;;;IAAZ,UAAa,WAAmB;QAC9B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC;IACpD,CAAC;;;;IAED,2CAAM;;;IAAN;QACE,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;QAC3B,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,IAAI,QAAQ,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE;YACxB,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE;SACzE,CAAC,CACH,CAAC;QACF,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC;IACjD,CAAC;;IArHM,+BAAI,mCAA2B;;gBANvC,SAAS,SAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,8+IAAkD;iBACnD;;;;gBAbgB,KAAK;gBACb,YAAY;;;iCA6BlB,SAAS,SAAC,aAAa,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE;8BAG7D,SAAS,SAAC,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE;sCAG1D,YAAY,SAAC,oBAAoB,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;;IAjBzD;QADC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;0CAC5B,UAAU;+DAAkB;IAGrC;QADC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;0CAC5B,UAAU;oEAAuC;IAG/D;QADC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC;0CAC1C,UAAU;kEAAsC;IAG5D;QADC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC;0CAC5B,UAAU;oEAA6B;IA0GvD,iCAAC;CAAA,AA5HD,IA4HC;SAxHY,0BAA0B;;;IAErC,gCAAsC;;IAEtC,6CACqC;;IAErC,kDAC+D;;IAE/D,gDAC4D;;IAE5D,kDACqD;;IAErD,oDACiC;;IAEjC,iDAC8B;;IAE9B,yDAC4C;;IAE5C,4DAAgC;;IAyBhC,uDAA2C;;IAE3C,+CAAmE;;IAEnE,sDAA2E;;;;;IAE/D,2CAAoB;;;;;IAAE,kDAAkC;;;;;;AAkEtE,SAAS,gBAAgB,CAAC,MAAuB;IAC/C,OAAO,MAAM,CAAC,MAAM;;;;;IAAC,UAAC,GAAG,EAAE,GAAG;QAC5B,IAAI,GAAG,CAAC,SAAS;YAAE,OAAO,GAAG,CAAC;QAE9B,IAAI,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE;YACvC,GAAG,CAAC,QAAQ,GAAG,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SAC/C;QAED,wBAAW,GAAG,GAAE,GAAG,GAAE;IACvB,CAAC,GAAE,EAAE,CAAC,CAAC;AACT,CAAC","sourcesContent":["import {\n  ABP,\n  ApplicationConfiguration,\n  GetAppConfiguration,\n  ConfigState,\n  eLayoutType,\n  SetLanguage,\n  SessionState,\n  takeUntilDestroy,\n} from '@abp/ng.core';\nimport {\n  AfterViewInit,\n  Component,\n  OnDestroy,\n  QueryList,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { NgbDropdown } from '@ng-bootstrap/ng-bootstrap';\nimport { Navigate, RouterState } from '@ngxs/router-plugin';\nimport { Select, Store } from '@ngxs/store';\nimport { OAuthService } from 'angular-oauth2-oidc';\nimport compare from 'just-compare';\nimport { fromEvent, Observable } from 'rxjs';\nimport { debounceTime, filter, map } from 'rxjs/operators';\nimport snq from 'snq';\nimport { AddNavigationElement } from '../../actions';\nimport { Layout } from '../../models/layout';\nimport { LayoutState } from '../../states';\n\n@Component({\n  selector: 'abp-layout-application',\n  templateUrl: './application-layout.component.html',\n})\nexport class ApplicationLayoutComponent implements AfterViewInit, OnDestroy {\n  // required for dynamic component\n  static type = eLayoutType.application;\n\n  @Select(ConfigState.getOne('routes'))\n  routes$: Observable<ABP.FullRoute[]>;\n\n  @Select(ConfigState.getOne('currentUser'))\n  currentUser$: Observable<ApplicationConfiguration.CurrentUser>;\n\n  @Select(ConfigState.getDeep('localization.languages'))\n  languages$: Observable<ApplicationConfiguration.Language[]>;\n\n  @Select(LayoutState.getNavigationElements)\n  navElements$: Observable<Layout.NavigationElement[]>;\n\n  @ViewChild('currentUser', { static: false, read: TemplateRef })\n  currentUserRef: TemplateRef<any>;\n\n  @ViewChild('language', { static: false, read: TemplateRef })\n  languageRef: TemplateRef<any>;\n\n  @ViewChildren('navbarRootDropdown', { read: NgbDropdown })\n  navbarRootDropdowns: QueryList<NgbDropdown>;\n\n  isDropdownChildDynamic: boolean;\n\n  get visibleRoutes$(): Observable<ABP.FullRoute[]> {\n    return this.routes$.pipe(map(routes => getVisibleRoutes(routes)));\n  }\n\n  get defaultLanguage$(): Observable<string> {\n    return this.languages$.pipe(\n      map(\n        languages => snq(() => languages.find(lang => lang.cultureName === this.selectedLangCulture).displayName),\n        '',\n      ),\n    );\n  }\n\n  get dropdownLanguages$(): Observable<ApplicationConfiguration.Language[]> {\n    return this.languages$.pipe(\n      map(languages => snq(() => languages.filter(lang => lang.cultureName !== this.selectedLangCulture)), []),\n    );\n  }\n\n  get selectedLangCulture(): string {\n    return this.store.selectSnapshot(SessionState.getLanguage);\n  }\n\n  rightPartElements: TemplateRef<any>[] = [];\n\n  trackByFn: TrackByFunction<ABP.FullRoute> = (_, item) => item.name;\n\n  trackElementByFn: TrackByFunction<ABP.FullRoute> = (_, element) => element;\n\n  constructor(private store: Store, private oauthService: OAuthService) {}\n\n  private checkWindowWidth() {\n    setTimeout(() => {\n      this.navbarRootDropdowns.forEach(item => {\n        item.close();\n      });\n      if (window.innerWidth < 768) {\n        this.isDropdownChildDynamic = false;\n      } else {\n        this.isDropdownChildDynamic = true;\n      }\n    }, 0);\n  }\n\n  ngAfterViewInit() {\n    const navigations = this.store.selectSnapshot(LayoutState.getNavigationElements).map(({ name }) => name);\n\n    if (navigations.indexOf('LanguageRef') < 0) {\n      this.store.dispatch(\n        new AddNavigationElement([\n          { element: this.languageRef, order: 4, name: 'LanguageRef' },\n          { element: this.currentUserRef, order: 5, name: 'CurrentUserRef' },\n        ]),\n      );\n    }\n\n    this.navElements$\n      .pipe(\n        map(elements => elements.map(({ element }) => element)),\n        filter(elements => !compare(elements, this.rightPartElements)),\n        takeUntilDestroy(this),\n      )\n      .subscribe(elements => {\n        setTimeout(() => (this.rightPartElements = elements), 0);\n      });\n\n    this.checkWindowWidth();\n\n    fromEvent(window, 'resize')\n      .pipe(\n        takeUntilDestroy(this),\n        debounceTime(250),\n      )\n      .subscribe(() => {\n        this.checkWindowWidth();\n      });\n  }\n\n  ngOnDestroy() {}\n\n  onChangeLang(cultureName: string) {\n    this.store.dispatch(new SetLanguage(cultureName));\n  }\n\n  logout() {\n    this.oauthService.logOut();\n    this.store.dispatch(\n      new Navigate(['/'], null, {\n        state: { redirectUrl: this.store.selectSnapshot(RouterState).state.url },\n      }),\n    );\n    this.store.dispatch(new GetAppConfiguration());\n  }\n}\n\nfunction getVisibleRoutes(routes: ABP.FullRoute[]) {\n  return routes.reduce((acc, val) => {\n    if (val.invisible) return acc;\n\n    if (val.children && val.children.length) {\n      val.children = getVisibleRoutes(val.children);\n    }\n\n    return [...acc, val];\n  }, []);\n}\n"]}