com.phloxui
Version:
PhloxUI Ng2+ Framework
285 lines (283 loc) • 22.8 kB
JavaScript
/**
* @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"]}