import ViewEngine from './view-engine'; /** * 多数据引擎 * * @export * @class MDViewEngine * @extends {ViewEngine} */ export default class MDViewEngine extends ViewEngine { /** * 表格部件 * * @type {*} * @memberof GridViewEngine */ protected md: any; /** * 表单部件 * * @type {*} * @memberof GridViewEngine */ protected searchForm: any; /** * 属性面板 * * @protected * @type {*} * @memberof PickupGridViewEngine */ protected propertypanel: any; /** * 打开数据 * * @protected * @memberof MDViewEngine */ protected openData?: (args: any[], fullargs?: any[], params?: any, $event?: any, xData?: any) => void; /** * 新建数据 * * @protected * @memberof GridViewEngine */ protected newData?: (args: any[], fullargs?: any[], params?: any, $event?: any, xData?: any) => void; /** * Creates an instance of GridViewEngine. * @memberof GridViewEngine */ constructor() { super(); } /** * 引擎初始化 * * @param {*} [options={}] * @memberof GridViewEngine */ public init(options: any = {}): void { this.propertypanel = options.propertypanel; this.searchForm = options.searchform; this.openData = options.opendata; this.newData = options.newdata; super.init(options); } /** * 引擎加载 * * @param {*} [opts={}] * @memberof MDViewEngine */ public load(opts: any = {}, isnotify: boolean=false): void { super.load(opts); if (this.getSearchForm() && (this.isLoadDefault || isnotify)) { const tag = this.getSearchForm().name; this.setViewState2({ tag: tag, action: 'loaddraft', viewdata: this.view.viewparams }); } else if (this.getMDCtrl() && (this.isLoadDefault || isnotify)) { const tag = this.getMDCtrl().name; this.setViewState2({ tag: tag, action: 'load', viewdata: Object.assign(this.view.viewparams,opts) }); } else { this.isLoadDefault = true; } } /** * 部件事件 * * @param {string} ctrlName * @param {string} eventName * @param {*} args * @memberof GridViewEngine */ public onCtrlEvent(ctrlName: string, eventName: string, args: any): void { super.onCtrlEvent(ctrlName, eventName, args); if (Object.is(ctrlName, 'searchform')) { this.searchFormEvent(eventName, args); } } /** * 搜索表单事件 * * @param {string} eventName * @param {*} [args={}] * @memberof MDViewEngine */ public searchFormEvent(eventName: string, args: any = {}): void { if (Object.is(eventName, 'load')) { this.onSearchFormLoad(args); } if (Object.is(eventName, 'search')) { this.onSearchFormLoad(args); } } /** * 事件处理 * * @param {string} eventName * @param {any[]} args * @memberof MDViewEngine */ public MDCtrlEvent(eventName: string, args: any): void { if (Object.is(eventName, 'rowclick')) { } if (Object.is(eventName, 'rowdblclick')) { this.doEdit(args); } if (Object.is(eventName, 'selectionchange')) { this.selectionChange(args); } if (Object.is(eventName, 'load')) { this.MDCtrlLoad(args); } if (Object.is(eventName, 'beforeload')) { this.MDCtrlBeforeLoad(args) } if (Object.is(eventName, 'remove')) { this.MDCtrlRemove(args) } } /** * 搜索表单加载完成 * * @param {*} [args={}] * @memberof MDViewEngine */ public onSearchFormLoad(args: any = {}): void { if (this.getMDCtrl() && this.isLoadDefault) { const tag = this.getMDCtrl().name; this.setViewState2({ tag: tag, action: 'load', viewdata: this.view.viewparams }); } this.isLoadDefault = true; } /** * 搜索表单搜索 * * @param {*} [args={}] * @memberof MDViewEngine */ public onSearchFormSearch(args: any = {}): void { if (this.getMDCtrl() && this.isLoadDefault) { const tag = this.getMDCtrl().name; this.setViewState2({ tag: tag, action: 'load', viewdata: this.view.viewparams }); } this.isLoadDefault = true; } /** * 处理实体界面行为 * * @param {string} tag * @param {string} [actionmode] * @returns {void} * @memberof MDViewEngine */ public doSysUIAction(tag: string, actionmode?: string): void { if (Object.is(tag, 'Edit')) { this.doEdit(); return; } if (Object.is(tag, 'Remove')) { this.doRemove(); return; } if (Object.is(tag, 'SaveRow')) { this.doSaveEditRow(); return; } if (Object.is(tag, 'New')) { this.doNew(); return; } if (Object.is(tag, 'OpenRowEdit')) { this.doOpenRowEdit(); return; } if (Object.is(tag, 'CloseRowEdit')) { this.doCloseRowEdit(); return; } super.doSysUIAction(tag, actionmode); } /** * 多数据项界面_开启行编辑操作 * * @memberof MDViewEngine */ public doOpenRowEdit(): void { if (this.getMDCtrl()) { const tag = this.getMDCtrl().name; this.setViewState2({ tag: tag, action: 'openEdit', viewdata: {} }); } } /** * 多数据项界面_关闭行编辑操作 * * @memberof MDViewEngine */ public doCloseRowEdit(): void { if (this.getMDCtrl()) { const tag = this.getMDCtrl().name; this.setViewState2({ tag: tag, action: 'closeEdit', viewdata: {} }); } } /** * 多数据项界面_提交编辑数据操作 * * @memberof MDViewEngine */ public doSaveEditRow(): void { if (this.getMDCtrl()) { const tag = this.getMDCtrl().name; this.setViewState2({ tag: tag, action: 'submitEidt', viewdata: {} }); } } /** * 多数据项界面_编辑操作 * * @param {*} [params={}] * @returns {void} * @memberof MDViewEngine */ public doEdit(params: any = {}): void { // 获取要编辑的数据集合 if (params && params.srfkey) { if (this.isFunc(this.getMDCtrl().findItem)) { params = this.getMDCtrl().findItem('srfkey', params.srfkey); } const arg = { data: params }; this.onEditData(arg); return; } if (this.isFunc(this.getMDCtrl().getSelection)) { const selectedData = this.getMDCtrl().getSelection(); if (selectedData == null || selectedData.length === 0) { return; } this.onEditData({ data: selectedData[0] }); } } /** * 编辑数据 * * @param {*} arg * @memberof MDViewEngine */ public onEditData(arg: any): void { const loadParam: any = {}; const { data }: { data: any } = arg; if (this.keyPSDEField && data[this.keyPSDEField] && !Object.is(data[this.keyPSDEField], '')) { Object.assign(loadParam, { [this.keyPSDEField]: data[this.keyPSDEField] }); } if (this.openData && this.isFunc(this.openData)) { this.openData([loadParam],[data], null, null, this.getMDCtrl()); } } /** * 多数据项界面_新建操作 * * @param {*} [params={}] * @memberof MDViewEngine */ public doNew(params: any = {}): void { this.onNewData(); } /** * 新建数据 * * @returns {void} * @memberof MDViewEngine */ public onNewData(): void { let loadParam: any = {}; Object.assign(loadParam, this.view.context); this.doNewDataNormal(loadParam); } /** * 常规新建数据 * * @param {*} arg * @returns {*} * @memberof MDViewEngine */ public doNewDataNormal(arg: any): any { return this.openDataView(arg); } /** * 多数据项界面_删除操作 * * @memberof MDViewEngine */ public doRemove(): void { } public openDataView(view: any = {}): boolean { if (this.newData && this.isFunc(this.newData)) { this.newData([],[],null, null, this.getMDCtrl()); } return true; } /** * 选中变化 * * @param {any[]} args * @memberof MDViewEngine */ public selectionChange(args: any[]): void { if (this.view) { this.view.$emit('viewdataschange', args); } if (this.getPropertyPanel()) { const tag = this.getPropertyPanel().name; this.setViewState2({ tag: tag, action: 'load', viewdata: args[0] }); } const state = args.length > 0 && !Object.is(args[0].srfkey, '') ? false : true; this.calcToolbarItemState(state); if(args && args.length > 0){ this.calcToolbarItemAuthState(this.transformData(args[0])); }else{ this.calcToolbarItemAuthState(null); } } /** * 多数据部件加载完成 * * @param {any[]} args * @memberof MDViewEngine */ public MDCtrlLoad(args: any[]) { let cacheArray:Array<any> = []; if(args.length >0){ args.forEach((item:any) =>{ cacheArray.push({srfkey:item.srfkey,srfmajortext:item.srfmajortext}); }) } this.view.viewCacheData = cacheArray; this.view.initNavDataWithRoute(cacheArray); this.view.initNavDataWithTab(cacheArray,false); if (this.view) { this.view.$emit('viewload', args); } this.calcToolbarItemState(true); this.calcToolbarItemAuthState(null); } /** * 多数据部件加载之前 * * @param {*} [arg={}] * @memberof MDViewEngine */ public MDCtrlBeforeLoad(arg: any = {}): void { if (this.view.viewparams && Object.keys(this.view.viewparams).length > 0) { Object.assign(arg, this.view.viewparams); } if (this.getSearchForm()) { Object.assign(arg, this.getSearchForm().getData()); } if (this.view && this.view.$refs.searchbar) { Object.assign(arg, this.view.$refs.searchbar.getData()); } if (this.view) { // 开启自定义面板时忽略是否展开搜索表单 if (this.view.layoutModelDetails) { const quickSearchBar = Object.values(this.view.layoutModelDetails).find((item: any) => item.name.toLowerCase() === 'quicksearchbar'); if (quickSearchBar) { Object.assign(arg, { query: this.view.query }); } } else if (!this.view.isExpandSearchForm) { Object.assign(arg, { query: this.view.query }); } } // 快速分组和快速搜索栏 let otherQueryParam:any = {}; if(this.view && this.view.quickGroupData){ Object.assign(otherQueryParam,this.view.quickGroupData); } if(this.view && this.view.quickFormData){ Object.assign(otherQueryParam,this.view.quickFormData); } Object.assign(arg,{viewparams:otherQueryParam}); } /** * 获取多数据部件 * * @returns {*} * @memberof MDViewEngine */ public getMDCtrl(): any { } public getSearchForm(): any { return this.searchForm; } /** * 获取属性面板 * * @returns * @memberof MDViewEngine */ public getPropertyPanel() { return this.propertypanel; } /** * 转化数据 * * @memberof EditViewEngine */ public transformData(arg:any){ if(!this.getMDCtrl() || !(this.getMDCtrl().transformData instanceof Function)){ return null; } return this.getMDCtrl().transformData(arg); } /** * 多数据部件删除后 * * @param {*} [arg={}] * @memberof MDViewEngine */ public MDCtrlRemove(arg: any = {}): void { this.view.$emit('drdatasremove', arg); } /** * @description 销毁 * @memberof MDViewEngine */ public destroy() { super.destroy(); this.searchForm = null; this.propertypanel = null; this.md = null; } }