@stratio/egeo
Version:
396 lines • 32.3 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';
var StModalComponent = /** @class */ (function () {
function StModalComponent(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 = [];
}
Object.defineProperty(StModalComponent.prototype, "hasIcon", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.iconStatus;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "isFullscreen", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.fullscreen;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "title", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.modalTitle;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "buttons", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.buttons || [];
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "isMessageModal", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.message && this.modalConfig.message.length > 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "isComplexMessageModal", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.html && this.modalConfig.html.length > 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "html", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.html;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "message", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.message;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "messageTitle", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.messageTitle;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "modalStyles", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var maxWidth = this.modalConfig.maxWidth || this.defaultMaxWidth;
/** @type {?} */
var minWidth = this.modalConfig.minWidth || this.defaultMinWidth;
/** @type {?} */
var width = this.getModalActualWidth(maxWidth, minWidth);
return { 'max-width': maxWidth + "px", 'min-width': minWidth + "px", 'width': width + "px" };
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "emptyModal", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig && this.modalConfig.empty;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StModalComponent.prototype, "showCloseBtn", {
get: /**
* @return {?}
*/
function () {
return this.modalConfig.showCloseBtn;
},
enumerable: true,
configurable: true
});
/**
* @param {?} event
* @return {?}
*/
StModalComponent.prototype.animationDone = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (event.toState === 'hidden') {
this.endAnimation.emit(true);
}
};
/**
* @param {?} event
* @return {?}
*/
StModalComponent.prototype.onClickButtons = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
this.visibility = 'hidden';
this._subscriptions.push(this.endAnimation.subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
if (data) {
_this.click.emit(event);
}
})));
};
/**
* @return {?}
*/
StModalComponent.prototype.onClose = /**
* @return {?}
*/
function () {
var _this = this;
this.visibility = 'hidden';
this._subscriptions.push(this.endAnimation.subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
if (data) {
_this.click.emit({
response: StModalResponse.CLOSE,
close: true
});
}
})));
};
/** DYNAMIC MODAL BODY COMPONENT LOAD */
/**
* DYNAMIC MODAL BODY COMPONENT LOAD
* @return {?}
*/
StModalComponent.prototype.ngAfterViewInit = /**
* DYNAMIC MODAL BODY COMPONENT LOAD
* @return {?}
*/
function () {
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 {?}
*/
StModalComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
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 {?}
*/
function (subscription) {
if (subscription) {
subscription.unsubscribe();
}
}));
}
};
/**
* @private
* @param {?} maxWidth
* @param {?=} minWidth
* @return {?}
*/
StModalComponent.prototype.getModalActualWidth = /**
* @private
* @param {?} maxWidth
* @param {?=} minWidth
* @return {?}
*/
function (maxWidth, minWidth) {
/** @type {?} */
var screenWidth = this.windowRef.nativeWindow.screen.width;
return screenWidth > maxWidth ? maxWidth : (screenWidth < minWidth ? minWidth : screenWidth);
};
/**
* @private
* @return {?}
*/
StModalComponent.prototype.loadBody = /**
* @private
* @return {?}
*/
function () {
if (!this.componentRef) {
this.target.clear();
/** @type {?} */
var compFactory = this.cfr.resolveComponentFactory(this.component);
this.componentRef = this.target.createComponent(compFactory);
this.bindModalInputs();
}
};
/**
* @private
* @return {?}
*/
StModalComponent.prototype.bindModalInputs = /**
* @private
* @return {?}
*/
function () {
var _this = this;
Object.keys(this.modalConfig.inputs).forEach((/**
* @param {?} key
* @return {?}
*/
function (key) {
_this.componentRef.instance[key] = ((/** @type {?} */ (_this.modalConfig.inputs)))[key];
}));
Object.keys(this.modalConfig.outputs).forEach((/**
* @param {?} key
* @return {?}
*/
function (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 = function () { return [
{ 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 },] }]
};
return StModalComponent;
}());
export { StModalComponent };
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":"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","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"]}