From fc6b946b1020ddff4fe2b01c9e439680cbda6b47 Mon Sep 17 00:00:00 2001
From: luohairen <3399054449@qq.com>
Date: 星期三, 04 十二月 2024 09:32:53 +0800
Subject: [PATCH] 分角色展示项目计划,实现不同角色的功能

---
 business/src/main/java/com/ycl/service/impl/ProjectPlanExamineRecordServiceImpl.java |   42 ++++++++++++++++++++++++++++--------------
 1 files changed, 28 insertions(+), 14 deletions(-)

diff --git a/business/src/main/java/com/ycl/service/impl/ProjectPlanExamineRecordServiceImpl.java b/business/src/main/java/com/ycl/service/impl/ProjectPlanExamineRecordServiceImpl.java
index 381c0b0..a176a1c 100644
--- a/business/src/main/java/com/ycl/service/impl/ProjectPlanExamineRecordServiceImpl.java
+++ b/business/src/main/java/com/ycl/service/impl/ProjectPlanExamineRecordServiceImpl.java
@@ -4,10 +4,12 @@
 import com.baomidou.mybatisplus.extension.conditions.update.LambdaUpdateChainWrapper;
 import com.ycl.common.utils.SecurityUtils;
 import com.ycl.domain.entity.ProjectPlanExamineRecord;
+import com.ycl.domain.entity.ProjectPlanInfo;
 import com.ycl.domain.entity.ProjectPlanRecord;
 import com.ycl.domain.vo.DepartmentApprovalResponseVO;
 import com.ycl.domain.vo.ProjectProcessToDoVo;
 import com.ycl.mapper.ProjectPlanExamineRecordMapper;
+import com.ycl.mapper.ProjectPlanInfoMapper;
 import com.ycl.mapper.ProjectPlanRecordMapper;
 import com.ycl.service.ProjectPlanExamineRecordService;
 import com.ycl.common.base.Result;
@@ -37,6 +39,7 @@
 
     private final ProjectPlanExamineRecordMapper projectPlanExamineRecordMapper;
     private final ProjectPlanRecordMapper projectPlanRecordMapper;
+    private final ProjectPlanInfoMapper projectPlanInfoMapper;
 
     /**
      * 娣诲姞
@@ -162,22 +165,33 @@
 
     @Override
     public Result saveExamine(ProjectPlanExamineRecordForm form) {
-        // 鍒ゆ柇锛屽鏋滈兘鍚屾剰锛屽垯鐩存帴鏇存柊瀹℃壒璁板綍
+        // 鏇存柊瀹℃壒璁板綍
+        ProjectPlanExamineRecord item = ProjectPlanExamineRecordForm.getEntityByForm(form, null);
+        item.setId(form.getId().longValue());
+        item.setDepartmentUserId(SecurityUtils.getUserId());
+        item.setManagerUserId(SecurityUtils.getUserId());
+        baseMapper.updateById(item);
+        Long projectPlanRecordId = baseMapper.selectById(item.getId()).getProjectPlanRecordId();
+        // 濡傛灉鍚屾剰锛岃鍒掗」鐘舵�佷负宸查�氳繃锛屽苟涓旀柊澧炰竴鏉¢」鐩繘搴﹀鏍歌褰曪紝鍚﹀垯涓哄凡椹冲洖
         if (null != form.getDepartmentExamine() && null != form.getManageExamine() && form.getDepartmentExamine() == 0 && form.getManageExamine() == 0) {
-            ProjectPlanExamineRecord projectPlanExamineRecord = ProjectPlanExamineRecordForm.getEntityByForm(form, null);
-            projectPlanExamineRecord.setId(form.getId().longValue());
-            projectPlanExamineRecord.setDepartmentUserId(SecurityUtils.getUserId());
-            projectPlanExamineRecord.setManagerUserId(SecurityUtils.getUserId());
-            baseMapper.updateById(projectPlanExamineRecord);
+            new LambdaUpdateChainWrapper<>(projectPlanInfoMapper)
+                    .eq(ProjectPlanInfo::getId, form.getProjectPlanInfoId())
+                    .set(ProjectPlanInfo::getPlanStatus, 2)
+                    .update();
+            // 鏂板椤圭洰杩涘害瀹℃牳璁板綍
+            ProjectPlanExamineRecord newItem = new ProjectPlanExamineRecord();
+            newItem.setProjectPlanRecordId(projectPlanRecordId); // 椤圭洰璁″垝璁板綍ID
+            newItem.setProjectPlanInfoId(item.getProjectPlanInfoId()); // 椤圭洰璁″垝椤笽D
+            newItem.setEventType(2); // 杩涘害涓婃姤
+            newItem.setDeleted(0); // 鏈垹闄�
+            baseMapper.insert(newItem);
+        }else{
+            new LambdaUpdateChainWrapper<>(projectPlanInfoMapper)
+                    .eq(ProjectPlanInfo::getId, form.getProjectPlanInfoId())
+                    .set(ProjectPlanInfo::getPlanStatus, 1)
+                    .update();
         }
-        // 鍚﹀垯锛屽皢椤圭洰璁板綍璁剧疆涓烘湭涓婃姤锛屽苟灏嗚褰曢�昏緫鍒犻櫎
-        new LambdaUpdateChainWrapper<>(projectPlanRecordMapper)
-                .eq(ProjectPlanRecord::getId, form.getProjectPlanRecordId())
-                .set(ProjectPlanRecord::getReportStatus, 1);
-        new LambdaUpdateChainWrapper<>(baseMapper)
-                .eq(ProjectPlanExamineRecord::getProjectPlanRecordId, form.getProjectPlanRecordId())
-                .remove();
-        return Result.ok("鍥炲鎴愬姛");
+        return Result.ok("瀹℃壒鎴愬姛");
     }
 
     @Override

--
Gitblit v1.8.0