<template> <div class="app-actionbar"> <div class="app-actionbar-item" v-for="(item,index) in items" :key="index"> <Badge v-if="item.counterService&&item.counterService.counterData" v-show="item.visabled" :count="item.counterService.counterData[item.counterId]" type="primary"> <i-button :disabled="item.disabled" @click="handleClick(item, $event)"><i v-if="item.icon" style="margin-right: 5px;" :class="item.icon"></i>{{item.actionName}}</i-button> </Badge> <i-button v-show="item.visabled" :disabled="item.disabled" v-else @click="handleClick(item, $event)">{{item.actionName}}</i-button> </div> </div> </template> <script lang="ts"> import { Vue, Component, Prop, Model, Emit,Inject, Watch } from "vue-property-decorator"; import { Subject,Subscription } from "rxjs"; @Component({}) export default class AppActionBar extends Vue { /** * 传入操作栏模型数据 * * @type {any} * @memberof AppActionBar */ @Prop() public items!:any; /** * 注入的UI服务 * * @type {*} * @memberof AppActionBar */ @Prop() public uiService!: any; /** * 视图通讯对象 * * @type {Subject<ViewState>} * @memberof AppActionBar */ @Prop() public viewState!: Subject<ViewState>; /** * 视图状态事件 * * @public * @type {(Subscription | undefined)} * @memberof ActionlinetestBase */ public viewStateEvent: Subscription | undefined; /** * 部件数据 * * @type {*} * @memberof AppActionBar */ public data: any; /** * 组件初始化 * * @memberof AppActionBar */ public created(){ if (this.viewState) { this.viewStateEvent = this.viewState.subscribe(({ tag, action, data }) => { if (!Object.is(tag, "app-actionbar")) { return; } if(Object.is(action,'loadmodel')){ this.data = data; this.calcActionItemAuthState(data,this.items,this.uiService); } }); } } /** * 触发界面行为 * * @memberof AppActionBar */ public handleClick(item: any, $event:any){ let _data = { tag : item.viewlogicname, params : this.data, event : $event }; this.$emit('itemClick',_data); } /** * 计算界面行为项权限状态 * * @param {*} [data] 传入数据 * @param {*} [ActionModel] 界面行为模型 * @param {*} [UIService] 界面行为服务 * @memberof AppActionBar */ public calcActionItemAuthState(data:any,ActionModel:any,UIService:any){ for (const key in ActionModel) { if (!ActionModel.hasOwnProperty(key)) { return; } const _item = ActionModel[key]; if(_item && _item['dataaccaction'] && UIService){ let dataActionResult:any; if(Object.is(_item['actiontarget'],"NONE")){ dataActionResult = UIService.getResourceOPPrivs(_item['dataaccaction']); }else{ if(data && Object.keys(data).length >0){ dataActionResult = UIService.getAllOPPrivs(data)[_item['dataaccaction']]; } } // 无权限:0;有权限:1 if(dataActionResult === 0){ // 禁用:1;隐藏:2;隐藏且默认隐藏:6 if(_item.noprivdisplaymode === 1){ _item.disabled = true; } if((_item.noprivdisplaymode === 2) || (_item.noprivdisplaymode === 6)){ _item.visabled = false; }else{ _item.visabled = true; } } if(dataActionResult === 1){ _item.visabled = true; _item.disabled = false; } } } } /** * 组件销毁 * * @memberof AppActionBar */ public destory(){ if (this.viewStateEvent) { this.viewStateEvent.unsubscribe(); } } } </script> <style lang='less'> @import "./app-actionbar.less"; </style>