From b536b4e005a3aee7908a60c31eddff90bf4b98dc Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期六, 07 八月 2021 22:20:16 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity
---
service-fee/src/main/java/com/java110/fee/bmo/payFeeDetail/impl/ImportPayFeeDetailBMOImpl.java | 185 ++++++++++++++++++++++++++++++++++++----------
1 files changed, 145 insertions(+), 40 deletions(-)
diff --git a/service-fee/src/main/java/com/java110/fee/bmo/payFeeDetail/impl/ImportPayFeeDetailBMOImpl.java b/service-fee/src/main/java/com/java110/fee/bmo/payFeeDetail/impl/ImportPayFeeDetailBMOImpl.java
old mode 100644
new mode 100755
index 7f9ee5a..5915f5e
--- a/service-fee/src/main/java/com/java110/fee/bmo/payFeeDetail/impl/ImportPayFeeDetailBMOImpl.java
+++ b/service-fee/src/main/java/com/java110/fee/bmo/payFeeDetail/impl/ImportPayFeeDetailBMOImpl.java
@@ -8,16 +8,19 @@
import com.java110.dto.fee.FeeDto;
import com.java110.entity.assetImport.ImportRoomFee;
import com.java110.fee.bmo.payFeeDetail.IImportPayFeeBMODetail;
-import com.java110.intf.IImportFeeDetailInnerServiceSMO;
import com.java110.intf.community.IRoomInnerServiceSMO;
import com.java110.intf.fee.IFeeConfigInnerServiceSMO;
import com.java110.intf.fee.IFeeDetailInnerServiceSMO;
import com.java110.intf.fee.IFeeInnerServiceSMO;
+import com.java110.intf.fee.IImportFeeDetailInnerServiceSMO;
+import com.java110.intf.user.IOwnerCarInnerServiceSMO;
import com.java110.po.fee.PayFeeDetailPo;
import com.java110.po.fee.PayFeePo;
+import com.java110.utils.constant.StatusConstant;
import com.java110.utils.util.Assert;
import com.java110.utils.util.BeanConvertUtil;
import com.java110.utils.util.DateUtil;
+import com.java110.utils.util.StringUtil;
import com.java110.vo.ResultVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
@@ -45,6 +48,9 @@
@Autowired
private IFeeDetailInnerServiceSMO feeDetailInnerServiceSMOImpl;
+ @Autowired
+ private IOwnerCarInnerServiceSMO ownerCarInnerServiceSMOImpl;
+
/**
* @param reqJson
* @return 璁㈠崟鏈嶅姟鑳藉鎺ュ彈鐨勬姤鏂�
@@ -56,8 +62,9 @@
String communityId = reqJson.getString("communityId");
String storeId = reqJson.getString("storeId");
String userId = reqJson.getString("userId");
+ String objType = reqJson.getString("objType");
- JSONArray datas = reqJson.getJSONArray("datas");
+ JSONArray datas = reqJson.getJSONArray("importRoomFees");
JSONObject data = null;
List<ImportRoomFee> importRoomFees = new ArrayList<>();
@@ -70,8 +77,11 @@
if (importRoomFees.size() < 1) {
return ResultVo.success();
}
-
- importFeeDetails(storeId, userId, importRoomFees);
+ if (FeeDto.PAYER_OBJ_TYPE_ROOM.equals(objType)) {
+ importFeeDetails(storeId, userId, importRoomFees);
+ } else {
+ importCarFeeDetails(storeId, userId, importRoomFees);
+ }
return ResultVo.success();
}
@@ -79,10 +89,88 @@
private void importFeeDetails(String storeId, String userId, List<ImportRoomFee> importRoomFees) {
importRoomFees = roomInnerServiceSMOImpl.freshRoomIds(importRoomFees);
-
for (ImportRoomFee importRoomFee : importRoomFees) {
+ if (StringUtil.isEmpty(importRoomFee.getRoomId())) {
+ continue;
+ }
importFeeDetail(importRoomFee, storeId, userId);
}
+ }
+
+
+ private void importCarFeeDetails(String storeId, String userId, List<ImportRoomFee> importCarFees) {
+
+ importCarFees = ownerCarInnerServiceSMOImpl.freshCarIds(importCarFees);
+ for (ImportRoomFee importCarFee : importCarFees) {
+ if (StringUtil.isEmpty(importCarFee.getCarId())) {
+ continue;
+ }
+ importCarFeeDetail(importCarFee, storeId, userId);
+ }
+ }
+
+ /**
+ * 瀵煎叆 璐圭敤鍘嗗彶
+ *
+ * @param importRoomFee
+ */
+ private void importCarFeeDetail(ImportRoomFee importRoomFee, String storeId, String userId) {
+
+ FeeConfigDto feeConfigDto = new FeeConfigDto();
+ feeConfigDto.setFeeNameEq(importRoomFee.getFeeName());
+ feeConfigDto.setCommunityId(importRoomFee.getCommunityId());
+ List<FeeConfigDto> feeConfigDtos = feeConfigInnerServiceSMOImpl.queryFeeConfigs(feeConfigDto);
+
+ Assert.listOnlyOne(feeConfigDtos, "璐圭敤椤逛笉瀛樺湪鎴栧瓨鍦ㄥ鏉�");
+
+ FeeConfigDto tmpFeeConfigDto = feeConfigDtos.get(0);
+
+ FeeDto feeDto = new FeeDto();
+ feeDto.setConfigId(tmpFeeConfigDto.getConfigId());
+ feeDto.setCommunityId(importRoomFee.getCommunityId());
+ feeDto.setPayerObjId(importRoomFee.getCarId());
+ feeDto.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_CAR);
+ List<FeeDto> feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
+
+ List<PayFeePo> payFeePos = null;
+ if (feeDtos == null || feeDtos.size() < 1) {
+ try {
+ PayFeePo payFeePo = new PayFeePo();
+ payFeePo.setCommunityId(importRoomFee.getCommunityId());
+ payFeePo.setConfigId(feeDto.getConfigId());
+ payFeePo.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_CAR);
+ payFeePo.setStartTime(importRoomFee.getStartTime());
+ payFeePo.setEndTime(importRoomFee.getEndTime());
+ payFeePo.setAmount(importRoomFee.getAmount());
+ payFeePo.setFeeFlag(tmpFeeConfigDto.getFeeFlag());
+ payFeePo.setFeeTypeCd(tmpFeeConfigDto.getFeeTypeCd());
+ payFeePo.setIncomeObjId(storeId);
+ if (FeeDto.FEE_FLAG_ONCE.equals(tmpFeeConfigDto.getFeeFlag())) {
+ payFeePo.setState(FeeDto.STATE_FINISH);
+ } else {
+ payFeePo.setState(FeeDto.STATE_DOING);
+ }
+ payFeePo.setFeeId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
+ payFeePo.setPayerObjId(importRoomFee.getCarId());
+ payFeePo.setUserId(userId);
+ payFeePo.setCreateTime(importRoomFee.getCreateTime());
+ payFeePos = new ArrayList<>();
+ payFeePos.add(payFeePo);
+ feeInnerServiceSMOImpl.saveFee(payFeePos);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
+ }
+
+ for (FeeDto tmpFeeDto : feeDtos) {
+ try {
+ doImportFeeDetail(tmpFeeDto, importRoomFee);
+ } catch (ParseException e) {
+ e.printStackTrace();
+ }
+ }
+
}
/**
@@ -97,41 +185,52 @@
feeConfigDto.setCommunityId(importRoomFee.getCommunityId());
List<FeeConfigDto> feeConfigDtos = feeConfigInnerServiceSMOImpl.queryFeeConfigs(feeConfigDto);
- Assert.listOnlyOne(feeConfigDtos, "璐圭敤涓嶅瓨鍦ㄦ垨瀛樺湪澶氭潯");
+ Assert.listOnlyOne(feeConfigDtos, "璐圭敤椤逛笉瀛樺湪鎴栧瓨鍦ㄥ鏉�");
FeeConfigDto tmpFeeConfigDto = feeConfigDtos.get(0);
FeeDto feeDto = new FeeDto();
feeDto.setConfigId(tmpFeeConfigDto.getConfigId());
feeDto.setCommunityId(importRoomFee.getCommunityId());
+ feeDto.setPayerObjId(importRoomFee.getRoomId());
+ feeDto.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_ROOM);
List<FeeDto> feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
List<PayFeePo> payFeePos = null;
if (feeDtos == null || feeDtos.size() < 1) {
- PayFeePo payFeePo = new PayFeePo();
- payFeePo.setCommunityId(importRoomFee.getCommunityId());
- payFeePo.setConfigId(feeDto.getConfigId());
- payFeePo.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_ROOM);
- payFeePo.setStartTime(importRoomFee.getStartTime());
- payFeePo.setEndTime(importRoomFee.getEndTime());
- payFeePo.setAmount(importRoomFee.getAmount());
- payFeePo.setFeeFlag(tmpFeeConfigDto.getFeeFlag());
- payFeePo.setFeeTypeCd(tmpFeeConfigDto.getFeeTypeCd());
- payFeePo.setIncomeObjId(storeId);
- payFeePo.setState(FeeDto.STATE_DOING);
- payFeePo.setFeeId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
- payFeePo.setPayerObjId(importRoomFee.getRoomId());
- payFeePo.setUserId(userId);
- payFeePos = new ArrayList<>();
- payFeePos.add(payFeePo);
- feeInnerServiceSMOImpl.saveFee(payFeePos);
+ try {
+ PayFeePo payFeePo = new PayFeePo();
+ payFeePo.setCommunityId(importRoomFee.getCommunityId());
+ payFeePo.setConfigId(feeDto.getConfigId());
+ payFeePo.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_ROOM);
+ payFeePo.setStartTime(importRoomFee.getStartTime());
+ payFeePo.setEndTime(importRoomFee.getEndTime());
+ payFeePo.setAmount(importRoomFee.getAmount());
+ payFeePo.setFeeFlag(tmpFeeConfigDto.getFeeFlag());
+ payFeePo.setFeeTypeCd(tmpFeeConfigDto.getFeeTypeCd());
+ payFeePo.setIncomeObjId(storeId);
+ if (FeeDto.FEE_FLAG_ONCE.equals(tmpFeeConfigDto.getFeeFlag())) {
+ payFeePo.setState(FeeDto.STATE_FINISH);
+ } else {
+ payFeePo.setState(FeeDto.STATE_DOING);
+ }
+ payFeePo.setFeeId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
+ payFeePo.setPayerObjId(importRoomFee.getRoomId());
+ payFeePo.setUserId(userId);
+ payFeePo.setCreateTime(importRoomFee.getCreateTime());
+ payFeePos = new ArrayList<>();
+ payFeePos.add(payFeePo);
+ feeInnerServiceSMOImpl.saveFee(payFeePos);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
}
for (FeeDto tmpFeeDto : feeDtos) {
try {
doImportFeeDetail(tmpFeeDto, importRoomFee);
- } catch (ParseException e) {
+ } catch (Exception e) {
e.printStackTrace();
}
}
@@ -139,19 +238,20 @@
}
private void doImportFeeDetail(FeeDto tmpFeeDto, ImportRoomFee importRoomFee) throws ParseException {
- FeeDetailDto feeDetailDto = new FeeDetailDto();
- feeDetailDto.setCommunityId(importRoomFee.getCommunityId());
- feeDetailDto.setFeeId(tmpFeeDto.getFeeId());
-
-
- feeDetailDto.setStartTime(DateUtil.getDateFromString(importRoomFee.getStartTime(), DateUtil.DATE_FORMATE_STRING_B));
- feeDetailDto.setEndTime(DateUtil.getDateFromString(importRoomFee.getEndTime(), DateUtil.DATE_FORMATE_STRING_B));
-
- List<FeeDetailDto> feeDetailDtos = feeDetailInnerServiceSMOImpl.queryFeeDetails(feeDetailDto);
-
- if (feeDetailDtos != null && feeDetailDtos.size() > 0) {//璇存槑宸茬粡瀵煎叆杩囦簡
- return;
- }
+// FeeDetailDto feeDetailDto = new FeeDetailDto();
+// feeDetailDto.setCommunityId(importRoomFee.getCommunityId());
+// feeDetailDto.setFeeId(tmpFeeDto.getFeeId());
+//
+//
+// feeDetailDto.setStartTime(DateUtil.getDateFromString(importRoomFee.getStartTime(), DateUtil.DATE_FORMATE_STRING_B));
+// feeDetailDto.setEndTime(DateUtil.getDateFromString(importRoomFee.getEndTime(), DateUtil.DATE_FORMATE_STRING_B));
+// feeDetailDto.setCreateTime(DateUtil.getDateFromString(importRoomFee.getCreateTime(), DateUtil.DATE_FORMATE_STRING_B));
+//
+// List<FeeDetailDto> feeDetailDtos = feeDetailInnerServiceSMOImpl.queryFeeDetails(feeDetailDto);
+//
+// if (feeDetailDtos != null && feeDetailDtos.size() > 0) {//璇存槑宸茬粡瀵煎叆杩囦簡
+// return;
+// }
PayFeeDetailPo payFeeDetailPo = new PayFeeDetailPo();
payFeeDetailPo.setCommunityId(importRoomFee.getCommunityId());
@@ -164,6 +264,8 @@
payFeeDetailPo.setEndTime(importRoomFee.getEndTime());
payFeeDetailPo.setDetailId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_detailId));
payFeeDetailPo.setRemark(importRoomFee.getRemark());
+ payFeeDetailPo.setCreateTime(importRoomFee.getCreateTime());
+ payFeeDetailPo.setState("1400");
int saved = feeDetailInnerServiceSMOImpl.saveFeeDetail(payFeeDetailPo);
if (saved < 1) {
@@ -177,10 +279,13 @@
//濡傛灉缁撴潫鏃堕棿灏忎簬 缂磋垂缁撴潫鏃堕棿鍒欏欢鏈�
PayFeePo payFeePo = new PayFeePo();
payFeePo.setCommunityId(importRoomFee.getCommunityId());
-
- payFeePo.setFeeId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
- payFeePo.setPayerObjId(tmpFeeDto.getFeeId());
+ payFeePo.setStatusCd(StatusConstant.STATUS_CD_VALID);
+ payFeePo.setFeeId(tmpFeeDto.getFeeId());
payFeePo.setEndTime(importRoomFee.getEndTime());
+ if (FeeDto.FEE_FLAG_ONCE.equals(tmpFeeDto.getFeeFlag())) {
+ payFeePo.setState(FeeDto.STATE_FINISH);
+ }
+
feeInnerServiceSMOImpl.updateFee(payFeePo);
}
--
Gitblit v1.8.0