From 9cd375c82cf24394ed94180149bba732a0e90446 Mon Sep 17 00:00:00 2001
From: zhouwenxuan <1175765986@qq.com>
Date: 星期一, 22 一月 2024 16:38:53 +0800
Subject: [PATCH] 项目跳转
---
src/api/projectManage/project.js | 5 +
src/views/safetyReview/projectManage/process.vue | 25 ++++++++
src/views/safetyReview/userManage/expertUsers/components/projectDialog.vue | 50 ++++++++++++----
src/views/safetyReview/projectManage/index.vue | 71 ++++++++++++++++-------
4 files changed, 115 insertions(+), 36 deletions(-)
diff --git a/src/api/projectManage/project.js b/src/api/projectManage/project.js
index d2cfa02..8f2e6cd 100644
--- a/src/api/projectManage/project.js
+++ b/src/api/projectManage/project.js
@@ -17,10 +17,11 @@
})
}
-export function getProjectStatistics() {
+export function getProjectStatistics(params) {
return request({
url: '/manage/project/statistics',
- method: 'get'
+ method: 'get',
+ params: params
})
}
diff --git a/src/views/safetyReview/projectManage/index.vue b/src/views/safetyReview/projectManage/index.vue
index f5abb09..10ca670 100644
--- a/src/views/safetyReview/projectManage/index.vue
+++ b/src/views/safetyReview/projectManage/index.vue
@@ -97,18 +97,33 @@
</div>
</template>
</el-table-column>
- <el-table-column label="项目实施天数" prop="" align="center" width="150"/>
- <el-table-column label="项目变更" prop="" align="center" width="120"/>
- <el-table-column label="预估金额(万元)" prop="" align="center" width="130"/>
- <el-table-column label="归档金额(万元)" prop="" align="center" width="130"/>
- <el-table-column label="缺失要件" align="center" width="150">
+ <el-table-column label="项目实施天数" prop="filingDate" align="center" width="150"/>
+ <el-table-column label="项目变更" prop="" align="center" width="120">
<template #default="scope">
<div style="cursor:pointer;color: #3b82f6;" >
- <span>{{scope.row.materialCnt}}</span>
+ <span v-if="scope.row.process !== 1" @click="goMenu('toFive',scope.row)">{{}}</span>
+ <span v-else></span>
</div>
</template>
</el-table-column>
- <el-table-column label="归档确认" prop="" align="center" width="150"/>
+ <el-table-column label="预估金额(万元)" prop="contractMoney" align="center" width="130"/>
+ <el-table-column label="归档金额(万元)" prop="actualContractMoney" align="center" width="130"/>
+ <el-table-column label="缺失要件" align="center" width="150">
+ <template #default="scope">
+ <div style="cursor:pointer;color: #3b82f6;" >
+ <span v-if="scope.row.process === 5" @click="goMenu('toTwelve',scope.row)">{{scope.row.materialCnt}}</span>
+ <span v-else></span>
+ </div>
+ </template>
+ </el-table-column>
+ <el-table-column label="归档确认" prop="" align="center" width="150">
+ <template #default="scope">
+ <div style="cursor:pointer;color: #3b82f6;" >
+ <span v-if="scope.row.process === 5" @click="goMenu('toThirteen',scope.row)">{{}}</span>
+ <span v-else></span>
+ </div>
+ </template>
+ </el-table-column>
<el-table-column fixed="right" label="操作" align="center" class-name="small-padding fixed-width" width="180">
<template #default="scope">
<el-button link type="primary" @click="toProcess('view',scope.row)">查看</el-button>
@@ -181,7 +196,7 @@
</el-select>
</el-form-item>
<el-form-item label="缺失要件">
- <el-select v-model="search.queryParams.miss" class="m-2" size="large" placeholder="请选择" style="width: 100%" >
+ <el-select v-model="search.queryParams.params.lostMaterial" class="m-2" size="large" placeholder="请选择" style="width: 100%" >
<el-option
v-for="item in missingList"
:key="item.id"
@@ -239,6 +254,7 @@
estimateType: '',
params:{
projectPhase: '',
+ lostMaterial: null
}
},
num: {
@@ -257,13 +273,13 @@
const estimateTypeList = ref([]);
const missingList = ref([
{
- id: 0,
- label: '否'
- },
- {
id: 1,
label: '是'
},
+ {
+ id: 0,
+ label: '否'
+ }
])
const tableRef = ref(null);
const tableHeight = ref(0);
@@ -299,10 +315,12 @@
...item,
process: item.reportProgress <= 4 ? 1 : item.reportProgress > 4 && item.reportProgress <= 6 ? 2 : item.reportProgress > 6 && item.reportProgress <= 9 ? 3 : item.reportProgress > 9 && item.reportProgress <= 11 ? 4 : 5,
leaderName: item.leader ? item.leader.name : '',
- area: item.district ? item.province + '/' + item.city + '/' + item.district : item.city?item.province + '/' + item.city:item.province ,
+ area: item.district ? item.province + '/' + item.city + '/' + item.district : item.city?item.province + '/' + item.city:item.province ,
+ filingDate: item.filingDate ? item.filingDate : conversionDays(item.createTime),
+ contractMoney: item.contract ? item.contract.contractMoney : '',
+ actualContractMoney: item.contract ? item.contract.actualContractMoney : ''
}
})
- console.log('data',dataList.value)
total.value = res.data.total
loading.value = false;
}else{
@@ -310,9 +328,11 @@
}
}
const getStatistics = async () => {
- const res = await getProjectStatistics();
+ const {pageNum,pageSize, ...data} = JSON.parse(JSON.stringify(search.queryParams))
+ console.log("data",data)
+ const res = await getProjectStatistics(data);
if(res.code == 200){
- console.log("res",res)
+ console.log("res统计",res)
search.num = res.data
}else{
@@ -328,9 +348,9 @@
search.queryParams.pageNum = val
getList()
}
-const toProcess = (type,value) => {
+const toProcess = (type,value,toPath) => {
value.type = type;
- router.push({ path: '/process', query: {id: value.id, type: type}});
+ router.push({ path: '/process', query: {id: value.id, type: type, toPath: toPath}});
}
const getArea = async ()=>{
@@ -415,6 +435,10 @@
getStatistics();
showDrawer.value = false;
}
+const conversionDays = (createTime) => {
+ let day = Date.now() - new Date(createTime).getTime();//日期转时间戳
+ return Math.floor(day / 86400000) ;//时间戳获取天数
+}
const handleChange = (value) => {
// if(state.registerForm.agency.attribute == 0){
// state.registerForm.agency.province = '新疆维吾尔自治区'
@@ -450,13 +474,18 @@
}
}
},
- '项目实施天数': '',
+ '项目实施天数': 'filingDate',
'项目变更': '',
- '预估金额(万元)': '',
- '归档金额(万元)': '',
+ '预估金额(万元)': 'contractMoney',
+ '归档金额(万元)': 'actualContractMoney',
'缺失要件': 'materialCnt',
'归档确认': ''
});
+const goMenu = (toPath,val) => {
+ console.log("val",val)
+ toProcess('edit',val,toPath);
+}
+
</script>
diff --git a/src/views/safetyReview/projectManage/process.vue b/src/views/safetyReview/projectManage/process.vue
index 6c494dc..d1a2bdf 100644
--- a/src/views/safetyReview/projectManage/process.vue
+++ b/src/views/safetyReview/projectManage/process.vue
@@ -228,6 +228,7 @@
const middleContentHeight = ref(0)
const projectId = ref()
const projectStatus = ref()
+const toPath = ref();
onMounted(() => {
middleHeight.value = window.innerHeight - 250;
middleContentHeight.value = window.innerHeight - 385;
@@ -239,6 +240,7 @@
if(route.query.type !== 'add'){
projectStatus.value = route.query.type;
projectId.value = route.query.id;
+ toPath.value = route.query.toPath;
getStatus(projectId.value);
}else {
projectStatus.value = route.query.type;
@@ -258,6 +260,10 @@
const getStatus = async (projectId) => {
const res = await getProjectStatus(projectId);
if(res.code == 200){
+ let fiveObj = {}
+ if(toPath.value && toPath.value === 'toFive' ){
+ fiveObj = menuList.value[1].subMenus[0]
+ }
if(res.data <= 4 ){
menuList.value[0].subMenus.forEach(item => {
if(item.id <= res.data){
@@ -285,6 +291,7 @@
if(res.data === 4){
menuList.value[0].subMenus[3].status = 3;
}
+
menuList.value[1].subMenus.forEach(item => {
if(item.id <= res.data) {
item.status = 2
@@ -307,6 +314,7 @@
menuList.value[0].status = 2;
menuList.value[1].status = 1;
console.log("menu22",menuList.value)
+
}
if(res.data >= 6 && res.data <= 9){
setMenuList(0);
@@ -374,6 +382,8 @@
if(res.data === 11){
menuList.value[3].subMenus[1].status = 3;
}
+ let twelveObj = {};
+ let thirteenObj = {};
menuList.value[4].subMenus.forEach(item => {
if(item.id <= res.data) {
item.status = 2
@@ -401,9 +411,22 @@
menuList.value[4].status = 2;
selectedObj.value =item;
}
+ if(toPath.value && toPath.value === 'toTwelve' && item.id === 12){
+ twelveObj = item;
+ }else if(toPath.value && toPath.value === 'toThirteen' && item.id === 13){
+ thirteenObj = item;
+ }
})
-
+ if(toPath.value && toPath.value === 'toTwelve' && twelveObj){
+ chooseSubMenu(twelveObj,true)
+ }else if(toPath.value && toPath.value === 'toThirteen' && thirteenObj){
+ chooseSubMenu(thirteenObj,true)
+ }
}
+ if(toPath.value && toPath.value === 'toFive' && fiveObj){
+ chooseSubMenu(fiveObj,true)
+ }
+
}else{
ElMessage.warning(res.message)
}
diff --git a/src/views/safetyReview/userManage/expertUsers/components/projectDialog.vue b/src/views/safetyReview/userManage/expertUsers/components/projectDialog.vue
index 1bff3f6..70dedc2 100644
--- a/src/views/safetyReview/userManage/expertUsers/components/projectDialog.vue
+++ b/src/views/safetyReview/userManage/expertUsers/components/projectDialog.vue
@@ -13,7 +13,7 @@
<el-table-column label="委托单位" prop="client" align="center" :show-overflow-tooltip="true" width="180"/>
<el-table-column label="所属地市" prop="updateTime" align="center" width="250">
<template #default="scope">
- {{scope.row.province}}/{{scope.row.city}}
+ {{scope.row.area}}
</template>
</el-table-column>
<el-table-column label="评价类型" prop="estimateTypeName" align="center" width="150"/>
@@ -38,18 +38,33 @@
</div>
</template>
</el-table-column>
- <el-table-column label="项目实施天数" prop="" align="center" width="150"/>
- <el-table-column label="项目变更" prop="" align="center" width="120"/>
- <el-table-column label="预估金额(万元)" prop="" align="center" width="130"/>
- <el-table-column label="归档金额(万元)" prop="" align="center" width="130"/>
- <el-table-column label="缺失要件" prop="" align="center" width="150">
+ <el-table-column label="项目实施天数" prop="filingDate" align="center" width="150"/>
+ <el-table-column label="项目变更" prop="" align="center" width="120">
<template #default="scope">
<div style="cursor:pointer;color: #3b82f6;" >
- <span>{{scope.row.materialCnt}}</span>
+ <span v-if="scope.row.process !== 1" @click="goMenu('toFive',scope.row)">{{}}</span>
+ <span v-else></span>
</div>
</template>
</el-table-column>
- <el-table-column label="归档确认" prop="" align="center" width="150"/>
+ <el-table-column label="预估金额(万元)" prop="contractMoney" align="center" width="130"/>
+ <el-table-column label="归档金额(万元)" prop="actualContractMoney" align="center" width="130"/>
+ <el-table-column label="缺失要件" prop="" align="center" width="150">
+ <template #default="scope">
+ <div style="cursor:pointer;color: #3b82f6;" >
+ <span v-if="scope.row.process === 5" @click="goMenu('toTwelve',scope.row)">{{scope.row.materialCnt}}</span>
+ <span v-else></span>
+ </div>
+ </template>
+ </el-table-column>
+ <el-table-column label="归档确认" prop="" align="center" width="150">
+ <template #default="scope">
+ <div style="cursor:pointer;color: #3b82f6;" >
+ <span v-if="scope.row.process === 5" @click="goMenu('toThirteen',scope.row)">{{}}</span>
+ <span v-else></span>
+ </div>
+ </template>
+ </el-table-column>
<el-table-column label="操作" fixed="right" align="center" class-name="small-padding fixed-width" width="180">
<template #default="scope">
<el-button link type="primary" @click="toProcess('view',scope.row)">查看</el-button>
@@ -108,7 +123,11 @@
return {
...item,
process: item.reportProgress <=4 ? 1 : item.reportProgress >4 && item.reportProgress <=6 ? 2 : item.reportProgress >6 && item.reportProgress <=9 ? 3 :item.reportProgress >9 && item.reportProgress <=11 ? 4:5,
- leaderName: item.leader ? item.leader.name : ''
+ leaderName: item.leader ? item.leader.name : '',
+ area: item.district ? item.province + '/' + item.city + '/' + item.district : item.city?item.province + '/' + item.city:item.province ,
+ filingDate: item.filingDate ? item.filingDate : conversionDays(item.createTime),
+ contractMoney: item.contract ? item.contract.contractMoney : '',
+ actualContractMoney: item.contract ? item.contract.actualContractMoney : ''
}
})
console.log(dataList.value,'dataList.value')
@@ -129,12 +148,19 @@
getList()
}
-const toProcess = (type,value) => {
+const toProcess = (type,value,toPath) => {
dialogVisible.value = false;
value.type = type;
- router.push({ path: '/process', query: {id: value.id, type: type}});
+ router.push({ path: '/process', query: {id: value.id, type: type, toPath: toPath}});
}
-
+const goMenu = (toPath,val) => {
+ console.log("val",val)
+ toProcess('edit',val,toPath);
+}
+const conversionDays = (createTime) => {
+ let day = Date.now() - new Date(createTime).getTime();//日期转时间戳
+ return Math.floor(day / 86400000) ;//时间戳获取天数
+}
defineExpose({
openDialog
--
Gitblit v1.9.2