UNPKG

@lunaeme/circe-modal

Version:
169 lines 18.8 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'; export class ModalComponent { /** * @param {?} ev * @param {?} _el * @param {?} _bm */ constructor(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 {?} */ _adjustContentBody() { /** @type {?} */ const _modalContentBody = this._bm.getElement('content__body'); if (this._element.contains(_modalContentBody)) { /** @type {?} */ const _contentBody = this._bm.getBoxModel('content__body'); /** @type {?} */ let _headerAggregated = 0; if (this.title || this.closeButton) { /** @type {?} */ const _contentHeader = this._bm.getBoxModel('content__header'); _headerAggregated = _contentHeader.boxModelAggregated; } /** @type {?} */ const _cssCalcHeight = `calc(100% - ${_headerAggregated}px + ${_contentBody.boxModelAdditions}px)`; ((/** @type {?} */ (_modalContentBody))).style.height = _cssCalcHeight; ((/** @type {?} */ (_modalContentBody))).style.minHeight = _cssCalcHeight; } } /** * @return {?} */ ngOnInit() { this.titleAddClass = { [this.titleClass]: !!this.titleClass }; } /** * @return {?} */ ngAfterViewInit() { /** @type {?} */ const _modalComponent = document.getElementsByClassName('modal-component').item(0); /** @type {?} */ const _modalCanvas = document.getElementsByClassName('modal__canvas').item(0); if (this._element.contains(_modalComponent) && this._element.contains(_modalCanvas)) { /** @type {?} */ const _modalComponentRect = _modalComponent.getBoundingClientRect(); /** @type {?} */ const _modalCanvasRect = _modalCanvas.getBoundingClientRect(); /** @type {?} */ const _fixed = this._bm.processSizeString(this.fixed); if (_fixed && Object.keys(_fixed)) { /** @type {?} */ const _modalCanvasWidth = (_fixed.with.unit === '%') ? _modalComponentRect.width * _fixed.with.value / 100 : _fixed.with.value; /** @type {?} */ const _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 {?} */ const _modalCanvasMaxWidth = _modalComponentRect.width * 0.9; /** @type {?} */ const _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 {?} */ ngOnDestroy() { } } 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 = () => [ { 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 }] }; 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"]}