132ee8c8 by 张猛

ztx个人审核

1 parent 6c6dcc02
......@@ -43,32 +43,36 @@
</view>
<view class="date" @click="goDetail(item)">
<uni-icons color="#AD181F" size="16" type="calendar-filled"></uni-icons>
{{ item.content?.commitTime }} 提交
{{ item.commitTime }} 提交
</view>
<view v-if="item?.wfCode" class="text-primary" @click="goDetail(item)">{{ item?.wfCode }}
<view v-if="item?.wfCode" class="text-primary" @click="goDetail(item)">{{ item.wfCode }}
</view>
<view class="name" @click="goDetail(item)">{{ item.name }}</view>
<view class="name" @click="goDetail(item)">{{ item.memName }}</view>
<view class="flexbox" @click="goDetail(item)">
<view>
人数合计
<view>{{ item.personCount }}</view>
<view>{{ item.allCount }}</view>
</view>
<view>
年限合计
<view>{{ item.totalYear }}</view>
<view>{{ item.yearCount }}</view>
</view>
<view>
提交单位
<view>{{ item.memberName }}</view>
新会员
<view>{{ item.newCount }}</view>
</view>
<view>
费用
<view>{{ (item.price * 1).toFixed(2) }}</view>
</view>
</view>
<view v-if="item.auditStatus==0" class="func">
<button @click="audit(item.recordId,'0')">拒绝</button>
<button @click="audit(item.recordId,'1')">同意</button>
</view>
<view v-if="item.auditStatus==1 && item.isView == 1" class="func">
<button @click="handleDelete(item)">撤回</button>
</view>
<!-- <view v-if="item.auditStatus==1 && item.isView == 1" class="func">-->
<!-- <button @click="handleDelete(item)">撤回</button>-->
<!-- </view>-->
</view>
</view>
......@@ -143,7 +147,6 @@ async function getList() {
const res = await api.auditList(queryParams.value)
list.value = res.rows
total.value = res.total
statistical.value = {
totalCost: 0,
personCount: 0,
......@@ -151,14 +154,12 @@ async function getList() {
oldPersonCount: 0,
totalYear: 0
}
for (const item of list.value) {
item.content = JSON.parse(item.content)
item.doc = JSON.parse(item.doc)
statistical.value.totalCost += (item.content.allFee * 1)
statistical.value.personCount += (item.content.personCount * 1)
statistical.value.newPersonCount += (item.content.newPersonCount * 1)
statistical.value.oldPersonCount += (item.content.oldPersonCount * 1)
statistical.value.totalYear += (item.content.totalYear * 1)
for (const val of list.value) {
statistical.value.totalCost += val.price * 1
statistical.value.personCount += val.allCount * 1
statistical.value.newPersonCount += val.newCount * 1
statistical.value.oldPersonCount += val.oldCount * 1
statistical.value.totalYear += val.yearCount * 1
}
uni.hideLoading()
......@@ -244,8 +245,14 @@ function goDetail(item) {
const form = encodeURIComponent(JSON.stringify(item))
// console.log(userType.value)
// let path =
// `/personalVip/auditDetail?form=${form}`
// uni.navigateTo({
// url: path
// });
let path =
`/personalVip/auditDetail?form=${form}`
`/personalVip/paymentDetail?form=${form}`
uni.navigateTo({
url: path
});
......
<template>
<view>
<view class="wBox">
<view class="tt">{{form.paymentName}}</view>
<view class="info">
<view><text>{{list.length}}</text></view>
</view>
<view class="userlist">
<view class="item" v-for="(n,index) in list" :key="index">
<view>
<view class="name">{{n.perName}}<text v-if="n.memberInfoName">({{n.memberInfoName || ''}})</text></view>
<view class="date">原有效期至 {{n.originValidityDate ? n.originValidityDate.slice(0,10) : '--'}}</view>
</view>
<view class="nian">
{{n.payYear}}
</view>
</view>
</view>
</view>
<view class="h3-padding" v-if="feelList.length>0">审核流程</view>
<view class="wBox" v-if="feelList.length>0">
<view class="stepItem" v-for="(n,index) in feelList" :key="index">
<view class="time">{{n.auditTime || '待审批'}}</view>
<view class="content">
<view class="status">
<text v-if="n.auditResult==0" class="text-primary"> 审核中</text>
<text v-if="n.auditResult==1" class="text-success">审核通过</text>
<text v-if="n.auditResult==2" class="text-danger"> 审核拒绝</text>
<text v-if="n.auditResult==3" class="text-warning"> 已撤回</text>
</view>
<view class="name">{{index+1}}</view>
<view class="deptName">{{n.auditDeptName || n.auditBy}}</view>
<view>备注:{{n.auditMsg || '/' }}</view>
</view>
</view>
</view>
</view>
<view>
<view class="wBox">
<view class="tt">{{ form.memName }}</view>
<view class="info" style="flex-wrap: wrap;">
<view class="w45">
<text class="text-danger"> {{ form?.allCount }}</text>
</view>
<view class="w45">新会员
<text class="text-primary"> {{ form?.newCount }}</text>
</view>
<view class="w45">续费合计
<text class="text-primary"> {{ form?.oldCount }}</text>
</view>
<view class="w45">费用合计
<text class="text-danger">{{ form?.price }}</text>
</view>
</view>
</view>
<view class="wBox">
<!-- <view class="tt">{{ // form.paymentName }}</view>-->
<view class="info">
<view>
<text>{{ list.length }}</text>
</view>
</view>
<view class="userlist">
<view v-for="(n,index) in list" :key="index" class="item">
<view>
<view class="name">{{ n.perName }}
<text v-if="n.memberInfoName">({{ n.memberInfoName || '' }})</text>
</view>
<view class="date">原有效期至 {{ n.originValidityDate ? n.originValidityDate.slice(0, 10) : '--' }}</view>
</view>
<view class="nian">
{{ n.payYear }}
</view>
</view>
</view>
</view>
<view v-if="feelList.length>0" class="h3-padding">审核流程</view>
<view v-if="feelList.length>0" class="wBox">
<view v-for="(n,index) in feelList" :key="index" class="stepItem">
<view class="time">{{ n.auditTime || '待审批' }}</view>
<view class="content">
<view class="status">
<text v-if="n.auditResult==0" class="text-primary"> 审核中</text>
<text v-if="n.auditResult==1" class="text-success">审核通过</text>
<text v-if="n.auditResult==2" class="text-danger"> 审核拒绝</text>
<text v-if="n.auditResult==3" class="text-warning"> 已撤回</text>
</view>
<view class="name">{{ index + 1 }}</view>
<view class="deptName">{{ n.auditDeptName || n.auditBy }}</view>
<view>备注:{{ n.auditMsg || '/' }}</view>
</view>
</view>
</view>
</view>
</template>
<script setup>
import * as api from '@/common/api.js'
import { ref } from 'vue'
import { onLoad } from '@dcloudio/uni-app'
// 查询参数(和PC保持一致)
const queryParams = ref({
rangeId: '',
pageNum: 1,
pageSize: 999
})
const form = ref({})
const list = ref([])
const feelList = ref([])
onLoad((option) => {
if (option.form) {
form.value = JSON.parse(decodeURIComponent(option.form))
queryParams.value.rangeId = form.value.rangId || form.value.rangeId
getList()
getAuditLogs()
}
})
async function getList() {
try {
const res = await api.listAPI(queryParams.value)
list.value = res.rows || []
} catch (e) {
list.value = []
console.error('获取成员失败', e)
}
}
function getAuditLogs() {
if (form.value.auditLogs) {
try {
feelList.value = JSON.parse(form.value.auditLogs)
} catch (e) {
feelList.value = []
}
}
}
import * as api from '@/common/api.js'
import {ref} from 'vue'
import {onLoad} from '@dcloudio/uni-app'
// 查询参数(和PC保持一致)
const queryParams = ref({
rangeId: '',
pageNum: 1,
pageSize: 999
})
const form = ref({})
const list = ref([])
const feelList = ref([])
onLoad((option) => {
if (option.form) {
form.value = JSON.parse(decodeURIComponent(option.form))
queryParams.value.rangeId = form.value.rangId || form.value.rangeId
getList()
getAuditLogs()
}
console.log(form.value)
})
async function getList() {
try {
const res = await api.listAPI(queryParams.value)
list.value = res.rows || []
} catch (e) {
list.value = []
console.error('获取成员失败', e)
}
}
function getAuditLogs() {
if (form.value.auditLogs) {
try {
feelList.value = JSON.parse(form.value.auditLogs)
} catch (e) {
feelList.value = []
}
}
}
</script>
<style scoped lang="scss">
.wBox {
width: 700rpx;
padding: 30rpx;
margin: 20rpx auto 0;
background: #FFFFFF;
box-shadow: 0rpx 12rpx 116rpx 0rpx rgba(196, 203, 214, 0.1);
border-radius: 15rpx;
.tt {
color: #0A1629;
font-size: 30rpx;
}
}
.userlist {
.item {
border-bottom: 1px dashed #e5e5e5;
position: relative;
padding: 20rpx 0;
.date {
margin-top: 10rpx;
font-size: 24rpx;
color: #999;
}
.name {
font-size: 30rpx;
text {
margin-left: 1em;
color: #4C5359;
font-size: 26rpx;
}
}
.nian {
position: absolute;
right: 0;
top: 30rpx;
font-size: 30rpx;
color: #AD181F;
}
}
}
.info {
display: flex;
margin: 30rpx 0 20rpx;
font-size: 28rpx;
view {
color: #7D8592;
margin-right: 20rpx;
text {
color: #AD181F;
}
}
}
.h3-padding {
padding: 20rpx 30rpx 0;
font-size: 30rpx;
font-weight: 500;
}
.stepItem {
border-left: 2rpx solid #E60012;
padding-left: 20rpx;
position: relative;
margin-bottom: 30rpx;
&:before {
content: '';
width: 12rpx;
height: 12rpx;
background: #E60012;
border-radius: 50%;
position: absolute;
left: -7rpx;
top: 0;
}
.time {
font-size: 24rpx;
color: #999;
}
.content {
margin-top: 10rpx;
font-size: 28rpx;
.status {
margin-bottom: 8rpx;
}
.name {
font-weight: 500;
}
.deptName {
margin: 6rpx 0;
color: #666;
}
}
}
</style>
\ No newline at end of file
<style lang="scss" scoped>
.wBox {
width: 700rpx;
padding: 30rpx;
margin: 20rpx auto 0;
background: #FFFFFF;
box-shadow: 0rpx 12rpx 116rpx 0rpx rgba(196, 203, 214, 0.1);
border-radius: 15rpx;
.tt {
color: #0A1629;
font-size: 30rpx;
}
}
.userlist {
.item {
border-bottom: 1px dashed #e5e5e5;
position: relative;
padding: 20rpx 0;
.date {
margin-top: 10rpx;
font-size: 24rpx;
color: #999;
}
.name {
font-size: 30rpx;
text {
margin-left: 1em;
color: #4C5359;
font-size: 26rpx;
}
}
.nian {
position: absolute;
right: 0;
top: 30rpx;
font-size: 30rpx;
color: #AD181F;
}
}
}
.info {
display: flex;
margin: 30rpx 0 20rpx;
font-size: 28rpx;
view {
color: #7D8592;
margin-right: 20rpx;
text {
color: #AD181F;
}
}
}
.h3-padding {
padding: 20rpx 30rpx 0;
font-size: 30rpx;
font-weight: 500;
}
.stepItem {
border-left: 2rpx solid #E60012;
padding-left: 20rpx;
position: relative;
margin-bottom: 30rpx;
&:before {
content: '';
width: 12rpx;
height: 12rpx;
background: #E60012;
border-radius: 50%;
position: absolute;
left: -7rpx;
top: 0;
}
.time {
font-size: 24rpx;
color: #999;
}
.content {
margin-top: 10rpx;
font-size: 28rpx;
.status {
margin-bottom: 8rpx;
}
.name {
font-weight: 500;
}
.deptName {
margin: 6rpx 0;
color: #666;
}
}
}
</style>
......
Styling with Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!