@universis/common
Version:
Universis - common directives and services
140 lines (139 loc) • 20.8 kB
JavaScript
import { Component, Renderer2, ViewEncapsulation } from '@angular/core';
import { ErrorService } from '../../error.service';
import { TranslateService } from '@ngx-translate/core';
import { ActivatedRoute, Router } from '@angular/router';
export class ErrorBaseComponent {
constructor(_errorService, _translateService, _renderer) {
this._errorService = _errorService;
this._translateService = _translateService;
this._renderer = _renderer;
this.isUserLoggedIn = false;
// hide universis-spinner
const spinnerElement = document.body.getElementsByTagName('universis-spinner')[0];
if (spinnerElement) {
this._renderer.setStyle(spinnerElement, 'display', 'none');
}
// user logged in
this.isUserLoggedIn = (sessionStorage.getItem('currentUser') != null);
// add center content classes
this._renderer.addClass(document.body, 'flex-row');
this._renderer.addClass(document.body, 'align-items-center');
// get last error
const error = this._errorService.getLastError();
// check error.code property
if (error && typeof error.code === 'string') {
this.code = error.code;
}
else if (error && typeof (error.status || error.statusCode) === 'number') {
this.code = `E${error.status || error.statusCode}`;
}
else {
this.code = 'E500';
}
if (error && typeof error.continue === 'string') {
this.continue = error.continue;
}
else {
this.continue = '/';
}
// check if continue link is an absolute URL
this.continueLinkIsAbsolute = this.continueIsAbsolute();
this.action = 'Error.Continue';
}
get displayCode() {
if (/^E(\d+)\.?(\d+)?$/g.test(this.code)) {
return this.code;
}
return 'E500';
}
ngOnInit() {
this._translateService.get(this.code).subscribe((translation) => {
if (translation) {
this.title = translation.title;
this.message = translation.message;
}
else {
this._translateService.get('E500').subscribe((result) => {
this.title = result.title;
this.message = result.message;
});
}
});
}
continueIsAbsolute() {
const regex = new RegExp('^((https?|ftps?):\\/\\/)([\\da-z.-]+)\\.([a-z.]{2,6})([\\/\\w .-]*)*\\/?$');
// returns true if the continue link is absolute
return regex.test(this.continue);
}
ngOnDestroy() {
// remove center content classes
this._renderer.removeClass(document.body, 'flex-row');
this._renderer.removeClass(document.body, 'align-items-center');
}
}
ErrorBaseComponent.decorators = [
{ type: Component, args: [{
selector: 'universis-error-base',
template: "<nav class=\"navbar navbar-expand navbar-light bg-light\" id=\"errorNav\">\n <div class=\"collapse navbar-collapse\">\n <ul class=\"navbar-nav ml-auto\">\n <li class=\"nav-item\">\n <a class=\"nav-link\" [routerLink]=\"['/auth/logout']\" routerLinkActive=\"router-link-active\" [translate]=\"'Error.Logout'\"></a>\n </li>\n </ul>\n </div>\n</nav>\n\n<div class=\"container error-container\">\n <div class=\"col-md-8 col-sm-10 col-xs-10\">\n <div class=\"d-flex flex-row justify-content-center\">\n <i class=\"far fa-frown fa-10x text-secondary\" [title]=displayCode></i>\n </div>\n <div class=\"d-flex flex-row justify-content-center\">\n <div class=\"px-4 py-md-3\">\n <h3 class=\"pt-3 text-center\">{{title}}</h3>\n <h5 class=\"text-muted text-center\">{{message}}</h5>\n <div class=\"text-center pt-4\">\n <ng-container *ngIf = \"continueLinkIsAbsolute\">\n <a [attr.href]=\"continue\" [translate]=\"action\" class=\"btn btn-light rounded\"></a>\n </ng-container>\n <ng-container *ngIf = \"!continueLinkIsAbsolute\">\n <a [routerLink]=\"continue\" [translate]=\"action\" class=\"btn btn-light rounded\"></a>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n\n",
encapsulation: ViewEncapsulation.None,
styles: [".m-error nav{position:fixed;width:100%;z-index:1}.error-container{position:absolute;height:100%;width:100%;padding:0;margin:-8px 0 0 -8px;display:flex;align-items:center;justify-content:center;max-width:none}@media (max-width:575.98px){.border-none{border-style:none!important}}@media (max-width:767.98px){.border-sm-none{border-style:none!important}}@media (max-width:991.98px){.border-md-none{border-style:none!important}}@media (max-width:1199.98px){.border-lg-none{border-style:none!important}}.border-xl-none{border-style:none!important}#errorNav{position:fixed;width:100%;z-index:2}"]
}] }
];
/** @nocollapse */
ErrorBaseComponent.ctorParameters = () => [
{ type: ErrorService },
{ type: TranslateService },
{ type: Renderer2 }
];
export class HttpErrorComponent extends ErrorBaseComponent {
constructor(_errorService, _translateService, _router, _route, _renderer) {
super(_errorService, _translateService, _renderer);
this._errorService = _errorService;
this._translateService = _translateService;
this._router = _router;
this._route = _route;
this._renderer = _renderer;
}
ngOnInit() {
// get params and query params
this._route.params.subscribe((params) => {
if (params.status) {
this.code = `E${params.status}`;
}
this._route.queryParams.subscribe((queryParams) => {
if (queryParams.continue) {
this.continue = queryParams.continue;
// check if continue link is an absolute URL
this.continueLinkIsAbsolute = this.continueIsAbsolute();
}
if (queryParams.action) {
this.action = queryParams.action;
}
this._translateService.get(this.code || 'E500').subscribe((translation) => {
if (translation) {
this.title = translation.title;
this.message = translation.message;
}
});
});
});
}
}
HttpErrorComponent.decorators = [
{ type: Component, args: [{
// tslint:disable-next-line:component-selector
selector: '.m-error.m-error--http',
template: "<nav class=\"navbar navbar-expand navbar-light bg-light\" id=\"errorNav\">\n <div class=\"collapse navbar-collapse\">\n <ul class=\"navbar-nav ml-auto\">\n <li class=\"nav-item\">\n <a class=\"nav-link\" [routerLink]=\"['/auth/logout']\" routerLinkActive=\"router-link-active\" [translate]=\"'Error.Logout'\"></a>\n </li>\n </ul>\n </div>\n</nav>\n\n<div class=\"container error-container\">\n <div class=\"col-md-8 col-sm-10 col-xs-10\">\n <div class=\"d-flex flex-row justify-content-center\">\n <i class=\"far fa-frown fa-10x text-secondary\" [title]=displayCode></i>\n </div>\n <div class=\"d-flex flex-row justify-content-center\">\n <div class=\"px-4 py-md-3\">\n <h3 class=\"pt-3 text-center\">{{title}}</h3>\n <h5 class=\"text-muted text-center\">{{message}}</h5>\n <div class=\"text-center pt-4\">\n <ng-container *ngIf = \"continueLinkIsAbsolute\">\n <a [attr.href]=\"continue\" [translate]=\"action\" class=\"btn btn-light rounded\"></a>\n </ng-container>\n <ng-container *ngIf = \"!continueLinkIsAbsolute\">\n <a [routerLink]=\"continue\" [translate]=\"action\" class=\"btn btn-light rounded\"></a>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n\n",
encapsulation: ViewEncapsulation.None,
styles: [".m-error nav{position:fixed;width:100%;z-index:1}.error-container{position:absolute;height:100%;width:100%;padding:0;margin:-8px 0 0 -8px;display:flex;align-items:center;justify-content:center;max-width:none}@media (max-width:575.98px){.border-none{border-style:none!important}}@media (max-width:767.98px){.border-sm-none{border-style:none!important}}@media (max-width:991.98px){.border-md-none{border-style:none!important}}@media (max-width:1199.98px){.border-lg-none{border-style:none!important}}.border-xl-none{border-style:none!important}#errorNav{position:fixed;width:100%;z-index:2}"]
}] }
];
/** @nocollapse */
HttpErrorComponent.ctorParameters = () => [
{ type: ErrorService },
{ type: TranslateService },
{ type: Router },
{ type: ActivatedRoute },
{ type: Renderer2 }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error-base.component.js","sourceRoot":"ng://@universis/common/","sources":["error/components/error-base/error-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnDestroy, OnInit, Renderer2, ViewEncapsulation} from '@angular/core';\nimport { ErrorService } from '../../error.service';\nimport { TranslateService } from '@ngx-translate/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\n@Component({\n  selector: 'universis-error-base',\n  templateUrl: './error-base.component.html',\n  encapsulation: ViewEncapsulation.None,\n  styleUrls: ['./error-base.component.scss']\n})\nexport class ErrorBaseComponent implements OnInit, OnDestroy {\n\n\n  public isUserLoggedIn = false;\n  public code: string;\n  public title: string;\n  public message: string;\n  public continue: string;\n  public action: string;\n  public continueLinkIsAbsolute: boolean;\n\n  constructor(protected _errorService: ErrorService,\n            protected _translateService: TranslateService,\n              protected _renderer: Renderer2) {\n      // hide universis-spinner\n      const spinnerElement = document.body.getElementsByTagName('universis-spinner')[0];\n      if (spinnerElement) {\n        this._renderer.setStyle(spinnerElement, 'display', 'none');\n      }\n      // user logged in\n      this.isUserLoggedIn = (sessionStorage.getItem('currentUser') != null);\n      // add center content classes\n      this._renderer.addClass(document.body, 'flex-row');\n      this._renderer.addClass(document.body, 'align-items-center');\n    // get last error\n    const error = this._errorService.getLastError();\n    // check error.code property\n    if (error && typeof error.code === 'string') {\n      this.code = error.code;\n    } else if (error && typeof (error.status || error.statusCode) === 'number') {\n      this.code = `E${error.status || error.statusCode}`;\n    } else {\n      this.code = 'E500';\n    }\n    if (error && typeof error.continue === 'string') {\n      this.continue = error.continue;\n    } else {\n      this.continue = '/';\n    }\n    // check if continue link is an absolute URL\n    this.continueLinkIsAbsolute = this.continueIsAbsolute();\n    this.action = 'Error.Continue';\n\n  }\n\n    get displayCode() {\n        if (/^E(\\d+)\\.?(\\d+)?$/g.test(this.code)) {\n            return this.code;\n        }\n        return 'E500';\n    }\n\n  ngOnInit() {\n\n\n    this._translateService.get(this.code).subscribe((translation) => {\n      if (translation) {\n        this.title = translation.title;\n        this.message = translation.message;\n      } else {\n        this._translateService.get('E500').subscribe((result) => {\n          this.title = result.title;\n          this.message = result.message;\n        });\n      }\n    });\n  }\n\n    continueIsAbsolute(): boolean {\n      const regex = new RegExp('^((https?|ftps?):\\\\/\\\\/)([\\\\da-z.-]+)\\\\.([a-z.]{2,6})([\\\\/\\\\w .-]*)*\\\\/?$');\n      // returns true if the continue link is absolute\n      return regex.test(this.continue);\n    }\n\n    ngOnDestroy(): void {\n      // remove center content classes\n        this._renderer.removeClass(document.body, 'flex-row');\n        this._renderer.removeClass(document.body, 'align-items-center');\n    }\n}\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: '.m-error.m-error--http',\n  templateUrl: './error-base.component.html',\n  encapsulation: ViewEncapsulation.None,\n  styleUrls: ['./error-base.component.scss']\n})\nexport class HttpErrorComponent extends ErrorBaseComponent implements OnInit, OnDestroy {\n  constructor(protected _errorService: ErrorService,\n    protected _translateService: TranslateService,\n    private _router: Router,\n    private _route: ActivatedRoute,\n              protected _renderer: Renderer2) {\n    super(_errorService, _translateService, _renderer);\n  }\n\n  ngOnInit() {\n    // get params and query params\n    this._route.params.subscribe((params) => {\n      if (params.status) {\n        this.code = `E${params.status}`;\n      }\n      this._route.queryParams.subscribe((queryParams) => {\n        if (queryParams.continue) {\n          this.continue = queryParams.continue;\n          // check if continue link is an absolute URL\n          this.continueLinkIsAbsolute = this.continueIsAbsolute();\n        }\n        if (queryParams.action) {\n          this.action = queryParams.action;\n        }\n        this._translateService.get(this.code || 'E500').subscribe((translation) => {\n          if (translation) {\n            this.title = translation.title;\n            this.message = translation.message;\n          }\n        });\n      });\n    });\n  }\n}\n"]}