<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> </div> <div class='dataview-exp-bar-content'> <view_dataviewexpbar_dataview :viewState="viewState" :viewparams="viewparams" :context="context" :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> <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 IBIZBOOKEntityService from '@/service/ibizbook/ibizbook-service'; import DataViewExpViewdataviewexpbarService from './data-view-exp-viewdataviewexpbar-dataviewexpbar-service'; import IBIZBOOKUIService from '@/uiservice/ibizbook/ibizbook-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; /** * 视图状态事件 * * @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 {IBIZBOOKService} * @memberof DataViewExpViewdataviewexpbarBase */ public appEntityService: IBIZBOOKEntityService = new IBIZBOOKEntityService({ $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); } /** * 转化数据 * * @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(); } }) } } /** * 打开新建数据视图 * * @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 = ""; /** * 导航视图参数 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ public navViewParam: string = '{}'; /** * 导航过滤项 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ public navFilter: string = ""; /** * 导航关系 * * @type {string} * @memberof DataViewExpViewdataviewexpbarBase */ public navPSDer: string = ""; /** * 导航上下文参数 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ public navigateContext:any = null; /** * 导航视图参数 * * @type {*} * @memberof DataViewExpViewdataviewexpbarBase */ public navigateParams:any = null; /** * 显示处理提示 * * @type {boolean} * @memberof DataViewExpViewdataviewexpbarBase */ @Prop({ default: true }) public showBusyIndicator!: boolean; /** * 获取多项数据 * * @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,{'ibizbook':arg['ibizbook']}); Object.assign(tempContext,{srfparentdename:'IBIZBOOK',srfparentkey:arg['ibizbook']}); if(this.navFilter && !Object.is(this.navFilter,"")){ Object.assign(tempViewParam,{[this.navFilter]:arg['ibizbook']}); } if(this.navPSDer && !Object.is(this.navPSDer,"")){ Object.assign(tempViewParam,{[this.navPSDer]:arg['ibizbook']}); } 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.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:IBIZBOOKUIService = new IBIZBOOKUIService(); 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='less'> @import './data-view-exp-viewdataviewexpbar-dataviewexpbar.less'; </style>