package com.java110.report.cmd.reportFeeMonthStatistics; import com.alibaba.fastjson.JSONObject; 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.dto.report.QueryStatisticsDto; import com.java110.report.statistics.IFeeStatistics; import com.java110.utils.exception.CmdException; import com.java110.utils.util.Assert; import com.java110.vo.ResultVo; import org.springframework.beans.factory.annotation.Autowired; import java.math.BigDecimal; import java.text.ParseException; import java.util.List; import java.util.Map; /** * 费用项费用统计 */ @Java110Cmd(serviceCode = "reportFeeMonthStatistics.queryReportConfigFeeSummary") public class QueryReportConfigFeeSummaryCmd extends Cmd { @Autowired private IFeeStatistics feeStatisticsImpl; @Override public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException { Assert.hasKeyAndValue(reqJson, "startDate", "未包含开始日期"); Assert.hasKeyAndValue(reqJson, "endDate", "未包含结束日期"); Assert.hasKeyAndValue(reqJson, "communityId", "未包含小区信息"); } @Override public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException { QueryStatisticsDto queryStatisticsDto = new QueryStatisticsDto(); queryStatisticsDto.setCommunityId(reqJson.getString("communityId")); queryStatisticsDto.setStartDate(reqJson.getString("startDate")); queryStatisticsDto.setEndDate(reqJson.getString("endDate")); queryStatisticsDto.setFloorId(reqJson.getString("floorId")); if (reqJson.containsKey("configIds")) { queryStatisticsDto.setConfigIds(reqJson.getString("configIds").split(",")); } List datas = feeStatisticsImpl.getConfigFeeSummary(queryStatisticsDto); if (datas == null || datas.size() < 1) { context.setResponseEntity(ResultVo.createResponseEntity(datas)); return; } BigDecimal feeRoomCountDec = null; BigDecimal oweRoomCountDec = null; BigDecimal feeRoomRate = null; BigDecimal hisOweFee = null; BigDecimal curReceivableFee = null; BigDecimal receivedFee = null; BigDecimal preReceivedFee = null; for (Map data : datas) { //todo 计算 户收费率 if (Double.parseDouble(data.get("feeRoomCount").toString()) > 0) { feeRoomCountDec = new BigDecimal(Double.parseDouble(data.get("feeRoomCount").toString())); oweRoomCountDec = new BigDecimal(Double.parseDouble(data.get("oweRoomCount").toString())); feeRoomRate = feeRoomCountDec.subtract(oweRoomCountDec).divide(feeRoomCountDec, 4, BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal(100)).setScale(2, BigDecimal.ROUND_HALF_UP); data.put("feeRoomRate", feeRoomRate.doubleValue()); } else { data.put("feeRoomRate", 0.0); } //todo 计算 收费率 hisOweFee = new BigDecimal(Double.parseDouble(data.get("hisOweFee").toString())); curReceivableFee = new BigDecimal(Double.parseDouble(data.get("curReceivableFee").toString())); hisOweFee = curReceivableFee.add(hisOweFee); if (hisOweFee.doubleValue() > 0) { receivedFee = new BigDecimal(Double.parseDouble(data.get("receivedFee").toString())); preReceivedFee = new BigDecimal(Double.parseDouble(data.get("preReceivedFee").toString())); feeRoomRate = receivedFee.subtract(preReceivedFee).divide(hisOweFee, 4, BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal(100)).setScale(2, BigDecimal.ROUND_HALF_UP); data.put("feeRate", feeRoomRate.doubleValue()); } else { data.put("feeRate", 0.0); } } context.setResponseEntity(ResultVo.createResponseEntity(datas)); } }