From cab3425bb92d01f3494eb25c1f299038dc634c65 Mon Sep 17 00:00:00 2001
From: Your Name <you@example.com>
Date: 星期三, 15 三月 2023 23:43:48 +0800
Subject: [PATCH] 优化保养转单功能

---
 service-user/src/main/java/com/java110/user/cmd/examine/UpdateExamineStaffCmd.java |   78 +++++++++++++++++++++++++++++++++++++++
 1 files changed, 78 insertions(+), 0 deletions(-)

diff --git a/service-user/src/main/java/com/java110/user/cmd/examine/UpdateExamineStaffCmd.java b/service-user/src/main/java/com/java110/user/cmd/examine/UpdateExamineStaffCmd.java
index c3dfb95..8a20ca8 100644
--- a/service-user/src/main/java/com/java110/user/cmd/examine/UpdateExamineStaffCmd.java
+++ b/service-user/src/main/java/com/java110/user/cmd/examine/UpdateExamineStaffCmd.java
@@ -15,21 +15,33 @@
  */
 package com.java110.user.cmd.examine;
 
+import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.java110.core.annotation.Java110Cmd;
 import com.java110.core.annotation.Java110Transactional;
 import com.java110.core.context.ICmdDataFlowContext;
 import com.java110.core.event.cmd.Cmd;
 import com.java110.core.event.cmd.CmdEvent;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.core.smo.IPhotoSMO;
+import com.java110.dto.user.UserDto;
+import com.java110.intf.user.IExamineStaffIntroductionV1InnerServiceSMO;
+import com.java110.intf.user.IExamineStaffProjectV1InnerServiceSMO;
 import com.java110.intf.user.IExamineStaffV1InnerServiceSMO;
+import com.java110.intf.user.IUserV1InnerServiceSMO;
 import com.java110.po.examineStaff.ExamineStaffPo;
+import com.java110.po.examineStaffIntroduction.ExamineStaffIntroductionPo;
+import com.java110.po.examineStaffProject.ExamineStaffProjectPo;
 import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.StringUtil;
 import com.java110.vo.ResultVo;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
+
+import java.util.List;
 
 
 /**
@@ -51,24 +63,90 @@
     @Autowired
     private IExamineStaffV1InnerServiceSMO examineStaffV1InnerServiceSMOImpl;
 
+    @Autowired
+    private IExamineStaffProjectV1InnerServiceSMO examineStaffProjectV1InnerServiceSMOImpl;
+
+
+    @Autowired
+    private IExamineStaffIntroductionV1InnerServiceSMO examineStaffIntroductionV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IPhotoSMO photoSMOImpl;
+
+    @Autowired
+    private IUserV1InnerServiceSMO userV1InnerServiceSMOImpl;
+
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
         Assert.hasKeyAndValue(reqJson, "esId", "esId涓嶈兘涓虹┖");
+        Assert.hasKeyAndValue(reqJson, "staffId", "staffId涓嶈兘涓虹┖");
         Assert.hasKeyAndValue(reqJson, "communityId", "communityId涓嶈兘涓虹┖");
 
+        if (!reqJson.containsKey("projectIds")) {
+            throw new CmdException("娌″寘鍚�冩牳椤圭洰");
+        }
+
+        JSONArray projectIds = reqJson.getJSONArray("projectIds");
+
+        if (projectIds == null || projectIds.size() < 1) {
+            throw new CmdException("娌″寘鍚�冩牳椤圭洰");
+        }
     }
 
     @Override
     @Java110Transactional
     public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
 
+        UserDto userDto = new UserDto();
+        userDto.setUserId(reqJson.getString("staffId"));
+        List<UserDto> userDtos = userV1InnerServiceSMOImpl.queryUsers(userDto);
+
+        Assert.listOnlyOne(userDtos, "鍛樺伐涓嶅瓨鍦�");
+
         ExamineStaffPo examineStaffPo = BeanConvertUtil.covertBean(reqJson, ExamineStaffPo.class);
+        examineStaffPo.setStaffName(userDtos.get(0).getName());
         int flag = examineStaffV1InnerServiceSMOImpl.updateExamineStaff(examineStaffPo);
 
         if (flag < 1) {
             throw new CmdException("鏇存柊鏁版嵁澶辫触");
         }
 
+        ExamineStaffProjectPo tmpExamineStaffProjectPo = null;
+        tmpExamineStaffProjectPo = new ExamineStaffProjectPo();
+        tmpExamineStaffProjectPo.setEsId(examineStaffPo.getEsId());
+        tmpExamineStaffProjectPo.setCommunityId(examineStaffPo.getCommunityId());
+        examineStaffProjectV1InnerServiceSMOImpl.deleteExamineStaffProject(tmpExamineStaffProjectPo);
+
+
+        JSONArray projectIds = reqJson.getJSONArray("projectIds");
+
+        for (int projectIndex = 0; projectIndex < projectIds.size(); projectIndex++) {
+            tmpExamineStaffProjectPo = new ExamineStaffProjectPo();
+            tmpExamineStaffProjectPo.setEsId(examineStaffPo.getEsId());
+            tmpExamineStaffProjectPo.setCommunityId(examineStaffPo.getCommunityId());
+            tmpExamineStaffProjectPo.setProjectId(projectIds.getString(projectIndex));
+            tmpExamineStaffProjectPo.setEspId(GenerateCodeFactory.getGeneratorId("11"));
+            examineStaffProjectV1InnerServiceSMOImpl.saveExamineStaffProject(tmpExamineStaffProjectPo);
+        }
+
+        // todo save examine staff introduction
+        if (reqJson.containsKey("introduction") && !StringUtil.isEmpty(reqJson.getString("introduction"))) {
+            ExamineStaffIntroductionPo examineStaffIntroductionPo = new ExamineStaffIntroductionPo();
+            examineStaffIntroductionPo.setStaffId(reqJson.getString("staffId"));
+            examineStaffIntroductionPo.setIntroduction(reqJson.getString("introduction"));
+            examineStaffIntroductionPo.setCommunityId(reqJson.getString("communityId"));
+            examineStaffIntroductionV1InnerServiceSMOImpl.updateExamineStaffIntroduction(examineStaffIntroductionPo);
+        }
+        // todo save examine staff face image
+        if(reqJson.containsKey("headerImg")) {
+
+            photoSMOImpl.savePhoto(reqJson.getString("headerImg"),
+                    examineStaffPo.getEsId(),
+                    reqJson.getString("communityId"));
+        }
+
         cmdDataFlowContext.setResponseEntity(ResultVo.success());
+
+
     }
 }

--
Gitblit v1.8.0