BusinessContractReceiveServiceImpl.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. package com.chinaitop.depot.business.service.impl;
  2. import java.math.BigDecimal;
  3. import java.util.ArrayList;
  4. import java.util.Date;
  5. import java.util.HashMap;
  6. import java.util.List;
  7. import java.util.Map;
  8. import javax.annotation.Resource;
  9. import org.apache.commons.lang.StringUtils;
  10. import org.slf4j.Logger;
  11. import org.slf4j.LoggerFactory;
  12. import org.springframework.stereotype.Service;
  13. import org.springframework.transaction.annotation.Transactional;
  14. import com.alibaba.fastjson.JSON;
  15. import com.alibaba.fastjson.JSONArray;
  16. import com.alibaba.fastjson.JSONObject;
  17. import com.chinaitop.depot.business.controller.BusinessContractController;
  18. import com.chinaitop.depot.business.mapper.BusinessContractReceiveMapper;
  19. import com.chinaitop.depot.business.model.BusinessContractReceive;
  20. import com.chinaitop.depot.business.model.BusinessContractReceiveExample;
  21. import com.chinaitop.depot.business.model.BusinessContractReceiveExample.Criteria;
  22. import com.chinaitop.depot.business.service.BusinessContractReceiveService;
  23. import com.chinaitop.depot.business.service.FeignBasicService;
  24. import com.chinaitop.depot.feignService.DepotKeeperAccountFeignService;
  25. import com.chinaitop.depot.utils.ParameterUtil;
  26. @Service
  27. @SuppressWarnings("all")
  28. public class BusinessContractReceiveServiceImpl implements BusinessContractReceiveService {
  29. @Resource
  30. private BusinessContractReceiveMapper businessContractReceiveMapper;
  31. @Resource
  32. private FeignBasicService feignBasicService;
  33. @Resource
  34. private DepotKeeperAccountFeignService feigenKeeperAccountService;
  35. public static final Logger logger = LoggerFactory.getLogger(BusinessContractReceiveServiceImpl.class);
  36. @Override
  37. @Transactional(rollbackFor = Exception.class)
  38. public Map<String, String> receiveContractData(String data) throws Exception {
  39. Map<String, String> resultMap = new HashMap<>();
  40. if (StringUtils.isBlank(data)) {
  41. resultMap.put("status", "500");
  42. resultMap.put("msg", "下发数据不能为空");
  43. return resultMap;
  44. }
  45. JSONObject obj = JSONObject.parseObject(data);
  46. Map<String, Object> check_map = checkDatas(obj);
  47. String msg = check_map.get("msg")+"";
  48. if (msg.length() > 0) {
  49. resultMap.put("status", "500");
  50. resultMap.put("msg", msg);
  51. return resultMap;
  52. } else {
  53. BusinessContractReceive obj_map = (BusinessContractReceive) check_map.get("data");
  54. //先处理客户信息数据
  55. Integer customerId = editCustomer(obj_map.getOrgId(), obj_map.getKhmc());
  56. //把新增或查到的客户ID给当前合同的客户ID赋值
  57. obj_map.setKhid(customerId);
  58. obj_map.setDataType("0");
  59. //保存合同数据
  60. updateOrSave(obj_map);
  61. resultMap.put("status", "200");
  62. resultMap.put("msg", "推送成功");
  63. }
  64. return resultMap;
  65. }
  66. private Map<String, Object> checkDatas(JSONObject obj) {
  67. BusinessContractReceive dataobj = new BusinessContractReceive();
  68. List<BusinessContractReceive> list = new ArrayList<>();
  69. StringBuffer sbf = new StringBuffer(100);
  70. String htbh = obj.getString("htbh");
  71. if (StringUtils.isNotBlank(htbh)) {
  72. dataobj.setHtbh(htbh.trim());
  73. } else {
  74. sbf.append("合同编号不能为空,");
  75. }
  76. String htlx = obj.getString("htlx");
  77. if (StringUtils.isNotBlank(htlx)) {
  78. dataobj.setHtlx(htlx.trim());
  79. } else {
  80. sbf.append("合同类型不能为空,");
  81. }
  82. String htsl = obj.getString("htsl");
  83. if (StringUtils.isNotBlank(htsl)) {
  84. dataobj.setHtzsl(new BigDecimal(htsl));
  85. } else {
  86. sbf.append("合同数量不能为空,");
  87. }
  88. String htdj = obj.getString("dj");
  89. if (StringUtils.isNotBlank(htdj)) {
  90. dataobj.setHtdj(new BigDecimal(htdj));
  91. } else {
  92. sbf.append("合同单价不能为空,");
  93. }
  94. String htzj = obj.getString("zj");
  95. if (StringUtils.isNotBlank(htzj)) {
  96. dataobj.setHtzj(new BigDecimal(htzj));
  97. } else {
  98. sbf.append("合同总价不能为空,");
  99. }
  100. String pz = obj.getString("pz");
  101. if (StringUtils.isNotBlank(pz)) {
  102. Map<String, Object> basicMap = feignBasicService.getIdByNameAndParentId(1061, null, pz);
  103. logger.info("根据"+pz+"获取到的品种数据如下:");
  104. logger.info(basicMap.toString());
  105. String lypz = basicMap.get("enumId")+"";
  106. if (StringUtils.isNotBlank(lypz)) {
  107. dataobj.setLypz(Integer.parseInt(lypz));
  108. } else {
  109. sbf.append("粮食品种的值"+pz+"有误或不合理,");
  110. }
  111. } else {
  112. sbf.append("粮食品种不能为空,");
  113. }
  114. String mxpz = obj.getString("mxpz");
  115. if (StringUtils.isNotBlank(mxpz)) {
  116. if (null != dataobj.getLypz()) {
  117. Integer enumid = getEnumId(dataobj.getLypz(), mxpz);
  118. logger.info("根据"+mxpz+"获取到的明细品种数据是:"+enumid);
  119. if (null != enumid) {
  120. dataobj.setMxpz(enumid);
  121. } else {
  122. sbf.append("粮食明细品种的值"+mxpz+"有误或不合理,");
  123. }
  124. }
  125. } else {
  126. sbf.append("粮食明细品种不能为空,");
  127. }
  128. String lydj = obj.getString("lsdj");
  129. if (StringUtils.isNotBlank(lydj)) {
  130. lydj = lydj.replace(" ", "");
  131. Map<String, Object> basicMap = feignBasicService.getIdByNameAndParentId(1002, null, lydj);
  132. logger.info("获取到的粮食等级数据如下:");
  133. logger.info(basicMap.toString());
  134. String dj = basicMap.get("enumId")+"";
  135. if (StringUtils.isNotBlank(dj)) {
  136. dataobj.setLydj(Integer.parseInt(dj));
  137. } else {
  138. sbf.append("粮食等级的值"+lydj+"有误或不合理,");
  139. }
  140. }
  141. String lyxz = obj.getString("lsxz");
  142. if (StringUtils.isNotBlank(lyxz)) {
  143. Integer enumid = getEnumId(1032, lyxz);
  144. logger.info("根据"+lyxz+"获取到的粮食性质数据如下:"+enumid);
  145. if (null != enumid) {
  146. dataobj.setLyxz(enumid);
  147. } else {
  148. sbf.append("粮食性质的值"+lyxz+"有误,");
  149. }
  150. } else {
  151. sbf.append("粮食等级不能为空,");
  152. }
  153. String scnf = obj.getString("scnf");
  154. if (StringUtils.isNotBlank(scnf)) {
  155. Map<String, Object> basicMap = feignBasicService.getIdByNameAndParentId(1004, null, scnf);
  156. logger.info("获取到的生产年份数据如下:");
  157. logger.info(basicMap.toString());
  158. String scnd = basicMap.get("enumId")+"";
  159. if (StringUtils.isNotBlank(scnd)) {
  160. dataobj.setScnf(Integer.parseInt(scnd));
  161. dataobj.setShnd(dataobj.getScnf());
  162. } else {
  163. sbf.append("生产年份的值"+scnf+"有误,");
  164. }
  165. } else {
  166. sbf.append("生产年份不能为空,");
  167. }
  168. String khmc = obj.getString("khmc");
  169. if (StringUtils.isNotBlank(khmc)) {
  170. dataobj.setKhmc(khmc.replace(" ", "").trim());
  171. } else {
  172. sbf.append("客户名称不能为空,");
  173. }
  174. String hw_sptid = obj.getString("hwbm");//市平台货位数据主键ID
  175. if (StringUtils.isNotBlank(hw_sptid)) {
  176. Map<String, Object> basicMap = feignBasicService.getWareOrTankObj(hw_sptid);
  177. logger.info("根据值"+hw_sptid+"获取到的货位数据如下:");
  178. logger.info(basicMap+"");
  179. if (!"0".equals(basicMap.get("houseId").toString()) && !"0".equals(basicMap.get("warehouseId").toString()) && !"0".equals(basicMap.get("orgId").toString())) {
  180. dataobj.setHouseId(Integer.parseInt(basicMap.get("houseId").toString()));
  181. dataobj.setWarehouseId(Integer.parseInt(basicMap.get("warehouseId").toString()));
  182. dataobj.setOrgId(Integer.parseInt(basicMap.get("orgId").toString()));
  183. dataobj.setInputTime(new Date());
  184. dataobj.setUpdateTime(dataobj.getInputTime());
  185. } else {
  186. sbf.append("未查询到hwbm的值对应的货位数据,");
  187. }
  188. } else {
  189. sbf.append("hwbm的值不能为空,");
  190. }
  191. String id = obj.getString("htbm");//市平台合同主键ID
  192. if (StringUtils.isNotBlank(hw_sptid)) {
  193. dataobj.setSptHtid(id);
  194. }
  195. Map<String, Object> resultMap = new HashMap<>();
  196. resultMap.put("msg", sbf.toString());
  197. resultMap.put("data", dataobj);
  198. return resultMap;
  199. }
  200. /**
  201. * 根据字典父级ID和国标编码获取下面的一个字典ID
  202. * @param parentId
  203. * @param gbCode
  204. * @return
  205. */
  206. private Integer getEnumId(int parentId, String gbCode) {
  207. Integer enumId = null;
  208. Map<String, Object> map = feignBasicService.findConditionEnum(parentId, null, null);
  209. if (null != map) {
  210. String json_str = JSON.toJSONString(map);
  211. JSONObject json_obj = JSONObject.parseObject(json_str);
  212. JSONArray array = JSONArray.parseArray(json_obj.getString("enumList"));
  213. for (int i = 0; i < array.size(); i++) {
  214. JSONObject object = JSONObject.parseObject(array.get(i).toString());
  215. String code = object.getString("gbcode");
  216. if (code.equals(gbCode)) {
  217. enumId = Integer.parseInt(object.getString("id"));
  218. break;
  219. }
  220. }
  221. }
  222. return enumId;
  223. }
  224. @Override
  225. public List<BusinessContractReceive> queryByExample(String htbh, Integer orgId, Integer houseId, Integer warehouseId, String htlx)
  226. throws Exception {
  227. List<BusinessContractReceive> list = null;
  228. BusinessContractReceiveExample example = new BusinessContractReceiveExample();
  229. Criteria criteria = example.createCriteria();
  230. if (StringUtils.isNotBlank(htbh)) {
  231. criteria.andHtbhLike("%"+htbh+"%");
  232. }
  233. if (null != orgId) {
  234. criteria.andOrgIdEqualTo(orgId);
  235. }
  236. if (null != houseId) {
  237. criteria.andHouseIdEqualTo(houseId);
  238. }
  239. if (null != warehouseId) {
  240. criteria.andWarehouseIdEqualTo(warehouseId);
  241. }
  242. if (StringUtils.isNotBlank(htlx)) {
  243. criteria.andHtlxEqualTo(htlx);
  244. }
  245. example.setOrderByClause("input_time desc");
  246. list = businessContractReceiveMapper.selectByExample(example);
  247. return list;
  248. }
  249. @Override
  250. public BusinessContractReceive findbyParmaryKey(Integer id) throws Exception {
  251. BusinessContractReceive businessContractReceive = businessContractReceiveMapper.selectByPrimaryKey(id);
  252. return businessContractReceive;
  253. }
  254. private Integer editCustomer(Integer orgId, String customerName) throws Exception {
  255. //查询这个客户在这个库是否存在
  256. Integer customerId = feigenKeeperAccountService.queryCustomerObj(orgId, 3153, customerName);
  257. //如果不存在就新增一条不完整的客户
  258. if (null == customerId) {//说明这个客户没再库级维护
  259. //形成客户编码
  260. StringBuffer sbf = new StringBuffer();
  261. //把单位ID格式化成3位,不足三位的补0
  262. String sxm = String.format("%03d", orgId);
  263. sbf.append("KH-").append(sxm).append("-").append(ParameterUtil.getDateYMDHMS(new Date()));
  264. JSONObject json = new JSONObject();
  265. json.put("name", customerName);
  266. json.put("classify", 3153);
  267. json.put("sfwz", "1");//客户数据是否完整(0:完整,1:不完整)
  268. json.put("customerNumber", sbf.toString());
  269. Map<String, Object> modelMap = feigenKeeperAccountService.save(json.toString(), orgId);
  270. if ("error".equals(modelMap.get("status"))) {
  271. throw new Exception("不完整客户保存异常");
  272. } else {
  273. customerId = Integer.parseInt(modelMap.get("id").toString());
  274. }
  275. }
  276. return customerId;
  277. }
  278. @Override
  279. public void updateOrSave(BusinessContractReceive businessContractReceive) throws Exception {
  280. //构建条件
  281. BusinessContractReceiveExample example = new BusinessContractReceiveExample();
  282. BusinessContractReceiveExample.Criteria criteria = example.createCriteria();
  283. criteria.andSptHtidEqualTo(businessContractReceive.getSptHtid());
  284. //查询符合条件的数据
  285. List<BusinessContractReceive> list = businessContractReceiveMapper.selectByExample(example);
  286. //没有符合的就新增,有的话就修改
  287. if (null == list || list.size() == 0) {
  288. businessContractReceiveMapper.insert(businessContractReceive);
  289. } else {
  290. businessContractReceive.setId(list.get(0).getId());
  291. businessContractReceive.setUpdateTime(new Date());
  292. businessContractReceiveMapper.updateByExample(businessContractReceive, example);
  293. }
  294. }
  295. }