@universis/common
Version:
Universis - common directives and services
219 lines (217 loc) • 23.6 kB
JavaScript
import { Injectable, Component, Input } from '@angular/core';
import { Router } from '@angular/router';
import { HttpErrorResponse } from '@angular/common/http';
import { BsModalService, BsModalRef } from 'ngx-bootstrap/modal';
import { TranslateService } from '@ngx-translate/core';
import * as i0 from "@angular/core";
import * as i1 from "@ngx-translate/core";
import * as i2 from "ngx-bootstrap/modal";
import * as i3 from "@angular/router";
import * as i4 from "@angular/common";
export class ErrorModalComponent {
constructor(_translateService, bsModalRef, _router) {
this._translateService = _translateService;
this.bsModalRef = bsModalRef;
this._router = _router;
this.continueLink = '/';
this.buttonText = 'Error.Continue';
this.language = this._translateService.currentLang;
}
hide() {
this.bsModalRef.hide();
if (this.continueLink == null) {
return Promise.resolve();
}
if (this.continueLink === '.') {
return Promise.resolve();
}
return this._router.navigate([this.continueLink]);
}
ngOnInit() {
// get last error
const error = this.error;
// 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.continueLink = error.continue;
}
this._translateService.get(this.code).subscribe((translation) => {
if (translation) {
this.title = translation.title;
this.message = (this.error instanceof HttpErrorResponse && this.error.error && this.error.error.message)
? this.error.error.message : translation.message;
// set custom icon class
if (this.iconClass == null) {
if (translation.iconClass || translation.icon) {
this.iconClass = translation.iconClass || translation.icon;
}
}
// set custom button text
if (this.buttonText === 'Error.Continue') {
if (translation.actionText || translation.action) {
this.buttonText = translation.actionText || translation.action;
}
}
if (translation.continue) {
// force set message
this.message = translation.message;
// force set continue link
this.continueLink = translation.continue;
}
}
else {
this._translateService.get('E500').subscribe((translation) => {
this.title = translation.title;
this.message = (this.error instanceof HttpErrorResponse && this.error.error && this.error.error.message)
? this.error.error.message : translation.message;
});
}
});
}
}
ErrorModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ErrorModalComponent, deps: [{ token: i1.TranslateService }, { token: i2.BsModalRef }, { token: i3.Router }], target: i0.ɵɵFactoryTarget.Component });
ErrorModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ErrorModalComponent, selector: "universis-error-modal", inputs: { continueLink: "continueLink", message: "message", title: "title", iconClass: "iconClass", buttonText: "buttonText", error: "error" }, ngImport: i0, template: `
<div class="modal-header text-center">
<button type="button" class="close pull-right" aria-label="Close" (click)="hide()">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body mt-0 mb-0 text-center">
<div class="text-center">
<ng-container *ngIf="iconClass; then iconTemplate; else iconDefault">
</ng-container>
<ng-template #iconTemplate>
<div class="mb-2">
<i [ngClass]="iconClass" class="fa-4x"></i>
</div>
</ng-template>
<ng-template #iconDefault>
<div class="icon-circle icon-circle-danger">
<i class="fa fa-times"></i>
</div>
</ng-template>
<div class="font-2xl font-weight-bold mt-2">
{{title}}
</div>
<p class="mt-2">
{{message}}
</p>
</div>
</div>
<div class="modal-footer">
<button [lang]="language" type="button" (click)="hide()"
class="btn btn-gray-100 btn-ok text-uppercase" [translate]="buttonText"></button>
</div>
`, isInline: true, styles: [".btn-ok{font-size:16px}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ErrorModalComponent, decorators: [{
type: Component,
args: [{ selector: 'universis-error-modal', template: `
<div class="modal-header text-center">
<button type="button" class="close pull-right" aria-label="Close" (click)="hide()">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body mt-0 mb-0 text-center">
<div class="text-center">
<ng-container *ngIf="iconClass; then iconTemplate; else iconDefault">
</ng-container>
<ng-template #iconTemplate>
<div class="mb-2">
<i [ngClass]="iconClass" class="fa-4x"></i>
</div>
</ng-template>
<ng-template #iconDefault>
<div class="icon-circle icon-circle-danger">
<i class="fa fa-times"></i>
</div>
</ng-template>
<div class="font-2xl font-weight-bold mt-2">
{{title}}
</div>
<p class="mt-2">
{{message}}
</p>
</div>
</div>
<div class="modal-footer">
<button [lang]="language" type="button" (click)="hide()"
class="btn btn-gray-100 btn-ok text-uppercase" [translate]="buttonText"></button>
</div>
`, styles: [".btn-ok{font-size:16px}\n"] }]
}], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.BsModalRef }, { type: i3.Router }]; }, propDecorators: { continueLink: [{
type: Input
}], message: [{
type: Input
}], title: [{
type: Input
}], iconClass: [{
type: Input
}], buttonText: [{
type: Input
}], error: [{
type: Input
}] } });
export class ErrorService {
constructor(_router, _modalService) {
this._router = _router;
this._modalService = _modalService;
//
}
/**
* @param {*} error
* @returns {Promise<boolean>}
*/
navigateToError(error) {
this.setLastError(error);
// if error is an instance of HttpErrorResponse
if (error instanceof HttpErrorResponse) {
if (error && error.error && error.error.statusCode) {
return this._router.navigate(['/error', error.error.statusCode]);
}
// navigate to specific error e.g. /error/401
// this will allow application to override specific error pages and show custom errors
return this._router.navigate(['/error', error.status]);
}
if (error && error.statusCode) {
return this._router.navigate(['/error', error.statusCode]);
}
// otherwise show default error component
return this._router.navigate(['/error']);
}
showError(error, options) {
const initialState = Object.assign({
error: error
}, options);
this._modalService.show(ErrorModalComponent, { initialState });
}
/**
* Sets last application error
* @param {*=} err
* @return ErrorService
*/
setLastError(err) {
this._lastError = err;
return this;
}
/**
* Gets last application error
* @return {any}
*/
getLastError() {
return this._lastError;
}
}
ErrorService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ErrorService, deps: [{ token: i3.Router }, { token: i2.BsModalService }], target: i0.ɵɵFactoryTarget.Injectable });
ErrorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ErrorService });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ErrorService, decorators: [{
type: Injectable
}], ctorParameters: function () { return [{ type: i3.Router }, { type: i2.BsModalService }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error.service.js","sourceRoot":"","sources":["../../../src/error/error.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Component, OnInit, Input } from '@angular/core';\nimport { Router } from '@angular/router';\nimport {HttpErrorResponse} from '@angular/common/http';\nimport { BsModalService, BsModalRef } from 'ngx-bootstrap/modal';\nimport { TranslateService } from '@ngx-translate/core';\n\nexport declare interface TranslateError {\n  title?: string;\n  message?: string;\n  action?: string;\n  actionText?: string;\n  continue?: string;\n  icon?: string;\n  iconClass?: string;\n}\n\nexport declare interface ShowErrorModalOptions {\n  continueLink?: string;\n  buttonText?: string;\n  iconClass?: string;\n}\n\n@Component( {\n  selector: 'universis-error-modal',\n  template: `\n    <div class=\"modal-header text-center\">\n      <button type=\"button\" class=\"close pull-right\" aria-label=\"Close\" (click)=\"hide()\">\n        <span aria-hidden=\"true\">&times;</span>\n      </button>\n    </div>\n    <div class=\"modal-body mt-0 mb-0 text-center\">\n      <div class=\"text-center\">\n        <ng-container *ngIf=\"iconClass; then iconTemplate; else iconDefault\">\n        </ng-container>\n        <ng-template #iconTemplate>\n          <div class=\"mb-2\">\n            <i [ngClass]=\"iconClass\" class=\"fa-4x\"></i>\n          </div>\n        </ng-template>\n\n        <ng-template #iconDefault>\n          <div class=\"icon-circle icon-circle-danger\">\n              <i class=\"fa fa-times\"></i>\n          </div>\n        </ng-template>\n            <div class=\"font-2xl font-weight-bold mt-2\">\n              {{title}}\n            </div>\n            <p class=\"mt-2\">\n             {{message}}\n            </p>\n        </div>\n    </div>\n    <div class=\"modal-footer\">\n      <button [lang]=\"language\" type=\"button\" (click)=\"hide()\"\n              class=\"btn btn-gray-100 btn-ok text-uppercase\" [translate]=\"buttonText\"></button>\n    </div>\n  `, styles: [`\n  .btn-ok {\n    font-size: 16px;\n  }\n  `]\n   })\n\n  export class ErrorModalComponent implements OnInit {\n\n    public code;\n    public language;\n    @Input() continueLink = '/';\n    @Input() message: string | undefined;\n    @Input() title: string | undefined;\n    @Input() iconClass?: string;\n    @Input() buttonText = 'Error.Continue';\n    @Input() error: any;\n\n    constructor ( private _translateService: TranslateService,\n                  public bsModalRef: BsModalRef,\n                  private _router: Router ) {\n      this.language = this._translateService.currentLang;\n    }\n\n  hide() {\n      this.bsModalRef.hide();\n      if (this.continueLink == null) {\n        return Promise.resolve();\n      }\n      if (this.continueLink === '.') {\n        return Promise.resolve();\n      }\n      return this._router.navigate([this.continueLink]);\n    }\n\n    ngOnInit() {\n\n      // get last error\n      const error = this.error;\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.continueLink = error.continue;\n      }\n      this._translateService.get(this.code).subscribe((translation: TranslateError) => {\n        if (translation) {\n          this.title = translation.title;\n          this.message = (this.error instanceof HttpErrorResponse && this.error.error && this.error.error.message)\n            ? this.error.error.message : translation.message;\n          // set custom icon class\n          if (this.iconClass == null) {\n            if (translation.iconClass || translation.icon) {\n              this.iconClass = translation.iconClass || translation.icon;\n            }\n          }\n          // set custom button text\n          if (this.buttonText === 'Error.Continue') {\n            if (translation.actionText || translation.action) {\n              this.buttonText = translation.actionText || translation.action;\n            }\n          }\n          if (translation.continue) {\n            // force set message\n            this.message = translation.message;\n            // force set continue link\n            this.continueLink = translation.continue;\n          }\n        } else {\n          this._translateService.get('E500').subscribe((translation: TranslateError) => {\n            this.title = translation.title;\n            this.message = (this.error instanceof HttpErrorResponse && this.error.error && this.error.error.message)\n              ? this.error.error.message : translation.message;\n          });\n        }\n      });\n    }\n  }\n\n\n@Injectable()\nexport class ErrorService {\n\n  private _lastError: any;\n\n  constructor(private _router: Router, private _modalService: BsModalService) {\n    //\n  }\n\n  /**\n   * @param {*} error\n   * @returns {Promise<boolean>}\n   */\n  navigateToError(error) {\n    this.setLastError(error);\n    // if error is an instance of HttpErrorResponse\n    if (error instanceof HttpErrorResponse) {\n      if (error && error.error && error.error.statusCode) {\n        return this._router.navigate(['/error', error.error.statusCode]);\n      }\n      // navigate to specific error e.g. /error/401\n      // this will allow application to override specific error pages and show custom errors\n      return this._router.navigate(['/error', error.status]);\n    }\n    if (error && error.statusCode) {\n      return this._router.navigate(['/error', error.statusCode]);\n    }\n    // otherwise show default error component\n    return this._router.navigate(['/error']);\n  }\n\n  showError(error: any, options?: ShowErrorModalOptions) {\n    const initialState = Object.assign({\n      error: error\n    }, options);\n    this._modalService.show(ErrorModalComponent, {initialState});\n  }\n\n  /**\n   * Sets last application error\n   * @param {*=} err\n   * @return ErrorService\n   */\n  setLastError(err?: any) {\n    this._lastError = err;\n    return this;\n  }\n\n  /**\n   * Gets last application error\n   * @return {any}\n   */\n  getLastError() {\n    return this._lastError;\n  }\n\n}\n"]}