ApiOrderService.java 31 KB

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