com.phloxui
Version:
PhloxUI Ng2+ Framework
276 lines (275 loc) • 24.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';
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"]}