From fbc8d20f0ae2f663e1a13560f314f05b870c998c Mon Sep 17 00:00:00 2001
From: his-uncles-father <88386378@qq.com>
Date: 星期三, 21 四月 2021 16:16:28 +0800
Subject: [PATCH] 合同附件上传
---
service-front/src/main/java/com/java110/front/smo/assetImport/impl/ImportRoomFeeSMOImpl.java | 232 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
1 files changed, 224 insertions(+), 8 deletions(-)
diff --git a/service-front/src/main/java/com/java110/front/smo/assetImport/impl/ImportRoomFeeSMOImpl.java b/service-front/src/main/java/com/java110/front/smo/assetImport/impl/ImportRoomFeeSMOImpl.java
index a093f3b..286e9de 100644
--- a/service-front/src/main/java/com/java110/front/smo/assetImport/impl/ImportRoomFeeSMOImpl.java
+++ b/service-front/src/main/java/com/java110/front/smo/assetImport/impl/ImportRoomFeeSMOImpl.java
@@ -2,17 +2,31 @@
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
+
+import com.java110.config.properties.code.Java110Properties;
+import com.java110.core.client.FtpUploadTemplate;
+import com.java110.core.client.OssUploadTemplate;
+
import com.java110.core.component.BaseComponentSMO;
import com.java110.core.context.IPageData;
import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.dto.RoomDto;
+import com.java110.dto.fee.FeeDto;
import com.java110.entity.assetImport.ImportRoomFee;
import com.java110.entity.component.ComponentValidateResult;
import com.java110.front.smo.assetImport.IImportRoomFeeSMO;
+
+import com.java110.utils.cache.MappingCache;
+import com.java110.utils.constant.ServiceConstant;
+import com.java110.utils.util.*;
+
import com.java110.utils.constant.ServiceConstant;
import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
import com.java110.utils.util.DateUtil;
import com.java110.utils.util.ImportExcelUtils;
import com.java110.utils.util.StringUtil;
+
import com.java110.vo.ResultVo;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
@@ -48,26 +62,83 @@
@Autowired
private RestTemplate restTemplate;
+ @Autowired
+ private FtpUploadTemplate ftpUploadTemplate;
+
+ @Autowired
+ private Java110Properties java110Properties;
+
+ @Autowired
+ private OssUploadTemplate ossUploadTemplate;
+
+
@Override
public ResponseEntity<String> importExcelData(IPageData pd, MultipartFile uploadFile) throws Exception {
try {
ComponentValidateResult result = this.validateStoreStaffCommunityRelationship(pd, restTemplate);
+ JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+ Assert.hasKeyAndValue(paramIn, "communityId", "璇锋眰涓湭鍖呭惈灏忓尯");
+ Assert.hasKeyAndValue(paramIn, "objType", "璇锋眰涓湭鍖呭惈璐圭敤瀵硅薄");
+
//InputStream is = uploadFile.getInputStream();
Workbook workbook = ImportExcelUtils.createWorkbook(uploadFile); //宸ヤ綔绨�
- List<ImportRoomFee> rooms = new ArrayList<ImportRoomFee>();
-
- //鑾峰彇妤间俊鎭�
- getRooms(workbook, rooms);
- // 淇濆瓨鏁版嵁
- return dealExcelData(pd, rooms, result);
+ if (FeeDto.PAYER_OBJ_TYPE_ROOM.equals(paramIn.getString("objType"))) {
+ List<ImportRoomFee> rooms = new ArrayList<ImportRoomFee>();
+ //鑾峰彇妤间俊鎭�
+ getRooms(workbook, rooms);
+ // 淇濆瓨鏁版嵁
+ return dealExcelData(pd, rooms, result);
+ }else{
+ List<ImportRoomFee> cars = new ArrayList<ImportRoomFee>();
+ //鑾峰彇妤间俊鎭�
+ getCars(workbook, cars);
+ // 淇濆瓨鏁版嵁
+ return dealExcelCarData(pd, cars, result);
+ }
} catch (Exception e) {
logger.error("瀵煎叆澶辫触 ", e);
return new ResponseEntity<String>("闈炲父鎶辨瓑锛屾偍濉啓鐨勬ā鏉挎暟鎹湁璇細" + e.getMessage(), HttpStatus.BAD_REQUEST);
}
+ }
+
+ @Override
+ public ResponseEntity<String> importFile(MultipartFile uploadFile) throws Exception {
+ try {
+ String fileName = "";
+ String ossSwitch = MappingCache.getValue(OSSUtil.DOMAIN, OSSUtil.OSS_SWITCH);
+ if (StringUtil.isEmpty(ossSwitch) || !OSSUtil.OSS_SWITCH_OSS.equals(ossSwitch)) {
+ fileName = ftpUploadTemplate.upload(uploadFile, java110Properties.getFtpServer(),
+ java110Properties.getFtpPort(), java110Properties.getFtpUserName(),
+ java110Properties.getFtpUserPassword(), java110Properties.getFtpPath());
+ } else {
+ fileName = ossUploadTemplate.upload(uploadFile, java110Properties.getFtpServer(),
+ java110Properties.getFtpPort(), java110Properties.getFtpUserName(),
+ java110Properties.getFtpUserPassword(), java110Properties.getFtpPath());
+ }
+ ResponseEntity<String> responseEntity = new ResponseEntity<String>(fileName, HttpStatus.OK);
+ return responseEntity;
+ } catch (Exception e) {
+ logger.error("涓婁紶鍚堝悓闄勪欢澶辫触 ", e);
+ return new ResponseEntity<String>("闈炲父鎶辨瓑锛屼笂浼犲悎鍚岄檮浠跺け璐ワ細" + e.getMessage(), HttpStatus.BAD_REQUEST);
+ }
+ }
+
+
+
+ @Override
+
+ public ResponseEntity<String> importTempData(IPageData pd) {
+ ComponentValidateResult result = this.validateStoreStaffCommunityRelationship(pd, restTemplate);
+ JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+ ImportRoomFee importRoomFee = BeanConvertUtil.covertBean(paramIn,ImportRoomFee.class);
+ importRoomFee.setRoomId(paramIn.getString("objId"));
+ List<ImportRoomFee> rooms = new ArrayList<ImportRoomFee>();
+ rooms.add(importRoomFee);
+ return dealExcelData(pd, rooms, result);
}
/**
@@ -82,6 +153,25 @@
ResponseEntity<String> responseEntity = null;
//淇濆瓨鍗曞厓淇℃伅 鍜� 妤兼爧淇℃伅
responseEntity = savedRoomFees(pd, roomFees, result);
+
+ if (responseEntity == null || responseEntity.getStatusCode() != HttpStatus.OK) {
+ return responseEntity;
+ }
+
+ return responseEntity;
+ }
+ /**
+ * 澶勭悊ExcelData鏁版嵁
+ *
+ * @param roomFees 鎴垮眿璐圭敤
+ */
+ private ResponseEntity<String> dealExcelCarData(IPageData pd,
+ List<ImportRoomFee> roomFees,
+
+ ComponentValidateResult result) {
+ ResponseEntity<String> responseEntity = null;
+ //淇濆瓨鍗曞厓淇℃伅 鍜� 妤兼爧淇℃伅
+ responseEntity = savedCarFees(pd, roomFees, result);
if (responseEntity == null || responseEntity.getStatusCode() != HttpStatus.OK) {
return responseEntity;
@@ -121,6 +211,37 @@
return ResultVo.createResponseEntity(ResultVo.CODE_OK, "鎴愬姛锛�" + paramOut.getString("successCount") + ",澶辫触锛�" + paramOut.getString("errorCount"));
}
+ private ResponseEntity<String> savedCarFees(IPageData pd, List<ImportRoomFee> carFees, ComponentValidateResult result) {
+
+ if (carFees.size() < 1) {
+ throw new IllegalArgumentException("娌℃湁鏁版嵁闇�瑕佸鐞�");
+ }
+
+ JSONObject paramOut = new JSONObject();
+ paramOut.put("successCount", 0);
+ paramOut.put("errorCount", 0);
+
+ JSONObject data = JSONObject.parseObject(pd.getReqData());
+ data.put("storeId", result.getStoreId());
+ data.put("importFeeId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
+ data.put("userId", result.getUserId());
+ data.put("communityId", result.getCommunityId());
+ List<ImportRoomFee> tmpImportCarFees = new ArrayList<>();
+ for (int carIndex = 0; carIndex < carFees.size(); carIndex++) {
+ tmpImportCarFees.add(carFees.get(carIndex));
+ if (carIndex % DEFAULT_ADD_FEE_COUNT == 0 && carIndex != 0) {
+ createCarFee(pd, tmpImportCarFees, data, paramOut);
+
+ tmpImportCarFees = new ArrayList<>();
+ }
+ }
+ if (tmpImportCarFees != null && tmpImportCarFees.size() > 0) {
+
+ createCarFee(pd, tmpImportCarFees, data, paramOut);
+ }
+ return ResultVo.createResponseEntity(ResultVo.CODE_OK, "鎴愬姛锛�" + paramOut.getString("successCount") + ",澶辫触锛�" + paramOut.getString("errorCount"));
+ }
+
/**
* 鍒涘缓璐圭敤
*
@@ -147,8 +268,57 @@
JSONObject resOut = JSONObject.parseObject(responseEntity.getBody());
- successCount += resOut.getInteger("successCount");
- errorCount += resOut.getInteger("errorCount");
+ if (ResultVo.CODE_OK != resOut.getInteger("code")) {
+ errorCount += tmpImportRoomFee.size();
+ paramOut.put("errorCount", errorCount);
+ return;
+ }
+
+ JSONObject resData = resOut.getJSONObject("data");
+
+ successCount += resData.getInteger("successCount");
+ errorCount += resData.getInteger("errorCount");
+
+ paramOut.put("successCount", successCount);
+ paramOut.put("errorCount", errorCount);
+ }
+
+ /**
+ * 鍒涘缓璐圭敤
+ *
+ * @param pd
+ * @param tmpImportCarFee
+ */
+ private void createCarFee(IPageData pd, List<ImportRoomFee> tmpImportCarFee, JSONObject data, JSONObject paramOut) {
+
+ int successCount = paramOut.getInteger("successCount");
+ int errorCount = paramOut.getInteger("errorCount");
+
+ JSONArray importCarFees = JSONArray.parseArray(JSONObject.toJSONString(tmpImportCarFee));
+ data.put("importCarFees", importCarFees);
+
+ String apiUrl = ServiceConstant.SERVICE_API_URL + "/api/feeApi/importCarFees";
+
+ ResponseEntity<String> responseEntity = this.callCenterService(restTemplate, pd, data.toJSONString(), apiUrl, HttpMethod.POST);
+
+ if (HttpStatus.OK != responseEntity.getStatusCode()) {
+ errorCount += tmpImportCarFee.size();
+ paramOut.put("errorCount", errorCount);
+ return;
+ }
+
+ JSONObject resOut = JSONObject.parseObject(responseEntity.getBody());
+
+ if (ResultVo.CODE_OK != resOut.getInteger("code")) {
+ errorCount += tmpImportCarFee.size();
+ paramOut.put("errorCount", errorCount);
+ return;
+ }
+
+ JSONObject resData = resOut.getJSONObject("data");
+
+ successCount += resData.getInteger("successCount");
+ errorCount += resData.getInteger("errorCount");
paramOut.put("successCount", successCount);
paramOut.put("errorCount", errorCount);
@@ -206,6 +376,52 @@
}
}
+ /**
+ * 鑾峰彇 鎴垮眿淇℃伅
+ *
+ * @param workbook
+ * @param cars
+ */
+ private void getCars(Workbook workbook, List<ImportRoomFee> cars) {
+ Sheet sheet = null;
+ sheet = ImportExcelUtils.getSheet(workbook, "杞︿綅璐圭敤淇℃伅");
+ List<Object[]> oList = ImportExcelUtils.listFromSheet(sheet);
+ ImportRoomFee importRoomFee = null;
+ for (int osIndex = 0; osIndex < oList.size(); osIndex++) {
+ Object[] os = oList.get(osIndex);
+ if (osIndex == 0 || osIndex == 1) { // 绗竴琛屾槸 澶撮儴淇℃伅 鐩存帴璺宠繃
+ continue;
+ }
+ if (StringUtil.isNullOrNone(os[0])) {
+ continue;
+ }
+
+ //璐圭敤鍚嶇О娌℃湁濉啓锛岄粯璁よ烦杩�
+ if (StringUtil.isNullOrNone(os[1])) {
+ continue;
+ }
+ Assert.hasValue(os[2], (osIndex + 1) + "琛屽紑濮嬫椂闂翠笉鑳戒负绌�");
+ Assert.hasValue(os[3], (osIndex + 1) + "琛岀粨鏉熸椂闂翠笉鑳戒负绌�");
+ Assert.hasValue(os[4], (osIndex + 1) + "琛岃垂鐢ㄤ笉鑳戒负绌�");
+
+//
+
+ String startTime = excelDoubleToDate(os[2].toString());
+ String endTime = excelDoubleToDate(os[3].toString());
+ Assert.isDate(startTime, DateUtil.DATE_FORMATE_STRING_B, (osIndex + 1) + "琛屽紑濮嬫椂闂存牸寮忛敊璇� 璇峰~鍐橸YYY-MM-DD 鏂囨湰鏍煎紡");
+ Assert.isDate(endTime, DateUtil.DATE_FORMATE_STRING_B, (osIndex + 1) + "琛岀粨鏉熸椂闂存牸寮忛敊璇� 璇峰~鍐橸YYY-MM-DD 鏂囨湰鏍煎紡");
+
+
+ importRoomFee = new ImportRoomFee();
+ importRoomFee.setCarNum(os[0].toString());
+ importRoomFee.setFeeName(os[1].toString());
+ importRoomFee.setStartTime(startTime);
+ importRoomFee.setEndTime(endTime);
+ importRoomFee.setAmount(os[4].toString());
+ cars.add(importRoomFee);
+ }
+ }
+
//瑙f瀽Excel鏃ユ湡鏍煎紡
public static String excelDoubleToDate(String strDate) {
--
Gitblit v1.8.0