AmsSaleOrderServiceImpl.java 134 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724
  1. package com.steerinfo.dil.service.impl;
  2. import com.alibaba.druid.support.json.JSONUtils;
  3. import com.alibaba.fastjson.JSON;
  4. import com.alibaba.fastjson.JSONObject;
  5. import com.steerinfo.dil.feign.JoinFeign;
  6. import com.steerinfo.dil.feign.OtmsFeign;
  7. import com.steerinfo.dil.feign.RmsFeign;
  8. import com.steerinfo.dil.feign.TmsTruckFeign;
  9. import com.steerinfo.dil.mapper.*;
  10. import com.steerinfo.dil.model.*;
  11. import com.steerinfo.dil.service.IAmsSaleOrderService;
  12. import com.steerinfo.dil.util.*;
  13. import org.springframework.beans.factory.annotation.Autowired;
  14. import org.springframework.stereotype.Service;
  15. import org.springframework.transaction.annotation.Transactional;
  16. import javax.annotation.Resource;
  17. import java.math.BigDecimal;
  18. import java.text.ParseException;
  19. import java.text.SimpleDateFormat;
  20. import java.util.*;
  21. /**
  22. * AmsSaleOrder服务实现:
  23. *
  24. * @author generator
  25. * @version 1.0-SNAPSHORT 2021-09-06 07:10
  26. * 类描述
  27. * 修订历史:
  28. * 日期:2021-09-06
  29. * 作者:generator
  30. * 参考:
  31. * 描述:AmsSaleOrder服务实现
  32. * @Copyright 湖南视拓信息技术股份有限公司. All rights reserved.
  33. * @see null
  34. */
  35. @Service(value = "amsSaleOrderService")
  36. public class AmsSaleOrderServiceImpl implements IAmsSaleOrderService {
  37. @Autowired
  38. private AmsSaleOrderMapper amsSaleOrderMapper;
  39. @Autowired
  40. private AmsSaleOrderMaterialMapper amsSaleOrderMaterialMapper;
  41. @Autowired
  42. private AmsSaleTrucknoMaterialMapper trucknoMaterialMapper;
  43. @Autowired
  44. TmstruckLoadResult tmstruckLoadResult;
  45. @Autowired
  46. TmstruckWeightResult tmstruckWeightResult;
  47. @Autowired
  48. TmstruckWeightResultMapper tmstruckWeightResultMapper;
  49. @Autowired
  50. TmstruckLoadResultMapper tmstruckLoadResultMapper;
  51. @Autowired
  52. AmsDispatchSaleOrderMapper amsDispatchSaleOrderMapper;
  53. @Autowired
  54. AmsSaleMaterialMapper amsSaleMaterialMapper;
  55. @Autowired
  56. AmsSaleTrucknoMaterialMapper amsSaleTrucknoMaterialMapper;
  57. @Autowired
  58. RmsReceivePlaceMapper rmsReceivePlaceMapper;
  59. @Autowired
  60. JoinFeign joinFeign;
  61. @Autowired
  62. OmstruckOrderMapper omstruckOrderMapper;
  63. @Autowired
  64. OmstruckOrderMaterialMapper omstruckOrderMaterialMapper;
  65. @Autowired
  66. AmsSaleOrderMaterialServiceImpl amsSaleOrderMaterialService;
  67. @Autowired
  68. TmsTruckFeign tmsTruckFeign;
  69. @Autowired
  70. EASUtil easUtil;
  71. @Autowired
  72. EASDeleteUtil easDeleteUtil;
  73. @Autowired
  74. EASSaleOrderUtil easSaleOrderUtil;
  75. @Autowired
  76. EASTestUtil easTestUtil;
  77. @Autowired
  78. EASDeleteTestUtil easDeleteTestUtil;
  79. @Autowired
  80. EASDeleteApproveUtil easDeleteApproveUtil;
  81. @Autowired
  82. RmsMaterialMapper rmsMaterialMapper;
  83. @Autowired
  84. TmstrainPleaseApproveResultMapper tmstrainPleaseApproveResultMapper;
  85. @Autowired
  86. WmspOutboundResultMaterialMapper wmspOutboundResultMaterialMapper;
  87. @Resource
  88. EasSaleOrderStatusUtil easSaleOrderStatusUtil;
  89. @Autowired
  90. OtmsFeign otmsFeign;
  91. @Autowired
  92. RmsFeign rmsFeign;
  93. @Autowired
  94. EasFluMakeDateUtil easFluMakeDateUtil;
  95. @Override
  96. public List<Map<String, Object>> getSaleOrderInfo(Map<String, Object> map) {
  97. return amsSaleOrderMapper.getSaleOrderInfo(map);
  98. }
  99. @Override
  100. public List<Map<String, Object>> getSaleOrderReported(Map<String, Object> map) {
  101. return amsSaleOrderMapper.getSaleOrderReported(map);
  102. }
  103. @Override
  104. public List<Map<String, Object>> getSaleOrderDetail(Map<String, Object> map) {
  105. return amsSaleOrderMapper.getSaleOrderDetail(map);
  106. }
  107. @Override
  108. public List<Map<String, Object>> getSalePlanName() {
  109. return amsSaleOrderMapper.getSalePlanName();
  110. }
  111. @Override
  112. public List<Map<String, Object>> getShipperName() {
  113. return amsSaleOrderMapper.getShipperName();
  114. }
  115. @Override
  116. public List<Map<String, Object>> getConsigneeCompanyName() {
  117. return amsSaleOrderMapper.getConsigneeCompanyName();
  118. }
  119. @Override
  120. /**
  121. * map存放为前端获取的amsSaleOrder基础数据以及selectionList物资信息
  122. * map1为基础数据包括,收货地址,收货人等
  123. * map2存放的从selectionList取出的数据,包括物资id,物资名称等。
  124. */
  125. public int addAmsSaleOrder(Map<String, Object> map) throws ParseException {
  126. //获取前端传过来的map,
  127. int i = 0;
  128. Map<String, Object> map1 = (Map<String, Object>) map.get("amsSaleOrder");
  129. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  130. Integer id = (amsSaleOrderMapper.selectMaxId()).intValue();
  131. //生成主键id
  132. amsSaleOrder.setSaleOrderId(new BigDecimal(id));
  133. //WXSDD-年月日-8位数的顺序号
  134. String wxsdd = DataChange.generateEightDigitsNumber("WXSDD", id);
  135. amsSaleOrder.setSaleNumber(wxsdd);
  136. //获得是否自提
  137. amsSaleOrder.setSaleOrderIsselfMention((String) map1.get("saleOrderIsselfMention"));
  138. //获取收货地址id
  139. amsSaleOrder.setReceiveId(DataChange.dataToBigDecimal(map1.get("receiveId")));
  140. //获取发货单位id
  141. amsSaleOrder.setShipperId(DataChange.dataToBigDecimal(map1.get("shipperId")));
  142. //获取备注
  143. amsSaleOrder.setSaleRemark((String) map1.get("saleRemark"));
  144. //设置销售订单状态
  145. amsSaleOrder.setSaleOrderStatus(new BigDecimal(0));
  146. amsSaleOrder.setSaleUnitPrice(new BigDecimal(4000));
  147. amsSaleOrder.setSaleOrderTax("13%");
  148. amsSaleOrder.setInsertUsername("admin");
  149. amsSaleOrder.setInsertTime(new Date());
  150. amsSaleOrder.setUpdateUsername("admin");
  151. amsSaleOrder.setUpdateTime(new Date());
  152. amsSaleOrder.setInsertUpdateRemark("无");
  153. amsSaleOrder.setDeleted(new BigDecimal(0));
  154. amsSaleOrder.setSaleOrderStatus(new BigDecimal(0));
  155. //设置收款客户
  156. amsSaleOrder.setSaleOrderReceiveCustomer((String) map1.get("saleOrderReceiveCustomer"));
  157. i += amsSaleOrderMapper.insertSelective(amsSaleOrder);
  158. //获取车序号和物资信息进行新增车序号与物资中间表
  159. //一个销售订单对应多个车序号
  160. List<Map<String, Object>> selectionList = (List<Map<String, Object>>) map.get("selectionList");
  161. for (Map<String, Object> map2 : selectionList) {
  162. BigDecimal materialId = DataChange.dataToBigDecimal(map2.get("materialId"));
  163. Integer cxh = (Integer) map2.get("cxh");
  164. //生成车序号与物资实体
  165. AmsSaleOrderMaterial amsSaleOrderMaterial = new AmsSaleOrderMaterial();
  166. //生成主键
  167. amsSaleOrderMaterial.setSaleOrderMaterialId(amsSaleOrderMaterialMapper.selectMaxId());
  168. amsSaleOrderMaterial.setSaleOrderId(amsSaleOrder.getSaleOrderId());
  169. // 生成定向派单
  170. AmsDispatchSaleOrder amsDispatchSaleOrder = new AmsDispatchSaleOrder();
  171. amsDispatchSaleOrder.setDispatchId(amsDispatchSaleOrderMapper.selectOtherId());
  172. amsDispatchSaleOrder.setSaleOrderMaterialId(amsSaleOrderMaterial.getSaleOrderMaterialId());
  173. //获取收货地址
  174. Integer saleShipperAddressId =(Integer) map2.get("saleShipperAddressId");
  175. amsSaleOrderMaterial.setSaleShippingAddressId(new BigDecimal(saleShipperAddressId));
  176. //根据收货地址查询承运商
  177. Map<String,Object> map4 = amsSaleOrderMapper.selectProvince(saleShipperAddressId);
  178. BigDecimal carrierId = amsSaleOrderMapper.selectCarrierIdByprovince(map4);
  179. //获取收货方电话号码
  180. amsDispatchSaleOrder.setCarrierId(carrierId);
  181. amsDispatchSaleOrder.setDispatchTime(new Date());
  182. //设置成交类型
  183. amsDispatchSaleOrder.setDispatchType(new BigDecimal(0));
  184. //设置下发状态为未下发
  185. amsDispatchSaleOrder.setDispatchStatus(new BigDecimal(1));
  186. amsDispatchSaleOrder.setInsertTime(new Date());
  187. amsDispatchSaleOrder.setInsertUsername("admin");
  188. amsDispatchSaleOrderMapper.insertSelective(amsDispatchSaleOrder);
  189. amsSaleOrderMaterial.setSaleOrderConsigneeTel(map2.get("saleOrderConsigneeTel").toString());
  190. //获取收货日期
  191. String saleDateOfReceipt =(String) map2.get("saleDateOfReceipt");
  192. SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy-MM-dd");
  193. Date date = simpleDateFormat.parse(saleDateOfReceipt);
  194. amsSaleOrderMaterial.setSaleDateOfReceipt(date);
  195. //获取收货方姓名
  196. amsSaleOrderMaterial.setSaleOrderConsignee((String) map2.get("saleOrderConsignee"));
  197. //设置车序号
  198. amsSaleOrderMaterial.setSaleOrderMaterialTruckNo(new BigDecimal(cxh));
  199. //设置删除状态
  200. amsSaleOrderMaterial.setDeleted(new BigDecimal(0));
  201. i += amsSaleOrderMaterialMapper.insertSelective(amsSaleOrderMaterial);
  202. //新增车序号与物资中间表
  203. AmsSaleTrucknoMaterial trucknoMaterial = new AmsSaleTrucknoMaterial();
  204. trucknoMaterial.setTrucknoMaterialId(trucknoMaterialMapper.selectMaxId());
  205. //设置物资id
  206. trucknoMaterial.setMaterialId(materialId);
  207. //获取车序号物资id
  208. trucknoMaterial.setSaleOrderMaterialId(amsSaleOrderMaterial.getSaleOrderMaterialId());
  209. Integer orderPlanWeight = (Integer) map2.get("orderPlanWeight");
  210. trucknoMaterial.setSaleOrderMaterialNumber(DataChange.dataToBigDecimal(orderPlanWeight));
  211. //获取物资理重
  212. BigDecimal materialTheoreticalWeight = DataChange.dataToBigDecimal(map2.get("materialTheoreticalWeight"));
  213. //判断是否有物资理重
  214. if (materialTheoreticalWeight.intValue() != 0) {
  215. trucknoMaterial.setMaterialTheoreticalWeight(materialTheoreticalWeight);
  216. }
  217. //新增车序号与物资中间表
  218. i += trucknoMaterialMapper.insertSelective(trucknoMaterial);
  219. }
  220. return i;
  221. }
  222. @Transactional(rollbackFor = Exception.class)
  223. @Override
  224. public int uploadSaleOrder(BigDecimal saleOrderId) throws Exception {
  225. AmsSaleOrder amsSaleOrder = amsSaleOrderMapper.selectByPrimaryKey(saleOrderId);
  226. // 调用金蝶接口,将销售订单推送到金蝶系统
  227. Map<String, Object> input = joinFeign.getSaleOrder(saleOrderId);
  228. Map<String, Object> head = (Map<String, Object>) input.get("head");
  229. head.put("status","");
  230. // 获得金蝶接口配置:正式
  231. Map<String, Object> totalMap = easUtil.getTotalMap();
  232. // 获得金蝶接口配置:测试
  233. //Map<String, Object> totalMap = easSaleOrderUtil.getTotalMap();
  234. // 组装报文
  235. totalMap.put("input",input);
  236. System.out.println(totalMap);
  237. String json = JSONUtils.toJSONString(totalMap);
  238. System.out.println(json);
  239. // 得到金蝶返回结果
  240. Map<String,Object> s = joinFeign.pushSaleOrderToEas(totalMap);
  241. String status = (String) s.get("status");
  242. if ("-1".equals(status)) {
  243. throw new Exception(amsSaleOrder.getSaleNumber() + "上传金蝶失败!");
  244. }
  245. System.out.println(s);
  246. amsSaleOrder.setSaleOrderStatus(new BigDecimal(1));
  247. return amsSaleOrderMapper.updateByPrimaryKey(amsSaleOrder);
  248. }
  249. @Override
  250. public List<Map<String, Object>> selectBySaleOrderId(BigDecimal saleOrderId) {
  251. return amsSaleOrderMapper.selectBySaleOrderId(saleOrderId);
  252. }
  253. /**
  254. * 修改订单信息、车序号表、车序号物资中间表
  255. *
  256. * @param map
  257. * @return
  258. */
  259. @Override
  260. @Transactional
  261. public int updateAmsSaleOrder(Map<String, Object> map) throws ParseException {
  262. int i = 0;
  263. int j = 0;
  264. Map<String, Object> map1 = (Map<String, Object>) map.get("amsSaleOrder");
  265. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  266. //修改销售订单表 更新销售订单基础信息
  267. amsSaleOrder.setSaleOrderId(DataChange.dataToBigDecimal(map1.get("saleOrderId")));
  268. amsSaleOrder.setShipperId(DataChange.dataToBigDecimal(map1.get("shipperId")));
  269. amsSaleOrder.setReceiveId(DataChange.dataToBigDecimal(map1.get("reciveId")));
  270. amsSaleOrder.setSaleOrderIsselfMention((String) map1.get("saleOrderIsselfMention"));
  271. amsSaleOrder.setSaleOrderReceiveCustomer((String) map1.get("saleOrderReciveCustomer"));
  272. amsSaleOrder.setSaleRemark((String) map1.get("saleRemark"));
  273. amsSaleOrder.setUpdateTime(new Date());
  274. i += amsSaleOrderMapper.updateByPrimaryKeySelective(amsSaleOrder);
  275. //根据销售订单id查找销售车序号和车序号与物资中间表主键
  276. List<Map<String, Object>> map2 = amsSaleOrderMapper.selectSaleOrderMaterialIdBySaleOrderId(DataChange.dataToBigDecimal(map1.get("saleOrderId")));
  277. for (Map<String,Object> Id:map2){
  278. BigDecimal truckNoMaterialId =(BigDecimal) Id.get("TruckNoMaterialId");
  279. BigDecimal saleOrderMaterialId=(BigDecimal) Id.get("saleOrderMaterialId");
  280. //删除对应的车序号表与车序号与物资中间表
  281. j+=amsSaleOrderMaterialMapper.deleteByPrimaryKey(saleOrderMaterialId);
  282. j+=trucknoMaterialMapper.deleteByPrimaryKey(truckNoMaterialId);
  283. }
  284. //新增车序号和物资中间表
  285. //获取车序号和物资信息进行新增车序号与物资中间表
  286. //一个销售订单对应多个车序号
  287. List<Map<String, Object>> selectionList = (List<Map<String, Object>>) map.get("selectionList");
  288. for (Map<String, Object> map3 : selectionList) {
  289. BigDecimal materialId = DataChange.dataToBigDecimal(map3.get("materialId"));
  290. Integer cxh = (Integer) map3.get("cxh");
  291. //生成车序号与物资实体
  292. AmsSaleOrderMaterial amsSaleOrderMaterial = new AmsSaleOrderMaterial();
  293. //生成主键
  294. amsSaleOrderMaterial.setSaleOrderMaterialId(amsSaleOrderMaterialMapper.selectMaxId());
  295. amsSaleOrderMaterial.setSaleOrderId(DataChange.dataToBigDecimal(map1.get("saleOrderId")));
  296. //获取收货地址
  297. amsSaleOrderMaterial.setSaleShippingAddressId(DataChange.dataToBigDecimal(map3.get("saleShipperAddressId")));
  298. //获取收货方电话号码
  299. amsSaleOrderMaterial.setSaleOrderConsigneeTel(map3.get("saleOrderConsigneeTel").toString());
  300. //获取收货日期
  301. String saleDateOfReceipt =(String) map3.get("saleDateOfReceipt");
  302. SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy-MM-dd");
  303. Date date = simpleDateFormat.parse(saleDateOfReceipt);
  304. amsSaleOrderMaterial.setSaleDateOfReceipt(date);
  305. //获取收货方姓名
  306. amsSaleOrderMaterial.setSaleOrderConsignee((String) map3.get("saleOrderConsignee"));
  307. //设置车序号
  308. amsSaleOrderMaterial.setSaleOrderMaterialTruckNo(new BigDecimal(cxh));
  309. //设置删除状态
  310. amsSaleOrderMaterial.setDeleted(new BigDecimal(0));
  311. i += amsSaleOrderMaterialMapper.insertSelective(amsSaleOrderMaterial);
  312. // 生成定向派单
  313. AmsDispatchSaleOrder amsDispatchSaleOrder = new AmsDispatchSaleOrder();
  314. amsDispatchSaleOrder.setDispatchId(amsDispatchSaleOrderMapper.selectOtherId());
  315. amsDispatchSaleOrder.setSaleOrderMaterialId(amsSaleOrderMaterial.getSaleOrderMaterialId());
  316. //获取收货地址
  317. Integer saleShipperAddressId =(Integer) map3.get("saleShipperAddressId");
  318. amsSaleOrderMaterial.setSaleShippingAddressId(new BigDecimal(saleShipperAddressId));
  319. //根据收货地址查询承运商
  320. Map<String,Object> map4 = amsSaleOrderMapper.selectProvince(saleShipperAddressId);
  321. BigDecimal carrierId = amsSaleOrderMapper.selectCarrierIdByprovince(map4);
  322. //获取收货方电话号码
  323. amsDispatchSaleOrder.setCarrierId(carrierId);
  324. amsDispatchSaleOrder.setDispatchTime(new Date());
  325. //设置成交类型
  326. amsDispatchSaleOrder.setDispatchType(new BigDecimal(0));
  327. //设置下发状态为已下发
  328. amsDispatchSaleOrder.setDispatchStatus(new BigDecimal(0));
  329. amsDispatchSaleOrder.setInsertTime(new Date());
  330. amsDispatchSaleOrder.setInsertUsername("admin");
  331. //新增车序号与物资中间表
  332. AmsSaleTrucknoMaterial trucknoMaterial = new AmsSaleTrucknoMaterial();
  333. trucknoMaterial.setTrucknoMaterialId(trucknoMaterialMapper.selectMaxId());
  334. //设置物资id
  335. trucknoMaterial.setMaterialId(materialId);
  336. //获取车序号物资id
  337. trucknoMaterial.setSaleOrderMaterialId(amsSaleOrderMaterial.getSaleOrderMaterialId());
  338. Integer orderPlanWeight = (Integer) map3.get("orderPlanWeight");
  339. trucknoMaterial.setSaleOrderMaterialNumber(DataChange.dataToBigDecimal(orderPlanWeight));
  340. //获取物资理重
  341. BigDecimal materialTheoreticalWeight = DataChange.dataToBigDecimal(map3.get("materialTheoreticalWeight"));
  342. //判断是否有物资理重
  343. if (materialTheoreticalWeight.intValue() != 0) {
  344. trucknoMaterial.setMaterialTheoreticalWeight(materialTheoreticalWeight);
  345. }
  346. //新增车序号与物资中间表
  347. i += trucknoMaterialMapper.insertSelective(trucknoMaterial);
  348. }
  349. // List<Map<String, Object>> mapList = (List<Map<String, Object>>) map.get("mapList");
  350. // ArrayList<Integer> list = new ArrayList<>();
  351. // for (Map<String, Object> truckMesMap : mapList) {
  352. // //修改车序号表
  353. // BigDecimal saleOrderMaterialId = DataChange.dataToBigDecimal(truckMesMap.get("saleOrderMaterialId"));
  354. // if (!list.contains(saleOrderMaterialId.intValue())) {
  355. // //车序号表专用字段
  356. // BigDecimal saleShipperAddressId = DataChange.dataToBigDecimal(truckMesMap.get("saleShipperAddressId"));
  357. // String saleDateOfReceipt =(String) truckMesMap.get("saleDateOfReceipt");
  358. // SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy-MM-dd");
  359. // Date date = simpleDateFormat.parse(saleDateOfReceipt);
  360. // String saleOrderConsignee = (String) truckMesMap.get("saleOrderConsignee");
  361. // String saleOrderConsigneeTel = (String) truckMesMap.get("saleOrderConsigneeTel");
  362. // AmsSaleOrderMaterial amsSaleOrderMaterial = new AmsSaleOrderMaterial();
  363. // amsSaleOrderMaterial.setSaleOrderMaterialId(saleOrderMaterialId);
  364. // amsSaleOrderMaterial.setSaleOrderMaterialTruckNo(DataChange.dataToBigDecimal(truckMesMap.get("cxh")));
  365. // amsSaleOrderMaterial.setSaleShippingAddressId(saleShipperAddressId);
  366. // amsSaleOrderMaterial.setSaleDateOfReceipt(date);
  367. // amsSaleOrderMaterial.setSaleOrderConsignee(saleOrderConsignee);
  368. // amsSaleOrderMaterial.setSaleOrderConsigneeTel(saleOrderConsigneeTel);
  369. // i += amsSaleOrderMaterialMapper.updateByPrimaryKeySelective(amsSaleOrderMaterial);
  370. // list.add(saleOrderMaterialId.intValue());
  371. // }
  372. // //修改车车序号物资表
  373. // AmsSaleTrucknoMaterial amsSaleTrucknoMaterial = new AmsSaleTrucknoMaterial();
  374. // amsSaleTrucknoMaterial.setTrucknoMaterialId(DataChange.dataToBigDecimal(truckMesMap.get("trucknoMaterialId")));
  375. // amsSaleTrucknoMaterial.setSaleOrderMaterialNumber(DataChange.dataToBigDecimal(truckMesMap.get("orderPlanWeight")));
  376. // amsSaleTrucknoMaterial.setMaterialId(DataChange.dataToBigDecimal(truckMesMap.get("materialId")));
  377. // i += trucknoMaterialMapper.updateByPrimaryKeySelective(amsSaleTrucknoMaterial);
  378. // }
  379. return i;
  380. }
  381. @Override
  382. public int deleteAmsSaleOrderBySaleOrderId(BigDecimal saleOrderId) {
  383. //删除所有从表信息
  384. //amsSaleOrderMapper.deleteBySaleOrderId(saleOrderId);
  385. AmsSaleOrder amsSaleOrder = amsSaleOrderMapper.selectByPrimaryKey(saleOrderId);
  386. amsSaleOrder.setDeleted(new BigDecimal(2));
  387. return amsSaleOrderMapper.updateByPrimaryKey(amsSaleOrder);
  388. }
  389. @Override
  390. public List<Map<String, Object>> getSaleOrderUpdateLog(Map<String, Object> map) {
  391. return amsSaleOrderMapper.getSaleOrderUpdateLog(map);
  392. }
  393. /**
  394. * 销售公司查询已审核的订单
  395. * @param map
  396. * @return
  397. */
  398. @Override
  399. public List<Map<String, Object>> getSaleOrderListBySaleCompany(Map<String, Object> map) {
  400. return amsSaleOrderMapper.getSaleOrderListBySaleCompany(map);
  401. }
  402. @Override
  403. public List<Map<String, Object>> getAmsSaleOrderApproved(Map<String, Object> map) {
  404. return amsSaleOrderMapper.getAmsSaleOrderApproved(map);
  405. }
  406. @Override
  407. public List<Map<String, Object>> getSaleOrderList(Map<String, Object> mapValue) {
  408. return amsSaleOrderMapper.getSaleOrderList(mapValue);
  409. }
  410. public Map<String, Object> getCarrier(Integer addressId) {
  411. return amsSaleOrderMapper.selectProvince(addressId);
  412. }
  413. /**
  414. * 根据销售订单id查找信息
  415. */
  416. @Override
  417. public Map<String, Object> selectInfoBySaleOrderId(BigDecimal saleOrderId) {
  418. return amsSaleOrderMapper.selectInfoBySaleOrderId(saleOrderId);
  419. }
  420. /**
  421. * 根据销售订单id查找物资信息
  422. *
  423. * @param saleOrderId
  424. * @return
  425. */
  426. @Override
  427. public List<Map<String, Object>> selectMaterialInfoBySaleOrderId(BigDecimal saleOrderId) {
  428. return amsSaleOrderMapper.selectMaterialInfoBySaleOrderId(saleOrderId);
  429. }
  430. @Override
  431. public int addAmsDispatchSaleOrder(List<Map<String, Object>> mapValue) {
  432. int result = 0;
  433. for (Map<String,Object> map : mapValue) {
  434. Integer dispatchId = (Integer)map.get("dispatchId");
  435. AmsDispatchSaleOrder amsDispatchSaleOrder = amsDispatchSaleOrderMapper.selectByPrimaryKey(new BigDecimal(dispatchId));
  436. amsDispatchSaleOrder.setDispatchStatus(new BigDecimal(0));
  437. result = amsDispatchSaleOrderMapper.updateByPrimaryKeySelective(amsDispatchSaleOrder);
  438. }
  439. return result;
  440. }
  441. @Override
  442. public List<Map<String, Object>> getSaleOrderInfoes(Map<String, Object> map) {
  443. return amsSaleOrderMapper.getSaleOrderInfoes(map);
  444. }
  445. @Override
  446. public List<Map<String, Object>> getSaleOrderReportedes(Map<String, Object> map) {
  447. return amsSaleOrderMapper.getSaleOrderReportedes(map);
  448. }
  449. @Override
  450. public List<Map<String, Object>> getSaleOrderListBySaleCompanyes(Map<String, Object> map) {
  451. List<Map<String, Object>> resultList = amsSaleOrderMapper.getSaleOrderListBySaleCompanyes(map);
  452. return resultList;
  453. }
  454. @Override
  455. public List<Map<String, Object>> getAmsSaleOrderApprovedes(Map<String, Object> map) {
  456. List<Map<String,Object>> resultList = amsSaleOrderMapper.getAmsSaleOrderApprovedes(map);
  457. return resultList;
  458. }
  459. /*
  460. * 根据销售订单主键展示销售基本信息、物资信息
  461. * */
  462. @Override
  463. public List<Map<String, Object>> getSaleOrderAndMaterialById(Map<String,Object> mapValue) {
  464. List<Map<String, Object>> mapList=amsSaleOrderMapper.getSaleOrderAndMaterialById(mapValue);
  465. for (Map<String, Object> map : mapList) {
  466. BigDecimal number;
  467. BigDecimal materialNumber = (BigDecimal) map.get("materialNumber");
  468. BigDecimal materialWeight = (BigDecimal) map.get("materialWeight");
  469. String materialName =(String) map.get("materialName");
  470. if (materialNumber != null && materialNumber.toString().length() != 0 && !materialName.equals("钒渣")) {
  471. number = materialNumber;
  472. }
  473. else {
  474. number = materialWeight;
  475. }
  476. map.put("number",number);
  477. }
  478. return mapList;
  479. }
  480. /**
  481. * 销售焦炭订单
  482. * @param mapValue
  483. * @return
  484. */
  485. @Override
  486. public List<Map<String, Object>> getCokeSaleOrderList(Map<String, Object> mapValue) {
  487. List<Map<String,Object>> mapList = amsSaleOrderMapper.getCokeSaleOrderList(mapValue);
  488. for (Map<String, Object> resultMap : mapList) {
  489. BigDecimal saleOrderId = (BigDecimal) resultMap.get("saleOrderId");
  490. BigDecimal netWeight = amsSaleOrderMapper.getNetWeight(saleOrderId);
  491. BigDecimal carNum = amsSaleOrderMapper.getCarNum(saleOrderId);
  492. resultMap.put("netWeight",netWeight);
  493. resultMap.put("carNum",carNum);
  494. }
  495. return mapList;
  496. }
  497. /**
  498. * 新增钢材销售订单
  499. * @param mapValue
  500. * @return
  501. */
  502. @Override
  503. @Transactional(rollbackFor = Exception.class)
  504. public int addSteelSaleOrder(Map<String, Object> mapValue) throws Exception {
  505. List<Map<String,Object>> mapList = (List<Map<String, Object>>) mapValue.get("mapList");
  506. //如果前端传输过来的销售订单id不是空,则改变为已上传
  507. if (mapValue.get("saleOrderId") != null) {
  508. //先判断该销售订单有没有被上传,如果传了则不允许重复上传
  509. int count = amsSaleOrderMaterialMapper.selectSaleOrderIdIsUpload(DataChange.dataToBigDecimal(mapValue.get("saleOrderId")));
  510. if(count != 0) {
  511. return 0;
  512. }
  513. amsSaleOrderMapper.updateOldSaleOrderUpload(DataChange.dataToBigDecimal(mapValue.get("saleOrderId")));
  514. }
  515. // 得到发货单位
  516. BigDecimal shipperId = DataChange.dataToBigDecimal(mapValue.get("shipperId"));
  517. // 收货单位
  518. BigDecimal receiveId = DataChange.dataToBigDecimal(mapValue.get("receiveId"));
  519. if (receiveId == null || receiveId.intValue() == 0) {
  520. receiveId = amsSaleOrderMapper.findReceiveId(mapValue.get("receiveName"));
  521. if (receiveId == null) {
  522. throw new RuntimeException("您输入的下单客户:" + mapValue.get("receiveName") + "不存在!!");
  523. }else {
  524. //判断该收货客户有没有绑定片区
  525. BigDecimal saleAreaId = amsSaleOrderMapper.selectSaleAreaId(receiveId);
  526. if(saleAreaId == null){
  527. //如果片区为null,则绑定片区
  528. //根据片区名称去查找片区ID
  529. if(mapValue.get("saleArea") != null){
  530. String saleAreaName = (String) mapValue.get("saleArea");
  531. saleAreaId = amsSaleOrderMapper.selectSaleAreaIdByName(saleAreaName);
  532. if(saleAreaId == null){
  533. throw new Exception("您输入的销售片区:" + mapValue.get("saleArea") +"不存在!!");
  534. }else{
  535. //更新收货客户下的销售片区
  536. amsSaleOrderMapper.bindSaleArea(receiveId,saleAreaId);
  537. }
  538. }
  539. }
  540. }
  541. }
  542. // 是否自提
  543. String isSelfMention = (String) mapValue.get("isSelfMention");
  544. // 备注
  545. String saleRemark = (String) mapValue.get("saleRemark");
  546. // 收款客户
  547. String saleOrderReceiveCustomer = (String) mapValue.get("saleOrderReceiveCustomer");
  548. // 业务员
  549. BigDecimal salerId = DataChange.dataToBigDecimal(mapValue.get("salerId"));
  550. if (salerId == null || salerId.intValue() == 0) {
  551. if(mapValue.get("salerName") == null) {
  552. throw new Exception("您输入的业务员为空,请检查后再导入!!");
  553. }
  554. salerId = amsSaleOrderMapper.findSalerId(mapValue.get("salerName"));
  555. if (salerId == null) {
  556. throw new Exception("您输入的业务员:" + mapValue.get("salerName") +"不存在!!");
  557. }
  558. }
  559. BigDecimal saleOrderId = amsSaleOrderMapper.selectMaxId();
  560. int result = 0;
  561. // 销售订单
  562. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  563. amsSaleOrder.setReceiveId(receiveId);
  564. amsSaleOrder.setSaleRemark(saleRemark == null ? "":saleRemark);
  565. amsSaleOrder.setShipperId(shipperId);
  566. amsSaleOrder.setSaleOrderIsselfMention(isSelfMention);
  567. amsSaleOrder.setSaleOrderId(saleOrderId);
  568. amsSaleOrder.setSalerId(salerId);
  569. // 设置钢材订单
  570. amsSaleOrder.setSaleType(new BigDecimal(1));
  571. amsSaleOrder.setSaleNumber(DataChange.generateEightDigitsNumber("WXSDD",saleOrderId.intValue(),"-"));
  572. amsSaleOrder.setInsertTime(new Date());
  573. amsSaleOrder.setInsertUpdateRemark("物流新增销售订单");
  574. amsSaleOrder.setInsertUsername("物流");
  575. amsSaleOrder.setUpdateTime(new Date());
  576. amsSaleOrder.setDeleted(new BigDecimal(0));
  577. amsSaleOrder.setSaleOrderStatus(new BigDecimal(0));
  578. // 税率默认13%
  579. amsSaleOrder.setSaleOrderTax("13%");
  580. // 含税单价某人4000
  581. amsSaleOrder.setSaleUnitPrice(new BigDecimal(4000));
  582. // 收款客户
  583. amsSaleOrder.setSaleOrderReceiveCustomer(saleOrderReceiveCustomer);
  584. // 销售订单物资表
  585. AmsSaleMaterial amsSaleMaterial = new AmsSaleMaterial();
  586. // 车序号物资表
  587. AmsSaleTrucknoMaterial amsSaleTrucknoMaterial = new AmsSaleTrucknoMaterial();
  588. // 遍历每一行
  589. for (Map<String, Object> map : mapList) {
  590. /*
  591. 车序号表
  592. */
  593. // 得到车序号
  594. BigDecimal truckNo = DataChange.dataToBigDecimal(map.get("truckNo"));
  595. Map<String,Object> saleMap = new HashMap<>();
  596. saleMap.put("saleOrderId",saleOrderId);
  597. saleMap.put("saleOrderMaterialTruckNo",truckNo);
  598. // 检测销售订单下的车序号是否已存在
  599. List<AmsSaleOrderMaterial> amsSaleOrderMaterials = amsSaleOrderMaterialMapper.selectByParameters(saleMap);
  600. // 车序号表
  601. AmsSaleOrderMaterial amsSaleOrderMaterial = new AmsSaleOrderMaterial();
  602. if (amsSaleOrderMaterials == null || amsSaleOrderMaterials.size() == 0) {
  603. // 车序号主键
  604. BigDecimal saleOrderMaterialId = amsSaleOrderMaterialMapper.selectMaxId();
  605. BigDecimal shippingAddressId = DataChange.dataToBigDecimal(map.get("shipperAddressId"));
  606. if (shippingAddressId == null || shippingAddressId.intValue() == 0) {
  607. String province = (String) map.get("province");
  608. String district = (String) map.get("district");
  609. String town = (String) map.get("town");
  610. Map<String,Object> addressMap = new HashMap<>();
  611. addressMap.put("province",province);
  612. addressMap.put("district",district);
  613. addressMap.put("town",town);
  614. shippingAddressId = amsSaleOrderMapper.findAddressId(addressMap);
  615. if (shippingAddressId == null) {
  616. throw new Exception("您输入的:" + province + district + town + "地址不存在!!");
  617. }
  618. }
  619. // 车号备注
  620. String truckRemark = (String) (map.get("truckRemark"));
  621. String place = (String) (map.get("place"));
  622. if (place != null && !"null".equals(place)) {
  623. List<Map<String, Object>> placeIdList = amsSaleOrderMaterialMapper.getPlaceId(place,shippingAddressId);
  624. if (placeIdList == null || placeIdList.size() == 0) {
  625. RmsReceivePlace rmsReceivePlace = new RmsReceivePlace();
  626. rmsReceivePlace.setPlaceId(rmsReceivePlaceMapper.selectMaxId());
  627. rmsReceivePlace.setAddressId(shippingAddressId);
  628. rmsReceivePlace.setAddressDeliveryAddress(place);
  629. amsSaleOrderMaterial.setSaleShippingAddressId(rmsReceivePlace.getPlaceId());
  630. rmsReceivePlaceMapper.insertSelective(rmsReceivePlace);
  631. } else {
  632. amsSaleOrderMaterial.setSaleShippingAddressId((BigDecimal) placeIdList.get(0).get("placeId"));
  633. }
  634. }
  635. if (amsSaleOrderMaterial.getSaleShippingAddressId() != null && isSelfMention.equals("否") && DataChange.dataToBigDecimal(map.get("carrierId")).intValue() == 0) {
  636. // 自动匹配承运商
  637. List<Map<String, Object>> carrierList = getCarrierByAddress(amsSaleOrderMaterial.getSaleShippingAddressId());
  638. BigDecimal carrierCount = null;
  639. if(place != null && !"null".equals(place)){
  640. carrierCount = amsSaleOrderMapper.getMoreCarrier(place);
  641. }
  642. //根据收货地址id查询备注,判断是否需要匹配承运商
  643. String addressRemark = amsSaleOrderMaterialMapper.getAddressRemark(shippingAddressId);
  644. // 单一承运商才进行匹配
  645. if (carrierList != null && carrierList.size() == 1 && carrierList.get(0) != null && carrierCount.intValue() == 0 && addressRemark == null) {
  646. List<Map<String, Object>> list = new ArrayList<>();
  647. Map<String, Object> map1 = carrierList.get(0);
  648. // 传入车序号主键和承运商id
  649. map1.put("saleOrderMaterialId", saleOrderMaterialId);
  650. list.add(map1);
  651. dispatchToCarrier(list);
  652. }
  653. }
  654. if (isSelfMention.equals("是")) {
  655. // 根据收货单位id查询出收货单位名称
  656. String consigneeName = amsSaleOrderMapper.selectConsigneeName(receiveId);
  657. // 根据收货单位名称查询承运商id
  658. BigDecimal carrierId = amsSaleOrderMapper.selectCarrierId(consigneeName);
  659. List<Map<String, Object>> list = new ArrayList<>();
  660. Map<String,Object> map1 = new HashMap<>();
  661. // 传入车序号主键和承运商id
  662. if (carrierId != null) {
  663. map1.put("saleOrderMaterialId", saleOrderMaterialId);
  664. map1.put("carrierId", carrierId);
  665. list.add(map1);
  666. dispatchToCarrier(list);
  667. }
  668. }
  669. if (isSelfMention.equals("否") && DataChange.dataToBigDecimal(map.get("carrierId")).intValue() != 0) {
  670. //说明有承运商
  671. List<Map<String, Object>> list = new ArrayList<>();
  672. Map<String, Object> carrierMap = new HashMap<>();
  673. carrierMap.put("carrierId",map.get("carrierId"));
  674. carrierMap.put("saleOrderMaterialId",saleOrderMaterialId);
  675. list.add(carrierMap);
  676. dispatchToCarrier(list);
  677. }
  678. // 收货方姓名
  679. String consigneeName = String.valueOf(map.get("saleOrderConsignee"));
  680. // 收货方电话
  681. String consigneeTel = String.valueOf(map.get("saleOrderConsigneeTel"));
  682. // 截止日期
  683. String dateOfReceiptStr = String.valueOf(map.get("saleDateOfReceipt"));
  684. Date dateOfReceipt = null;
  685. if (!"null".equals(dateOfReceiptStr) && !"undefined".equals(dateOfReceiptStr)) {
  686. dateOfReceipt = new Date(Long.valueOf(dateOfReceiptStr));
  687. }
  688. amsSaleOrderMaterial.setSaleOrderMaterialId(saleOrderMaterialId);
  689. amsSaleOrderMaterial.setSaleOrderId(saleOrderId);
  690. amsSaleOrderMaterial.setTruckRemark(truckRemark);
  691. amsSaleOrderMaterial.setSaleOrderMaterialTruckNo(truckNo);
  692. if(map.get("orderNo") != null) {
  693. amsSaleOrderMaterial.setPreviousOrderNumber((String) map.get("orderNo"));
  694. }
  695. if (consigneeName != null && !consigneeName.equals("null")) {
  696. amsSaleOrderMaterial.setSaleOrderConsignee(consigneeName);
  697. }
  698. if (consigneeTel != null && !consigneeTel.equals("null")) {
  699. amsSaleOrderMaterial.setSaleOrderConsigneeTel(consigneeTel);
  700. }
  701. amsSaleOrderMaterial.setSaleDateOfReceipt(dateOfReceipt);
  702. amsSaleOrderMaterial.setInsertTime(new Date());
  703. amsSaleOrderMaterial.setUpdateTime(new Date());
  704. amsSaleOrderMaterial.setInsertUpdateRemark("物流新增");
  705. result += amsSaleOrderMaterialMapper.insertSelective(amsSaleOrderMaterial);
  706. }
  707. else {
  708. amsSaleOrderMaterial = amsSaleOrderMaterials.get(0);
  709. }
  710. /*
  711. 销售订单物资表
  712. */
  713. // 物资
  714. BigDecimal materialId = DataChange.dataToBigDecimal(map.get("materialId"));
  715. if (materialId == null || materialId.intValue() == 0) {
  716. String name = (String) map.get("materialName");
  717. String specification = (String) map.get("materialSpecification");
  718. String model = (String) map.get("materialModel");
  719. Map<String,Object> materialMap = new HashMap<>();
  720. materialMap.put("name",name);
  721. materialMap.put("specification",specification);
  722. if (model == null || model.equals("") || model.equals("null")) {
  723. model = null;
  724. }
  725. materialMap.put("model",model);
  726. materialId = amsSaleOrderMapper.findMaterialId(materialMap);
  727. if (materialId == null) {
  728. throw new Exception("您输入的物资:" + name + specification + model + "不存在!!");
  729. }
  730. }
  731. Integer materialCount = amsSaleMaterialMapper.getMaterialCount(materialId);
  732. RmsMaterial rmsMaterial = new RmsMaterial();
  733. rmsMaterial.setMaterialId(materialId);
  734. if (materialCount == null) {
  735. materialCount = new Integer(0);
  736. }
  737. rmsMaterial.setMaterialCount(new BigDecimal(materialCount + 1));
  738. rmsMaterialMapper.updateByPrimaryKeySelective(rmsMaterial);
  739. // 物资件数
  740. BigDecimal materialNumber = DataChange.dataToBigDecimal(map.get("materialNumber"));
  741. // 物资名称
  742. Object materialName = map.get("materialName");
  743. // 钢材米数
  744. BigDecimal steelMeters = DataChange.dataToBigDecimal(map.get("steelMeters"));
  745. // 判断物资是否是盘螺或盘元/盘圆
  746. if (materialName != null && (materialName.toString().contains("盘螺") || materialName.toString().contains("盘元") || materialName.toString().contains("盘圆"))) {
  747. amsSaleMaterial.setSteelMeter(null);
  748. }
  749. else {
  750. amsSaleMaterial.setSteelMeter(steelMeters);
  751. }
  752. // 是否磅重销售(0:磅重;1:理重)
  753. BigDecimal isPoundSale = DataChange.dataToBigDecimal(map.get("isPoundSale"));
  754. // 销售订单物资表主键
  755. BigDecimal saleMaterialId = amsSaleMaterialMapper.selectMaxId();
  756. amsSaleMaterial.setSaleMaterialId(saleMaterialId);
  757. amsSaleMaterial.setSaleOrderId(saleOrderId);
  758. amsSaleMaterial.setMaterialId(materialId);
  759. amsSaleMaterial.setMaterialNumber(materialNumber);
  760. amsSaleMaterial.setMaterialPlanNumber(materialNumber);
  761. amsSaleMaterial.setInsertTime(new Date());
  762. amsSaleMaterial.setUpdateTime(new Date());
  763. amsSaleMaterial.setIsPoundSale(isPoundSale);
  764. amsSaleMaterial.setInsertUpdateRemark("物流新增");
  765. result += amsSaleMaterialMapper.insertSelective(amsSaleMaterial);
  766. /*
  767. 车序号物资表
  768. */
  769. // 车序号物资表主键
  770. BigDecimal truckNoMaterialId = amsSaleTrucknoMaterialMapper.selectMaxId();
  771. amsSaleTrucknoMaterial.setTrucknoMaterialId(truckNoMaterialId);
  772. amsSaleTrucknoMaterial.setSaleOrderMaterialId(amsSaleOrderMaterial.getSaleOrderMaterialId());
  773. amsSaleTrucknoMaterial.setMaterialId(amsSaleMaterial.getSaleMaterialId());
  774. amsSaleTrucknoMaterial.setSaleOrderMaterialNumber(materialNumber);
  775. amsSaleTrucknoMaterial.setInsertTime(new Date());
  776. amsSaleTrucknoMaterial.setUpdateTime(new Date());
  777. amsSaleTrucknoMaterial.setInsertUpdateRemark("物流新增");
  778. result += amsSaleTrucknoMaterialMapper.insertSelective(amsSaleTrucknoMaterial);
  779. }
  780. result += amsSaleOrderMapper.insertSelective(amsSaleOrder);
  781. return saleOrderId.intValue();
  782. }
  783. /**
  784. * 展示销售订单下的车序号和物资
  785. * @param saleOrderId
  786. * @return
  787. */
  788. @Override
  789. public List<Map<String, Object>> getTruckNoAndMaterialList(BigDecimal saleOrderId) {
  790. HashMap<String,Object> mapValue = new HashMap<>();
  791. mapValue.put("saleOrderId",saleOrderId);
  792. List<Map<String,Object>> mapList = amsSaleOrderMapper.getTruckNoAndMaterial(mapValue);
  793. for (Map<String,Object> map : mapList) {
  794. BigDecimal placeId = (BigDecimal) map.get("placeId");
  795. if (placeId != null) {
  796. List<Map<String, Object>> carrierAndPriceList = getCarrierByPlace(placeId);
  797. map.put("carrierAndPriceList", carrierAndPriceList);
  798. }
  799. }
  800. return mapList;
  801. }
  802. /**
  803. * 销售钢材派车
  804. * @param mapList
  805. * @return
  806. */
  807. @Transactional(rollbackFor = Exception.class)
  808. @Override
  809. public int dispatchSteelOrder(List<Map<String, Object>> mapList) throws Exception {
  810. Map<String, Object> stringObjectMap = mapList.get(0);
  811. Integer isCheckGps = amsSaleOrderMapper.getDispachSwitch();
  812. Integer saleStatus = amsSaleOrderMapper.findStatus(DataChange.dataToBigDecimal(stringObjectMap.get("saleOrderMaterialId")));
  813. String selfMention = amsSaleOrderMapper.findSelfMention(DataChange.dataToBigDecimal(stringObjectMap.get("saleOrderMaterialId")));
  814. //如果这个车序号下面有运单,则证明已经派了
  815. Map<String,Object> orderMap = amsSaleOrderMapper.getSteelOrderMap(DataChange.dataToBigDecimal(stringObjectMap.get("saleOrderMaterialId")));
  816. if (orderMap != null) {
  817. throw new Exception("该订单已派发,无法重复派车");
  818. }
  819. if (saleStatus == 1) {
  820. throw new Exception("订单未审核,无法派车!");
  821. }
  822. int result = 0;
  823. // 遍历每一行
  824. for (Map<String,Object> map : mapList) {
  825. // 得到车牌号
  826. String capacityNumber = (String) map.get("capacityNumber");
  827. //Map<String,Object> details = amsSaleOrderMapper.getOrderIdByCapacity(map);
  828. //if(details!=null && details.get("orderId")!=null){
  829. // if(details.get("isEn")==null){
  830. // throw new Exception(capacityNumber+"有未进厂的运输订单任务,无法派单");
  831. // }else if(details.get("isLeave")==null){
  832. // throw new Exception(capacityNumber+"有未出厂的运输订单任务,无法派单");
  833. // }else if(details.get("isArrival")==null){
  834. // throw new Exception(capacityNumber+"有未抵达的运输订单任务,无法派单");
  835. // }else if(details.get("isReceipt")==null){
  836. // throw new Exception(capacityNumber+"有未签收的运输订单任务,无法派单");
  837. // }
  838. // throw new Exception(capacityNumber+"有未完成的运输订单任务,无法派单");
  839. //}
  840. if(isCheckGps!=null && isCheckGps==0){
  841. Map<String,Object> locationResult = null;
  842. int isGPS=0;
  843. try{
  844. Map<String,Object> data = (Map<String,Object>)otmsFeign.getCurrentLocation(capacityNumber).getData();
  845. locationResult = (Map<String,Object>)data.get("result");
  846. isGPS=amsSaleOrderMapper.isGPS(capacityNumber);
  847. }catch (Exception e){
  848. //出现任何异常不抛出,不终止程序
  849. }
  850. if(isGPS > 0){
  851. System.out.println(capacityNumber+"允许无GPS派车");
  852. }else if(locationResult==null || locationResult.get("lon")==null || locationResult.get("lat")==null){
  853. throw new Exception("该车没有GPS定位信息,请联系销售公司物流部,申请是否可以派车。");
  854. }
  855. }
  856. // 得到车序号表主键
  857. BigDecimal saleOrderMaterialId = DataChange.dataToBigDecimal(map.get("saleOrderMaterialId"));
  858. // 得到承运商
  859. BigDecimal carrierId = DataChange.dataToBigDecimal(map.get("carrierId"));
  860. // 查询到车序号的单价
  861. BigDecimal priceId = amsSaleOrderMapper.getOrderPrice(map);
  862. // 得到详细地址id
  863. BigDecimal placeId = amsSaleOrderMapper.getPlaceId(saleOrderMaterialId);
  864. // 如果详细地址匹配不到单价,则匹配省市县内最高的一条单价(只给非自提的进行匹配)
  865. if (priceId == null && selfMention.equals("否")) {
  866. // 找到详细地址下的省市县id
  867. BigDecimal addressId = amsSaleOrderMapper.getAddressByPlace(placeId);
  868. // 根据省市县匹配出省市县下的所有单价
  869. Map<String, Object> hashMap = new HashMap<>();
  870. hashMap.put("addressId", addressId);
  871. hashMap.put("carrierId", carrierId);
  872. List<Map<String, Object>> priceList = amsSaleOrderMapper.getAddressPriceList(hashMap);
  873. // 如果长度为0,说明此地址所在省市县内也无单价
  874. if (priceList != null && priceList.size() != 0) {
  875. Map<String, Object> priceMap = priceList.get(0);
  876. priceId = (BigDecimal) priceMap.get("priceId");
  877. } else {
  878. priceId = new BigDecimal(2400);
  879. }
  880. }
  881. // 运输线路id
  882. BigDecimal lineId = DataChange.dataToBigDecimal(map.get("lineId"));
  883. // 司机电话号码
  884. String driverTel = (String) map.get("driverTel");
  885. BigDecimal isSteel = new BigDecimal(1);
  886. // 得到运力id
  887. BigDecimal capacityId = amsSaleOrderMaterialMapper.getCapacityId(capacityNumber);
  888. try{
  889. Map<String,Object> map1=new HashMap<>();
  890. map1.put("capacityNumber",capacityNumber);
  891. map1.put("capacityTel",driverTel);
  892. //在得到司机电话后给运力添加电话号码(通过车牌号)
  893. rmsFeign.updateCapacity(map1);
  894. }catch (Exception e){
  895. e.printStackTrace();
  896. }
  897. if (capacityId == null) {
  898. return 0;
  899. }
  900. List<Map<String, Object>> materialList = amsSaleOrderMaterialMapper.getMaterial(saleOrderMaterialId);
  901. /*
  902. 定向派单表
  903. */
  904. // 通过车序号主键确认定向派单是否已存在
  905. BigDecimal dispatchId0 = amsDispatchSaleOrderMapper.isDispatchExist(saleOrderMaterialId);
  906. if (dispatchId0 == null || dispatchId0.toString().length() == 0) {
  907. AmsDispatchSaleOrder amsDispatchSaleOrder = new AmsDispatchSaleOrder();
  908. // 主键
  909. BigDecimal dispatchId = amsDispatchSaleOrderMapper.selectOtherId();
  910. amsDispatchSaleOrder.setDispatchId(dispatchId);
  911. // 车序号表id
  912. amsDispatchSaleOrder.setSaleOrderMaterialId(saleOrderMaterialId);
  913. // 承运商id
  914. amsDispatchSaleOrder.setCarrierId(carrierId);
  915. // 派单时间和成交时间
  916. amsDispatchSaleOrder.setDispatchTime(new Date());
  917. amsDispatchSaleOrder.setDispatchDealTime(new Date());
  918. // 成交类型
  919. amsDispatchSaleOrder.setDispatchType(new BigDecimal(2));
  920. // 车序号状态
  921. amsDispatchSaleOrder.setDispatchStatus(new BigDecimal(2));
  922. result += amsDispatchSaleOrderMapper.insertSelective(amsDispatchSaleOrder);
  923. }
  924. // 如果已经匹配过承运商或者给某个承运商授权过,则派车时做修改承运商操作
  925. else {
  926. AmsDispatchSaleOrder amsDispatchSaleOrder = amsDispatchSaleOrderMapper.selectByPrimaryKey(dispatchId0);
  927. amsDispatchSaleOrder.setCarrierId(carrierId);
  928. result += amsDispatchSaleOrderMapper.updateByPrimaryKeySelective(amsDispatchSaleOrder);
  929. }
  930. /*
  931. 运输订单
  932. */
  933. OmstruckOrder omstruckOrder = new OmstruckOrder();
  934. Map<String, Object> map1 = new HashMap<>();
  935. map1.put("orderType", new BigDecimal(2));
  936. map1.put("orderPlanId", saleOrderMaterialId);
  937. List<OmstruckOrder> omstruckOrders = omstruckOrderMapper.selectByParameters(map1);
  938. if (omstruckOrders == null || omstruckOrders.size() == 0) {
  939. // 运输订单主键
  940. BigDecimal orderId = omstruckOrderMapper.selectMaxId();
  941. omstruckOrder.setOrderId(orderId);
  942. // 车序号主键
  943. omstruckOrder.setOrderPlanId(saleOrderMaterialId);
  944. //添加承运商ID 和 运价ID
  945. // Object priceId = map.get("priceId");
  946. if (priceId != null) {
  947. omstruckOrder.setPriceId(priceId);
  948. } else {
  949. omstruckOrder.setPriceId(new BigDecimal(0));
  950. }
  951. omstruckOrder.setCarrierId(carrierId);
  952. // 运输订单号
  953. omstruckOrder.setOrderNumber(DataChange.generateEightDigitsNumber("WYSDD", orderId.intValue()));
  954. // 运力id
  955. omstruckOrder.setCapacityId(capacityId);
  956. // 承运商
  957. omstruckOrder.setCarrierId(carrierId);
  958. // 是否可作业
  959. omstruckOrder.setCanWork(new BigDecimal(0));
  960. // 下发时间
  961. omstruckOrder.setOrderIssueTime(new Date());
  962. // 运单状态
  963. omstruckOrder.setOrderStatus(new BigDecimal(4));
  964. // 司机电话
  965. if (driverTel != null && !"null".equals(driverTel)) {
  966. omstruckOrder.setDriverTel(driverTel);
  967. }
  968. BigDecimal status;
  969. // 钢材
  970. if (isSteel != null && isSteel.intValue() == 1) {
  971. status = new BigDecimal(1);
  972. }
  973. // 非钢材(危化品,焦炭,副产品)
  974. else {
  975. status = new BigDecimal(2);
  976. }
  977. // 订单类型
  978. omstruckOrder.setOrderType(status);
  979. // 运输线路id
  980. omstruckOrder.setLineId(lineId);
  981. omstruckOrder.setInsertTime(new Date());
  982. omstruckOrder.setInsertUsername("");
  983. result += omstruckOrderMapper.insertSelective(omstruckOrder);
  984. } else {
  985. omstruckOrder = omstruckOrders.get(0);
  986. }
  987. for (Map<String, Object> materialMap : materialList) {
  988. BigDecimal materialId = (BigDecimal) materialMap.get("materialId");
  989. BigDecimal materialWeight = (BigDecimal) materialMap.get("materialWeight");
  990. BigDecimal materialNumber = (BigDecimal) materialMap.get("materialNumber");
  991. /*
  992. 运输订单物资子表
  993. */
  994. OmstruckOrderMaterial omstruckOrderMaterial = new OmstruckOrderMaterial();
  995. // 主键
  996. BigDecimal orderMaterialId = omstruckOrderMaterialMapper.selectMaxId();
  997. omstruckOrderMaterial.setOrderMaterialId(orderMaterialId);
  998. // 运输订单id
  999. omstruckOrderMaterial.setOrderId(omstruckOrder.getOrderId());
  1000. // 物资id
  1001. omstruckOrderMaterial.setMaterialId(materialId);
  1002. // 物资重量
  1003. omstruckOrderMaterial.setOrderMaterialWeight(materialWeight);
  1004. // 物资件数
  1005. omstruckOrderMaterial.setOrderMaterialNumber(materialNumber);
  1006. // 新增运输订单子表
  1007. result += omstruckOrderMaterialMapper.insertSelective(omstruckOrderMaterial);
  1008. }
  1009. // 调用websocket
  1010. Map<String, Object> orderIdMap = new HashMap<>();
  1011. orderIdMap.put("orderId", omstruckOrder.getOrderId());
  1012. try {
  1013. amsSaleOrderMaterialService.pushMesToWebsocket(orderIdMap);
  1014. } catch (Exception e) {
  1015. e.printStackTrace();
  1016. }
  1017. // 生成运输执行总实绩
  1018. result += tmsTruckFeign.addTotalResult(orderIdMap);
  1019. }
  1020. return result;
  1021. }
  1022. @Override
  1023. public int continueSteelOrder(List<Map<String, Object>> mapList) throws Exception {
  1024. int result = 0;
  1025. // 遍历每一行
  1026. for (Map<String,Object> map : mapList) {
  1027. List<OmstruckOrder> orders=omstruckOrderMapper.selectByParameters(map);
  1028. if(orders==null || orders.size()<=0){
  1029. throw new Exception("没有对应的运输订单");
  1030. }
  1031. OmstruckOrder omstruckOrder=orders.get(0);
  1032. // 得到车序号表主键
  1033. BigDecimal saleOrderMaterialId = DataChange.dataToBigDecimal(map.get("saleOrderMaterialId"));
  1034. // 得到承运商
  1035. BigDecimal carrierId = omstruckOrder.getCarrierId();
  1036. //查询车序号表物资
  1037. List<Map<String, Object>> materialList = amsSaleOrderMaterialMapper.getMaterial(saleOrderMaterialId);
  1038. if(materialList==null||materialList.size()<=0){
  1039. throw new Exception("车序号没有剩余物资");
  1040. }
  1041. // 程序根据剩余多少拼生成运输线路id 110001 到 110010(单拼到十拼)
  1042. BigDecimal lineId = DataChange.dataToBigDecimal(110000+materialList.size());
  1043. /*
  1044. 定向派单表
  1045. */
  1046. // 通过车序号主键确认定向派单是否已存在
  1047. BigDecimal dispatchId0 = amsDispatchSaleOrderMapper.isDispatchExist(saleOrderMaterialId);
  1048. if (dispatchId0 == null || dispatchId0.toString().length() == 0) {
  1049. AmsDispatchSaleOrder amsDispatchSaleOrder = new AmsDispatchSaleOrder();
  1050. // 主键
  1051. BigDecimal dispatchId = amsDispatchSaleOrderMapper.selectOtherId();
  1052. amsDispatchSaleOrder.setDispatchId(dispatchId);
  1053. // 车序号表id
  1054. amsDispatchSaleOrder.setSaleOrderMaterialId(saleOrderMaterialId);
  1055. // 承运商id
  1056. amsDispatchSaleOrder.setCarrierId(carrierId);
  1057. // 派单时间和成交时间
  1058. amsDispatchSaleOrder.setDispatchTime(new Date());
  1059. amsDispatchSaleOrder.setDispatchDealTime(new Date());
  1060. // 成交类型
  1061. amsDispatchSaleOrder.setDispatchType(new BigDecimal(2));
  1062. // 车序号状态
  1063. amsDispatchSaleOrder.setDispatchStatus(new BigDecimal(2));
  1064. result += amsDispatchSaleOrderMapper.insertSelective(amsDispatchSaleOrder);
  1065. }
  1066. // 如果已经匹配过承运商或者给某个承运商授权过,则派车时做修改承运商操作
  1067. else {
  1068. AmsDispatchSaleOrder amsDispatchSaleOrder = amsDispatchSaleOrderMapper.selectByPrimaryKey(dispatchId0);
  1069. amsDispatchSaleOrder.setCarrierId(carrierId);
  1070. result += amsDispatchSaleOrderMapper.updateByPrimaryKeySelective(amsDispatchSaleOrder);
  1071. }
  1072. /*
  1073. 运输订单
  1074. */
  1075. // 运输订单主键
  1076. BigDecimal orderId = omstruckOrderMapper.selectMaxId();
  1077. omstruckOrder.setOrderId(orderId);
  1078. // 车序号主键
  1079. omstruckOrder.setOrderPlanId(saleOrderMaterialId);
  1080. // 是否可作业
  1081. omstruckOrder.setCanWork(new BigDecimal(0));
  1082. // 下发时间
  1083. omstruckOrder.setOrderIssueTime(new Date());
  1084. // 运单状态
  1085. if(omstruckOrder.getOrderReceiveRefuseTime()!=null){
  1086. omstruckOrder.setOrderStatus(new BigDecimal(7));
  1087. }else{
  1088. omstruckOrder.setOrderStatus(new BigDecimal(4));
  1089. }
  1090. //路段顺序号
  1091. //omstruckOrder.setOrderLineSequence(new BigDecimal(2));
  1092. // 运输线路id
  1093. omstruckOrder.setLineId(lineId);
  1094. omstruckOrder.setInsertTime(new Date());
  1095. omstruckOrder.setInsertUsername("continue");
  1096. result += omstruckOrderMapper.insertSelective(omstruckOrder);
  1097. for (Map<String, Object> materialMap : materialList) {
  1098. BigDecimal materialId = (BigDecimal) materialMap.get("materialId");
  1099. BigDecimal materialWeight = (BigDecimal) materialMap.get("materialWeight");
  1100. BigDecimal materialNumber = (BigDecimal) materialMap.get("materialNumber");
  1101. /*
  1102. 运输订单物资子表
  1103. */
  1104. OmstruckOrderMaterial omstruckOrderMaterial = new OmstruckOrderMaterial();
  1105. // 主键
  1106. BigDecimal orderMaterialId = omstruckOrderMaterialMapper.selectMaxId();
  1107. omstruckOrderMaterial.setOrderMaterialId(orderMaterialId);
  1108. // 运输订单id
  1109. omstruckOrderMaterial.setOrderId(omstruckOrder.getOrderId());
  1110. // 物资id
  1111. omstruckOrderMaterial.setMaterialId(materialId);
  1112. // 物资重量
  1113. omstruckOrderMaterial.setOrderMaterialWeight(materialWeight);
  1114. // 物资件数
  1115. omstruckOrderMaterial.setOrderMaterialNumber(materialNumber);
  1116. // 新增运输订单子表
  1117. result += omstruckOrderMaterialMapper.insertSelective(omstruckOrderMaterial);
  1118. }
  1119. // 调用websocket
  1120. Map<String, Object> orderIdMap = new HashMap<>();
  1121. orderIdMap.put("orderId", omstruckOrder.getOrderId());
  1122. amsSaleOrderMaterialService.pushMesToWebsocket(orderIdMap);
  1123. orderIdMap.put("orderIdOld", map.get("orderId"));
  1124. orderIdMap.put("resultTotalIdOld",map.get("resultTotalId"));
  1125. // 生成所有实绩
  1126. result += tmsTruckFeign.copyAllResult(orderIdMap);
  1127. }
  1128. return result;
  1129. }
  1130. /**
  1131. * 根据详细地址匹配承运商
  1132. * @param placeId
  1133. * @return
  1134. */
  1135. @Override
  1136. public synchronized List<Map<String,Object>> getCarrierByPlace(BigDecimal placeId) {
  1137. BigDecimal addressId = amsSaleOrderMapper.getAddressByPlace(placeId);
  1138. List<Map<String,Object>> mapList = amsSaleOrderMapper.getCarrierByPlace(placeId);
  1139. return mapList;
  1140. }
  1141. /**
  1142. * 根据省市县匹配承运商
  1143. * @param placeId
  1144. * @return
  1145. */
  1146. public synchronized List<Map<String,Object>> getCarrierByAddress(BigDecimal placeId) {
  1147. BigDecimal addressId = amsSaleOrderMapper.getAddressByPlace(placeId);
  1148. List<Map<String,Object>> mapList = amsSaleOrderMapper.getCarrierByAddress(addressId);
  1149. try {
  1150. if(mapList != null && mapList.size() != 1) {
  1151. mapList = amsSaleOrderMapper.getNextCarrier(addressId);
  1152. }
  1153. } catch (Exception e) {
  1154. e.printStackTrace();
  1155. }
  1156. return mapList;
  1157. }
  1158. /**
  1159. * 根据详细地址和承运商匹配单价
  1160. * @param mapValue
  1161. * @return
  1162. */
  1163. @Override
  1164. public Map<String, Object> getPriceByCarrierAndPlace(Map<String, Object> mapValue) {
  1165. Map<String,Object> map = amsSaleOrderMapper.getPriceByCarrierAndPlace(mapValue);
  1166. return map;
  1167. }
  1168. /**
  1169. * 将车序号下发给承运商
  1170. * @param mapList
  1171. * @return
  1172. */
  1173. @Override
  1174. public int dispatchToCarrier(List<Map<String,Object>> mapList) {
  1175. int result = 0;
  1176. // 遍历每一行
  1177. for (Map<String, Object> map : mapList) {
  1178. // 得到承运商
  1179. BigDecimal carrierId =DataChange.dataToBigDecimal(map.get("carrierId"));
  1180. // 得到车序号表主键
  1181. BigDecimal saleOrderMaterialId =DataChange.dataToBigDecimal(map.get("saleOrderMaterialId"));
  1182. //判断该车序号有没有被授权
  1183. List<BigDecimal> dispatchCarriers = amsDispatchSaleOrderMapper.getDispatchCarriers(saleOrderMaterialId);
  1184. //如果有的话删除授权,重新新增
  1185. for(BigDecimal dispatchId : dispatchCarriers) {
  1186. amsDispatchSaleOrderMapper.deleteByPrimaryKey(dispatchId);
  1187. }
  1188. //判断该车序号有没有被授权
  1189. AmsDispatchSaleOrder amsDispatchSaleOrder = new AmsDispatchSaleOrder();
  1190. BigDecimal dispatchId = amsDispatchSaleOrderMapper.selectOtherId();
  1191. amsDispatchSaleOrder.setDispatchId(dispatchId);
  1192. amsDispatchSaleOrder.setCarrierId(carrierId);
  1193. amsDispatchSaleOrder.setSaleOrderMaterialId(saleOrderMaterialId);
  1194. amsDispatchSaleOrder.setInsertTime(new Date());
  1195. amsDispatchSaleOrder.setInsertUpdateRemark("授权承运商");
  1196. // 派单时间和成交时间
  1197. amsDispatchSaleOrder.setDispatchTime(new Date());
  1198. amsDispatchSaleOrder.setDispatchDealTime(new Date());
  1199. // 成交类型
  1200. amsDispatchSaleOrder.setDispatchType(new BigDecimal(2));
  1201. // 车序号状态
  1202. amsDispatchSaleOrder.setDispatchStatus(new BigDecimal(2));
  1203. result += amsDispatchSaleOrderMapper.insertSelective(amsDispatchSaleOrder);
  1204. }
  1205. return result;
  1206. }
  1207. @Override
  1208. public List<Map<String, Object>> getSaleOrderListToCarrier(Map<String, Object> map) {
  1209. List<Map<String, Object>> resultList = amsSaleOrderMapper.getSaleOrderListToCarrier(map);
  1210. if (resultList.isEmpty()){
  1211. }else {
  1212. for (Map<String, Object> stringObjectMap : resultList) {
  1213. try {
  1214. BigDecimal saleShippingAddressId = (BigDecimal) stringObjectMap.get("saleShippingAddressId");
  1215. if (saleShippingAddressId!=null&&!("".equals(saleShippingAddressId))){
  1216. String address = amsSaleOrderMapper.getshippingAddress(saleShippingAddressId);
  1217. stringObjectMap.put("saleShippingAddress",address);
  1218. }
  1219. }catch (Exception e){
  1220. System.out.println("e"+e.getMessage());
  1221. stringObjectMap.put("saleShippingAddress","");
  1222. }
  1223. }
  1224. }
  1225. return resultList;
  1226. }
  1227. @Override
  1228. public List<Map<String, Object>> getSaleOrderListByCarrierSsoId(Map<String, Object> map) {
  1229. List<Map<String, Object>> resultList = amsSaleOrderMapper.getSaleOrderListByCarrierSsoId(map);
  1230. return resultList;
  1231. }
  1232. /**
  1233. * 同步金蝶删除
  1234. * @param saleOrderId
  1235. * @return
  1236. */
  1237. @Override
  1238. public int deleteSaleOrderById(BigDecimal saleOrderId) {
  1239. int result = 0;
  1240. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  1241. amsSaleOrder.setSaleOrderId(saleOrderId);
  1242. amsSaleOrder.setDeleted(new BigDecimal(2));
  1243. // 如果是已经上传金蝶的销售订单,则同步删除
  1244. AmsSaleOrder amsSaleOrder1 = amsSaleOrderMapper.selectByPrimaryKey(saleOrderId);
  1245. if (amsSaleOrder1.getSaleOrderStatus().intValue() == 4) {
  1246. String reason = "修改物资关闭上一条销售订单";
  1247. String number = amsSaleOrder1.getSaleNumber();
  1248. String wholeOrder = "1";
  1249. String status = "close";
  1250. Map<String,Object> head = new HashMap<>();
  1251. head.put("number",number);
  1252. head.put("reason",reason);
  1253. head.put("wholeOrder",wholeOrder);
  1254. head.put("status",status);
  1255. Map<String,Object> input = new HashMap<>();
  1256. Map<String, Object> totalMap = easDeleteApproveUtil.getTotalMap();
  1257. input.put("head",head);
  1258. totalMap.put("input",input);
  1259. // 调用金蝶关闭接口
  1260. String json = JSONUtils.toJSONString(totalMap);
  1261. System.out.println(json);
  1262. Map<String,Object> resultMap = joinFeign.deleteSaleOrderToEas(totalMap);
  1263. System.out.println(resultMap);
  1264. }else if(amsSaleOrder1.getSaleOrderStatus().intValue() == 1 || amsSaleOrder1.getSaleOrderStatus().intValue() == 2){
  1265. String reason = "修改物资关闭上一条销售订单";
  1266. String number = amsSaleOrder1.getSaleNumber();
  1267. Map<String, Object> deleteMap = new HashMap<>();
  1268. deleteMap.put("saleOrderId",saleOrderId);
  1269. deleteMap.put("reason",reason);
  1270. deleteMap.put("number",number);
  1271. deleteSaleOrderSame(deleteMap);
  1272. }
  1273. // 如果是副产品订单则关闭时同步关闭未进厂的运单
  1274. Map<String,Object> map = new HashMap<>();
  1275. map.put("saleOrderId",saleOrderId);
  1276. List<AmsSaleMaterial> amsSaleMaterials = amsSaleMaterialMapper.selectByParameters(map);
  1277. if (amsSaleMaterials != null && amsSaleMaterials.get(0).getSaleWarehouse() != null && amsSaleMaterials.get(0).getSaleWarehouse().equals("副产品库")) {
  1278. result += amsSaleOrderMapper.closeOrderNotIn(saleOrderId);
  1279. }
  1280. result += amsSaleOrderMapper.updateByPrimaryKeySelective(amsSaleOrder);
  1281. return result;
  1282. }
  1283. /**
  1284. * 查询出销售订单下的所有数据
  1285. * @param saleOrderId
  1286. * @return
  1287. */
  1288. @Override
  1289. public Map<String, Object> getAllSaleMessages(BigDecimal saleOrderId) {
  1290. Map<String,Object> saleMap = amsSaleOrderMapper.getSaleMapMessages(saleOrderId);
  1291. List<Map<String,Object>> mapList = amsSaleOrderMapper.getSaleListMessages(saleOrderId);
  1292. saleMap.put("mapList",mapList);
  1293. return saleMap;
  1294. }
  1295. /**
  1296. * 修改承运商授权
  1297. * @param mapValue
  1298. * @return
  1299. */
  1300. @Override
  1301. public int updateTruckNoCarrier(Map<String, Object> mapValue) {
  1302. BigDecimal carrierId = DataChange.dataToBigDecimal(mapValue.get("carrierId"));
  1303. mapValue.remove("carrierId");
  1304. List<AmsDispatchSaleOrder> amsDispatchSaleOrders = amsDispatchSaleOrderMapper.selectByParameters(mapValue);
  1305. AmsDispatchSaleOrder amsDispatchSaleOrder = amsDispatchSaleOrders.get(0);
  1306. amsDispatchSaleOrder.setCarrierId(carrierId);
  1307. int result = amsDispatchSaleOrderMapper.updateByPrimaryKeySelective(amsDispatchSaleOrder);
  1308. return result;
  1309. }
  1310. /**
  1311. * 批量上传销售订单至金蝶
  1312. * @param saleOrderIdList
  1313. * @return
  1314. */
  1315. @Transactional(rollbackFor = Exception.class)
  1316. @Override
  1317. public int uploadSaleOrderList(List<Map<String, Object>> saleOrderIdList) {
  1318. int result = 0;
  1319. for (Map<String, Object> map : saleOrderIdList) {
  1320. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  1321. BigDecimal saleOrderId = DataChange.dataToBigDecimal(map.get("saleOrderId"));
  1322. // 调用金蝶接口,将销售订单推送到金蝶系统
  1323. Map<String, Object> input = joinFeign.getSaleOrder(saleOrderId);
  1324. Map<String, Object> head = (Map<String, Object>) input.get("head");
  1325. head.put("status","");
  1326. // 获得金蝶接口配置:正式
  1327. // Map<String, Object> totalMap = easUtil.getTotalMap();
  1328. // 获得金蝶接口配置:测试
  1329. Map<String, Object> totalMap = easUtil.getTotalMap();
  1330. // 组装报文
  1331. totalMap.put("input",input);
  1332. System.out.println(totalMap);
  1333. String json = JSONUtils.toJSONString(totalMap);
  1334. System.out.println(json);
  1335. Map<String,Object> s = joinFeign.pushSaleOrderToEas(totalMap);
  1336. String status = (String) s.get("status");
  1337. if ("-1".equals(status)) {
  1338. continue;
  1339. }
  1340. System.out.println(s);
  1341. amsSaleOrder.setSaleOrderId(saleOrderId);
  1342. amsSaleOrder.setSaleOrderStatus(new BigDecimal(1));
  1343. result += amsSaleOrderMapper.updateByPrimaryKeySelective(amsSaleOrder);
  1344. }
  1345. return result;
  1346. }
  1347. /**
  1348. * 新增钒渣销售订单
  1349. * @param mapValue
  1350. * @return
  1351. */
  1352. @Override
  1353. public int addVanadiumSaleOrder(Map<String, Object> mapValue) {
  1354. List<Map<String,Object>> mapList = (List<Map<String, Object>>) mapValue.get("mapList");
  1355. // 得到发货单位
  1356. BigDecimal shipperId = DataChange.dataToBigDecimal(mapValue.get("shipperId"));
  1357. // 收货单位
  1358. BigDecimal receiveId = DataChange.dataToBigDecimal(mapValue.get("receiveId"));
  1359. // 是否自提
  1360. String isSelfMention = (String) mapValue.get("isSelfMention");
  1361. // 备注
  1362. String saleRemark = (String) mapValue.get("saleRemark");
  1363. // 收款客户
  1364. String saleOrderReceiveCustomer = (String) mapValue.get("saleOrderReceiveCustomer");
  1365. // 业务员
  1366. BigDecimal salerId = DataChange.dataToBigDecimal(mapValue.get("salerId"));
  1367. BigDecimal saleOrderId = amsSaleOrderMapper.selectMaxId();
  1368. int result = 0;
  1369. // 销售订单
  1370. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  1371. amsSaleOrder.setReceiveId(receiveId);
  1372. amsSaleOrder.setSaleRemark(saleRemark == null ? "":saleRemark);
  1373. amsSaleOrder.setShipperId(shipperId);
  1374. amsSaleOrder.setSaleOrderIsselfMention(isSelfMention);
  1375. amsSaleOrder.setSaleOrderId(saleOrderId);
  1376. amsSaleOrder.setSalerId(salerId);
  1377. // 设置钒渣订单
  1378. amsSaleOrder.setSaleType(new BigDecimal(2));
  1379. amsSaleOrder.setSaleNumber(DataChange.generateEightDigitsNumber("WXSDD",saleOrderId.intValue(),"-"));
  1380. amsSaleOrder.setInsertTime(new Date());
  1381. amsSaleOrder.setInsertUpdateRemark("物流新增销售订单");
  1382. amsSaleOrder.setInsertUsername("物流");
  1383. amsSaleOrder.setUpdateTime(new Date());
  1384. amsSaleOrder.setDeleted(new BigDecimal(0));
  1385. amsSaleOrder.setSaleOrderStatus(new BigDecimal(0));
  1386. // 税率默认13%
  1387. amsSaleOrder.setSaleOrderTax("13%");
  1388. // 含税单价某人4000
  1389. amsSaleOrder.setSaleUnitPrice(new BigDecimal(4000));
  1390. // 收款客户
  1391. amsSaleOrder.setSaleOrderReceiveCustomer(saleOrderReceiveCustomer);
  1392. // 销售订单物资表
  1393. AmsSaleMaterial amsSaleMaterial = new AmsSaleMaterial();
  1394. // 车序号物资表
  1395. AmsSaleTrucknoMaterial amsSaleTrucknoMaterial = new AmsSaleTrucknoMaterial();
  1396. // 遍历每一行
  1397. for (Map<String, Object> map : mapList) {
  1398. /*
  1399. 车序号表
  1400. */
  1401. // 得到车序号
  1402. BigDecimal truckNo = DataChange.dataToBigDecimal(map.get("truckNo"));
  1403. Map<String,Object> saleMap = new HashMap<>();
  1404. saleMap.put("saleOrderId",saleOrderId);
  1405. saleMap.put("saleOrderMaterialTruckNo",truckNo);
  1406. // 检测销售订单下的车序号是否已存在
  1407. List<AmsSaleOrderMaterial> amsSaleOrderMaterials = amsSaleOrderMaterialMapper.selectByParameters(saleMap);
  1408. // 车序号表
  1409. AmsSaleOrderMaterial amsSaleOrderMaterial = new AmsSaleOrderMaterial();
  1410. if (amsSaleOrderMaterials == null || amsSaleOrderMaterials.size() == 0) {
  1411. // 车序号主键
  1412. BigDecimal saleOrderMaterialId = amsSaleOrderMaterialMapper.selectMaxId();
  1413. BigDecimal shippingAddressId = DataChange.dataToBigDecimal(map.get("shipperAddressId"));
  1414. // 车号备注
  1415. String truckRemark = (String) (map.get("truckRemark"));
  1416. String place = (String) (map.get("place"));
  1417. if (place != null && !"null".equals(place)) {
  1418. List<Map<String, Object>> placeIdList = amsSaleOrderMaterialMapper.getPlaceId(place,shippingAddressId);
  1419. if (placeIdList == null || placeIdList.size() == 0) {
  1420. RmsReceivePlace rmsReceivePlace = new RmsReceivePlace();
  1421. rmsReceivePlace.setPlaceId(rmsReceivePlaceMapper.selectMaxId());
  1422. rmsReceivePlace.setAddressId(shippingAddressId);
  1423. rmsReceivePlace.setAddressDeliveryAddress(place);
  1424. amsSaleOrderMaterial.setSaleShippingAddressId(rmsReceivePlace.getPlaceId());
  1425. rmsReceivePlaceMapper.insertSelective(rmsReceivePlace);
  1426. } else {
  1427. amsSaleOrderMaterial.setSaleShippingAddressId((BigDecimal) placeIdList.get(0).get("placeId"));
  1428. }
  1429. }
  1430. if (amsSaleOrderMaterial.getSaleShippingAddressId() != null && isSelfMention.equals("否")) {
  1431. // 自动匹配承运商
  1432. List<Map<String, Object>> carrierList = getCarrierByPlace(amsSaleOrderMaterial.getSaleShippingAddressId());
  1433. // 单一承运商才进行匹配
  1434. if (carrierList != null && carrierList.size() == 1) {
  1435. List<Map<String, Object>> list = new ArrayList<>();
  1436. Map<String, Object> map1 = carrierList.get(0);
  1437. // 传入车序号主键和承运商id
  1438. map1.put("saleOrderMaterialId", saleOrderMaterialId);
  1439. map1.put("carrierId", map1.get("value"));
  1440. list.add(map1);
  1441. dispatchToCarrier(list);
  1442. }
  1443. }
  1444. if (isSelfMention.equals("是")) {
  1445. // 根据收货单位id查询出收货单位名称
  1446. String consigneeName = amsSaleOrderMapper.selectConsigneeName(receiveId);
  1447. // 根据收货单位名称查询承运商id
  1448. BigDecimal carrierId = amsSaleOrderMapper.selectCarrierId(consigneeName);
  1449. List<Map<String, Object>> list = new ArrayList<>();
  1450. Map<String,Object> map1 = new HashMap<>();
  1451. // 传入车序号主键和承运商id
  1452. if (carrierId != null) {
  1453. map1.put("saleOrderMaterialId", saleOrderMaterialId);
  1454. map1.put("carrierId", carrierId);
  1455. list.add(map1);
  1456. dispatchToCarrier(list);
  1457. }
  1458. }
  1459. // 收货方姓名
  1460. String consigneeName = String.valueOf(map.get("saleOrderConsignee"));
  1461. // 收货方电话
  1462. String consigneeTel = String.valueOf(map.get("saleOrderConsigneeTel"));
  1463. // 截止日期
  1464. String dateOfReceiptStr = String.valueOf(map.get("saleDateOfReceipt"));
  1465. Date dateOfReceipt = null;
  1466. if (!"null".equals(dateOfReceiptStr) && !"undefined".equals(dateOfReceiptStr)) {
  1467. dateOfReceipt = new Date(Long.valueOf(dateOfReceiptStr));
  1468. }
  1469. amsSaleOrderMaterial.setSaleOrderMaterialId(saleOrderMaterialId);
  1470. amsSaleOrderMaterial.setSaleOrderId(saleOrderId);
  1471. amsSaleOrderMaterial.setTruckRemark(truckRemark);
  1472. amsSaleOrderMaterial.setSaleOrderMaterialTruckNo(truckNo);
  1473. if (consigneeName != null && !consigneeName.equals("null")) {
  1474. amsSaleOrderMaterial.setSaleOrderConsignee(consigneeName);
  1475. }
  1476. if (consigneeTel != null && !consigneeTel.equals("null")) {
  1477. amsSaleOrderMaterial.setSaleOrderConsigneeTel(consigneeTel);
  1478. }
  1479. amsSaleOrderMaterial.setSaleDateOfReceipt(dateOfReceipt);
  1480. amsSaleOrderMaterial.setInsertTime(new Date());
  1481. amsSaleOrderMaterial.setUpdateTime(new Date());
  1482. amsSaleOrderMaterial.setInsertUpdateRemark("物流新增");
  1483. result += amsSaleOrderMaterialMapper.insertSelective(amsSaleOrderMaterial);
  1484. }
  1485. else {
  1486. amsSaleOrderMaterial = amsSaleOrderMaterials.get(0);
  1487. }
  1488. /*
  1489. 销售订单物资表
  1490. */
  1491. // 物资
  1492. BigDecimal materialId = DataChange.dataToBigDecimal(map.get("materialId"));
  1493. // 物资件数
  1494. BigDecimal materialNumber = DataChange.dataToBigDecimal(map.get("materialNumber"));
  1495. // 钢材米数
  1496. BigDecimal steelMeters = DataChange.dataToBigDecimal(map.get("steelMeters"));
  1497. // 是否磅重销售(0:磅重;1:理重)
  1498. BigDecimal isPoundSale = DataChange.dataToBigDecimal(map.get("isPoundSale"));
  1499. // 销售订单物资表主键
  1500. BigDecimal saleMaterialId = amsSaleMaterialMapper.selectMaxId();
  1501. amsSaleMaterial.setSaleMaterialId(saleMaterialId);
  1502. amsSaleMaterial.setSaleOrderId(saleOrderId);
  1503. amsSaleMaterial.setMaterialId(materialId);
  1504. amsSaleMaterial.setMaterialNumber(materialNumber);
  1505. amsSaleMaterial.setInsertTime(new Date());
  1506. amsSaleMaterial.setUpdateTime(new Date());
  1507. if (steelMeters != null && !steelMeters.toString().equals("0")) {
  1508. amsSaleMaterial.setSteelMeter(steelMeters);
  1509. }
  1510. amsSaleMaterial.setIsPoundSale(isPoundSale);
  1511. amsSaleMaterial.setInsertUpdateRemark("物流新增");
  1512. result += amsSaleMaterialMapper.insertSelective(amsSaleMaterial);
  1513. /*
  1514. 车序号物资表
  1515. */
  1516. // 车序号物资表主键
  1517. BigDecimal truckNoMaterialId = amsSaleTrucknoMaterialMapper.selectMaxId();
  1518. amsSaleTrucknoMaterial.setTrucknoMaterialId(truckNoMaterialId);
  1519. amsSaleTrucknoMaterial.setSaleOrderMaterialId(amsSaleOrderMaterial.getSaleOrderMaterialId());
  1520. amsSaleTrucknoMaterial.setMaterialId(amsSaleMaterial.getSaleMaterialId());
  1521. amsSaleTrucknoMaterial.setSaleOrderMaterialNumber(materialNumber);
  1522. amsSaleTrucknoMaterial.setInsertTime(new Date());
  1523. amsSaleTrucknoMaterial.setUpdateTime(new Date());
  1524. amsSaleTrucknoMaterial.setInsertUpdateRemark("物流新增");
  1525. result += amsSaleTrucknoMaterialMapper.insertSelective(amsSaleTrucknoMaterial);
  1526. }
  1527. result += amsSaleOrderMapper.insertSelective(amsSaleOrder);
  1528. return result;
  1529. }
  1530. /**
  1531. * 自动匹配出最近的一个地址
  1532. * @param receiveId
  1533. * @return
  1534. */
  1535. @Override
  1536. public List<Map<String, Object>> matchingAddressRecently(BigDecimal receiveId) {
  1537. List<Map<String,Object>> mapList = amsSaleOrderMapper.matchingAddressRecently(receiveId);
  1538. List<Map<String,Object>> salerList = amsSaleOrderMapper.getSalerByReceiveId(receiveId);
  1539. if (mapList != null && mapList.size() != 0) {
  1540. if (salerList != null && salerList.size() !=0) {
  1541. Map<String, Object> salerMap = salerList.get(0);
  1542. for (Map<String, Object> map : mapList) {
  1543. map.putAll(salerMap);
  1544. }
  1545. }
  1546. }
  1547. return mapList;
  1548. }
  1549. /**
  1550. * 自动匹配上一条运单的司机电话
  1551. * @param capacityNumber
  1552. * @return
  1553. */
  1554. @Override
  1555. public String matchingDriverTelRecently(String capacityNumber) {
  1556. String driverTel = amsSaleOrderMapper.matchingDriverTelRecently(capacityNumber);
  1557. return driverTel;
  1558. }
  1559. /**
  1560. * 查询内转焦炭订单
  1561. * @param mapValue
  1562. * @return
  1563. */
  1564. @Override
  1565. public List<Map<String, Object>> getCokeInwardOrderList(Map<String, Object> mapValue) {
  1566. return amsSaleOrderMapper.getCokeInwardOrderList(mapValue);
  1567. }
  1568. /**
  1569. * 修改收货地址
  1570. * @param mapValue
  1571. * @return
  1572. */
  1573. @Transactional(rollbackFor = Exception.class)
  1574. @Override
  1575. public int updateCarAddress(Map<String, Object> mapValue) {
  1576. // 判断是否需要删除金蝶分录
  1577. Integer isCloseEas = (Integer) mapValue.get("isCloseEas");
  1578. String operateName = (String) mapValue.get("operateName");
  1579. int result = 0;
  1580. // 运输订单id
  1581. BigDecimal orderId = DataChange.dataToBigDecimal(mapValue.get("orderId"));
  1582. // 车序号id
  1583. BigDecimal saleOrderMaterialId = DataChange.dataToBigDecimal(mapValue.get("saleOrderMaterialId"));
  1584. // 是
  1585. if (isCloseEas == 0 && orderId != null && orderId.intValue() != 0) {
  1586. OmstruckOrder omstruckOrder = new OmstruckOrder();
  1587. omstruckOrder.setOrderId(orderId);
  1588. omstruckOrder.setOrderStatus(new BigDecimal(7));
  1589. if(operateName != null){
  1590. omstruckOrder.setOptionerCode(operateName);
  1591. }
  1592. omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  1593. // 得到销售订单物资表主键
  1594. List<Map<String,Object>> saleMaterialIdList = amsSaleOrderMapper.getSaleMaterialId(saleOrderMaterialId);
  1595. for (Map<String, Object> map : saleMaterialIdList) {
  1596. // 关闭销售订单物资子表
  1597. BigDecimal saleMaterialId = (BigDecimal) map.get("saleMaterialId");
  1598. AmsSaleMaterial amsSaleMaterial = new AmsSaleMaterial();
  1599. amsSaleMaterial.setDeleted(new BigDecimal(0));
  1600. amsSaleMaterial.setSaleMaterialId(saleMaterialId);
  1601. amsSaleMaterialMapper.updateByPrimaryKeySelective(amsSaleMaterial);
  1602. }
  1603. return 0;
  1604. }
  1605. // 判断是否需要修改派车
  1606. Object isNewCar = mapValue.get("isNewCar");
  1607. // 省市县ID
  1608. BigDecimal shippingAddressId = DataChange.dataToBigDecimal(mapValue.get("shipperAddressId"));
  1609. // 具体地址
  1610. String place = (String) mapValue.get("place");
  1611. Integer addressid1= (Integer) mapValue.get("placeId");
  1612. BigDecimal addressid2 =BigDecimal.ZERO;
  1613. AmsSaleOrderMaterial amsSaleOrderMaterial = amsSaleOrderMaterialMapper.selectByPrimaryKey(saleOrderMaterialId);
  1614. if (place != null && !("".equals(place))) {
  1615. List<Map<String, Object>> placeIdList = amsSaleOrderMaterialMapper.getPlaceId(place,shippingAddressId);
  1616. if (placeIdList == null || placeIdList.size() == 0) {
  1617. RmsReceivePlace rmsReceivePlace = new RmsReceivePlace();
  1618. BigDecimal placeId = rmsReceivePlaceMapper.selectMaxId();
  1619. rmsReceivePlace.setPlaceId(placeId);
  1620. rmsReceivePlace.setAddressId(shippingAddressId);
  1621. rmsReceivePlace.setAddressDeliveryAddress(place);
  1622. amsSaleOrderMaterial.setSaleShippingAddressId(rmsReceivePlace.getPlaceId());
  1623. rmsReceivePlaceMapper.insertSelective(rmsReceivePlace);
  1624. addressid2 = placeId;
  1625. } else {
  1626. addressid2 =(BigDecimal) placeIdList.get(0).get("placeId");
  1627. amsSaleOrderMaterial.setSaleShippingAddressId((BigDecimal) placeIdList.get(0).get("placeId"));
  1628. }
  1629. }
  1630. String addressids="";
  1631. addressids =addressid1+","+addressid2;
  1632. amsSaleOrderMaterial.setShippingAddressIds(addressids);
  1633. result += amsSaleOrderMaterialMapper.updateByPrimaryKeySelective(amsSaleOrderMaterial);
  1634. // 需要换车
  1635. if (isNewCar != null && (Integer) isNewCar == 0) {
  1636. // 根据车序号得到定向派单表主键
  1637. BigDecimal dispatchId = amsSaleOrderMapper.getDispatchId(saleOrderMaterialId);
  1638. if (dispatchId != null) {
  1639. amsDispatchSaleOrderMapper.deleteByPrimaryKey(dispatchId);
  1640. }
  1641. if (orderId != null) {
  1642. omstruckOrderMapper.deleteByPrimaryKey(orderId);
  1643. }
  1644. if (amsSaleOrderMaterial.getSaleShippingAddressId() != null) {
  1645. // 自动匹配承运商
  1646. List<Map<String, Object>> carrierList = getCarrierByPlace(amsSaleOrderMaterial.getSaleShippingAddressId());
  1647. // 单一承运商才进行匹配
  1648. if (carrierList != null && carrierList.size() == 1) {
  1649. List<Map<String, Object>> list = new ArrayList<>();
  1650. Map<String, Object> map1 = carrierList.get(0);
  1651. // 传入车序号主键和承运商id
  1652. map1.put("saleOrderMaterialId", saleOrderMaterialId);
  1653. map1.put("carrierId", map1.get("value"));
  1654. list.add(map1);
  1655. dispatchToCarrier(list);
  1656. }
  1657. }
  1658. }
  1659. return result;
  1660. }
  1661. /**
  1662. * 展示未匹配承运商的车序号
  1663. * @param mapValue
  1664. * @return
  1665. */
  1666. @Override
  1667. public List<Map<String, Object>> getSteelTruckNoList(Map<String, Object> mapValue) {
  1668. List<Map<String, Object>> resultList = amsSaleOrderMapper.getSteelTruckNoList(mapValue);
  1669. return resultList;
  1670. }
  1671. /**
  1672. * 展示车序号的详情
  1673. * @param saleOrderMaterialId
  1674. * @return
  1675. */
  1676. @Override
  1677. public List<Map<String, Object>> getTruckNoMaterial(BigDecimal saleOrderMaterialId) {
  1678. List<Map<String,Object>> mapList = amsSaleOrderMapper.getTruckNoMaterialAndCarrier(saleOrderMaterialId);
  1679. for (Map<String,Object> map : mapList) {
  1680. BigDecimal placeId = (BigDecimal) map.get("placeId");
  1681. if (placeId != null) {
  1682. List<Map<String, Object>> carrierAndPriceList = getCarrierByPlace(placeId);
  1683. map.put("carrierAndPriceList", carrierAndPriceList);
  1684. }
  1685. }
  1686. return mapList;
  1687. }
  1688. /**
  1689. * 展示已分配承运商但未派车的车序号
  1690. * @param mapValue
  1691. * @return
  1692. */
  1693. @Override
  1694. public List<Map<String, Object>> getNoCarTruckNoList(Map<String, Object> mapValue) {
  1695. List<Map<String, Object>> resultList = amsSaleOrderMapper.getCarrierTruckNoList(mapValue);
  1696. return resultList;
  1697. }
  1698. /**
  1699. * 展示已派车的车序号
  1700. * @param mapValue
  1701. * @return
  1702. */
  1703. @Override
  1704. public List<Map<String, Object>> getHaveCarTruckNoList(Map<String, Object> mapValue) {
  1705. List<Map<String, Object>> resultList = amsSaleOrderMapper.getHaveCarTruckNoList(mapValue);
  1706. return resultList;
  1707. }
  1708. /**
  1709. * 修改销售订单中的物资
  1710. * @param mapValue
  1711. * @return
  1712. */
  1713. @Transactional(rollbackFor = Exception.class)
  1714. @Override
  1715. public int updateAllMaterialInSale(Map<String, Object> mapValue) {
  1716. int result = 0;
  1717. // 得到销售订单主键
  1718. BigDecimal saleOrderId = DataChange.dataToBigDecimal(mapValue.get("saleOrderId"));
  1719. BigDecimal saleOrderMaterialId = DataChange.dataToBigDecimal(mapValue.get("saleOrderMaterialId"));
  1720. BigDecimal orderId = DataChange.dataToBigDecimal(mapValue.get("orderId"));
  1721. // 将车辆改为不可作业状态
  1722. OmstruckOrder omstruckOrder = new OmstruckOrder();
  1723. omstruckOrder.setOrderId(orderId);
  1724. omstruckOrder.setCanWork(new BigDecimal(1));
  1725. omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  1726. // 得到运单中的物资
  1727. List<Map<String, Object>> oldList = omstruckOrderMaterialMapper.getMaterialList(orderId);
  1728. Map<String, Object> toTmsMap = new HashMap<>();
  1729. Map<String, Object> truckNoMap = new HashMap<>();
  1730. truckNoMap.put("saleOrderMaterialId",saleOrderMaterialId);
  1731. toTmsMap.put("orderId", orderId);
  1732. toTmsMap.put("oldMaterialMapList", oldList);
  1733. // 得到所有的物资
  1734. List<Map<String, Object>> mapList = (List<Map<String, Object>>) mapValue.get("mapList");
  1735. /*
  1736. 删除三个物资表数据
  1737. */
  1738. List<AmsSaleTrucknoMaterial> amsSaleTrucknoMaterials = amsSaleTrucknoMaterialMapper.selectByParameters(truckNoMap);
  1739. for (AmsSaleTrucknoMaterial amsSaleTrucknoMaterial : amsSaleTrucknoMaterials) {
  1740. // 销售订单物资子表
  1741. amsSaleMaterialMapper.deleteByPrimaryKey(amsSaleTrucknoMaterial.getMaterialId());
  1742. // 车序号子表
  1743. amsSaleTrucknoMaterialMapper.deleteByPrimaryKey(amsSaleTrucknoMaterial.getTrucknoMaterialId());
  1744. }
  1745. // 运输订单物资子表
  1746. List<OmstruckOrderMaterial> omstruckOrderMaterials = omstruckOrderMaterialMapper.selectByParameters(toTmsMap);
  1747. for (OmstruckOrderMaterial omstruckOrderMaterial : omstruckOrderMaterials) {
  1748. omstruckOrderMaterialMapper.deleteByPrimaryKey(omstruckOrderMaterial.getOrderMaterialId());
  1749. }
  1750. /*
  1751. 重新新增三个表
  1752. */
  1753. for (Map<String, Object> map : mapList) {
  1754. Object saleMaterialId = map.get("saleMaterialId");
  1755. BigDecimal materialId = DataChange.dataToBigDecimal(map.get("materialId"));
  1756. BigDecimal materialNumber = DataChange.dataToBigDecimal(map.get("orderPlanWeight"));
  1757. Object trucknoMaterialId = map.get("trucknoMaterialId");
  1758. BigDecimal isPoundSale = DataChange.dataToBigDecimal(map.get("isPound"));
  1759. Object materialWeight = map.get("materialWeight");
  1760. Object steelMeter = map.get("meterNumber");
  1761. Object easId = map.get("easId");
  1762. Object warehouse = map.get("warehouse");
  1763. // 销售订单分录表
  1764. AmsSaleMaterial amsSaleMaterial = new AmsSaleMaterial();
  1765. // 车序号子表
  1766. AmsSaleTrucknoMaterial amsSaleTrucknoMaterial = new AmsSaleTrucknoMaterial();
  1767. // 运输订单子表
  1768. OmstruckOrderMaterial omstruckOrderMaterial = new OmstruckOrderMaterial();
  1769. // if (saleMaterialId != null) {
  1770. // amsSaleMaterial.setSaleMaterialId(DataChange.dataToBigDecimal(saleMaterialId));
  1771. // amsSaleTrucknoMaterial.setTrucknoMaterialId(DataChange.dataToBigDecimal(trucknoMaterialId));
  1772. // }
  1773. // if (saleMaterialId == null){
  1774. amsSaleMaterial.setSaleMaterialId(amsSaleMaterialMapper.selectMaxId());
  1775. amsSaleTrucknoMaterial.setTrucknoMaterialId(amsSaleTrucknoMaterialMapper.selectMaxId());
  1776. // }
  1777. if (easId != null) {
  1778. amsSaleMaterial.setEasPrimaryId(easId.toString());
  1779. }
  1780. if (warehouse != null) {
  1781. amsSaleMaterial.setSaleWarehouse(warehouse.toString());
  1782. }
  1783. if (steelMeter != null) {
  1784. amsSaleMaterial.setSteelMeter(DataChange.dataToBigDecimal(steelMeter));
  1785. }
  1786. if (materialWeight != null) {
  1787. amsSaleMaterial.setMaterialWeight(DataChange.dataToBigDecimal(materialWeight));
  1788. omstruckOrderMaterial.setOrderMaterialWeight(DataChange.dataToBigDecimal(materialWeight));
  1789. }
  1790. amsSaleMaterial.setSaleOrderId(saleOrderId);
  1791. amsSaleMaterial.setIsPoundSale(isPoundSale);
  1792. amsSaleMaterial.setMaterialId(materialId);
  1793. amsSaleMaterial.setDeleted(new BigDecimal(0));
  1794. amsSaleMaterial.setMaterialNumber(materialNumber);
  1795. amsSaleMaterial.setUpdateTime(new Date());
  1796. result += amsSaleMaterialMapper.insertSelective(amsSaleMaterial);
  1797. // 车序号子表
  1798. amsSaleTrucknoMaterial.setSaleOrderMaterialId(saleOrderMaterialId);
  1799. amsSaleTrucknoMaterial.setMaterialId(amsSaleMaterial.getSaleMaterialId());
  1800. amsSaleTrucknoMaterial.setSaleOrderMaterialNumber(materialNumber);
  1801. amsSaleTrucknoMaterial.setUpdateTime(new Date());
  1802. result += amsSaleTrucknoMaterialMapper.insertSelective(amsSaleTrucknoMaterial);
  1803. // 运输订单子表
  1804. omstruckOrderMaterial.setOrderMaterialId(omstruckOrderMaterialMapper.selectMaxId());
  1805. omstruckOrderMaterial.setOrderId(orderId);
  1806. omstruckOrderMaterial.setMaterialId(materialId);
  1807. omstruckOrderMaterial.setOrderMaterialNumber(materialNumber);
  1808. result += omstruckOrderMaterialMapper.insertSelective(omstruckOrderMaterial);
  1809. }
  1810. // 得到运单中的物资
  1811. List<Map<String, Object>> newList = omstruckOrderMaterialMapper.getMaterialList(orderId);
  1812. toTmsMap.put("newMaterialMapList", newList);
  1813. // 修改实绩结果
  1814. Map<String, Object> updateResult = tmsTruckFeign.update(toTmsMap);
  1815. System.out.println(updateResult);
  1816. return result;
  1817. }
  1818. /**
  1819. * 副产品订单
  1820. * @param map
  1821. * @return
  1822. */
  1823. @Override
  1824. public List<Map<String, Object>> getFuSaleOrderList(Map<String, Object> map) {
  1825. List<Map<String, Object>> resultList = amsSaleOrderMapper.getFuSaleOrderList(map);
  1826. return resultList;
  1827. }
  1828. /**
  1829. * 同步关闭金蝶销售订单
  1830. * @param mapValue
  1831. * @return
  1832. */
  1833. @Override
  1834. public int deleteSaleOrderSame(Map<String, Object> mapValue) {
  1835. int result = 0;
  1836. BigDecimal saleOrderId = DataChange.dataToBigDecimal(mapValue.get("saleOrderId"));
  1837. String reason = (String) mapValue.get("reason");
  1838. String number = (String) mapValue.get("number");
  1839. Map<String,Object> head = new HashMap<>();
  1840. Map<String,Object> input = new HashMap<>();
  1841. // 销售订单号
  1842. input.put("number",number);
  1843. Map<String, Object> totalMap = easDeleteUtil.getTotalMap();
  1844. totalMap.put("input",input);
  1845. // 调用金蝶关闭接口
  1846. String json = JSONUtils.toJSONString(totalMap);
  1847. System.out.println(json);
  1848. Map<String,Object> resultMap = joinFeign.deleteSaleOrderToEas(totalMap);
  1849. System.out.println(resultMap);
  1850. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  1851. amsSaleOrder.setSaleOrderId(saleOrderId);
  1852. amsSaleOrder.setDeleted(new BigDecimal(2));
  1853. amsSaleOrder.setInsertUpdateRemark(reason);
  1854. result += amsSaleOrderMapper.closeOrderNotIn(saleOrderId);
  1855. result += amsSaleOrderMapper.updateByPrimaryKeySelective(amsSaleOrder);
  1856. return result;
  1857. }
  1858. /**
  1859. * 展示反审批的钢材订单
  1860. * @param mapValue
  1861. * @return
  1862. */
  1863. @Override
  1864. public List<Map<String, Object>> getSteelOrderDeletedList(Map<String, Object> mapValue) {
  1865. List<Map<String, Object>> mapList = amsSaleOrderMapper.getSteelOrderDeletedList(mapValue);
  1866. return mapList;
  1867. }
  1868. /**
  1869. * 展示所有状态销售订单列表
  1870. * @param mapValue
  1871. * @return
  1872. */
  1873. @Override
  1874. public List<Map<String, Object>> getAllSteelSaleOrderList(Map<String, Object> mapValue) {
  1875. return amsSaleOrderMapper.getAllSteelSaleOrderList(mapValue);
  1876. }
  1877. /**
  1878. * 修改厂内未装货车辆的运单车牌号
  1879. * @param mapValue
  1880. * @return
  1881. */
  1882. @Override
  1883. public Map<String, Object> updateCapacityNumberInFactory(Map<String, Object> mapValue) throws Exception {
  1884. Object lineSequence = mapValue.get("lineSequence");
  1885. int result = 0;
  1886. //查询输入进来的车牌号是否与原有车牌号一致,如果一致则退出
  1887. BigDecimal oldCapacityId = omstruckOrderMapper.getOldCapacityId(DataChange.dataToBigDecimal(mapValue.get("orderId")));
  1888. if(oldCapacityId.compareTo(DataChange.dataToBigDecimal(mapValue.get("capacityId"))) == 0) {
  1889. mapValue.put("result",1);
  1890. return mapValue;
  1891. }
  1892. Integer isCheckGps = amsSaleOrderMapper.getDispachSwitch();
  1893. String capacityNo = (String) mapValue.get("capacityNo");
  1894. if(isCheckGps!=null && isCheckGps==0){
  1895. Map<String,Object> data = (Map<String,Object>)otmsFeign.getCurrentLocation(capacityNo).getData();
  1896. Map<String,Object> locationResult = (Map<String,Object>)data.get("result");
  1897. int isGPS=amsSaleOrderMapper.isGPS(capacityNo);
  1898. if(isGPS > 0){
  1899. System.out.println(capacityNo+"允许无GPS派车");
  1900. }else if(locationResult==null || locationResult.get("lon")==null || locationResult.get("lat")==null){
  1901. throw new Exception("该车没有GPS定位信息,请联系销售公司物流部,申请是否可以派车。");
  1902. }
  1903. }
  1904. BigDecimal capacityTel = omstruckOrderMapper.getCapacityTel(capacityNo);
  1905. if (capacityTel.compareTo(BigDecimal.ZERO)!=0){
  1906. mapValue.put("capacityTel",capacityTel);
  1907. }else {
  1908. mapValue.put("capacityTel",0);
  1909. }
  1910. if (lineSequence == null || "0".equals(lineSequence.toString()) || "1".equals(lineSequence.toString()) || "2".equals(lineSequence.toString())) {
  1911. String capacityids="";
  1912. Integer capacityid1= (Integer) mapValue.get("capacityIds");
  1913. Integer capacityid2= (Integer) mapValue.get("capacityId");
  1914. if (capacityid1!=null && !("".equals(capacityid1))){
  1915. capacityids=capacityid1+","+capacityid2;
  1916. }
  1917. mapValue.put("capacityids",capacityids);
  1918. //这是修改车牌号
  1919. //将排队信息删掉
  1920. Map<String, Object> isSpellingMap = omstruckOrderMapper.getSteelIsSpelling(DataChange.dataToBigDecimal(mapValue.get("orderId")));
  1921. if(isSpellingMap != null && isSpellingMap.get("listId") != null){
  1922. int isSpelling = DataChange.dataToBigDecimal(isSpellingMap.get("isSpelling")).intValue();
  1923. if(isSpelling == 1 ){
  1924. result += omstruckOrderMapper.deleteSpellingList(isSpellingMap.get("listId"));
  1925. }else{
  1926. result += omstruckOrderMapper.deleteQueueList(isSpellingMap.get("listId"));
  1927. }
  1928. }
  1929. result += amsSaleOrderMapper.updateCapacityNumberInFactory(mapValue);
  1930. //若是接单之后还需要删除实绩且将状态变为4
  1931. //查询运输订单的状态和总实绩ID
  1932. Map<String, Object> orderMesMap = amsSaleOrderMapper.getOrderMes(mapValue);
  1933. BigDecimal resultTotalId = DataChange.dataToBigDecimal(orderMesMap.get("resultTotalId"));
  1934. //删除排队实绩
  1935. if (resultTotalId !=null && !("".equals(resultTotalId))){
  1936. omstruckOrderMapper.deleteQueuingPerformance(resultTotalId);
  1937. }
  1938. if(DataChange.dataToBigDecimal(orderMesMap.get("orderStatus")).intValue() == 5){
  1939. OmstruckOrder omstruckOrder = new OmstruckOrder();
  1940. omstruckOrder.setOrderId(DataChange.dataToBigDecimal(mapValue.get("orderId")));
  1941. omstruckOrder.setOrderStatus(new BigDecimal(4));
  1942. omstruckOrder.setOrderLineSequence(new BigDecimal(0));
  1943. /*omstruckOrder.set*/
  1944. result += omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  1945. result += omstruckOrderMapper.deleteEnResult(resultTotalId);
  1946. result += omstruckOrderMapper.deleteWeightResult(resultTotalId);
  1947. result += omstruckOrderMapper.deleteLoadResult(resultTotalId);
  1948. result += omstruckOrderMapper.deleteLeaveResult(resultTotalId);
  1949. }
  1950. }
  1951. mapValue.put("result",result);
  1952. return mapValue;
  1953. }
  1954. @Override
  1955. public int updateConsigneeTel(Map<String, Object> mapValue) {
  1956. String saleOrderNo= (String) mapValue.get("saleOrderNo");
  1957. Integer saleOrderMaterialId= (Integer) mapValue.get("saleOrderMaterialId");
  1958. String consigneeTel= (String) mapValue.get("consigneeTel");
  1959. int result = 0;
  1960. if (saleOrderNo!=null&&!("".equals(saleOrderNo)) && saleOrderMaterialId!=null && !("".equals(saleOrderMaterialId))){
  1961. BigDecimal id = DataChange.dataToBigDecimal(saleOrderMaterialId);
  1962. if (id!=null&&!("".equals(id))){
  1963. result += amsSaleOrderMapper.updateForTel(id,consigneeTel);
  1964. }
  1965. }
  1966. return result;
  1967. }
  1968. @Override
  1969. public List<Map<String, Object>> getSaleMaterialId(BigDecimal saleOrderMaterialId) {
  1970. return amsSaleOrderMapper.getSaleMaterialId(saleOrderMaterialId);
  1971. }
  1972. /**
  1973. * 展示下发给承运商的车序号和物资
  1974. * @param map
  1975. * @return
  1976. */
  1977. @Override
  1978. public List<Map<String, Object>> getCarrierTruckNoAndMaterialList(Map<String,Object> map) {
  1979. Object carrierSsoId = map.get("carrierSsoId");
  1980. if (carrierSsoId != null && ("".equals(carrierSsoId)) || "null".equals(carrierSsoId) || "undefined".equals(carrierSsoId)) {
  1981. map.replace("carrierSsoId",null);
  1982. }
  1983. List<Map<String,Object>> mapList = amsSaleOrderMapper.getTruckNoAndMaterial(map);
  1984. for (Map<String,Object> mapValue : mapList) {
  1985. BigDecimal placeId = (BigDecimal) mapValue.get("placeId");
  1986. if (placeId != null) {
  1987. List<Map<String, Object>> carrierAndPriceList = getCarrierByPlace(placeId);
  1988. mapValue.put("carrierAndPriceList", carrierAndPriceList);
  1989. }
  1990. }
  1991. return mapList;
  1992. }
  1993. @Override
  1994. public int updateAMSDeleted(BigDecimal closeWlEntryId) {
  1995. return amsSaleOrderMapper.updateAMSDeleted(closeWlEntryId);
  1996. }
  1997. /**
  1998. * 同步关闭金蝶物资分录
  1999. * @param mapValue
  2000. * @return
  2001. */
  2002. @Override
  2003. @Transactional
  2004. public int closeSteelMaterialId(Map<String, Object> mapValue) {
  2005. int result = 0;
  2006. Object orderId = mapValue.get("orderId");
  2007. Integer orderStatus = (Integer) mapValue.get("orderStatus");
  2008. BigDecimal saleOrderMaterialId = DataChange.dataToBigDecimal(mapValue.get("saleOrderMaterialId"));
  2009. List<Map<String, Object>> loadIdList = amsSaleMaterialMapper.findLoadIdList(saleOrderMaterialId);
  2010. List<Map<String, Object>> weightIdList = amsSaleMaterialMapper.findWeightIdList(saleOrderMaterialId);
  2011. String reason = (String) mapValue.get("reason");
  2012. BigDecimal saleMaterialId = DataChange.dataToBigDecimal(mapValue.get("saleMaterialId"));
  2013. // 如果还未派车
  2014. if (orderId == null) {
  2015. // 订单子表设为关闭状态
  2016. AmsSaleMaterial amsSaleMaterial = new AmsSaleMaterial();
  2017. amsSaleMaterial.setSaleMaterialId(saleMaterialId);
  2018. amsSaleMaterial.setDeleted(new BigDecimal(0));
  2019. amsSaleMaterial.setInsertUpdateRemark(reason);
  2020. result += amsSaleMaterialMapper.updateByPrimaryKeySelective(amsSaleMaterial);
  2021. return result;
  2022. }
  2023. orderStatus = omstruckOrderMapper.getOrderStatus(DataChange.dataToBigDecimal(orderId));
  2024. // 订单子表设为关闭状态
  2025. AmsSaleMaterial amsSaleMaterial = new AmsSaleMaterial();
  2026. amsSaleMaterial.setSaleMaterialId(saleMaterialId);
  2027. amsSaleMaterial.setDeleted(new BigDecimal(0));
  2028. amsSaleMaterial.setInsertUpdateRemark(reason);
  2029. // 已派车
  2030. if ((loadIdList == null || loadIdList.size() == 0) && orderStatus == 5) {
  2031. return result;
  2032. }
  2033. //判断关闭分录是否为最后一拼
  2034. int asmMaterialCount = amsSaleMaterialMapper.getSaleMaterialDelete(saleOrderMaterialId);
  2035. if (asmMaterialCount > 1 && orderStatus == 5) {
  2036. // 删除实绩表
  2037. Map<String, Object> loadMap = loadIdList.get(0);
  2038. Map<String, Object> weightMap = weightIdList.get(0);
  2039. BigDecimal loadId = (BigDecimal) loadMap.get("loadId");
  2040. BigDecimal weightId = (BigDecimal) weightMap.get("weightId");
  2041. result += amsSaleMaterialMapper.deleteLoadResult(loadId);
  2042. result += amsSaleMaterialMapper.deleteWeightResult(weightId);
  2043. result += amsSaleMaterialMapper.deleteWmspOutResult(mapValue);
  2044. }else if(asmMaterialCount <= 1){
  2045. //关闭运输订单
  2046. OmstruckOrder omstruckOrder = new OmstruckOrder();
  2047. omstruckOrder.setOrderId(DataChange.dataToBigDecimal(orderId));
  2048. //如果是单拼或者只剩一条分录没有关闭了则将状态设为7
  2049. omstruckOrder.setOrderStatus(new BigDecimal(7));
  2050. omstruckOrder.setUpdateTime(new Date());
  2051. omstruckOrder.setInsertUpdateRemark("关闭分录,同步关闭运输订单");
  2052. result += omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  2053. }
  2054. result += amsSaleMaterialMapper.updateByPrimaryKeySelective(amsSaleMaterial);
  2055. result += amsSaleMaterialMapper.updateOrderMaterialToClose(mapValue);
  2056. return result;
  2057. }
  2058. /**
  2059. * 展示已审核化产焦炭销售订单列表
  2060. * @param mapValue
  2061. * @return
  2062. */
  2063. @Override
  2064. public List<Map<String, Object>> getSaleCokeOrder(Map<String, Object> mapValue) {
  2065. List<Map<String, Object>> resultList = amsSaleOrderMapper.getSaleCokeOrder(mapValue);
  2066. return resultList;
  2067. }
  2068. /**
  2069. * 反关闭金蝶单个分录
  2070. * @param saleMaterialId
  2071. * @return
  2072. */
  2073. @Override
  2074. public int adverseCloseSaleMaterial(BigDecimal saleMaterialId) {
  2075. Map<String,Object> head = new HashMap<>();
  2076. Map<String,Object> input = new HashMap<>();
  2077. // 0:代表不关闭整单
  2078. String wholeOrder = "0";
  2079. // unClose : 代表反关闭
  2080. String status = "unClose";
  2081. AmsSaleMaterial amsSaleMaterial = amsSaleMaterialMapper.selectByPrimaryKey(saleMaterialId);
  2082. int result = amsSaleMaterialMapper.adverseCloseSaleMaterial(saleMaterialId);
  2083. AmsSaleOrder amsSaleOrder = amsSaleOrderMapper.selectByPrimaryKey(amsSaleMaterial.getSaleOrderId());
  2084. // 根据分录id查询运单id,物资id,总实绩id
  2085. Map<String,Object> saleMaterialMap = amsSaleOrderMapper.getSaleMaterialMessage(saleMaterialId);
  2086. BigDecimal orderId = (BigDecimal) saleMaterialMap.get("orderId");
  2087. BigDecimal orderStatus = (BigDecimal) saleMaterialMap.get("orderStatus");
  2088. //查询订单字表条数
  2089. int orderMaterialNum = omstruckOrderMapper.getOrderMaterialNum(orderId);
  2090. //查询计量实绩条数
  2091. int weightResultNum = omstruckOrderMapper.getWeightResultNum(orderId);
  2092. if (orderId != null && orderStatus.intValue() == 5 && orderMaterialNum != weightResultNum) {
  2093. BigDecimal resultTotalId = (BigDecimal) saleMaterialMap.get("resultTotalId");
  2094. BigDecimal materialId = (BigDecimal) saleMaterialMap.get("materialId");
  2095. // 根据总实绩id查询订单中的最大路段顺序号
  2096. // 得到皮重顺序号
  2097. int tareNum = (weightResultNum + 1) * 3 - 1;
  2098. // 得到装货顺序号
  2099. int loadNum = (weightResultNum + 1) * 3;
  2100. // 得到毛重顺序号
  2101. int grossNum = (weightResultNum + 1) * 3 + 1;
  2102. // 装货实绩
  2103. TmstruckLoadResult tmstruckLoadResult = new TmstruckLoadResult();
  2104. TmstruckWeightResult tmstruckWeightResult = new TmstruckWeightResult();
  2105. tmstruckLoadResult.setResultId(tmstruckLoadResultMapper.selectMaxId());
  2106. tmstruckLoadResult.setResultTotalId(resultTotalId);
  2107. tmstruckLoadResult.setSegmentSqe(new BigDecimal(loadNum));
  2108. result += tmstruckLoadResultMapper.insertSelective(tmstruckLoadResult);
  2109. // 计量实绩
  2110. tmstruckWeightResult.setWeightTaskResultId(tmstruckWeightResultMapper.selectMaxId());
  2111. tmstruckWeightResult.setResultTotalId(resultTotalId);
  2112. tmstruckWeightResult.setResultTarePlaceId(new BigDecimal(10));
  2113. tmstruckWeightResult.setResultGrossPlaceId(new BigDecimal(2));
  2114. tmstruckWeightResult.setGrossSegmentSqe(new BigDecimal(grossNum));
  2115. tmstruckWeightResult.setTareSegmentSqe(new BigDecimal(tareNum));
  2116. result += tmstruckWeightResultMapper.insertSelective(tmstruckWeightResult);
  2117. // 出库子表
  2118. BigDecimal outBoundId = (BigDecimal) saleMaterialMap.get("outBoundId");
  2119. BigDecimal materialNumber = (BigDecimal) saleMaterialMap.get("materialNumber");
  2120. if (outBoundId != null) {
  2121. BigDecimal resultMaterialId = wmspOutboundResultMaterialMapper.getSeqNumber("seq__WMSP_OUTBOUND_RESUL_TMATRIAL");
  2122. WmspOutboundResultMaterial wmspOutboundResultMaterial = new WmspOutboundResultMaterial();
  2123. wmspOutboundResultMaterial.setResultMaterialId(resultMaterialId);
  2124. wmspOutboundResultMaterial.setOutboundResultId(outBoundId);
  2125. wmspOutboundResultMaterial.setMaterialId(materialId);
  2126. wmspOutboundResultMaterial.setMaterialNumber(materialNumber);
  2127. wmspOutboundResultMaterial.setInsertTime(new Date());
  2128. wmspOutboundResultMaterial.setInsertUsername("admin");
  2129. wmspOutboundResultMaterial.setStatus(new BigDecimal(1));
  2130. result += wmspOutboundResultMaterialMapper.insertSelective(wmspOutboundResultMaterial);
  2131. }
  2132. }
  2133. //去掉取消装货
  2134. result += omstruckOrderMaterialMapper.updateOmsMaterial(saleMaterialMap);
  2135. if (orderId != null && orderStatus.intValue() == 7) {
  2136. //如果订单被关闭,那么还原
  2137. //判断下面有没有实绩
  2138. int resultCount = omstruckOrderMapper.getResultCount(orderId);
  2139. OmstruckOrder omstruckOrder = new OmstruckOrder();
  2140. if (resultCount == 0) {
  2141. omstruckOrder.setOrderId(orderId);
  2142. omstruckOrder.setOrderStatus(new BigDecimal(4));
  2143. omstruckOrder.setInsertUpdateRemark("反关闭分录,运单同步开启");
  2144. omstruckOrder.setUpdateTime(new Date());
  2145. omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  2146. }else{
  2147. omstruckOrder.setOrderId(orderId);
  2148. omstruckOrder.setOrderStatus(new BigDecimal(5));
  2149. omstruckOrder.setInsertUpdateRemark("反关闭分录,运单同步开启");
  2150. omstruckOrder.setUpdateTime(new Date());
  2151. omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  2152. }
  2153. }
  2154. // 设置反关闭分录id
  2155. head.put("unCloseEntryId",amsSaleMaterial.getEasPrimaryId());
  2156. // 设置是否整单
  2157. head.put("wholeOrder",wholeOrder);
  2158. // 设置销售订单号
  2159. head.put("number",amsSaleOrder.getSaleNumber());
  2160. // 设置状态:unClose,反关闭;close,关闭
  2161. head.put("status",status);
  2162. input.put("head",head);
  2163. // 测试
  2164. Map<String, Object> totalMap = easUtil.getTotalMap();
  2165. // 正式
  2166. // Map<String, Object> totalMap = easDeleteUtil.getTotalMap();
  2167. input.put("head",head);
  2168. totalMap.put("input",input);
  2169. // 调用金蝶关闭接口
  2170. String json = JSONUtils.toJSONString(totalMap);
  2171. System.out.println(json);
  2172. Map<String,Object> resultMap = joinFeign.deleteSaleOrderToEas(totalMap);
  2173. System.out.println(resultMap);
  2174. return result;
  2175. }
  2176. /**
  2177. * 反关闭金蝶整个销售订单
  2178. * @param saleOrderId
  2179. * @return
  2180. */
  2181. @Override
  2182. public int adverseCloseSaleOrder(BigDecimal saleOrderId) {
  2183. Map<String,Object> head = new HashMap<>();
  2184. Map<String,Object> input = new HashMap<>();
  2185. // 0:代表不关闭整单
  2186. String wholeOrder = "1";
  2187. // unClose : 代表反关闭
  2188. String status = "unClose";
  2189. AmsSaleOrder amsSaleOrder = amsSaleOrderMapper.selectByPrimaryKey(saleOrderId);
  2190. amsSaleOrder.setDeleted(new BigDecimal(0));
  2191. // 开启所有的分录
  2192. int result = amsSaleMaterialMapper.openAllSaleMaterial(amsSaleOrder.getSaleOrderId());
  2193. result += amsSaleOrderMapper.updateByPrimaryKeySelective(amsSaleOrder);
  2194. // 设置是否整单
  2195. head.put("wholeOrder",wholeOrder);
  2196. // 设置销售订单号
  2197. head.put("number",amsSaleOrder.getSaleNumber());
  2198. // 设置状态:unClose,反关闭;close,关闭
  2199. head.put("status",status);
  2200. input.put("head",head);
  2201. // 测试
  2202. Map<String, Object> totalMap = easUtil.getTotalMap();
  2203. // 正式
  2204. // Map<String, Object> totalMap = easDeleteUtil.getTotalMap();
  2205. input.put("head",head);
  2206. totalMap.put("input",input);
  2207. // 调用金蝶关闭接口
  2208. String json = JSONUtils.toJSONString(totalMap);
  2209. System.out.println(json);
  2210. Map<String,Object> resultMap = joinFeign.deleteSaleOrderToEas(totalMap);
  2211. System.out.println(resultMap);
  2212. return result;
  2213. }
  2214. @Override
  2215. public List<Map<String, Object>> getKucunList(Map<String, Object> map) {
  2216. return amsSaleOrderMapper.getKucunList(map);
  2217. }
  2218. //反关闭
  2219. @Override
  2220. public int reverseCloseOrder(Map<String, Object> map) {
  2221. Integer isOpenEas = (Integer) map.get("isOpenEas");
  2222. String operateName = (String) map.get("operateName");
  2223. int result = 0;
  2224. // 运输订单id
  2225. BigDecimal orderId = DataChange.dataToBigDecimal(map.get("orderId"));
  2226. // 车序号id
  2227. BigDecimal saleOrderMaterialId = DataChange.dataToBigDecimal(map.get("saleOrderMaterialId"));
  2228. Map<String,Object> head = new HashMap<>();
  2229. Map<String,Object> input = new HashMap<>();
  2230. // 0:代表不关闭整单
  2231. String wholeOrder = "0";
  2232. // unClose : 代表反关闭
  2233. String status = "unClose";
  2234. if( orderId != null && orderId.intValue() != 0){
  2235. //根据订单id查询下面的实绩个数
  2236. int resultCount = amsSaleMaterialMapper.getOrderResults(orderId);
  2237. OmstruckOrder omstruckOrder = new OmstruckOrder();
  2238. omstruckOrder.setOrderId(orderId);
  2239. if(resultCount == 0){
  2240. omstruckOrder.setOrderStatus(new BigDecimal(4));
  2241. }else{
  2242. omstruckOrder.setOrderStatus(new BigDecimal(5));
  2243. }
  2244. if(operateName != null){
  2245. omstruckOrder.setOptionerCode(operateName);
  2246. }
  2247. omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  2248. // 根据车序号主键修改子表
  2249. amsSaleMaterialMapper.updateSaleMaterial(saleOrderMaterialId);
  2250. //查询分录ID,修改金蝶
  2251. List<Map<String,Object>> saleMaterialIdList = amsSaleOrderMapper.getSaleMaterialId(saleOrderMaterialId);
  2252. for(Map<String,Object> easMap:saleMaterialIdList){
  2253. // 设置反关闭分录id
  2254. head.put("unCloseEntryId",easMap.get("closeEntryId"));
  2255. // 设置是否整单
  2256. head.put("wholeOrder",wholeOrder);
  2257. // 设置销售订单号
  2258. head.put("number",map.get("saleNumber"));
  2259. // 设置状态:unClose,反关闭;close,关闭
  2260. head.put("status",status);
  2261. input.put("head",head);
  2262. Map<String, Object> totalMap = easUtil.getTotalMap();
  2263. input.put("head",head);
  2264. totalMap.put("input",input);
  2265. // 调用金蝶关闭接口
  2266. String json = JSONUtils.toJSONString(totalMap);
  2267. System.out.println(json);
  2268. Map<String,Object> resultMap = joinFeign.deleteSaleOrderToEas(totalMap);
  2269. System.out.println(resultMap);
  2270. }
  2271. return 0;
  2272. }
  2273. return 1;
  2274. }
  2275. @Override
  2276. public int getSaleOrderStatus(String saleNumber) {
  2277. int result = 0;
  2278. Map<String,Object> input = new HashMap<>();
  2279. // 销售订单号
  2280. input.put("number",saleNumber);
  2281. Map<String, Object> totalMap = easSaleOrderStatusUtil.getTotalMap();
  2282. totalMap.put("input",input);
  2283. // 调用金蝶关闭接口
  2284. String json = JSONUtils.toJSONString(totalMap);
  2285. System.out.println(json);
  2286. Map<String,Object> resultMap = joinFeign.deleteSaleOrderToEas(totalMap);
  2287. System.out.println(resultMap);
  2288. String outPutMap = (String) resultMap.get("output");
  2289. JSONObject jsonObject = JSON.parseObject(outPutMap);
  2290. if(jsonObject != null){
  2291. result = DataChange.dataToBigDecimal(jsonObject.get("NumberStatus")).intValue();
  2292. }
  2293. if(result == 7){
  2294. //如果为7则更新
  2295. amsSaleOrderMapper.updateSaleOrderStatus(saleNumber);
  2296. }
  2297. return result;
  2298. }
  2299. @Override
  2300. public int adverseCloseSaleMaterialByEas(BigDecimal saleMaterialId) {
  2301. AmsSaleMaterial amsSaleMaterial = amsSaleMaterialMapper.selectByPrimaryKey(saleMaterialId);
  2302. int result = amsSaleMaterialMapper.adverseCloseSaleMaterial(saleMaterialId);
  2303. AmsSaleOrder amsSaleOrder = amsSaleOrderMapper.selectByPrimaryKey(amsSaleMaterial.getSaleOrderId());
  2304. // 根据分录id查询运单id,物资id,总实绩id
  2305. Map<String,Object> saleMaterialMap = amsSaleOrderMapper.getSaleMaterialMessage(saleMaterialId);
  2306. BigDecimal orderId = (BigDecimal) saleMaterialMap.get("orderId");
  2307. BigDecimal orderStatus = (BigDecimal) saleMaterialMap.get("orderStatus");
  2308. //查询订单字表条数
  2309. int orderMaterialNum = omstruckOrderMapper.getOrderMaterialNum(orderId);
  2310. //查询计量实绩条数
  2311. int weightResultNum = omstruckOrderMapper.getWeightResultNum(orderId);
  2312. if (orderId != null && orderStatus.intValue() == 5 && orderMaterialNum != weightResultNum) {
  2313. BigDecimal resultTotalId = (BigDecimal) saleMaterialMap.get("resultTotalId");
  2314. BigDecimal materialId = (BigDecimal) saleMaterialMap.get("materialId");
  2315. // 根据总实绩id查询订单中的最大路段顺序号
  2316. // 得到皮重顺序号
  2317. int tareNum = (weightResultNum + 1) * 3 - 1;
  2318. // 得到装货顺序号
  2319. int loadNum = (weightResultNum + 1) * 3;
  2320. // 得到毛重顺序号
  2321. int grossNum = (weightResultNum + 1) * 3 + 1;
  2322. // 装货实绩
  2323. TmstruckLoadResult tmstruckLoadResult = new TmstruckLoadResult();
  2324. TmstruckWeightResult tmstruckWeightResult = new TmstruckWeightResult();
  2325. tmstruckLoadResult.setResultId(tmstruckLoadResultMapper.selectMaxId());
  2326. tmstruckLoadResult.setResultTotalId(resultTotalId);
  2327. tmstruckLoadResult.setSegmentSqe(new BigDecimal(loadNum));
  2328. result += tmstruckLoadResultMapper.insertSelective(tmstruckLoadResult);
  2329. // 计量实绩
  2330. tmstruckWeightResult.setWeightTaskResultId(tmstruckWeightResultMapper.selectMaxId());
  2331. tmstruckWeightResult.setResultTotalId(resultTotalId);
  2332. tmstruckWeightResult.setResultTarePlaceId(new BigDecimal(10));
  2333. tmstruckWeightResult.setResultGrossPlaceId(new BigDecimal(2));
  2334. tmstruckWeightResult.setGrossSegmentSqe(new BigDecimal(grossNum));
  2335. tmstruckWeightResult.setTareSegmentSqe(new BigDecimal(tareNum));
  2336. result += tmstruckWeightResultMapper.insertSelective(tmstruckWeightResult);
  2337. // 出库子表
  2338. BigDecimal outBoundId = (BigDecimal) saleMaterialMap.get("outBoundId");
  2339. BigDecimal materialNumber = (BigDecimal) saleMaterialMap.get("materialNumber");
  2340. if (outBoundId != null) {
  2341. BigDecimal resultMaterialId = wmspOutboundResultMaterialMapper.getSeqNumber("seq__WMSP_OUTBOUND_RESUL_TMATRIAL");
  2342. WmspOutboundResultMaterial wmspOutboundResultMaterial = new WmspOutboundResultMaterial();
  2343. wmspOutboundResultMaterial.setResultMaterialId(resultMaterialId);
  2344. wmspOutboundResultMaterial.setOutboundResultId(outBoundId);
  2345. wmspOutboundResultMaterial.setMaterialId(materialId);
  2346. wmspOutboundResultMaterial.setMaterialNumber(materialNumber);
  2347. wmspOutboundResultMaterial.setInsertTime(new Date());
  2348. wmspOutboundResultMaterial.setInsertUsername("admin");
  2349. wmspOutboundResultMaterial.setStatus(new BigDecimal(1));
  2350. result += wmspOutboundResultMaterialMapper.insertSelective(wmspOutboundResultMaterial);
  2351. }
  2352. }
  2353. //去掉取消装货
  2354. result += omstruckOrderMaterialMapper.updateOmsMaterial(saleMaterialMap);
  2355. if (orderId != null && orderStatus.intValue() == 7) {
  2356. //如果订单被关闭,那么还原
  2357. //判断下面有没有实绩
  2358. int resultCount = omstruckOrderMapper.getResultCount(orderId);
  2359. OmstruckOrder omstruckOrder = new OmstruckOrder();
  2360. if (resultCount == 0) {
  2361. omstruckOrder.setOrderId(orderId);
  2362. omstruckOrder.setOrderStatus(new BigDecimal(4));
  2363. omstruckOrder.setInsertUpdateRemark("反关闭分录,运单同步开启");
  2364. omstruckOrder.setUpdateTime(new Date());
  2365. omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  2366. }else{
  2367. omstruckOrder.setOrderId(orderId);
  2368. omstruckOrder.setOrderStatus(new BigDecimal(5));
  2369. omstruckOrder.setInsertUpdateRemark("反关闭分录,运单同步开启");
  2370. omstruckOrder.setUpdateTime(new Date());
  2371. omstruckOrderMapper.updateByPrimaryKeySelective(omstruckOrder);
  2372. }
  2373. }
  2374. return result;
  2375. }
  2376. @Override
  2377. public List<String> getEasPrimaryIds(Map<String, Object> map) {
  2378. List<String> easPrimaryIds = amsSaleOrderMapper.getEasPrimaryIds(map);
  2379. String easPrimaryList = "";
  2380. for (String easPrimaryId :easPrimaryIds) {
  2381. easPrimaryList = easPrimaryList + '\'' + easPrimaryId + '\'' + ',';
  2382. }
  2383. easPrimaryList = easPrimaryList.substring(0,easPrimaryList.length() - 1);
  2384. ArrayList<String> easPrimaryList1 = new ArrayList<>();
  2385. easPrimaryList1.add(easPrimaryList);
  2386. System.out.println(easPrimaryList);
  2387. Map<String,Object> totalMap = easFluMakeDateUtil.getTotalMap();
  2388. Map<String, Object> input = new HashMap<>();
  2389. input.put("defineSqlNumber","defineXSCKTime");
  2390. input.put("defineSqlparams",easPrimaryList1);
  2391. totalMap.put("input",input);
  2392. totalMap.put("outerSystem","DG");
  2393. JSONObject jsonObject = new JSONObject(totalMap);
  2394. System.out.println(jsonObject);
  2395. Map<String,Object> resultMap = joinFeign.deleteSaleOrderToEas(totalMap);
  2396. String outPut = (String) resultMap.get("output");
  2397. JSONObject outputjson = JSONObject.parseObject(outPut);
  2398. Map<String,Object> outputMap = (Map<String,Object>) outputjson;
  2399. List<Map<String,Object>> rowSetList = (List<Map<String,Object>>) outputMap.get("rowset");
  2400. for (Map<String,Object> rowSet : rowSetList) {
  2401. Map<String, Object> easMap = new HashMap<>();
  2402. System.out.println(rowSet);
  2403. String easprimaryIdMakeDate = (String) rowSet.get("FCREATETIME");
  2404. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  2405. Date easprimaryIdMakeDate1 = null;
  2406. try {
  2407. easprimaryIdMakeDate1 = sdf.parse(easprimaryIdMakeDate);
  2408. } catch (ParseException e) {
  2409. e.printStackTrace();
  2410. }
  2411. rowSet.put("easprimaryIdMakeDate",easprimaryIdMakeDate1);
  2412. amsSaleMaterialMapper.updateSaleMaterialMakeDate(rowSet);
  2413. }
  2414. return easPrimaryIds;
  2415. }
  2416. @Override
  2417. @Transactional(rollbackFor = Exception.class)
  2418. public synchronized int addSteelSaleOrderLoading(Map<String, Object> mapValue) throws Exception {
  2419. List<Map<String,Object>> mapList = (List<Map<String, Object>>) mapValue.get("mapList");
  2420. //如果前端传输过来的销售订单id不是空,则改变为已上传
  2421. if (mapValue.get("saleOrderId") != null) {
  2422. //先判断该销售订单有没有被上传,如果传了则不允许重复上传
  2423. int count = amsSaleOrderMaterialMapper.selectSaleOrderIdIsUpload(DataChange.dataToBigDecimal(mapValue.get("saleOrderId")));
  2424. if(count != 0) {
  2425. return 0;
  2426. }
  2427. amsSaleOrderMapper.updateOldSaleOrderUpload(DataChange.dataToBigDecimal(mapValue.get("saleOrderId")));
  2428. }
  2429. // 得到发货单位
  2430. BigDecimal shipperId = DataChange.dataToBigDecimal(mapValue.get("shipperId"));
  2431. // 收货单位
  2432. BigDecimal receiveId = DataChange.dataToBigDecimal(mapValue.get("receiveId"));
  2433. // 是否自提
  2434. String isSelfMention = (String) mapValue.get("isSelfMention");
  2435. // 备注
  2436. String saleRemark = (String) mapValue.get("saleRemark");
  2437. // 收款客户
  2438. String saleOrderReceiveCustomer = (String) mapValue.get("saleOrderReceiveCustomer");
  2439. // 业务员
  2440. BigDecimal salerId = DataChange.dataToBigDecimal(mapValue.get("salerId"));
  2441. BigDecimal saleOrderId = amsSaleOrderMapper.selectMaxId();
  2442. int result = 0;
  2443. // 销售订单
  2444. AmsSaleOrder amsSaleOrder = new AmsSaleOrder();
  2445. amsSaleOrder.setReceiveId(receiveId);
  2446. amsSaleOrder.setSaleRemark(saleRemark == null ? "":saleRemark);
  2447. amsSaleOrder.setShipperId(shipperId);
  2448. amsSaleOrder.setSaleOrderIsselfMention(isSelfMention);
  2449. amsSaleOrder.setSaleOrderId(saleOrderId);
  2450. amsSaleOrder.setSalerId(salerId);
  2451. // 设置钢材订单
  2452. amsSaleOrder.setSaleType(new BigDecimal(1));
  2453. amsSaleOrder.setSaleNumber(DataChange.generateEightDigitsNumber("WXSDD",saleOrderId.intValue(),"-"));
  2454. amsSaleOrder.setInsertTime(new Date());
  2455. amsSaleOrder.setInsertUpdateRemark("物流新增继续装销售订单");
  2456. amsSaleOrder.setInsertUsername("物流");
  2457. amsSaleOrder.setUpdateTime(new Date());
  2458. amsSaleOrder.setDeleted(new BigDecimal(0));
  2459. amsSaleOrder.setSaleOrderStatus(new BigDecimal(0));
  2460. // 税率默认13%
  2461. amsSaleOrder.setSaleOrderTax("13%");
  2462. // 含税单价某人4000
  2463. amsSaleOrder.setSaleUnitPrice(new BigDecimal(4000));
  2464. // 收款客户
  2465. amsSaleOrder.setSaleOrderReceiveCustomer(saleOrderReceiveCustomer);
  2466. // 销售订单物资表
  2467. AmsSaleMaterial amsSaleMaterial = new AmsSaleMaterial();
  2468. // 车序号物资表
  2469. AmsSaleTrucknoMaterial amsSaleTrucknoMaterial = new AmsSaleTrucknoMaterial();
  2470. // 遍历每一行
  2471. for (Map<String, Object> map : mapList) {
  2472. /*
  2473. 车序号表
  2474. */
  2475. // 得到车序号
  2476. BigDecimal truckNo = DataChange.dataToBigDecimal(map.get("truckNo"));
  2477. Map<String,Object> saleMap = new HashMap<>();
  2478. saleMap.put("saleOrderId",saleOrderId);
  2479. saleMap.put("saleOrderMaterialTruckNo",truckNo);
  2480. // 检测销售订单下的车序号是否已存在
  2481. List<AmsSaleOrderMaterial> amsSaleOrderMaterials = amsSaleOrderMaterialMapper.selectByParameters(saleMap);
  2482. // 车序号表
  2483. AmsSaleOrderMaterial amsSaleOrderMaterial = new AmsSaleOrderMaterial();
  2484. if (amsSaleOrderMaterials == null || amsSaleOrderMaterials.size() == 0) {
  2485. // 车序号主键
  2486. BigDecimal saleOrderMaterialId = amsSaleOrderMaterialMapper.selectMaxId();
  2487. BigDecimal shippingAddressId = DataChange.dataToBigDecimal(map.get("shipperAddressId"));
  2488. // 车号备注
  2489. String truckRemark = (String) (map.get("truckRemark"));
  2490. String place = (String) (map.get("place"));
  2491. amsSaleOrderMaterial.setSaleShippingAddressId(DataChange.dataToBigDecimal(map.get("placeId")));
  2492. if (amsSaleOrderMaterial.getSaleShippingAddressId() != null && isSelfMention.equals("否") && DataChange.dataToBigDecimal(map.get("carrierId")).intValue() == 0) {
  2493. // 自动匹配承运商
  2494. List<Map<String, Object>> carrierList = getCarrierByAddress(amsSaleOrderMaterial.getSaleShippingAddressId());
  2495. BigDecimal carrierCount = null;
  2496. if(place != null && !"null".equals(place)){
  2497. carrierCount = amsSaleOrderMapper.getMoreCarrier(place);
  2498. }
  2499. //根据收货地址id查询备注,判断是否需要匹配承运商
  2500. String addressRemark = amsSaleOrderMaterialMapper.getAddressRemark(shippingAddressId);
  2501. // 单一承运商才进行匹配
  2502. if (carrierList != null && carrierList.size() == 1 && carrierList.get(0) != null && carrierCount.intValue() == 0 && addressRemark == null) {
  2503. List<Map<String, Object>> list = new ArrayList<>();
  2504. Map<String, Object> map1 = carrierList.get(0);
  2505. // 传入车序号主键和承运商id
  2506. map1.put("saleOrderMaterialId", saleOrderMaterialId);
  2507. list.add(map1);
  2508. dispatchToCarrier(list);
  2509. }
  2510. }
  2511. if (isSelfMention.equals("是")) {
  2512. // 根据收货单位id查询出收货单位名称
  2513. String consigneeName = amsSaleOrderMapper.selectConsigneeName(receiveId);
  2514. // 根据收货单位名称查询承运商id
  2515. BigDecimal carrierId = amsSaleOrderMapper.selectCarrierId(consigneeName);
  2516. List<Map<String, Object>> list = new ArrayList<>();
  2517. Map<String,Object> map1 = new HashMap<>();
  2518. // 传入车序号主键和承运商id
  2519. if (carrierId != null) {
  2520. map1.put("saleOrderMaterialId", saleOrderMaterialId);
  2521. map1.put("carrierId", carrierId);
  2522. list.add(map1);
  2523. dispatchToCarrier(list);
  2524. }
  2525. }
  2526. if (isSelfMention.equals("否") && DataChange.dataToBigDecimal(map.get("carrierId")).intValue() != 0) {
  2527. //说明有承运商
  2528. List<Map<String, Object>> list = new ArrayList<>();
  2529. Map<String, Object> carrierMap = new HashMap<>();
  2530. carrierMap.put("carrierId",map.get("carrierId"));
  2531. carrierMap.put("saleOrderMaterialId",saleOrderMaterialId);
  2532. list.add(carrierMap);
  2533. dispatchToCarrier(list);
  2534. }
  2535. // 收货方姓名
  2536. String consigneeName = String.valueOf(map.get("saleOrderConsignee"));
  2537. // 收货方电话
  2538. String consigneeTel = String.valueOf(map.get("saleOrderConsigneeTel"));
  2539. // 截止日期
  2540. String dateOfReceiptStr = String.valueOf(map.get("saleDateOfReceipt"));
  2541. Date dateOfReceipt = null;
  2542. if (!"null".equals(dateOfReceiptStr) && !"undefined".equals(dateOfReceiptStr)) {
  2543. dateOfReceipt = new Date(Long.valueOf(dateOfReceiptStr));
  2544. }
  2545. amsSaleOrderMaterial.setSaleOrderMaterialId(saleOrderMaterialId);
  2546. amsSaleOrderMaterial.setSaleOrderId(saleOrderId);
  2547. amsSaleOrderMaterial.setTruckRemark(truckRemark);
  2548. amsSaleOrderMaterial.setSaleOrderMaterialTruckNo(truckNo);
  2549. if(map.get("orderNo") != null) {
  2550. amsSaleOrderMaterial.setPreviousOrderNumber((String) map.get("orderNo"));
  2551. }
  2552. if (consigneeName != null && !consigneeName.equals("null")) {
  2553. amsSaleOrderMaterial.setSaleOrderConsignee(consigneeName);
  2554. }
  2555. if (consigneeTel != null && !consigneeTel.equals("null")) {
  2556. amsSaleOrderMaterial.setSaleOrderConsigneeTel(consigneeTel);
  2557. }
  2558. amsSaleOrderMaterial.setSaleDateOfReceipt(dateOfReceipt);
  2559. amsSaleOrderMaterial.setInsertTime(new Date());
  2560. amsSaleOrderMaterial.setUpdateTime(new Date());
  2561. amsSaleOrderMaterial.setInsertUpdateRemark("物流新增");
  2562. result += amsSaleOrderMaterialMapper.insertSelective(amsSaleOrderMaterial);
  2563. }
  2564. else {
  2565. amsSaleOrderMaterial = amsSaleOrderMaterials.get(0);
  2566. }
  2567. /*
  2568. 销售订单物资表
  2569. */
  2570. // 物资
  2571. BigDecimal materialId = DataChange.dataToBigDecimal(map.get("materialId"));
  2572. Integer materialCount = amsSaleMaterialMapper.getMaterialCount(materialId);
  2573. RmsMaterial rmsMaterial = new RmsMaterial();
  2574. rmsMaterial.setMaterialId(materialId);
  2575. if (materialCount == null) {
  2576. materialCount = new Integer(0);
  2577. }
  2578. rmsMaterial.setMaterialCount(new BigDecimal(materialCount + 1));
  2579. rmsMaterialMapper.updateByPrimaryKeySelective(rmsMaterial);
  2580. // 物资件数
  2581. BigDecimal materialNumber = DataChange.dataToBigDecimal(map.get("materialNumber"));
  2582. // 物资名称
  2583. Object materialName = map.get("materialName");
  2584. // 钢材米数
  2585. BigDecimal steelMeters = DataChange.dataToBigDecimal(map.get("steelMeters"));
  2586. // 判断物资是否是盘螺或盘元/盘圆
  2587. if (materialName != null && (materialName.toString().contains("盘螺") || materialName.toString().contains("盘元") || materialName.toString().contains("盘圆"))) {
  2588. amsSaleMaterial.setSteelMeter(null);
  2589. }
  2590. else {
  2591. amsSaleMaterial.setSteelMeter(steelMeters);
  2592. }
  2593. // 是否磅重销售(0:磅重;1:理重)
  2594. BigDecimal isPoundSale = DataChange.dataToBigDecimal(map.get("isPoundSale"));
  2595. // 销售订单物资表主键
  2596. BigDecimal saleMaterialId = amsSaleMaterialMapper.selectMaxId();
  2597. amsSaleMaterial.setSaleMaterialId(saleMaterialId);
  2598. amsSaleMaterial.setSaleOrderId(saleOrderId);
  2599. amsSaleMaterial.setMaterialId(materialId);
  2600. amsSaleMaterial.setMaterialNumber(materialNumber);
  2601. amsSaleMaterial.setMaterialPlanNumber(materialNumber);
  2602. amsSaleMaterial.setInsertTime(new Date());
  2603. amsSaleMaterial.setUpdateTime(new Date());
  2604. amsSaleMaterial.setIsPoundSale(isPoundSale);
  2605. amsSaleMaterial.setInsertUpdateRemark("物流新增");
  2606. result += amsSaleMaterialMapper.insertSelective(amsSaleMaterial);
  2607. /*
  2608. 车序号物资表
  2609. */
  2610. // 车序号物资表主键
  2611. BigDecimal truckNoMaterialId = amsSaleTrucknoMaterialMapper.selectMaxId();
  2612. amsSaleTrucknoMaterial.setTrucknoMaterialId(truckNoMaterialId);
  2613. amsSaleTrucknoMaterial.setSaleOrderMaterialId(amsSaleOrderMaterial.getSaleOrderMaterialId());
  2614. amsSaleTrucknoMaterial.setMaterialId(amsSaleMaterial.getSaleMaterialId());
  2615. amsSaleTrucknoMaterial.setSaleOrderMaterialNumber(materialNumber);
  2616. amsSaleTrucknoMaterial.setInsertTime(new Date());
  2617. amsSaleTrucknoMaterial.setUpdateTime(new Date());
  2618. amsSaleTrucknoMaterial.setInsertUpdateRemark("物流新增");
  2619. result += amsSaleTrucknoMaterialMapper.insertSelective(amsSaleTrucknoMaterial);
  2620. }
  2621. result += amsSaleOrderMapper.insertSelective(amsSaleOrder);
  2622. return saleOrderId.intValue();
  2623. }
  2624. }