UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

466 lines (465 loc) 37.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, ViewChild, ElementRef } from '@angular/core'; import { AbstractHasDataHelp } from '../AbstractHasDataHelp'; import { AbstractDataEditor } from './AbstractDataEditor'; import { DefaultEntryEditorPopover } from './DefaultEntryEditorPopover.component'; import { EllipsisButton } from '../../component/EllipsisButton.component'; import { Option } from '../../decorator/Option.decorator'; var /** @type {?} */ TYPE_NAME = "phx-default-calendar-entry-list-popover"; var DefaultCalendarEntryListPopover = /** @class */ (function (_super) { tslib_1.__extends(DefaultCalendarEntryListPopover, _super); function DefaultCalendarEntryListPopover(elementRef) { var _this = _super.call(this, elementRef) || this; _this.entryList = []; _this.showList = true; _this.autoFocusMoreMenu = false; _this.editorType = DefaultEntryEditorPopover; _this.selectedHeaderTitle = ""; _this.selectedData = null; return _this; } /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; _super.prototype.ngOnInit.call(this); if (this.editor !== null && typeof this.editor !== 'undefined') { this.menuFactory = this.editor.getMenuModelFactory(); } this.componentHandler = function (result) { var /** @type {?} */ comInstance = null; if (result !== null && typeof result !== 'undefined') { comInstance = result.instance; } if (_this.data !== null && typeof _this.data !== 'undefined' && comInstance !== null) { if (typeof comInstance.setData === 'function') { comInstance.setData(_this.data); } } if (typeof comInstance.setCalendarEntryMapper === 'function') { comInstance.setCalendarEntryMapper(_this.entryMapper); } if (typeof comInstance.setEditor === 'function') { comInstance.setEditor(_this.editor); } _this.compoWrapInstance = comInstance; }; if (this.dataParent !== null && typeof this.dataParent !== 'undefined') { var /** @type {?} */ parent_1 = this.dataParent; if (typeof parent_1.getHideEvent === 'function') { var /** @type {?} */ hideEvent = parent_1.getHideEvent(); if (hideEvent !== null && (typeof hideEvent !== 'undefined')) { hideEvent.subscribe(function (event) { _this.showList = true; // hide more menu if (_this.ellipsisButton !== null && typeof _this.ellipsisButton !== 'undefined') { _this.ellipsisButton.hideMenu(); } }); } } } }; /** * @param {?} data * @return {?} */ DefaultCalendarEntryListPopover.prototype.getCalendarEntry = /** * @param {?} data * @return {?} */ function (data) { if (this.entryMapper !== null && typeof this.entryMapper !== 'undefined') { return this.entryMapper.getCalendarEntry(data); } return null; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.reloadEntryList = /** * @return {?} */ function () { this.entryList = []; if (this.data !== null && typeof this.data !== 'undefined') { if (Array.isArray(this.data)) { try { for (var _a = tslib_1.__values(this.data), _b = _a.next(); !_b.done; _b = _a.next()) { var d = _b.value; this.entryList.push(this.getCalendarEntry(d)); } } 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; } } } else { this.entryList.push(this.getCalendarEntry(this.data)); } } var e_1, _c; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype._getEntryListSize = /** * @return {?} */ function () { if (this.entryList !== null && typeof this.entryList !== 'undefined') { return this.entryList.length; } return 0; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype._getEntryList = /** * @return {?} */ function () { return this.entryList; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype._isAutoFocusMoreMenu = /** * @return {?} */ function () { return this.autoFocusMoreMenu; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype._getComponentHandler = /** * @return {?} */ function () { return this.componentHandler; }; /** * @param {?} $event * @param {?} index * @return {?} */ DefaultCalendarEntryListPopover.prototype.onItemClicked = /** * @param {?} $event * @param {?} index * @return {?} */ function ($event, index) { this.showList = false; this.selectedHeaderTitle = ""; this.selectedData = null; if (this.compoWrapInstance !== null && typeof this.compoWrapInstance !== 'undefined') { if (typeof this.compoWrapInstance.setData === 'function') { var /** @type {?} */ data = null; if (this.data !== null && typeof this.data !== 'undefined') { if (Array.isArray(this.data)) { if (index < this.data.length) { data = this.data[index]; } } else { data = this.data; } } if (index < this.entryList.length) { var /** @type {?} */ entry = this.entryList[index]; this.selectedHeaderTitle = entry.title; } this.selectedData = data; this.compoWrapInstance.setData(data); } } }; /** * @param {?} $event * @return {?} */ DefaultCalendarEntryListPopover.prototype.onBackToList = /** * @param {?} $event * @return {?} */ function ($event) { this.showList = true; if (this.ellipsisButton !== null && typeof this.ellipsisButton !== 'undefined') { this.ellipsisButton.hideMenu(); } }; /** * @param {?} data * @return {?} */ DefaultCalendarEntryListPopover.prototype.setData = /** * @param {?} data * @return {?} */ function (data) { _super.prototype.setData.call(this, data); this.reloadEntryList(); }; /** * @param {?} entryMapper * @return {?} */ DefaultCalendarEntryListPopover.prototype.setCalendarEntryMapper = /** * @param {?} entryMapper * @return {?} */ function (entryMapper) { this.entryMapper = entryMapper; this.reloadEntryList(); }; /** * @param {?} editor * @return {?} */ DefaultCalendarEntryListPopover.prototype.setEditor = /** * @param {?} editor * @return {?} */ function (editor) { this.editor = editor; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.isSelfDataDirty = /** * @return {?} */ function () { return false; }; /** * @param {?} data * @return {?} */ DefaultCalendarEntryListPopover.prototype.selfSaveData = /** * @param {?} data * @return {?} */ function (data) { }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.selfResetData = /** * @return {?} */ function () { }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.getModel = /** * @return {?} */ function () { return this.model; }; /** * @param {?} model * @return {?} */ DefaultCalendarEntryListPopover.prototype.setModel = /** * @param {?} model * @return {?} */ function (model) { this.model = model; if (this.model !== null && typeof this.model !== 'undefined') { this.editorType = this.model.type; } if (this.editorType === null || typeof this.editorType === 'undefined') { this.editorType = DefaultEntryEditorPopover; } }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.isShowList = /** * @return {?} */ function () { return this.showList; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.getSelectedHeaderTitle = /** * @return {?} */ function () { return this.selectedHeaderTitle; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.getMenuModelFactory = /** * @return {?} */ function () { return this.menuFactory; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.getSelectedData = /** * @return {?} */ function () { return this.selectedData; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.getEditorType = /** * @return {?} */ function () { return this.editorType; }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.doPreload = /** * @return {?} */ function () { return new Promise(function (resolve, reject) { resolve(null); }); }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.doLoaded = /** * @return {?} */ function () { }; /** * @param {?} $event * @return {?} */ DefaultCalendarEntryListPopover.prototype.onPopoverClosed = /** * @param {?} $event * @return {?} */ function ($event) { }; /** * @param {?} $event * @return {?} */ DefaultCalendarEntryListPopover.prototype.onAutoSaved = /** * @param {?} $event * @return {?} */ function ($event) { }; /** * @return {?} */ DefaultCalendarEntryListPopover.prototype.isAutoSave = /** * @return {?} */ function () { return false; }; DefaultCalendarEntryListPopover.TYPE_NAME = TYPE_NAME; DefaultCalendarEntryListPopover.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: "<div class=\"phx-default-calendar-entry-list-popover\">\n\t<div class=\"header\">\n\t\t<div class=\"left\" [class.show]=\"!isShowList()\"\n\t\t\t(click)=\"onBackToList($event)\">\n\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t<div class=\"table-cell-wrapper middle\"><div class=\"left-angle\"></div></div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"right\" [class.expand]=\"isShowList()\">\n\t\t\t<div class=\"info\">\n\t\t\t\t<div [class.expand]=\"!isShowList()\">\n\t\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t\t{{isShowList() ? getModel().title : getSelectedHeaderTitle()}}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t{{isShowList() ? _getEntryListSize() + 'items' : ''}}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t<div class=\"more\">\n\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\"><phx-ellipsis-btn #ellipsisButton [menuFactory]=\"getMenuModelFactory()\" [data]=\"getSelectedData()\"></phx-ellipsis-btn></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=\"list\" [class.show]=\"isShowList()\">\n\t\t\t<ng-template ngFor let-item [ngForOf]=\"_getEntryList()\" let-i=\"index\">\n\t\t\t\t<div class=\"row\" (click)=\"onItemClicked($event, i)\">\n\t\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t\t<div class=\"left\">{{item.title}}</div>\n\t\t\t\t\t\t\t<div class=\"right\"> > </div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t</div>\n\t\t<div class=\"form\" [class.show]=\"!isShowList()\">\n\t\t\t<phx-component-wrapper [type]=\"getEditorType()\" [handler]=\"_getComponentHandler()\" [dataParent]=\"this\"></phx-component-wrapper>\n\t\t</div>\n\t</div>\n</div>\n" },] }, ]; /** @nocollapse */ DefaultCalendarEntryListPopover.ctorParameters = function () { return [ { type: ElementRef, }, ]; }; DefaultCalendarEntryListPopover.propDecorators = { "data": [{ type: Input },], "entryMapper": [{ type: Input },], "editor": [{ type: Input },], "model": [{ type: Input },], "menuFactory": [{ type: Input },], "ellipsisButton": [{ type: ViewChild, args: ['ellipsisButton',] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], DefaultCalendarEntryListPopover.prototype, "data", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], DefaultCalendarEntryListPopover.prototype, "entryMapper", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", AbstractDataEditor) ], DefaultCalendarEntryListPopover.prototype, "editor", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], DefaultCalendarEntryListPopover.prototype, "model", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], DefaultCalendarEntryListPopover.prototype, "menuFactory", void 0); return DefaultCalendarEntryListPopover; }(AbstractHasDataHelp)); export { DefaultCalendarEntryListPopover }; function DefaultCalendarEntryListPopover_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ DefaultCalendarEntryListPopover.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ DefaultCalendarEntryListPopover.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ DefaultCalendarEntryListPopover.propDecorators; /** @type {?} */ DefaultCalendarEntryListPopover.TYPE_NAME; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.data; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.entryMapper; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.editor; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.model; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.menuFactory; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.ellipsisButton; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.entryList; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.showList; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.editorType; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.componentHandler; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.compoWrapInstance; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.selectedHeaderTitle; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.selectedData; /** @type {?} */ DefaultCalendarEntryListPopover.prototype.autoFocusMoreMenu; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DefaultCalendarEntryListPopover.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/DefaultCalendarEntryListPopover.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Type, ViewChild, ElementRef } from '@angular/core';\nimport { AbstractHasDataHelp } from '../AbstractHasDataHelp';\nimport { IHasModel } from '../IHasModel';\nimport { CalendarEntry } from '../model/CalendarEntry';\nimport { ICalendarEntryMapper } from './ICalendarEntryMapper';\nimport { ICalendarEntryPopoverContent } from './ICalendarEntryPopoverContent';\nimport { AbstractDataEditor } from './AbstractDataEditor';\nimport { DefaultEntryEditorPopover } from './DefaultEntryEditorPopover.component';\nimport { IMenuModelFactory } from '../../component/IMenuModelFactory';\nimport { EllipsisButton } from '../../component/EllipsisButton.component';\nimport { Option } from '../../decorator/Option.decorator';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-default-calendar-entry-list-popover\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-default-calendar-entry-list-popover\">\n\t<div class=\"header\">\n\t\t<div class=\"left\" [class.show]=\"!isShowList()\"\n\t\t\t(click)=\"onBackToList($event)\">\n\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t<div class=\"table-cell-wrapper middle\"><div class=\"left-angle\"></div></div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"right\" [class.expand]=\"isShowList()\">\n\t\t\t<div class=\"info\">\n\t\t\t\t<div [class.expand]=\"!isShowList()\">\n\t\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t\t{{isShowList() ? getModel().title : getSelectedHeaderTitle()}}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t{{isShowList() ? _getEntryListSize() + 'items' : ''}}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t<div class=\"more\">\n\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\"><phx-ellipsis-btn #ellipsisButton [menuFactory]=\"getMenuModelFactory()\" [data]=\"getSelectedData()\"></phx-ellipsis-btn></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=\"list\" [class.show]=\"isShowList()\">\n\t\t\t<ng-template ngFor let-item [ngForOf]=\"_getEntryList()\" let-i=\"index\">\n\t\t\t\t<div class=\"row\" (click)=\"onItemClicked($event, i)\">\n\t\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t\t<div class=\"left\">{{item.title}}</div>\n\t\t\t\t\t\t\t<div class=\"right\"> > </div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t</div>\n\t\t<div class=\"form\" [class.show]=\"!isShowList()\">\n\t\t\t<phx-component-wrapper  [type]=\"getEditorType()\" [handler]=\"_getComponentHandler()\" [dataParent]=\"this\"></phx-component-wrapper>\n\t\t</div>\n\t</div>\n</div>\n`\n})\nexport class DefaultCalendarEntryListPopover extends AbstractHasDataHelp implements OnInit, ICalendarEntryPopoverContent, IHasModel {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  @Option()\n  protected data: any;\n  @Input()\n  @Option()\n  private entryMapper: ICalendarEntryMapper;\n  @Input()\n  @Option()\n  private editor: AbstractDataEditor;\n  @Input()\n  @Option()\n  private model: any;\n  @Input()\n  @Option()\n  private menuFactory: IMenuModelFactory;\n  @ViewChild('ellipsisButton')\n  private ellipsisButton: EllipsisButton;\n  \n  private entryList: CalendarEntry[];\n  private showList: boolean;\n  private editorType: Type<any>;\n  private componentHandler: Function;\n  private compoWrapInstance: any;\n  private selectedHeaderTitle: string;\n  private selectedData: any;\n  private autoFocusMoreMenu: boolean;\n\n  constructor(elementRef: ElementRef) {\n    super(elementRef);\n    this.entryList = [];\n    this.showList = true;\n    this.autoFocusMoreMenu = false;\n    this.editorType = DefaultEntryEditorPopover;\n    this.selectedHeaderTitle = \"\";\n    this.selectedData = null;\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    if (this.editor !== null && typeof this.editor !== 'undefined') {\n      this.menuFactory = this.editor.getMenuModelFactory();\n    }\n\n    this.componentHandler = (result: any) => {\n      let comInstance = null;\n      if (result !== null && typeof result !== 'undefined') {\n        comInstance = result.instance;\n      }\n      if (this.data !== null && typeof this.data !== 'undefined' && comInstance !== null) {\n        if (typeof comInstance.setData === 'function') {\n          comInstance.setData(this.data);\n        }\n      }\n      if (typeof comInstance.setCalendarEntryMapper === 'function') {\n        comInstance.setCalendarEntryMapper(this.entryMapper);\n      }\n      if (typeof comInstance.setEditor === 'function') {\n        comInstance.setEditor(this.editor);\n      }\n      this.compoWrapInstance = comInstance;\n    };\n\n    if (this.dataParent !== null && typeof this.dataParent !== 'undefined') {\n      let parent: any = this.dataParent;\n      if (typeof parent.getHideEvent === 'function') {\n        let hideEvent = parent.getHideEvent();\n\n        if (hideEvent !== null && (typeof hideEvent !== 'undefined')) {\n          hideEvent.subscribe((event: any) => {\n            this.showList = true;\n            // hide more menu\n            if (this.ellipsisButton !== null && typeof this.ellipsisButton !== 'undefined') {\n              this.ellipsisButton.hideMenu();\n            }\n          });\n        }\n      }\n    }\n  }\n\n  private getCalendarEntry(data: any): CalendarEntry {\n    if (this.entryMapper !== null && typeof this.entryMapper !== 'undefined') {\n      return this.entryMapper.getCalendarEntry(data);\n    }\n    return null;\n  }\n\n  private reloadEntryList(): void {\n    this.entryList = [];\n    if (this.data !== null && typeof this.data !== 'undefined') {\n      if (Array.isArray(this.data)) {\n        for (let d of this.data) {\n          this.entryList.push(this.getCalendarEntry(d));\n        }\n      } else {\n        this.entryList.push(this.getCalendarEntry(this.data));\n      }\n    }\n  }\n\n  public _getEntryListSize(): number {\n    if (this.entryList !== null && typeof this.entryList !== 'undefined') {\n      return this.entryList.length;\n    }\n    return 0;\n  }\n\n  public _getEntryList(): CalendarEntry[] {\n    return this.entryList;\n  }\n\n  public _isAutoFocusMoreMenu(): boolean {\n    return this.autoFocusMoreMenu;\n  }\n\n  public _getComponentHandler(): Function {\n    return this.componentHandler;\n  }\n\n  public onItemClicked($event: any, index: any): void {\n    this.showList = false;\n    this.selectedHeaderTitle = \"\";\n    this.selectedData = null;\n\n    if (this.compoWrapInstance !== null && typeof this.compoWrapInstance !== 'undefined') {\n      if (typeof this.compoWrapInstance.setData === 'function') {\n        let data: any = null;\n        if (this.data !== null && typeof this.data !== 'undefined') {\n          if (Array.isArray(this.data)) {\n            if (index < this.data.length) {\n              data = this.data[index];\n            }\n          } else {\n            data = this.data;\n          }\n        }\n\n        if (index < this.entryList.length) {\n          let entry = this.entryList[index];\n          this.selectedHeaderTitle = entry.title;\n        }\n        this.selectedData = data;\n\n        this.compoWrapInstance.setData(data);\n      }\n    }\n  }\n\n  public onBackToList($event: any): void {\n    this.showList = true;\n    if (this.ellipsisButton !== null && typeof this.ellipsisButton !== 'undefined') {\n      this.ellipsisButton.hideMenu();\n    }\n  }\n\n  public setData(data: any): void {\n    super.setData(data);\n\n    this.reloadEntryList();\n  }\n\n  public setCalendarEntryMapper(entryMapper: ICalendarEntryMapper): void {\n    this.entryMapper = entryMapper;\n\n    this.reloadEntryList();\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 getModel(): any {\n    return this.model;\n  }\n\n  public setModel(model: any): void {\n    this.model = model;\n\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      this.editorType = this.model.type;\n    }\n\n    if (this.editorType === null || typeof this.editorType === 'undefined') {\n      this.editorType = DefaultEntryEditorPopover;\n    }\n  }\n\n  public isShowList(): boolean {\n    return this.showList;\n  }\n\n  public getSelectedHeaderTitle(): string {\n    return this.selectedHeaderTitle;\n  }\n\n  public getMenuModelFactory(): IMenuModelFactory {\n    return this.menuFactory;\n  }\n\n  public getSelectedData(): any {\n    return this.selectedData;\n  }\n\n  public getEditorType(): Type<any> {\n    return this.editorType;\n  }\n\n  public doPreload(): Promise<any> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  public doLoaded(): void {\n\n  }\n\n  public onPopoverClosed($event: Event): void {\n  }\n\n  public onAutoSaved($event: Event): void {\n  }\n\n  public isAutoSave(): boolean {\n  \treturn false;\n  }\n}\n"]}