com.phloxui
Version:
PhloxUI Ng2+ Framework
250 lines (249 loc) • 21.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, ElementRef } from '@angular/core';
import { AbstractHasData } from '../AbstractHasData';
import { AbstractDataEditor } from './AbstractDataEditor';
import { EntryEditorModel } from '../model/EntryEditorModel';
import { Option } from '../../decorator/Option.decorator';
import { DateTimeUtils } from '../../share/utils/DateTimeUtils';
const /** @type {?} */ TYPE_NAME = "phx-default-entry-editor-popover";
export class DefaultEntryEditorPopover extends AbstractHasData {
/**
* @param {?} elementRef
*/
constructor(elementRef) {
super(elementRef);
this.dataContainer = [];
this.entryEditors = [];
this.entryEditors.push(new EntryEditorModel('Title', "title", null));
this.entryEditors.push(new EntryEditorModel('StartTime', "startDateTime", null, null));
this.entryEditors.push(new EntryEditorModel('EndTime', "endDateTime", null, null));
}
/**
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
this.setData(this.data);
}
/**
* @return {?}
*/
isEntryEmpty() {
return (this.entry === null || typeof this.entry === 'undefined') ? true : false;
}
/**
* @return {?}
*/
getCalendarEntry() {
if (this.entryMapper !== null && typeof this.entryMapper !== 'undefined') {
return this.entryMapper.getCalendarEntry(this.data);
}
return null;
}
/**
* @param {?} data
* @return {?}
*/
setData(data) {
// overide method
this.data = data;
this.entry = this.getCalendarEntry();
this.dataContainer = [];
if (this.entry !== null && typeof this.entry !== 'undefined') {
this.dataContainer.push(this.entry);
}
// child add entry instead
if (this.dataChildren !== null) {
for (let /** @type {?} */ c of this.dataChildren) {
c.setData(this.dataContainer);
}
}
}
/**
* @param {?} entryMapper
* @return {?}
*/
setCalendarEntryMapper(entryMapper) {
this.entryMapper = entryMapper;
this.setData(this.data);
}
/**
* @param {?} editor
* @return {?}
*/
setEditor(editor) {
this.editor = editor;
}
/**
* @return {?}
*/
isSelfDataDirty() {
return false;
}
/**
* @param {?} data
* @return {?}
*/
selfSaveData(data) {
}
/**
* @return {?}
*/
selfResetData() {
}
/**
* @return {?}
*/
doPreload() { return new Promise((resolve, reject) => { resolve(null); }); }
/**
* @return {?}
*/
doLoaded() {
}
/**
* @return {?}
*/
getDataContainer() {
return this.dataContainer;
}
/**
* @return {?}
*/
hasEntryEditors() {
if (this.entryEditors !== null && this.entryEditors !== undefined) {
return true;
}
return false;
}
/**
* @return {?}
*/
getEntryEditors() {
return this.entryEditors;
}
/**
* @param {?} $event
* @return {?}
*/
onPopoverClosed($event) {
}
/**
* @param {?} $event
* @return {?}
*/
onAutoSaved($event) {
if (this.entryMapper !== null && typeof this.entryMapper !== 'undefined') {
let /** @type {?} */ startTime = this.entry.startDateTime;
let /** @type {?} */ endTime = this.entry.endDateTime;
if (startTime !== null && typeof startTime !== 'undefined') {
startTime = DateTimeUtils.getDateFromAny(startTime);
this.entry.startDateTime = startTime;
}
if (endTime !== null && typeof endTime !== 'undefined') {
endTime = DateTimeUtils.getDateFromAny(endTime);
this.entry.endDateTime = endTime;
}
this.entryMapper.updateData(this.data, this.entry);
}
}
/**
* @return {?}
*/
isAutoSave() {
return true;
}
}
DefaultEntryEditorPopover.TYPE_NAME = TYPE_NAME;
DefaultEntryEditorPopover.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="phx-default-entry-editor-popover">
<ng-template [ngIf]="!isEntryEmpty() && hasEntryEditors()">
<div *ngFor="let entryModel of getEntryEditors(); let i = index;" class="textbox-container">
<material-text-box [label]="entryModel.label" [description]="entryModel.description" [data]="getDataContainer()" [field]="entryModel.field" [dataParent]="this" [formatterName]="entryModel.formatterName"></material-text-box>
</div>
</ng-template>
</div>
`
},] },
];
/** @nocollapse */
DefaultEntryEditorPopover.ctorParameters = () => [
{ type: ElementRef, },
];
DefaultEntryEditorPopover.propDecorators = {
"editor": [{ type: Input },],
"entryMapper": [{ type: Input },],
"data": [{ type: Input },],
"dataParent": [{ type: Input },],
"ignoreParentData": [{ type: Input },],
"ignoreParentDisabled": [{ type: Input },],
"delegateHistory": [{ type: Input },],
"onDisabled": [{ type: Input },],
"onEnabled": [{ type: Input },],
"loadingEnabled": [{ type: Input },],
"i18nKey": [{ type: Input },],
"bypass": [{ type: Input, args: ['i18nBypass',] },],
"options": [{ type: Input },],
};
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", AbstractDataEditor)
], DefaultEntryEditorPopover.prototype, "editor", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], DefaultEntryEditorPopover.prototype, "entryMapper", void 0);
function DefaultEntryEditorPopover_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
DefaultEntryEditorPopover.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
DefaultEntryEditorPopover.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
DefaultEntryEditorPopover.propDecorators;
/** @type {?} */
DefaultEntryEditorPopover.TYPE_NAME;
/** @type {?} */
DefaultEntryEditorPopover.prototype.editor;
/** @type {?} */
DefaultEntryEditorPopover.prototype.dataContainer;
/** @type {?} */
DefaultEntryEditorPopover.prototype.entryMapper;
/** @type {?} */
DefaultEntryEditorPopover.prototype.entry;
/** @type {?} */
DefaultEntryEditorPopover.prototype.titleTFHandler;
/** @type {?} */
DefaultEntryEditorPopover.prototype.entryEditors;
/** @type {?} */
DefaultEntryEditorPopover.prototype.data;
/** @type {?} */
DefaultEntryEditorPopover.prototype.dataParent;
/** @type {?} */
DefaultEntryEditorPopover.prototype.ignoreParentData;
/** @type {?} */
DefaultEntryEditorPopover.prototype.ignoreParentDisabled;
/** @type {?} */
DefaultEntryEditorPopover.prototype.delegateHistory;
/** @type {?} */
DefaultEntryEditorPopover.prototype.onDisabled;
/** @type {?} */
DefaultEntryEditorPopover.prototype.onEnabled;
/** @type {?} */
DefaultEntryEditorPopover.prototype.loadingEnabled;
/** @type {?} */
DefaultEntryEditorPopover.prototype.i18nKey;
/** @type {?} */
DefaultEntryEditorPopover.prototype.bypass;
/** @type {?} */
DefaultEntryEditorPopover.prototype.options;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DefaultEntryEditorPopover.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/DefaultEntryEditorPopover.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Type, ViewChild, ElementRef } from '@angular/core';\nimport { AbstractHasData } from '../AbstractHasData';\nimport { CalendarEntry } from '../model/CalendarEntry';\nimport { ICalendarEntryMapper } from './ICalendarEntryMapper';\nimport { MaterialTextBox } from '../../theme/material/component/dataview/input/MaterialTextBox.component';\nimport { ICalendarEntryPopoverContent } from './ICalendarEntryPopoverContent';\nimport { AbstractDataEditor } from './AbstractDataEditor';\nimport { IHasData } from '../IHasData';\nimport { EntryEditorModel } from '../model/EntryEditorModel';\nimport { Option } from '../../decorator/Option.decorator';\nimport { DateTimeUtils } from '../../share/utils/DateTimeUtils';\nimport { DateFormatter } from '../../share/formatter/formatters';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-default-entry-editor-popover\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-default-entry-editor-popover\">\n\t<ng-template [ngIf]=\"!isEntryEmpty() && hasEntryEditors()\">\n\t\t<div *ngFor=\"let entryModel of getEntryEditors(); let i = index;\" class=\"textbox-container\">\n\t\t\t<material-text-box [label]=\"entryModel.label\" [description]=\"entryModel.description\" [data]=\"getDataContainer()\" [field]=\"entryModel.field\" [dataParent]=\"this\" [formatterName]=\"entryModel.formatterName\"></material-text-box>\n\t\t</div>\n\t</ng-template>\n</div>\n`\n})\nexport class DefaultEntryEditorPopover extends AbstractHasData implements OnInit, ICalendarEntryPopoverContent {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  @Option()\n  private editor: AbstractDataEditor;\n  private dataContainer: any[];\n  @Input()\n  @Option()\n  private entryMapper: ICalendarEntryMapper;\n  private entry: CalendarEntry;\n  private titleTFHandler: Function;\n  private entryEditors: EntryEditorModel[];\n  @Input()\n  protected data: any;\n  @Input()\n  protected dataParent: IHasData;\n  @Input()\n  protected ignoreParentData: boolean;\n  @Input()\n  protected ignoreParentDisabled: boolean;\n  @Input()\n  protected delegateHistory: boolean;\n  @Input()\n  protected onDisabled: Function;\n  @Input()\n  protected onEnabled: Function;\n  @Input()\n  protected loadingEnabled: boolean;\n  @Input()\n  protected i18nKey: string;\n  @Input('i18nBypass')\n  protected bypass: boolean;\n  @Input()\n  protected options: any;\n\n  constructor(elementRef: ElementRef) {\n    super(elementRef);\n\n    this.dataContainer = [];\n    this.entryEditors = [];\n    this.entryEditors.push(new EntryEditorModel('Title', \"title\", null));\n    this.entryEditors.push(new EntryEditorModel('StartTime', \"startDateTime\", null, null));\n    this.entryEditors.push(new EntryEditorModel('EndTime', \"endDateTime\", null, null));\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    this.setData(this.data);\n  }\n\n  /* use for save by editor\n  public onSaveData(): void {\n    if (this.editor !== null && typeof this.editor !== 'undefined') {\n      if (this.entryMapper !== null && typeof this.entryMapper !== 'undefined') {\n        let startTime: any = this.entry.startDateTime;\n        let endTime: any = this.entry.endDateTime;\n        if (startTime !== null && typeof startTime !== 'undefined') {\n          startTime = DateTimeUtils.getDateFromAny(startTime);\n          this.entry.startDateTime = startTime;\n        }\n        if (endTime !== null && typeof endTime !== 'undefined') {\n          endTime = DateTimeUtils.getDateFromAny(endTime);\n          this.entry.endDateTime = endTime;\n        }\n        this.entryMapper.updateData(this.data, this.entry);\n      }\n      this.editor.updateData(this.data);\n    }\n  }*/\n\n  public isEntryEmpty(): boolean {\n    return (this.entry === null || typeof this.entry === 'undefined') ? true : false;\n  }\n\n  public getCalendarEntry(): CalendarEntry {\n    if (this.entryMapper !== null && typeof this.entryMapper !== 'undefined') {\n      return this.entryMapper.getCalendarEntry(this.data);\n    }\n    return null;\n  }\n\n  public setData(data: any): void {\n    // overide method\n    this.data = data;\n\n    this.entry = this.getCalendarEntry();\n    this.dataContainer = [];\n    if (this.entry !== null && typeof this.entry !== 'undefined') {\n      this.dataContainer.push(this.entry);\n    }\n\n    // child add entry instead\n    if (this.dataChildren !== null) {\n      for (let c of this.dataChildren) {\n        c.setData(this.dataContainer);\n      }\n    }\n  }\n\n  public setCalendarEntryMapper(entryMapper: ICalendarEntryMapper): void {\n    this.entryMapper = entryMapper;\n\n    this.setData(this.data);\n  }\n\n  public setEditor(editor: AbstractDataEditor): void {\n    this.editor = editor;\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 getDataContainer(): any[] {\n    return this.dataContainer;\n  }\n\n  public hasEntryEditors(): boolean {\n    if(this.entryEditors !== null && this.entryEditors !== undefined){\n      return true;\n    }\n\n    return false;\n  }\n\n  public getEntryEditors(): EntryEditorModel[] {\n    return this.entryEditors;\n  }\n\n  public onPopoverClosed($event: Event): void {\n  }\n\n  public onAutoSaved($event: Event): void {\n    if (this.entryMapper !== null && typeof this.entryMapper !== 'undefined') {\n      let startTime: any = this.entry.startDateTime;\n      let endTime: any = this.entry.endDateTime;\n\n      if (startTime !== null && typeof startTime !== 'undefined') {\n        startTime = DateTimeUtils.getDateFromAny(startTime);\n        this.entry.startDateTime = startTime;\n      }\n\n      if (endTime !== null && typeof endTime !== 'undefined') {\n        endTime = DateTimeUtils.getDateFromAny(endTime);\n        this.entry.endDateTime = endTime;\n      }\n\n      this.entryMapper.updateData(this.data, this.entry);\n    }\n  }\n\n  public isAutoSave(): boolean {\n  \treturn true;\n  }\n}\n"]}