<template> <split id="calendarexpviewcalendarexpbar" class="app-calendar-exp-bar" v-model="split" mode="horizontal" @on-move-end="onSplitChange"> <div slot='left'> <div class='calendar-exp-bar-header'> <div class="calendar-exp-bar-title"> <icon type='ios-home-outline'/>{{ $t('app.calendarExpBar.title') }} </div> </div> <div class="container-header"> <div class='search-container'> <i-input :search="true" @on-change="($event) => { this.searchText = $event.target.value; }" :placeholder="placeholder" @on-search="onSearch"> </i-input> </div> <div class='toolbar-container'> <tooltip :transfer="true" :max-width="600"> <i-button v-show="calendarexpviewcalendarexpbar_toolbarModels.deuiaction3.visabled" :disabled="calendarexpviewcalendarexpbar_toolbarModels.deuiaction3.disabled" class='' v-loading:i-button @click="calendarexpbar_toolbar_click({ tag: 'deuiaction3' }, $event)"> <i class='fa fa-edit'></i> <span class='caption'>{{$t('entities.ibizorder.calendarexpviewcalendarexpbar_toolbar_toolbar.deuiaction3.caption')}}</span> </i-button> <div slot='content'>{{$t('entities.ibizorder.calendarexpviewcalendarexpbar_toolbar_toolbar.deuiaction3.tip')}}</div> </tooltip> </div> </div> <div class='calendar-exp-bar-content'> <view_calendarexpbar_calendar :viewState="viewState" :viewparams="viewparams" :context="context" :showBusyIndicator="true" :isSelectFirstDefault="true" :newdata="newdata" :opendata="opendata" name="calendarexpbar_calendar" ref='calendarexpbar_calendar' @selectionchange="calendarexpbar_calendar_selectionchange($event)" @load="calendarexpbar_calendar_load($event)" @closeview="closeView($event)"> </view_calendarexpbar_calendar> </div> </div> <div slot='right'> <component v-if="selection.view && !Object.is(this.selection.view.viewname, '')" :is="selection.view.viewname" class="viewcontainer2" :viewDefaultUsage="false" :viewdata="JSON.stringify(selection.context)" :viewparam="JSON.stringify(selection.viewparam)"> </component> </div> </split> </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 IBIZOrderEntityService from '@/service/ibizorder/ibizorder-service'; import CalendarExpViewcalendarexpbarService from './calendar-exp-viewcalendarexpbar-calendarexpbar-service'; import IBIZOrderUIService from '@/uiservice/ibizorder/ibizorder-ui-service'; @Component({ components: { } }) export default class CalendarExpViewcalendarexpbarBase extends Vue implements ControlInterface { /** * 名称 * * @type {string} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop() public name?: string; /** * 视图通讯对象 * * @type {Subject<ViewState>} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop() public viewState!: Subject<ViewState>; /** * 应用上下文 * * @type {*} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop() public context!: any; /** * 视图参数 * * @type {*} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop() public viewparams!: any; /** * 视图状态事件 * * @public * @type {(Subscription | undefined)} * @memberof CalendarExpViewcalendarexpbarBase */ public viewStateEvent: Subscription | undefined; /** * 获取部件类型 * * @returns {string} * @memberof CalendarExpViewcalendarexpbarBase */ public getControlType(): string { return 'CALENDAREXPBAR' } /** * 计数器服务对象集合 * * @type {Array<*>} * @memberof CalendarExpViewcalendarexpbarBase */ public counterServiceArray:Array<any> = []; /** * 建构部件服务对象 * * @type {CalendarExpViewcalendarexpbarService} * @memberof CalendarExpViewcalendarexpbarBase */ public service: CalendarExpViewcalendarexpbarService = new CalendarExpViewcalendarexpbarService({ $store: this.$store }); /** * 实体服务对象 * * @type {IBIZOrderService} * @memberof CalendarExpViewcalendarexpbarBase */ public appEntityService: IBIZOrderEntityService = new IBIZOrderEntityService({ $store: this.$store }); /** * calendarexpbar_calendar 部件 selectionchange 事件 * * @param {*} [args={}] * @param {*} $event * @memberof CalendarExpViewcalendarexpbarBase */ public calendarexpbar_calendar_selectionchange($event: any, $event2?: any) { this.calendarexpbar_selectionchange($event, 'calendarexpbar_calendar', $event2); } /** * calendarexpbar_calendar 部件 load 事件 * * @param {*} [args={}] * @param {*} $event * @memberof CalendarExpViewcalendarexpbarBase */ public calendarexpbar_calendar_load($event: any, $event2?: any) { this.calendarexpbar_load($event, 'calendarexpbar_calendar', $event2); } /** * calendarexpbar_toolbar 部件 click 事件 * * @param {*} [args={}] * @param {*} $event * @memberof CalendarExpViewcalendarexpbarBase */ public calendarexpbar_toolbar_click($event: any, $event2?: any) { if (Object.is($event.tag, 'deuiaction3')) { this.calendarexpbar_toolbar_deuiaction3_click(null, 'calendarexpbar_toolbar', $event2); } } /** * 逻辑事件 * * @param {*} [params={}] * @param {*} [tag] * @param {*} [$event] * @memberof */ public calendarexpbar_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.calendarexpbar_calendar; 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 IBIZOrderCalendarExpViewBase */ 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 CalendarExpViewcalendarexpbarBase */ 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 CalendarExpViewcalendarexpbarBase */ public closeView(args: any): void { let _this: any = this; _this.$emit('closeview', [args]); } /** * 计数器刷新 * * @memberof CalendarExpViewcalendarexpbarBase */ 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 {boolean} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop() public viewUID!:string; /** * 打开新建数据视图 * * @type {any} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop() public newdata: any; /** * 打开编辑数据视图 * * @type {any} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop() public opendata: any; /** * 是否单选 * * @public * @type {(boolean)} * @memberof CalendarExpViewcalendarexpbarBase */ public isSingleSelect:boolean = true; /** * 呈现模式,可选值:horizontal或者vertical * * @public * @type {(string)} * @memberof CalendarExpViewcalendarexpbarBase */ public showMode:string ="horizontal"; /** * 控件宽度 * * @type {number} * @memberof CalendarExpViewcalendarexpbarBase */ public ctrlWidth:number = 0; /** * 控件高度 * * @type {number} * @memberof CalendarExpViewcalendarexpbarBase */ public ctrlHeight: number = 0; /** * 可搜索字段名称 * * * @type {(string)} * @memberof CalendarExpViewcalendarexpbarBase */ public placeholder="订单名称"; /** * 搜素值 * * @public * @type {(string)} * @memberof CalendarExpViewcalendarexpbarBase */ public searchText:string = ""; /** * 分割宽度 * * @type {number} * @memberof CalendarExpViewcalendarexpbarBase */ public split: number = 0.5; /** * 导航视图名称 * * @type {string} * @memberof CalendarExpViewcalendarexpbarBase */ public navViewName: any = { item1: "ibizorder-detail-sgrid-view9" }; /** * 导航参数 * * @type {*} * @memberof CalendarExpViewcalendarexpbarBase */ public navParam: any = { item1: { navigateContext:null, navigateParams:null } }; /** * 导航过滤项 * * @type {*} * @memberof CalendarExpViewcalendarexpbarBase */ public navFilter: any = { item1: "" }; /** * 导航关系 * * @type {*} * @memberof CalendarExpViewcalendarexpbarBase */ public navPSDer: any = { item1: "n_ibizorderid_eq" }; /** * 显示处理提示 * * @type {boolean} * @memberof CalendarExpViewcalendarexpbarBase */ @Prop({ default: true }) public showBusyIndicator!: boolean; /** * 工具栏模型 * * @type {*} * @memberof IBIZOrderCalendarExpView */ public calendarexpviewcalendarexpbar_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 CalendarExpViewcalendarexpbarBase */ public getDatas(): any[] { return []; } /** * 获取单项树 * * @returns {*} * @memberof CalendarExpViewcalendarexpbarBase */ public getData(): any { return null; } /** * 选中数据 * * @type {*} * @memberof CalendarExpViewcalendarexpbarBase */ public selection: any = {}; /** * split值变化事件 * * @memberof CalendarExpViewcalendarexpbarBase */ public onSplitChange() { if(this.$refs.calendarexpbar_calendar){ const calendarContainer:any = this.$refs.calendarexpbar_calendar; if(calendarContainer.$refs.calendar){ const appCalendar: any = calendarContainer.$refs.calendar; const api = appCalendar.getApi(); api.updateSize(); } } if(this.split){ this.$store.commit("setViewSplit",{viewUID:this.viewUID,viewSplit:this.split}); } } /** * Vue声明周期(组件初始化完毕) * * @memberof CalendarExpViewcalendarexpbarBase */ public created() { this.afterCreated(); } /** * 执行created后的逻辑 * * @memberof CalendarExpViewcalendarexpbarBase */ public afterCreated(){ if (this.viewState) { this.viewStateEvent = this.viewState.subscribe(({ tag, action, data }) => { if (!Object.is(tag, this.name)) { return; } this.viewState.next({ tag: 'calendarexpbar_calendar', action: action, data: data }); }); } } /** * Vue声明周期(组件渲染完毕) * * @memberof CalendarExpViewcalendarexpbarBase */ public mounted() { this.afterMounted(); } /** * 执行mounted后的逻辑 * * @memberof CalendarExpViewcalendarexpbarBase */ public afterMounted(){ if(this.$store.getters.getViewSplit(this.viewUID)){ this.split = this.$store.getters.getViewSplit(this.viewUID); }else{ let containerWidth:number = (document.getElementById("calendarexpviewcalendarexpbar") as any).offsetWidth; let containerHeight:number = (document.getElementById("calendarexpviewcalendarexpbar") as any).offsetHeight; if(Object.is(this.showMode,'horizontal')){ if(this.ctrlWidth && containerWidth != 0){ this.split = this.ctrlWidth/containerWidth; } }else{ if(this.ctrlHeight && containerHeight != 0){ this.split = this.ctrlHeight/containerHeight; } } this.$store.commit("setViewSplit",{viewUID:this.viewUID,viewSplit:this.split}); } } /** * vue 生命周期 * * @memberof CalendarExpViewcalendarexpbarBase */ public destroyed() { this.afterDestroy(); } /** * 执行destroyed后的逻辑 * * @memberof CalendarExpViewcalendarexpbarBase */ public afterDestroy() { if (this.viewStateEvent) { this.viewStateEvent.unsubscribe(); } } /** * 刷新 * * @memberof CalendarExpViewcalendarexpbarBase */ public refresh(args?: any): void { const refs: any = this.$refs; if (refs && refs.calendarexpbar_calendar) { refs.calendarexpbar_calendar.refresh(); } } /** * calendarexpbar的选中数据事件 * * @memberof CalendarExpViewcalendarexpbarBase */ public calendarexpbar_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))); } switch(arg.itemType) { case "item1": Object.assign(tempContext,{ ibizorder : arg.ibizorder}); Object.assign(tempContext,{srfparentdename:'IBIZOrder',srfparentkey:arg['ibizorder']}); if(this.navFilter && this.navFilter['item1'] && !Object.is(this.navFilter['item1'],"")){ Object.assign(tempViewParam,{[this.navFilter['item1']]:arg['ibizorder']}); } if(this.navPSDer && this.navFilter['item1'] && !Object.is(this.navPSDer['item1'],"")){ Object.assign(tempViewParam,{[this.navPSDer['item1']]:arg['ibizorder']}); } if(this.navParam && this.navParam['item1'] && this.navParam['item1'].navigateContext && Object.keys(this.navParam['item1'].navigateContext).length >0){ let _context:any = this.$util.computedNavData(arg,tempContext,tempViewParam,this.navParam['item1'].navigateContext); Object.assign(tempContext,_context); } if(this.navParam && this.navParam['item1'] && this.navParam['item1'].navigateParams && Object.keys(this.navParam['item1'].navigateParams).length >0){ let _params:any = this.$util.computedNavData(arg,tempContext,tempViewParam,this.navParam['item1'].navigateParams); Object.assign(tempViewParam,_params); } break; } this.selection = {}; Object.assign(this.selection, { view: { viewname: this.navViewName[arg.itemType] }, context:tempContext,viewparam:tempViewParam }); this.calcToolbarItemState(false); this.$emit('selectionchange',args); this.$forceUpdate(); } /** * calendarexpbar的load完成事件 * * @memberof CalendarExpViewcalendarexpbarBase */ public calendarexpbar_load(args:any, tag?: string, $event2?: any){ this.calcToolbarItemState(true); this.$emit('load',args); } /** * 设置导航区工具栏禁用状态 * * @param {boolean} state * @return {*} * @memberof CalendarExpViewcalendarexpbarBase */ public calcToolbarItemState(state: boolean) { let _this: any = this; const models:any = _this.calendarexpviewcalendarexpbar_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 CalendarExpViewcalendarexpbarBase */ public calcNavigationToolbarState(){ let _this: any = this; // 界面行为 if(_this.calendarexpviewcalendarexpbar_toolbarModels){ const curUIService:IBIZOrderUIService = new IBIZOrderUIService(); ViewTool.calcActionItemAuthState({},_this.calendarexpviewcalendarexpbar_toolbarModels,curUIService); } } /** * 执行搜索 * * @memberof CalendarExpViewcalendarexpbarBase */ public onSearch($event:any) { let calendar:any = this.$refs.calendarexpbar_calendar; calendar.searchEvents({ query: this.searchText }); } } </script> <style lang='less'> @import './calendar-exp-viewcalendarexpbar-calendarexpbar.less'; </style>