From fbfd01086ad9dc0c710ebc3eee3bdf5499a07091 Mon Sep 17 00:00:00 2001 From: JiangYouYao <ak473600000> Date: Fri, 18 Mar 2022 09:33:23 +0800 Subject: [PATCH] 重构:订单取消逻辑 --- zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceImpl.java | 350 ++++++++++++++++------------------------------------------ 1 files changed, 97 insertions(+), 253 deletions(-) diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceImpl.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceImpl.java index 72f57c1..def632f 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceImpl.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceImpl.java @@ -34,8 +34,6 @@ import com.matrix.system.hive.plugin.util.CollectionUtils; import com.matrix.system.hive.plugin.util.MoneyUtil; import com.matrix.system.hive.pojo.CzXkVo; -import com.matrix.system.hive.pojo.ShoppingCarItem; -import com.matrix.system.hive.pojo.ShoppingCarItemsVo; import com.matrix.system.hive.service.*; import com.matrix.system.score.service.ScoreVipDetailService; import com.matrix.system.shopXcx.mqTask.AsyncMessageRouting; @@ -44,7 +42,6 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import javax.servlet.http.HttpSession; import javax.validation.constraints.NotEmpty; import java.math.BigDecimal; import java.util.*; @@ -61,6 +58,7 @@ private SysOrderItemDao orderItemDao; @Autowired private SysProjUseDao sysProjUseDao; + private SysProjUseService sysProjUseService; @Autowired @@ -175,217 +173,110 @@ public void cancelOrder(Long id) { SysOrder order = sysOrderDao.selectById(id); - SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); + if (order.getStatu().equals(Dictionary.ORDER_STATU_DFK)) { - - order.setStatu(Dictionary.ORDER_STATU_YQX); - order.setArrears(0D); - - //发送微信公众号提醒 - UniformMsgParam uniformMsgParam = new UniformMsgParam(order.getCompanyId(), UniformMsgParam.GZH_DDQX); - uniformMsgParam.put("orderId", order.getId()); - asyncMessageManager.sendMsg(AsyncMessageRouting.SEND_UNIFORM_TEMPLATE_MSG, uniformMsgParam); - - sysOrderDao.update(order); - //保存单据日志 - operationLogService.saveOperation(order.getCompanyId(), order.getShopId(), sysUsers.getSuId(), - OperationFunctionEnum.ORDER, - OperationButtonEnum.CANCEL, - order.getId(), - order.getOrderNo(), - order.getVipId(), - "未付款取消订单"); + //待付款订单取消 + cancelDFKOrder(order); } else { + //已付款订单取消 + cancelYFKOrder(order); + } + } - //一个订单只能被取消一次 - if (Dictionary.ORDER_STATU_YQX.equals(order.getStatu())) { - throw new GlobleException("订单已取消"); - } - - List<SysOrderFlow> flows = sysOrderFlowDao.selectByOrderId(id); - // 非现金收款退回扣卡余额 - for (SysOrderFlow flow : flows) { - if (SysOrderFlow.PAY_METHOD_CARD.equals(flow.getPayMethod())) { - - MoneyCardUse moneyCardUse = moneyCardUseDao.selectById(flow.getCardId()); - MoneyCardUseFlow moneyCardUseFlow = new MoneyCardUseFlow(); - - if (moneyCardUse != null) { - // 根据订单明细判断是赠送金额购买还是本金购买 - moneyCardUseFlow.setTotal(flow.getAmount().doubleValue()); - if (SysOrderFlow.IS_GIFT_Y.equals(flow.getIsGift())) { - moneyCardUse.setGiftMoney(MoneyUtil.add(moneyCardUse.getGiftMoney(), flow.getAmount().doubleValue())); - } else { - moneyCardUse.setRealMoney(MoneyUtil.add(moneyCardUse.getRealMoney(), flow.getAmount().doubleValue())); - } - - if (!moneyCardUse.getIsVipCar().equals(Dictionary.FLAG_YES_Y)) { - if (moneyCardUse.getLastCount() != null) { - moneyCardUse.setLastCount(moneyCardUse.getLastCount() + 1); - moneyCardUseFlow.setTimes(1); - } - } - moneyCardUseDao.update(moneyCardUse); - //插入充值卡变动流水 - SysUsers user = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - moneyCardUseFlow.setOrderNo(order.getOrderNo()); - moneyCardUseFlow.setCarUseId(moneyCardUse.getId()); - moneyCardUseFlow.setVipId(order.getVipId()); - moneyCardUseFlow.setType(MoneyCardUseFlow.USE_TYPE_ORDRE_CANCEL); - moneyCardUseFlow.setCreateTime(new Date()); - moneyCardUseFlow.setOperationId(user.getSuId()); - moneyCardUseFlow.setContent(moneyCardUse.getChangeRemark()); - moneyCardUseFlow.setBalance(moneyCardUse.getGiftMoney() + moneyCardUse.getRealMoney()); - moneyCardUseFlowDao.insert(moneyCardUseFlow); - } - } - } - - List<SysOrderItem> sysOrderItems = orderItemDao.selectByOrderId(id); - for (SysOrderItem orderItem : sysOrderItems) { - // 充值卡类型退款 - if (Dictionary.SHOPPING_GOODS_TYPE_CZK.equals(orderItem.getType())) { - ShoppingGoods shoppingGoods = shoppingGoodsDao.selectById(orderItem.getGoodsId()); - //删除购买的充值卡 - moneyCardUseDao.deleteByOrderItemId(orderItem.getId()); - } else if (Dictionary.SHOPPING_GOODS_TYPE_XM.equals(orderItem.getType()) - || Dictionary.SHOPPING_GOODS_TYPE_TC.equals(orderItem.getType())) { - // 项目套餐退款 - // 删除套餐项目使用情况 - sysProjUseDao.deleteByOrderItemId(orderItem.getId()); - } else if (Dictionary.SHOPPING_GOODS_TYPE_ZHK.equals(orderItem.getType())) { - // 综合卡 - // 删除套餐项目使用情况 - sysProjUseDao.deleteByOrderItemId(orderItem.getId()); - // 删除充值卡 - moneyCardUseDao.deleteByOrderItemId(orderItem.getId()); - } - } - - //删除出库单,恢复库存 - SysOutStore sysOutStore = new SysOutStore(); - sysOutStore.setOrderId(order.getId()); - List<SysOutStore> sysOutStores = sysOutStoreDao.selectByModel(sysOutStore); - if (sysOutStores.size() == 1) { - sysOutStore = sysOutStores.get(0); - List<SysOutStoreItem> outStoreItemList = sysOutStoreItemDao.selectByOrderId(sysOutStore.getId()); - for (SysOutStoreItem item : outStoreItemList) { - SysStoreInfo sysStoreInfo = storeInfoDao.selectById(item.getStoreId()); - sysStoreInfo.setStoreTotal(sysStoreInfo.getStoreTotal() + item.getAmount()); - //更新库存 - storeInfoDao.update(sysStoreInfo); - } - sysOutStoreDao.deleteById(sysOutStore.getId()); - sysOutStoreItemDao.deleteByOrderId(sysOutStore.getId()); - } - // 删除业绩 - AchieveNew achieveNew = new AchieveNew(); - achieveNew.setOrderId(id); - achieveNewService.removeByModel(achieveNew); - - // 删除收款记录 - sysOrderFlowDao.deleteByOrderId(id); - - //删除积分 - scoreVipDetailService.removeByBusinessId(order.getVipId(), order.getId()); - - // 取消订单 - order.setStatu(Dictionary.ORDER_STATU_YQX); - sysOrderDao.update(order); - //保存单据日志 - operationLogService.saveOperation(order.getCompanyId(), order.getShopId(), sysUsers.getSuId(), - OperationFunctionEnum.ORDER, - OperationButtonEnum.CANCEL, - order.getId(), - order.getOrderNo(), - order.getVipId(), - "已付款取消订单"); + /** + * 已付款订单取消 + * @param order + */ + private void cancelYFKOrder(SysOrder order) { + SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); + //一个订单只能被取消一次 + if (Dictionary.ORDER_STATU_YQX.equals(order.getStatu())) { + throw new GlobleException("订单已取消"); } + //储值卡退款 + sysOrderServiceHelper.returnMoneyCardPay(order); + + List<SysOrderItem> sysOrderItems = orderItemDao.selectByOrderId(order.getId()); + for (SysOrderItem orderItem : sysOrderItems) { + // 充值卡类型退款 + if (Dictionary.SHOPPING_GOODS_TYPE_CZK.equals(orderItem.getType())) { + //删除购买的充值卡 + moneyCardUseService.deleteByOrderItemId(orderItem.getId()); + } else if (Dictionary.SHOPPING_GOODS_TYPE_XM.equals(orderItem.getType()) + || Dictionary.SHOPPING_GOODS_TYPE_TC.equals(orderItem.getType())) { + // 项目套餐退款 + // 删除套餐项目使用情况 + sysProjUseService.deleteByOrderItemId(orderItem.getId()); + } + } + + //删除出库单,恢复库存 + SysOutStore sysOutStore = new SysOutStore(); + sysOutStore.setOrderId(order.getId()); + List<SysOutStore> sysOutStores = sysOutStoreDao.selectByModel(sysOutStore); + if (sysOutStores.size() == 1) { + sysOutStore = sysOutStores.get(0); + List<SysOutStoreItem> outStoreItemList = sysOutStoreItemDao.selectByOrderId(sysOutStore.getId()); + for (SysOutStoreItem item : outStoreItemList) { + SysStoreInfo sysStoreInfo = storeInfoDao.selectById(item.getStoreId()); + sysStoreInfo.setStoreTotal(sysStoreInfo.getStoreTotal() + item.getAmount()); + //更新库存 + storeInfoDao.update(sysStoreInfo); + } + sysOutStoreDao.deleteById(sysOutStore.getId()); + sysOutStoreItemDao.deleteByOrderId(sysOutStore.getId()); + } + + // 删除业绩 + AchieveNew achieveNew = new AchieveNew(); + achieveNew.setOrderId(order.getId()); + achieveNewService.removeByModel(achieveNew); + + // 删除收款记录 + sysOrderFlowDao.deleteByOrderId(order.getId()); + + //删除积分 + scoreVipDetailService.removeByBusinessId(order.getVipId(), order.getId()); + + // 取消订单 + order.setStatu(Dictionary.ORDER_STATU_YQX); + sysOrderDao.update(order); + //保存单据日志 + operationLogService.saveOperation(order.getCompanyId(), order.getShopId(), sysUsers.getSuId(), + OperationFunctionEnum.ORDER, + OperationButtonEnum.CANCEL, + order.getId(), + order.getOrderNo(), + order.getVipId(), + "已付款取消订单"); } - /** - * 创建订单 lk + * 待付款订单取消 + * @param order */ - @Override - @Transactional(rollbackFor = Exception.class) - public int createOrder(HttpSession session, ShoppingCarItemsVo car) { + private void cancelDFKOrder(SysOrder order) { - if (car.getCarItems().size() < 1) { - throw new GlobleException("没用选择购买产品"); - } - // 获取会员信息,判断等级 获取相应家居折扣 - SysVipInfo info = sysVipInfoDao.selectById(car.getVipId()); + SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); + order.setStatu(Dictionary.ORDER_STATU_YQX); + order.setArrears(0D); - //获取折扣----- - Double zk = zk = 1.0; + //发送微信公众号提醒 + UniformMsgParam uniformMsgParam = new UniformMsgParam(order.getCompanyId(), UniformMsgParam.GZH_DDQX); + uniformMsgParam.put("orderId", order.getId()); + asyncMessageManager.sendMsg(AsyncMessageRouting.SEND_UNIFORM_TEMPLATE_MSG, uniformMsgParam); - SysOrder order = new SysOrder(); - SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY); - order.setShopId(user.getShopId()); - order.setOrderNo(codeService.getOrderCode()); - order.setVipId(info.getId()); - order.setOrderTime(new Date()); - order.setRemark(car.getRemark()); - order.setStaffId(user.getSuId()); - order.setIsCross(2 + ""); - order.setChangeId(car.getChangeId()); - order.setStatu(Dictionary.ORDER_STATU_DFK); - order.setCardPay(0.00); - order.setCashPay(0.00); - order.setCompanyId(user.getCompanyId()); - order.setBeatuyId(car.getBeatuyId() + ""); - // 根据美疗师id查询美疗师姓名 - if (car.getBeatuyId() != null) { - String beatuyName = shopStaffInfoDao.selectById(car.getBeatuyId()).getSuName(); - System.out.println("美疗师:" + beatuyName); - order.setBeatuyName(beatuyName); - } - int i = sysOrderDao.insert(order); - // 创建订单明细,并计算总价与折扣总价 - // 总价 - double total = 0; - double zkTotal = 0; - int count = 0; - // 设置订单条目 - for (ShoppingCarItem carItem : car.getCarItems()) { - - SysOrderItem orderItem = new SysOrderItem(); - orderItem.setOrderId(order.getId()); - orderItem.setCount(carItem.getCount()); - orderItem.setIsFree(carItem.getIsFree()); - orderItem.setType(carItem.getType()); - orderItem.setStatus(Dictionary.ORDER_STATU_DFK); - // 新增明细 - // 设置商品id - orderItem.setGoodsId(carItem.getGoodsId()); - // 设置assembleId - orderItem.setAssembleId(carItem.getAssembleId()); - // 如果是家居产品的话,要取出组合sku中的价格 - double p = carItem.getShoppingGoods().getSealPice(); - orderItem.setPrice(p); - if (carItem.getIsFree().equals(Dictionary.FLAG_NO)) { - orderItem.setZkPrice(MoneyUtil.mul(p, zk)); - } else { - // 如果是免费,则设置为0.0 - orderItem.setZkPrice(0.0); - } - - - orderItemDao.insert(orderItem); - total = MoneyUtil.add(total, - MoneyUtil.mul(orderItem.getPrice(), Double.parseDouble(carItem.getCount() + ""))); - zkTotal = MoneyUtil.add(zkTotal, - MoneyUtil.mul(orderItem.getZkPrice(), Double.parseDouble(carItem.getCount() + ""))); - } - - // 设置订单总价与折后价 - order.setTotal(total); - order.setZkTotal(zkTotal); sysOrderDao.update(order); - return i; + //保存单据日志 + operationLogService.saveOperation(order.getCompanyId(), order.getShopId(), sysUsers.getSuId(), + OperationFunctionEnum.ORDER, + OperationButtonEnum.CANCEL, + order.getId(), + order.getOrderNo(), + order.getVipId(), + "未付款取消订单"); } @@ -397,7 +288,7 @@ public void updateReceiptMoney(SysOrder pageOrder) throws GlobleException { //校验订单是否满足收款条件 - checkOrder(pageOrder); + checkOrderAblePay(pageOrder); // 更新订单主表信息 updateOrderInfo(pageOrder); @@ -494,7 +385,11 @@ } - private void checkOrder(SysOrder pageOrder) { + /** + * 检查订单是否满足支付条件 + * @param pageOrder + */ + private void checkOrderAblePay(SysOrder pageOrder) { SysOrder checkOrder = sysOrderDao.selectById(pageOrder.getId()); @@ -797,54 +692,7 @@ } - private void refundCard(MoneyCardUse moneyCardUse, SysOrder sourceOrder, SysOrderFlow flow) { - SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY); - MoneyCardUseFlow moneyCardUseFlow = new MoneyCardUseFlow(); - if (SysOrderFlow.IS_GIFT_Y.equals(flow.getIsGift())) { - if (moneyCardUse.getGiftMoney() >= flow.getAmount().doubleValue()) { - double surplus = MoneyUtil.sub(moneyCardUse.getGiftMoney(), flow.getAmount().doubleValue()); - moneyCardUse.setGiftMoney(surplus); - moneyCardUseFlow.setGiftMoney(0D - flow.getAmount().doubleValue()); - } else { - throw new GlobleException(moneyCardUse.getCardName() + "余额不足"); - } - } else { - if (moneyCardUse.getRealMoney() >= flow.getAmount().doubleValue()) { - double surplus = MoneyUtil.sub(moneyCardUse.getRealMoney(), flow.getAmount().doubleValue()); - moneyCardUse.setRealMoney(surplus); - moneyCardUseFlow.setTotal(0 - flow.getAmount().doubleValue()); - } else { - throw new GlobleException(moneyCardUse.getCardName() + "余额不足"); - } - } - - if (moneyCardUse.getIsVipCar().equals(Dictionary.FLAG_NO_N)) { - //余额为0时充值卡变为无效 - if (moneyCardUse.getRealMoney().equals(0D) && moneyCardUse.getGiftMoney().equals(0D)) { - moneyCardUse.setIsOver(Dictionary.FLAG_YES_Y); - moneyCardUse.setStatus(Dictionary.MONEYCARD_STATUS_WX); - } - } - - ShoppingGoods shoppingGoods = shoppingGoodsService.findById(moneyCardUse.getGoodsId()); - if (shoppingGoods != null) { - Date invalidTime = shoppingGoodsService.calInvalidTime(shoppingGoods, 2, moneyCardUse.getFailTime()); - moneyCardUse.setFailTime(invalidTime); - } - // 更新充值卡信息 - moneyCardUseDao.update(moneyCardUse); - //设置卡项使用流水 - moneyCardUseFlow.setCarUseId(moneyCardUse.getId()); - moneyCardUseFlow.setOrderNo(sourceOrder.getOrderNo()); - moneyCardUseFlow.setVipId(sourceOrder.getVipId()); - moneyCardUseFlow.setTimes(-1); - moneyCardUseFlow.setType(MoneyCardUseFlow.USE_TYPE_CONSUMER); - moneyCardUseFlow.setCreateTime(new Date()); - moneyCardUseFlow.setOperationId(user.getSuId()); - moneyCardUseFlow.setBalance(moneyCardUse.getGiftMoney() + moneyCardUse.getRealMoney()); - moneyCardUseFlowDao.insert(moneyCardUseFlow); - } /** * 退款退项目,套餐,卡项 @@ -923,10 +771,6 @@ } } - // TODO 综合卡退款 - if (Dictionary.SHOPPING_GOODS_TYPE_ZHK.equals(item.getType())) { - - } ShoppingGoods goods = shoppingGoodsDao.selectById(item.getGoodsId()); -- Gitblit v1.9.1