UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

276 lines (275 loc) 24.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, Inject, EventEmitter, Output, ViewChild } from '@angular/core'; import { AbstractDataEditor } from './AbstractDataEditor'; import { DataEditorActionProvider } from './IDataEditorActionProvider'; import { DataEditorViewProvider } from './IDataEditorViewProvider'; import { DataServiceFactory } from './IDataServiceFactory'; import { EditorSettingServiceFactory } from './IEditorSettingServiceFactory'; import { PhloxAppInfoService } from '../../service/PhloxAppInfoService.service'; import { DialogService } from '../../service/DialogService.service'; import { BackgroundProcessManager } from '../../service/BackgroundProcessManager.service'; import { Option } from '../../decorator/Option.decorator'; import { I18N } from '../../decorator/decorators'; import { ActionMenuBar } from './editor.internal/ActionMenuBar.component'; var /** @type {?} */ TYPE_NAME = "phx-default-data-editor"; var DefaultDataEditor = /** @class */ (function (_super) { tslib_1.__extends(DefaultDataEditor, _super); function DefaultDataEditor(actionProvider, viewProvider, dataFactory, settingServiceFactory, phloxAppService, dialogService, bgProcessMgr) { return _super.call(this, actionProvider, viewProvider, dataFactory, settingServiceFactory, phloxAppService, dialogService, bgProcessMgr) || this; } /** * @param {?} model * @return {?} */ DefaultDataEditor.prototype._isViewModelActive = /** * @param {?} model * @return {?} */ function (model) { if (model === null || typeof model === 'undefined') { return false; } try { for (var _a = tslib_1.__values(this.views), _b = _a.next(); !_b.done; _b = _a.next()) { var v = _b.value; if (v.getModel() === model) { return v.isActive(); } } } 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; } } return false; var e_1, _c; }; /** * @param {?} headerTitle * @return {?} */ DefaultDataEditor.prototype.setHeaderTitle = /** * @param {?} headerTitle * @return {?} */ function (headerTitle) { this.headerTitle = headerTitle; }; /** * @return {?} */ DefaultDataEditor.prototype.getHeaderTitle = /** * @return {?} */ function () { return this.headerTitle; }; /** * @param {?} $event * @param {?} view * @return {?} */ DefaultDataEditor.prototype.onViewBtnClicked = /** * @param {?} $event * @param {?} view * @return {?} */ function ($event, view) { this.showView(view); }; /** * @return {?} */ DefaultDataEditor.prototype.getMenuModelFactory = /** * @return {?} */ function () { return this.menuModelFactory; }; /** * @return {?} */ DefaultDataEditor.prototype.getDataComparator = /** * @return {?} */ function () { return this.dataComparator; }; /** * @return {?} */ DefaultDataEditor.prototype.isPageLoaded = /** * @return {?} */ function () { return true; }; /** * @return {?} */ DefaultDataEditor.prototype.newDataObject = /** * @return {?} */ function () { return { "name": "TEST Name", "title": "TEST VALUE", "description": "TEST description", "startDate": (new Date()).getTime(), "endDate": (new Date()).getTime() }; }; /** * @param {?} actionModels * @return {?} */ DefaultDataEditor.prototype.setActionModels = /** * @param {?} actionModels * @return {?} */ function (actionModels) { _super.prototype.setActionModels.call(this, actionModels); this.actionMenuBar.setModels(actionModels); }; /** * @param {?} settings * @return {?} */ DefaultDataEditor.prototype.onEditorSettingLoaded = /** * @param {?} settings * @return {?} */ function (settings) { // do sthing when reload editor setting }; DefaultDataEditor.TYPE_NAME = TYPE_NAME; DefaultDataEditor.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: "<div class=\"phx-default-data-editor\">\n\t<div class=\"background\">\n\t</div>\n\t<div class=\"wrapper\">\n\t\t<div class=\"content\">\n\t\t\t<!-- # this will open in the next version -->\n\t\t\t<!-- <phx-search-btn [editor]=\"this\"></phx-search-btn> -->\n\t\t\t<div class=\"phlox-editor-header\">\n\t\t\t\t<div class=\"page-info-wrapper\">\n\t\t\t\t\t<phx-search-btn [editor]=\"this\"></phx-search-btn>\n\t\t\t\t\t<div class=\"page-info\">\n\t\t\t\t\t\t{{getHeaderTitle()}}\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"page-search\">\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"page-header-center\">\n\t\t\t\t\t<div class=\"page-action-wrapper\">\n\t\t\t\t\t\t<ul class=\"page-action\">\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<ul class=\"action-button-group\">\n\t\t\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t\t\t<phx-action-menu-bar #actionMenuBar></phx-action-menu-bar>\n\t\t\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t\t\t</ul>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<div class=\"page-separate\"></div>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t</ul>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"page-view-wrapper\">\n\t\t\t\t\t<ul class=\"view-button-group\">\n\t\t\t\t\t\t<li *ngFor=\"let view of getViewModels(); let i = index;\">\n\t\t\t\t\t\t\t<phx-view-btn #phxView [model]=\"view\" [active]=\"_isViewModelActive(view)\" (click)=\"onViewBtnClicked($event,view)\"></phx-view-btn>\n\t\t\t\t\t\t</li>\n\t\t\t\t\t</ul>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div class=\"phlox-editor-body\">\n\t\t\t\t\t<phx-view-wrapper *ngFor=\"let view of getViewModels()\" [editor]=\"this\" [model]=\"view\"\n\t\t\t\t\t[showEventHandler]=\"getViewShowHandler()\" [hideEventHandler]=\"getViewHideHandler()\"></phx-view-wrapper>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n" },] }, ]; /** @nocollapse */ DefaultDataEditor.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [DataEditorActionProvider,] },] }, { type: undefined, decorators: [{ type: Inject, args: [DataEditorViewProvider,] },] }, { type: undefined, decorators: [{ type: Inject, args: [DataServiceFactory,] },] }, { type: undefined, decorators: [{ type: Inject, args: [EditorSettingServiceFactory,] },] }, { type: PhloxAppInfoService, }, { type: DialogService, }, { type: BackgroundProcessManager, }, ]; }; DefaultDataEditor.propDecorators = { "dataCreateEvent": [{ type: Output, args: ['phxDataCreate',] },], "dataUpdateEvent": [{ type: Output, args: ['phxDataUpdate',] },], "dataDeleteEvent": [{ type: Output, args: ['phxDataDelete',] },], "dataDestroyEvent": [{ type: Output, args: ['phxDataDestroy',] },], "dataRevertEvent": [{ type: Output, args: ['phxDataRevert',] },], "dataQueryEvent": [{ type: Output, args: ['phxDataQuery',] },], "dataPromoteEvent": [{ type: Output, args: ['phxDataPromote',] },], "dataReloadEvent": [{ type: Output, args: ['phxDataReload',] },], "dataSchemaLoadEvent": [{ type: Output, args: ['phxDataSchemaLoad',] },], "viewShowEvent": [{ type: Output, args: ['phxViewShow',] },], "viewHideEvent": [{ type: Output, args: ['phxViewHide',] },], "headerTitle": [{ type: Input },], "actionMenuBar": [{ type: ViewChild, args: ["actionMenuBar",] },], }; tslib_1.__decorate([ Option('dataCreate'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataCreateEvent", void 0); tslib_1.__decorate([ Option('dataUpdate'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataUpdateEvent", void 0); tslib_1.__decorate([ Option('dataDelete'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataDeleteEvent", void 0); tslib_1.__decorate([ Option('dataDestroy'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataDestroyEvent", void 0); tslib_1.__decorate([ Option('dataRevert'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataRevertEvent", void 0); tslib_1.__decorate([ Option('dataQuery'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataQueryEvent", void 0); tslib_1.__decorate([ Option('dataPromote'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataPromoteEvent", void 0); tslib_1.__decorate([ Option('dataReload'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataReloadEvent", void 0); tslib_1.__decorate([ Option('dataSchemaLoad'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "dataSchemaLoadEvent", void 0); tslib_1.__decorate([ Option('viewShow'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "viewShowEvent", void 0); tslib_1.__decorate([ Option('viewHide'), tslib_1.__metadata("design:type", EventEmitter) ], DefaultDataEditor.prototype, "viewHideEvent", void 0); tslib_1.__decorate([ I18N("header.title"), tslib_1.__metadata("design:type", String) ], DefaultDataEditor.prototype, "headerTitle", void 0); return DefaultDataEditor; }(AbstractDataEditor)); export { DefaultDataEditor }; function DefaultDataEditor_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ DefaultDataEditor.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ DefaultDataEditor.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ DefaultDataEditor.propDecorators; /** @type {?} */ DefaultDataEditor.TYPE_NAME; /** @type {?} */ DefaultDataEditor.prototype.dataCreateEvent; /** @type {?} */ DefaultDataEditor.prototype.dataUpdateEvent; /** @type {?} */ DefaultDataEditor.prototype.dataDeleteEvent; /** @type {?} */ DefaultDataEditor.prototype.dataDestroyEvent; /** @type {?} */ DefaultDataEditor.prototype.dataRevertEvent; /** @type {?} */ DefaultDataEditor.prototype.dataQueryEvent; /** @type {?} */ DefaultDataEditor.prototype.dataPromoteEvent; /** @type {?} */ DefaultDataEditor.prototype.dataReloadEvent; /** @type {?} */ DefaultDataEditor.prototype.dataSchemaLoadEvent; /** @type {?} */ DefaultDataEditor.prototype.viewShowEvent; /** @type {?} */ DefaultDataEditor.prototype.viewHideEvent; /** @type {?} */ DefaultDataEditor.prototype.headerTitle; /** @type {?} */ DefaultDataEditor.prototype.actionMenuBar; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DefaultDataEditor.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/DefaultDataEditor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, Inject, EventEmitter, Output, ViewChild } from '@angular/core';\nimport { AbstractDataEditor } from './AbstractDataEditor';\nimport { DataEditorActionProvider, IDataEditorActionProvider } from './IDataEditorActionProvider';\nimport { DataEditorViewProvider, IDataEditorViewProvider } from './IDataEditorViewProvider';\nimport { DataServiceFactory, IDataServiceFactory } from './IDataServiceFactory';\nimport { EditorSettingServiceFactory, IEditorSettingServiceFactory } from './IEditorSettingServiceFactory';\nimport { IMenuModelFactory } from '../IMenuModelFactory';\nimport { IDataComparator } from '../IDataComparator';\nimport { PhloxAppInfoService } from '../../service/PhloxAppInfoService.service';\nimport { DialogService } from '../../service/DialogService.service';\nimport { BackgroundProcessManager } from '../../service/BackgroundProcessManager.service';\nimport { ViewModel } from '../model/ViewModel';\nimport { Option } from '../../decorator/Option.decorator';\nimport { I18N } from '../../decorator/decorators';\nimport { ViewButton } from './editor.internal/ViewButton.component';\nimport { ActionMenuBar } from './editor.internal/ActionMenuBar.component';\nimport { ActionModel } from '../model/ActionModel';\n\nconst TYPE_NAME: string = \"phx-default-data-editor\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-default-data-editor\">\n\t<div class=\"background\">\n\t</div>\n\t<div class=\"wrapper\">\n\t\t<div class=\"content\">\n\t\t\t<!-- # this will open in the next version  -->\n\t\t\t<!-- <phx-search-btn [editor]=\"this\"></phx-search-btn> -->\n\t\t\t<div class=\"phlox-editor-header\">\n\t\t\t\t<div class=\"page-info-wrapper\">\n\t\t\t\t\t<phx-search-btn [editor]=\"this\"></phx-search-btn>\n\t\t\t\t\t<div class=\"page-info\">\n\t\t\t\t\t\t{{getHeaderTitle()}}\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"page-search\">\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"page-header-center\">\n\t\t\t\t\t<div class=\"page-action-wrapper\">\n\t\t\t\t\t\t<ul class=\"page-action\">\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<ul class=\"action-button-group\">\n\t\t\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t\t\t<phx-action-menu-bar #actionMenuBar></phx-action-menu-bar>\n\t\t\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t\t\t</ul>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t\t<li>\n\t\t\t\t\t\t\t\t<div class=\"page-separate\"></div>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t</ul>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"page-view-wrapper\">\n\t\t\t\t\t<ul class=\"view-button-group\">\n\t\t\t\t\t\t<li *ngFor=\"let view of getViewModels(); let i = index;\">\n\t\t\t\t\t\t\t<phx-view-btn #phxView [model]=\"view\" [active]=\"_isViewModelActive(view)\" (click)=\"onViewBtnClicked($event,view)\"></phx-view-btn>\n\t\t\t\t\t\t</li>\n\t\t\t\t\t</ul>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div class=\"phlox-editor-body\">\n\t\t\t\t\t<phx-view-wrapper *ngFor=\"let view of getViewModels()\" [editor]=\"this\" [model]=\"view\"\n\t\t\t\t\t[showEventHandler]=\"getViewShowHandler()\" [hideEventHandler]=\"getViewHideHandler()\"></phx-view-wrapper>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n`\n})\nexport class DefaultDataEditor extends AbstractDataEditor {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Output('phxDataCreate')\n  @Option('dataCreate')\n  protected dataCreateEvent: EventEmitter<any>;\n  @Output('phxDataUpdate')\n  @Option('dataUpdate')\n  protected dataUpdateEvent: EventEmitter<any>;\n  @Output('phxDataDelete')\n  @Option('dataDelete')\n  protected dataDeleteEvent: EventEmitter<any>;\n  @Output('phxDataDestroy')\n  @Option('dataDestroy')\n  protected dataDestroyEvent: EventEmitter<any>;\n  @Output('phxDataRevert')\n  @Option('dataRevert')\n  protected dataRevertEvent: EventEmitter<any>;\n  @Output('phxDataQuery')\n  @Option('dataQuery')\n  protected dataQueryEvent: EventEmitter<any>;\n  @Output('phxDataPromote')\n  @Option('dataPromote')\n  protected dataPromoteEvent: EventEmitter<any>;\n  @Output('phxDataReload')\n  @Option('dataReload')\n  protected dataReloadEvent: EventEmitter<any>;\n  @Output('phxDataSchemaLoad')\n  @Option('dataSchemaLoad')\n  protected dataSchemaLoadEvent: EventEmitter<any>;\n  @Output('phxViewShow')\n  @Option('viewShow')\n  protected viewShowEvent: EventEmitter<any>;\n  @Output('phxViewHide')\n  @Option('viewHide')\n  protected viewHideEvent: EventEmitter<any>;\n  @Input()\n  @I18N(\"header.title\")\n  private headerTitle: string;\n  @ViewChild(\"actionMenuBar\")\n  private actionMenuBar: ActionMenuBar;\n\n  constructor( @Inject(DataEditorActionProvider) actionProvider: IDataEditorActionProvider, @Inject(DataEditorViewProvider) viewProvider: IDataEditorViewProvider, @Inject(DataServiceFactory) dataFactory: IDataServiceFactory,\n    @Inject(EditorSettingServiceFactory) settingServiceFactory: IEditorSettingServiceFactory, phloxAppService: PhloxAppInfoService, dialogService: DialogService,\n    bgProcessMgr: BackgroundProcessManager) {\n    super(actionProvider, viewProvider, dataFactory, settingServiceFactory, phloxAppService, dialogService, bgProcessMgr);\n  }\n\n  public _isViewModelActive(model: ViewModel): boolean {\n    if (model === null || typeof model === 'undefined') {\n      return false;\n    }\n    for (let v of this.views) {\n      if (v.getModel() === model) {\n        return v.isActive();\n      }\n    }\n    return false;\n  }\n\n  public setHeaderTitle(headerTitle: string): void {\n    this.headerTitle = headerTitle;\n  }\n\n  public getHeaderTitle(): string {\n    return this.headerTitle;\n  }\n\n  public onViewBtnClicked($event: MouseEvent, view: ViewModel): void {\n    this.showView(view);\n  }\n\n  public getMenuModelFactory(): IMenuModelFactory {\n    return this.menuModelFactory;\n  }\n\n  public getDataComparator(): IDataComparator<any> {\n    return this.dataComparator;\n  }\n\n  public isPageLoaded(): boolean {\n    return true;\n  }\n  \n  public newDataObject(): any {\n    return {\n      \"name\": \"TEST Name\",\n      \"title\": \"TEST VALUE\",\n      \"description\": \"TEST description\",\n      \"startDate\": (new Date()).getTime(),\n      \"endDate\": (new Date()).getTime()\n    };\n  }\n\n  public setActionModels(actionModels: ActionModel[]): void {\n    super.setActionModels(actionModels);\n\n    this.actionMenuBar.setModels(actionModels);\n  }\n\n  protected onEditorSettingLoaded(settings: any): void {\n    // do sthing when reload editor setting\n  }\n}\n"]}