@stratio/egeo
Version:
314 lines • 29 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-modal/st-modal.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/*
* © 2017 Stratio Big Data Inc., Sucursal en España.
*
* This software is licensed under the Apache License, Version 2.0.
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the terms of the License for more details.
*
* SPDX-License-Identifier: Apache-2.0.
*/
import { ChangeDetectionStrategy, Component, ComponentFactoryResolver, EventEmitter, HostBinding, Input, Output, ViewChild, ViewContainerRef } from '@angular/core';
import { animate, state, style, transition, trigger } from '@angular/animations';
import { StModalConfig, StModalResponse } from './st-modal.model';
import { StWindowRefService } from '../utils/window-service';
export class StModalComponent {
/**
* @param {?} cfr
* @param {?} windowRef
*/
constructor(cfr, windowRef) {
this.cfr = cfr;
this.windowRef = windowRef;
this.disabledAnimation = true;
this.click = new EventEmitter();
this.endAnimation = new EventEmitter();
this.defaultMaxWidth = 600;
this.defaultMinWidth = 400;
this.visibility = 'visible';
this._subscriptions = [];
}
/**
* @return {?}
*/
get hasIcon() {
return this.modalConfig.iconStatus;
}
/**
* @return {?}
*/
get isFullscreen() {
return this.modalConfig.fullscreen;
}
/**
* @return {?}
*/
get title() {
return this.modalConfig.modalTitle;
}
/**
* @return {?}
*/
get buttons() {
return this.modalConfig.buttons || [];
}
/**
* @return {?}
*/
get isMessageModal() {
return this.modalConfig.message && this.modalConfig.message.length > 0;
}
/**
* @return {?}
*/
get isComplexMessageModal() {
return this.modalConfig.html && this.modalConfig.html.length > 0;
}
/**
* @return {?}
*/
get html() {
return this.modalConfig.html;
}
/**
* @return {?}
*/
get message() {
return this.modalConfig.message;
}
/**
* @return {?}
*/
get messageTitle() {
return this.modalConfig.messageTitle;
}
/**
* @return {?}
*/
get modalStyles() {
/** @type {?} */
const maxWidth = this.modalConfig.maxWidth || this.defaultMaxWidth;
/** @type {?} */
const minWidth = this.modalConfig.minWidth || this.defaultMinWidth;
/** @type {?} */
const width = this.getModalActualWidth(maxWidth, minWidth);
return { 'max-width': `${maxWidth}px`, 'min-width': `${minWidth}px`, 'width': `${width}px` };
}
/**
* @return {?}
*/
get emptyModal() {
return this.modalConfig && this.modalConfig.empty;
}
/**
* @return {?}
*/
get showCloseBtn() {
return this.modalConfig.showCloseBtn;
}
/**
* @param {?} event
* @return {?}
*/
animationDone(event) {
if (event.toState === 'hidden') {
this.endAnimation.emit(true);
}
}
/**
* @param {?} event
* @return {?}
*/
onClickButtons(event) {
this.visibility = 'hidden';
this._subscriptions.push(this.endAnimation.subscribe((/**
* @param {?} data
* @return {?}
*/
(data) => {
if (data) {
this.click.emit(event);
}
})));
}
/**
* @return {?}
*/
onClose() {
this.visibility = 'hidden';
this._subscriptions.push(this.endAnimation.subscribe((/**
* @param {?} data
* @return {?}
*/
(data) => {
if (data) {
this.click.emit({
response: StModalResponse.CLOSE,
close: true
});
}
})));
}
/**
* DYNAMIC MODAL BODY COMPONENT LOAD
* @return {?}
*/
ngAfterViewInit() {
this.target = this.emptyModal ? this.targetEmpty : this.targetContent;
if (this.component && !(this.modalConfig.html || this.modalConfig.message)) {
this.loadBody();
}
this.windowRef.nativeWindow.document.body.classList.add('st-modal-overlay');
}
/**
* @return {?}
*/
ngOnDestroy() {
if (this.componentRef) {
this.componentRef.destroy();
}
this.windowRef.nativeWindow.document.body.classList.remove('st-modal-overlay');
if (this._subscriptions.length > 0) {
this._subscriptions.forEach((/**
* @param {?} subscription
* @return {?}
*/
(subscription) => {
if (subscription) {
subscription.unsubscribe();
}
}));
}
}
/**
* @private
* @param {?} maxWidth
* @param {?=} minWidth
* @return {?}
*/
getModalActualWidth(maxWidth, minWidth) {
/** @type {?} */
const screenWidth = this.windowRef.nativeWindow.screen.width;
return screenWidth > maxWidth ? maxWidth : (screenWidth < minWidth ? minWidth : screenWidth);
}
/**
* @private
* @return {?}
*/
loadBody() {
if (!this.componentRef) {
this.target.clear();
/** @type {?} */
const compFactory = this.cfr.resolveComponentFactory(this.component);
this.componentRef = this.target.createComponent(compFactory);
this.bindModalInputs();
}
}
/**
* @private
* @return {?}
*/
bindModalInputs() {
Object.keys(this.modalConfig.inputs).forEach((/**
* @param {?} key
* @return {?}
*/
(key) => {
this.componentRef.instance[key] = ((/** @type {?} */ (this.modalConfig.inputs)))[key];
}));
Object.keys(this.modalConfig.outputs).forEach((/**
* @param {?} key
* @return {?}
*/
(key) => {
this.componentRef.instance[key].subscribe(((/** @type {?} */ (this.modalConfig.outputs)))[key]);
}));
this.componentRef.changeDetectorRef.detectChanges();
}
}
StModalComponent.decorators = [
{ type: Component, args: [{
selector: 'st-modal',
template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<div class=\"st-modal-container\" [@state]=\"visibility\" (@state.done)=\"animationDone($event)\" [@.disabled]=\"disabledAnimation\">\n <section *ngIf=\"emptyModal\" class=\"st-modal\" [ngClass]=\"{'st-modal-fullscreen': isFullscreen}\" [ngStyle]=\"modalStyles\" [hidden]=\"emptyModal\">\n <div #stModalBodyEmpty></div>\n </section>\n <section *ngIf=\"!emptyModal\" class=\"st-modal\" [ngClass]=\"{'st-modal-fullscreen': isFullscreen}\" [ngStyle]=\"modalStyles\" [hidden]=\"!emptyModal\">\n <div class=\"st-modal-header\">\n <div class=\"container\">\n <span class=\"status-icon\" [ngClass]=\"hasIcon\" *ngIf=\"hasIcon\"></span>\n <p class=\"title\">{{title}}</p> <span class=\"close-button\" *ngIf=\"showCloseBtn\" (click)=\"onClose()\"></span>\n\n <st-modal-buttons *ngIf=\"isFullscreen\" [buttonConfig]=\"buttons\" [fullscreen]=\"isFullscreen\" (click)=\"onClickButtons($event)\"></st-modal-buttons>\n </div>\n </div>\n <div class=\"st-modal-body\">\n <div class=\"container\">\n\n <div *ngIf=\"isMessageModal\" class=\"message\">\n <h1 id=\"st-modal-message-plain-title\" class=\"st-modal-message-plain-title\">{{messageTitle}}</h1>\n <p id=\"st-modal-message-plain-message\" class=\"st-modal-message-plain-message\">{{message}}</p>\n </div>\n <div *ngIf=\"isComplexMessageModal\" [innerHTML]=\"html\" id=\"st-modal-message-html\"></div>\n <div #stModalBody id=\"st-modal-message-component\"></div>\n\n </div>\n </div>\n <footer class=\"st-modal-footer\" *ngIf=\"buttons && buttons.length > 0\">\n <div class=\"container\">\n <st-modal-buttons *ngIf=\"!isFullscreen\" [buttonConfig]=\"buttons\" (click)=\"onClickButtons($event)\"></st-modal-buttons>\n </div>\n </footer>\n </section>\n</div>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
animations: [
trigger('state', [
state('void, hidden', style({ opacity: 0 })),
state('visible', style({ opacity: 1 })),
transition('* => visible', [
style({ opacity: 0 }),
animate(300)
]),
transition('* => hidden', [
style({ opacity: 1 }),
animate(300)
])
])
],
styles: ["@charset \"UTF-8\";.st-modal-container{display:flex;height:100vh;left:0;position:fixed;top:0;width:100%}.st-modal-container .st-modal{-ms-grid-row-align:center;align-self:center;display:flex;flex-direction:column;margin:auto}.st-modal-container .st-modal.st-modal-fullscreen{min-height:100vh;max-height:100vh;min-width:100%;max-width:100%}.st-modal-container .st-modal .st-modal-header{display:flex;flex-direction:row;height:70px;width:100%}.st-modal-container .st-modal .st-modal-header .container{display:flex;margin-right:auto;margin-left:auto;width:100%;align-items:center;flex-wrap:nowrap}.st-modal-container .st-modal .st-modal-header .container .status-icon{padding-right:1.05rem}.st-modal-container .st-modal .st-modal-header .container .status-icon.delete:before{content:var(--egeo-st-modal__delete-icon--content, \"\uE043\")}.st-modal-container .st-modal .st-modal-header .container .status-icon.alert:before{content:var(--egeo-st-modal__warning-icon--content, \"\uE613\")}.st-modal-container .st-modal .st-modal-header .container .close-button{font-size:var(--egeo-st-modal__close-icon--font-size,inherit);color:var(--egeo-st-modal__close-icon--color,inherit)}.st-modal-container .st-modal .st-modal-header .container .close-button:before{content:var(--egeo-st-modal__close-icon--content, \"\uE117\")}.st-modal-container .st-modal st-modal-buttons{display:flex;justify-content:flex-end;margin-left:auto}.st-modal-container .st-modal .container{min-width:auto}"]
}] }
];
/** @nocollapse */
StModalComponent.ctorParameters = () => [
{ type: ComponentFactoryResolver },
{ type: StWindowRefService }
];
StModalComponent.propDecorators = {
modalConfig: [{ type: Input }],
component: [{ type: Input }],
disabledAnimation: [{ type: HostBinding, args: ['@.disabled',] }, { type: Input }],
click: [{ type: Output }],
endAnimation: [{ type: Output }],
targetContent: [{ type: ViewChild, args: ['stModalBody', { read: ViewContainerRef, static: false },] }],
targetEmpty: [{ type: ViewChild, args: ['stModalBodyEmpty', { read: ViewContainerRef, static: false },] }]
};
if (false) {
/** @type {?} */
StModalComponent.prototype.modalConfig;
/** @type {?} */
StModalComponent.prototype.component;
/** @type {?} */
StModalComponent.prototype.disabledAnimation;
/** @type {?} */
StModalComponent.prototype.click;
/** @type {?} */
StModalComponent.prototype.endAnimation;
/** @type {?} */
StModalComponent.prototype.targetContent;
/** @type {?} */
StModalComponent.prototype.targetEmpty;
/** @type {?} */
StModalComponent.prototype.defaultMaxWidth;
/** @type {?} */
StModalComponent.prototype.defaultMinWidth;
/** @type {?} */
StModalComponent.prototype.target;
/** @type {?} */
StModalComponent.prototype.visibility;
/**
* @type {?}
* @private
*/
StModalComponent.prototype.componentRef;
/**
* @type {?}
* @private
*/
StModalComponent.prototype._subscriptions;
/**
* @type {?}
* @private
*/
StModalComponent.prototype.cfr;
/**
* @type {?}
* @private
*/
StModalComponent.prototype.windowRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-modal.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-modal/st-modal.component.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAUA,OAAO,EACJ,uBAAuB,EACvB,SAAS,EACT,wBAAwB,EAExB,YAAY,EACZ,WAAW,EACX,KAAK,EAGL,MAAM,EACN,SAAS,EACT,gBAAgB,EAAC,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,OAAO,EAAkB,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAGjG,OAAO,EAAwC,aAAa,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACxG,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAsB7D,MAAM,OAAO,gBAAgB;;;;;IAmB1B,YACW,GAA6B,EAC7B,SAA6B;QAD7B,QAAG,GAAH,GAAG,CAA0B;QAC7B,cAAS,GAAT,SAAS,CAAoB;QAjB/B,sBAAiB,GAAY,IAAI,CAAC;QACjC,UAAK,GAAwC,IAAI,YAAY,EAAyB,CAAC;QACvF,iBAAY,GAA2B,IAAI,YAAY,EAAW,CAAC;QAIpE,oBAAe,GAAW,GAAG,CAAC;QAC9B,oBAAe,GAAW,GAAG,CAAC;QAGvC,eAAU,GAAW,SAAS,CAAC;QAGvB,mBAAc,GAAwB,EAAE,CAAC;IAK7C,CAAC;;;;IAEL,IAAI,OAAO;QACR,OAAO,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;IACtC,CAAC;;;;IAED,IAAI,YAAY;QACb,OAAO,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;IACtC,CAAC;;;;IAED,IAAI,KAAK;QACN,OAAO,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;IACtC,CAAC;;;;IAED,IAAI,OAAO;QACR,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,EAAE,CAAC;IACzC,CAAC;;;;IAED,IAAI,cAAc;QACf,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;IAC1E,CAAC;;;;IAED,IAAI,qBAAqB;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IACpE,CAAC;;;;IAED,IAAI,IAAI;QACL,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IAChC,CAAC;;;;IAED,IAAI,OAAO;QACR,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;IACnC,CAAC;;;;IAED,IAAI,YAAY;QACb,OAAO,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;IACxC,CAAC;;;;IAED,IAAI,WAAW;;cACN,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe;;cAC5D,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe;;cAC5D,KAAK,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC;QAC1D,OAAO,EAAE,WAAW,EAAE,GAAG,QAAQ,IAAI,EAAE,WAAW,EAAE,GAAG,QAAQ,IAAI,EAAE,OAAO,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC;IAChG,CAAC;;;;IAED,IAAI,UAAU;QACX,OAAO,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;IACrD,CAAC;;;;IAED,IAAI,YAAY;QACb,OAAO,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;IACxC,CAAC;;;;;IAED,aAAa,CAAC,KAAqB;QAChC,IAAI,KAAK,CAAC,OAAO,KAAK,QAAQ,EAAE;YAC7B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/B;IACJ,CAAC;;;;;IAED,cAAc,CAAC,KAAU;QACtB,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS;;;;QAAC,CAAC,IAAI,EAAE,EAAE;YAC3D,IAAI,IAAI,EAAE;gBACP,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACzB;QACJ,CAAC,EAAC,CAAC,CAAC;IACP,CAAC;;;;IAED,OAAO;QACJ,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS;;;;QAAC,CAAC,IAAI,EAAE,EAAE;YAC3D,IAAI,IAAI,EAAE;gBACP,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;oBACb,QAAQ,EAAE,eAAe,CAAC,KAAK;oBAC/B,KAAK,EAAE,IAAI;iBACb,CAAC,CAAC;aACL;QACJ,CAAC,EAAC,CAAC,CAAC;IACP,CAAC;;;;;IAGD,eAAe;QACZ,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;QACtE,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE;YACzE,IAAI,CAAC,QAAQ,EAAE,CAAC;SAClB;QACD,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;IAC/E,CAAC;;;;IAED,WAAW;QACR,IAAI,IAAI,CAAC,YAAY,EAAE;YACpB,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;SAC9B;QACD,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAC/E,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;YACjC,IAAI,CAAC,cAAc,CAAC,OAAO;;;;YAAC,CAAC,YAAY,EAAE,EAAE;gBAC1C,IAAI,YAAY,EAAE;oBACf,YAAY,CAAC,WAAW,EAAE,CAAC;iBAC7B;YACJ,CAAC,EAAC,CAAC;SACL;IACJ,CAAC;;;;;;;IAEO,mBAAmB,CAAC,QAAgB,EAAE,QAAiB;;cACtD,WAAW,GAAW,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK;QACpE,OAAO,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IAChG,CAAC;;;;;IAEO,QAAQ;QACb,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;;kBACd,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC;YACpE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YAC7D,IAAI,CAAC,eAAe,EAAE,CAAC;SACzB;IACJ,CAAC;;;;;IAEO,eAAe;QACpB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,OAAO;;;;QAAC,CAAC,GAAW,EAAE,EAAE;YAC1D,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,mBAAA,IAAI,CAAC,WAAW,CAAC,MAAM,EAAO,CAAC,CAAC,GAAG,CAAC,CAAC;QAC3E,CAAC,EAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,OAAO;;;;QAAC,CAAC,GAAW,EAAE,EAAE;YAC3D,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,mBAAA,IAAI,CAAC,WAAW,CAAC,OAAO,EAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACrF,CAAC,EAAC,CAAC;QACH,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IACvD,CAAC;;;YAvKH,SAAS,SAAC;gBACR,QAAQ,EAAE,UAAU;gBACpB,kzEAAwC;gBAExC,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,UAAU,EAAE;oBACT,OAAO,CAAC,OAAO,EAAE;wBACd,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC;wBAC1C,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC,CAAC;wBACrC,UAAU,CAAC,cAAc,EAAE;4BACxB,KAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC;4BACnB,OAAO,CAAC,GAAG,CAAE;yBACZ,CAAC;wBACL,UAAU,CAAC,aAAa,EAAE;4BACvB,KAAK,CAAC,EAAC,OAAO,EAAE,CAAC,EAAC,CAAC;4BACnB,OAAO,CAAC,GAAG,CAAE;yBACZ,CAAC;qBACP,CAAC;iBACL;;aACF;;;;YAnCE,wBAAwB;YAclB,kBAAkB;;;0BAuBvB,KAAK;wBACL,KAAK;gCACL,WAAW,SAAC,YAAY,cACxB,KAAK;oBACL,MAAM;2BACN,MAAM;4BACN,SAAS,SAAC,aAAa,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,KAAK,EAAE;0BAClE,SAAS,SAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,KAAK,EAAE;;;;IAPxE,uCAAoC;;IACpC,qCAAwB;;IACxB,6CAC2C;;IAC3C,iCAAiG;;IACjG,wCAA6E;;IAC7E,yCAAqG;;IACrG,uCAAwG;;IAExG,2CAAuC;;IACvC,2CAAuC;;IAEvC,kCAAyB;;IACzB,sCAA+B;;;;;IAE/B,wCAAwC;;;;;IACxC,0CAAiD;;;;;IAG9C,+BAAqC;;;;;IACrC,qCAAqC","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport {\n   ChangeDetectionStrategy,\n   Component,\n   ComponentFactoryResolver,\n   ComponentRef,\n   EventEmitter,\n   HostBinding,\n   Input,\n   OnDestroy,\n   AfterViewInit,\n   Output,\n   ViewChild,\n   ViewContainerRef} from '@angular/core';\nimport { animate, AnimationEvent, state, style, transition, trigger } from '@angular/animations';\nimport { Subscription } from 'rxjs';\n\nimport { StModalButton, StModalButtonResponse, StModalConfig, StModalResponse } from './st-modal.model';\nimport { StWindowRefService } from '../utils/window-service';\n\n@Component({\n   selector: 'st-modal',\n   templateUrl: './st-modal.component.html',\n   styleUrls: ['./st-modal.component.scss'],\n   changeDetection: ChangeDetectionStrategy.OnPush,\n   animations: [\n      trigger('state', [\n         state('void, hidden', style({opacity: 0})),\n         state('visible', style({opacity: 1})),\n         transition('* => visible', [\n            style({opacity: 0}),\n            animate(300 )\n            ]),\n         transition('* => hidden', [\n            style({opacity: 1}),\n            animate(300 )\n            ])\n      ])\n  ]\n})\nexport class StModalComponent implements OnDestroy, AfterViewInit {\n   @Input() modalConfig: StModalConfig;\n   @Input() component: any;\n   @HostBinding('@.disabled')\n   @Input() disabledAnimation: boolean = true;\n   @Output() click: EventEmitter<StModalButtonResponse> = new EventEmitter<StModalButtonResponse>();\n   @Output() endAnimation: EventEmitter<boolean>  = new EventEmitter<boolean>();\n   @ViewChild('stModalBody', { read: ViewContainerRef, static: false }) targetContent: ViewContainerRef;\n   @ViewChild('stModalBodyEmpty', { read: ViewContainerRef, static: false }) targetEmpty: ViewContainerRef;\n\n   readonly defaultMaxWidth: number = 600;\n   readonly defaultMinWidth: number = 400;\n\n   target: ViewContainerRef;\n   visibility: string = 'visible';\n\n   private componentRef: ComponentRef<any>;\n   private _subscriptions: Array<Subscription> = [];\n\n   constructor(\n      private cfr: ComponentFactoryResolver,\n      private windowRef: StWindowRefService\n   ) { }\n\n   get hasIcon(): string {\n      return this.modalConfig.iconStatus;\n   }\n\n   get isFullscreen(): boolean {\n      return this.modalConfig.fullscreen;\n   }\n\n   get title(): string {\n      return this.modalConfig.modalTitle;\n   }\n\n   get buttons(): StModalButton[] {\n      return this.modalConfig.buttons || [];\n   }\n\n   get isMessageModal(): boolean {\n      return this.modalConfig.message && this.modalConfig.message.length > 0;\n   }\n\n   get isComplexMessageModal(): boolean {\n      return this.modalConfig.html && this.modalConfig.html.length > 0;\n   }\n\n   get html(): string {\n      return this.modalConfig.html;\n   }\n\n   get message(): string {\n      return this.modalConfig.message;\n   }\n\n   get messageTitle(): string {\n      return this.modalConfig.messageTitle;\n   }\n\n   get modalStyles(): Object {\n      const maxWidth = this.modalConfig.maxWidth || this.defaultMaxWidth;\n      const minWidth = this.modalConfig.minWidth || this.defaultMinWidth;\n      const width = this.getModalActualWidth(maxWidth, minWidth);\n      return { 'max-width': `${maxWidth}px`, 'min-width': `${minWidth}px`, 'width': `${width}px` };\n   }\n\n   get emptyModal(): boolean {\n      return this.modalConfig && this.modalConfig.empty;\n   }\n\n   get showCloseBtn(): boolean {\n      return this.modalConfig.showCloseBtn;\n   }\n\n   animationDone(event: AnimationEvent): void {\n      if (event.toState === 'hidden') {\n         this.endAnimation.emit(true);\n      }\n   }\n\n   onClickButtons(event: any): void  {\n      this.visibility = 'hidden';\n      this._subscriptions.push(this.endAnimation.subscribe((data) => {\n         if (data) {\n            this.click.emit(event);\n         }\n      }));\n   }\n\n   onClose(): void {\n      this.visibility = 'hidden';\n      this._subscriptions.push(this.endAnimation.subscribe((data) => {\n         if (data) {\n            this.click.emit({\n               response: StModalResponse.CLOSE,\n               close: true\n            });\n         }\n      }));\n   }\n\n   /** DYNAMIC MODAL BODY COMPONENT LOAD */\n   ngAfterViewInit(): void {\n      this.target = this.emptyModal ? this.targetEmpty : this.targetContent;\n      if (this.component && !(this.modalConfig.html || this.modalConfig.message)) {\n         this.loadBody();\n      }\n      this.windowRef.nativeWindow.document.body.classList.add('st-modal-overlay');\n   }\n\n   ngOnDestroy(): void {\n      if (this.componentRef) {\n         this.componentRef.destroy();\n      }\n      this.windowRef.nativeWindow.document.body.classList.remove('st-modal-overlay');\n      if (this._subscriptions.length > 0) {\n         this._subscriptions.forEach((subscription) => {\n            if (subscription) {\n               subscription.unsubscribe();\n            }\n         });\n      }\n   }\n\n   private getModalActualWidth(maxWidth: number, minWidth?: number): number {\n      const screenWidth: number = this.windowRef.nativeWindow.screen.width;\n      return screenWidth > maxWidth ? maxWidth : (screenWidth < minWidth ? minWidth : screenWidth);\n   }\n\n   private loadBody(): void {\n      if (!this.componentRef) {\n         this.target.clear();\n         const compFactory = this.cfr.resolveComponentFactory(this.component);\n         this.componentRef = this.target.createComponent(compFactory);\n         this.bindModalInputs();\n      }\n   }\n\n   private bindModalInputs(): void {\n      Object.keys(this.modalConfig.inputs).forEach((key: string) => {\n         this.componentRef.instance[key] = (this.modalConfig.inputs as any)[key];\n      });\n      Object.keys(this.modalConfig.outputs).forEach((key: string) => {\n         this.componentRef.instance[key].subscribe((this.modalConfig.outputs as any)[key]);\n      });\n      this.componentRef.changeDetectorRef.detectChanges();\n   }\n}\n"]}