@universis/common
Version:
Universis - common directives and services
510 lines • 60.8 kB
JavaScript
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">×</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">×</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":"AAAA,OAAO,EAAC,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,iBAAiB,EAAgB,SAAS,EAAC,MAAM,eAAe,CAAC;AACvG,OAAO,EAAC,cAAc,EAAE,MAAM,EAAC,MAAM,iBAAiB,CAAC;AAEvD,OAAO,EAAE,WAAW,EAAc,MAAM,eAAe,CAAC;;;;;AAyFxD,MAAM,OAAO,oBAAoB;IAiE/B,YAAoB,QAAoB,EACtB,eAA+B,EAC/B,OAAe,EACf,SAAoB;QAHlB,aAAQ,GAAR,QAAQ,CAAY;QACtB,oBAAe,GAAf,eAAe,CAAgB;QAC/B,YAAO,GAAP,OAAO,CAAQ;QACf,cAAS,GAAT,SAAS,CAAW;QAjE9B,0BAAqB,GAAwB,IAAI,CAAC;QAClD,2BAAsB,GAAwB,IAAI,CAAC;QACpD,YAAO,GAAG,KAAK,CAAC;QACd,eAAU,GAAG,EAAE,CAAC;QAGzB,wGAAwG;QAE/F,iBAAY,GAAG,WAAW,CAAC,EAAE,CAAC,UAAU,CAAC;QACzC,kBAAa,GAAG,WAAW,CAAC,EAAE,CAAC,WAAW,CAAC;QAE3C,qBAAgB,GAAG,WAAW,CAAC,MAAM,CAAC,UAAU,CAAC;QACjD,sBAAiB,GAAG,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC;QAEnD,kBAAa,GAAG,WAAW,CAAC,GAAG,CAAC,UAAU,CAAE;QAC5C,mBAAc,GAAG,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC;QAE7C,iBAAY,GAAG,WAAW,CAAC,EAAE,CAAC,UAAU,CAAE;QAC1C,kBAAa,GAAG,WAAW,CAAC,EAAE,CAAC,WAAW,CAAC;QAE3C,oBAAe,GAAG,WAAW,CAAC,KAAK,CAAC,UAAU,CAAC;QAC/C,qBAAgB,GAAG,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC;QAEjD,oBAAe,GAAG,WAAW,CAAC,KAAK,CAAC,UAAU,CAAC;QAC/C,qBAAgB,GAAG,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC;QAEjD,qBAAgB,GAAG,WAAW,CAAC,MAAM,CAAC,UAAU,CAAC;QACjD,sBAAiB,GAAG,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC;QAEnD,uBAAkB,GAAG,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC;QACrD,wBAAmB,GAAG,WAAW,CAAC,QAAQ,CAAC,WAAW,CAAC;QAEvD,mBAAc,GAAG,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC;QAC7C,oBAAe,GAAG,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC;QAKxD,2BAA2B;QAEpB,oBAAe,GAUlB;YACF,EAAE,EAAE,IAAI;YACR,MAAM,EAAE,IAAI;YACZ,GAAG,EAAE,IAAI;YACT,EAAE,EAAE,IAAI;YACR,KAAK,EAAE,IAAI;YACX,KAAK,EAAE,IAAI;YACX,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;SACX,CAAC;IAOF,CAAC;IAED,KAAK,CAAC,MAAM;QACV,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAE3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,mCAAmC;gBACnC,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,KAAK,UAAU,EAAE;oBACxD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;iBACxC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,EAAE;QACN,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,EAAE,KAAK,UAAU,EAAE;oBACpD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,CAAC;iBACpC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,KAAK,UAAU,EAAE;oBACvD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;iBACvC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,KAAK,UAAU,EAAE;oBACvD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;iBACvC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,MAAM;QACV,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,KAAK,UAAU,EAAE;oBACxD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;iBACxC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,KAAK,UAAU,EAAE;oBAC1D,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;iBAC1C;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,KAAK,UAAU,EAAE;oBACtD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;iBACtC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,GAAG;QACP,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,GAAG,KAAK,UAAU,EAAE;oBACrD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,CAAC;iBACrC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,KAAK,CAAC,EAAE;QACN,IAAI;YACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,cAAc;gBACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,EAAE,KAAK,UAAU,EAAE;oBACpD,YAAY;oBACZ,MAAM,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,CAAC;iBACpC;qBAAM;oBACL,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;iBAC5E;gBACD,gBAAgB;gBAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAED,UAAU,CAAC,KAAK;QACd,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,8BAA8B;QAC9B,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAEzB,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE;gBACvC,mCAAmC;gBACnC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa;qBAC9D,SAAS,CAAE,CAAC,YAA+C,EAAE,EAAE;oBAChE,IAAI,YAAY,EAAE;wBACd,wBAAwB;wBACxB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;qBACrD;gBACL,CAAC,CAAC,CAAC;aACN;YAEH,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE;gBACtC,oBAAoB;gBACpB,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,SAAS,CAAE,CAAC,YAA0B,EAAE,EAAE;oBACxG,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,UAAU,CAAC;oBAClD,IAAI,YAAY,CAAC,UAAU,EAAE;wBACzB,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,UAAU,CAAC;qBACrD;gBACL,CAAC,CAAC,CAAC;aACN;YACD,YAAY;YACZ,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC;YAC7D,YAAY;YACZ,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC;YAC7D,gCAAgC;YAChC,IAAI,mBAAmB,GAAG,KAAK,CAAC;YAChC,IAAI,CAAC,eAAe,GAAG;gBACrB,EAAE,EAAE,IAAI;gBACR,MAAM,EAAE,IAAI;gBACZ,GAAG,EAAE,IAAI;gBACT,EAAE,EAAE,IAAI;gBACR,KAAK,EAAE,IAAI;gBACX,KAAK,EAAE,IAAI;gBACX,MAAM,EAAE,IAAI;gBACZ,QAAQ,EAAE,IAAI;gBACd,IAAI,EAAE,IAAI;aACX,CAAC;YACF,yBAAyB;YACzB,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAE,GAAG,CAAC,EAAE;gBACtC,sDAAsD;gBACtD,IAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,UAAU,EAAE;oBACtD,gBAAgB;oBAChB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,EAAG,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;oBACjE,mBAAmB,GAAG,IAAI,CAAC;oBAC3B,MAAM,kBAAkB,GAAG,GAAG,GAAG,YAAY,CAAC;oBAC9C,IAAI,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,kBAAkB,CAAC,EAAE;wBAC9D,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,CAAC;qBACpF;yBAAM;wBACL,mCAAmC;wBACnC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC;qBACjE;oBACD,MAAM,mBAAmB,GAAG,GAAG,GAAG,aAAa,CAAC;oBAChD,IAAI,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,mBAAmB,CAAC,EAAE;wBAC/D,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,CAAC;qBACtF;yBAAM;wBACL,mCAAmC;wBACnC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC;qBACnE;iBACF;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,mBAAmB,EAAE;gBACxB,uCAAuC;gBACvC,IAAI,CAAC,eAAe,CAAC,EAAE,GAAG,MAAM,CAAC,MAAM,CAAC,EAAG,EAAE,WAAW,CAAC,EAAE,CAAC,CAAC;aAC9D;SACF;QACD,MAAM,eAAe,GAAoB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;QACtG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAClF,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC;QAC1D,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC/C,iCAAiC;QACjC,mDAAmD;QACnD,6DAA6D;QAC7D,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACzE,IAAI,YAAY,EAAE;YAChB,YAAY,CAAC,KAAK,CAAC,WAAW,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YACvD,YAAY,CAAC,KAAK,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;SACtD;QACD,IAAI,eAAe,EAAE;YACnB,gBAAgB;YAChB,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC3C,WAAW;YACX,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;SACvC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,oCAAoC;IACpC,YAAY,CAAC,KAAK;QAChB,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;YACzC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;SACnC;QACD,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC/B,IAAI,CAAC,sBAAsB,CAAC,WAAW,EAAE,CAAC;YAC1C,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;SACpC;QACD,qBAAqB;QACrB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC;QAC1C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC;QAE1C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,MAAM,eAAe,GAAoB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;QACtG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC/E,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC;QAC7D,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAClD,IAAI,eAAe,EAAE;YACnB,cAAc;YACd,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YACzC,aAAa;YACb,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SACzC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;;kHA1WU,oBAAoB;sGAApB,oBAAoB,8vBA7ErB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0DT;4FAmBU,oBAAoB;kBAhFhC,SAAS;+BAEE,cAAc,YACd;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0DT,iBAiBc,iBAAiB,CAAC,IAAI;2KAQ5B,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAIG,YAAY;sBAApB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBAEG,kBAAkB;sBAA1B,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBACG,eAAe;sBAAvB,KAAK","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