UNPKG

@lunaeme/circe-modal

Version:
180 lines 19.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output } from '@angular/core'; import { BoxModelService, EventsService } from '@lunaeme/circe-core'; var ModalComponent = /** @class */ (function () { function ModalComponent(ev, _el, _bm) { this.ev = ev; this._el = _el; this._bm = _bm; this.clickOutside = false; this.clickOutsideExceptions = []; this.close = new EventEmitter(); this._element = _el.nativeElement; } /** * @private * @return {?} */ ModalComponent.prototype._adjustContentBody = /** * @private * @return {?} */ function () { /** @type {?} */ var _modalContentBody = this._bm.getElement('content__body'); if (this._element.contains(_modalContentBody)) { /** @type {?} */ var _contentBody = this._bm.getBoxModel('content__body'); /** @type {?} */ var _headerAggregated = 0; if (this.title || this.closeButton) { /** @type {?} */ var _contentHeader = this._bm.getBoxModel('content__header'); _headerAggregated = _contentHeader.boxModelAggregated; } /** @type {?} */ var _cssCalcHeight = "calc(100% - " + _headerAggregated + "px + " + _contentBody.boxModelAdditions + "px)"; ((/** @type {?} */ (_modalContentBody))).style.height = _cssCalcHeight; ((/** @type {?} */ (_modalContentBody))).style.minHeight = _cssCalcHeight; } }; /** * @return {?} */ ModalComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _a; this.titleAddClass = (_a = {}, _a[this.titleClass] = !!this.titleClass, _a); }; /** * @return {?} */ ModalComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { /** @type {?} */ var _modalComponent = document.getElementsByClassName('modal-component').item(0); /** @type {?} */ var _modalCanvas = document.getElementsByClassName('modal__canvas').item(0); if (this._element.contains(_modalComponent) && this._element.contains(_modalCanvas)) { /** @type {?} */ var _modalComponentRect = _modalComponent.getBoundingClientRect(); /** @type {?} */ var _modalCanvasRect = _modalCanvas.getBoundingClientRect(); /** @type {?} */ var _fixed = this._bm.processSizeString(this.fixed); if (_fixed && Object.keys(_fixed)) { /** @type {?} */ var _modalCanvasWidth = (_fixed.with.unit === '%') ? _modalComponentRect.width * _fixed.with.value / 100 : _fixed.with.value; /** @type {?} */ var _modalCanvasHeight = (_fixed.height.unit === '%') ? _modalComponentRect.height * _fixed.height.value / 100 : _fixed.height.value; ((/** @type {?} */ (_modalCanvas))).style.width = _modalCanvasWidth + 'px'; ((/** @type {?} */ (_modalCanvas))).style.minWidth = _modalCanvasWidth + 'px'; ((/** @type {?} */ (_modalCanvas))).style.height = _modalCanvasHeight + 'px'; ((/** @type {?} */ (_modalCanvas))).style.minHeight = _modalCanvasHeight + 'px'; this._adjustContentBody(); } else { /** @type {?} */ var _modalCanvasMaxWidth = _modalComponentRect.width * 0.9; /** @type {?} */ var _modalCanvasMaxHeight = _modalComponentRect.height * 0.9; if (_modalCanvasRect.width > _modalCanvasMaxWidth) { ((/** @type {?} */ (_modalCanvas))).style.width = _modalCanvasMaxWidth + 'px'; ((/** @type {?} */ (_modalCanvas))).style.minWidth = _modalCanvasMaxWidth + 'px'; } if (_modalCanvasRect.height > _modalCanvasMaxHeight) { ((/** @type {?} */ (_modalCanvas))).style.height = _modalCanvasMaxHeight + 'px'; ((/** @type {?} */ (_modalCanvas))).style.minHeight = _modalCanvasMaxHeight + 'px'; } } } }; /** * @return {?} */ ModalComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { }; ModalComponent.decorators = [ { type: Component, args: [{ selector: 'cc-modal', template: "<div class=\"medea-tpl__layer modal-component\" [ngClass]=\"{noModalBg: !modalBackground}\">\n <div\n class=\"modal__canvas\"\n ccClickOutside\n [apply]=\"clickOutside\"\n [exceptions]=\"clickOutsideExceptions\"\n (clickOutside)=\"close.emit()\">\n <div class=\"modal__content\">\n <div class=\"content__header\" *ngIf=\"title || closeButton\" [ngClass]=\"{noBg: !titleBackground}\">\n <div class=\"header__left mda-fs__22\" [ngClass]=\"titleAddClass\">{{title}}</div>\n <div class=\"header__right\">\n <i\n class=\"mda-icon icon-cross mda-fs__18 modal__close\"\n *ngIf=\"closeButton\"\n (click)=\"ev.preventNoNeededEvent($event); close.emit();\"\n title=\"Close\">\n </i>\n </div>\n </div>\n <div\n class=\"content__body\"\n [ngStyle]=\"{\n padding: (noPadding) ? '0' : (!titleBackground) ? '0 20px 20px 20px' : '20px',\n 'box-sizing': (!titleBackground) ? 'content-box' : 'border-box'\n }\">\n <ng-content></ng-content>\n </div>\n </div>\n </div>\n</div>\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: [".modal-component{display:flex;display:-ms-flexbox;flex-flow:row nowrap;flex-shrink:0;-webkit-flex-shrink:0;align-items:center;-webkit-align-items:center;-ms-flex-align:center;justify-content:center;-webkit-justify-content:center;position:absolute;z-index:10;left:0;top:0;width:100%;height:100%;background-color:rgba(17,17,17,.3);overflow:hidden}.modal-component.noModalBg{background-color:transparent}.modal-component .modal__canvas{background-color:#fff;border:1px solid #fff;border-radius:5px;box-shadow:0 1px 10px 0 rgba(85,85,85,.8)}.modal-component .modal__canvas .modal__content{overflow:hidden;width:100%;min-width:100%;height:100%;min-height:100%}.modal-component .modal__canvas .modal__content .content__header{display:flex;display:-ms-flexbox;flex-flow:row nowrap;flex-shrink:0;-webkit-flex-shrink:0;align-items:center;-webkit-align-items:center;-ms-flex-align:center;justify-content:space-between;-webkit-justify-content:space-between;padding:20px;background-color:#f4f4f4}.modal-component .modal__canvas .modal__content .content__header.noBg{background-color:#fff}.modal-component .modal__canvas .modal__content .content__header .header__right .modal__close{margin-left:15px;cursor:pointer}.modal-component .modal__canvas .modal__content .content__body{padding:20px;position:relative}"] }] } ]; /** @nocollapse */ ModalComponent.ctorParameters = function () { return [ { type: EventsService }, { type: ElementRef }, { type: BoxModelService } ]; }; ModalComponent.propDecorators = { title: [{ type: Input }], titleClass: [{ type: Input }], titleBackground: [{ type: Input }], closeButton: [{ type: Input }], modalBackground: [{ type: Input }], clickOutside: [{ type: Input }], clickOutsideExceptions: [{ type: Input }], fixed: [{ type: Input }], noPadding: [{ type: Input }], close: [{ type: Output }] }; return ModalComponent; }()); export { ModalComponent }; if (false) { /** @type {?} */ ModalComponent.prototype.title; /** @type {?} */ ModalComponent.prototype.titleClass; /** @type {?} */ ModalComponent.prototype.titleBackground; /** @type {?} */ ModalComponent.prototype.closeButton; /** @type {?} */ ModalComponent.prototype.modalBackground; /** @type {?} */ ModalComponent.prototype.clickOutside; /** @type {?} */ ModalComponent.prototype.clickOutsideExceptions; /** @type {?} */ ModalComponent.prototype.fixed; /** @type {?} */ ModalComponent.prototype.noPadding; /** @type {?} */ ModalComponent.prototype.close; /** @type {?} */ ModalComponent.prototype.titleAddClass; /** * @type {?} * @private */ ModalComponent.prototype._element; /** @type {?} */ ModalComponent.prototype.ev; /** * @type {?} * @private */ ModalComponent.prototype._el; /** * @type {?} * @private */ ModalComponent.prototype._bm; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"ng://@lunaeme/circe-modal/","sources":["lib/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output\n} from '@angular/core';\nimport { BoxModelService, BoxModelSwapObject, EventsService, SizeObject } from '@lunaeme/circe-core';\n\n@Component({\n  selector: 'cc-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ModalComponent implements OnInit, OnDestroy, AfterViewInit {\n  @Input() title: string;\n  @Input() titleClass: string;\n  @Input() titleBackground: boolean;\n  @Input() closeButton: boolean;\n  @Input() modalBackground: boolean;\n  @Input() clickOutside: boolean = false;\n  @Input() clickOutsideExceptions: Array<string> = [];\n  @Input() fixed: string;\n  @Input() noPadding: boolean;\n  @Output() close: EventEmitter<boolean> = new EventEmitter();\n\n  public titleAddClass: any;\n\n  private readonly _element: HTMLElement;\n\n  constructor(public ev: EventsService, private _el: ElementRef, private _bm: BoxModelService) {\n    this._element = _el.nativeElement;\n  }\n\n  private _adjustContentBody(): void {\n    const _modalContentBody: Element = this._bm.getElement('content__body');\n    if (this._element.contains(_modalContentBody)) {\n      const _contentBody: BoxModelSwapObject = this._bm.getBoxModel('content__body');\n      let _headerAggregated: number = 0;\n      if (this.title || this.closeButton) {\n        const _contentHeader: BoxModelSwapObject = this._bm.getBoxModel('content__header');\n        _headerAggregated = _contentHeader.boxModelAggregated;\n      }\n      const _cssCalcHeight: string = `calc(100% - ${_headerAggregated}px + ${_contentBody.boxModelAdditions}px)`;\n      (_modalContentBody as HTMLElement).style.height = _cssCalcHeight;\n      (_modalContentBody as HTMLElement).style.minHeight = _cssCalcHeight;\n    }\n  }\n\n  ngOnInit(): void {\n    this.titleAddClass = {\n      [this.titleClass]: !!this.titleClass\n    };\n  }\n\n  ngAfterViewInit(): void {\n    const _modalComponent: Element = document.getElementsByClassName('modal-component').item(0);\n    const _modalCanvas: Element = document.getElementsByClassName('modal__canvas').item(0);\n    if (this._element.contains(_modalComponent) && this._element.contains(_modalCanvas)) {\n      const _modalComponentRect: DOMRect | ClientRect = _modalComponent.getBoundingClientRect();\n      const _modalCanvasRect: DOMRect | ClientRect = _modalCanvas.getBoundingClientRect();\n      const _fixed: SizeObject = this._bm.processSizeString(this.fixed);\n      if (_fixed && Object.keys(_fixed)) {\n        const _modalCanvasWidth: number = (_fixed.with.unit === '%') ?\n          _modalComponentRect.width * _fixed.with.value / 100 : _fixed.with.value;\n        const _modalCanvasHeight: number = (_fixed.height.unit === '%') ?\n          _modalComponentRect.height * _fixed.height.value / 100 : _fixed.height.value;\n        (_modalCanvas as HTMLElement).style.width = _modalCanvasWidth + 'px';\n        (_modalCanvas as HTMLElement).style.minWidth = _modalCanvasWidth + 'px';\n        (_modalCanvas as HTMLElement).style.height = _modalCanvasHeight + 'px';\n        (_modalCanvas as HTMLElement).style.minHeight = _modalCanvasHeight + 'px';\n        this._adjustContentBody();\n      } else {\n        const _modalCanvasMaxWidth: number = _modalComponentRect.width * 0.9;\n        const _modalCanvasMaxHeight: number = _modalComponentRect.height * 0.9;\n        if (_modalCanvasRect.width > _modalCanvasMaxWidth) {\n          (_modalCanvas as HTMLElement).style.width = _modalCanvasMaxWidth + 'px';\n          (_modalCanvas as HTMLElement).style.minWidth = _modalCanvasMaxWidth + 'px';\n        }\n        if (_modalCanvasRect.height > _modalCanvasMaxHeight) {\n          (_modalCanvas as HTMLElement).style.height = _modalCanvasMaxHeight + 'px';\n          (_modalCanvas as HTMLElement).style.minHeight = _modalCanvasMaxHeight + 'px';\n        }\n      }\n    }\n  }\n\n  ngOnDestroy(): void {}\n}\n"]}