com.phloxui
Version:
PhloxUI Ng2+ Framework
493 lines (492 loc) • 47.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, Input, ViewChild, EventEmitter } from '@angular/core';
import { Notification, NotificationAction } from './model/models';
import { NotificationManager } from '../service/NotificationManager.service';
import { DialogService } from '../service/DialogService.service';
import { AbstractHasData } from './AbstractHasData';
import { MaterialTextBox } from '../theme/material/component/dataview/input/MaterialTextBox.component';
import { MaterialDatePicker } from '../theme/material/component/dataview/input/MaterialDatePicker.component';
import { MaterialTimePicker } from '../theme/material/component/dataview/input/MaterialTimePicker.component';
import { MaterialTextArea } from '../theme/material/component/dataview/input/MaterialTextArea.component';
import { TestComponent } from './TestComponent.component';
import { CHANGE_EVENT } from '../share/CustomEventType';
import { EventUtils } from '../share/utils/EventUtils';
var /** @type {?} */ FORM_VIEW = 'form-view';
var /** @type {?} */ TYPE_NAME = "phx-data-form";
var DataForm = /** @class */ (function (_super) {
tslib_1.__extends(DataForm, _super);
function DataForm(notifyMgr, dialogServ, elementRef) {
var _this = _super.call(this, elementRef) || this;
_this.testCount = 0;
_this.dataContainer = [];
_this.descriptions = [];
_this.changeEvent = new EventEmitter();
// for test notification
// for test notification
_this.notifyMgr = notifyMgr;
_this.dialogServ = dialogServ;
return _this;
}
/**
* @return {?}
*/
DataForm.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
_super.prototype.ngOnInit.call(this);
this.fields = ["name", "shortName", "_created", "datePickerName", "timePickerName", "areaName"];
this.labels = ["Name", "ShortName", "Create Date", "DatePickerName", "TimePickerName", "AreaName"];
this.descriptions = ["name description", "shortName description", "createDate Description",
"datePickerName description", "timePickerName description", "areaName description"];
var /** @type {?} */ nameFieldChangeEV = this.nameTextField.getChangeEvent();
if (nameFieldChangeEV !== null && typeof nameFieldChangeEV !== 'undefined') {
nameFieldChangeEV.subscribe(function (event) {
if (event.detail.data !== null && typeof event.detail.data !== 'undefined') {
if (event.detail.data.bubbleStack !== null && typeof event.detail.data.bubbleStack !== 'undefined') {
event.detail.data.bubbleStack.push(_this);
}
else {
event.detail.data.bubbleStack = [_this];
}
}
_this.onEmitChange(event);
});
}
var /** @type {?} */ shortNameChangeEV = this.shortNameTextField.getChangeEvent();
if (shortNameChangeEV !== null && typeof shortNameChangeEV !== 'undefined') {
shortNameChangeEV.subscribe(function (event) {
if (event.detail.data !== null && typeof event.detail.data !== 'undefined') {
if (event.detail.data.bubbleStack !== null && typeof event.detail.data.bubbleStack !== 'undefined') {
event.detail.data.bubbleStack.push(_this);
}
else {
event.detail.data.bubbleStack = [_this];
}
}
_this.onEmitChange(event);
});
}
this.minDate = new Date();
this.minDate.setHours(0, 0, 0, 0);
this.minDate.setMonth(5);
this.maxDate = new Date();
this.maxDate.setHours(0, 0, 0, 0);
this.maxDate.setMonth(10);
this.minTime = new Date();
this.minTime.setHours(10, 0, 0, 0);
this.maxTime = new Date();
this.maxTime.setHours(15, 0, 0, 0);
this.rows = 8;
this.cols = 100;
};
/**
* @param {?} event
* @return {?}
*/
DataForm.prototype.onEmitChange = /**
* @param {?} event
* @return {?}
*/
function (event) {
var /** @type {?} */ data = {
source: event,
bubbleStack: [this]
};
var /** @type {?} */ ev = EventUtils.newCustomEvent(CHANGE_EVENT, this, data, null);
this.changeEvent.emit(ev);
};
/**
* @return {?}
*/
DataForm.prototype._getDataContainer = /**
* @return {?}
*/
function () {
return this.dataContainer;
};
/**
* @return {?}
*/
DataForm.prototype.getModel = /**
* @return {?}
*/
function () {
return this.model;
};
/**
* @param {?} model
* @return {?}
*/
DataForm.prototype.setModel = /**
* @param {?} model
* @return {?}
*/
function (model) {
this.model = model;
};
/**
* @param {?} data
* @return {?}
*/
DataForm.prototype.setData = /**
* @param {?} data
* @return {?}
*/
function (data) {
// overide method
this.data = data;
if (data !== null && typeof data !== 'undefined') {
if (Array.isArray(data.objects)) {
this.dataContainer = data.objects;
}
}
// child add dataContainer instead
if (this.dataChildren !== null) {
try {
for (var _a = tslib_1.__values(this.dataChildren), _b = _a.next(); !_b.done; _b = _a.next()) {
var c = _b.value;
c.setData(this.dataContainer);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
}
finally { if (e_1) throw e_1.error; }
}
}
var e_1, _c;
};
/**
* @param {?} $event
* @return {?}
*/
DataForm.prototype.showDataClicked = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
// test notification
if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {
this.testCount += 1;
var /** @type {?} */ d = new Date();
var /** @type {?} */ clickFunc = function () {
console.log('BODY CLICKED');
};
var /** @type {?} */ notification = new Notification("", "TITLE: " + this.testCount, "description", true, "LB", d, 2000);
notification.clickHandler = clickFunc;
var /** @type {?} */ action1 = new NotificationAction('MORE', function (ev) {
console.log('first CLICKED');
if (ev !== null && typeof ev !== 'undefined') {
ev.detail.data.instance.showBody();
}
});
var /** @type {?} */ action2 = new NotificationAction('CANCEL', function () {
console.log('cancel CLICKED');
}, true);
notification.addAction(action1);
notification.addAction(action2);
notification.bodyComponent = TestComponent;
this.notifyMgr.notify(notification);
}
};
/**
* @param {?} $event
* @return {?}
*/
DataForm.prototype.saveDataClicked = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ name = this.nameTextField.getInputValue();
var /** @type {?} */ shortName = this.shortNameTextField.getInputValue();
var /** @type {?} */ dateString = this.dateTextField.getInputValue();
var /** @type {?} */ datePicker = this.datePickerTextField.getData();
var /** @type {?} */ timePicker = this.timePickerTextField.getData();
var /** @type {?} */ areaName = this.areaTextField.getInputValue();
if (this.data.editor !== null && typeof this.data.editor !== 'undefined') {
var /** @type {?} */ formView = /** @type {?} */ (this.data.editor.getViewComponentFromType(FORM_VIEW));
var /** @type {?} */ curIndex = formView.getCurrentTabIndex();
var /** @type {?} */ obj = formView.getTabData(curIndex);
if (obj !== null && obj.length > 0) {
var /** @type {?} */ objs = formView.getTabData(curIndex);
var /** @type {?} */ createdArray = [];
var /** @type {?} */ updatedArray = [];
var /** @type {?} */ objectIdField = this.data.editor.getObjectIdField();
try {
for (var objs_1 = tslib_1.__values(objs), objs_1_1 = objs_1.next(); !objs_1_1.done; objs_1_1 = objs_1.next()) {
var obj_1 = objs_1_1.value;
if (obj_1[objectIdField] !== null && typeof obj_1[objectIdField] !== 'undefined') {
updatedArray.push(obj_1);
}
else {
createdArray.push(obj_1);
}
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (objs_1_1 && !objs_1_1.done && (_a = objs_1.return)) _a.call(objs_1);
}
finally { if (e_2) throw e_2.error; }
}
// create data
if (createdArray.length > 0) {
this.data.editor.createData(createdArray);
}
// update data
if (updatedArray.length > 0) {
this.data.editor.updateData(updatedArray);
}
}
else {
// create new object
var /** @type {?} */ newObj = {
name: name, shortName: shortName,
_created: dateString, datePicker: datePicker,
timePicker: timePicker, areaName: areaName
};
this.data.editor.createData(newObj);
}
}
var e_2, _a;
};
/**
* @param {?} $event
* @return {?}
*/
DataForm.prototype.editDataClicked = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
// test clear all notify
if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {
this.notifyMgr.clearAll();
}
};
/**
* @return {?}
*/
DataForm.prototype.getChangeEvent = /**
* @return {?}
*/
function () {
return this.changeEvent;
};
/**
* @return {?}
*/
DataForm.prototype.isSelfDataDirty = /**
* @return {?}
*/
function () {
return false;
};
/**
* @param {?} data
* @return {?}
*/
DataForm.prototype.selfSaveData = /**
* @param {?} data
* @return {?}
*/
function (data) {
};
/**
* @return {?}
*/
DataForm.prototype.selfResetData = /**
* @return {?}
*/
function () {
};
/**
* @return {?}
*/
DataForm.prototype.doPreload = /**
* @return {?}
*/
function () { return new Promise(function (resolve, reject) { resolve(null); }); };
/**
* @return {?}
*/
DataForm.prototype.doLoaded = /**
* @return {?}
*/
function () {
};
/**
* @return {?}
*/
DataForm.prototype.getFields = /**
* @return {?}
*/
function () {
return this.fields;
};
/**
* @return {?}
*/
DataForm.prototype.getLabels = /**
* @return {?}
*/
function () {
return this.labels;
};
/**
* @return {?}
*/
DataForm.prototype.getDescriptions = /**
* @return {?}
*/
function () {
return this.descriptions;
};
/**
* @return {?}
*/
DataForm.prototype.getMinDate = /**
* @return {?}
*/
function () {
return this.minDate;
};
/**
* @return {?}
*/
DataForm.prototype.getMaxDate = /**
* @return {?}
*/
function () {
return this.maxDate;
};
/**
* @return {?}
*/
DataForm.prototype.getMinTime = /**
* @return {?}
*/
function () {
return this.minTime;
};
/**
* @return {?}
*/
DataForm.prototype.getMaxTime = /**
* @return {?}
*/
function () {
return this.maxTime;
};
/**
* @return {?}
*/
DataForm.prototype.getRows = /**
* @return {?}
*/
function () {
return this.rows;
};
/**
* @return {?}
*/
DataForm.prototype.getCols = /**
* @return {?}
*/
function () {
return this.cols;
};
DataForm.TYPE_NAME = TYPE_NAME;
DataForm.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"data-form\">\n\t<div class=\"header\">\n\t\t<div class=\"left\">\n\t\t\t<div class=\"table-wrapper\">\n\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t<div class=\"title\"> Payment voucher </div>\n\t\t\t\t\t<div class=\"subtitle\"> voucherNo: POXXXXXXXXX </div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"right\">\n\t\t\t<div class=\"table-wrapper\">\n\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t<div class=\"title\"> ABS Management solution </div>\n\t\t\t\t\t<div class=\"subtitle\"> address sthing </div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n\t<div class=\"body\">\n\t\t<div class=\"body-container\">\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\"><material-text-box required #nameTextField [label]=\"getLabels()[0]\" [description]=\"getDescriptions()[0]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[0]\" [dataParent]=\"this\"></material-text-box></div>\n\t\t\t</div>\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\"><material-text-box #shortNameTextField [label]=\"getLabels()[1]\" [description]=\"getDescriptions()[1]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[1]\" [dataParent]=\"this\"></material-text-box></div>\n\t\t\t</div>\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\"><material-text-box #dateTextField [label]=\"getLabels()[2]\" [description]=\"getDescriptions()[2]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[2]\" [dataParent]=\"this\"></material-text-box></div>\n\t\t\t</div>\n\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-6\">\n\t\t\t\t\t<material-date-picker [phxMin]=\"getMinDate()\" [phxMax]=\"getMaxDate()\" [description]=\"getDescriptions()[3]\"></material-date-picker>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-md-6\">\n\t\t\t\t\t<material-time-picker [phxMin]=\"getMinTime()\" [phxMax]=\"getMaxTime()\" [description]=\"getDescriptions()[4]\"></material-time-picker>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\">\n\t\t\t\t\t<material-text-area required [rows]=\"getRows()\" [cols]=\"getCols()\" #areaTextField [label]=\"getLabels()[5]\" [description]=\"getDescriptions()[5]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[5]\" [dataParent]=\"this\"></material-text-area>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-3\"><button type=\"button\" class=\"btn btn-default\" (click)=\"showDataClicked($event)\">Show Data</button></div>\n\t\t\t\t<div class=\"col-md-3\"><button type=\"button\" class=\"btn btn-default\" (click)=\"editDataClicked($event)\">Edit Data</button></div>\n\t\t\t\t<div class=\"col-md-3\"><button type=\"button\" class=\"btn btn-default\" (click)=\"saveDataClicked($event)\">Save Data</button></div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n"
},] },
];
/** @nocollapse */
DataForm.ctorParameters = function () { return [
{ type: NotificationManager, },
{ type: DialogService, },
{ type: ElementRef, },
]; };
DataForm.propDecorators = {
"dataParent": [{ type: Input },],
"nameTextField": [{ type: ViewChild, args: ['nameTextField',] },],
"shortNameTextField": [{ type: ViewChild, args: ['shortNameTextField',] },],
"dateTextField": [{ type: ViewChild, args: ['dateTextField',] },],
"datePickerTextField": [{ type: ViewChild, args: ['datePickerTextField',] },],
"timePickerTextField": [{ type: ViewChild, args: ['timePickerTextField',] },],
"areaTextField": [{ type: ViewChild, args: ['areaTextField',] },],
};
return DataForm;
}(AbstractHasData));
export { DataForm };
function DataForm_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
DataForm.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
DataForm.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
DataForm.propDecorators;
/** @type {?} */
DataForm.TYPE_NAME;
/** @type {?} */
DataForm.prototype.dataParent;
/** @type {?} */
DataForm.prototype.model;
/** @type {?} */
DataForm.prototype.fields;
/** @type {?} */
DataForm.prototype.labels;
/** @type {?} */
DataForm.prototype.descriptions;
/** @type {?} */
DataForm.prototype.nameTextField;
/** @type {?} */
DataForm.prototype.shortNameTextField;
/** @type {?} */
DataForm.prototype.dateTextField;
/** @type {?} */
DataForm.prototype.datePickerTextField;
/** @type {?} */
DataForm.prototype.timePickerTextField;
/** @type {?} */
DataForm.prototype.areaTextField;
/** @type {?} */
DataForm.prototype.dataContainer;
/** @type {?} */
DataForm.prototype.changeEvent;
/** @type {?} */
DataForm.prototype.notifyMgr;
/** @type {?} */
DataForm.prototype.dialogServ;
/** @type {?} */
DataForm.prototype.minDate;
/** @type {?} */
DataForm.prototype.maxDate;
/** @type {?} */
DataForm.prototype.minTime;
/** @type {?} */
DataForm.prototype.maxTime;
/** @type {?} */
DataForm.prototype.rows;
/** @type {?} */
DataForm.prototype.cols;
/** @type {?} */
DataForm.prototype.testCount;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataForm.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/DataForm.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener, ViewChild, EventEmitter } from '@angular/core';\nimport { MenuItemModel, MenuModel, Notification, NotificationAction } from './model/models';\nimport { NotificationManager } from '../service/NotificationManager.service';\nimport { DialogService } from '../service/DialogService.service';\nimport { IHasData } from './IHasData';\nimport { IHasModel } from './IHasModel';\nimport { AbstractHasData } from './AbstractHasData';\nimport { MaterialTextBox } from '../theme/material/component/dataview/input/MaterialTextBox.component';\nimport { MaterialDatePicker } from '../theme/material/component/dataview/input/MaterialDatePicker.component';\nimport { MaterialTimePicker } from '../theme/material/component/dataview/input/MaterialTimePicker.component';\nimport { MaterialTextArea } from '../theme/material/component/dataview/input/MaterialTextArea.component';\nimport { TextBox } from './dataview/input/TextBox.component';\nimport { TextArea } from './dataview/input/TextArea.component';\nimport { IChangeable } from './IChangeable';\nimport { FormView } from './editor/editor.internal/FormView.component';\nimport { TestComponent } from './TestComponent.component';\nimport { CHANGE_EVENT } from '../share/CustomEventType'\nimport { EventUtils } from '../share/utils/EventUtils';\n\nconst FORM_VIEW = 'form-view';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-data-form\";\n\n// for testing only remove this component when all fishished\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"data-form\">\n\t<div class=\"header\">\n\t\t<div class=\"left\">\n\t\t\t<div class=\"table-wrapper\">\n\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t<div class=\"title\"> Payment voucher </div>\n\t\t\t\t\t<div class=\"subtitle\"> voucherNo: POXXXXXXXXX </div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"right\">\n\t\t\t<div class=\"table-wrapper\">\n\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t<div class=\"title\"> ABS Management solution </div>\n\t\t\t\t\t<div class=\"subtitle\"> address sthing </div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n\t<div class=\"body\">\n\t\t<div class=\"body-container\">\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\"><material-text-box required #nameTextField [label]=\"getLabels()[0]\" [description]=\"getDescriptions()[0]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[0]\" [dataParent]=\"this\"></material-text-box></div>\n\t\t\t</div>\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\"><material-text-box #shortNameTextField [label]=\"getLabels()[1]\" [description]=\"getDescriptions()[1]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[1]\" [dataParent]=\"this\"></material-text-box></div>\n\t\t\t</div>\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\"><material-text-box #dateTextField [label]=\"getLabels()[2]\" [description]=\"getDescriptions()[2]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[2]\" [dataParent]=\"this\"></material-text-box></div>\n\t\t\t</div>\n\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-6\">\n\t\t\t\t\t<material-date-picker [phxMin]=\"getMinDate()\" [phxMax]=\"getMaxDate()\" [description]=\"getDescriptions()[3]\"></material-date-picker>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"col-md-6\">\n\t\t\t\t\t<material-time-picker [phxMin]=\"getMinTime()\" [phxMax]=\"getMaxTime()\" [description]=\"getDescriptions()[4]\"></material-time-picker>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-12\">\n\t\t\t\t\t<material-text-area required [rows]=\"getRows()\" [cols]=\"getCols()\" #areaTextField [label]=\"getLabels()[5]\" [description]=\"getDescriptions()[5]\" [data]=\"_getDataContainer()\" [field]=\"getFields()[5]\" [dataParent]=\"this\"></material-text-area>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div class=\"row\">\n\t\t\t\t<div class=\"col-md-3\"><button type=\"button\" class=\"btn btn-default\" (click)=\"showDataClicked($event)\">Show Data</button></div>\n\t\t\t\t<div class=\"col-md-3\"><button type=\"button\" class=\"btn btn-default\" (click)=\"editDataClicked($event)\">Edit Data</button></div>\n\t\t\t\t<div class=\"col-md-3\"><button type=\"button\" class=\"btn btn-default\" (click)=\"saveDataClicked($event)\">Save Data</button></div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n`\n})\nexport class DataForm extends AbstractHasData implements OnInit, IHasModel, IChangeable {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  protected dataParent: IHasData;\n  private model: any;\n  private fields: string[];\n  private labels: string[];\n  private descriptions: string[];\n  @ViewChild('nameTextField')\n  private nameTextField: MaterialTextBox;\n  @ViewChild('shortNameTextField')\n  private shortNameTextField: MaterialTextBox;\n  @ViewChild('dateTextField')\n  private dateTextField: MaterialTextBox;\n  @ViewChild('datePickerTextField')\n  private datePickerTextField: MaterialDatePicker;\n  @ViewChild('timePickerTextField')\n  private timePickerTextField: MaterialTimePicker;\n  @ViewChild('areaTextField')\n  private areaTextField: MaterialTextArea;\n  private dataContainer: any[];\n  private changeEvent: EventEmitter<any>;\n  // test\n  private notifyMgr: NotificationManager;\n  private dialogServ: DialogService;\n  private minDate: Date;\n  private maxDate: Date;\n  private minTime: Date;\n  private maxTime: Date;\n  private rows: number;\n  private cols: number;\n\n  private testCount: number = 0;\n\n  constructor(notifyMgr: NotificationManager, dialogServ: DialogService, elementRef: ElementRef) {\n    super(elementRef);\n    this.dataContainer = [];\n    this.descriptions = [];\n    this.changeEvent = new EventEmitter();\n\n    // for test notification\n    this.notifyMgr = notifyMgr;\n    this.dialogServ = dialogServ;\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    this.fields = [\"name\", \"shortName\", \"_created\", \"datePickerName\", \"timePickerName\", \"areaName\"];\n    this.labels = [\"Name\", \"ShortName\", \"Create Date\", \"DatePickerName\", \"TimePickerName\", \"AreaName\"];\n    this.descriptions = [\"name description\", \"shortName description\", \"createDate Description\"\n      , \"datePickerName description\", \"timePickerName description\", \"areaName description\"];\n\n    let nameFieldChangeEV = this.nameTextField.getChangeEvent();\n    if (nameFieldChangeEV !== null && typeof nameFieldChangeEV !== 'undefined') {\n      nameFieldChangeEV.subscribe((event: any) => {\n        if (event.detail.data !== null && typeof event.detail.data !== 'undefined') {\n          if (event.detail.data.bubbleStack !== null && typeof event.detail.data.bubbleStack !== 'undefined') {\n            event.detail.data.bubbleStack.push(this);\n          } else {\n            event.detail.data.bubbleStack = [this];\n          }\n        }\n        this.onEmitChange(event);\n      });\n    }\n    let shortNameChangeEV = this.shortNameTextField.getChangeEvent();\n    if (shortNameChangeEV !== null && typeof shortNameChangeEV !== 'undefined') {\n      shortNameChangeEV.subscribe((event: any) => {\n        if (event.detail.data !== null && typeof event.detail.data !== 'undefined') {\n          if (event.detail.data.bubbleStack !== null && typeof event.detail.data.bubbleStack !== 'undefined') {\n            event.detail.data.bubbleStack.push(this);\n          } else {\n            event.detail.data.bubbleStack = [this];\n          }\n        }\n        this.onEmitChange(event);\n      });\n    }\n\n    this.minDate = new Date();\n    this.minDate.setHours(0, 0, 0, 0);\n    this.minDate.setMonth(5);\n    this.maxDate = new Date();\n    this.maxDate.setHours(0, 0, 0, 0);\n    this.maxDate.setMonth(10);\n\n    this.minTime = new Date();\n    this.minTime.setHours(10, 0, 0, 0);\n    this.maxTime = new Date();\n    this.maxTime.setHours(15, 0, 0, 0);\n\n    this.rows = 8;\n    this.cols = 100;\n  }\n\n  private onEmitChange(event: any): void {\n    let data: any = {\n      source: event,\n      bubbleStack: [this]\n    };\n    let ev = EventUtils.newCustomEvent(CHANGE_EVENT, this, data, null);\n\n    this.changeEvent.emit(ev);\n  }\n\n  public _getDataContainer(): any[] {\n    return this.dataContainer;\n  }\n\n  public getModel(): any {\n    return this.model;\n  }\n\n  public setModel(model: any): void {\n    this.model = model;\n  }\n\n  public setData(data: any): void {\n    // overide method\n    this.data = data;\n\n    if (data !== null && typeof data !== 'undefined') {\n      if (Array.isArray(data.objects)) {\n        this.dataContainer = data.objects;\n      }\n    }\n\n    // child add dataContainer instead\n    if (this.dataChildren !== null) {\n      for (let c of this.dataChildren) {\n        c.setData(this.dataContainer);\n      }\n    }\n  }\n\n  public showDataClicked($event: Event): void {\n    // test notification\n    if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {\n      this.testCount += 1;\n      let d = new Date();\n      let clickFunc: Function = () => {\n        console.log('BODY CLICKED');\n      };\n      let notification: Notification = new Notification(\"\", \"TITLE: \" + this.testCount, \"description\", true, \"LB\", d, 2000);\n      notification.clickHandler = clickFunc;\n      let action1: NotificationAction = new NotificationAction('MORE', (ev: any) => {\n        console.log('first CLICKED');\n        if (ev !== null && typeof ev !== 'undefined') {\n          ev.detail.data.instance.showBody();\n        }\n      });\n      let action2: NotificationAction = new NotificationAction('CANCEL', () => {\n        console.log('cancel CLICKED');\n      }, true);\n      notification.addAction(action1);\n      notification.addAction(action2);\n      notification.bodyComponent = TestComponent;\n      this.notifyMgr.notify(notification);\n    }\n  }\n\n  public saveDataClicked($event: Event): void {\n    let name: string = this.nameTextField.getInputValue();\n    let shortName: string = this.shortNameTextField.getInputValue();\n    let dateString: string = this.dateTextField.getInputValue();\n    let datePicker: any = this.datePickerTextField.getData();\n    let timePicker: any = this.timePickerTextField.getData();\n    let areaName: string = this.areaTextField.getInputValue();\n\n    if (this.data.editor !== null && typeof this.data.editor !== 'undefined') {\n      let formView = this.data.editor.getViewComponentFromType(FORM_VIEW) as FormView;\n      let curIndex = formView.getCurrentTabIndex();\n\n      let obj: any = formView.getTabData(curIndex);\n\n      if (obj !== null && obj.length > 0) {\n        let objs: any[] = formView.getTabData(curIndex);\n\n        let createdArray: any[] = [];\n        let updatedArray: any[] = [];\n\n        let objectIdField: string = this.data.editor.getObjectIdField();\n        for (let obj of objs) {\n          if (obj[objectIdField] !== null && typeof obj[objectIdField] !== 'undefined') {\n            updatedArray.push(obj);\n          } else {\n            createdArray.push(obj);\n          }\n        }\n\n        // create data\n        if (createdArray.length > 0) {\n          this.data.editor.createData(createdArray);\n        }\n        // update data\n        if (updatedArray.length > 0) {\n          this.data.editor.updateData(updatedArray);\n        }\n\n      } else {\n        // create new object\n        let newObj: any = {\n          name: name, shortName: shortName\n          , _created: dateString, datePicker: datePicker\n          , timePicker: timePicker, areaName: areaName\n        };\n        this.data.editor.createData(newObj);\n      }\n    }\n  }\n\n  public editDataClicked($event: Event): void {\n    // test clear all notify\n    if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {\n\n      this.notifyMgr.clearAll();\n    }\n  }\n\n  public getChangeEvent(): EventEmitter<any> {\n    return this.changeEvent;\n  }\n\n  public isSelfDataDirty(): boolean {\n    return false;\n  }\n\n  public selfSaveData(data: any): void {\n\n  }\n\n  public selfResetData(): void {\n\n  }\n\n  public doPreload(): Promise<any> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  public doLoaded(): void {\n\n  }\n\n  public getFields(): string[] {\n    return this.fields;\n  }\n\n  public getLabels(): string[] {\n    return this.labels;\n  }\n\n  public getDescriptions(): string[] {\n    return this.descriptions;\n  }\n\n  public getMinDate(): Date {\n    return this.minDate;\n  }\n\n  public getMaxDate(): Date {\n    return this.maxDate;\n  }\n\n  public getMinTime(): Date {\n    return this.minTime;\n  }\n\n  public getMaxTime(): Date {\n    return this.maxTime;\n  }\n\n  public getRows(): number {\n    return this.rows;\n  }\n\n  public getCols(): number {\n    return this.cols;\n  }\n\n}\n"]}