ApiOrderService.java 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785
  1. package com.kmall.api.service;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.kmall.api.contants.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.printer.FeiGeUtils;
  23. import com.kmall.common.utils.wxtemplate.TemplateData;
  24. import com.kmall.common.utils.wxtemplate.WxTemplate;
  25. import org.springframework.beans.factory.annotation.Autowired;
  26. import org.springframework.stereotype.Service;
  27. import org.springframework.transaction.annotation.Transactional;
  28. import java.io.Serializable;
  29. import java.math.BigDecimal;
  30. import java.text.SimpleDateFormat;
  31. import java.util.*;
  32. @Service
  33. public class ApiOrderService {
  34. @Autowired
  35. private ApiSysPrinterMapper apiSysPrinterMapper;
  36. @Autowired
  37. private ApiProductMapper apiProductMapper;
  38. @Autowired
  39. private ApiCartMapper apiCartMapper;
  40. @Autowired
  41. private ApiCouponMapper apiCouponMapper;
  42. @Autowired
  43. private ApiOrderMapper apiOrderMapper;
  44. @Autowired
  45. private ApiOrderGoodsMapper apiOrderGoodsMapper;
  46. @Autowired
  47. private ApiUserCouponMapper apiUserCouponMapper;
  48. @Autowired
  49. private TemplateConfDao apiTemplateConfMapper;
  50. @Autowired
  51. private ApiUserMapper apiUserMapper;
  52. @Autowired
  53. private ApiGoodsGroupOpenMapper apiGoodsGroupOpenMapper;
  54. @Autowired
  55. private ApiGoodsGroupOpenDetailMapper apiGoodsGroupOpenDetailMapper;
  56. @Autowired
  57. private FormIdsService formIdsService;
  58. @Autowired
  59. private ApiGoodsMapper apiGoodsMapper;
  60. @Autowired
  61. private ApiFreightService apiFreightService;
  62. @Autowired
  63. private ApiOrderProcessRecordMapper orderProcessRecordMapper;
  64. @Autowired
  65. private ApiStoreMapper apiStoreMapper;
  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"+new SimpleDateFormat("yyyyMMddhhmmss").format(new Date());
  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. if (null == delivery_date) {
  331. delivery_date = new Date();
  332. }
  333. String delivery_remark = jsonParam.getString("delivery_remark");
  334. if (StringUtils.isNullOrEmpty(delivery_remark)) {
  335. delivery_remark = "尽快送达";
  336. }
  337. BigDecimal fullCutCouponDec = Constant.ZERO;
  338. BigDecimal goodsTotalPrice = new BigDecimal(0.00);
  339. for (CartVo goodsItem : checkedGoodsList) {
  340. if(bizType.equalsIgnoreCase(goodsItem.getGoodsBizType())){
  341. goodsTotalPrice = goodsTotalPrice.add(goodsItem.getRetail_price().multiply(new BigDecimal(goodsItem.getNumber())));
  342. }
  343. }
  344. //查询未使用的优惠券
  345. String couponName = "";
  346. UserCouponVo couponVo = null;
  347. BigDecimal couponPrice = new BigDecimal(0.00);
  348. if (null != userCouponId && 0 != userCouponId) {
  349. couponVo = apiUserCouponMapper.queryObjectByIdAndUsed(userCouponId);
  350. if (null != couponVo && null != couponVo.getType_money()) {
  351. couponPrice = couponVo.getType_money();
  352. couponName = couponVo.getCoupon_name();
  353. }
  354. }
  355. /*// 获取优惠信息提示
  356. Map couponParam = new HashMap();
  357. couponParam.put("enabled", true);
  358. Integer[] send_types = new Integer[]{7};
  359. couponParam.put("send_types", send_types);
  360. List<CouponVo> couponVos = apiCouponMapper.queryList(couponParam);
  361. if (null != couponVos && couponVos.size() > 0) {
  362. for (CouponVo couponVo : couponVos) {
  363. // 是否免运费
  364. if (couponVo.getSend_type() == 7 && couponVo.getMin_goods_amount().compareTo(goodsTotalPrice) <= 0) {
  365. freightPrice = couponVo.getType_money();
  366. }
  367. }
  368. }
  369. //todo 获取优惠信息 满减,暂时不用
  370. CouponVo fullCutCoupon = apiCouponMapper.queryObject(fullCutCouponId);
  371. if (null != fullCutCoupon) {
  372. fullCutCouponDec = fullCutCoupon.getType_money();
  373. }*/
  374. //订单价格计算:订单的总价+运费
  375. BigDecimal orderTotalPrice = goodsTotalPrice.add(freightPrice);
  376. //减去其它支付的金额后,要实际支付的金额 订单的总价+运费-优惠券金额
  377. BigDecimal actualPrice = orderTotalPrice.subtract(couponPrice);
  378. // BigDecimal actualPrice = orderTotalPrice.subtract(fullCutCouponDec).subtract(couponPrice);
  379. //商户(拼音首字母)+业务类型+编号
  380. String merchSn = OmsMerchPropertiesBuilder.instance().getMerchSn();
  381. String merchShortName = OmsMerchPropertiesBuilder.instance().getMerchShortName();
  382. String orderSn = merchShortName + bizType + CommonUtil.generateOrderNumber();
  383. orderInfo.setOrder_sn(orderSn);
  384. orderInfo.setMerchSn(merchSn);
  385. orderInfo.setUser_id(loginUser.getId());
  386. //收货地址和运费
  387. orderInfo.setConsignee(addressVo.getUserName());
  388. orderInfo.setMobile(addressVo.getTelNumber());
  389. orderInfo.setCountry(addressVo.getNationalCode());
  390. orderInfo.setProvince(addressVo.getProvinceName());
  391. orderInfo.setCity(addressVo.getCityName());
  392. orderInfo.setDistrict(addressVo.getCountyName());
  393. orderInfo.setAddress(addressVo.getDetailInfo());
  394. orderInfo.setAddress_id(addressVo.getId());
  395. orderInfo.setDelivery_date(delivery_date);
  396. orderInfo.setDelivery_remark(delivery_remark);
  397. orderInfo.setStore_id(storeId);
  398. //
  399. orderInfo.setFreight_price(freightPrice.intValue());
  400. orderInfo.setCoupon_id(userCouponId);
  401. orderInfo.setCoupon_price(couponPrice);
  402. orderInfo.setCoupon_name(couponName);
  403. //留言
  404. orderInfo.setPostscript(postscript);
  405. //使用的优惠券
  406. orderInfo.setFull_cut_price(fullCutCouponDec);
  407. orderInfo.setAdd_time(new Date());
  408. orderInfo.setGoods_price(goodsTotalPrice);
  409. orderInfo.setOrder_price(orderTotalPrice);
  410. orderInfo.setActual_price(actualPrice);
  411. orderInfo.setOrder_type("1");
  412. // 待付款
  413. orderInfo.setOrder_status(0);
  414. orderInfo.setShipping_status(0);
  415. orderInfo.setPay_status(0);
  416. orderInfo.setShipping_id(0L);
  417. orderInfo.setShipping_fee(Constant.ZERO);
  418. orderInfo.setIntegral(0);
  419. orderInfo.setIntegral_money(Constant.ZERO);
  420. orderInfo.setCreateTime(new Date());
  421. orderInfo.setModTime(new Date());
  422. orderInfo.setPayMobile(loginUser.getMobile());
  423. orderInfo.setPayTransactionId("");
  424. orderInfo.setIsScan("0");//默认未扫描
  425. UserVo userVo = apiUserMapper.queryObject(orderInfo.getUser_id());
  426. orderInfo.setPayMobile(userVo.getMobile());
  427. orderInfo.setPay_name(userVo.getUsername());
  428. //标记该订单已使用优惠券
  429. if(couponVo != null){
  430. couponVo.setUsed_time(new Date());
  431. couponVo.setIsUsed(Dict.isUsed.item_1.getItem());
  432. apiUserCouponMapper.update(couponVo);
  433. }
  434. return orderInfo;
  435. }
  436. public OrderGoodsVo setOrderGoodsVo(OrderVo orderInfo,CartVo goodsItem,GoodsVo goodsVo){
  437. OrderGoodsVo orderGoodsVo = new OrderGoodsVo();
  438. orderGoodsVo.setOrder_id(orderInfo.getId());
  439. orderGoodsVo.setGoods_id(goodsItem.getGoods_id());
  440. orderGoodsVo.setGoods_sn(goodsItem.getGoods_sn());
  441. orderGoodsVo.setProduct_id(goodsItem.getProduct_id());
  442. orderGoodsVo.setGoods_name(goodsItem.getGoods_name());
  443. orderGoodsVo.setList_pic_url(goodsItem.getList_pic_url());
  444. orderGoodsVo.setMarket_price(goodsItem.getMarket_price());
  445. orderGoodsVo.setRetail_price(goodsItem.getRetail_price());
  446. orderGoodsVo.setNumber(goodsItem.getNumber());
  447. orderGoodsVo.setGoods_specification_name_value(goodsItem.getGoods_specification_name_value());
  448. orderGoodsVo.setGoods_specification_ids(goodsItem.getGoods_specification_ids());
  449. orderGoodsVo.setOrderBizType(goodsItem.getGoodsBizType());
  450. orderGoodsVo.setCreateTime(new Date());
  451. orderGoodsVo.setModTime(new Date());
  452. orderGoodsVo.setGoodsRate(goodsVo.getGoodsRate());
  453. BigDecimal number = new BigDecimal(Long.valueOf(goodsItem.getNumber()));
  454. BigDecimal goodsTotal = goodsItem.getRetail_price().multiply(number);//单商品总价
  455. BigDecimal rate = goodsTotal.divide(orderInfo.getGoods_price(),2, BigDecimal.ROUND_HALF_UP);//单商品总价/订单总价(不含运费、不含优惠券)
  456. BigDecimal freightPrice = BigDecimal.valueOf(orderInfo.getFreight_price());
  457. BigDecimal settlePrice = Constant.ZERO;
  458. if(orderInfo.getFreight_price()!=0 && !"0".equalsIgnoreCase(orderInfo.getCoupon_price()+"")){
  459. //运费-优惠券
  460. BigDecimal rateTotal = freightPrice.subtract(orderInfo.getCoupon_price());
  461. //商品结算平摊价格(含优惠券、运费金额) = 单商品总价 + 单商品总价/订单总价(不含运费、不含优惠券) * 运费与优惠券合计税率
  462. settlePrice = goodsTotal.add(rate.multiply(rateTotal));
  463. }else{
  464. if(orderInfo.getFreight_price()!=0){
  465. //运费税率 = 单商品总价/订单总价(不含运费)* 运费金额
  466. BigDecimal freightRate = rate.multiply(freightPrice);
  467. //商品结算平摊价格(含运费金额) = 单商品总价+运费税率
  468. settlePrice = goodsTotal.add(freightRate);
  469. }
  470. if(!"0".equalsIgnoreCase(orderInfo.getCoupon_price()+"")){
  471. //优惠券税率 = 单商品总价/订单总价(不含优惠券)* 优惠券金额
  472. BigDecimal couponRate = rate.multiply(orderInfo.getCoupon_price());
  473. //商品结算平摊价格(含优惠券金额) = 单商品总价-优惠券税率
  474. settlePrice = goodsTotal.subtract(couponRate);
  475. }
  476. }
  477. if(settlePrice.compareTo(BigDecimal.valueOf(0)) == 0){
  478. orderGoodsVo.setSettlePrice(goodsTotal);//商品结算平摊价格
  479. }else{
  480. orderGoodsVo.setSettlePrice(settlePrice);//商品结算平摊价格
  481. }
  482. orderGoodsVo.setSku(goodsVo.getSku());
  483. return orderGoodsVo;
  484. }
  485. /**
  486. * 支付成功通知
  487. */
  488. @Transactional
  489. public void notifyPaySuccess(OrderVo orderInfo) {
  490. WxTemplate tem = new WxTemplate();
  491. FormIdsEntity formIdsEntity = formIdsService.getFormIdsByMerchOrderSn(orderInfo.getMerchOrderSn());
  492. if (null == formIdsEntity || !StringUtils.isNotEmpty(formIdsEntity.getFormId())) {
  493. return;
  494. }
  495. if (orderInfo.getOrder_type().equals("1")) { // 订单类型 1:普通订单 2:团购订单
  496. TemplateConfVo templateConfVo = apiTemplateConfMapper.queryByTypeId(1); // 模板类型 1订单付款成功 2团购成功 3拼团失败通知 4拼团进度 5 6 7订单配送 8订单评价提醒
  497. if (null == templateConfVo) {
  498. return;
  499. }
  500. UserVo userVo = apiUserMapper.queryObject(orderInfo.getUser_id());
  501. tem.setTemplate_id(templateConfVo.getTemplateId());
  502. // tem.setTopcolor("#00DD00");
  503. tem.setTouser(userVo.getWeixin_openid());
  504. tem.setPage("/pages/ucenter/orderDetail/orderDetail?id=" + orderInfo.getId());
  505. tem.setForm_id(formIdsEntity.getFormId());
  506. List<TemplateData> paras = new ArrayList<TemplateData>();
  507. paras.add(new TemplateData("first", templateConfVo.getDesc(), "#000000"));
  508. paras.add(new TemplateData("keyword1", orderInfo.getMerchOrderSn(), "#000000"));
  509. //订单的商品
  510. Map orderGoodsParam = new HashMap();
  511. orderGoodsParam.put("order_id", orderInfo.getId());
  512. List<OrderGoodsVo> orderGoods = apiOrderGoodsMapper.queryList(orderGoodsParam);
  513. String body = "";
  514. if (null != orderGoods) {
  515. for (OrderGoodsVo goodsVo : orderGoods) {
  516. body = body + goodsVo.getGoods_name() + "、";
  517. }
  518. if (body.length() > 0) {
  519. body = body.substring(0, body.length() - 1);
  520. }
  521. }
  522. paras.add(new TemplateData("keyword2", body, "#000000"));
  523. paras.add(new TemplateData("keyword3", orderInfo.getActual_price().setScale(2, BigDecimal.ROUND_HALF_DOWN).toString(), "#000000"));
  524. paras.add(new TemplateData("keyword4", DateUtils.format(orderInfo.getAdd_time(), DateUtils.DATE_TIME_PATTERN), "#000000"));
  525. tem.setData(paras);
  526. }
  527. // TODO: 2018/10/25 暂时不实现团购订单
  528. /*if (orderInfo.getOrder_type().equals("2")) { // 订单类型 1:普通订单 2:团购订单
  529. TemplateConfVo templateConfVo = apiTemplateConfMapper.queryByTypeId(2); // 模板类型 1订单付款成功 2团购成功 3拼团失败通知 4拼团进度 5 6 7订单配送 8订单评价提醒
  530. if (null == templateConfVo) {
  531. return;
  532. }
  533. UserVo userVo = apiUserMapper.queryObject(orderInfo.getUser_id());
  534. // 团购明细
  535. GoodsGroupOpenDetailVo openDetailVo = apiGoodsGroupOpenDetailMapper.queryObject(orderInfo.getActivity_id());
  536. // 获取团购
  537. GoodsGroupOpenVo groupOpenVo = apiGoodsGroupOpenMapper.queryObject(openDetailVo.getOpen_id());
  538. tem.setTemplate_id(templateConfVo.getTemplateId());
  539. tem.setTopcolor("#00DD00");
  540. tem.setTouser(userVo.getWeixin_openid());
  541. tem.setPage("/pages/ucenter/orderDetail/orderDetail?id=" + orderInfo.getId());
  542. tem.setForm_id(formIdsEntity.getFormId());
  543. List<TemplateData> paras = new ArrayList<TemplateData>();
  544. paras.add(new TemplateData("keyword1", groupOpenVo.getTitle(), "#000000"));
  545. paras.add(new TemplateData("keyword2", DateUtils.format(groupOpenVo.getOpen_time(), DateUtils.DATE_TIME_PATTERN), "#000000"));
  546. //订单的商品
  547. Map orderGoodsParam = new HashMap();
  548. orderGoodsParam.put("order_id", orderInfo.getId());
  549. List<OrderGoodsVo> orderGoods = apiOrderGoodsMapper.queryList(orderGoodsParam);
  550. String body = "";
  551. if (null != orderGoods) {
  552. for (OrderGoodsVo goodsVo : orderGoods) {
  553. body = body + goodsVo.getGoods_name() + "、";
  554. }
  555. if (body.length() > 0) {
  556. body = body.substring(0, body.length() - 1);
  557. }
  558. }
  559. paras.add(new TemplateData("keyword3", body, "#000000"));
  560. // 团成员
  561. Map groupParam = new HashMap();
  562. groupParam.put("open_id", orderInfo.getActivity_id());
  563. List<GoodsGroupOpenDetailVo> openDetailVos = apiGoodsGroupOpenDetailMapper.queryList(groupParam);
  564. String attendMember = "";
  565. if (null != openDetailVos) {
  566. for (GoodsGroupOpenDetailVo detailVo : openDetailVos) {
  567. attendMember = attendMember + detailVo.getNickname() + "、";
  568. }
  569. if (attendMember.length() > 0) {
  570. attendMember = attendMember.substring(0, attendMember.length() - 1);
  571. }
  572. }
  573. paras.add(new TemplateData("keyword4", attendMember, "#000000"));
  574. paras.add(new TemplateData("keyword5", orderInfo.getActual_price().setScale(2, BigDecimal.ROUND_HALF_DOWN).toString(), "#000000"));
  575. paras.add(new TemplateData("keyword5", templateConfVo.getDesc(), "#000000"));
  576. tem.setData(paras);
  577. }*/
  578. try {
  579. // WxTemplateUtil.sendMessage(tem);
  580. formIdsService.releaseFormIds(formIdsEntity);
  581. } catch (Exception e) {
  582. e.printStackTrace();
  583. }
  584. }
  585. /**
  586. * 确认收货
  587. *
  588. * @param orderId
  589. */
  590. @Transactional
  591. public void confirmOrder(Long orderId) {
  592. OrderVo orderVo = apiOrderMapper.queryObject(orderId);
  593. orderVo.setOrder_status(301);
  594. orderVo.setShipping_status(2);
  595. orderVo.setConfirm_time(new Date());
  596. orderVo.setModTime(new Date());
  597. apiOrderMapper.update(orderVo);
  598. }
  599. /*public String printMsgs(Long orderId) {
  600. OrderVo orderEntity = queryObject(orderId);
  601. Map<String, Object> map = new HashMap<String, Object>();
  602. map.put("order_id", orderEntity.getId());
  603. List<OrderGoodsVo> orderGoodsEntities = apiOrderGoodsMapper.queryList(map);
  604. UserVo userVo = apiUserMapper.queryObject(orderEntity.getUser_id());
  605. String content = "<CB>商城超市</CB><BR>";
  606. content += "名称/商品编码 单价 数量 金额<BR>";
  607. for (OrderGoodsVo orderGoodsEntity : orderGoodsEntities) {
  608. content += "--------------------------------<BR>";
  609. content += orderGoodsEntity.getGoods_name() + "<BR>" + orderGoodsEntity.getGoods_sn() + " " + orderGoodsEntity.getRetail_price() + " " + orderGoodsEntity.getNumber()
  610. + " " + orderGoodsEntity.getRetail_price().multiply(new BigDecimal(orderGoodsEntity.getNumber())) + "<BR>";
  611. }
  612. content += "--------------------------------<BR>";
  613. content += "备注:" + orderEntity.getPostscript() + "<BR>";
  614. content += "--------------------------------<BR>";
  615. content += "订单编号:" + orderEntity.getOrder_sn() + "<BR>";
  616. content += "配送配用:" + orderEntity.getShipping_fee() + "元<BR>";
  617. content += "优惠价格:" + orderEntity.getCoupon_price() + "元<BR>";
  618. content += "合计:" + orderEntity.getOrder_price() + "元<BR>";
  619. content += "实付:" + orderEntity.getActual_price() + "元<BR>";
  620. content += "姓名:" + null != userVo.getNickname() ? userVo.getNickname() : "" + "<BR>";
  621. content += "送货地点:" + orderEntity.getProvince() + orderEntity.getCity() + orderEntity.getDistrict() + orderEntity.getAddress() + "<BR>";
  622. content += "联系电话:" + orderEntity.getMobile() + "<BR>";
  623. content += "付款时间:" + DateUtils.format(orderEntity.getPay_time(), DateUtils.DATE_TIME_PATTERN) + "<BR>";
  624. content += "<QR>" + orderEntity.getId() + "</QR>";
  625. if ("2".equals(orderEntity.getOrder_type())) {
  626. content += "<RIGHT><BOLD>【团购】</BOLD></RIGHT>";
  627. }
  628. //所属门店
  629. Long storeId = orderEntity.getStore_id();
  630. //获取门店的打印机编号,每个门店只有一个打票机
  631. Map<String, Object> printParams = new HashMap<String, Object>();
  632. List<SysPrinterVo> printerEntities = apiSysPrinterMapper.queryList(printParams);
  633. printParams.put("storeId", storeId);
  634. String sn = "";
  635. if (printerEntities != null && printerEntities.size() != 0) {
  636. sn = printerEntities.get(0).getSn();
  637. }
  638. return FeiGeUtils.printMsg(sn, content, "1");
  639. }*/
  640. public Ticket printMsg(Long orderId) {
  641. OrderVo orderEntity = queryObject(orderId);
  642. if(orderEntity != null) {
  643. if (orderEntity.getOrderBizType().equalsIgnoreCase(Dict.orderBizType.item_10.getItem())
  644. || orderEntity.getOrderBizType().equalsIgnoreCase(Dict.orderBizType.item_02.getItem())) {
  645. Map<String, Object> map = new HashMap<String, Object>();
  646. map.put("order_id", orderEntity.getId());
  647. List<OrderGoodsVo> orderGoodsEntityList = apiOrderGoodsMapper.queryList(map);
  648. // 获取门店
  649. StoreVo storeEntity = apiStoreMapper.queryObject(orderEntity.getStore_id());
  650. // 获取清关信息
  651. OrderProcessRecordEntity orderProcessRecordEntity = orderProcessRecordMapper.queryObjectByOrderSn(orderEntity.getOrder_sn());
  652. UserVo userVo = apiUserMapper.queryObject(orderEntity.getUser_id());
  653. // 小票头
  654. TicketHead head = new TicketHead();
  655. head.setTitle(OmsMerchPropertiesBuilder.instance().getMerchName() + storeEntity.getStoreName());
  656. head.setMemberId(userVo.getUsername().toString());
  657. head.setOrderId(orderEntity.getOrder_sn());
  658. head.setTradeTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss EEE").format(new Date()));
  659. // 商品信息
  660. Integer goodsTotal = 0; // 商品总个数
  661. BigDecimal total = Constant.ZERO; // 商品总计
  662. List<Goods> goodsList = new ArrayList<>();
  663. for (OrderGoodsVo orderGoods : orderGoodsEntityList) {
  664. goodsTotal += orderGoods.getNumber();
  665. total = total.add(orderGoods.getRetail_price().subtract(new BigDecimal(orderGoods.getNumber()))).setScale(2, BigDecimal.ROUND_HALF_UP);
  666. Goods goods = new Goods(orderGoods.getGoods_name(), orderGoods.getRetail_price().toString(), orderGoods.getNumber().toString(),
  667. orderGoods.getRetail_price().multiply(new BigDecimal(orderGoods.getNumber()).setScale(2, BigDecimal.ROUND_HALF_UP)).toString());
  668. goodsList.add(goods);
  669. }
  670. // 收银信息
  671. CashInfo cashInfo = new CashInfo();
  672. cashInfo.setGoodsTotal(goodsTotal.toString());
  673. cashInfo.setTotal(total.setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  674. cashInfo.setReceipts(orderEntity.getActual_price().setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  675. cashInfo.setOddChange("0.00");
  676. cashInfo.setCoupon(orderEntity.getCoupon_price().setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  677. cashInfo.setFreight(new BigDecimal(orderEntity.getFreight_price()).setScale(2, BigDecimal.ROUND_HALF_UP).toString());
  678. cashInfo.setPaymentMode("微信支付");
  679. // 海关清单
  680. CusListing cusListing = new CusListing();
  681. cusListing.setOrderId(orderEntity.getOrder_sn());
  682. cusListing.setWaybillId(orderProcessRecordEntity.getLogisticsNo());
  683. cusListing.setInvtNo(orderProcessRecordEntity.getInvtNo());
  684. cusListing.setConsignee(orderEntity.getConsignee());
  685. cusListing.setConsigneeTel(orderEntity.getMobile());
  686. cusListing.setOriginAddress(PrintTicketPropertiesBuilder.instance().getAddress());
  687. cusListing.setDeliveryAddress(storeEntity.getStoreAddress());
  688. return TicketPrintUtil.print(head, goodsList, cashInfo, cusListing);
  689. }else{
  690. return null;
  691. }
  692. }else{
  693. return null;
  694. }
  695. }
  696. public List<OrderVo> queryObjectByIdList(List<Long> orderIdList){
  697. return apiOrderMapper.queryObjectByIdList(orderIdList);
  698. }
  699. public List<OrderVo> queryObjectByMerchOrderSn(String merchOrderSn){
  700. return apiOrderMapper.queryObjectByMerchOrderSn(merchOrderSn);
  701. }
  702. public int queryCountByMerchOrderSn(String merchOrderSn){
  703. return apiOrderMapper.queryCountByMerchOrderSn(merchOrderSn);
  704. }
  705. public int queryCountByPayId(String payId){
  706. return apiOrderMapper.queryCountByPayId(payId);
  707. }
  708. public List<OrderVo> queryOrderByMerchOrderSnAndRefundStatus(String merchOrderSn){
  709. return apiOrderMapper.queryOrderByMerchOrderSnAndRefundStatus(merchOrderSn);
  710. }
  711. }