ApiOrderService.java 36 KB

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