From 19a303f4edfd445f01c8048490207e67162157c5 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期五, 21 八月 2020 23:55:29 +0800
Subject: [PATCH] 优化代码
---
service-fee/src/main/java/com/java110/fee/bmo/impl/QueryOweFeeImpl.java | 170 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 170 insertions(+), 0 deletions(-)
diff --git a/service-fee/src/main/java/com/java110/fee/bmo/impl/QueryOweFeeImpl.java b/service-fee/src/main/java/com/java110/fee/bmo/impl/QueryOweFeeImpl.java
index 2951db4..84d2b87 100644
--- a/service-fee/src/main/java/com/java110/fee/bmo/impl/QueryOweFeeImpl.java
+++ b/service-fee/src/main/java/com/java110/fee/bmo/impl/QueryOweFeeImpl.java
@@ -1,10 +1,12 @@
package com.java110.fee.bmo.impl;
+import com.alibaba.fastjson.JSONArray;
import com.java110.dto.RoomDto;
import com.java110.dto.fee.BillDto;
import com.java110.dto.fee.BillOweFeeDto;
import com.java110.dto.fee.FeeConfigDto;
import com.java110.dto.fee.FeeDto;
+import com.java110.dto.owner.OwnerDto;
import com.java110.dto.parking.ParkingSpaceDto;
import com.java110.fee.bmo.IQueryOweFee;
import com.java110.intf.community.IParkingSpaceInnerServiceSMO;
@@ -13,13 +15,17 @@
import com.java110.intf.fee.IFeeInnerServiceSMO;
import com.java110.intf.user.IOwnerInnerServiceSMO;
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;
import org.springframework.stereotype.Service;
import java.math.BigDecimal;
+import java.math.RoundingMode;
import java.util.ArrayList;
+import java.util.Calendar;
+import java.util.Date;
import java.util.List;
@Service
@@ -71,12 +77,63 @@
@Override
public ResponseEntity<String> queryAllOwneFee(FeeDto feeDto) {
ResponseEntity<String> responseEntity = null;
+
+ if (!freshFeeDtoParam(feeDto)) {
+ return ResultVo.createResponseEntity(1, 0, new JSONArray());
+ }
+
if (FeeConfigDto.BILL_TYPE_EVERY.equals(feeDto.getBillType())) {
responseEntity = computeEveryOweFee(feeDto);
} else {
responseEntity = computeBillOweFee(feeDto);
}
return responseEntity;
+ }
+
+ private boolean freshFeeDtoParam(FeeDto feeDto) {
+
+ if (StringUtil.isEmpty(feeDto.getPayerObjId())) {
+ return true;
+ }
+
+ if (!feeDto.getPayerObjId().contains("#")) {
+ return false;
+ }
+ if (FeeDto.PAYER_OBJ_TYPE_ROOM.equals(feeDto.getPayerObjType())) {
+ String[] nums = feeDto.getPayerObjId().split("#");
+ if (nums.length != 3) {
+ return false;
+ }
+ RoomDto roomDto = new RoomDto();
+ roomDto.setFloorId(nums[0]);
+ roomDto.setUnitNum(nums[1]);
+ roomDto.setRoomNum(nums[2]);
+ roomDto.setCommunityId(feeDto.getCommunityId());
+ List<RoomDto> roomDtos = roomInnerServiceSMOImpl.queryRooms(roomDto);
+
+ if (roomDtos == null || roomDtos.size() < 1) {
+ return false;
+ }
+ feeDto.setPayerObjId(roomDtos.get(0).getRoomId());
+
+ } else {
+ String[] nums = feeDto.getPayerObjId().split("#");
+ if (nums.length != 2) {
+ return false;
+ }
+ ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
+ parkingSpaceDto.setAreaNum(nums[0]);
+ parkingSpaceDto.setNum(nums[1]);
+ parkingSpaceDto.setCommunityId(feeDto.getCommunityId());
+ List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
+
+ if (parkingSpaceDtos == null || parkingSpaceDtos.size() < 1) {
+ return false;
+ }
+ feeDto.setPayerObjId(parkingSpaceDtos.get(0).getPsId());
+ }
+
+ return true;
}
/**
@@ -148,6 +205,66 @@
* @param psFees
*/
private void computePsFee(List<FeeDto> psFees, List<String> psIds) {
+ ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
+ parkingSpaceDto.setCommunityId(psFees.get(0).getCommunityId());
+ parkingSpaceDto.setPsIds(psIds.toArray(new String[psIds.size()]));
+ List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
+
+ if (parkingSpaceDtos == null || parkingSpaceDtos.size() < 1) { //鏁版嵁鏈夐棶棰�
+ return;
+ }
+ List<String> ownerIds = new ArrayList<>();
+ for (ParkingSpaceDto tmpParkingSpaceDto : parkingSpaceDtos) {
+ for (FeeDto feeDto : psFees) {
+ dealFeePs(tmpParkingSpaceDto, feeDto);
+ }
+ ownerIds.add(tmpParkingSpaceDto.getOwnerId());
+ }
+
+ if (ownerIds.size() < 1) {
+ return;
+ }
+
+ OwnerDto ownerDto = new OwnerDto();
+ ownerDto.setOwnerIds(ownerIds.toArray(new String[ownerIds.size()]));
+ ownerDto.setCommunityId(psFees.get(0).getCommunityId());
+ List<OwnerDto> ownerDtos = ownerInnerServiceSMOImpl.queryOwners(ownerDto);
+
+ for (OwnerDto tmpOwnerDto : ownerDtos) {
+ for (FeeDto feeDto : psFees) {
+ dealFeeOwner(tmpOwnerDto, feeDto);
+ }
+ }
+ }
+
+ private void dealFeePs(ParkingSpaceDto tmpParkingSpaceDto, FeeDto feeDto) {
+ if (!tmpParkingSpaceDto.getPsId().equals(feeDto.getPayerObjId())) {
+ return;
+ }
+ feeDto.setRoomName(tmpParkingSpaceDto.getAreaNum() + "鍋滆溅鍦�" + tmpParkingSpaceDto.getNum() + "杞︿綅");
+
+ String computingFormula = feeDto.getComputingFormula();
+ double feePrice = 0.00;
+ if ("1001".equals(computingFormula)) { //闈㈢Н*鍗曚环+闄勫姞璐�
+ BigDecimal squarePrice = new BigDecimal(Double.parseDouble(feeDto.getSquarePrice()));
+ BigDecimal builtUpArea = new BigDecimal(Double.parseDouble(tmpParkingSpaceDto.getArea()));
+ BigDecimal additionalAmount = new BigDecimal(Double.parseDouble(feeDto.getAdditionalAmount()));
+ feePrice = squarePrice.multiply(builtUpArea).add(additionalAmount).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue();
+ } else if ("2002".equals(computingFormula)) { // 鍥哄畾璐圭敤
+
+ BigDecimal additionalAmount = new BigDecimal(Double.parseDouble(feeDto.getAdditionalAmount()));
+ feePrice = additionalAmount.setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue();
+ } else if ("4004".equals(computingFormula)) {
+ feePrice = Double.parseDouble(feeDto.getAmount());
+ } else {
+ feePrice = 0.00;
+ }
+
+ feeDto.setFeePrice(feePrice);
+ double month = dayCompare(feeDto.getEndTime(), DateUtil.getCurrentDate());
+ BigDecimal price = new BigDecimal(feeDto.getFeePrice());
+ price = price.multiply(new BigDecimal(month));
+ feeDto.setAmountOwed(price.doubleValue() + "");
}
/**
@@ -171,7 +288,27 @@
}
}
+ OwnerDto ownerDto = new OwnerDto();
+ ownerDto.setRoomIds(roomIds.toArray(new String[roomIds.size()]));
+ ownerDto.setCommunityId(roomFees.get(0).getCommunityId());
+ List<OwnerDto> ownerDtos = ownerInnerServiceSMOImpl.queryOwners(ownerDto);
+ for (OwnerDto tmpOwnerDto : ownerDtos) {
+ for (FeeDto feeDto : roomFees) {
+ dealFeeOwner(tmpOwnerDto, feeDto);
+ }
+ }
+
+ }
+
+ private void dealFeeOwner(OwnerDto tmpOwnerDto, FeeDto feeDto) {
+
+ if (!tmpOwnerDto.getRoomId().equals(feeDto.getPayerObjId())) {
+ return;
+ }
+
+ feeDto.setOwnerName(tmpOwnerDto.getName());
+ feeDto.setOwnerTel(feeDto.getOwnerTel());
}
private void dealFeeRoom(RoomDto tmpRoomDto, FeeDto feeDto) {
@@ -197,6 +334,11 @@
feePrice = 0.00;
}
feeDto.setFeePrice(feePrice);
+
+ double month = dayCompare(feeDto.getEndTime(), DateUtil.getCurrentDate());
+ BigDecimal price = new BigDecimal(feeDto.getFeePrice());
+ price = price.multiply(new BigDecimal(month));
+ feeDto.setAmountOwed(price.doubleValue() + "");
}
@@ -312,4 +454,32 @@
feeDto.setFeePrice(feePrice);
}
+
+ /**
+ * 璁$畻2涓棩鏈熶箣闂寸浉宸殑 浠ュ勾銆佹湀銆佹棩涓哄崟浣嶏紝鍚勮嚜璁$畻缁撴灉鏄灏�
+ * 姣斿锛�2011-02-02 鍒� 2017-03-02
+ * 浠ュ勾涓哄崟浣嶇浉宸负锛�6骞�
+ * 浠ユ湀涓哄崟浣嶇浉宸负锛�73涓湀
+ * 浠ユ棩涓哄崟浣嶇浉宸负锛�2220澶�
+ *
+ * @param fromDate
+ * @param toDate
+ * @return
+ */
+ public static double dayCompare(Date fromDate, Date toDate) {
+ Calendar from = Calendar.getInstance();
+ from.setTime(fromDate);
+ Calendar to = Calendar.getInstance();
+ to.setTime(toDate);
+
+ long t1 = from.getTimeInMillis();
+ long t2 = to.getTimeInMillis();
+ long days = (t2 - t1) / (24 * 60 * 60 * 1000);
+
+ BigDecimal tmpDays = new BigDecimal(days);
+ BigDecimal monthDay = new BigDecimal(30);
+
+ return tmpDays.divide(monthDay, 2, RoundingMode.HALF_UP).doubleValue();
+ }
+
}
--
Gitblit v1.8.0