1
0

ApiOrderService.java 37 KB

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