You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

437 lines
21 KiB

<template>
<a-card :bordered="false">
<!--流程申请选择-->
<a-input-search style="margin-bottom: 10px;margin-right:10px;width: 200px" v-model="searchProcessKey"
placeholder="输入流程名称" @search="onSearchProcess" />
<a-button @click="onSearchProcess(searchProcessKey)" type="primary">查询</a-button>
<a-button @click="onSearchProcess('')" style="margin-left: 1%">重置</a-button>
<a-button @click="handleToApplyList" type="primary" style="float: right;">前往我的申请列表</a-button>
<a-empty description="无流程可供选择" v-if="activeKeyAll.length==0" />
<div v-else >
<a-collapse v-model="activeKey">
<a-collapse-panel v-for="(value, index) in activeKeyAll" :header="filterDictText(dictOptions,value) ||'未分类'" :key="value" >
<a-list :grid="{ gutter: 20,column:4}" :dataSource="processDataMap[value]">
<template slot="renderItem" slot-scope="item" >
<a-card v-if="item.name=='预算计划采购流程'" style="margin-bottom: 1%" v-has="'applyHome:planAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='物资入库流程'" v-has="'applyHome:warehousingAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='物资出库流程'" v-has="'applyHome:deliberyAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='物资调拨流程'" v-has="'applyHome:allotAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='物资报废流程'" v-has="'applyHome:srcapAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='权限授权流程'" v-has="'applyHome:authAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='民爆采购流程'" style="margin-bottom: 1%" v-has="'industrial:planAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='民爆入库流程'" v-has="'industrial:warehousingAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='民爆出库流程'" v-has="'industrial:deliberyAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='民爆报废流程'" v-has="'industrial:srcapAdd'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
<a-card v-if="item.name=='民爆归还流程'" v-has="'industrial:restore'" hoverable @click="chooseProcess(item)" class="forRadius" :style="{'background-color':item.color,'border-radius':'12px','width':'24%','display': 'inline-block','margin-right':'1%'}" :headStyle="{'border-radius':'12px'}">
<div slot="title">
<a-row style="text-align: center;">
<!-- <a-col span="12" :title="item.name">{{item.name}} </a-col>-->
<!--<a-col span="12" style="text-align: center;">-->
<a href="javascript:void (0)" style="color: white;font-size: 18px;font-weight: bolder;">{{item.name}}</a>
<!-- <a href="javascript:void (0)" @click="chooseProcess(item)">{{item.name}}</a>-->
<!--</a-col>-->
</a-row>
</div>
<!-- <b>版本:</b>v.{{item.version}}
<br/>
<b>说明:</b>{{item.description}}-->
</a-card>
</template>
</a-list>
</a-collapse-panel>
</a-collapse>
</div>
<!--流程表单-->
<a-modal
:destroyOnClose="false"
:title="lcModa.title"
:visible="lcModa.visible"
switchFullscreen
:footer="null"
:maskClosable="false"
:okButtonProps="{ class:{'jee-hidden': disableSubmit} }"
width="80%"
@cancel="close"
>
<component :disabled="lcModa.disabled" v-if="lcModa.visible" :is="lcModa.formComponent" :hieg = "lcModa.hieg"
:processData="lcModa.processData" :isNew = "lcModa.isNew" :pictureId="lcModa.pictureId" :procInstId="lcModa.procInstId"
@afterSubmit="afterSub" @close="closeThis">
</component>
</a-modal>
</a-card>
</template>
<script>
import { activitiMixin } from '@/views/activiti/mixins/activitiMixin'
import JEllipsis from '@/components/jeecg/JEllipsis'
import JTreeSelect from '@/components/jeecg/JTreeSelect'
import {initDictOptions, filterDictText} from '@/components/dict/JDictSelectUtil'
import historicDetail from '@/views/activiti/historicDetail'
import hasPermission, { filterGlobalPermission, filterNodePermission } from '../../utils/hasPermission'
export default {
name: "applyHome",
mixins:[activitiMixin],
components: {
JEllipsis
,JTreeSelect
,historicDetail
},
data () {
return {
description: '所有',
dictOptions:[],
disableSubmit: false,
hasVaule:[],
url: {
getProcessDataList: "/activiti_process/listData",
getFirstNode:'/actProcessIns/getFirstNode',
applyBusiness:'/actBusiness/apply',
getProcessNodeByDepart: '/activiti_process/getProcessNodeByDepart'
},
// 查询条件
queryParam: {
createTimeRange:[],
keyWord:'',
},
// 表头
labelCol: {
xs: { span: 4 },
sm: { span: 4 },
},
wrapperCol: {
xs: { span: 20 },
sm: { span: 20 },
},
processModalVisible: null,
activeKeyAll: [],
activeKey: [],
processDataMap: {},
searchProcessKey: null,
addApplyLoading: false,
lcModa: {
title:'',
hieg:true,
disabled:false,
visible:false,
formComponent : null,
isNew : false,
pictrueId:'',
procInstId:''
},
colors:["#ced4fc",
"#fad172",
"#46cea8",
"#b1d5e0",
"#e4b8f1",
"#fa8e8e",
"#4bfceb","#fd7186","#f9d500","#7191e4","#8759ff","#fc7798","#00bf50","#b7d264"]
}
},
computed:{
},
mounted() {
this.initDictConfig()
this.getProcessList()
},
methods: {
initDictConfig() {
//初始化字典 - 流程分类
initDictOptions('bpm_process_type').then((res) => {
if (res.success) {
this.dictOptions = res.result;
}
});
},
closeThis(){
this.lcModa.visible=false
this.lcModa.disabled = false
},
close(){
this.$confirm({
title: "关闭",
content: `确定关闭当前页面?`,
centered: true,
onOk: () => {
this.lcModa.visible=false
this.lcModa.disabled = false
},
})
},
filterDictText(dictOptions, text) {
// console.log("-=-=",dictOptions,text);
if (dictOptions instanceof Array) {
for (let dictItem of dictOptions) {
if (text === dictItem.value) {
return dictItem.text
}
}
}
return text||text=='null'?'':text
},
/*加载流程列表*/
getProcessList() {
this.addApplyLoading = true;
this.getAction(this.url.getProcessDataList,{status:1,roles:true}).then(res => {
this.activeKeyAll = [];
if (res.success) {
var result = res.result||[];
if (result.length>0){
// console.log("====================",result);
//14种颜色的循环
for (let i in result){
this.$set(result[i],'color',this.colors[i%14])
}
let searchProcessKey = this.searchProcessKey;
if (searchProcessKey){ //过滤条件
result = _.filter(result, function(o) { return o.name.indexOf(searchProcessKey)>-1; });
}
this.processDataMap = _.groupBy(result,'categoryId');
// console.log("111111111111",this.categoryId)
// console.log("===================",this.processDataMap,"=====================")
// console.log("=======",this.processDataMap.wuzi)
for (const categoryId in this.processDataMap) {
this.activeKeyAll.push(categoryId)
}
this.activeKey = this.activeKeyAll;
// console.log("=====================",this.activeKey)
}
this.processModalVisible = true;
}else {
this.$message.warning(res.message)
}
}).finally(()=>this.addApplyLoading = false);
},
onSearchProcess(value) {
this.searchProcessKey = value;
this.getProcessList()
},
/*验证流程表单是否配置人员*/
getNodeData(row,v,callback){
return new Promise((resolve, reject) => {
let ss = false;
let _this = this;
_this.postFormAction(_this.url.getProcessNodeByDepart,{
id:v.id,
departId:row
}).then(res => {
if (res.success) {
// 转换null为""
// console.log("res.result",res.result);
let arry=[];
for (let i = 0; i < res.result.length; i++) {
if (i!=0&&i!=res.result.length-1){
arry.push(res.result[i])
}
}
_this.nodeList=arry;
if (arry.length>0){
// console.log(_this.nodeList[0],"用户信息!")
// if (!_this.nodeList[0].users[0]){
// _this.$message.warning(v.name+"审批人员未配置,请配置后在申请!!!");
// ss= true;
// }
}
}
resolve(callback(ss));
});
});
},
async chooseProcess(v) {
// console.log("人员信息===",v);
let userInfo = sessionStorage.getItem('USER_INFORMATION');
let res = JSON.parse(userInfo);
// console.log("人员信息",res);
let re = false;
if(v.name != "预算计划采购流程" && v.name != "权限授权流程" && res.post != "系统管理员"){
await this.getNodeData(res.departIds,v,(result) => {
// console.log("-===========",result);
if(result){
re = true;
}
});
}
if (!re){
if (!v.routeName) {
this.$message.warning(
"该流程信息未配置表单,请联系开发人员!"
);
return;
}
this.lcModa.formComponent = this.getFormComponent(v.routeName).component;
this.lcModa.title = '发起流程:'+v.name;
this.lcModa.isNew = true;
this.lcModa.hieg = true;
this.lcModa.pictureId=v.id;
this.lcModa.procInstId='';
this.lcModa.processData = v;
this.lcModa.visible = true;
}
console.log("发起",v)
},
/*提交成功申请后*/
afterSub(formData){
this.lcModa.visible = false;
this.$message.success("操作成功!请前往我的申请列表提交审批!")
},
/*前往我的申请页面*/
handleToApplyList() {
this.$router.push({path:'/activiti/applyList'})
}
}
}
</script>
<style scoped>
@import '~@assets/less/common.less';
.forRadius {
border-radius: 5px;
}
/deep/.ant-modal {
overflow-y: hidden;
}
/deep/.ant-modal-content{
height: 100%;
overflow-y: scroll;
}
/deep/.ant-modal-body{
height: 100%;
/*overflow-y: scroll;*/
}
/deep/.ant-modal{
top:45px
}
</style>