com.phloxui
Version:
PhloxUI Ng2+ Framework
207 lines (206 loc) • 19.2 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 { AbstractDataViewWrapper } from '../dataview/AbstractDataViewWrapper';
import { DATA_CHANGE_EVENT } from '../../share/CustomEventType';
var /** @type {?} */ TYPE_NAME = "phx-record-data-view-wrapper";
var RecordDataViewWrapper = /** @class */ (function (_super) {
tslib_1.__extends(RecordDataViewWrapper, _super);
function RecordDataViewWrapper(target, componentFactoryResolver) {
return _super.call(this, target, componentFactoryResolver) || this;
}
/**
* @return {?}
*/
RecordDataViewWrapper.prototype.ngOnInit = /**
* @return {?}
*/
function () {
_super.prototype.ngOnInit.call(this);
};
/**
* @param {?} key
* @param {?} dataObj
* @return {?}
*/
RecordDataViewWrapper.prototype.parseValue = /**
* @param {?} key
* @param {?} dataObj
* @return {?}
*/
function (key, dataObj) {
if (key == null || dataObj == null) {
return null;
}
var /** @type {?} */ result = null;
if (key.indexOf(".") > 0) {
var /** @type {?} */ splitKeys = key.split(".");
if (splitKeys.length > 0) {
var /** @type {?} */ firstKey = splitKeys[0];
var /** @type {?} */ firstValue = dataObj[firstKey];
if (firstValue != null && typeof firstValue !== 'undefined') {
if (typeof firstValue === 'object') {
if (splitKeys.length > 1) {
var /** @type {?} */ secondKey = key.substring(key.indexOf(".") + 1, key.length);
return this.parseValue(secondKey, firstValue); // recursive beware looping
}
}
}
}
}
else {
result = dataObj[key];
}
if (result != null && typeof result !== 'undefined') {
return result;
}
return null;
};
/**
* @param {?} key
* @param {?} dataObj
* @param {?} value
* @return {?}
*/
RecordDataViewWrapper.prototype.editDataObjectValue = /**
* @param {?} key
* @param {?} dataObj
* @param {?} value
* @return {?}
*/
function (key, dataObj, value) {
if (key == null || dataObj == null || value == null) {
return;
}
if (key.indexOf(".") > 0) {
var /** @type {?} */ splitKeys = key.split(".");
if (splitKeys.length > 0) {
var /** @type {?} */ firstKey = splitKeys[0];
var /** @type {?} */ firstValue = dataObj[firstKey];
if (firstValue != null && typeof firstValue !== 'undefined') {
if (typeof firstValue === 'object') {
if (splitKeys.length > 1) {
var /** @type {?} */ secondKey = key.substring(key.indexOf(".") + 1, key.length);
this.editDataObjectValue(secondKey, firstValue, value); // recursive beware looping
}
}
}
}
}
else {
dataObj[key] = value;
}
};
/**
* @return {?}
*/
RecordDataViewWrapper.prototype.render = /**
* @return {?}
*/
function () {
var _this = this;
if (this.componentType != null && (typeof this.componentType !== 'undefined')) {
var /** @type {?} */ simpleCompoFactory = this.componentFactoryResolver.resolveComponentFactory(this.componentType);
var /** @type {?} */ compRef = this.target.createComponent(simpleCompoFactory);
if (typeof compRef.instance.setData === 'function') {
compRef.instance.setData(this.data);
}
if (typeof compRef.instance.setField === 'function') {
compRef.instance.setField(this.fieldValue);
}
if (typeof compRef.instance.setOptions === 'function') {
compRef.instance.setOptions(this.options);
}
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
if (_this.editorHandler != null) {
_this.editorHandler.onDataChange(event.detail.data);
}
else {
_this.editDataObjectValue(_this.fieldValue, _this.data, event.detail.data);
}
}
_this.eventHandler.emit(event);
});
}
}
};
/**
* @return {?}
*/
RecordDataViewWrapper.prototype.getEventHandler = /**
* @return {?}
*/
function () {
return this.eventHandler;
};
/**
* @param {?} event
* @return {?}
*/
RecordDataViewWrapper.prototype.setEventHandler = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.eventHandler = event;
};
RecordDataViewWrapper.TYPE_NAME = TYPE_NAME;
RecordDataViewWrapper.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: ""
},] },
];
/** @nocollapse */
RecordDataViewWrapper.ctorParameters = function () { return [
{ type: ViewContainerRef, },
{ type: ComponentFactoryResolver, },
]; };
RecordDataViewWrapper.propDecorators = {
"componentType": [{ type: Input },],
"data": [{ type: Input },],
"eventHandler": [{ type: Output },],
"fieldValue": [{ type: Input },],
"options": [{ type: Input },],
"editorHandler": [{ type: Input },],
};
return RecordDataViewWrapper;
}(AbstractDataViewWrapper));
export { RecordDataViewWrapper };
function RecordDataViewWrapper_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
RecordDataViewWrapper.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
RecordDataViewWrapper.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
RecordDataViewWrapper.propDecorators;
/** @type {?} */
RecordDataViewWrapper.TYPE_NAME;
/** @type {?} */
RecordDataViewWrapper.prototype.componentType;
/** @type {?} */
RecordDataViewWrapper.prototype.data;
/** @type {?} */
RecordDataViewWrapper.prototype.eventHandler;
/** @type {?} */
RecordDataViewWrapper.prototype.fieldValue;
/** @type {?} */
RecordDataViewWrapper.prototype.options;
/** @type {?} */
RecordDataViewWrapper.prototype.editorHandler;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RecordDataViewWrapper.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/RecordDataViewWrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, ViewContainerRef, Type, EventEmitter, ComponentFactoryResolver } from '@angular/core';\nimport { AbstractDataViewWrapper } from '../dataview/AbstractDataViewWrapper';\nimport { IEditorHandler } from './IEditorHandler';\nimport { DATA_CHANGE_EVENT } from '../../share/CustomEventType';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-record-data-view-wrapper\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: ``\n})\nexport class RecordDataViewWrapper extends AbstractDataViewWrapper implements OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  protected componentType: Type<any>;\n  @Input()\n  protected data: any;\n  @Output()\n  protected eventHandler: EventEmitter<any>;\n  @Input()\n  protected fieldValue: string;\n  @Input()\n  protected options: any;\n  @Input()\n  private editorHandler: IEditorHandler;\n\n  constructor(target: ViewContainerRef, componentFactoryResolver: ComponentFactoryResolver) {\n    super(target, componentFactoryResolver);\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n  }\n\n  private parseValue(key: string, dataObj: any): string {\n    if (key == null || dataObj == null) {\n      return null;\n    }\n\n    let result = null;\n\n    if (key.indexOf(\".\") > 0) {\n      let splitKeys: string[] = key.split(\".\");\n      if (splitKeys.length > 0) {\n        let firstKey: string = splitKeys[0];\n        let firstValue: any = dataObj[firstKey];\n\n        if (firstValue != null && typeof firstValue !== 'undefined') {\n          if (typeof firstValue === 'object') {\n            if (splitKeys.length > 1) {\n              let secondKey: string = key.substring(key.indexOf(\".\") + 1, key.length);\n\n              return this.parseValue(secondKey, firstValue); // recursive beware looping\n            }\n          }\n        }\n      }\n    } else {\n      result = dataObj[key];\n    }\n\n    if (result != null && typeof result !== 'undefined') {\n      return result;\n    }\n\n    return null;\n  }\n\n  private editDataObjectValue(key: string, dataObj: any, value: any): void {\n    if (key == null || dataObj == null || value == null) {\n      return;\n    }\n\n    if (key.indexOf(\".\") > 0) {\n      let splitKeys: string[] = key.split(\".\");\n      if (splitKeys.length > 0) {\n        let firstKey: string = splitKeys[0];\n        let firstValue: any = dataObj[firstKey];\n\n        if (firstValue != null && typeof firstValue !== 'undefined') {\n          if (typeof firstValue === 'object') {\n            if (splitKeys.length > 1) {\n              let secondKey: string = key.substring(key.indexOf(\".\") + 1, key.length);\n\n              this.editDataObjectValue(secondKey, firstValue, value); // recursive beware looping\n            }\n          }\n        }\n      }\n    } else {\n      dataObj[key] = value;\n    }\n  }\n\n  public render(): void {\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\n      if (typeof compRef.instance.setData === 'function') {\n        compRef.instance.setData(this.data);\n      }\n      if (typeof compRef.instance.setField === 'function') {\n        compRef.instance.setField(this.fieldValue);\n      }\n      if (typeof compRef.instance.setOptions === 'function') {\n        compRef.instance.setOptions(this.options);\n      }\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            if (this.editorHandler != null) {\n              this.editorHandler.onDataChange(event.detail.data);\n            } else {\n              this.editDataObjectValue(this.fieldValue, this.data, event.detail.data);\n            }\n          }\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}\n"]}