<template> <div id="dataviewexpviewdataviewexpbar" class="app-dataview-exp-bar"> <div slot='left'> <div class='dataview-exp-bar-header'> <div class="dataview-exp-bar-title"> <icon type='ios-home-outline'/>{{ $t('app.dataViewExpBar.title') }} </div> </div> <div class="exp-bar-action-container"> <div class='search-container'> <i-input v-model="searchText" :search="true" :placeholder="placeholder" @on-search="onSearch"> </i-input> </div> <div class='toolbar-container'> <tooltip :transfer="true" :max-width="600"> <i-button v-show="dataviewexpviewdataviewexpbar_toolbarModels.deuiaction3.visabled" :disabled="dataviewexpviewdataviewexpbar_toolbarModels.deuiaction3.disabled" class=' srfactionlevel100' v-button-loading:i-button @click="dataviewexpbar_toolbar_click({ tag: 'deuiaction3' }, $event)"> <i class='fa fa-edit'></i> <span class='caption'>{{$t('entities.ibizorder.dataviewexpviewdataviewexpbar_toolbar_toolbar.deuiaction3.caption')}}</span> </i-button> <div slot='content'>{{$t('entities.ibizorder.dataviewexpviewdataviewexpbar_toolbar_toolbar.deuiaction3.tip')}}</div> </tooltip> </div> </div> </div> <div class='dataview-exp-bar-content'> <view_dataviewexpbar_dataview :viewState="viewState" :viewparams="viewparams" :context="context" :pViewCtx="viewCtx" :isSingleSelect="isSingleSelect" createAction="Create" removeAction="Remove" updateAction="Update" fetchAction="FetchDefault" :showBusyIndicator="true" :isSelectFirstDefault="true" :newdata="newdata" :opendata="opendata" name="dataviewexpbar_dataview" ref='dataviewexpbar_dataview' @selectionchange="dataviewexpbar_dataview_selectionchange($event)" @load="dataviewexpbar_dataview_load($event)" @closeview="closeView($event)"> </view_dataviewexpbar_dataview> </div> </div> </template> // 基于 @CONTROL/卡片视图导航/CONTROL-BASE.vue.ftl 生成 <script lang='tsx'> import { Vue, Component, Prop, Provide, Emit, Watch, Model,Inject } from 'vue-property-decorator'; import { CreateElement } from 'vue'; import { Subject, Subscription } from 'rxjs'; import { ControlInterface } from '@/interface/control'; import { UIActionTool,Util,ViewTool } from '@/utils'; import NavDataService from '@/service/app/navdata-service'; import AppCenterService from "@service/app/app-center-service"; import IBIZOrderEntityService from '@/service/ibizorder/ibizorder-service'; import DataViewExpViewdataviewexpbarService from './data-view-exp-viewdataviewexpbar-dataviewexpbar-service'; import IBIZOrderUIService from '@/uiservice/ibizorder/ibizorder-ui-service'; import CodeListService from "@/codelist/codelist-service"; @Component({ components: { } }) export default class DataViewExpViewdataviewexpbarBase extends Vue implements ControlInterface { /** * 名称 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public name?: string; /** * 视图通讯对象 * * @type {Subject<ViewState>} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public viewState!: Subject<ViewState>; /** * 应用上下文 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public context!: any; /** * 视图参数 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public viewparams!: any; /** * 视图操作参数(父级) * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public pViewCtx!: any; /** * 视图操作参数 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ public viewCtx: any = {}; /** * 监听视图操作参数变化 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ @Watch('pViewCtx', { immediate: true }) public onViewCtxChange(newVal: any, oldVal: any) { Object.assign(this.viewCtx, newVal, { xData: this, ctrl: this }); } /** * 视图状态事件 * * @public * @type {(Subscription | undefined)} * @memberof DataViewExpViewdataviewexpbarBase */ public viewStateEvent: Subscription | undefined; /** * 获取部件类型 * * @returns {string} * @memberof DataViewExpViewdataviewexpbarBase */ public getControlType(): string { return 'DATAVIEWEXPBAR' } /** * 计数器服务对象集合 * * @type {Array<*>} * @memberof DataViewExpViewdataviewexpbarBase */ public counterServiceArray:Array<any> = []; /** * 建构部件服务对象 * * @type {DataViewExpViewdataviewexpbarService} * @memberof DataViewExpViewdataviewexpbarBase */ public service: DataViewExpViewdataviewexpbarService = new DataViewExpViewdataviewexpbarService({ $store: this.$store }); /** * 实体服务对象 * * @type {IBIZOrderService} * @memberof DataViewExpViewdataviewexpbarBase */ public appEntityService: IBIZOrderEntityService = new IBIZOrderEntityService({ $store: this.$store }); /** * dataviewexpbar_dataview 部件 selectionchange 事件 * * @param {*} [args={}] * @param {*} $event * @memberof DataViewExpViewdataviewexpbarBase */ public dataviewexpbar_dataview_selectionchange($event: any, $event2?: any) { this.dataviewexpbar_selectionchange($event, 'dataviewexpbar_dataview', $event2); } /** * dataviewexpbar_dataview 部件 load 事件 * * @param {*} [args={}] * @param {*} $event * @memberof DataViewExpViewdataviewexpbarBase */ public dataviewexpbar_dataview_load($event: any, $event2?: any) { this.dataviewexpbar_load($event, 'dataviewexpbar_dataview', $event2); } /** * dataviewexpbar_toolbar 部件 click 事件 * * @param {*} [args={}] * @param {*} $event * @memberof DataViewExpViewdataviewexpbarBase */ public dataviewexpbar_toolbar_click($event: any, $event2?: any) { if (Object.is($event.tag, 'deuiaction3')) { this.dataviewexpbar_toolbar_deuiaction3_click(null, 'dataviewexpbar_toolbar', $event2); } } /** * 逻辑事件 * * @param {*} [params={}] * @param {*} [tag] * @param {*} [$event] * @memberof */ public dataviewexpbar_toolbar_deuiaction3_click(params: any = {}, tag?: any, $event?: any) { // 参数 // 取数 let datas: any[] = []; let xData: any = null; // _this 指向容器对象 const _this: any = this; let paramJO:any = {}; let contextJO:any = {}; xData = this.$refs.dataviewexpbar_dataview; if (xData.getDatas && xData.getDatas instanceof Function) { datas = [...xData.getDatas()]; } if(params){ datas = [params]; } // 界面行为 this.Edit(datas, contextJO,paramJO, $event, xData,this,"IBIZOrder"); } /** * 编辑 * * @param {any[]} args 当前数据 * @param {any} contextJO 行为附加上下文 * @param {*} [params] 附加参数 * @param {*} [$event] 事件源 * @param {*} [xData] 执行行为所需当前部件 * @param {*} [actionContext] 执行行为上下文 * @memberof IBIZOrderDataViewExpViewBase */ public Edit(args: any[],contextJO?:any, params?: any, $event?: any, xData?: any,actionContext?:any,srfParentDeName?:string) { if (args.length === 0) { return; } const _this: any = this; if (_this.opendata && _this.opendata instanceof Function) { const data: any = { }; if (args.length > 0) { Object.assign(data, { ibizorder: args[0].ibizorder }) } _this.opendata([{ ...data }], args, params, $event, xData); } else { _this.$Notice.error({ title: '错误', desc: 'opendata 视图处理逻辑不存在,请添加!' }); } } /** * 转化数据 * * @param {any} args * @memberof DataViewExpViewdataviewexpbarBase */ public transformData(args: any) { let _this: any = this; if(_this.service && _this.service.handleRequestData instanceof Function && _this.service.handleRequestData('transform',_this.context,args)){ return _this.service.handleRequestData('transform',_this.context,args)['data']; } } /** * 关闭视图 * * @param {any} args * @memberof DataViewExpViewdataviewexpbarBase */ public closeView(args: any): void { let _this: any = this; _this.$emit('closeview', [args]); } /** * 计数器刷新 * * @memberof DataViewExpViewdataviewexpbarBase */ public counterRefresh(){ const _this:any =this; if(_this.counterServiceArray && _this.counterServiceArray.length >0){ _this.counterServiceArray.forEach((item:any) =>{ if(item.refreshData && item.refreshData instanceof Function){ item.refreshData(); } }) } } /** * 处理部件事件 * * @memberof DataViewExpViewdataviewexpbarBase */ public async handleCtrlEvents(eventName: string, args: any = {}): Promise<boolean> { const actionData = { data: this.getData() || {}, context: Util.deepCopy(this.context), viewparams: Util.deepCopy(this.viewparams), xData: this } let result: boolean = true; Object.assign(actionData, args); if (!result) { return false; } this.$emit(eventName, actionData); return true; } /** * 打开新建数据视图 * * @type {any} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public newdata: any; /** * 打开编辑数据视图 * * @type {any} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public opendata: any; /** * 视图唯一标识 * * @type {boolean} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop() public viewUID!:string; /** * 是否单选 * * @public * @type {(boolean)} * @memberof DataViewExpViewdataviewexpbarBase */ public isSingleSelect:boolean = true; /** * 可搜索字段名称 * * * @type {(string)} * @memberof DataViewExpViewdataviewexpbarBase */ public placeholder = "订单名称"; /** * 搜素值 * * @public * @type {(string)} * @memberof DataViewExpViewdataviewexpbarBase */ public searchText: string = ""; /** * 导航视图名称 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ public navViewName: string = "ibizorder-detail-sgrid-view9"; /** * 导航视图参数 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ public navViewParam: string = '{}'; /** * 导航过滤项 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ public navFilter: string = ""; /** * 导航关系 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ public navPSDer: string = "n_ibizorderid_eq"; /** * 导航上下文参数 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ public navigateContext:any = null; /** * 导航视图参数 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ public navigateParams:any = null; /** * 显示处理提示 * * @type {boolean} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop({ default: true }) public showBusyIndicator!: boolean; /** * 工具栏模型 * * @type {*} * @memberof IBIZOrderDataViewExpView */ public dataviewexpviewdataviewexpbar_toolbarModels: any = { deuiaction3: { name: 'deuiaction3', actiontarget: 'NONE', caption: '编辑', disabled: false, type: 'DEUIACTION', visabled: true,noprivdisplaymode:2,dataaccaction: '', uiaction: { tag: 'Edit', target: 'SINGLEKEY' } }, }; /** * 获取多项数据 * * @returns {any[]} * @memberof DataViewExpViewdataviewexpbarBase */ public getDatas(): any[] { return []; } /** * 获取单项树 * * @returns {*} * @memberof DataViewExpViewdataviewexpbarBase */ public getData(): any { return null; } /** * Vue声明周期(组件初始化完毕) * * @memberof DataViewExpViewdataviewexpbarBase */ public created() { this.afterCreated(); } /** * 执行created后的逻辑 * * @memberof DataViewExpViewdataviewexpbarBase */ public afterCreated(){ if (this.viewState) { this.viewStateEvent = this.viewState.subscribe(({ tag, action, data }) => { if (!Object.is(tag, this.name)) { return; } this.viewState.next({ tag: 'dataviewexpbar_dataview', action: action, data: data }); }); } } /** * Vue声明周期(组件渲染完毕) * * @memberof DataViewExpViewdataviewexpbarBase */ public mounted() { this.afterMounted(); } /** * 执行mounted后的逻辑 * * @memberof DataViewExpViewdataviewexpbarBase */ public afterMounted() { } /** * vue 生命周期 * * @memberof DataViewExpViewdataviewexpbarBase */ public destroyed() { this.afterDestroy(); } /** * 执行destroyed后的逻辑 * * @memberof DataViewExpViewdataviewexpbarBase */ public afterDestroy() { if (this.viewStateEvent) { this.viewStateEvent.unsubscribe(); } } /** * 刷新 * * @memberof DataViewExpViewdataviewexpbarBase */ public refresh(args?: any): void { const refs: any = this.$refs; if (refs && refs.dataviewexpbar_dataview) { refs.dataviewexpbar_dataview.refresh(); } } /** * 卡片视图导航选中 * * @param {any []} args * @param {string} [tag] * @param {*} [$event2] * @returns {void} * @memberof DataViewExpViewdataviewexpbarBase */ public dataviewexpbar_selectionchange(args: any [], tag?: string, $event2?: any): void { let tempContext:any = {}; let tempViewParam:any = {}; if (args.length === 0) { this.calcToolbarItemState(true); return ; } const arg:any = args[0]; if(this.context){ Object.assign(tempContext,JSON.parse(JSON.stringify(this.context))); } Object.assign(tempContext,{'ibizorder':arg['ibizorder']}); Object.assign(tempContext,{srfparentdename:'IBIZOrder',srfparentkey:arg['ibizorder']}); if(this.navFilter && !Object.is(this.navFilter,"")){ Object.assign(tempViewParam,{[this.navFilter]:arg['ibizorder']}); } if(this.navPSDer && !Object.is(this.navPSDer,"")){ Object.assign(tempViewParam,{[this.navPSDer]:arg['ibizorder']}); } if(this.navigateContext && Object.keys(this.navigateContext).length >0){ let _context:any = this.$util.computedNavData(arg,tempContext,tempViewParam,this.navigateContext); Object.assign(tempContext,_context); } if(this.navigateParams && Object.keys(this.navigateParams).length >0){ let _params:any = this.$util.computedNavData(arg,tempContext,tempViewParam,this.navigateParams); Object.assign(tempViewParam,_params); } const navItem: any = { navView: this.navViewName, data: args, srfnavdata: { context: tempContext, viewparams: tempViewParam } } this.handleCtrlEvents('onselectionchange', { data: args }).then((res: boolean) => { if (!res) { this.calcToolbarItemState(true); return; } this.calcToolbarItemState(false); this.$emit('selectionchange', navItem); }) } /** * 卡片视图加载完成 * * @param {any[]} args * @param {string} [tag] * @param {*} [$event2] * @returns {void} * @memberof DataViewExpViewdataviewexpbarBase */ public dataviewexpbar_load(args: any[], tag?: string, $event2?: any): void { this.calcToolbarItemState(true); this.$emit('load',args); } /** * 设置导航区工具栏禁用状态 * * @param {boolean} state * @return {*} * @memberof DataViewExpViewdataviewexpbarBase */ public calcToolbarItemState(state: boolean) { let _this: any = this; const models:any = _this.dataviewexpviewdataviewexpbar_toolbarModels; if (models) { for (const key in models) { if (!models.hasOwnProperty(key)) { return; } const _item = models[key]; if (_item.uiaction && (Object.is(_item.uiaction.target, 'SINGLEKEY') || Object.is(_item.uiaction.target, 'MULTIKEY'))) { _item.disabled = state; } _item.visabled = true; if (_item.noprivdisplaymode && _item.noprivdisplaymode === 6) { _item.visabled = false; } } this.calcNavigationToolbarState(); } } /** * 计算导航工具栏权限状态 * * @memberof DataViewExpViewdataviewexpbarBase */ public calcNavigationToolbarState(){ let _this: any = this; // 界面行为 if(_this.dataviewexpviewdataviewexpbar_toolbarModels){ const curUIService:IBIZOrderUIService = new IBIZOrderUIService(); ViewTool.calcActionItemAuthState({},_this.dataviewexpviewdataviewexpbar_toolbarModels,curUIService); } } /** * 执行搜索 * * @memberof DataViewExpViewdataviewexpbarBase */ public onSearch() { this.viewState.next({ tag: 'dataviewexpbar_dataview', action: 'filter', data: { query: this.searchText} }); } } </script> <style lang='scss'> @import './data-view-exp-viewdataviewexpbar-dataviewexpbar.scss'; </style>