绩效考核手机版
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.
 
 
 
 

355 lines
9.6 KiB

<template>
<view class="container">
<uni-card :is-shadow="false">
<view class="">
<text class="uni-body">审批编号{{receiveData.outid}}</text>
</view>
<view class="titlesize">
<text class="uni-body ">{{contdata.title}}</text>
</view>
</uni-card>
<uni-card :is-shadow="false" style="margin-bottom: 10px;">
<uni-row class="demo-uni-row" >
<uni-col :span="5">
<view class="demo-uni-col dark">考核纬度</view>
</uni-col>
<uni-col :span="19">
<view class="demo-uni-col light">{{contdata.dimension}}</view>
</uni-col>
</uni-row>
<uni-row class="demo-uni-row" >
<uni-col :span="5">
<view class="demo-uni-col dark">考核指标</view>
</uni-col>
<uni-col :span="19">
<view class="demo-uni-col light">{{contdata.target}}</view>
</uni-col>
</uni-row>
<uni-row class="demo-uni-row" >
<uni-col :span="5">
<view class="demo-uni-col dark">考核项目</view>
</uni-col>
<uni-col :span="19">
<view class="demo-uni-col light">{{contdata.targetsun}}</view>
</uni-col>
</uni-row>
<uni-row class="demo-uni-row" >
<uni-col :span="5">
<view class="demo-uni-col dark">考核内容</view>
</uni-col>
<uni-col :span="19">
<view class="demo-uni-col light">{{contdata.detailedtargent}}</view>
</uni-col>
</uni-row>
<uni-row class="demo-uni-row" >
<uni-col :span="5">
<view class="demo-uni-col dark">考核标准</view>
</uni-col>
<uni-col :span="19">
<view class="demo-uni-col light">{{contdata.content}}</view>
</uni-col>
</uni-row>
<uni-row class="demo-uni-row" >
<uni-col :span="5">
<view class="demo-uni-col dark">{{contdata.lanmuname}}</view>
</uni-col>
<uni-col :span="19">
<view class="demo-uni-col light">{{contdata.reasoninfo}}</view>
</uni-col>
</uni-row>
<uni-row class="demo-uni-row" >
<uni-col :span="5">
<view class="demo-uni-col dark">考核原因</view>
</uni-col>
<uni-col :span="19">
<view class="demo-uni-col light">{{contdata.reason}}</view>
</uni-col>
</uni-row>
<uni-row class="demo-uni-row" v-if="contdata.enclosure" >
<uni-col :span="5">
<view class="demo-uni-col dark">附件:</view>
</uni-col>
<uni-col :span="19">
<uni-grid style="margin-top: 20rpx;" :column="3" :highlight="true" >
<uni-grid-item v-for="(encItem, encindex) in contdata.enclosure" :index="encindex" :key="encindex">
<view class="grid-item-box" v-if="encItem.type==1" style="background-color: #fff;">
<image :src="encItem.filepath" ></image>
</view>
<view class="grid-item-box" v-if="encItem.type==2" style="background-color: #fff;">
<uni-icons type="videocam" :size="30" color="#777" />
<text class="text">文本信息</text>
</view>
<view class="grid-item-box" v-if="encItem.type>2" style="background-color: #fff;">
<uni-icons type="wallet" :size="30" color="#777" />
<text class="text">文本信息</text>
</view>
</uni-grid-item>
</uni-grid>
</uni-col>
</uni-row>
</uni-card>
<uni-card :isShadow="false" v-if="receiveData.isset==2" style="margin-bottom: 10px;">
<view class="appideabox">
<uni-easyinput type="textarea" v-model="approvalIdea" placeholder="请输入审批意见" />
</view>
<view class="example-body">
<uni-row>
<uni-col :span="11"><button :loading="loading" type="primary" @click="xingOperation(1)">批准</button></uni-col>
<uni-col :span="2" style="min-height: 1px;"></uni-col>
<uni-col :span="11"><button :loading="loading" type="warn" @click="xingOperation(2)" >驳回</button></uni-col>
</uni-row>
</view>
</uni-card>
<uni-card :isShadow="false" >
<uni-steps :options="flowList" active-color="#007AFF" :active="active" direction="column" />
</uni-card>
<u-toast ref="uToast"></u-toast>
</view>
</template>
<script> //定量
export default {
data() {
return {
loading:false,
approvalIdea:"",
active:1,
headerVerify:{
userkey:"",
token:"",
userCont:""
},
receiveData:{
},
contdata:[],
flowList:[]
};
},
onLoad(option) {
console.log("option",option)
console.log("option",JSON.parse(option.data))
let _this = this
//判断Token是否有效
let systemCache = _this.$commonMethod.getSystemCacheDate('myCache')
if(!systemCache){
_this.$commonMethod.JumpUrl('/pages/login/login')
}else{
let currentTime = new Date().getTime() - systemCache.tokenTime
if (currentTime >= 10800000){
_this.$commonMethod.verifyPowerIsTrue('myCache')
}
}
_this.headerVerify.userkey = systemCache.userKey
_this.headerVerify.token = systemCache.token
_this.headerVerify.userCont = systemCache.userInfo
this.receiveData = JSON.parse(option.data)
},
onReady(){
this.getDataCont()
},
methods:{
//获取数据
getDataCont(){
let _this = this
let sunTargetDate = {
id:_this.receiveData.outid*1,
outid:_this.receiveData.outid.toString()
}
//获取审批列表
uni.request({
url:_this.$commonMethod.localhostUrl+'/api/eval/lookdutkscoreflow',
header: {
'Content-Type': 'application/json', //自定义请求头信息
// 'User-Agent':250,
'user-key': _this.headerVerify.userkey,
'user-token':_this.headerVerify.token
},
method:'POST',//请求方式,必须为大写
data:sunTargetDate,
success: (res) => {
console.log(res)
let callBackDate = res.data
if(callBackDate.code == 0){
console.log("列表值---------------->",callBackDate.data)
_this.contdata=callBackDate.data
_this.contdata.flowmapall.forEach(item=>{
let userList = new Array //节点审批人
console.log(item.userlist,"item.userlist")
if(item.userlist != null && item.userlist.length > 0){
item.userlist.forEach(usItem=>{
let usLog = new Array //节点审批人审批记录
if(usItem.log != null && usItem.log.length > 0){
usItem.log.forEach(logItem=>{
let logCont = {
state:logItem.state,
time:logItem.time,
enclosure:logItem.enclosure
}
usLog.push(logCont)
});
}
let userCont = { //节点审批人信息
id:usItem.id,
name:usItem.name,
icon:usItem.icon,
groupname:usItem.groupname,
departmentname:usItem.departmentname,
postname:usItem.postname,
workshopname:usItem.workshopname,
userlist:usLog
}
userList.push(userCont)
});
}
let flowCont = { //流程图
title: item.nodename,
desc: item.step,
state: item.state,
userlist:userList
}
_this.flowList.push(flowCont)
})
}else{
_this.$refs.uToast.show({
message: callBackDate.msg,
duration: 1000 * 2,
position:'bottom',
})
}
},
fail:function(e){
_this.$refs.uToast.show({
message: e,
duration: 1000 * 2,
position:'bottom',
})
}
});
},
//审批处理
xingOperation(vlaIsTrue){
let _this = this
_this.loading = true
// console.log("审批处理-----1------>",vlaIsTrue)
// console.log("审批处理-----2------>",_this.approvalIdea)
uni.request({
url:_this.$commonMethod.localhostUrl+'/api/qual/operation',
header: {
'Content-Type': 'application/json', //自定义请求头信息
// 'User-Agent':250,
'user-key': _this.headerVerify.userkey,
'user-token': _this.headerVerify.token
},
method:'POST',//请求方式,必须为大写
data:{
// group:_this.headerVerify.userCont.company, //公司
orderid:_this.receiveData.outid, //部门
yesorno:vlaIsTrue,
content:_this.approvalIdea
},
success: (res) => {
console.log(res)
let callBackDate = res.data
if(callBackDate.code == 0){
_this.loading = false
let chartDate = callBackDate.data
console.log('接口返回--login--2--',chartDate);
_this.receiveData.isset = 1
_this.$refs.uToast.show({
message: callBackDate.msg,
duration: 1000 * 1,
position:'bottom',
complete(){
uni.navigateBack();
}
})
}else{
_this.loading = false
_this.$refs.uToast.show({
message: callBackDate.msg,
duration: 1000 * 1,
position:'bottom',
})
}
},
fail:function(e){
_this.loading = false
console.log('接口返回--login--2--',e);
_this.$refs.uToast.show({
message: e,
duration: 1000 * 1,
position:'bottom',
})
},
})
}
}
}
</script>
<style lang="scss">
.titlesize{
font-size: 40rpx;
color: #000000;
margin-top: 20rpx;
}
.demo-uni-col{
padding-top: 20rpx;
}
.grid-item-box{
overflow: hidden;
image{
width: 94%;
height: 78px;
margin:2px 3%;
}
}
.card-actions {
display: flex;
flex-direction: row;
justify-content: space-around;
align-items: center;
height: 45px;
border-top: 1px #eee solid;
}
.card-actions-item {
display: flex;
flex-direction: row;
align-items: center;
}
.card-actions-item-text {
font-size: 12px;
color: #666;
margin-left: 5px;
}
.example-body {
/* #ifndef APP-NVUE */
display: block;
/* #endif */
// padding: 5rpx 10rpx 0;
overflow: hidden;
}
.appideabox{
padding: 10px 0;
}
</style>