mirror of https://github.com/abpframework/abp
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.
316 lines
28 KiB
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":"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","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"]}
|