From d2a2a0543a9b504ce0a374dadf9d9c1034499d0e Mon Sep 17 00:00:00 2001
From: Your Name <you@example.com>
Date: 星期五, 30 六月 2023 20:44:04 +0800
Subject: [PATCH] 优化代码

---
 service-user/src/main/java/com/java110/user/cmd/owner/DeleteOwnerCarsCmd.java |  138 +++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 117 insertions(+), 21 deletions(-)

diff --git a/service-user/src/main/java/com/java110/user/cmd/owner/DeleteOwnerCarsCmd.java b/service-user/src/main/java/com/java110/user/cmd/owner/DeleteOwnerCarsCmd.java
index b408faf..cbeb38e 100644
--- a/service-user/src/main/java/com/java110/user/cmd/owner/DeleteOwnerCarsCmd.java
+++ b/service-user/src/main/java/com/java110/user/cmd/owner/DeleteOwnerCarsCmd.java
@@ -8,15 +8,25 @@
 import com.java110.core.event.cmd.Cmd;
 import com.java110.core.event.cmd.CmdEvent;
 import com.java110.dto.fee.FeeDto;
+import com.java110.dto.fee.PayFeeDto;
 import com.java110.dto.owner.OwnerCarDto;
 import com.java110.dto.parking.ParkingSpaceDto;
 import com.java110.intf.community.IParkingSpaceInnerServiceSMO;
 import com.java110.intf.community.IParkingSpaceV1InnerServiceSMO;
 import com.java110.intf.fee.IFeeInnerServiceSMO;
+import com.java110.intf.fee.IPayFeeDetailMonthInnerServiceSMO;
+import com.java110.intf.fee.IPayFeeDetailV1InnerServiceSMO;
+import com.java110.intf.fee.IPayFeeV1InnerServiceSMO;
+import com.java110.intf.report.IReportOweFeeInnerServiceSMO;
 import com.java110.intf.user.IOwnerCarInnerServiceSMO;
 import com.java110.intf.user.IOwnerCarV1InnerServiceSMO;
 import com.java110.po.car.OwnerCarPo;
+import com.java110.po.fee.PayFeeDetailPo;
+import com.java110.po.fee.PayFeePo;
 import com.java110.po.parking.ParkingSpacePo;
+import com.java110.po.payFee.PayFeeDetailMonthPo;
+import com.java110.po.reportFee.ReportOweFeePo;
+import com.java110.po.room.RoomPo;
 import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
@@ -42,6 +52,18 @@
 
     @Autowired
     private IOwnerCarV1InnerServiceSMO ownerCarV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IPayFeeV1InnerServiceSMO payFeeV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IPayFeeDetailV1InnerServiceSMO payFeeDetailV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IReportOweFeeInnerServiceSMO reportOweFeeInnerServiceSMOImpl;
+
+    @Autowired
+    private IPayFeeDetailMonthInnerServiceSMO payFeeDetailMonthInnerServiceSMOImpl;
 
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
@@ -81,7 +103,7 @@
             ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
             parkingSpaceDto.setPsId(reqJson.getString("psId"));
             List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
-            if (parkingSpaceDtos != null && parkingSpaceDtos.size()> 0 &&
+            if (parkingSpaceDtos != null && parkingSpaceDtos.size() > 0 &&
                     "2".equals(parkingSpaceDtos.get(0).getParkingType())
                     && "1001".equals(reqJson.getString("carTypeCd"))) { //瀛愭瘝杞︿綅
                 OwnerCarDto ownerCarDto = new OwnerCarDto();
@@ -106,30 +128,104 @@
         if (StringUtil.isEmpty(reqJson.getString("psId")) || "-1".equals(reqJson.getString("psId"))) {
             return;
         }
-        //閲婃斁杞︿綅
-        if (reqJson.getString("carId").equals(reqJson.getString("memberId"))) {
-            reqJson.put("carNumType", ParkingSpaceDto.STATE_FREE);//淇敼涓虹┖闂�
-            ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
-            parkingSpaceDto.setCommunityId(reqJson.getString("communityId"));
-            parkingSpaceDto.setPsId(reqJson.getString("psId"));
-            List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
+        // todo 閲婃斁杞︿綅
+        releaseParkSpace(reqJson);
 
-            if (parkingSpaceDtos == null || parkingSpaceDtos.size() != 1) {
-                //throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_ERROR, "鏈煡璇㈠埌鍋滆溅浣嶄俊鎭�" + JSONObject.toJSONString(parkingSpaceDto));
-                return;
-            }
+        // todo 鍒犻櫎杞﹁締璐圭敤
+        deleteCarFee(reqJson);
+    }
 
-            parkingSpaceDto = parkingSpaceDtos.get(0);
+    /**
+     * 閲婃斁杞︿綅淇℃伅
+     *
+     * @param reqJson
+     */
+    private void releaseParkSpace(JSONObject reqJson) {
+        int flag;
+        if (!reqJson.getString("carId").equals(reqJson.getString("memberId"))) {
+            return;
+        }
+        reqJson.put("carNumType", ParkingSpaceDto.STATE_FREE);//淇敼涓虹┖闂�
+        ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
+        parkingSpaceDto.setCommunityId(reqJson.getString("communityId"));
+        parkingSpaceDto.setPsId(reqJson.getString("psId"));
+        List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
 
-            JSONObject businessParkingSpace = new JSONObject();
+        if (parkingSpaceDtos == null || parkingSpaceDtos.size() != 1) {
+            //throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_ERROR, "鏈煡璇㈠埌鍋滆溅浣嶄俊鎭�" + JSONObject.toJSONString(parkingSpaceDto));
+            return;
+        }
 
-            businessParkingSpace.putAll(BeanConvertUtil.beanCovertMap(parkingSpaceDto));
-            businessParkingSpace.put("state", reqJson.getString("carNumType"));
-            ParkingSpacePo parkingSpacePo = BeanConvertUtil.covertBean(businessParkingSpace, ParkingSpacePo.class);
-            flag = parkingSpaceV1InnerServiceSMOImpl.updateParkingSpace(parkingSpacePo);
-            if (flag < 1) {
-                throw new IllegalArgumentException("淇敼杞﹁締鍑洪敊");
-            }
+        parkingSpaceDto = parkingSpaceDtos.get(0);
+        JSONObject businessParkingSpace = new JSONObject();
+        businessParkingSpace.putAll(BeanConvertUtil.beanCovertMap(parkingSpaceDto));
+        businessParkingSpace.put("state", reqJson.getString("carNumType"));
+        ParkingSpacePo parkingSpacePo = BeanConvertUtil.covertBean(businessParkingSpace, ParkingSpacePo.class);
+        flag = parkingSpaceV1InnerServiceSMOImpl.updateParkingSpace(parkingSpacePo);
+        if (flag < 1) {
+            throw new IllegalArgumentException("淇敼杞﹁締鍑洪敊");
         }
     }
+
+    /**
+     * 鍒犻櫎鎴垮眿璐圭敤
+     *
+     * @param reqJson
+     */
+    private void deleteCarFee(JSONObject reqJson) {
+
+        if (!reqJson.getString("carId").equals(reqJson.getString("memberId"))) {
+            return;
+        }
+
+        if (StringUtil.isEmpty(reqJson.getString("carId"))) {
+            throw new CmdException("杞﹁仈涓嶈兘涓虹┖");
+        }
+        PayFeeDto feeDto = new PayFeeDto();
+        feeDto.setPayerObjId(reqJson.getString("carId"));
+        feeDto.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_CAR);
+        feeDto.setCommunityId(reqJson.getString("communityId"));
+        List<PayFeeDto> feeDtos = payFeeV1InnerServiceSMOImpl.queryPayFees(feeDto);
+
+        if (feeDtos == null || feeDtos.size() < 1) {
+            return;
+        }
+
+        for (PayFeeDto payFeeDto : feeDtos) {
+            doDeleteFee(payFeeDto);
+        }
+
+    }
+
+    /**
+     * @param payFeeDto
+     */
+    private void doDeleteFee(PayFeeDto payFeeDto) {
+        //todo 鍒犻櫎缂磋垂璁板綍
+
+        PayFeeDetailPo payFeeDetailPo = new PayFeeDetailPo();
+        payFeeDetailPo.setFeeId(payFeeDto.getFeeId());
+        payFeeDetailPo.setCommunityId(payFeeDto.getCommunityId());
+        payFeeDetailV1InnerServiceSMOImpl.deletePayFeeDetailNew(payFeeDetailPo);
+
+        //todo 鍒犻櫎璐圭敤
+        PayFeePo payFeePo = new PayFeePo();
+        payFeePo.setFeeId(payFeeDto.getFeeId());
+        payFeePo.setCommunityId(payFeeDto.getCommunityId());
+        payFeeV1InnerServiceSMOImpl.deletePayFee(payFeePo);
+
+        //todo 鍒犻櫎娆犺垂
+        ReportOweFeePo reportOweFeePo = new ReportOweFeePo();
+        reportOweFeePo.setFeeId(payFeeDto.getFeeId());
+        reportOweFeePo.setCommunityId(payFeeDto.getCommunityId());
+        reportOweFeeInnerServiceSMOImpl.deleteReportOweFee(reportOweFeePo);
+
+        //todo 鍒犻櫎 绂绘暎鏈堟暟鎹�
+        PayFeeDetailMonthPo payFeeDetailMonthPo = new PayFeeDetailMonthPo();
+        payFeeDetailMonthPo.setFeeId(payFeeDto.getFeeId());
+        payFeeDetailMonthPo.setCommunityId(payFeeDto.getCommunityId());
+        payFeeDetailMonthInnerServiceSMOImpl.deletePayFeeDetailMonth(payFeeDetailMonthPo);
+
+    }
+
 }

--
Gitblit v1.8.0