package com.java110.api.smo.assetImport.impl;
|
|
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONObject;
|
import com.java110.api.smo.DefaultAbstractComponentSMO;
|
import com.java110.api.smo.assetImport.IImportResourceStoreSMO;
|
import com.java110.core.context.IPageData;
|
import com.java110.core.factory.GenerateCodeFactory;
|
import com.java110.core.log.LoggerFactory;
|
import com.java110.dto.importData.ImportResourceStoreDto;
|
import com.java110.dto.importData.Vtil;
|
import com.java110.dto.system.ComponentValidateResult;
|
import com.java110.intf.community.IImportOwnerRoomInnerServiceSMO;
|
import com.java110.intf.store.IPurchaseApplyInnerServiceSMO;
|
import com.java110.intf.store.IResourceStoreTypeInnerServiceSMO;
|
import com.java110.intf.store.IStorehouseV1InnerServiceSMO;
|
import com.java110.po.purchase.*;
|
import com.java110.utils.util.BeanConvertUtil;
|
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;
|
import org.mybatis.spring.SqlSessionTemplate;
|
import org.slf4j.Logger;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.http.HttpMethod;
|
import org.springframework.http.HttpStatus;
|
import org.springframework.http.ResponseEntity;
|
import org.springframework.stereotype.Service;
|
import org.springframework.web.client.RestTemplate;
|
import org.springframework.web.multipart.MultipartFile;
|
|
import java.text.ParseException;
|
import java.util.*;
|
|
@Service("importResourceStoreSMOImpl")
|
public class ImportResourceStoreV3SMOImpl extends DefaultAbstractComponentSMO implements IImportResourceStoreSMO {
|
|
private final static Logger logger = LoggerFactory.getLogger(ImportResourceStoreV3SMOImpl.class);
|
|
public static final int DEFAULT_ROWS = 500;
|
|
@Autowired
|
private RestTemplate restTemplate;
|
|
@Autowired
|
private IImportOwnerRoomInnerServiceSMO importOwnerRoomInnerServiceSMOImpl;
|
|
@Autowired
|
private IStorehouseV1InnerServiceSMO storehouseV1InnerServiceSMOImpl;
|
|
@Autowired
|
private IResourceStoreTypeInnerServiceSMO resourceStoreTypeInnerServiceSMOImpl;
|
|
@Autowired
|
private IPurchaseApplyInnerServiceSMO purchaseApplyInnerServiceSMOImpl;
|
|
@Autowired
|
private SqlSessionTemplate sqlSessionTemplate;
|
|
|
public static final String CODE_PREFIX_ID = "10";
|
|
@Override
|
public ResponseEntity<String> importExcelData(IPageData pd, MultipartFile uploadFile) throws Exception {
|
try {
|
ComponentValidateResult result = this.validateStoreStaffCommunityRelationship(pd, restTemplate);
|
//InputStream is = uploadFile.getInputStream();
|
Workbook workbook = ImportExcelUtils.createWorkbook(uploadFile); //工作簿
|
List<Object[]> resourceStoreDtos = new ArrayList<Object[]>();
|
//封装对象
|
getResourceStores(workbook, resourceStoreDtos, result);
|
|
// 保存数据
|
return dealExcelData(pd, resourceStoreDtos, result);
|
} catch (Exception e) {
|
logger.error("导入失败 ", e);
|
return new ResponseEntity<String>("非常抱歉,您填写的模板数据有误:" + e.getMessage(), HttpStatus.BAD_REQUEST);
|
}
|
}
|
|
|
/**
|
* 获取业主车辆信息
|
*
|
* @param workbook
|
* @param resourceStoreDtos
|
*/
|
private void getResourceStores(Workbook workbook, List<Object[]> resourceStoreDtos, ComponentValidateResult result) throws ParseException {
|
Sheet sheet = null;
|
sheet = ImportExcelUtils.getSheet(workbook, "登记表");
|
List<Object[]> oList = ImportExcelUtils.listFromSheet(sheet);
|
ImportResourceStoreDto resourceStoreDto = null;
|
for (int osIndex = 0; osIndex < oList.size(); osIndex++) {
|
|
Object[] os = oList.get(osIndex);
|
resourceStoreDtos.add(os);
|
}
|
}
|
|
|
/**
|
* 处理房产信息
|
*/
|
private ResponseEntity<String> dealExcelData(IPageData pd, List<Object[]> resourceStoreDtos, ComponentValidateResult result) {
|
ResponseEntity<String> responseEntity = null;
|
|
List<ImportResourceStoreDto> tmpImportResourceStoreDtos = new ArrayList<>();
|
int flag = 0;
|
|
JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
|
|
int successCount = 0;
|
JSONObject data = new JSONObject();
|
data.put("userId", result.getUserId());
|
data.put("userName", result.getUserName());
|
data.put("storeId", result.getStoreId());
|
data.put("communityId", result.getCommunityId());
|
data.put("shId", paramIn.getString("shId"));
|
// data.put("shName", "系统仓库");
|
|
// Map<String, String> com = new HashMap<>();
|
// Map<String, String> rst = new HashMap<>();
|
|
try {
|
for (int roomIndex = 0; roomIndex < resourceStoreDtos.size(); roomIndex++) {
|
|
}
|
|
if (tmpImportResourceStoreDtos.size() > 0) {
|
flag = saveResourceStore(pd, tmpImportResourceStoreDtos, data);
|
|
successCount += flag;
|
}
|
} catch (Exception e) {
|
logger.error("导入失败", e);
|
//按批次做撤销功能
|
throw e;
|
}
|
|
return ResultVo.createResponseEntity("总共导入:" + tmpImportResourceStoreDtos.size() + ";成功导入:" + successCount + ";导入失败:" + (tmpImportResourceStoreDtos.size() - successCount));
|
}
|
|
/**
|
* 创建费用
|
*
|
* @param pd
|
* @param tmpImportResourceStoreDtos
|
*/
|
private int saveResourceStore(IPageData pd, List<ImportResourceStoreDto> tmpImportResourceStoreDtos, JSONObject data) {
|
|
JSONArray importRoomFees = JSONArray.parseArray(JSONObject.toJSONString(tmpImportResourceStoreDtos));
|
data.put("importResourceStoreDtos", importRoomFees);
|
|
String apiUrl = "resourceStore.importResourceStore";
|
|
ResponseEntity<String> responseEntity = this.callCenterService(restTemplate, pd, data.toJSONString(), apiUrl, HttpMethod.POST);
|
|
if (responseEntity.getStatusCode() != HttpStatus.OK) {
|
throw new IllegalArgumentException(responseEntity.getBody());
|
}
|
|
JSONObject paramOut = JSONObject.parseObject(responseEntity.getBody());
|
if (ResultVo.CODE_OK != paramOut.getInteger("code")) {
|
throw new IllegalArgumentException(paramOut.getString("msg"));
|
}
|
|
return paramOut.getIntValue("data");
|
|
}
|
|
//解析Excel日期格式
|
public static Date DoubleToDate(Double dVal) {
|
Date tDate = new Date();
|
long localOffset = tDate.getTimezoneOffset() * 60000; //系统时区偏移 1900/1/1 到 1970/1/1 的 25569 天
|
tDate.setTime((long) ((dVal - 25569) * 24 * 3600 * 1000 + localOffset));
|
return tDate;
|
}
|
}
|