|
|
@@ -20,15 +20,20 @@ import com.java110.core.annotation.Java110Cmd;
|
|
|
import com.java110.core.context.ICmdDataFlowContext;
|
|
|
import com.java110.core.event.cmd.Cmd;
|
|
|
import com.java110.core.event.cmd.CmdEvent;
|
|
|
+import com.java110.core.smo.IComputeFeeSMO;
|
|
|
+import com.java110.dto.fee.FeeDto;
|
|
|
import com.java110.intf.fee.IPayFeeRuleBillV1InnerServiceSMO;
|
|
|
import com.java110.utils.exception.CmdException;
|
|
|
-import com.java110.utils.util.Assert;
|
|
|
-import com.java110.utils.util.BeanConvertUtil;
|
|
|
+import com.java110.utils.util.*;
|
|
|
import com.java110.vo.ResultVo;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import com.java110.dto.payFeeRuleBill.PayFeeRuleBillDto;
|
|
|
+
|
|
|
+import java.math.BigDecimal;
|
|
|
import java.util.List;
|
|
|
import java.util.ArrayList;
|
|
|
+import java.util.Map;
|
|
|
+
|
|
|
import org.springframework.http.ResponseEntity;
|
|
|
import org.springframework.http.HttpStatus;
|
|
|
import org.slf4j.Logger;
|
|
|
@@ -48,10 +53,14 @@ import org.slf4j.LoggerFactory;
|
|
|
@Java110Cmd(serviceCode = "payFeeRule.listPayFeeRuleBill")
|
|
|
public class ListPayFeeRuleBillCmd extends Cmd {
|
|
|
|
|
|
- private static Logger logger = LoggerFactory.getLogger(ListPayFeeRuleBillCmd.class);
|
|
|
+ private static Logger logger = LoggerFactory.getLogger(ListPayFeeRuleBillCmd.class);
|
|
|
@Autowired
|
|
|
private IPayFeeRuleBillV1InnerServiceSMO payFeeRuleBillV1InnerServiceSMOImpl;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private IComputeFeeSMO computeFeeSMOImpl;
|
|
|
+
|
|
|
+
|
|
|
@Override
|
|
|
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
|
|
|
super.validatePageInfo(reqJson);
|
|
|
@@ -60,23 +69,95 @@ public class ListPayFeeRuleBillCmd extends Cmd {
|
|
|
|
|
|
@Override
|
|
|
public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
|
|
|
+ //todo 如果根据费用ID查询账单规则
|
|
|
+ ifHasFeeId(reqJson);
|
|
|
+ PayFeeRuleBillDto payFeeRuleBillDto = BeanConvertUtil.covertBean(reqJson, PayFeeRuleBillDto.class);
|
|
|
+
|
|
|
+ int count = payFeeRuleBillV1InnerServiceSMOImpl.queryPayFeeRuleBillsCount(payFeeRuleBillDto);
|
|
|
+
|
|
|
+ List<PayFeeRuleBillDto> payFeeRuleBillDtos = null;
|
|
|
+
|
|
|
+ if (count > 0) {
|
|
|
+ payFeeRuleBillDtos = payFeeRuleBillV1InnerServiceSMOImpl.queryPayFeeRuleBills(payFeeRuleBillDto);
|
|
|
+ } else {
|
|
|
+ payFeeRuleBillDtos = new ArrayList<>();
|
|
|
+ }
|
|
|
+
|
|
|
+ computeFeePrice(payFeeRuleBillDtos);
|
|
|
+
|
|
|
+ ResultVo resultVo = new ResultVo((int) Math.ceil((double) count / (double) reqJson.getInteger("row")), count, payFeeRuleBillDtos);
|
|
|
|
|
|
- PayFeeRuleBillDto payFeeRuleBillDto = BeanConvertUtil.covertBean(reqJson, PayFeeRuleBillDto.class);
|
|
|
+ ResponseEntity<String> responseEntity = new ResponseEntity<String>(resultVo.toString(), HttpStatus.OK);
|
|
|
|
|
|
- int count = payFeeRuleBillV1InnerServiceSMOImpl.queryPayFeeRuleBillsCount(payFeeRuleBillDto);
|
|
|
+ cmdDataFlowContext.setResponseEntity(responseEntity);
|
|
|
+ }
|
|
|
+
|
|
|
+ private void computeFeePrice(List<PayFeeRuleBillDto> payFeeRuleBillDtos) {
|
|
|
+
|
|
|
+ if(payFeeRuleBillDtos == null || payFeeRuleBillDtos.isEmpty()){
|
|
|
+ return ;
|
|
|
+ }
|
|
|
+
|
|
|
+ for(PayFeeRuleBillDto payFeeRuleBillDto : payFeeRuleBillDtos){
|
|
|
+ payFeeRuleBillDto.setCycle("1");
|
|
|
+
|
|
|
+ try{
|
|
|
+ doComputeFeePrice(payFeeRuleBillDto,1);
|
|
|
+ } catch (Exception e) {
|
|
|
+ logger.error("查询费用信息 ,费用信息错误", e);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 根据房屋来算单价
|
|
|
+ *
|
|
|
+ * @param feeDto
|
|
|
+ */
|
|
|
+ private void doComputeFeePrice(FeeDto feeDto, double oweMonth) {
|
|
|
+ String computingFormula = feeDto.getComputingFormula();
|
|
|
+ Map feePriceAll = computeFeeSMOImpl.getFeePrice(feeDto);
|
|
|
+ feeDto.setFeePrice(Double.parseDouble(feePriceAll.get("feePrice").toString()));
|
|
|
+ //BigDecimal feeTotalPrice = new BigDecimal(Double.parseDouble(feePriceAll.get("feeTotalPrice").toString()));
|
|
|
+ feeDto.setFeeTotalPrice(MoneyUtil.computePriceScale(Double.parseDouble(feePriceAll.get("feeTotalPrice").toString()),
|
|
|
+ feeDto.getScale(),
|
|
|
+ Integer.parseInt(feeDto.getDecimalPlace())));
|
|
|
+ BigDecimal curFeePrice = new BigDecimal(feeDto.getFeePrice());
|
|
|
+ curFeePrice = curFeePrice.multiply(new BigDecimal(oweMonth));
|
|
|
+ feeDto.setAmountOwed(MoneyUtil.computePriceScale(curFeePrice.doubleValue(), feeDto.getScale(), Integer.parseInt(feeDto.getDecimalPlace())) + "");
|
|
|
+ //动态费用
|
|
|
+ if ("4004".equals(computingFormula)
|
|
|
+ && FeeDto.FEE_FLAG_ONCE.equals(feeDto.getFeeFlag())
|
|
|
+ && !FeeDto.STATE_FINISH.equals(feeDto.getState())
|
|
|
+ && feeDto.getDeadlineTime() == null) {
|
|
|
+ feeDto.setDeadlineTime(DateUtil.getCurrentDate());
|
|
|
+ }
|
|
|
+ //考虑租金递增
|
|
|
+ computeFeeSMOImpl.dealRentRate(feeDto);
|
|
|
+
|
|
|
+ }
|
|
|
|
|
|
- List<PayFeeRuleBillDto> payFeeRuleBillDtos = null;
|
|
|
+ private void ifHasFeeId(JSONObject reqJson) {
|
|
|
+ if (!reqJson.containsKey("feeId")) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
|
|
|
- if (count > 0) {
|
|
|
- payFeeRuleBillDtos = payFeeRuleBillV1InnerServiceSMOImpl.queryPayFeeRuleBills(payFeeRuleBillDto);
|
|
|
- } else {
|
|
|
- payFeeRuleBillDtos = new ArrayList<>();
|
|
|
- }
|
|
|
+ String feeId = reqJson.getString("feeId");
|
|
|
|
|
|
- ResultVo resultVo = new ResultVo((int) Math.ceil((double) count / (double) reqJson.getInteger("row")), count, payFeeRuleBillDtos);
|
|
|
+ if (StringUtil.isEmpty(feeId)) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
|
|
|
- ResponseEntity<String> responseEntity = new ResponseEntity<String>(resultVo.toString(), HttpStatus.OK);
|
|
|
+ PayFeeRuleBillDto payFeeRuleBillDto = new PayFeeRuleBillDto();
|
|
|
+ payFeeRuleBillDto.setFeeId(feeId);
|
|
|
+ payFeeRuleBillDto.setCommunityId(reqJson.getString("communityId"));
|
|
|
+ List<PayFeeRuleBillDto> payFeeRuleBillDtos = payFeeRuleBillV1InnerServiceSMOImpl.queryPayFeeRuleBills(payFeeRuleBillDto);
|
|
|
|
|
|
- cmdDataFlowContext.setResponseEntity(responseEntity);
|
|
|
+ if (payFeeRuleBillDtos == null || payFeeRuleBillDtos.isEmpty()) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ reqJson.remove("feeId");
|
|
|
+ reqJson.put("ruleId", payFeeRuleBillDtos.get(0).getRuleId());
|
|
|
}
|
|
|
}
|