UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

285 lines (283 loc) 22.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'; const /** @type {?} */ TYPE_NAME = "phx-default-data-editor"; export class DefaultDataEditor extends AbstractDataEditor { /** * @param {?} actionProvider * @param {?} viewProvider * @param {?} dataFactory * @param {?} settingServiceFactory * @param {?} phloxAppService * @param {?} dialogService * @param {?} bgProcessMgr */ constructor(actionProvider, viewProvider, dataFactory, settingServiceFactory, phloxAppService, dialogService, bgProcessMgr) { super(actionProvider, viewProvider, dataFactory, settingServiceFactory, phloxAppService, dialogService, bgProcessMgr); } /** * @param {?} model * @return {?} */ _isViewModelActive(model) { if (model === null || typeof model === 'undefined') { return false; } for (let /** @type {?} */ v of this.views) { if (v.getModel() === model) { return v.isActive(); } } return false; } /** * @param {?} headerTitle * @return {?} */ setHeaderTitle(headerTitle) { this.headerTitle = headerTitle; } /** * @return {?} */ getHeaderTitle() { return this.headerTitle; } /** * @param {?} $event * @param {?} view * @return {?} */ onViewBtnClicked($event, view) { this.showView(view); } /** * @return {?} */ getMenuModelFactory() { return this.menuModelFactory; } /** * @return {?} */ getDataComparator() { return this.dataComparator; } /** * @return {?} */ isPageLoaded() { return true; } /** * @return {?} */ newDataObject() { return { "name": "TEST Name", "title": "TEST VALUE", "description": "TEST description", "startDate": (new Date()).getTime(), "endDate": (new Date()).getTime() }; } /** * @param {?} actionModels * @return {?} */ setActionModels(actionModels) { super.setActionModels(actionModels); this.actionMenuBar.setModels(actionModels); } /** * @param {?} settings * @return {?} */ onEditorSettingLoaded(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"> <div class="background"> </div> <div class="wrapper"> <div class="content"> <!-- # this will open in the next version --> <!-- <phx-search-btn [editor]="this"></phx-search-btn> --> <div class="phlox-editor-header"> <div class="page-info-wrapper"> <phx-search-btn [editor]="this"></phx-search-btn> <div class="page-info"> {{getHeaderTitle()}} </div> <div class="page-search"> </div> </div> <div class="page-header-center"> <div class="page-action-wrapper"> <ul class="page-action"> <li> <ul class="action-button-group"> <li> <phx-action-menu-bar #actionMenuBar></phx-action-menu-bar> </li> </ul> </li> <li> <div class="page-separate"></div> </li> </ul> </div> </div> <div class="page-view-wrapper"> <ul class="view-button-group"> <li *ngFor="let view of getViewModels(); let i = index;"> <phx-view-btn #phxView [model]="view" [active]="_isViewModelActive(view)" (click)="onViewBtnClicked($event,view)"></phx-view-btn> </li> </ul> </div> </div> <div class="wrapper"> <div class="phlox-editor-body"> <phx-view-wrapper *ngFor="let view of getViewModels()" [editor]="this" [model]="view" [showEventHandler]="getViewShowHandler()" [hideEventHandler]="getViewHideHandler()"></phx-view-wrapper> </div> </div> </div> </div> </div> ` },] }, ]; /** @nocollapse */ DefaultDataEditor.ctorParameters = () => [ { 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); 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"]}