UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

493 lines (492 loc) 47.4 kB
/** * @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"]}