UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

444 lines (440 loc) 44 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ 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'; const /** @type {?} */ FORM_VIEW = 'form-view'; const /** @type {?} */ TYPE_NAME = "phx-data-form"; export class DataForm extends AbstractHasData { /** * @param {?} notifyMgr * @param {?} dialogServ * @param {?} elementRef */ constructor(notifyMgr, dialogServ, elementRef) { super(elementRef); this.testCount = 0; this.dataContainer = []; this.descriptions = []; this.changeEvent = new EventEmitter(); // for test notification this.notifyMgr = notifyMgr; this.dialogServ = dialogServ; } /** * @return {?} */ ngOnInit() { super.ngOnInit(); 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"]; let /** @type {?} */ nameFieldChangeEV = this.nameTextField.getChangeEvent(); if (nameFieldChangeEV !== null && typeof nameFieldChangeEV !== 'undefined') { nameFieldChangeEV.subscribe((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); }); } let /** @type {?} */ shortNameChangeEV = this.shortNameTextField.getChangeEvent(); if (shortNameChangeEV !== null && typeof shortNameChangeEV !== 'undefined') { shortNameChangeEV.subscribe((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 {?} */ onEmitChange(event) { let /** @type {?} */ data = { source: event, bubbleStack: [this] }; let /** @type {?} */ ev = EventUtils.newCustomEvent(CHANGE_EVENT, this, data, null); this.changeEvent.emit(ev); } /** * @return {?} */ _getDataContainer() { return this.dataContainer; } /** * @return {?} */ getModel() { return this.model; } /** * @param {?} model * @return {?} */ setModel(model) { this.model = model; } /** * @param {?} data * @return {?} */ setData(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) { for (let /** @type {?} */ c of this.dataChildren) { c.setData(this.dataContainer); } } } /** * @param {?} $event * @return {?} */ showDataClicked($event) { // test notification if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { this.testCount += 1; let /** @type {?} */ d = new Date(); let /** @type {?} */ clickFunc = () => { console.log('BODY CLICKED'); }; let /** @type {?} */ notification = new Notification("", "TITLE: " + this.testCount, "description", true, "LB", d, 2000); notification.clickHandler = clickFunc; let /** @type {?} */ action1 = new NotificationAction('MORE', (ev) => { console.log('first CLICKED'); if (ev !== null && typeof ev !== 'undefined') { ev.detail.data.instance.showBody(); } }); let /** @type {?} */ action2 = new NotificationAction('CANCEL', () => { console.log('cancel CLICKED'); }, true); notification.addAction(action1); notification.addAction(action2); notification.bodyComponent = TestComponent; this.notifyMgr.notify(notification); } } /** * @param {?} $event * @return {?} */ saveDataClicked($event) { let /** @type {?} */ name = this.nameTextField.getInputValue(); let /** @type {?} */ shortName = this.shortNameTextField.getInputValue(); let /** @type {?} */ dateString = this.dateTextField.getInputValue(); let /** @type {?} */ datePicker = this.datePickerTextField.getData(); let /** @type {?} */ timePicker = this.timePickerTextField.getData(); let /** @type {?} */ areaName = this.areaTextField.getInputValue(); if (this.data.editor !== null && typeof this.data.editor !== 'undefined') { let /** @type {?} */ formView = /** @type {?} */ (this.data.editor.getViewComponentFromType(FORM_VIEW)); let /** @type {?} */ curIndex = formView.getCurrentTabIndex(); let /** @type {?} */ obj = formView.getTabData(curIndex); if (obj !== null && obj.length > 0) { let /** @type {?} */ objs = formView.getTabData(curIndex); let /** @type {?} */ createdArray = []; let /** @type {?} */ updatedArray = []; let /** @type {?} */ objectIdField = this.data.editor.getObjectIdField(); for (let /** @type {?} */ obj of objs) { if (obj[objectIdField] !== null && typeof obj[objectIdField] !== 'undefined') { updatedArray.push(obj); } else { createdArray.push(obj); } } // 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 let /** @type {?} */ newObj = { name: name, shortName: shortName, _created: dateString, datePicker: datePicker, timePicker: timePicker, areaName: areaName }; this.data.editor.createData(newObj); } } } /** * @param {?} $event * @return {?} */ editDataClicked($event) { // test clear all notify if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { this.notifyMgr.clearAll(); } } /** * @return {?} */ getChangeEvent() { return this.changeEvent; } /** * @return {?} */ isSelfDataDirty() { return false; } /** * @param {?} data * @return {?} */ selfSaveData(data) { } /** * @return {?} */ selfResetData() { } /** * @return {?} */ doPreload() { return new Promise((resolve, reject) => { resolve(null); }); } /** * @return {?} */ doLoaded() { } /** * @return {?} */ getFields() { return this.fields; } /** * @return {?} */ getLabels() { return this.labels; } /** * @return {?} */ getDescriptions() { return this.descriptions; } /** * @return {?} */ getMinDate() { return this.minDate; } /** * @return {?} */ getMaxDate() { return this.maxDate; } /** * @return {?} */ getMinTime() { return this.minTime; } /** * @return {?} */ getMaxTime() { return this.maxTime; } /** * @return {?} */ getRows() { return this.rows; } /** * @return {?} */ getCols() { return this.cols; } } DataForm.TYPE_NAME = TYPE_NAME; DataForm.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="data-form"> <div class="header"> <div class="left"> <div class="table-wrapper"> <div class="table-cell-wrapper middle"> <div class="title"> Payment voucher </div> <div class="subtitle"> voucherNo: POXXXXXXXXX </div> </div> </div> </div> <div class="right"> <div class="table-wrapper"> <div class="table-cell-wrapper middle"> <div class="title"> ABS Management solution </div> <div class="subtitle"> address sthing </div> </div> </div> </div> </div> <div class="body"> <div class="body-container"> <div class="row"> <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> </div> <div class="row"> <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> </div> <div class="row"> <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> </div> <div class="row"> <div class="col-md-6"> <material-date-picker [phxMin]="getMinDate()" [phxMax]="getMaxDate()" [description]="getDescriptions()[3]"></material-date-picker> </div> <div class="col-md-6"> <material-time-picker [phxMin]="getMinTime()" [phxMax]="getMaxTime()" [description]="getDescriptions()[4]"></material-time-picker> </div> </div> <div class="row"> <div class="col-md-12"> <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> </div> </div> <div class="row"> <div class="col-md-3"><button type="button" class="btn btn-default" (click)="showDataClicked($event)">Show Data</button></div> <div class="col-md-3"><button type="button" class="btn btn-default" (click)="editDataClicked($event)">Edit Data</button></div> <div class="col-md-3"><button type="button" class="btn btn-default" (click)="saveDataClicked($event)">Save Data</button></div> </div> </div> </div> </div> ` },] }, ]; /** @nocollapse */ DataForm.ctorParameters = () => [ { 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',] },], }; 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":";;;;AAAA,OAAO,EAAE,SAAS,EAAU,UAAU,EAAE,KAAK,EAAgB,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC5G,OAAO,EAA4B,YAAY,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC5F,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC7E,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAGjE,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,sEAAsE,CAAC;AACvG,OAAO,EAAE,kBAAkB,EAAE,MAAM,yEAAyE,CAAC;AAC7G,OAAO,EAAE,kBAAkB,EAAE,MAAM,yEAAyE,CAAC;AAC7G,OAAO,EAAE,gBAAgB,EAAE,MAAM,uEAAuE,CAAC;AAKzG,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAEvD,uBAAM,SAAS,GAAG,WAAW,CAAC;AAI9B,uBAAM,SAAS,GAAW,eAAe,CAAC;AA8D1C,MAAM,eAAgB,SAAQ,eAAe;;;;;;IAoC3C,YAAY,SAA8B,EAAE,UAAyB,EAAE,UAAsB;QAC3F,KAAK,CAAC,UAAU,CAAC,CAAC;yBAHQ,CAAC;QAI3B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,IAAI,YAAY,EAAE,CAAC;;QAGtC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;KAC9B;;;;IAEM,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,CAAC,MAAM,GAAG,CAAC,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;QAChG,IAAI,CAAC,MAAM,GAAG,CAAC,MAAM,EAAE,WAAW,EAAE,aAAa,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;QACnG,IAAI,CAAC,YAAY,GAAG,CAAC,kBAAkB,EAAE,uBAAuB,EAAE,wBAAwB;YACtF,4BAA4B,EAAE,4BAA4B,EAAE,sBAAsB,CAAC,CAAC;QAExF,qBAAI,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC;QAC5D,EAAE,CAAC,CAAC,iBAAiB,KAAK,IAAI,IAAI,OAAO,iBAAiB,KAAK,WAAW,CAAC,CAAC,CAAC;YAC3E,iBAAiB,CAAC,SAAS,CAAC,CAAC,KAAU,EAAE,EAAE;gBACzC,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,KAAK,IAAI,IAAI,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC;oBAC3E,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,KAAK,IAAI,IAAI,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,KAAK,WAAW,CAAC,CAAC,CAAC;wBACnG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBAC1C;oBAAC,IAAI,CAAC,CAAC;wBACN,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,CAAC;qBACxC;iBACF;gBACD,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aAC1B,CAAC,CAAC;SACJ;QACD,qBAAI,iBAAiB,GAAG,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,CAAC;QACjE,EAAE,CAAC,CAAC,iBAAiB,KAAK,IAAI,IAAI,OAAO,iBAAiB,KAAK,WAAW,CAAC,CAAC,CAAC;YAC3E,iBAAiB,CAAC,SAAS,CAAC,CAAC,KAAU,EAAE,EAAE;gBACzC,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,KAAK,IAAI,IAAI,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC;oBAC3E,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,KAAK,IAAI,IAAI,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,KAAK,WAAW,CAAC,CAAC,CAAC;wBACnG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBAC1C;oBAAC,IAAI,CAAC,CAAC;wBACN,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,CAAC;qBACxC;iBACF;gBACD,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aAC1B,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAE1B,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACnC,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAEnC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC;;;;;;IAGV,YAAY,CAAC,KAAU;QAC7B,qBAAI,IAAI,GAAQ;YACd,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,CAAC,IAAI,CAAC;SACpB,CAAC;QACF,qBAAI,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,YAAY,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAEnE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;;;;;IAGrB,iBAAiB;QACtB,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC;;;;;IAGrB,QAAQ;QACb,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;;;;;;IAGb,QAAQ,CAAC,KAAU;QACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;;;;;;IAGd,OAAO,CAAC,IAAS;;QAEtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QAEjB,EAAE,CAAC,CAAC,IAAI,KAAK,IAAI,IAAI,OAAO,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC;YACjD,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAChC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC;aACnC;SACF;;QAGD,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,CAAC,CAAC;YAC/B,GAAG,CAAC,CAAC,qBAAI,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;gBAChC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aAC/B;SACF;;;;;;IAGI,eAAe,CAAC,MAAa;;QAElC,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,WAAW,CAAC,CAAC,CAAC;YACrE,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC;YACpB,qBAAI,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC;YACnB,qBAAI,SAAS,GAAa,GAAG,EAAE;gBAC7B,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;aAC7B,CAAC;YACF,qBAAI,YAAY,GAAiB,IAAI,YAAY,CAAC,EAAE,EAAE,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;YACtH,YAAY,CAAC,YAAY,GAAG,SAAS,CAAC;YACtC,qBAAI,OAAO,GAAuB,IAAI,kBAAkB,CAAC,MAAM,EAAE,CAAC,EAAO,EAAE,EAAE;gBAC3E,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;gBAC7B,EAAE,CAAC,CAAC,EAAE,KAAK,IAAI,IAAI,OAAO,EAAE,KAAK,WAAW,CAAC,CAAC,CAAC;oBAC7C,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;iBACpC;aACF,CAAC,CAAC;YACH,qBAAI,OAAO,GAAuB,IAAI,kBAAkB,CAAC,QAAQ,EAAE,GAAG,EAAE;gBACtE,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;aAC/B,EAAE,IAAI,CAAC,CAAC;YACT,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YAChC,YAAY,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YAChC,YAAY,CAAC,aAAa,GAAG,aAAa,CAAC;YAC3C,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;SACrC;;;;;;IAGI,eAAe,CAAC,MAAa;QAClC,qBAAI,IAAI,GAAW,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC;QACtD,qBAAI,SAAS,GAAW,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;QAChE,qBAAI,UAAU,GAAW,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC;QAC5D,qBAAI,UAAU,GAAQ,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC;QACzD,qBAAI,UAAU,GAAQ,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC;QACzD,qBAAI,QAAQ,GAAW,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC;QAE1D,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC;YACzE,qBAAI,QAAQ,qBAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,wBAAwB,CAAC,SAAS,CAAa,CAAA,CAAC;YAChF,qBAAI,QAAQ,GAAG,QAAQ,CAAC,kBAAkB,EAAE,CAAC;YAE7C,qBAAI,GAAG,GAAQ,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAE7C,EAAE,CAAC,CAAC,GAAG,KAAK,IAAI,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnC,qBAAI,IAAI,GAAU,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;gBAEhD,qBAAI,YAAY,GAAU,EAAE,CAAC;gBAC7B,qBAAI,YAAY,GAAU,EAAE,CAAC;gBAE7B,qBAAI,aAAa,GAAW,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;gBAChE,GAAG,CAAC,CAAC,qBAAI,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC;oBACrB,EAAE,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,KAAK,IAAI,IAAI,OAAO,GAAG,CAAC,aAAa,CAAC,KAAK,WAAW,CAAC,CAAC,CAAC;wBAC7E,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;qBACxB;oBAAC,IAAI,CAAC,CAAC;wBACN,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;qBACxB;iBACF;;gBAGD,EAAE,CAAC,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;oBAC5B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;iBAC3C;;gBAED,EAAE,CAAC,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;oBAC5B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;iBAC3C;aAEF;YAAC,IAAI,CAAC,CAAC;;gBAEN,qBAAI,MAAM,GAAQ;oBAChB,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;oBAC9B,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU;oBAC5C,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ;iBAC7C,CAAC;gBACF,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;aACrC;SACF;;;;;;IAGI,eAAe,CAAC,MAAa;;QAElC,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,WAAW,CAAC,CAAC,CAAC;YAErE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;SAC3B;;;;;IAGI,cAAc;QACnB,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC;;;;;IAGnB,eAAe;QACpB,MAAM,CAAC,KAAK,CAAC;;;;;;IAGR,YAAY,CAAC,IAAS;;;;;IAItB,aAAa;;;;;IAIb,SAAS,KAAuB,MAAM,CAAC,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,GAAS,OAAO,CAAC,IAAI,CAAC,CAAC,EAAM,CAAC,CAAC;;;;IAAa,QAAQ;;;;;IAI3H,SAAS;QACd,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;;;;;IAGd,SAAS;QACd,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;;;;;IAGd,eAAe;QACpB,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;;;;;IAGpB,UAAU;QACf,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;;;;;IAGf,UAAU;QACf,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;;;;;IAGf,UAAU;QACf,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;;;;;IAGf,UAAU;QACf,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;;;;;IAGf,OAAO;QACZ,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;IAGZ,OAAO;QACZ,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;;;qBAjRwB,SAAS;;YA7DrD,SAAS,SAAC;gBACT,QAAQ,EAAE,MAAM,CAAC,EAAE;gBACnB,QAAQ,EAAE,SAAS;gBACnB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAsDX;aACA;;;;YAlFQ,mBAAmB;YACnB,aAAa;YAHM,UAAU;;;2BAyFnC,KAAK;8BAML,SAAS,SAAC,eAAe;mCAEzB,SAAS,SAAC,oBAAoB;8BAE9B,SAAS,SAAC,eAAe;oCAEzB,SAAS,SAAC,qBAAqB;oCAE/B,SAAS,SAAC,qBAAqB;8BAE/B,SAAS,SAAC,eAAe","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"]}