import Vue from "vue"; import {USER_INFO} from "@/store/mutation-types"; /** * */ export const FlowableMixin = { data(){ return { loginUser:{} } }, created() { this.loginUser = Vue.ls.get(USER_INFO); }, methods:{ // 当前数据是否可提交 isCanApply(row){ // 没有流程实例的即可提交 return !Boolean(row.processInstanceId); }, // 当前数据是否可撤回 isCanRecall(row){ // 进行中的流程&&当前节点不是开始节点&&状态不是通过 return Boolean(row.processInstanceId)&&row.taskNameId!=='start'&&row.actStatus!=='审批通过'; }, // 重新提交按钮 isCanReApply(row){ return row.taskNameId=='start'&&this.isTodoUsers(row); }, // 通过按钮 isCanPass(row){ return row.taskNameId!=='start'&& this.isTodoUsers(row); }, // 驳回退回按钮 isCanBacke(row){ // 不是start节点&&在可操作人员列表 return row.taskNameId!=='start'&&this.isTodoUsers(row); }, // 查看审批历史按钮 isCanHistoric(row){ // 有实例id就能查看 return Boolean(row.processInstanceId); }, // 当前登录人是否在处理人列表 isTodoUsers(row){ const todoUsers = row.todoUsers; if (todoUsers&&todoUsers.length){ const parse = JSON.parse(todoUsers)||[]; return parse.includes(this.loginUser.username); }else { return false; } }, // 当前登录人是否是处理过的人列表 isDoneUsers(row){ const doneUsers = row.doneUsers; if (doneUsers&&doneUsers.length){ const parse = JSON.parse(doneUsers)||[]; return parse.includes(this.loginUser.username); }else { return false; } }, } }