UNPKG

@universis/common

Version:

Universis - common directives and services

510 lines 60.8 kB
import { Component, Input, ElementRef, ViewEncapsulation, Renderer2 } from '@angular/core'; import { ActivatedRoute, Router } from '@angular/router'; import { ButtonTypes } from './ButtonTypes'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "@angular/common"; import * as i3 from "@ngx-translate/core"; export class RouterModalComponent { constructor(_element, _activatedRoute, _router, _renderer) { this._element = _element; this._activatedRoute = _activatedRoute; this._router = _router; this._renderer = _renderer; this.componentModalChanges = null; this.componentButtonChanges = null; this.waiting = false; this.modalTitle = ''; // these properties are here as inputs in order to have a way to customize text and class of each button this.okButtonText = ButtonTypes.ok.buttonText; this.okButtonClass = ButtonTypes.ok.buttonClass; this.cancelButtonText = ButtonTypes.cancel.buttonText; this.cancelButtonClass = ButtonTypes.cancel.buttonClass; this.yesButtonText = ButtonTypes.yes.buttonText; this.yesButtonClass = ButtonTypes.yes.buttonClass; this.noButtonText = ButtonTypes.no.buttonText; this.noButtonClass = ButtonTypes.no.buttonClass; this.abortButtonText = ButtonTypes.abort.buttonText; this.abortButtonClass = ButtonTypes.abort.buttonClass; this.retryButtonText = ButtonTypes.retry.buttonText; this.retryButtonClass = ButtonTypes.retry.buttonClass; this.ignoreButtonText = ButtonTypes.ignore.buttonText; this.ignoreButtonClass = ButtonTypes.ignore.buttonClass; this.previousButtonText = ButtonTypes.previous.buttonText; this.previousButtonClass = ButtonTypes.previous.buttonClass; this.nextButtonText = ButtonTypes.next.buttonText; this.nextButtonClass = ButtonTypes.next.buttonClass; // default instance buttons this.instanceButtons = { ok: null, cancel: null, yes: null, no: null, abort: null, retry: null, ignore: null, previous: null, next: null }; } async cancel() { try { if (this.componentReference) { // set waiting this.waiting = true; // if component has cancel() method if (typeof this.componentReference.cancel === 'function') { // do cancel await this.componentReference.cancel(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async ok() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.ok === 'function') { // do submit await this.componentReference.ok(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async abort() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.abort === 'function') { // do submit await this.componentReference.abort(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async retry() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.retry === 'function') { // do submit await this.componentReference.retry(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async ignore() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.ignore === 'function') { // do submit await this.componentReference.ignore(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async previous() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.previous === 'function') { // do submit await this.componentReference.previous(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async next() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.next === 'function') { // do submit await this.componentReference.next(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async yes() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.yes === 'function') { // do submit await this.componentReference.yes(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } async no() { try { if (this.componentReference) { // set waiting this.waiting = true; if (typeof this.componentReference.no === 'function') { // do submit await this.componentReference.no(); } else { await this._router.navigate(['../'], { relativeTo: this._activatedRoute }); } // unset waiting this.waiting = false; } } catch (err) { this.waiting = false; } } onActivate(event) { this.componentReference = event; // get router outlet component if (this.componentReference) { if (this.componentReference.buttonChanges) { // subscribe for any button changes this.componentButtonChanges = this.componentReference.buttonChanges .subscribe((buttonChange) => { if (buttonChange) { // assign button changes Object.assign(this.instanceButtons, buttonChange); } }); } if (this.componentReference.modalChanges) { // get modal changes this.componentModalChanges = this.componentReference.modalChanges.subscribe((modalChanges) => { this.modalInstanceTitle = modalChanges.modalTitle; if (modalChanges.modalClass) { this.modalInstanceClass = modalChanges.modalClass; } }); } // get title this.modalInstanceTitle = this.componentReference.modalTitle; // get class this.modalInstanceClass = this.componentReference.modalClass; // hold this to validate buttons let hasAtLeastOneButton = false; this.instanceButtons = { ok: null, cancel: null, yes: null, no: null, abort: null, retry: null, ignore: null, previous: null, next: null }; // enumerate button types Object.keys(ButtonTypes).forEach(key => { // search if component has a method with the same name if (typeof this.componentReference[key] === 'function') { // enable button this.instanceButtons[key] = Object.assign({}, ButtonTypes[key]); hasAtLeastOneButton = true; const buttonTextProperty = `${key}ButtonText`; if (this.componentReference.hasOwnProperty(buttonTextProperty)) { this.instanceButtons[key].buttonText = this.componentReference[buttonTextProperty]; } else { // get property from this component this.instanceButtons[key].buttonText = this[buttonTextProperty]; } const buttonClassProperty = `${key}ButtonClass`; if (this.componentReference.hasOwnProperty(buttonClassProperty)) { this.instanceButtons[key].buttonClass = this.componentReference[buttonClassProperty]; } else { // get property from this component this.instanceButtons[key].buttonClass = this[buttonClassProperty]; } } }); if (!hasAtLeastOneButton) { // there are no buttons, so add only ok this.instanceButtons.ok = Object.assign({}, ButtonTypes.ok); } } const backdropElement = this._element.nativeElement.querySelector('.modal-backdrop'); this._element.nativeElement.querySelector('.bd-modal').classList.remove('d-none'); this._renderer.addClass(document.body, 'overflow-hidden'); this._renderer.addClass(document.body, 'pr-3'); // add large modal default styles // this operation adds scrolling to modal container // in cases where modal overflows the height of the container const modalElement = this._element.nativeElement.querySelector('.modal'); if (modalElement) { modalElement.style.setProperty('overflow-x', 'hidden'); modalElement.style.setProperty('overflow-y', 'auto'); } if (backdropElement) { // remove d-none backdropElement.classList.remove('d-none'); // add show backdropElement.classList.add('show'); } return false; } // noinspection JSUnusedLocalSymbols onDeactivate(event) { if (this.componentModalChanges) { this.componentModalChanges.unsubscribe(); this.componentModalChanges = null; } if (this.componentButtonChanges) { this.componentButtonChanges.unsubscribe(); this.componentButtonChanges = null; } // restore properties this.modalInstanceTitle = this.modalTitle; this.modalInstanceClass = this.modalClass; this.componentReference = null; const backdropElement = this._element.nativeElement.querySelector('.modal-backdrop'); this._element.nativeElement.querySelector('.bd-modal').classList.add('d-none'); this._renderer.removeClass(document.body, 'overflow-hidden'); this._renderer.removeClass(document.body, 'pr-3'); if (backdropElement) { // remove show backdropElement.classList.remove('show'); // add d-none backdropElement.classList.add('d-none'); } return false; } } RouterModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RouterModalComponent, deps: [{ token: i0.ElementRef }, { token: i1.ActivatedRoute }, { token: i1.Router }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); RouterModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: RouterModalComponent, selector: "router-modal", inputs: { modalTitle: "modalTitle", modalClass: "modalClass", okButtonText: "okButtonText", okButtonClass: "okButtonClass", cancelButtonText: "cancelButtonText", cancelButtonClass: "cancelButtonClass", yesButtonText: "yesButtonText", yesButtonClass: "yesButtonClass", noButtonText: "noButtonText", noButtonClass: "noButtonClass", abortButtonText: "abortButtonText", abortButtonClass: "abortButtonClass", retryButtonText: "retryButtonText", retryButtonClass: "retryButtonClass", ignoreButtonText: "ignoreButtonText", ignoreButtonClass: "ignoreButtonClass", previousButtonText: "previousButtonText", previousButtonClass: "previousButtonClass", nextButtonText: "nextButtonText", nextButtonClass: "nextButtonClass" }, ngImport: i0, template: ` <div class="bd-modal d-none"> <div class="modal-backdrop fade d-none"></div> <div class="modal" tabindex="-1" role="dialog" [ngClass]="{ 'modal-waiting': waiting }"> <div class="modal-dialog" [ngClass]="modalInstanceClass" role="document"> <div class="modal-content"> <div class="modal-header" *ngIf="modalInstanceTitle"> <h5 class="modal-title">{{modalInstanceTitle | translate}}</h5> <button *ngIf="instanceButtons.cancel" [disabled]="waiting || instanceButtons.cancel.buttonDisabled" (click)="cancel()" type="button" class="close" data-dismiss="modal" aria-label="Cancel"> <span aria-hidden="true">&times;</span> </button> </div> <div class="modal-body"> <router-outlet (activate)="onActivate($event)" (deactivate)="onDeactivate($event)" name="modal"></router-outlet> </div> <div class="modal-footer justify-content-end"> <button *ngIf="instanceButtons.previous" [disabled]="waiting || instanceButtons.previous.buttonDisabled" (click)="previous()" type="button" [ngClass]="instanceButtons.previous.buttonClass"> {{instanceButtons.previous.buttonText | translate}} </button> <button *ngIf="instanceButtons.ok" [disabled]="waiting || instanceButtons.ok.buttonDisabled" (click)="ok()" type="button" [ngClass]="instanceButtons.ok.buttonClass"> {{instanceButtons.ok.buttonText | translate}} </button> <button *ngIf="instanceButtons.yes" [disabled]="waiting || instanceButtons.yes.buttonDisabled" (click)="yes()" type="button" [ngClass]="instanceButtons.yes.buttonClass"> {{instanceButtons.yes.buttonText | translate}} </button> <button *ngIf="instanceButtons.no" [disabled]="waiting || instanceButtons.no.buttonDisabled" (click)="no()" type="button" [ngClass]="instanceButtons.no.buttonClass"> {{instanceButtons.no.buttonText | translate}} </button> <button *ngIf="instanceButtons.next" [disabled]="waiting || instanceButtons.next.buttonDisabled" (click)="next()" type="button" [ngClass]="instanceButtons.next.buttonClass"> {{instanceButtons.next.buttonText | translate}} </button> <button *ngIf="instanceButtons.cancel" [disabled]="waiting || instanceButtons.cancel.buttonDisabled" (click)="cancel()" type="button" [ngClass]="instanceButtons.cancel.buttonClass" data-dismiss="modal"> {{instanceButtons.cancel.buttonText | translate}} </button> <button *ngIf="instanceButtons.abort" [disabled]="waiting || instanceButtons.abort.buttonDisabled" (click)="abort()" type="button" [ngClass]="instanceButtons.abort.buttonClass"> {{instanceButtons.abort.buttonText | translate}} </button> <button *ngIf="instanceButtons.retry" [disabled]="waiting || instanceButtons.retry.buttonDisabled" (click)="retry()" type="button" [ngClass]="instanceButtons.retry.buttonClass"> {{instanceButtons.retry.buttonText | translate}} </button> <button *ngIf="instanceButtons.ignore" [disabled]="waiting || instanceButtons.ignore.buttonDisabled" (click)="ignore()" type="button" [ngClass]="instanceButtons.ignore.buttonClass" data-dismiss="modal"> {{instanceButtons.ignore.buttonText | translate}} </button> </div> </div> </div> </div> </div> `, isInline: true, styles: [".bd-modal .modal{position:fixed;right:auto;bottom:auto;z-index:1045;display:block}.bd-modal .modal .modal-body{margin-top:0;margin-bottom:0}.bd-modal .modal.modal-waiting{opacity:.6}\n"], dependencies: [{ kind: "directive", type: i1.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RouterModalComponent, decorators: [{ type: Component, args: [{ selector: 'router-modal', template: ` <div class="bd-modal d-none"> <div class="modal-backdrop fade d-none"></div> <div class="modal" tabindex="-1" role="dialog" [ngClass]="{ 'modal-waiting': waiting }"> <div class="modal-dialog" [ngClass]="modalInstanceClass" role="document"> <div class="modal-content"> <div class="modal-header" *ngIf="modalInstanceTitle"> <h5 class="modal-title">{{modalInstanceTitle | translate}}</h5> <button *ngIf="instanceButtons.cancel" [disabled]="waiting || instanceButtons.cancel.buttonDisabled" (click)="cancel()" type="button" class="close" data-dismiss="modal" aria-label="Cancel"> <span aria-hidden="true">&times;</span> </button> </div> <div class="modal-body"> <router-outlet (activate)="onActivate($event)" (deactivate)="onDeactivate($event)" name="modal"></router-outlet> </div> <div class="modal-footer justify-content-end"> <button *ngIf="instanceButtons.previous" [disabled]="waiting || instanceButtons.previous.buttonDisabled" (click)="previous()" type="button" [ngClass]="instanceButtons.previous.buttonClass"> {{instanceButtons.previous.buttonText | translate}} </button> <button *ngIf="instanceButtons.ok" [disabled]="waiting || instanceButtons.ok.buttonDisabled" (click)="ok()" type="button" [ngClass]="instanceButtons.ok.buttonClass"> {{instanceButtons.ok.buttonText | translate}} </button> <button *ngIf="instanceButtons.yes" [disabled]="waiting || instanceButtons.yes.buttonDisabled" (click)="yes()" type="button" [ngClass]="instanceButtons.yes.buttonClass"> {{instanceButtons.yes.buttonText | translate}} </button> <button *ngIf="instanceButtons.no" [disabled]="waiting || instanceButtons.no.buttonDisabled" (click)="no()" type="button" [ngClass]="instanceButtons.no.buttonClass"> {{instanceButtons.no.buttonText | translate}} </button> <button *ngIf="instanceButtons.next" [disabled]="waiting || instanceButtons.next.buttonDisabled" (click)="next()" type="button" [ngClass]="instanceButtons.next.buttonClass"> {{instanceButtons.next.buttonText | translate}} </button> <button *ngIf="instanceButtons.cancel" [disabled]="waiting || instanceButtons.cancel.buttonDisabled" (click)="cancel()" type="button" [ngClass]="instanceButtons.cancel.buttonClass" data-dismiss="modal"> {{instanceButtons.cancel.buttonText | translate}} </button> <button *ngIf="instanceButtons.abort" [disabled]="waiting || instanceButtons.abort.buttonDisabled" (click)="abort()" type="button" [ngClass]="instanceButtons.abort.buttonClass"> {{instanceButtons.abort.buttonText | translate}} </button> <button *ngIf="instanceButtons.retry" [disabled]="waiting || instanceButtons.retry.buttonDisabled" (click)="retry()" type="button" [ngClass]="instanceButtons.retry.buttonClass"> {{instanceButtons.retry.buttonText | translate}} </button> <button *ngIf="instanceButtons.ignore" [disabled]="waiting || instanceButtons.ignore.buttonDisabled" (click)="ignore()" type="button" [ngClass]="instanceButtons.ignore.buttonClass" data-dismiss="modal"> {{instanceButtons.ignore.buttonText | translate}} </button> </div> </div> </div> </div> </div> `, encapsulation: ViewEncapsulation.None, styles: [".bd-modal .modal{position:fixed;right:auto;bottom:auto;z-index:1045;display:block}.bd-modal .modal .modal-body{margin-top:0;margin-bottom:0}.bd-modal .modal.modal-waiting{opacity:.6}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ActivatedRoute }, { type: i1.Router }, { type: i0.Renderer2 }]; }, propDecorators: { modalTitle: [{ type: Input }], modalClass: [{ type: Input }], okButtonText: [{ type: Input }], okButtonClass: [{ type: Input }], cancelButtonText: [{ type: Input }], cancelButtonClass: [{ type: Input }], yesButtonText: [{ type: Input }], yesButtonClass: [{ type: Input }], noButtonText: [{ type: Input }], noButtonClass: [{ type: Input }], abortButtonText: [{ type: Input }], abortButtonClass: [{ type: Input }], retryButtonText: [{ type: Input }], retryButtonClass: [{ type: Input }], ignoreButtonText: [{ type: Input }], ignoreButtonClass: [{ type: Input }], previousButtonText: [{ type: Input }], previousButtonClass: [{ type: Input }], nextButtonText: [{ type: Input }], nextButtonClass: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RouterModalComponent.js","sourceRoot":"","sources":["../../../routing/src/RouterModalComponent.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, ElementRef, ViewEncapsulation, EventEmitter, Renderer2} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {Subscription} from 'rxjs';\nimport { ButtonTypes, ButtonType } from './ButtonTypes';\nimport { ModalChanges } from './RouterModal';\n\nexport declare interface RouterModalOutletComponent {\n  modalTitle: string;\n  modalClass: string;\n  statusChanges: EventEmitter<any>;\n}\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'router-modal',\n  template: `\n  <div class=\"bd-modal d-none\">\n    <div class=\"modal-backdrop fade d-none\"></div>\n    <div class=\"modal\" tabindex=\"-1\" role=\"dialog\" [ngClass]=\"{ 'modal-waiting': waiting }\">\n    <div class=\"modal-dialog\" [ngClass]=\"modalInstanceClass\" role=\"document\">\n      <div class=\"modal-content\">\n        <div class=\"modal-header\" *ngIf=\"modalInstanceTitle\">\n          <h5 class=\"modal-title\">{{modalInstanceTitle | translate}}</h5>\n          <button *ngIf=\"instanceButtons.cancel\" [disabled]=\"waiting || instanceButtons.cancel.buttonDisabled\" (click)=\"cancel()\"\n                  type=\"button\" class=\"close\" data-dismiss=\"modal\" aria-label=\"Cancel\">\n            <span aria-hidden=\"true\">&times;</span>\n          </button>\n        </div>\n        <div class=\"modal-body\">\n          <router-outlet (activate)=\"onActivate($event)\" (deactivate)=\"onDeactivate($event)\" name=\"modal\"></router-outlet>\n        </div>\n        <div class=\"modal-footer justify-content-end\">\n          <button *ngIf=\"instanceButtons.previous\" [disabled]=\"waiting || instanceButtons.previous.buttonDisabled\" (click)=\"previous()\"\n                  type=\"button\" [ngClass]=\"instanceButtons.previous.buttonClass\">\n            {{instanceButtons.previous.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.ok\" [disabled]=\"waiting || instanceButtons.ok.buttonDisabled\" (click)=\"ok()\"\n                  type=\"button\" [ngClass]=\"instanceButtons.ok.buttonClass\">\n            {{instanceButtons.ok.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.yes\" [disabled]=\"waiting || instanceButtons.yes.buttonDisabled\"\n                  (click)=\"yes()\" type=\"button\" [ngClass]=\"instanceButtons.yes.buttonClass\">\n            {{instanceButtons.yes.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.no\" [disabled]=\"waiting || instanceButtons.no.buttonDisabled\"\n                  (click)=\"no()\" type=\"button\" [ngClass]=\"instanceButtons.no.buttonClass\">\n            {{instanceButtons.no.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.next\" [disabled]=\"waiting || instanceButtons.next.buttonDisabled\" (click)=\"next()\"\n                  type=\"button\" [ngClass]=\"instanceButtons.next.buttonClass\">\n            {{instanceButtons.next.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.cancel\" [disabled]=\"waiting || instanceButtons.cancel.buttonDisabled\"\n                  (click)=\"cancel()\" type=\"button\" [ngClass]=\"instanceButtons.cancel.buttonClass\" data-dismiss=\"modal\">\n            {{instanceButtons.cancel.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.abort\" [disabled]=\"waiting || instanceButtons.abort.buttonDisabled\"\n                  (click)=\"abort()\" type=\"button\" [ngClass]=\"instanceButtons.abort.buttonClass\">\n            {{instanceButtons.abort.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.retry\" [disabled]=\"waiting || instanceButtons.retry.buttonDisabled\"\n                  (click)=\"retry()\" type=\"button\" [ngClass]=\"instanceButtons.retry.buttonClass\">\n            {{instanceButtons.retry.buttonText | translate}}\n          </button>\n          <button *ngIf=\"instanceButtons.ignore\" [disabled]=\"waiting || instanceButtons.ignore.buttonDisabled\"\n                  (click)=\"ignore()\" type=\"button\" [ngClass]=\"instanceButtons.ignore.buttonClass\" data-dismiss=\"modal\">\n            {{instanceButtons.ignore.buttonText | translate}}\n          </button>\n        </div>\n      </div>\n    </div>\n  </div>\n  </div>\n  `,\n  styles: [`\n    .bd-modal .modal {\n        position: fixed;\n        right: auto;\n        bottom: auto;\n        z-index: 1045;\n        display: block;\n        }\n        .bd-modal .modal .modal-body {\n                margin-top: 0;\n                margin-bottom: 0;\n          }\n        .bd-modal .modal.modal-waiting {\n            opacity: 0.6;\n          }\n  `],\n  encapsulation: ViewEncapsulation.None\n})\nexport class RouterModalComponent {\n\n  private componentReference: any;\n  private componentModalChanges: Subscription | null = null;\n  private componentButtonChanges: Subscription | null = null;\n  public waiting = false;\n  @Input() modalTitle = '';\n  @Input() modalClass: string | undefined;\n\n  // these properties are here as inputs in order to have a way to customize text and class of each button\n\n  @Input() okButtonText = ButtonTypes.ok.buttonText;\n  @Input() okButtonClass = ButtonTypes.ok.buttonClass;\n\n  @Input() cancelButtonText = ButtonTypes.cancel.buttonText;\n  @Input() cancelButtonClass = ButtonTypes.cancel.buttonClass;\n\n  @Input() yesButtonText = ButtonTypes.yes.buttonText ;\n  @Input() yesButtonClass = ButtonTypes.yes.buttonClass;\n\n  @Input() noButtonText = ButtonTypes.no.buttonText ;\n  @Input() noButtonClass = ButtonTypes.no.buttonClass;\n\n  @Input() abortButtonText = ButtonTypes.abort.buttonText;\n  @Input() abortButtonClass = ButtonTypes.abort.buttonClass;\n\n  @Input() retryButtonText = ButtonTypes.retry.buttonText;\n  @Input() retryButtonClass = ButtonTypes.retry.buttonClass;\n\n  @Input() ignoreButtonText = ButtonTypes.ignore.buttonText;\n  @Input() ignoreButtonClass = ButtonTypes.ignore.buttonClass;\n\n  @Input() previousButtonText = ButtonTypes.previous.buttonText;\n  @Input() previousButtonClass = ButtonTypes.previous.buttonClass;\n\n  @Input() nextButtonText = ButtonTypes.next.buttonText;\n  @Input() nextButtonClass = ButtonTypes.next.buttonClass;\n\n  public modalInstanceTitle: string | undefined;\n  public modalInstanceClass: string | undefined;\n\n  // default instance buttons\n\n  public instanceButtons: {\n    ok: ButtonType | null,\n    cancel: ButtonType | null,\n    yes: ButtonType | null,\n    no: ButtonType | null,\n    abort: ButtonType | null,\n    retry: ButtonType | null,\n    ignore: ButtonType | null,\n    previous: ButtonType | null,\n    next: ButtonType | null\n  } = {\n    ok: null,\n    cancel: null,\n    yes: null,\n    no: null,\n    abort: null,\n    retry: null,\n    ignore: null,\n    previous: null,\n    next: null\n  };\n\n  constructor(private _element: ElementRef,\n            private _activatedRoute: ActivatedRoute,\n            private _router: Router,\n            private _renderer: Renderer2) {\n\n  }\n\n  async cancel() {\n    try {\n      if (this.componentReference) {\n\n        // set waiting\n        this.waiting = true;\n        // if component has cancel() method\n        if (typeof this.componentReference.cancel === 'function') {\n          // do cancel\n          await this.componentReference.cancel();\n        } else {\n          await this._router.navigate(['../'], { relativeTo: this._activatedRoute });\n        }\n        // unset waiting\n        this.waiting = false;\n      }\n    } catch (err) {\n      this.waiting = false;\n    }\n  }\n\n  async ok() {\n    try {\n      if (this.componentReference) {\n        // set waiting\n        this.waiting = true;\n        if (typeof this.componentReference.ok === 'function') {\n          // do submit\n          await this.componentReference.ok();\n        } else {\n          await this._router.navigate(['../'], { relativeTo: this._activatedRoute });\n        }\n        // unset waiting\n        this.waiting = false;\n      }\n    } catch (err) {\n      this.waiting = false;\n    }\n  }\n\n  async abort() {\n    try {\n      if (this.componentReference) {\n        // set waiting\n        this.waiting = true;\n        if (typeof this.componentReference.abort === 'function') {\n          // do submit\n          await this.componentReference.abort();\n        } else {\n          await