From 663dbe4ddca1fa409e6acbc1f77d924c161b0c39 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期一, 09 六月 2025 17:04:50 +0800
Subject: [PATCH] 提交一把订单

---
 server/service/src/main/java/com/doumee/service/business/impl/SolutionsServiceImpl.java |   25 +++++++++++++++++++++++--
 1 files changed, 23 insertions(+), 2 deletions(-)

diff --git a/server/service/src/main/java/com/doumee/service/business/impl/SolutionsServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/SolutionsServiceImpl.java
index 3ecda64..fc9f3f2 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/SolutionsServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/SolutionsServiceImpl.java
@@ -98,6 +98,7 @@
         solutions.setDataType(Constants.ZERO);
         solutions.setStatus(Constants.ZERO);
         solutions.setCorrectWarnTime(solutionsBase.getCorrectWarnTime());
+        solutions.setDelOnlyReplace(solutionsBase.getDelOnlyReplace());
         //2024骞�6鏈�17鏃�15:56:18 浠呮敮鎸佹浛鎹㈡ā寮忎笅锛屾壒澧炴棩鏈� 绛変簬 鎵瑰噺鏃ユ湡
         if(Constants.equalsInteger(solutions.getDelOnlyReplace(),Constants.ONE)){
             solutions.setAddValidDays(solutions.getDelValidDays());
@@ -141,6 +142,7 @@
     private void dealWorkType(Solutions solutions, Solutions newModel, List<SolutionWorktype> worktypes) {
 
         int num =0;
+        List<SolutionWorktype> typeList = new ArrayList<>();
         for(SolutionWorktype type : worktypes) {
             //鍩虹鐗堟湰
             SolutionWorktype w = new SolutionWorktype();
@@ -157,8 +159,12 @@
             //鍘嗗彶鐗堟湰鐨勫伐绉嶄俊鎭�
             SolutionWorktype newType = new SolutionWorktype();
             BeanUtils.copyProperties(w, newType);
+            newType.setId(null);
             newType.setSolutionId(newModel.getId());
-            solutionWorktypeJoinMapper.insert(newType);
+            typeList.add(newType);
+        }
+        if(typeList.size()>0){
+            solutionWorktypeJoinMapper.insert(typeList);
         }
     }
 
@@ -221,7 +227,22 @@
 
     @Override
     public void deleteById(Integer id) {
-        solutionsMapper.deleteById(id);
+        //鏌ヨ鏄惁宸插瓨鍦ㄤ娇鐢ㄤ腑鐨勪繚鍗�
+        if(insuranceApplyMapper.selectCount(new QueryWrapper<InsuranceApply>().lambda()
+                .apply(" solution_id in (  select id from solutions where BASE_ID = "+id+" or id = "+id+"  )" )
+                .notIn(InsuranceApply::getStatus
+                        ,Constants.InsuranceApplyStatus.PLATFORM_RETURN.getKey()
+                        ,Constants.InsuranceApplyStatus.CLOSE.getKey()
+                        ,Constants.InsuranceApplyStatus.WTB_CLOSED.getKey()
+                )
+        )>Constants.ZERO){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀛樺湪宸叉姇淇濈殑淇濆崟鏁版嵁,鏃犳硶杩涜鍒犻櫎");
+        };
+        solutionsMapper.update(null,new UpdateWrapper<Solutions>()
+                .lambda()
+                .set(Solutions::getIsdeleted,Constants.ONE)
+                .and(i->i.eq(Solutions::getId,id).or().eq(Solutions::getBaseId,id))
+        );
     }
 
     @Override

--
Gitblit v1.9.3