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/SysOrderServiceHelper.java | 49 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 49 insertions(+), 0 deletions(-) diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceHelper.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceHelper.java index fc54596..ce4c734 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceHelper.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceHelper.java @@ -241,6 +241,45 @@ } } + + /** + * 储值卡退款 + * @param order + */ + public void returnMoneyCardPay(SysOrder order) { + SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY); + List<MoneyCardPayDto> moneyCardPayDtoList = Lists.newArrayList(); + + List<SysOrderFlow> flows = sysOrderFlowDao.selectByOrderId(order.getId()); + // 非现金收款退回扣卡余额 + for (SysOrderFlow flow : flows) { + if (SysOrderFlow.PAY_METHOD_CARD.equals(flow.getPayMethod())) { + if (flow.getCardId() != null) { + MoneyCardPayDto dto = new MoneyCardPayDto(); + dto.setOrderNo(order.getOrderNo()); + dto.setOrderId(order.getId()); + dto.setCount(1); + dto.setCarUseId(flow.getCardId()); + dto.setType(MoneyCardUseFlow.USE_TYPE_ORDRE_CANCEL); + if (SysOrderFlow.IS_GIFT_Y.equals(flow.getIsGift())) { + dto.setGiftMoney(flow.getAmount().doubleValue()); + } else { + dto.setRealMoney(flow.getAmount().doubleValue()); + } + dto.setUpdateUser(user.getSuId()); + moneyCardPayDtoList.add(dto); + } else { + throw new GlobleException("无效的储值卡支付方式"); + } + } + } + + if (CollectionUtils.isNotEmpty(moneyCardPayDtoList)) { + LogUtil.info("退回储值卡余额{}", JSON.toJSONString(moneyCardPayDtoList)); + moneyCardUseService.changeMoneyCard(moneyCardPayDtoList); + } + } + /** * @param sourceOrder 如果购买了充值卡设置会员的充值卡 * @author:姜友瑶 @@ -629,6 +668,16 @@ sysOrderItem.setOrderId(sysOrder.getId()); orderItemDao.insert(sysOrderItem); }); + + SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY); + //保存单据日志 + operationLogService.saveOperation(sysOrder.getCompanyId(), sysOrder.getShopId(), user.getSuId(), + OperationFunctionEnum.ORDER, + OperationButtonEnum.UPDATE, + sysOrder.getId(), + sysOrder.getOrderNo(), + sysOrder.getVipId()); + return sysOrder; } } \ No newline at end of file -- Gitblit v1.9.1