com.phloxui
Version:
PhloxUI Ng2+ Framework
197 lines (196 loc) • 18.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { Component, Input, ViewContainerRef, ComponentFactoryResolver, ElementRef } from '@angular/core';
import { AbstractDataEditor } from './AbstractDataEditor';
import { RecordView } from './editor.internal/RecordView.component';
import { CalendarView } from './editor.internal/CalendarView.component';
import { FormView } from './editor.internal/FormView.component';
import { ViewModel } from '../model/ViewModel';
var /** @type {?} */ TYPE_NAME = "phx-view-wrapper";
var /** @type {?} */ RECORD_VIEW = RecordView.TYPE_NAME;
var /** @type {?} */ CALENDAR_VIEW = CalendarView.TYPE_NAME;
var /** @type {?} */ FORM_VIEW = FormView.TYPE_NAME;
var /** @type {?} */ KANBAN_VIEW = 'kanban-view';
var /** @type {?} */ RECYCLE_VIEW = 'recycle-view';
var ViewWrapper = /** @class */ (function () {
function ViewWrapper(target, componentFactoryResolver, elementRef) {
this.target = target;
this.componentFactoryResolver = componentFactoryResolver;
this.elementRef = elementRef;
this.isRendered = false;
}
/**
* @return {?}
*/
ViewWrapper.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.editor !== null && (typeof this.editor !== 'undefined')) {
this.editor.addViewWrapper(this);
}
};
/**
* @return {?}
*/
ViewWrapper.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this.editor !== null && (typeof this.editor !== 'undefined')) {
this.editor.removeViewWrapper(this);
}
};
/**
* @return {?}
*/
ViewWrapper.prototype.reRender = /**
* @return {?}
*/
function () {
this.isRendered = false;
this.render();
};
/**
* @return {?}
*/
ViewWrapper.prototype.render = /**
* @return {?}
*/
function () {
var _this = this;
if (this.isRendered) {
return;
}
if (this.model === null || this.model === undefined) {
return;
}
// remove old dom
if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {
if (this.componentRef !== null && typeof this.componentRef !== 'undefined') {
if (typeof this.componentRef.instance.setData === 'function') {
this.componentRef.instance.setData(null);
}
if (typeof this.componentRef.instance.setDataParent === 'function') {
this.componentRef.instance.setDataParent(null);
}
this.componentRef.destroy();
}
}
var /** @type {?} */ compType = this.getViewComponentType(this.model.type);
if (compType != null && (typeof compType !== 'undefined')) {
var /** @type {?} */ simpleCompoFactory = this.componentFactoryResolver.resolveComponentFactory(compType);
var /** @type {?} */ compRef = this.target.createComponent(simpleCompoFactory);
compRef.instance.setEditor(this.editor);
compRef.instance.setModel(this.model);
this.componentRef = compRef;
// use Function handler form because cant use output and emit out
var /** @type {?} */ showEvent = compRef.instance.getShowEvent();
if (showEvent !== null && typeof showEvent !== 'undefined') {
showEvent.subscribe(function (event) {
if (_this.showEventHandler !== null && typeof _this.showEventHandler !== 'undefined') {
_this.showEventHandler(event);
}
});
}
var /** @type {?} */ hideEvent = compRef.instance.getHideEvent();
if (hideEvent !== null && typeof hideEvent !== 'undefined') {
hideEvent.subscribe(function (event) {
if (_this.hideEventHandler !== null && typeof _this.hideEventHandler !== 'undefined') {
_this.hideEventHandler(event);
}
});
}
}
this.isRendered = true;
};
/**
* @param {?} typeName
* @return {?}
*/
ViewWrapper.prototype.getViewComponentType = /**
* @param {?} typeName
* @return {?}
*/
function (typeName) {
if (typeName === RECORD_VIEW) {
return RecordView;
}
else if (typeName === CALENDAR_VIEW) {
return CalendarView;
}
else if (typeName === FORM_VIEW) {
return FormView;
}
else if (typeName === KANBAN_VIEW) {
}
else if (typeName === RECYCLE_VIEW) {
}
return null;
};
/**
* @return {?}
*/
ViewWrapper.prototype.isRender = /**
* @return {?}
*/
function () {
return this.isRendered;
};
ViewWrapper.TYPE_NAME = TYPE_NAME;
ViewWrapper.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: ""
},] },
];
/** @nocollapse */
ViewWrapper.ctorParameters = function () { return [
{ type: ViewContainerRef, },
{ type: ComponentFactoryResolver, },
{ type: ElementRef, },
]; };
ViewWrapper.propDecorators = {
"editor": [{ type: Input },],
"model": [{ type: Input },],
"showEventHandler": [{ type: Input },],
"hideEventHandler": [{ type: Input },],
};
return ViewWrapper;
}());
export { ViewWrapper };
function ViewWrapper_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ViewWrapper.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ViewWrapper.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
ViewWrapper.propDecorators;
/** @type {?} */
ViewWrapper.TYPE_NAME;
/** @type {?} */
ViewWrapper.prototype.editor;
/** @type {?} */
ViewWrapper.prototype.model;
/** @type {?} */
ViewWrapper.prototype.componentFactoryResolver;
/** @type {?} */
ViewWrapper.prototype.target;
/** @type {?} */
ViewWrapper.prototype.showEventHandler;
/** @type {?} */
ViewWrapper.prototype.hideEventHandler;
/** @type {?} */
ViewWrapper.prototype.isRendered;
/** @type {?} */
ViewWrapper.prototype.elementRef;
/** @type {?} */
ViewWrapper.prototype.componentRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ViewWrapper.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/ViewWrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewContainerRef, Type, ComponentFactoryResolver, Output,\n  OnDestroy, ElementRef } from '@angular/core';\nimport { AbstractDataEditor } from './AbstractDataEditor';\nimport { RecordView } from './editor.internal/RecordView.component';\nimport { CalendarView } from './editor.internal/CalendarView.component';\nimport { FormView } from './editor.internal/FormView.component';\nimport { ViewModel } from '../model/ViewModel';\n\nconst TYPE_NAME: string = \"phx-view-wrapper\";\n\nconst RECORD_VIEW: string = RecordView.TYPE_NAME;\nconst CALENDAR_VIEW: string = CalendarView.TYPE_NAME;\nconst FORM_VIEW: string = FormView.TYPE_NAME;\nconst KANBAN_VIEW: string = 'kanban-view';\nconst RECYCLE_VIEW: string = 'recycle-view';\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: ``\n})\nexport class ViewWrapper implements OnInit, OnDestroy {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  private editor: AbstractDataEditor;\n  @Input()\n  private model: ViewModel;\n  private componentFactoryResolver: ComponentFactoryResolver;\n  private target: ViewContainerRef;\n  @Input()\n  private showEventHandler: Function;\n  @Input()\n  private hideEventHandler: Function;\n  private isRendered: boolean;\n  private elementRef: any;\n  private componentRef: any;\n\n  constructor(target: ViewContainerRef, componentFactoryResolver: ComponentFactoryResolver, elementRef: ElementRef) {\n    this.target = target;\n    this.componentFactoryResolver = componentFactoryResolver;\n    this.elementRef = elementRef;\n    this.isRendered = false;\n  }\n\n  public ngOnInit(): void {\n    if (this.editor !== null && (typeof this.editor !== 'undefined')) {\n      this.editor.addViewWrapper(this);\n    }\n  }\n\n  public ngOnDestroy() {\n    if (this.editor !== null && (typeof this.editor !== 'undefined')) {\n      this.editor.removeViewWrapper(this);\n    }\n  }\n\n  public reRender(): void {\n    this.isRendered = false;\n    this.render();\n  }\n\n  public render(): void {\n    if (this.isRendered) {\n      return;\n    }\n\n    if(this.model === null || this.model === undefined){\n      return;\n    }\n\n    // remove old dom\n    if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {\n      if (this.componentRef !== null && typeof this.componentRef !== 'undefined') {\n        if (typeof this.componentRef.instance.setData === 'function') {\n          this.componentRef.instance.setData(null);\n        }\n\n        if (typeof this.componentRef.instance.setDataParent === 'function') {\n          this.componentRef.instance.setDataParent(null);\n        }\n\n        this.componentRef.destroy();\n      }\n    }\n\n    let compType = this.getViewComponentType(this.model.type);\n\n    if (compType != null && (typeof compType !== 'undefined')) {\n      const simpleCompoFactory = this.componentFactoryResolver.resolveComponentFactory(compType);\n      let compRef = this.target.createComponent(simpleCompoFactory);\n      compRef.instance.setEditor(this.editor);\n      compRef.instance.setModel(this.model);\n      this.componentRef = compRef;\n\n      // use Function handler form because cant use output and emit out\n      let showEvent = compRef.instance.getShowEvent();\n      if (showEvent !== null && typeof showEvent !== 'undefined') {\n        showEvent.subscribe((event: any) => {\n          if (this.showEventHandler !== null && typeof this.showEventHandler !== 'undefined') {\n            this.showEventHandler(event);\n          }\n        });\n      }\n      let hideEvent = compRef.instance.getHideEvent();\n      if (hideEvent !== null && typeof hideEvent !== 'undefined') {\n        hideEvent.subscribe((event: any) => {\n          if (this.hideEventHandler !== null && typeof this.hideEventHandler !== 'undefined') {\n            this.hideEventHandler(event);\n          }\n        });\n      }\n    }\n\n    this.isRendered = true;\n  }\n\n  private getViewComponentType(typeName: string): Type<any> {\n\n    if (typeName === RECORD_VIEW) {\n      return RecordView;\n    } else if (typeName === CALENDAR_VIEW) {\n      return CalendarView;\n    } else if (typeName === FORM_VIEW) {\n      return FormView;\n    } else if (typeName === KANBAN_VIEW) {\n\n    } else if (typeName === RECYCLE_VIEW) {\n\n    }\n\n    return null;\n  }\n\n  public isRender(): boolean {\n    return this.isRendered;\n  }\n}\n"]}