From e1ff283be2a6ca6ed8cead6248b4efa8eb005f6e Mon Sep 17 00:00:00 2001
From: JiangYouYao <ak473600000>
Date: Fri, 18 Mar 2022 13:51:29 +0800
Subject: [PATCH] 重构:订单取消逻辑

---
 zq-erp/src/main/java/com/matrix/system/hive/service/MoneyCardUseService.java         |    3 
 zq-erp/src/main/java/com/matrix/system/hive/service/SysOrderService.java             |    7 -
 zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOutStoreServiceImpl.java  |   29 ++++-
 zq-erp/src/main/java/com/matrix/system/hive/action/MoneyCardUseController.java       |    3 
 zq-erp/src/main/java/com/matrix/system/hive/action/OrderController.java              |    4 
 zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceHelper.java   |   44 ++++++++
 zq-erp/src/main/java/com/matrix/system/hive/bean/SysOrder.java                       |    2 
 zq-erp/src/main/java/com/matrix/system/hive/service/imp/MoneyCardUseServiceImpl.java |   15 +++
 zq-erp/src/main/java/com/matrix/system/hive/service/imp/AchieveNewServiceImpl.java   |    5 +
 zq-erp/src/main/java/com/matrix/system/hive/service/SysOutStoreService.java          |   14 ++
 zq-erp/src/main/java/com/matrix/system/hive/service/AchieveNewService.java           |    1 
 zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceImpl.java     |  143 ++++++----------------------
 12 files changed, 136 insertions(+), 134 deletions(-)

diff --git a/zq-erp/src/main/java/com/matrix/system/hive/action/MoneyCardUseController.java b/zq-erp/src/main/java/com/matrix/system/hive/action/MoneyCardUseController.java
index 09274b6..d82f7e1 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/action/MoneyCardUseController.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/action/MoneyCardUseController.java
@@ -2,7 +2,6 @@
 
 import com.matrix.component.asyncmessage.AsyncMessageManager;
 import com.matrix.core.constance.MatrixConstance;
-import com.matrix.core.exception.GlobleException;
 import com.matrix.core.pojo.AjaxResult;
 import com.matrix.core.pojo.PaginationVO;
 import com.matrix.core.tools.WebUtil;
@@ -87,7 +86,7 @@
     @RequestMapping(value = "/cz")
     public @ResponseBody
     AjaxResult cz(@RequestBody CzXkVo czVo) {
-        SysOrder order=  orderService.updateAddCardMoney(czVo);
+        SysOrder order=  orderService.moneyCardCz(czVo);
         AjaxResult result = new AjaxResult(AjaxResult.STATUS_SUCCESS, "充值成功");
 
         //发送微信公众号提醒
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/action/OrderController.java b/zq-erp/src/main/java/com/matrix/system/hive/action/OrderController.java
index c31ba85..2f6ffce 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/action/OrderController.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/action/OrderController.java
@@ -149,7 +149,7 @@
         sysOrder.setIsHasRefund(SysOrder.IS_HAS_REFUND_N);
         //校验订单是否满足结算调价,新订单则保存订单,已有订单则删除后更新
         sysOrder = orderService.checkAndSaveOrder(sysOrder);
-        orderService.updateReceiptMoney(sysOrder);
+        orderService.payOrder(sysOrder);
 
         //发送微信公众号提醒
         UniformMsgParam uniformMsgParam = new UniformMsgParam(user.getCompanyId(), UniformMsgParam.GZH_GMCG);
@@ -259,7 +259,7 @@
     @RequestMapping(value = "/sk")
     public @ResponseBody
     AjaxResult sk(SysOrder order) throws GlobleException {
-        orderService.updateReceiptMoney(order);
+        orderService.payOrder(order);
         return new AjaxResult(AjaxResult.STATUS_SUCCESS, "收款成功");
     }
 
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/bean/SysOrder.java b/zq-erp/src/main/java/com/matrix/system/hive/bean/SysOrder.java
index 62d0769..b61dbf9 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/bean/SysOrder.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/bean/SysOrder.java
@@ -26,6 +26,8 @@
 	 */
 	public static final int ORDER_TYPE_REFUND= 2;
 
+
+
 	/**
 	 * 序号
 	 */
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/AchieveNewService.java b/zq-erp/src/main/java/com/matrix/system/hive/service/AchieveNewService.java
index 0698dac..2de24d1 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/service/AchieveNewService.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/service/AchieveNewService.java
@@ -121,4 +121,5 @@
 	List<DailyBeautyListVo> findDailyBeautyList(AchieveNew achieveNew, PaginationVO pageVo);
 	int findDailyBeautyListTotal(AchieveNew achieveNew);
 
+    void removeByOrderId(Long id);
 }
\ No newline at end of file
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/MoneyCardUseService.java b/zq-erp/src/main/java/com/matrix/system/hive/service/MoneyCardUseService.java
index b70f7e7..ed99cd5 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/service/MoneyCardUseService.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/service/MoneyCardUseService.java
@@ -5,6 +5,7 @@
 import com.matrix.system.hive.dto.MoneyCardOperationDto;
 import com.matrix.system.hive.dto.MoneyCardPayDto;
 import com.matrix.system.hive.plugin.util.BaseServices;
+import com.matrix.system.hive.pojo.CzXkVo;
 
 import java.util.List;
 
@@ -135,4 +136,6 @@
      * @param id
      */
     void deleteByOrderItemId(Long id);
+
+    void vipCardRecharge(CzXkVo czVo);
 }
\ No newline at end of file
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/SysOrderService.java b/zq-erp/src/main/java/com/matrix/system/hive/service/SysOrderService.java
index 83a8ada..42f6e71 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/service/SysOrderService.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/service/SysOrderService.java
@@ -80,7 +80,7 @@
 	* @date 2016年7月18日 上午11:14:07
 	* @throws
 	 */
-	public void updateReceiptMoney(SysOrder sysOrder) throws GlobleException;
+	public void payOrder(SysOrder sysOrder) throws GlobleException;
 
 	public void refundOrderMoney(SysOrder sysOrder);
 
@@ -100,10 +100,7 @@
 	* @date 2016年9月20日 下午12:07:21
 	* @throws
 	 */
-	public SysOrder updateAddCardMoney(CzXkVo czVo);
-
-
-
+	public SysOrder moneyCardCz(CzXkVo czVo);
 
 	/**
 	 * 校验订单是否满足结算条件
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/SysOutStoreService.java b/zq-erp/src/main/java/com/matrix/system/hive/service/SysOutStoreService.java
index b0a096a..cd13e5f 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/service/SysOutStoreService.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/service/SysOutStoreService.java
@@ -61,11 +61,19 @@
 	 */
 	public SysOutStore  findById(Long id);
 
+
 	/**
-	 * 出库单审核通过,并扣减库存
-	 * @param sysOutStore
-	 * @return
+	 * 删除出库单,恢复库存
+	 * @param id
 	 */
+	public void cancelOutStore(Long id);
+
+
+		/**
+         * 出库单审核通过,并扣减库存
+         * @param sysOutStore
+         * @return
+         */
 	public int effectOutStore(SysOutStore sysOutStore);
 
    	
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/AchieveNewServiceImpl.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/AchieveNewServiceImpl.java
index f32259e..66890ed 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/AchieveNewServiceImpl.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/AchieveNewServiceImpl.java
@@ -489,4 +489,9 @@
     public int findDailyBeautyListTotal(AchieveNew achieveNew) {
         return achieveNewDao.selectDailyBeautyListTotal(achieveNew);
     }
+
+    @Override
+    public void removeByOrderId(Long orderId) {
+        achieveNewDao.deleteByOrderId(orderId);
+    }
 }
\ No newline at end of file
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/MoneyCardUseServiceImpl.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/MoneyCardUseServiceImpl.java
index 40b1c48..5a7e799 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/MoneyCardUseServiceImpl.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/MoneyCardUseServiceImpl.java
@@ -16,6 +16,7 @@
 import com.matrix.system.hive.dto.MoneyCardOperationDto;
 import com.matrix.system.hive.dto.MoneyCardPayDto;
 import com.matrix.system.hive.plugin.util.MoneyUtil;
+import com.matrix.system.hive.pojo.CzXkVo;
 import com.matrix.system.hive.service.MoneyCardUseService;
 import com.matrix.system.hive.service.ShoppingGoodsService;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -109,6 +110,20 @@
         }
     }
 
+
+    @Override
+    public void vipCardRecharge(CzXkVo czVo) {
+        MoneyCardUse cardUser = moneyCardUseDao.selectVipCard(czVo.getVipId());
+
+        MoneyCardPayDto moneyCardPayDto=new MoneyCardPayDto();
+
+        moneyCardPayDto.setRealMoney(MoneyUtil.add(cardUser.getRealMoney(), czVo.getBjmoney()));
+        moneyCardPayDto.setGiftMoney(MoneyUtil.add(cardUser.getGiftMoney(), czVo.getGiftMoney()));
+        moneyCardPayDto.setCarUseId(cardUser.getId());
+        moneyCardPayDto.setOrderId();
+        moneyCardUseDao.update(cardUser);
+    }
+
     @Override
     @Transactional(rollbackFor = Exception.class)
     public void changeMoneyCard(List<MoneyCardPayDto> moneyCardPayDtoList) {
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 ce4c734..b403130 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
@@ -30,6 +30,7 @@
 import com.matrix.system.hive.dto.ProjUseOperationDto;
 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.service.CodeService;
 import com.matrix.system.hive.service.MoneyCardUseService;
 import com.matrix.system.hive.service.SysProjUseService;
@@ -43,6 +44,7 @@
 
 import java.math.BigDecimal;
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.Date;
 import java.util.List;
 import java.util.stream.Collectors;
@@ -96,16 +98,18 @@
     @Autowired
     BusParameterSettingsDao busParameterSettingsDao;
 
-
     @Autowired
     private WarehouseDao warehouseDao;
 
     @Autowired
     MoneyCardUseService moneyCardUseService;
 
-
     @Autowired
     private SysOrderItemDao orderItemDao;
+
+
+    @Autowired
+    MoneyCardUseDao moneyCardUseDao;
 
     /**
      * 创建支付流水
@@ -206,6 +210,7 @@
     public void cardPaySk(SysOrder pageOrder) {
 
 
+
         SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY);
         List<SysOrderFlow> flows = pageOrder.getFlows();
         List<Long> goodsIds = pageOrder.getItems().stream().map(e -> e.getGoodsId()).collect(Collectors.toList());
@@ -286,6 +291,8 @@
      * @date 2016年9月19日
      */
     public void addMoneyCardUse(SysOrder sourceOrder) {
+
+
         List<MoneyCardOperationDto> moneyCardOperationDtos = Lists.newArrayList();
         List<SysOrderItem> orderItemList = sourceOrder.getItems();
         for (SysOrderItem sysOrderItem : orderItemList) {
@@ -612,9 +619,11 @@
         SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY);
         sysOrder.setZkTotal(zkTotal);
         sysOrder.setStatu(Dictionary.ORDER_STATU_DFK);
-
+        sysOrder.setShopId(user.getShopId());
         sysOrder.setStaffId(user.getSuId());
         sysOrder.setCompanyId(user.getCompanyId());
+        sysOrder.setOrderTime(new Date());
+        sysOrder.setOrderType(SysOrder.ORDER_TYPE_SEAL);
 
         //新增订单
         sysOrder.setOrderNo(codeService.getOrderCode());
@@ -680,4 +689,33 @@
 
         return sysOrder;
     }
+
+    /**
+     * 创建充值订单
+     * @param czVo
+     * @return
+     */
+    public SysOrder createCzOrder(CzXkVo czVo){
+
+        MoneyCardUse cardUser = moneyCardUseDao.selectVipCard(czVo.getVipId());
+
+        SysOrder order= new SysOrder();
+        order.setFlows(czVo.getFlows());
+        order.setVipId(czVo.getVipId());
+        order.setRemark(cardUser.getCardName());
+
+        SysOrderItem orderItem = new SysOrderItem();
+        ShoppingGoods shoppingGoods = shoppingGoodsDao.selectVipCzGoods();
+        orderItem.setGoodsId(shoppingGoods.getId());
+        orderItem.setType(Dictionary.SHOPPING_GOODS_TYPE_CZK);
+        orderItem.setCount(1);
+        orderItem.setIsFree(Dictionary.FLAG_NO);
+        orderItem.setZkPrice(czVo.getBjmoney());
+        orderItem.setAchieveList(czVo.getAchaeveList());
+        order.setItems(Arrays.asList(orderItem));
+        saveOrder(order);
+        return order;
+    }
+
+
 }
\ No newline at end of file
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 def632f..bd48315 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
@@ -9,7 +9,6 @@
 import com.matrix.core.pojo.PaginationVO;
 import com.matrix.core.tools.DateUtil;
 import com.matrix.core.tools.LogUtil;
-import com.matrix.core.tools.StringUtils;
 import com.matrix.core.tools.WebUtil;
 import com.matrix.system.app.dto.OrderListDto;
 import com.matrix.system.app.mapper.SysProjUseMapper;
@@ -30,6 +29,7 @@
 import com.matrix.system.hive.bean.*;
 import com.matrix.system.hive.dao.*;
 import com.matrix.system.hive.dto.GoodsSealLimitDto;
+import com.matrix.system.hive.dto.MoneyCardPayDto;
 import com.matrix.system.hive.dto.SysOrderItemDto;
 import com.matrix.system.hive.plugin.util.CollectionUtils;
 import com.matrix.system.hive.plugin.util.MoneyUtil;
@@ -68,7 +68,7 @@
     @Autowired
     SysVipInfoDao sysVipInfoDao;
     @Autowired
-    SysOutStoreDao sysOutStoreDao;
+    SysOutStoreService sysOutStoreService;
     @Autowired
     SysOutStoreItemDao sysOutStoreItemDao;
     @Autowired
@@ -153,7 +153,7 @@
 
         if (Objects.isNull(sysOrder.getId())) {
             LogUtil.info("新增正向订单");
-            return sysOrderServiceHelper.saveOrder(sysOrder);
+            return sysOrderServiceHelper.saveOrder(sysOrder,SysOrder.ORDER_TYPE_SEAL);
         } else {
             LogUtil.info("修改订单");
             return sysOrderServiceHelper.modifyOrder(sysOrder);
@@ -197,6 +197,7 @@
         //储值卡退款
         sysOrderServiceHelper.returnMoneyCardPay(order);
 
+        //套餐项目取消
         List<SysOrderItem> sysOrderItems = orderItemDao.selectByOrderId(order.getId());
         for (SysOrderItem orderItem : sysOrderItems) {
             // 充值卡类型退款
@@ -214,24 +215,14 @@
         //删除出库单,恢复库存
         SysOutStore sysOutStore = new SysOutStore();
         sysOutStore.setOrderId(order.getId());
-        List<SysOutStore> sysOutStores = sysOutStoreDao.selectByModel(sysOutStore);
+        List<SysOutStore> sysOutStores = sysOutStoreService.findByModel(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());
+            sysOutStoreService.cancelOutStore(sysOutStore.getId());
         }
 
         // 删除业绩
-        AchieveNew achieveNew = new AchieveNew();
-        achieveNew.setOrderId(order.getId());
-        achieveNewService.removeByModel(achieveNew);
+        achieveNewService.removeByOrderId(order.getId());
 
         // 删除收款记录
         sysOrderFlowDao.deleteByOrderId(order.getId());
@@ -242,6 +233,7 @@
         // 取消订单
         order.setStatu(Dictionary.ORDER_STATU_YQX);
         sysOrderDao.update(order);
+
         //保存单据日志
         operationLogService.saveOperation(order.getCompanyId(), order.getShopId(), sysUsers.getSuId(),
                 OperationFunctionEnum.ORDER,
@@ -285,16 +277,13 @@
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public void updateReceiptMoney(SysOrder pageOrder) throws GlobleException {
+    public void payOrder(SysOrder pageOrder) throws GlobleException {
 
         //校验订单是否满足收款条件
         checkOrderAblePay(pageOrder);
 
         // 更新订单主表信息
-        updateOrderInfo(pageOrder);
-
-        // 设置用户为成交客户
-        sysVipInfoService.updateDealStatus(pageOrder.getVipId(), BooleanEnum.TRUE.getValue());
+        payEndUpdateOrderInfo(pageOrder);
 
         //添加支付流水
         sysOrderServiceHelper.addOrderFlow(pageOrder, false);
@@ -344,7 +333,7 @@
      *
      * @param pageOrder
      */
-    private void updateOrderInfo(SysOrder pageOrder) {
+    private void payEndUpdateOrderInfo(SysOrder pageOrder) {
         LogUtil.info("付款更新订单信息 id={}", pageOrder.getId());
         SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY);
         pageOrder.setCashierId(user.getSuId());
@@ -381,8 +370,8 @@
 
 
         sysOrderDao.update(pageOrder);
-
-
+        // 设置用户为成交客户
+        sysVipInfoService.updateDealStatus(pageOrder.getVipId(), BooleanEnum.TRUE.getValue());
     }
 
     /**
@@ -497,91 +486,33 @@
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public SysOrder updateAddCardMoney(CzXkVo czVo) {
-        SysUsers user = (SysUsers) WebUtil.getSession().getAttribute(MatrixConstance.LOGIN_KEY);
-
-//        SysVipInfo vip = (SysVipInfo) WebUtil.getSession().getAttribute(SystemConstance.CURRENT_CUSTOMER);
-//        czVo.setVipId(vip.getId());
-
-        //更新会员会员卡金额
-        MoneyCardUse cardUser = moneyCardUseDao.selectVipCard(czVo.getVipId());
-        cardUser.setRealMoney(MoneyUtil.add(cardUser.getRealMoney(), czVo.getBjmoney()));
-        cardUser.setGiftMoney(MoneyUtil.add(cardUser.getGiftMoney(), czVo.getGiftMoney()));
-        moneyCardUseDao.update(cardUser);
-
-
-        // 为会员新增积分
-        SysVipInfo vipInfo = sysVipInfoDao.selectById(cardUser.getVipId());
-        vipInfo.setPointAll(vipInfo.getPointAll() == null ? 0 : vipInfo.getPointAll() + czVo.getJf());
-        sysVipInfoDao.update(vipInfo);
-
+    public SysOrder moneyCardCz(CzXkVo czVo) {
 
         // 新增一个充值订单
-        SysOrder order = new SysOrder();
-        order.setArrears(0D);
-        order.setTotal(czVo.getBjmoney());
-        order.setZkTotal(czVo.getBjmoney());
-        order.setCashPay(czVo.getBjmoney());
-        order.setShopId(user.getShopId());
-        order.setOrderNo(codeService.getOrderCode());
-        order.setVipId(czVo.getVipId());
-        Date orderTime = new Date();
-        if (StringUtils.isNotBlank(czVo.getDateTime())) {
-            orderTime = DateUtil.stringToDateNew(czVo.getDateTime(), DateUtil.DATE_FORMAT_DD);
-        }
-        order.setOrderTime(orderTime);
-        order.setPayTime(orderTime);
-        order.setRemark(cardUser.getCardName());
-        order.setStaffId(user.getSuId());
-        order.setIsCross(2 + "");
-        order.setOrderType(SysOrder.ORDER_TYPE_SEAL);
-        order.setStatu(Dictionary.ORDER_STATU_YFK);
-        order.setCompanyId(user.getCompanyId());
-        sysOrderDao.insert(order);
+        SysOrder order =sysOrderServiceHelper.createCzOrder(czVo);
 
-        SysOrderItem orderItem = new SysOrderItem();
-        orderItem.setOrderId(order.getId());
-        orderItem.setOrderNo(order.getOrderNo());
-        orderItem.setArrears(0D);
-        ShoppingGoods shoppingGoods = shoppingGoodsDao.selectVipCzGoods();
-        orderItem.setGoodsId(shoppingGoods.getId());
-        orderItem.setPayMethod(Dictionary.PAY_TYPE_MOENY);
-        orderItem.setCashPay(czVo.getBjmoney());
-        orderItem.setZkPrice(czVo.getBjmoney());
-        orderItem.setCardPay(0D);
-        orderItem.setType(Dictionary.SHOPPING_GOODS_TYPE_CZK);
-        orderItem.setCount(1);
-        orderItem.setIsFree(Dictionary.FLAG_NO);
-        orderItem.setPrice(czVo.getBjmoney());
-        orderItem.setStatus(Dictionary.ORDER_STATU_YFK);
-        orderItem.setAchieveList(czVo.getAchaeveList());
-        orderItem.setShoppingGoods(shoppingGoods);
-        orderItemDao.insert(orderItem);
-        List<SysOrderItem> items = new ArrayList<>();
-        items.add(orderItem);
-        order.setItems(items);
+        //新增会员卡金额
+        MoneyCardUse cardUser = moneyCardUseDao.selectVipCard(czVo.getVipId());
+        MoneyCardPayDto moneyCardPayDto=new MoneyCardPayDto();
+        moneyCardPayDto.setRealMoney(MoneyUtil.add(cardUser.getRealMoney(), czVo.getBjmoney()));
+        moneyCardPayDto.setGiftMoney(MoneyUtil.add(cardUser.getGiftMoney(), czVo.getGiftMoney()));
+        moneyCardPayDto.setCarUseId(cardUser.getId());
+        moneyCardPayDto.setOrderId(order.getId());
+        moneyCardPayDto.setOrderNo(order.getOrderNo());
+        moneyCardPayDto.setType(MoneyCardUseFlow.USE_TYPE_CZ);
+        moneyCardUseService.changeMoneyCard(Arrays.asList(moneyCardPayDto));
 
+        // 更新订单主表信息
+        payEndUpdateOrderInfo(order);
 
-        //设置卡项使用流水
-        MoneyCardUseFlow moneyCardUseFlow = new MoneyCardUseFlow();
-        moneyCardUseFlow.setTotal(czVo.getBjmoney());
-        moneyCardUseFlow.setGiftMoney(czVo.getGiftMoney());
-        moneyCardUseFlow.setCarUseId(czVo.getCardId());
-        moneyCardUseFlow.setVipId(czVo.getVipId());
-        moneyCardUseFlow.setType(MoneyCardUseFlow.USE_TYPE_CZ);
-        moneyCardUseFlow.setOrderNo(order.getOrderNo());
-        moneyCardUseFlow.setCreateTime(new Date());
-        moneyCardUseFlow.setOperationId(user.getSuId());
-        moneyCardUseFlow.setBalance(cardUser.getGiftMoney() + cardUser.getRealMoney());
-        moneyCardUseFlow.setCarUseId(cardUser.getId());
-        moneyCardUseFlowDao.insert(moneyCardUseFlow);
-
-        order.setFlows(czVo.getFlows());
-
+        //添加支付流水
         sysOrderServiceHelper.addOrderFlow(order, false);
 
-        // 添加员工业绩
+        // 设置业绩
         achieveNewService.addAchaeveByOrder(order);
+
+        //设置会员积分
+        sysOrderServiceHelper.addVipScore(order);
 
         return order;
 
@@ -637,7 +568,6 @@
         SysOrder sourceOrder = new SysOrder();
         sourceOrder.setId(sysOrder.getOldOrderId());
         sourceOrder.setIsHasRefund(SysOrder.IS_HAS_REFUND_Y);
-//        sourceOrder.setStatu(Dictionary.ORDER_STATU_TK);
         sysOrderDao.update(sourceOrder);
         SysOrder oldOrder = sysOrderDao.selectById(sysOrder.getOldOrderId());
 
@@ -669,8 +599,6 @@
             item.setOrderId(sysOrder.getId());
             orderItemDao.insert(item);
         }
-
-
         // 添加订单收款流水
         sysOrderServiceHelper.addOrderFlow(sysOrder, false);
         //退款退套餐退项目
@@ -690,10 +618,6 @@
                 sysOrder.getVipId());
 
     }
-
-
-
-
     /**
      * 退款退项目,套餐,卡项
      *
@@ -770,9 +694,6 @@
                     moneyCardUseDao.update(moneyCardUse);
                 }
             }
-
-
-
             ShoppingGoods goods = shoppingGoodsDao.selectById(item.getGoodsId());
             goods.setRealSealCount(goods.getRealSealCount() - item.getCount());
             shoppingGoodsDao.update(goods);
diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOutStoreServiceImpl.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOutStoreServiceImpl.java
index 5e431ab..3d3c73e 100644
--- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOutStoreServiceImpl.java
+++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOutStoreServiceImpl.java
@@ -3,30 +3,23 @@
 import com.matrix.core.constance.MatrixConstance;
 import com.matrix.core.exception.GlobleException;
 import com.matrix.core.pojo.PaginationVO;
-
-
-import com.matrix.core.tools.DateUtil;
-import com.matrix.core.tools.LogUtil;
 import com.matrix.core.tools.WebUtil;
 import com.matrix.system.common.bean.SysUsers;
 import com.matrix.system.constance.Dictionary;
 import com.matrix.system.hive.bean.SysOutStore;
 import com.matrix.system.hive.bean.SysOutStoreItem;
-import com.matrix.system.hive.bean.SysShopInfo;
 import com.matrix.system.hive.bean.SysStoreInfo;
 import com.matrix.system.hive.dao.SysOutStoreDao;
 import com.matrix.system.hive.dao.SysOutStoreItemDao;
 import com.matrix.system.hive.dao.SysStoreInfoDao;
 import com.matrix.system.hive.service.CodeService;
 import com.matrix.system.hive.service.SysOutStoreService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
-import org.springframework.beans.factory.annotation.Autowired;
 
 import java.util.ArrayList;
-import java.util.Date;
 import java.util.List;
-import java.util.Random;
 
 /**
  * @date 2016-07-25 12:43
@@ -143,7 +136,27 @@
 
     }
 
+
+    /**
+     * 取消出库单
+     * @param id
+     * @return
+     */
+    @Transactional(rollbackFor = Exception.class)
     @Override
+    public void cancelOutStore(Long id) {
+        List<SysOutStoreItem> outStoreItemList = sysOutStoreItemDao.selectByOrderId(id);
+        for (SysOutStoreItem item : outStoreItemList) {
+            SysStoreInfo sysStoreInfo = storeInfoDao.selectById(item.getStoreId());
+            sysStoreInfo.setStoreTotal(sysStoreInfo.getStoreTotal() + item.getAmount());
+            //更新库存
+            storeInfoDao.update(sysStoreInfo);
+        }
+        sysOutStoreDao.deleteById(id);
+        sysOutStoreItemDao.deleteByOrderId(id);
+    }
+
+        @Override
     public int effectOutStore(SysOutStore sysOutStore) {
 
         SysOutStore queryStore = sysOutStoreDao.selectById(sysOutStore.getId());

--
Gitblit v1.9.1