| | |
| | | import com.java110.core.component.BaseComponentSMO; |
| | | import com.java110.core.context.IPageData; |
| | | import com.java110.core.factory.GenerateCodeFactory; |
| | | import com.java110.entity.assetImport.ImportRoomFee; |
| | | import com.java110.dto.meterWater.ImportExportMeterWaterDto; |
| | | import com.java110.entity.component.ComponentValidateResult; |
| | | import com.java110.front.smo.assetImport.IImportRoomFeeSMO; |
| | | import com.java110.utils.constant.ServiceConstant; |
| | |
| | | |
| | | Workbook workbook = ImportExcelUtils.createWorkbook(uploadFile); //工作簿 |
| | | |
| | | List<ImportRoomFee> rooms = new ArrayList<ImportRoomFee>(); |
| | | List<ImportExportMeterWaterDto> rooms = new ArrayList<ImportExportMeterWaterDto>(); |
| | | |
| | | //获取楼信息 |
| | | getRooms(workbook, rooms); |
| | |
| | | |
| | | /** |
| | | * 处理ExcelData数据 |
| | | * |
| | | * @param roomFees 房屋费用 |
| | | */ |
| | | private ResponseEntity<String> dealExcelData(IPageData pd, |
| | | List<ImportRoomFee> roomFees, |
| | | List<ImportExportMeterWaterDto> rooms, |
| | | |
| | | ComponentValidateResult result) { |
| | | ResponseEntity<String> responseEntity = null; |
| | | //保存单元信息 和 楼栋信息 |
| | | responseEntity = savedRoomFees(pd, roomFees, result); |
| | | responseEntity = savedRoomFees(pd, rooms, result); |
| | | |
| | | if (responseEntity == null || responseEntity.getStatusCode() != HttpStatus.OK) { |
| | | return responseEntity; |
| | |
| | | return responseEntity; |
| | | } |
| | | |
| | | private ResponseEntity<String> savedRoomFees(IPageData pd, List<ImportRoomFee> roomFees, ComponentValidateResult result) { |
| | | private ResponseEntity<String> savedRoomFees(IPageData pd, List<ImportExportMeterWaterDto> rooms, ComponentValidateResult result) { |
| | | |
| | | if (roomFees.size() < 1) { |
| | | JSONObject reqJson = JSONObject.parseObject(pd.getReqData()); |
| | | if (rooms.size() < 1) { |
| | | throw new IllegalArgumentException("没有数据需要处理"); |
| | | } |
| | | |
| | |
| | | data.put("importFeeId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId)); |
| | | data.put("storeId", result.getStoreId()); |
| | | data.put("userId", result.getUserId()); |
| | | data.put("configId", reqJson.getString("configId")); |
| | | data.put("feeTypeCd", reqJson.getString("feeTypeCd")); |
| | | data.put("communityId", result.getCommunityId()); |
| | | |
| | | List<ImportRoomFee> tmpImportRoomFees = new ArrayList<>(); |
| | | for (int roomIndex = 0; roomIndex < roomFees.size(); roomIndex++) { |
| | | List<ImportExportMeterWaterDto> tmpImportRoomFees = new ArrayList<>(); |
| | | for (int roomIndex = 0; roomIndex < rooms.size(); roomIndex++) { |
| | | |
| | | tmpImportRoomFees.add(roomFees.get(roomIndex)); |
| | | tmpImportRoomFees.add(rooms.get(roomIndex)); |
| | | |
| | | if (roomIndex % DEFAULT_ADD_FEE_COUNT == 0 && roomIndex != 0) { |
| | | |
| | |
| | | * 创建费用 |
| | | * |
| | | * @param pd |
| | | * @param tmpImportRoomFee |
| | | * @param tmpImportRoomFees |
| | | */ |
| | | private void createRoomFee(IPageData pd, List<ImportRoomFee> tmpImportRoomFee, JSONObject data) { |
| | | private void createRoomFee(IPageData pd, List<ImportExportMeterWaterDto> tmpImportRoomFees, JSONObject data) { |
| | | |
| | | JSONArray importRoomFees = JSONArray.parseArray(JSONObject.toJSONString(tmpImportRoomFee)); |
| | | data.put("importRoomFees", importRoomFees); |
| | | JSONArray importRoomFees = JSONArray.parseArray(JSONObject.toJSONString(tmpImportRoomFees)); |
| | | data.put("importMeteWaterFees", importRoomFees); |
| | | |
| | | String apiUrl = ServiceConstant.SERVICE_API_URL + "/api/feeApi/importRoomFees"; |
| | | String apiUrl = ServiceConstant.SERVICE_API_URL + "/api/meterWater/importMeterWater"; |
| | | |
| | | this.callCenterService(restTemplate, pd, data.toJSONString(), apiUrl, HttpMethod.POST); |
| | | } |
| | |
| | | * @param workbook |
| | | * @param rooms |
| | | */ |
| | | private void getRooms(Workbook workbook, List<ImportRoomFee> rooms) { |
| | | private void getRooms(Workbook workbook, List<ImportExportMeterWaterDto> rooms) { |
| | | Sheet sheet = null; |
| | | sheet = ImportExcelUtils.getSheet(workbook, "房屋费用信息"); |
| | | List<Object[]> oList = ImportExcelUtils.listFromSheet(sheet); |
| | | ImportRoomFee importRoomFee = null; |
| | | ImportExportMeterWaterDto importRoomFee = null; |
| | | for (int osIndex = 0; osIndex < oList.size(); osIndex++) { |
| | | Object[] os = oList.get(osIndex); |
| | | if (osIndex == 0 || osIndex == 1) { // 第一行是 头部信息 直接跳过 |
| | |
| | | if (StringUtil.isNullOrNone(os[0])) { |
| | | continue; |
| | | } |
| | | |
| | | //费用名称没有填写,默认跳过 |
| | | if (StringUtil.isNullOrNone(os[4])) { |
| | | continue; |
| | | } |
| | | Assert.hasValue(os[1], (osIndex + 1) + "行单元编号不能为空"); |
| | | Assert.hasValue(os[2], (osIndex + 1) + "行房屋编号不能为空"); |
| | | Assert.hasValue(os[3], (osIndex + 1) + "行费用名称不能为空"); |
| | | Assert.hasValue(os[4], (osIndex + 1) + "行开始时间不能为空"); |
| | | Assert.hasValue(os[5], (osIndex + 1) + "行结束时间不能为空"); |
| | | Assert.hasValue(os[6], (osIndex + 1) + "行费用不能为空"); |
| | | Assert.hasValue(os[1], (osIndex + 1) + "单元编号不能为空"); |
| | | Assert.hasValue(os[2], (osIndex + 1) + "房屋编号不能为空"); |
| | | Assert.hasValue(os[3], (osIndex + 1) + "上期度数不能为空"); |
| | | Assert.hasValue(os[4], (osIndex + 1) + "上期度数时间不能为空"); |
| | | Assert.hasValue(os[5], (osIndex + 1) + "本期度数不能为空"); |
| | | Assert.hasValue(os[6], (osIndex + 1) + "本期度数时间不能为空"); |
| | | |
| | | // |
| | | |
| | | String startTime = excelDoubleToDate(os[4].toString()); |
| | | String endTime = excelDoubleToDate(os[5].toString()); |
| | | Assert.isDate(startTime, DateUtil.DATE_FORMATE_STRING_B, (osIndex + 1) + "行开始时间格式错误 请填写YYYY-MM-DD 文本格式"); |
| | | Assert.isDate(endTime, DateUtil.DATE_FORMATE_STRING_B, (osIndex + 1) + "行结束时间格式错误 请填写YYYY-MM-DD 文本格式"); |
| | | String startTime = excelDoubleToDate(os[5].toString()); |
| | | String endTime = excelDoubleToDate(os[6].toString()); |
| | | Assert.isDate(startTime, DateUtil.DATE_FORMATE_STRING_A, (osIndex + 1) + "行开始时间格式错误 请填写YYYY-MM-DD hh:mm:ss 文本格式"); |
| | | Assert.isDate(endTime, DateUtil.DATE_FORMATE_STRING_A, (osIndex + 1) + "行结束时间格式错误 请填写YYYY-MM-DD hh:mm:ss 文本格式"); |
| | | |
| | | |
| | | importRoomFee = new ImportRoomFee(); |
| | | importRoomFee = new ImportExportMeterWaterDto(); |
| | | importRoomFee.setFloorNum(os[0].toString()); |
| | | importRoomFee.setUnitNum(os[1].toString()); |
| | | importRoomFee.setRoomNum(os[2].toString()); |
| | | importRoomFee.setFeeName(os[3].toString()); |
| | | importRoomFee.setStartTime(startTime); |
| | | importRoomFee.setEndTime(endTime); |
| | | importRoomFee.setAmount(os[6].toString()); |
| | | importRoomFee.setPreDegrees(os[3].toString()); |
| | | importRoomFee.setPreReadingTime(startTime); |
| | | importRoomFee.setCurDegrees(endTime); |
| | | importRoomFee.setCurReadingTime(os[6].toString()); |
| | | rooms.add(importRoomFee); |
| | | } |
| | | } |