UNPKG

@stratio/egeo

Version:
396 lines 32.3 kB
/** * @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"]}