ApiOrderService.java 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835
  1. package com.kmall.api.service;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.kmall.common.constant.Dict;
  5. import com.kmall.api.dao.*;
  6. import com.kmall.api.dto.IdCardMsgVo;
  7. import com.kmall.api.entity.*;
  8. import com.kmall.api.service.merch.OmsMerchPropertiesBuilder;
  9. import com.kmall.api.util.CommonUtil;
  10. import com.kmall.api.util.IdCardUtil;
  11. import com.kmall.common.dao.TemplateConfDao;
  12. import com.kmall.common.entity.FormIdsEntity;
  13. import com.kmall.common.entity.TemplateConfVo;
  14. import com.kmall.common.service.FormIdsService;
  15. import com.kmall.common.service.print.ticket.PrintTicketPropertiesBuilder;
  16. import com.kmall.common.utils.Constant;
  17. import com.kmall.common.utils.DateUtils;
  18. import com.kmall.common.utils.RRException;
  19. import com.kmall.common.utils.StringUtils;
  20. import com.kmall.common.utils.print.ticket.TicketPrintUtil;
  21. import com.kmall.common.utils.print.ticket.item.*;
  22. import com.kmall.common.utils.wxtemplate.TemplateData;
  23. import com.kmall.common.utils.wxtemplate.WxTemplate;
  24. import org.springframework.beans.factory.annotation.Autowired;
  25. import org.springframework.stereotype.Service;
  26. import org.springframework.transaction.annotation.Transactional;
  27. import java.math.BigDecimal;
  28. import java.text.SimpleDateFormat;
  29. import java.util.*;
  30. @Service
  31. public class ApiOrderService {
  32. @Autowired
  33. private ApiSysPrinterMapper apiSysPrinterMapper;
  34. @Autowired
  35. private ApiProductMapper apiProductMapper;
  36. @Autowired
  37. private ApiCartMapper apiCartMapper;
  38. @Autowired
  39. private ApiCouponMapper apiCouponMapper;
  40. @Autowired
  41. private ApiOrderMapper apiOrderMapper;
  42. @Autowired
  43. private ApiOrderGoodsMapper apiOrderGoodsMapper;
  44. @Autowired
  45. private ApiUserCouponMapper apiUserCouponMapper;
  46. @Autowired
  47. private TemplateConfDao apiTemplateConfMapper;
  48. @Autowired
  49. private ApiUserMapper apiUserMapper;
  50. @Autowired
  51. private ApiGoodsGroupOpenMapper apiGoodsGroupOpenMapper;
  52. @Autowired
  53. private ApiGoodsGroupOpenDetailMapper apiGoodsGroupOpenDetailMapper;
  54. @Autowired
  55. private FormIdsService formIdsService;
  56. @Autowired
  57. private ApiGoodsMapper apiGoodsMapper;
  58. @Autowired
  59. private ApiFreightService apiFreightService;
  60. @Autowired
  61. private ApiOrderProcessRecordMapper orderProcessRecordMapper;
  62. @Autowired
  63. private ApiStoreMapper apiStoreMapper;
  64. @Autowired
  65. private ApiMerchMapper apiMerchMapper;
  66. public OrderVo queryObject(Long id) {
  67. return apiOrderMapper.queryObject(id);
  68. }
  69. public OrderVo queryObjectByOrderSn(String order_sn) {
  70. return apiOrderMapper.queryObjectByOrderSn(order_sn);
  71. }
  72. public Map queryUcenterMap(Map<String, Object> map) {
  73. return apiOrderMapper.queryUcenterMap(map);
  74. }
  75. public List<OrderVo> queryList(Map<String, Object> map) {
  76. return apiOrderMapper.queryList(map);
  77. }
  78. public int queryTotal(Map<String, Object> map) {
  79. return apiOrderMapper.queryTotal(map);
  80. }
  81. public void save(OrderVo order) {
  82. apiOrderMapper.save(order);
  83. }
  84. @Transactional
  85. public void cancelOrder(OrderVo order) {
  86. Map orderGoodsParam = new HashMap();
  87. orderGoodsParam.put("order_id", order.getId());
  88. //订单的商品
  89. List<OrderGoodsVo> goodsList = apiOrderGoodsMapper.queryList(orderGoodsParam);
  90. for (OrderGoodsVo orderGoodsVo : goodsList) {
  91. ProductVo productInfo = apiProductMapper.queryByStoreId(orderGoodsVo.getProduct_id(), order.getStore_id());
  92. productInfo.setStock_num(productInfo.getStock_num() + orderGoodsVo.getNumber());
  93. productInfo.minusSellVolume();
  94. apiProductMapper.updateStockNum(productInfo);
  95. }
  96. update(order);
  97. // 判断是否有优惠券
  98. UserCouponVo couponVo = apiUserCouponMapper.queryByOrderId(order.getId());
  99. if (null != couponVo) {
  100. apiUserCouponMapper.cancelOrder(couponVo);
  101. }
  102. }
  103. public void update(OrderVo order) {
  104. order.setIsScan("0");
  105. order.setModTime(new Date());
  106. apiOrderMapper.update(order);
  107. }
  108. public void updateOrderByMerchOrderSn(OrderVo order) {
  109. apiOrderMapper.updateOrderByMerchOrderSn(order);
  110. }
  111. public void updateBatch(List<OrderVo> list) {
  112. for (OrderVo order : list) {
  113. order.setIsScan("0");
  114. order.setModTime(new Date());
  115. }
  116. apiOrderMapper.updateBatch(list);
  117. }
  118. public void delete(Integer id) {
  119. apiOrderMapper.delete(id);
  120. }
  121. public void deleteBatch(Integer[] ids) {
  122. apiOrderMapper.deleteBatch(ids);
  123. }
  124. @Transactional
  125. public Map submit(JSONObject jsonParam, UserVo loginUser, Long storeId) {
  126. Map resultObj = new HashMap();
  127. AddressVo addressVo = jsonParam.getObject("checkedAddress", AddressVo.class);
  128. if (addressVo == null) {
  129. resultObj.put("errno", 400);
  130. resultObj.put("errmsg", "地址不能为空");
  131. return resultObj;
  132. }
  133. String formId = jsonParam.getString("formId");
  134. String idNo = jsonParam.getString("idNo");
  135. String userName = jsonParam.getString("userName");
  136. String postscript00 = jsonParam.getString("postscript00");
  137. String postscript02 = jsonParam.getString("postscript02");
  138. String postscript10 = jsonParam.getString("postscript10");
  139. String postscript11 = jsonParam.getString("postscript11");//留言备注
  140. String checkCart = jsonParam.getString("checkCart");//业务区分,11为普通商品,00为保税商品
  141. UserVo user = apiUserMapper.queryObjectByIdNoAndName(idNo, userName);
  142. UserVo userVo = new UserVo();
  143. userVo.setId(loginUser.getId());
  144. userVo.setIdNo(idNo);
  145. userVo.setUsername(userName);
  146. if(user != null){
  147. if(loginUser.getId() != user.getId()){
  148. resultObj.put("errno", 400);
  149. resultObj.put("errmsg", "该身份证信息已被绑定");
  150. return resultObj;
  151. }
  152. }
  153. // 实名认证身份证信息,认证成功更新到用户表
  154. String result = IdCardUtil.checkIdCard(userVo.getIdNo(), userVo.getUsername());
  155. IdCardMsgVo vo = JSON.parseObject(result,IdCardMsgVo.class);
  156. if(vo.getRespCode().equalsIgnoreCase("0000")){
  157. apiUserMapper.update(userVo);
  158. }else{
  159. resultObj.put("errno", 400);
  160. resultObj.put("errmsg", vo.getRespMessage());
  161. return resultObj;
  162. }
  163. //获取要购买的商品
  164. Map param = new HashMap();
  165. param.put("user_id", loginUser.getId());
  166. param.put("store_id", storeId);
  167. param.put("checked", 1);
  168. param.put("checkCart", checkCart);
  169. List<CartVo> checkedGoodsList = apiCartMapper.queryList(param);
  170. if (null == checkedGoodsList) {
  171. resultObj.put("errno", 400);
  172. resultObj.put("errmsg", "请选择商品");
  173. return resultObj;
  174. }
  175. // 检查库存和更新库存
  176. List<ProductVo> productVos = new ArrayList();
  177. for (CartVo goodsItem : checkedGoodsList) {
  178. //取得规格的信息,判断规格库存
  179. ProductVo productInfo = apiProductMapper.queryByStoreId(goodsItem.getProduct_id(), storeId);
  180. synchronized (productInfo){
  181. if (null == productInfo || null == productInfo.getStock_num() || productInfo.getStock_num() < goodsItem.getNumber()) {
  182. resultObj.put("errno", 400);
  183. resultObj.put("errmsg", "库存不足,仅剩余" + productInfo.getStock_num());
  184. return resultObj;
  185. }else{
  186. productInfo.setStock_num(productInfo.getStock_num() - goodsItem.getNumber());
  187. productInfo.setStore_id(storeId);
  188. productInfo.addSellVolume();
  189. productVos.add(productInfo);
  190. apiProductMapper.updateStockNum(productInfo);
  191. }
  192. }
  193. }
  194. BigDecimal freightPrice00 = new BigDecimal(0.00);
  195. BigDecimal freightPrice02 = new BigDecimal(0.00);
  196. BigDecimal freightPrice10 = new BigDecimal(0.00);
  197. BigDecimal freightPrice11 = new BigDecimal(0.00);
  198. Boolean isBizType00 = false;
  199. Boolean isBizType02 = false;
  200. Boolean isBizType10 = false;
  201. Boolean isBizType11 = false;
  202. //订单按业务类型进行分单
  203. for (CartVo goodsItem : checkedGoodsList) {
  204. //订单业务类型:00:保税备货, 02:保税展示补货,10:保税展示跨境,11:普通商品
  205. if(org.apache.commons.lang.StringUtils.isEmpty(checkCart)){
  206. if(Dict.orderBizType.item_11.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  207. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  208. freightPrice11 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice11;//查询商品运费信息
  209. isBizType11 =true;
  210. }
  211. if(Dict.orderBizType.item_00.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  212. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  213. freightPrice00 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice00;//查询商品运费信息
  214. isBizType00 =true;
  215. }
  216. if(Dict.orderBizType.item_02.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  217. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  218. freightPrice02 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice02;//查询商品运费信息
  219. isBizType02 =true;
  220. }
  221. if(Dict.orderBizType.item_10.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  222. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  223. freightPrice10 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice10;//查询商品运费信息
  224. isBizType10 =true;
  225. }
  226. }else{
  227. if(checkCart.equalsIgnoreCase(Dict.orderBizType.item_11.getItem())){
  228. if(Dict.orderBizType.item_11.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  229. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  230. freightPrice11 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice11;//查询商品运费信息
  231. isBizType11 =true;
  232. }
  233. }else{
  234. if(Dict.orderBizType.item_00.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  235. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  236. freightPrice00 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice00;//查询商品运费信息
  237. isBizType00 =true;
  238. }
  239. if(Dict.orderBizType.item_02.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  240. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  241. freightPrice02 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice02;//查询商品运费信息
  242. isBizType02 =true;
  243. }
  244. if(Dict.orderBizType.item_10.getItem().equalsIgnoreCase(goodsItem.getGoodsBizType())){
  245. FreightEntity freightEntity = apiFreightService.queryObjectByGoodsId(goodsItem.getGoods_id());
  246. freightPrice10 = freightEntity!=null ? freightEntity.getDefaultFreight() : freightPrice10;//查询商品运费信息
  247. isBizType10 =true;
  248. }
  249. }
  250. }
  251. }
  252. List<OrderVo> orderInfoList = new ArrayList();
  253. String merchOrderSn = "EMATO"+CommonUtil.generateOrderNumber();
  254. if(isBizType00){
  255. OrderVo order00 = setOrderVo(loginUser,jsonParam,storeId,freightPrice00,checkedGoodsList,Dict.orderBizType.item_00.getItem());
  256. order00.setOrderBizType(Dict.orderBizType.item_00.getItem());
  257. order00.setMerchOrderSn(merchOrderSn);
  258. if(org.apache.commons.lang.StringUtils.isNotEmpty(postscript00)) {
  259. order00.setPostscript(postscript00);
  260. }
  261. orderInfoList.add(order00);
  262. }
  263. if(isBizType02){
  264. OrderVo order02 = setOrderVo(loginUser,jsonParam,storeId,freightPrice02,checkedGoodsList,Dict.orderBizType.item_02.getItem());
  265. order02.setOrderBizType(Dict.orderBizType.item_02.getItem());
  266. order02.setMerchOrderSn(merchOrderSn);
  267. if(org.apache.commons.lang.StringUtils.isNotEmpty(postscript02)) {
  268. order02.setPostscript(postscript02);
  269. }
  270. orderInfoList.add(order02);
  271. }
  272. if(isBizType10){
  273. OrderVo order10 = setOrderVo(loginUser,jsonParam,storeId,freightPrice10,checkedGoodsList,Dict.orderBizType.item_10.getItem());
  274. order10.setOrderBizType(Dict.orderBizType.item_10.getItem());
  275. order10.setMerchOrderSn(merchOrderSn);
  276. if(org.apache.commons.lang.StringUtils.isNotEmpty(postscript10)) {
  277. order10.setPostscript(postscript10);
  278. }
  279. orderInfoList.add(order10);
  280. }
  281. if(isBizType11){
  282. OrderVo order11 = setOrderVo(loginUser,jsonParam,storeId,freightPrice11,checkedGoodsList,Dict.orderBizType.item_11.getItem());
  283. order11.setOrderBizType(Dict.orderBizType.item_11.getItem());
  284. order11.setMerchOrderSn(merchOrderSn);
  285. if(org.apache.commons.lang.StringUtils.isNotEmpty(postscript11)) {
  286. order11.setPostscript(postscript11);
  287. }
  288. orderInfoList.add(order11);
  289. }
  290. //开启事务,插入订单信息和订单商品
  291. if(orderInfoList != null && orderInfoList.size() > 0) {
  292. apiOrderMapper.saveBatch(orderInfoList);
  293. List<OrderProcessRecordEntity> processRecordEntityList = new ArrayList<>();
  294. for (OrderVo orderInfo : orderInfoList) {
  295. if (null == orderInfo.getId()) {
  296. throw new RRException("订单提交失败");
  297. }
  298. //新增订单详情
  299. for (CartVo goodsItem : checkedGoodsList) {
  300. //统计商品总价
  301. if (orderInfo.getOrderBizType().equalsIgnoreCase(goodsItem.getGoodsBizType())) {
  302. GoodsVo goodsVo = apiGoodsMapper.queryObject(goodsItem.getGoods_id());
  303. if(goodsVo==null){
  304. throw new RRException("订单提交失败:商品不存在");
  305. }
  306. OrderGoodsVo orderGoodsVo = setOrderGoodsVo(orderInfo, goodsItem,goodsVo);
  307. apiOrderGoodsMapper.save(orderGoodsVo);
  308. }
  309. }
  310. OrderProcessRecordEntity entity = new OrderProcessRecordEntity();
  311. entity.setOrderSn(orderInfo.getOrder_sn());
  312. entity.setUserId(Integer.valueOf(loginUser.getId()+""));
  313. entity.setAddOrderStartTime(orderInfo.getAdd_time());
  314. entity.setAddOrderSuccTime(orderInfo.getAdd_time());
  315. entity.setIsAddOrderSend(Dict.isSend.item_1.getItem());
  316. entity.setOrderBizType(orderInfo.getOrderBizType());
  317. processRecordEntityList.add(entity);
  318. }
  319. orderProcessRecordMapper.saveBatch(processRecordEntityList);//新增订单流转信息
  320. //清空已购买的商品
  321. apiCartMapper.deleteByCart(loginUser.getId(), storeId, 1, checkCart);
  322. if (apiOrderMapper.queryCountByMerchOrderSn(merchOrderSn) > 1) {//不止一笔订单则为拆单订单
  323. OrderVo orderVo = new OrderVo();
  324. orderVo.setIsMergePay("2");//多笔订单单笔支付
  325. orderVo.setMerchOrderSn(merchOrderSn);
  326. apiOrderMapper.updateOrderByMerchOrderSn(orderVo);
  327. }
  328. resultObj.put("errno", 0);
  329. resultObj.put("errmsg", "订单提交成功");
  330. //
  331. Map orderInfoMap = new HashMap();
  332. orderInfoMap.put("orderInfo", orderInfoList);
  333. resultObj.put("data", orderInfoMap);
  334. // 优惠券标记已用
  335. /*for (OrderVo orderInfo : orderInfoList) {
  336. if (null != userCouponId && 0 != userCouponId) {
  337. UserCouponVo userCouponVo = apiUserCouponMapper.queryObject(userCouponId);
  338. if (null != userCouponVo && (null == userCouponVo.getOrder_id() || 0 == userCouponVo.getOrder_id())) {
  339. userCouponVo.setUsed_time(new Date());
  340. userCouponVo.setOrder_id(orderInfo.getId());
  341. userCouponVo.setIsUsed(Dict.isUsed.item_1.getItem());
  342. apiUserCouponMapper.update(userCouponVo);
  343. }
  344. }
  345. }*/
  346. }
  347. return resultObj;
  348. }
  349. /**
  350. * 设置订单数据
  351. * @param loginUser
  352. * @param jsonParam
  353. * @param storeId
  354. * @param freightPrice
  355. * @param checkedGoodsList
  356. * @return
  357. */
  358. public OrderVo setOrderVo(UserVo loginUser,JSONObject jsonParam,Long storeId,BigDecimal freightPrice,List<CartVo> checkedGoodsList,String bizType){
  359. OrderVo orderInfo = new OrderVo();
  360. Integer userCouponId = jsonParam.getInteger("userCouponId");
  361. String postscript = jsonParam.getString("postscript");
  362. Long fullCutCouponId = jsonParam.getLong("fullCutCouponId");//满减券
  363. AddressVo addressVo = jsonParam.getObject("checkedAddress", AddressVo.class);
  364. Date delivery_date = jsonParam.getDate("delivery_date");
  365. String merchSn = (String)jsonParam.get("merchSn");
  366. if (null == delivery_date) {
  367. delivery_date = new Date();
  368. }
  369. String delivery_remark = jsonParam.getString("delivery_remark");
  370. if (StringUtils.isNullOrEmpty(delivery_remark)) {
  371. delivery_remark = "尽快送达";
  372. }
  373. BigDecimal fullCutCouponDec = Constant.ZERO;
  374. BigDecimal goodsTotalPrice = new BigDecimal(0.00);
  375. for (CartVo goodsItem : checkedGoodsList) {
  376. if(bizType.equalsIgnoreCase(goodsItem.getGoodsBizType())){
  377. goodsTotalPrice = goodsTotalPrice.add(goodsItem.getRetail_price().multiply(new BigDecimal(goodsItem.getNumber())));
  378. }
  379. }
  380. //查询未使用的优惠券
  381. String couponName = "";
  382. UserCouponVo couponVo = null;
  383. BigDecimal couponPrice = new BigDecimal(0.00);
  384. if (null != userCouponId && 0 != userCouponId) {
  385. couponVo = apiUserCouponMapper.queryObjectByIdAndUsed(userCouponId);
  386. if (null != couponVo && null != couponVo.getType_money()) {
  387. couponPrice = couponVo.getType_money();
  388. couponName = couponVo.getCoupon_name();
  389. }
  390. }
  391. /*// 获取优惠信息提示
  392. Map couponParam = new HashMap();
  393. couponParam.put("enabled", true);
  394. Integer[] send_types = new Integer[]{7};
  395. couponParam.put("send_types", send_types);
  396. List<CouponVo> couponVos = apiCouponMapper.queryList(couponParam);
  397. if (null != couponVos && couponVos.size() > 0) {
  398. for (CouponVo couponVo : couponVos) {
  399. // 是否免运费
  400. if (couponVo.getSend_type() == 7 && couponVo.getMin_goods_amount().compareTo(goodsTotalPrice) <= 0) {
  401. freightPrice = couponVo.getType_money();
  402. }
  403. }
  404. }
  405. //todo 获取优惠信息 满减,暂时不用
  406. CouponVo fullCutCoupon = apiCouponMapper.queryObject(fullCutCouponId);
  407. if (null != fullCutCoupon) {
  408. fullCutCouponDec = fullCutCoupon.getType_money();
  409. }*/
  410. //订单价格计算:订单的总价+运费
  411. BigDecimal orderTotalPrice = goodsTotalPrice.add(freightPrice);
  412. //减去其它支付的金额后,要实际支付的金额 订单的总价+运费-优惠券金额
  413. BigDecimal actualPrice = orderTotalPrice.subtract(couponPrice);
  414. // BigDecimal actualPrice = orderTotalPrice.subtract(fullCutCouponDec).subtract(couponPrice);
  415. // String merchSn = OmsMerchPropertiesBuilder.instance().getMerchSn();
  416. // String merchShortName = OmsMerchPropertiesBuilder.instance().getMerchShortName();
  417. MerchVo merchVo = apiMerchMapper.queryObjectByMerchSn(merchSn);
  418. // String merchShortName = "";
  419. // if(merchVo != null){
  420. // merchShortName = merchVo.getMerchShortName();
  421. // }
  422. String thirdMerchSn = "";
  423. StoreVo storeVo = apiStoreMapper.queryObject(storeId);
  424. if(storeVo != null){
  425. thirdMerchSn = storeVo.getThirdPartyMerchCode()==null?"":storeVo.getThirdPartyMerchCode();
  426. }
  427. // //一级商户 + 二级商户(拼音首字母)+ 三级商户 + 业务类型 + 编号
  428. // String orderSn = oneMerchName + merchShortName + thirdMerchSn + bizType + CommonUtil.generateOrderNumber();
  429. //一级商户 + 三级商户(拼音首字母) + 业务类型 + 编号
  430. String orderSn = "ZW" + thirdMerchSn + bizType + CommonUtil.generateOrderNumber();
  431. orderInfo.setOrder_sn(orderSn);
  432. orderInfo.setMerchSn(merchSn);
  433. orderInfo.setUser_id(loginUser.getId());
  434. //收货地址和运费
  435. orderInfo.setConsignee(addressVo.getUserName());
  436. orderInfo.setMobile(addressVo.getTelNumber());
  437. orderInfo.setCountry(addressVo.getNationalCode());
  438. orderInfo.setProvince(addressVo.getProvinceName());
  439. orderInfo.setCity(addressVo.getCityName());
  440. orderInfo.setDistrict(addressVo.getCountyName());
  441. orderInfo.setAddress(addressVo.getDetailInfo());
  442. orderInfo.setAddress_id(addressVo.getId());
  443. orderInfo.setDelivery_date(delivery_date);
  444. orderInfo.setDelivery_remark(delivery_remark);
  445. orderInfo.setStore_id(storeId);
  446. //
  447. orderInfo.setFreight_price(freightPrice.intValue());
  448. orderInfo.setCoupon_id(userCouponId);
  449. orderInfo.setCoupon_price(couponPrice);
  450. orderInfo.setCoupon_name(couponName);
  451. //留言
  452. orderInfo.setPostscript(postscript);
  453. //使用的优惠券
  454. orderInfo.setFull_cut_price(fullCutCouponDec);
  455. orderInfo.setAdd_time(new Date());
  456. orderInfo.setGoods_price(goodsTotalPrice);
  457. orderInfo.setOrder_price(orderTotalPrice);
  458. orderInfo.setActual_price(actualPrice);
  459. orderInfo.setOrder_type("1");
  460. // 待付款
  461. orderInfo.setOrder_status(0);
  462. orderInfo.setShipping_status(0);
  463. orderInfo.setPay_status(0);
  464. orderInfo.setShipping_id(0L);
  465. orderInfo.setShipping_fee(Constant.ZERO);
  466. orderInfo.setIntegral(0);
  467. orderInfo.setIntegral_money(Constant.ZERO);
  468. orderInfo.setCreateTime(new Date());
  469. orderInfo.setModTime(new Date());
  470. orderInfo.setPayMobile(loginUser.getMobile());
  471. orderInfo.setPayTransactionId("");
  472. orderInfo.setIsScan("0");//默认未扫描
  473. UserVo userVo = apiUserMapper.queryObject(orderInfo.getUser_id());
  474. orderInfo.setPayMobile(userVo.getMobile());
  475. orderInfo.setPay_name(userVo.getUsername());
  476. orderInfo.setIsOnfflineOrder(Dict.isOnfflineOrder.item_0.getItem());
  477. //标记该订单已使用优惠券
  478. if(couponVo != null){
  479. couponVo.setUsed_time(new Date());
  480. couponVo.setIsUsed(Dict.isUsed.item_1.getItem());
  481. apiUserCouponMapper.update(couponVo);
  482. }
  483. return orderInfo;
  484. }
  485. public OrderGoodsVo setOrderGoodsVo(OrderVo orderInfo,CartVo goodsItem,GoodsVo goodsVo){
  486. OrderGoodsVo orderGoodsVo = new OrderGoodsVo();
  487. orderGoodsVo.setOrder_id(orderInfo.getId());
  488. orderGoodsVo.setGoods_id(goodsItem.getGoods_id());
  489. orderGoodsVo.setGoods_sn(goodsItem.getGoods_sn());
  490. orderGoodsVo.setProduct_id(goodsItem.getProduct_id());
  491. orderGoodsVo.setGoods_name(goodsItem.getGoods_name());
  492. orderGoodsVo.setList_pic_url(goodsItem.getList_pic_url());
  493. orderGoodsVo.setMarket_price(goodsItem.getMarket_price());
  494. orderGoodsVo.setRetail_price(goodsItem.getRetail_price());
  495. orderGoodsVo.setNumber(goodsItem.getNumber());
  496. orderGoodsVo.setGoods_specification_name_value(goodsItem.getGoods_specification_name_value());
  497. orderGoodsVo.setGoods_specification_ids(goodsItem.getGoods_specification_ids());
  498. orderGoodsVo.setOrderBizType(goodsItem.getGoodsBizType());
  499. orderGoodsVo.setCreateTime(new Date());
  500. orderGoodsVo.setModTime(new Date());
  501. orderGoodsVo.setGoodsRate(goodsVo.getGoodsRate());
  502. BigDecimal number = new BigDecimal(Long.valueOf(goodsItem.getNumber()));
  503. BigDecimal goodsTotal = goodsItem.getRetail_price().multiply(number);//单商品总价
  504. BigDecimal rate = goodsTotal.divide(orderInfo.getGoods_price(),2, BigDecimal.ROUND_HALF_UP);//单商品总价/订单总价(不含运费、不含优惠券)
  505. BigDecimal freightPrice = BigDecimal.valueOf(orderInfo.getFreight_price());
  506. BigDecimal settlePrice = Constant.ZERO;
  507. if(orderInfo.getFreight_price()!=0 && !"0".equalsIgnoreCase(orderInfo.getCoupon_price()+"")){
  508. //运费-优惠券
  509. BigDecimal rateTotal = freightPrice.subtract(orderInfo.getCoupon_price());
  510. //商品结算平摊价格(含优惠券、运费金额) = 单商品总价 + 单商品总价/订单总价(不含运费、不含优惠券) * 运费与优惠券合计税率
  511. settlePrice = goodsTotal.add(rate.multiply(rateTotal));
  512. }else{
  513. if(orderInfo.getFreight_price()!=0){
  514. //运费税率 = 单商品总价/订单总价(不含运费)* 运费金额
  515. BigDecimal freightRate = rate.multiply(freightPrice);
  516. //商品结算平摊价格(含运费金额) = 单商品总价+运费税率
  517. settlePrice = goodsTotal.add(freightRate);
  518. }
  519. if(!"0".equalsIgnoreCase(orderInfo.getCoupon_price()+"")){
  520. //优惠券税率 = 单商品总价/订单总价(不含优惠券)* 优惠券金额
  521. BigDecimal couponRate = rate.multiply(orderInfo.getCoupon_price());
  522. //商品结算平摊价格(含优惠券金额) = 单商品总价-优惠券税率
  523. settlePrice = goodsTotal.subtract(couponRate);
  524. }
  525. }
  526. if(settlePrice.compareTo(BigDecimal.valueOf(0)) == 0){
  527. orderGoodsVo.setSettlePrice(goodsTotal);//商品结算平摊价格
  528. }else{
  529. orderGoodsVo.setSettlePrice(settlePrice);//商品结算平摊价格
  530. }
  531. orderGoodsVo.setSku(goodsVo.getSku());
  532. return orderGoodsVo;
  533. }
  534. /**
  535. * 支付成功通知
  536. */
  537. @Transactional
  538. public void notifyPaySuccess(OrderVo orderInfo) {
  539. WxTemplate tem = new WxTemplate();
  540. FormIdsEntity formIdsEntity = formIdsService.getFormIdsByMerchOrderSn(orderInfo.getMerchOrderSn());
  541. if (null == formIdsEntity || !StringUtils.isNotEmpty(formIdsEntity.getFormId())) {
  542. return;
  543. }
  544. if (orderInfo.getOrder_type().equals("1")) { // 订单类型 1:普通订单 2:团购订单
  545. TemplateConfVo templateConfVo = apiTemplateConfMapper.queryByTypeId(1); // 模板类型 1订单付款成功 2团购成功 3拼团失败通知 4拼团进度 5 6 7订单配送 8订单评价提醒
  546. if (null == templateConfVo) {
  547. return;
  548. }
  549. UserVo userVo = apiUserMapper.queryObject(orderInfo.getUser_id());
  550. tem.setTemplate_id(templateConfVo.getTemplateId());
  551. // tem.setTopcolor("#00DD00");
  552. tem.setTouser(userVo.getWeixin_openid());
  553. tem.setPage("/pages/ucenter/orderDetail/orderDetail?id=" + orderInfo.getId());
  554. tem.setForm_id(formIdsEntity.getFormId());
  555. List<TemplateData> paras = new ArrayList<TemplateData>();
  556. paras.add(new TemplateData("first", templateConfVo.getDesc(), "#000000"));
  557. paras.add(new TemplateData("keyword1", orderInfo.getMerchOrderSn(), "#000000"));
  558. //订单的商品
  559. Map orderGoodsParam = new HashMap();
  560. orderGoodsParam.put("order_id", orderInfo.getId());
  561. List<OrderGoodsVo> orderGoods = apiOrderGoodsMapper.queryList(orderGoodsParam);
  562. String body = "";
  563. if (null != orderGoods) {
  564. for (OrderGoodsVo goodsVo : orderGoods) {
  565. body = body + goodsVo.getGoods_name() + "、";
  566. }
  567. if (body.length() > 0) {
  568. body = body.substring(0, body.length() - 1);
  569. }
  570. }
  571. paras.add(new TemplateData("keyword2", body, "#000000"));
  572. paras.add(new TemplateData("keyword3", orderInfo.getActual_price().setScale(2, BigDecimal.ROUND_HALF_DOWN).toString(), "#000000"));
  573. paras.add(new TemplateData("keyword4", DateUtils.format(orderInfo.getAdd_time(), DateUtils.DATE_TIME_PATTERN), "#000000"));
  574. tem.setData(paras);
  575. }
  576. // TODO: 2018/10/25 暂时不实现团购订单
  577. /*if (orderInfo.getOrder_type().equals("2")) { // 订单类型 1:普通订单 2:团购订单
  578. TemplateConfVo templateConfVo = apiTemplateConfMapper.queryByTypeId(2); // 模板类型 1订单付款成功 2团购成功 3拼团失败通知 4拼团进度 5 6 7订单配送 8订单评价提醒
  579. if (null == templateConfVo) {
  580. return;
  581. }
  582. UserVo userVo = apiUserMapper.queryObject(orderInfo.getUser_id());
  583. // 团购明细
  584. GoodsGroupOpenDetailVo openDetailVo = apiGoodsGroupOpenDetailMapper.queryObject(orderInfo.getActivity_id());
  585. // 获取团购
  586. GoodsGroupOpenVo groupOpenVo = apiGoodsGroupOpenMapper.queryObject(openDetailVo.getOpen_id());
  587. tem.setTemplate_id(templateConfVo.getTemplateId());
  588. tem.setTopcolor("#00DD00");
  589. tem.setTouser(userVo.getWeixin_openid());
  590. tem.setPage("/pages/ucenter/orderDetail/orderDetail?id=" + orderInfo.getId());
  591. tem.setForm_id(formIdsEntity.getFormId());
  592. List<TemplateData> paras = new ArrayList<TemplateData>();
  593. paras.add(new TemplateData("keyword1", groupOpenVo.getTitle(), "#000000"));
  594. paras.add(new TemplateData("keyword2", DateUtils.format(groupOpenVo.getOpen_time(), DateUtils.DATE_TIME_PATTERN), "#000000"));
  595. //订单的商品
  596. Map orderGoodsParam = new HashMap();
  597. orderGoodsParam.put("order_id", orderInfo.getId());
  598. List<OrderGoodsVo> orderGoods = apiOrderGoodsMapper.queryList(orderGoodsParam);
  599. String body = "";
  600. if (null != orderGoods) {
  601. for (OrderGoodsVo goodsVo : orderGoods) {
  602. body = body + goodsVo.getGoods_name() + "、";
  603. }
  604. if (body.length() > 0) {
  605. body = body.substring(0, body.length() - 1);
  606. }
  607. }
  608. paras.add(new TemplateData("keyword3", body, "#000000"));
  609. // 团成员
  610. Map groupParam = new HashMap();
  611. groupParam.put("open_id", orderInfo.getActivity_id());
  612. List<GoodsGroupOpenDetailVo> openDetailVos = apiGoodsGroupOpenDetailMapper.queryList(groupParam);
  613. String attendMember = "";
  614. if (null != openDetailVos) {
  615. for (GoodsGroupOpenDetailVo detailVo : openDetailVos) {
  616. attendMember = attendMember + detailVo.getNickname() + "、";
  617. }
  618. if (attendMember.length() > 0) {
  619. attendMember = attendMember.substring(0, attendMember.length() - 1);
  620. }
  621. }
  622. paras.add(new TemplateData("keyword4", attendMember, "#000000"));
  623. paras.add(new TemplateData("keyword5", orderInfo.getActual_price().setScale(2, BigDecimal.ROUND_HALF_DOWN).toString(), "#000000"));
  624. paras.add(new TemplateData("keyword5", templateConfVo.getDesc(), "#000000"));
  625. tem.setData(paras);
  626. }*/
  627. try {
  628. // WxTemplateUtil.sendMessage(tem);
  629. formIdsService.releaseFormIds(formIdsEntity);
  630. } catch (Exception e) {
  631. e.printStackTrace();
  632. }
  633. }
  634. /**
  635. * 确认收货
  636. *
  637. * @param orderId
  638. */
  639. @Transactional
  640. public void confirmOrder(Long orderId) {
  641. OrderVo orderVo = apiOrderMapper.queryObject(orderId);
  642. orderVo.setOrder_status(301);
  643. orderVo.setShipping_status(2);
  644. orderVo.setConfirm_time(new Date());
  645. orderVo.setModTime(new Date());
  646. apiOrderMapper.update(orderVo);
  647. }
  648. /*public String printMsgs(Long orderId) {
  649. OrderVo orderEntity = queryObject(orderId);
  650. Map<String, Object> map = new HashMap<String, Object>();
  651. map.put("order_id", orderEntity.getId());
  652. List<OrderGoodsVo> orderGoodsEntities = apiOrderGoodsMapper.queryList(map);
  653. UserVo userVo = apiUserMapper.queryObject(orderEntity.getUser_id());
  654. String content = "<CB>商城超市</CB><BR>";
  655. content += "名称/商品编码 单价 数量 金额<BR>";
  656. for (OrderGoodsVo orderGoodsEntity : orderGoodsEntities) {
  657. content += "--------------------------------<BR>";
  658. content += orderGoodsEntity.getGoods_name() + "<BR>" + orderGoodsEntity.getGoods_sn() + " " + orderGoodsEntity.getRetail_price() + " " + orderGoodsEntity.getNumber()
  659. + " " + orderGoodsEntity.getRetail_price().multiply(new BigDecimal(orderGoodsEntity.getNumber())) + "<BR>";
  660. }
  661. content += "--------------------------------<BR>";
  662. content += "备注:" + orderEntity.getPostscript() + "<BR>";
  663. content += "--------------------------------<BR>";
  664. content += "订单编号:" + orderEntity.getOrder_sn() + "<BR>";
  665. content += "配送配用:" + orderEntity.getShipping_fee() + "元<BR>";
  666. content += "优惠价格:" + orderEntity.getCoupon_price() + "元<BR>";
  667. content += "合计:" + orderEntity.getOrder_price() + "元<BR>";
  668. content += "实付:" + orderEntity.getActual_price() + "元<BR>";
  669. content += "姓名:" + null != userVo.getNickname() ? userVo.getNickname() : "" + "<BR>";
  670. content += "送货地点:" + orderEntity.getProvince() + orderEntity.getCity() + orderEntity.getDistrict() + orderEntity.getAddress() + "<BR>";
  671. content += "联系电话:" + orderEntity.getMobile() + "<BR>";
  672. content += "付款时间:" + DateUtils.format(orderEntity.getPay_time(), DateUtils.DATE_TIME_PATTERN) + "<BR>";
  673. content += "<QR>" + orderEntity.getId() + "</QR>";
  674. if ("2".equals(orderEntity.getOrder_type())) {
  675. content += "<RIGHT><BOLD>【团购】</BOLD></RIGHT>";
  676. }
  677. //所属门店
  678. Long storeId = orderEntity.getStore_id();
  679. //获取门店的打印机编号,每个门店只有一个打票机
  680. Map<String, Object> printParams = new HashMap<String, Object>();
  681. List<SysPrinterVo> printerEntities = apiSysPrinterMapper.queryList(printParams);
  682. printParams.put("storeId", storeId);
  683. String sn = "";
  684. if (printerEntities != null && printerEntities.size() != 0) {
  685. sn = printerEntities.get(0).getSn();
  686. }
  687. return FeiGeUtils.printMsg(sn, content, "1");
  688. }*/
  689. public Ticket printMsg(Long orderId) {
  690. OrderVo orderEntity = queryObject(orderId);
  691. if(orderEntity != null) {
  692. if (orderEntity.getOrderBizType().equalsIgnoreCase(Dict.orderBizType.item_10.getItem())
  693. || orderEntity.getOrderBizType().equalsIgnoreCase(Dict.orderBizType.item_02.getItem())) {
  694. Map<String, Object> map = new HashMap<String, Object>();
  695. map.put("order_id", orderEntity.getId());
  696. List<OrderGoodsVo> orderGoodsEntityList = apiOrderGoodsMapper.queryList(map);
  697. // 获取门店
  698. StoreVo storeEntity = apiStoreMapper.queryObject(orderEntity.getStore_id());
  699. // 获取清关信息
  700. OrderProcessRecordEntity orderProcessRecordEntity = orderProcessRecordMapper.queryObjectByOrderSn(orderEntity.getOrder_sn());
  701. UserVo userVo = apiUserMapper.queryObject(orderEntity.getUser_id());
  702. // 小票头
  703. TicketHead head = new TicketHead();
  704. head.setTitle(OmsMerchPropertiesBuilder.instance().getMerchName() + storeEntity.getStoreName());
  705. head.setMemberId(userVo.getUsername().toString());
  706. head.setOrderId(orderEntity.getOrder_sn());
  707. head.setTradeTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss EEE").format(new Date()));
  708. // 商品信息
  709. Integer goodsTotal = 0; // 商品总个数
  710. BigDecimal total = Constant.ZERO; // 商品总计
  711. List<Goods> goodsList = new ArrayList<>();
  712. for (OrderGoodsVo orderGoods : orderGoodsEntityList) {
  713. goodsTotal += orderGoods.getNumber();
  714. total = total.add(orderGoods.getRetail_price().subtract(new BigDecimal(orderGoods.getNumber()))).setScale(2, BigDecimal.ROUND_HALF_UP);
  715. Goods goods = new Goods(orderGoods.getGoods_name(), orderGoods.getRetail_price().toString(), orderGoods.getNumber().toString()
  716. ,orderGoods.getRetail_price().multiply(new BigDecimal(orderGoods.getNumber())).setScale(2,BigDecimal.ROUND_HALF_UP).toString());
  717. goodsList.add(goods);
  718. }
  719. // 收银信息
  720. CashInfo cashInfo = new CashInfo();
  721. cashInfo.setGoodsTotal(goodsTotal.toString());
  722. cashInfo.setTotal(total.setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  723. cashInfo.setReceipts(orderEntity.getActual_price().setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  724. cashInfo.setOddChange("0.00");
  725. cashInfo.setCoupon(orderEntity.getCoupon_price().setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  726. cashInfo.setFreight(new BigDecimal(orderEntity.getFreight_price()).setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  727. cashInfo.setPaymentMode("微信支付");
  728. // 海关清单
  729. CusListing cusListing = new CusListing();
  730. cusListing.setOrderId(orderEntity.getOrder_sn());
  731. cusListing.setWaybillId(orderProcessRecordEntity.getLogisticsNo());
  732. cusListing.setInvtNo(orderProcessRecordEntity.getInvtNo());
  733. cusListing.setConsignee(orderEntity.getConsignee());
  734. cusListing.setConsigneeTel(orderEntity.getMobile());
  735. cusListing.setOriginAddress(PrintTicketPropertiesBuilder.instance().getAddress());
  736. cusListing.setDeliveryAddress(storeEntity.getStoreAddress());
  737. return TicketPrintUtil.print(head, goodsList, cashInfo, cusListing);
  738. }else{
  739. return null;
  740. }
  741. }else{
  742. return null;
  743. }
  744. }
  745. public List<OrderVo> queryObjectByIdList(List<Long> orderIdList){
  746. return apiOrderMapper.queryObjectByIdList(orderIdList);
  747. }
  748. public List<OrderVo> queryObjectByMerchOrderSn(String merchOrderSn){
  749. return apiOrderMapper.queryObjectByMerchOrderSn(merchOrderSn);
  750. }
  751. public int queryCountByMerchOrderSn(String merchOrderSn){
  752. return apiOrderMapper.queryCountByMerchOrderSn(merchOrderSn);
  753. }
  754. public int queryCountByPayId(String payId){
  755. return apiOrderMapper.queryCountByPayId(payId);
  756. }
  757. public List<OrderVo> queryOrderByMerchOrderSnAndRefundStatus(String merchOrderSn){
  758. return apiOrderMapper.queryOrderByMerchOrderSnAndRefundStatus(merchOrderSn);
  759. }
  760. }