|
@@ -8,15 +8,25 @@ import com.java110.core.context.ICmdDataFlowContext;
|
|
|
import com.java110.core.event.cmd.Cmd;
|
|
import com.java110.core.event.cmd.Cmd;
|
|
|
import com.java110.core.event.cmd.CmdEvent;
|
|
import com.java110.core.event.cmd.CmdEvent;
|
|
|
import com.java110.dto.fee.FeeDto;
|
|
import com.java110.dto.fee.FeeDto;
|
|
|
|
|
+import com.java110.dto.fee.PayFeeDto;
|
|
|
import com.java110.dto.owner.OwnerCarDto;
|
|
import com.java110.dto.owner.OwnerCarDto;
|
|
|
import com.java110.dto.parking.ParkingSpaceDto;
|
|
import com.java110.dto.parking.ParkingSpaceDto;
|
|
|
import com.java110.intf.community.IParkingSpaceInnerServiceSMO;
|
|
import com.java110.intf.community.IParkingSpaceInnerServiceSMO;
|
|
|
import com.java110.intf.community.IParkingSpaceV1InnerServiceSMO;
|
|
import com.java110.intf.community.IParkingSpaceV1InnerServiceSMO;
|
|
|
import com.java110.intf.fee.IFeeInnerServiceSMO;
|
|
import com.java110.intf.fee.IFeeInnerServiceSMO;
|
|
|
|
|
+import com.java110.intf.fee.IPayFeeDetailMonthInnerServiceSMO;
|
|
|
|
|
+import com.java110.intf.fee.IPayFeeDetailV1InnerServiceSMO;
|
|
|
|
|
+import com.java110.intf.fee.IPayFeeV1InnerServiceSMO;
|
|
|
|
|
+import com.java110.intf.report.IReportOweFeeInnerServiceSMO;
|
|
|
import com.java110.intf.user.IOwnerCarInnerServiceSMO;
|
|
import com.java110.intf.user.IOwnerCarInnerServiceSMO;
|
|
|
import com.java110.intf.user.IOwnerCarV1InnerServiceSMO;
|
|
import com.java110.intf.user.IOwnerCarV1InnerServiceSMO;
|
|
|
import com.java110.po.car.OwnerCarPo;
|
|
import com.java110.po.car.OwnerCarPo;
|
|
|
|
|
+import com.java110.po.fee.PayFeeDetailPo;
|
|
|
|
|
+import com.java110.po.fee.PayFeePo;
|
|
|
import com.java110.po.parking.ParkingSpacePo;
|
|
import com.java110.po.parking.ParkingSpacePo;
|
|
|
|
|
+import com.java110.po.payFee.PayFeeDetailMonthPo;
|
|
|
|
|
+import com.java110.po.reportFee.ReportOweFeePo;
|
|
|
|
|
+import com.java110.po.room.RoomPo;
|
|
|
import com.java110.utils.exception.CmdException;
|
|
import com.java110.utils.exception.CmdException;
|
|
|
import com.java110.utils.util.Assert;
|
|
import com.java110.utils.util.Assert;
|
|
|
import com.java110.utils.util.BeanConvertUtil;
|
|
import com.java110.utils.util.BeanConvertUtil;
|
|
@@ -43,6 +53,18 @@ public class DeleteOwnerCarsCmd extends Cmd {
|
|
|
@Autowired
|
|
@Autowired
|
|
|
private IOwnerCarV1InnerServiceSMO ownerCarV1InnerServiceSMOImpl;
|
|
private IOwnerCarV1InnerServiceSMO ownerCarV1InnerServiceSMOImpl;
|
|
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IPayFeeV1InnerServiceSMO payFeeV1InnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IPayFeeDetailV1InnerServiceSMO payFeeDetailV1InnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IReportOweFeeInnerServiceSMO reportOweFeeInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IPayFeeDetailMonthInnerServiceSMO payFeeDetailMonthInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
@Override
|
|
@Override
|
|
|
public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
|
|
public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
|
|
|
Environment.isDevEnv();
|
|
Environment.isDevEnv();
|
|
@@ -81,7 +103,7 @@ public class DeleteOwnerCarsCmd extends Cmd {
|
|
|
ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
|
|
ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
|
|
|
parkingSpaceDto.setPsId(reqJson.getString("psId"));
|
|
parkingSpaceDto.setPsId(reqJson.getString("psId"));
|
|
|
List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
|
|
List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
|
|
|
- if (parkingSpaceDtos != null && parkingSpaceDtos.size()> 0 &&
|
|
|
|
|
|
|
+ if (parkingSpaceDtos != null && parkingSpaceDtos.size() > 0 &&
|
|
|
"2".equals(parkingSpaceDtos.get(0).getParkingType())
|
|
"2".equals(parkingSpaceDtos.get(0).getParkingType())
|
|
|
&& "1001".equals(reqJson.getString("carTypeCd"))) { //子母车位
|
|
&& "1001".equals(reqJson.getString("carTypeCd"))) { //子母车位
|
|
|
OwnerCarDto ownerCarDto = new OwnerCarDto();
|
|
OwnerCarDto ownerCarDto = new OwnerCarDto();
|
|
@@ -106,30 +128,104 @@ public class DeleteOwnerCarsCmd extends Cmd {
|
|
|
if (StringUtil.isEmpty(reqJson.getString("psId")) || "-1".equals(reqJson.getString("psId"))) {
|
|
if (StringUtil.isEmpty(reqJson.getString("psId")) || "-1".equals(reqJson.getString("psId"))) {
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
- //释放车位
|
|
|
|
|
- if (reqJson.getString("carId").equals(reqJson.getString("memberId"))) {
|
|
|
|
|
- reqJson.put("carNumType", ParkingSpaceDto.STATE_FREE);//修改为空闲
|
|
|
|
|
- ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
|
|
|
|
|
- parkingSpaceDto.setCommunityId(reqJson.getString("communityId"));
|
|
|
|
|
- parkingSpaceDto.setPsId(reqJson.getString("psId"));
|
|
|
|
|
- List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
|
|
|
|
|
|
|
+ // todo 释放车位
|
|
|
|
|
+ releaseParkSpace(reqJson);
|
|
|
|
|
|
|
|
- if (parkingSpaceDtos == null || parkingSpaceDtos.size() != 1) {
|
|
|
|
|
- //throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_ERROR, "未查询到停车位信息" + JSONObject.toJSONString(parkingSpaceDto));
|
|
|
|
|
- return;
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ // todo 删除车辆费用
|
|
|
|
|
+ deleteCarFee(reqJson);
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- parkingSpaceDto = parkingSpaceDtos.get(0);
|
|
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 释放车位信息
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param reqJson
|
|
|
|
|
+ */
|
|
|
|
|
+ private void releaseParkSpace(JSONObject reqJson) {
|
|
|
|
|
+ int flag;
|
|
|
|
|
+ if (!reqJson.getString("carId").equals(reqJson.getString("memberId"))) {
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ reqJson.put("carNumType", ParkingSpaceDto.STATE_FREE);//修改为空闲
|
|
|
|
|
+ ParkingSpaceDto parkingSpaceDto = new ParkingSpaceDto();
|
|
|
|
|
+ parkingSpaceDto.setCommunityId(reqJson.getString("communityId"));
|
|
|
|
|
+ parkingSpaceDto.setPsId(reqJson.getString("psId"));
|
|
|
|
|
+ List<ParkingSpaceDto> parkingSpaceDtos = parkingSpaceInnerServiceSMOImpl.queryParkingSpaces(parkingSpaceDto);
|
|
|
|
|
+
|
|
|
|
|
+ if (parkingSpaceDtos == null || parkingSpaceDtos.size() != 1) {
|
|
|
|
|
+ //throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_ERROR, "未查询到停车位信息" + JSONObject.toJSONString(parkingSpaceDto));
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- JSONObject businessParkingSpace = new JSONObject();
|
|
|
|
|
|
|
+ parkingSpaceDto = parkingSpaceDtos.get(0);
|
|
|
|
|
+ JSONObject businessParkingSpace = new JSONObject();
|
|
|
|
|
+ businessParkingSpace.putAll(BeanConvertUtil.beanCovertMap(parkingSpaceDto));
|
|
|
|
|
+ businessParkingSpace.put("state", reqJson.getString("carNumType"));
|
|
|
|
|
+ ParkingSpacePo parkingSpacePo = BeanConvertUtil.covertBean(businessParkingSpace, ParkingSpacePo.class);
|
|
|
|
|
+ flag = parkingSpaceV1InnerServiceSMOImpl.updateParkingSpace(parkingSpacePo);
|
|
|
|
|
+ if (flag < 1) {
|
|
|
|
|
+ throw new IllegalArgumentException("修改车辆出错");
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- businessParkingSpace.putAll(BeanConvertUtil.beanCovertMap(parkingSpaceDto));
|
|
|
|
|
- businessParkingSpace.put("state", reqJson.getString("carNumType"));
|
|
|
|
|
- ParkingSpacePo parkingSpacePo = BeanConvertUtil.covertBean(businessParkingSpace, ParkingSpacePo.class);
|
|
|
|
|
- flag = parkingSpaceV1InnerServiceSMOImpl.updateParkingSpace(parkingSpacePo);
|
|
|
|
|
- if (flag < 1) {
|
|
|
|
|
- throw new IllegalArgumentException("修改车辆出错");
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 删除房屋费用
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param reqJson
|
|
|
|
|
+ */
|
|
|
|
|
+ private void deleteCarFee(JSONObject reqJson) {
|
|
|
|
|
+
|
|
|
|
|
+ if (!reqJson.getString("carId").equals(reqJson.getString("memberId"))) {
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if (StringUtil.isEmpty(reqJson.getString("carId"))) {
|
|
|
|
|
+ throw new CmdException("车联不能为空");
|
|
|
|
|
+ }
|
|
|
|
|
+ PayFeeDto feeDto = new PayFeeDto();
|
|
|
|
|
+ feeDto.setPayerObjId(reqJson.getString("carId"));
|
|
|
|
|
+ feeDto.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_CAR);
|
|
|
|
|
+ feeDto.setCommunityId(reqJson.getString("communityId"));
|
|
|
|
|
+ List<PayFeeDto> feeDtos = payFeeV1InnerServiceSMOImpl.queryPayFees(feeDto);
|
|
|
|
|
+
|
|
|
|
|
+ if (feeDtos == null || feeDtos.size() < 1) {
|
|
|
|
|
+ return;
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
|
|
+ for (PayFeeDto payFeeDto : feeDtos) {
|
|
|
|
|
+ doDeleteFee(payFeeDto);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * @param payFeeDto
|
|
|
|
|
+ */
|
|
|
|
|
+ private void doDeleteFee(PayFeeDto payFeeDto) {
|
|
|
|
|
+ //todo 删除缴费记录
|
|
|
|
|
+
|
|
|
|
|
+ PayFeeDetailPo payFeeDetailPo = new PayFeeDetailPo();
|
|
|
|
|
+ payFeeDetailPo.setFeeId(payFeeDto.getFeeId());
|
|
|
|
|
+ payFeeDetailPo.setCommunityId(payFeeDto.getCommunityId());
|
|
|
|
|
+ payFeeDetailV1InnerServiceSMOImpl.deletePayFeeDetailNew(payFeeDetailPo);
|
|
|
|
|
+
|
|
|
|
|
+ //todo 删除费用
|
|
|
|
|
+ PayFeePo payFeePo = new PayFeePo();
|
|
|
|
|
+ payFeePo.setFeeId(payFeeDto.getFeeId());
|
|
|
|
|
+ payFeePo.setCommunityId(payFeeDto.getCommunityId());
|
|
|
|
|
+ payFeeV1InnerServiceSMOImpl.deletePayFee(payFeePo);
|
|
|
|
|
+
|
|
|
|
|
+ //todo 删除欠费
|
|
|
|
|
+ ReportOweFeePo reportOweFeePo = new ReportOweFeePo();
|
|
|
|
|
+ reportOweFeePo.setFeeId(payFeeDto.getFeeId());
|
|
|
|
|
+ reportOweFeePo.setCommunityId(payFeeDto.getCommunityId());
|
|
|
|
|
+ reportOweFeeInnerServiceSMOImpl.deleteReportOweFee(reportOweFeePo);
|
|
|
|
|
+
|
|
|
|
|
+ //todo 删除 离散月数据
|
|
|
|
|
+ PayFeeDetailMonthPo payFeeDetailMonthPo = new PayFeeDetailMonthPo();
|
|
|
|
|
+ payFeeDetailMonthPo.setFeeId(payFeeDto.getFeeId());
|
|
|
|
|
+ payFeeDetailMonthPo.setCommunityId(payFeeDto.getCommunityId());
|
|
|
|
|
+ payFeeDetailMonthInnerServiceSMOImpl.deletePayFeeDetailMonth(payFeeDetailMonthPo);
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
}
|
|
}
|