ng-modals
Version:
Make a modal in angular extremely easily with ng-modals. Installation to have a modal pop up is quick and easy.
200 lines • 17.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ViewChild, ComponentFactoryResolver, Directive, ViewContainerRef, TemplateRef, HostListener } from '@angular/core';
var NgModalsDirective = /** @class */ (function () {
function NgModalsDirective(containers) {
this.containers = containers;
}
NgModalsDirective.decorators = [
{ type: Directive, args: [{
selector: '[ngmodals]'
},] }
];
/** @nocollapse */
NgModalsDirective.ctorParameters = function () { return [
{ type: ViewContainerRef }
]; };
return NgModalsDirective;
}());
export { NgModalsDirective };
if (false) {
/** @type {?} */
NgModalsDirective.prototype.containers;
}
var NgModalsComponent = /** @class */ (function () {
function NgModalsComponent(componentFactoryResolver) {
this.componentFactoryResolver = componentFactoryResolver;
this.close = new EventEmitter();
this.css = {};
this.viewIsInit = false;
this.initialClick = false;
}
/**
* @param {?} targetElement
* @return {?}
*/
NgModalsComponent.prototype.onclick = /**
* @param {?} targetElement
* @return {?}
*/
function (targetElement) {
if (this.initialClick) {
/** @type {?} */
var clickedInside = document.getElementById("modelContainer").contains(targetElement);
if (!clickedInside) {
this.closeModal();
}
}
};
/**
* @return {?}
*/
NgModalsComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
};
/**
* @return {?}
*/
NgModalsComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this.loadComponent();
}), 10);
};
/**
* @return {?}
*/
NgModalsComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this.loadComponent();
this.viewIsInit = true;
};
/**
* @return {?}
*/
NgModalsComponent.prototype.loadComponent = /**
* @return {?}
*/
function () {
var _this = this;
if (this.condition) {
/** @type {?} */
var contain = document.getElementById('modelContainer');
if (this.options.ignore) {
if (this.options.width) {
contain.style.width = this.options.width + "vw";
contain.style.left = this.options.left + "vw";
}
if (this.options.height) {
contain.style.height = this.options.height + "vh";
contain.style.top = ((100 - (parseInt(this.options.height))) / 2) + "vh";
}
}
else {
if (this.options.width) {
contain.style.width = this.options.width + "vw";
contain.style.left = ((100 - (parseInt(this.options.width))) / 2) + "vw";
}
if (this.options.height) {
contain.style.height = this.options.height + "vh";
contain.style.top = ((100 - (parseInt(this.options.height))) / 2) + "vh";
}
}
if (this.options.background) {
contain.style.background = this.options.background;
contain.style.boxShadow = 'none';
}
/** @type {?} */
var factory = this.componentFactoryResolver.resolveComponentFactory(this.options.component);
/** @type {?} */
var container = this.modalDirective.containers;
container.clear();
/** @type {?} */
var component = container.createComponent(factory);
((/** @type {?} */ (component.instance))).data = this.options.data;
((/** @type {?} */ (component.instance))).toggleModal.subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
_this.closeModal();
}));
document.getElementById("mainWrapper").style.opacity = "1";
this.initialClick = true;
}
};
/**
* @return {?}
*/
NgModalsComponent.prototype.closeModal = /**
* @return {?}
*/
function () {
var _this = this;
this.initialClick = false;
document.getElementById("mainWrapper").style.opacity = "0";
setTimeout((/**
* @return {?}
*/
function () {
_this.close.emit();
}), 200);
};
NgModalsComponent.decorators = [
{ type: Component, args: [{
selector: 'ng-modals',
template: "\n <div class=\"mainWrapper\" *ngIf=\"condition\" id=\"mainWrapper\">\n <div class=\"modalContainer\" id=\"modelContainer\" #container>\n <ng-template ngmodals></ng-template>\n </div>\n </div>\n ",
styles: ["\n .mainWrapper{\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0,0,0,0.5);\n width: 100%;\n height: 100vh;\n opacity: 0;\n transition: opacity 0.2s ease-out;\n z-index: 1000;\n }\n .modalContainer{\n position: fixed;\n top: 15vh;\n left: 20vw;\n width: 60vw;\n height: 70vh;\n background: white;\n border-radius: 32px;\n box-shadow: 2px 2px 4px rgba(0,0,0,0.5);\n overflow-y: auto;\n }\n "]
}] }
];
/** @nocollapse */
NgModalsComponent.ctorParameters = function () { return [
{ type: ComponentFactoryResolver }
]; };
NgModalsComponent.propDecorators = {
options: [{ type: Input, args: ['options',] }],
condition: [{ type: Input, args: ['status',] }],
close: [{ type: Output, args: ['close',] }],
modalDirective: [{ type: ViewChild, args: [NgModalsDirective,] }],
container: [{ type: ViewChild, args: ['container',] }],
onclick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
};
return NgModalsComponent;
}());
export { NgModalsComponent };
if (false) {
/** @type {?} */
NgModalsComponent.prototype.options;
/** @type {?} */
NgModalsComponent.prototype.condition;
/** @type {?} */
NgModalsComponent.prototype.close;
/** @type {?} */
NgModalsComponent.prototype.css;
/** @type {?} */
NgModalsComponent.prototype.viewIsInit;
/** @type {?} */
NgModalsComponent.prototype.modalDirective;
/** @type {?} */
NgModalsComponent.prototype.container;
/** @type {?} */
NgModalsComponent.prototype.initialClick;
/**
* @type {?}
* @private
*/
NgModalsComponent.prototype.componentFactoryResolver;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-modals.component.js","sourceRoot":"ng://ng-modals/","sources":["lib/ng-modals.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, OnChanges, Input, Output, EventEmitter, ViewChild, ComponentFactoryResolver, Directive, ViewContainerRef, TemplateRef, ElementRef, HostListener } from '@angular/core';\nimport { NgModalsInterface } from './interface/ng-modals.interface';\n\n\n@Directive({\n  selector: '[ngmodals]'\n})\nexport class NgModalsDirective {\n  constructor(public containers: ViewContainerRef) { }\n}\n\n@Component({\n  selector: 'ng-modals',\n  template: `\n    <div class=\"mainWrapper\" *ngIf=\"condition\" id=\"mainWrapper\">\n      <div class=\"modalContainer\" id=\"modelContainer\" #container>\n        <ng-template ngmodals></ng-template>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .mainWrapper{\n        position: fixed;\n        top: 0;\n        left: 0;\n        right: 0;\n        bottom: 0;\n        background: rgba(0,0,0,0.5);\n        width: 100%;\n        height: 100vh;\n        opacity: 0;\n        transition: opacity 0.2s ease-out;\n        z-index: 1000;\n      }\n      .modalContainer{\n        position: fixed;\n        top: 15vh;\n        left: 20vw;\n        width: 60vw;\n        height: 70vh;\n        background: white;\n        border-radius: 32px;\n        box-shadow: 2px 2px 4px rgba(0,0,0,0.5);\n        overflow-y: auto;\n      }\n    `\n  ]\n})\nexport class NgModalsComponent implements OnInit, AfterViewInit, OnChanges {\n\n  @Input('options') options;\n  @Input('status') condition;\n  @Output('close') close = new EventEmitter();\n  public css = {};\n  public viewIsInit = false;\n  @ViewChild(NgModalsDirective) modalDirective: NgModalsDirective;\n  @ViewChild('container') container: TemplateRef<any>;\n  public initialClick = false;\n\n  @HostListener('document:click', ['$event.target']) onclick(targetElement) {\n    if (this.initialClick) {\n      const clickedInside = document.getElementById(\"modelContainer\").contains(targetElement);\n      if (!clickedInside) {\n        this.closeModal();\n      }\n    }\n  }\n  constructor(private componentFactoryResolver: ComponentFactoryResolver) { }\n\n  ngOnInit() {\n\n  }\n\n  ngOnChanges() {\n    setTimeout(() => {\n      this.loadComponent();\n    }, 10);\n  }\n\n  ngAfterViewInit() {\n    this.loadComponent();\n    this.viewIsInit = true;\n  }\n\n  loadComponent() {\n    if (this.condition) {\n      let contain = document.getElementById('modelContainer');\n      if (this.options.ignore) {\n        if (this.options.width) {\n          contain.style.width = this.options.width + \"vw\";\n          contain.style.left = this.options.left + \"vw\";\n        }\n        if (this.options.height) {\n          contain.style.height = this.options.height + \"vh\";\n          contain.style.top = ((100 - (parseInt(this.options.height))) / 2) + \"vh\";\n        }\n      } else {\n        if (this.options.width) {\n          contain.style.width = this.options.width + \"vw\";\n          contain.style.left = ((100 - (parseInt(this.options.width))) / 2) + \"vw\";\n        }\n        if (this.options.height) {\n          contain.style.height = this.options.height + \"vh\";\n          contain.style.top = ((100 - (parseInt(this.options.height))) / 2) + \"vh\";\n        }\n      }\n      if (this.options.background) {\n        contain.style.background = this.options.background;\n        contain.style.boxShadow = 'none';\n      }\n      let factory = this.componentFactoryResolver.resolveComponentFactory(this.options.component);\n      let container = this.modalDirective.containers;\n      container.clear();\n      let component = container.createComponent(factory);\n      (<NgModalsInterface>component.instance).data = this.options.data;\n      (<NgModalsInterface>component.instance).toggleModal.subscribe(data => {\n        this.closeModal();\n      })\n      document.getElementById(\"mainWrapper\").style.opacity = \"1\";\n      this.initialClick = true;\n    }\n  }\n\n  closeModal() {\n    this.initialClick = false;\n    document.getElementById(\"mainWrapper\").style.opacity = \"0\";\n    setTimeout(() => {\n      this.close.emit();\n    }, 200);\n  }\n\n}\n"]}