From 0b04f664887c73e90bf684a4e69c0fdbfe26349d Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期三, 29 三月 2023 13:35:20 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity

---
 service-fee/src/main/java/com/java110/fee/cmd/fee/UpdateFeeCmd.java |   65 ++++++++++++++++++++++++++------
 1 files changed, 53 insertions(+), 12 deletions(-)

diff --git a/service-fee/src/main/java/com/java110/fee/cmd/fee/UpdateFeeCmd.java b/service-fee/src/main/java/com/java110/fee/cmd/fee/UpdateFeeCmd.java
index b252a69..bb0d61e 100644
--- a/service-fee/src/main/java/com/java110/fee/cmd/fee/UpdateFeeCmd.java
+++ b/service-fee/src/main/java/com/java110/fee/cmd/fee/UpdateFeeCmd.java
@@ -5,6 +5,7 @@
 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.dto.fee.FeeAttrDto;
 import com.java110.dto.fee.FeeConfigDto;
 import com.java110.dto.fee.FeeDto;
@@ -64,45 +65,85 @@
         PayFeePo payFeePo = BeanConvertUtil.covertBean(reqJson, PayFeePo.class);
         int flag = payFeeV1InnerServiceSMOImpl.updatePayFee(payFeePo);
 
-        if(flag < 1){
+        if (flag < 1) {
             throw new CmdException("淇敼璐圭敤");
         }
 
-        if(reqJson.containsKey("maxEndTime") && !StringUtil.isEmpty(reqJson.getString("maxEndTime"))){
+        if (reqJson.containsKey("maxEndTime") && !StringUtil.isEmpty(reqJson.getString("maxEndTime"))) {
+            FeeAttrDto feeAttrDto = new FeeAttrDto();
+            feeAttrDto.setFeeId(payFeePo.getFeeId());
+            feeAttrDto.setSpecCd(FeeAttrDto.SPEC_CD_ONCE_FEE_DEADLINE_TIME);
+            List<FeeAttrDto> feeAttrDtos = feeAttrInnerServiceSMOImpl.queryFeeAttrs(feeAttrDto);
             FeeAttrPo feeAttrPo = new FeeAttrPo();
             feeAttrPo.setFeeId(payFeePo.getFeeId());
             feeAttrPo.setSpecCd(FeeAttrDto.SPEC_CD_ONCE_FEE_DEADLINE_TIME);
             feeAttrPo.setValue(reqJson.getString("maxEndTime"));
-            feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            feeAttrPo.setCommunityId(reqJson.getString("communityId"));
+            if (feeAttrDtos == null || feeAttrDtos.size() < 1) {
+                feeAttrPo.setAttrId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_attrId));
+                feeAttrInnerServiceSMOImpl.saveFeeAttr(feeAttrPo);
+            } else {
+                feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            }
         }
 
-        if(!reqJson.containsKey("computingFormula")
-                || !FeeConfigDto.COMPUTING_FORMULA_RANT_RATE.equals(reqJson.getString("computingFormula"))){
-            return ;
+        if (!reqJson.containsKey("computingFormula")
+                || !FeeConfigDto.COMPUTING_FORMULA_RANT_RATE.equals(reqJson.getString("computingFormula"))) {
+            return;
         }
 
-        if(reqJson.containsKey("rate")) {
+        if (reqJson.containsKey("rate")) {
+            FeeAttrDto feeAttrDto = new FeeAttrDto();
+            feeAttrDto.setFeeId(payFeePo.getFeeId());
+            feeAttrDto.setSpecCd(FeeAttrDto.SPEC_CD_RATE);
+            List<FeeAttrDto> feeAttrDtos = feeAttrInnerServiceSMOImpl.queryFeeAttrs(feeAttrDto);
             FeeAttrPo feeAttrPo = new FeeAttrPo();
             feeAttrPo.setFeeId(payFeePo.getFeeId());
             feeAttrPo.setSpecCd(FeeAttrDto.SPEC_CD_RATE);
             feeAttrPo.setValue(reqJson.getString("rate"));
-            feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            feeAttrPo.setCommunityId(reqJson.getString("communityId"));
+            if (feeAttrDtos == null || feeAttrDtos.size() < 1) {
+                feeAttrPo.setAttrId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_attrId));
+                feeAttrInnerServiceSMOImpl.saveFeeAttr(feeAttrPo);
+            } else {
+                feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            }
         }
 
-        if(reqJson.containsKey("rateCycle")) {
+        if (reqJson.containsKey("rateCycle")) {
+            FeeAttrDto feeAttrDto = new FeeAttrDto();
+            feeAttrDto.setFeeId(payFeePo.getFeeId());
+            feeAttrDto.setSpecCd(FeeAttrDto.SPEC_CD_RATE_CYCLE);
+            List<FeeAttrDto> feeAttrDtos = feeAttrInnerServiceSMOImpl.queryFeeAttrs(feeAttrDto);
             FeeAttrPo feeAttrPo = new FeeAttrPo();
             feeAttrPo.setFeeId(payFeePo.getFeeId());
             feeAttrPo.setSpecCd(FeeAttrDto.SPEC_CD_RATE_CYCLE);
             feeAttrPo.setValue(reqJson.getString("rateCycle"));
-            feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            feeAttrPo.setCommunityId(reqJson.getString("communityId"));
+            if (feeAttrDtos == null || feeAttrDtos.size() < 1) {
+                feeAttrPo.setAttrId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_attrId));
+                feeAttrInnerServiceSMOImpl.saveFeeAttr(feeAttrPo);
+            } else {
+                feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            }
         }
 
-        if(reqJson.containsKey("rateStartTime")) {
+        if (reqJson.containsKey("rateStartTime")) {
+            FeeAttrDto feeAttrDto = new FeeAttrDto();
+            feeAttrDto.setFeeId(payFeePo.getFeeId());
+            feeAttrDto.setSpecCd(FeeAttrDto.SPEC_CD_RATE_START_TIME);
+            List<FeeAttrDto> feeAttrDtos = feeAttrInnerServiceSMOImpl.queryFeeAttrs(feeAttrDto);
             FeeAttrPo feeAttrPo = new FeeAttrPo();
             feeAttrPo.setFeeId(payFeePo.getFeeId());
             feeAttrPo.setSpecCd(FeeAttrDto.SPEC_CD_RATE_START_TIME);
             feeAttrPo.setValue(reqJson.getString("rateStartTime"));
-            feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            feeAttrPo.setCommunityId(reqJson.getString("communityId"));
+            if (feeAttrDtos == null || feeAttrDtos.size() < 1) {
+                feeAttrPo.setAttrId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_attrId));
+                feeAttrInnerServiceSMOImpl.saveFeeAttr(feeAttrPo);
+            } else {
+                feeAttrInnerServiceSMOImpl.updateFeeAttr(feeAttrPo);
+            }
         }
     }
 }

--
Gitblit v1.8.0