com.phloxui
Version:
PhloxUI Ng2+ Framework
180 lines (179 loc) • 17.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, Output, ViewContainerRef, Type, EventEmitter, ComponentFactoryResolver } from '@angular/core';
import { DATA_CHANGE_EVENT } from '../../share/CustomEventType';
import { AbstractDataViewWrapper } from './AbstractDataViewWrapper';
var /** @type {?} */ TYPE_NAME = "phx-data-view-wrapper";
var DataViewWrapper = /** @class */ (function (_super) {
tslib_1.__extends(DataViewWrapper, _super);
function DataViewWrapper(target, componentFactoryResolver) {
return _super.call(this, target, componentFactoryResolver) || this;
}
/**
* @return {?}
*/
DataViewWrapper.prototype.ngOnInit = /**
* @return {?}
*/
function () {
_super.prototype.ngOnInit.call(this);
};
/**
* @param {?} changes
* @return {?}
*/
DataViewWrapper.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes['componentType'] !== null && typeof changes['componentType'] !== 'undefined') {
var /** @type {?} */ oldType = changes['componentType'].previousValue;
var /** @type {?} */ newType = changes['componentType'].currentValue;
if (oldType !== newType) {
this.render();
}
}
if (changes['data'] !== null && typeof changes['data'] !== 'undefined') {
var /** @type {?} */ oldData = changes['data'].previousValue;
var /** @type {?} */ newData = changes['data'].currentValue;
if (oldData !== newData) {
if (this.componentRef !== null && this.componentRef !== undefined) {
this.componentRef.instance.setData(this.data);
}
else {
this.render();
}
}
}
if (changes['options'] !== null && typeof changes['options'] !== 'undefined') {
var /** @type {?} */ oldOpt = changes['options'].previousValue;
var /** @type {?} */ newOpt = changes['options'].currentValue;
if (oldOpt !== newOpt) {
if (this.componentRef !== null && this.componentRef !== undefined) {
this.componentRef.instance.setOptions(this.options);
}
else {
this.render();
}
}
}
if (this.componentRef !== null && typeof this.componentRef !== 'undefined') {
if (changes['class'] !== null && typeof changes['class'] !== 'undefined') {
var /** @type {?} */ oldClass = changes['class'].previousValue;
var /** @type {?} */ newClass = changes['class'].currentValue;
if (oldClass !== newClass) {
$(this.componentRef.location.nativeElement).attr('class', newClass);
}
}
}
};
/**
* @return {?}
*/
DataViewWrapper.prototype.render = /**
* @return {?}
*/
function () {
var _this = this;
// remove old dom
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();
}
if (this.componentType != null && (typeof this.componentType !== 'undefined')) {
var /** @type {?} */ simpleCompoFactory = this.componentFactoryResolver.resolveComponentFactory(this.componentType);
var /** @type {?} */ compRef = this.target.createComponent(simpleCompoFactory);
compRef.instance.setData(this.data);
compRef.instance.setOptions(this.options);
this.componentRef = compRef;
var /** @type {?} */ compHandler = null;
if (typeof compRef.instance.getEventHandler === 'function') {
compHandler = compRef.instance.getEventHandler();
}
if (compHandler !== null && typeof compHandler !== 'undefined') {
compHandler.subscribe(function (event) {
if (event.type == DATA_CHANGE_EVENT) {
// update data row
// update data row
_this.data = event.detail.data;
}
_this.eventHandler.emit(event);
});
}
}
};
/**
* @return {?}
*/
DataViewWrapper.prototype.getEventHandler = /**
* @return {?}
*/
function () {
return this.eventHandler;
};
/**
* @param {?} event
* @return {?}
*/
DataViewWrapper.prototype.setEventHandler = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.eventHandler = event;
};
DataViewWrapper.TYPE_NAME = TYPE_NAME;
DataViewWrapper.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: ""
},] },
];
/** @nocollapse */
DataViewWrapper.ctorParameters = function () { return [
{ type: ViewContainerRef, },
{ type: ComponentFactoryResolver, },
]; };
DataViewWrapper.propDecorators = {
"componentType": [{ type: Input, args: ['type',] },],
"data": [{ type: Input },],
"options": [{ type: Input },],
"eventHandler": [{ type: Output },],
};
return DataViewWrapper;
}(AbstractDataViewWrapper));
export { DataViewWrapper };
function DataViewWrapper_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
DataViewWrapper.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
DataViewWrapper.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
DataViewWrapper.propDecorators;
/** @type {?} */
DataViewWrapper.TYPE_NAME;
/** @type {?} */
DataViewWrapper.prototype.componentType;
/** @type {?} */
DataViewWrapper.prototype.data;
/** @type {?} */
DataViewWrapper.prototype.options;
/** @type {?} */
DataViewWrapper.prototype.eventHandler;
/** @type {?} */
DataViewWrapper.prototype.componentRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataViewWrapper.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/DataViewWrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, ViewContainerRef, Type, EventEmitter, ComponentFactoryResolver } from '@angular/core';\nimport { DATA_CHANGE_EVENT } from '../../share/CustomEventType';\nimport { AbstractDataViewWrapper } from './AbstractDataViewWrapper';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-data-view-wrapper\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: ``\n})\nexport class DataViewWrapper extends AbstractDataViewWrapper implements OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input('type')\n  protected componentType: Type<any>;\n  @Input()\n  protected data: any;\n  @Input()\n  protected options: any;\n  @Output()\n  protected eventHandler: EventEmitter<any>;\n\n  private componentRef: any;\n\n  constructor(target: ViewContainerRef, componentFactoryResolver: ComponentFactoryResolver) {\n    super(target, componentFactoryResolver);\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n  }\n\n  public ngOnChanges(changes: any) {\n    if (changes['componentType'] !== null && typeof changes['componentType'] !== 'undefined') {\n      let oldType = changes['componentType'].previousValue;\n      let newType: any = changes['componentType'].currentValue;\n\n      if (oldType !== newType) {\n        this.render();\n      }\n    }\n\n    if (changes['data'] !== null && typeof changes['data'] !== 'undefined') {\n      let oldData = changes['data'].previousValue;\n      let newData: any = changes['data'].currentValue;\n\n      if (oldData !== newData) {\n        if (this.componentRef !== null && this.componentRef !== undefined) {\n          this.componentRef.instance.setData(this.data);\n        } else {\n          this.render();\n        }\n      }\n    }\n\n    if (changes['options'] !== null && typeof changes['options'] !== 'undefined') {\n      let oldOpt = changes['options'].previousValue;\n      let newOpt: any = changes['options'].currentValue;\n\n      if (oldOpt !== newOpt) {\n        if (this.componentRef !== null && this.componentRef !== undefined) {\n          this.componentRef.instance.setOptions(this.options);\n        } else {\n          this.render();\n        }\n      }\n    }\n\n    if (this.componentRef !== null && typeof this.componentRef !== 'undefined') {\n      if (changes['class'] !== null && typeof changes['class'] !== 'undefined') {\n        let oldClass = changes['class'].previousValue;\n        let newClass: any = changes['class'].currentValue;\n\n        if (oldClass !== newClass) {\n          $(this.componentRef.location.nativeElement).attr('class', newClass);\n        }\n      }\n    }\n  }\n\n  public render(): void {\n    // remove old dom\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    if (this.componentType != null && (typeof this.componentType !== 'undefined')) {\n      const simpleCompoFactory = this.componentFactoryResolver.resolveComponentFactory(this.componentType);\n      let compRef = this.target.createComponent(simpleCompoFactory);\n      compRef.instance.setData(this.data);\n      compRef.instance.setOptions(this.options);\n      this.componentRef = compRef;\n\n      let compHandler = null;\n      if (typeof compRef.instance.getEventHandler === 'function') {\n        compHandler = compRef.instance.getEventHandler();\n      }\n\n      if (compHandler !== null && typeof compHandler !== 'undefined') {\n        compHandler.subscribe((event: any) => {\n          if (event.type == DATA_CHANGE_EVENT) {\n            // update data row\n            this.data = event.detail.data;\n          }\n          this.eventHandler.emit(event);\n        });\n      }\n\n    }\n  }\n\n  public getEventHandler(): EventEmitter<any> {\n    return this.eventHandler;\n  }\n\n  public setEventHandler(event: any) {\n    this.eventHandler = event;\n  }\n}\n"]}