@lunaeme/circe-modal
Version:
Circe :: Angular Modal Component
180 lines • 19.3 kB
JavaScript
/**
* @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"]}