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/MoneyCardUseService.java | 8 zq-erp/src/main/java/com/matrix/system/hive/service/SysOrderService.java | 11 zq-erp/src/main/java/com/matrix/system/hive/service/imp/MoneyCardUseServiceImpl.java | 184 +++++++++----- zq-erp/src/main/java/com/matrix/system/constance/Dictionary.java | 4 zq-erp/src/main/java/com/matrix/system/app/action/ApiOrderAction.java | 33 +- zq-erp/src/main/java/com/matrix/system/hive/service/SysBeauticianStateService.java | 8 zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUseFlow.java | 1 zq-erp/src/main/java/com/matrix/system/hive/service/SysProjUseService.java | 8 zq-erp/src/main/resources/mybatis/mapper/hive/SysProjUseDao.xml | 8 zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceImpl.java | 350 ++++++++--------------------- zq-erp/src/main/java/com/matrix/system/hive/dao/SysProjUseDao.java | 2 zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysOrderServiceHelper.java | 49 ++++ zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java | 22 + zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/OrderTask.java | 11 zq-erp/src/main/java/com/matrix/system/hive/action/ShoppingGoodsController.java | 7 zq-erp/src/main/java/com/matrix/system/hive/service/imp/ShoppingGoodsServiceImpl.java | 3 zq-erp/src/main/java/com/matrix/system/hiveErp/action/ErpShoppingGoodsController.java | 6 zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUse.java | 1 18 files changed, 329 insertions(+), 387 deletions(-) diff --git a/zq-erp/src/main/java/com/matrix/system/app/action/ApiOrderAction.java b/zq-erp/src/main/java/com/matrix/system/app/action/ApiOrderAction.java index 10237fb..d8dc496 100644 --- a/zq-erp/src/main/java/com/matrix/system/app/action/ApiOrderAction.java +++ b/zq-erp/src/main/java/com/matrix/system/app/action/ApiOrderAction.java @@ -17,10 +17,10 @@ import com.matrix.system.hive.action.util.QueryUtil; import com.matrix.system.hive.bean.ShoppingGoodsCategory; import com.matrix.system.hive.bean.SysOrder; +import com.matrix.system.hive.bean.SysOrderItem; import com.matrix.system.hive.bean.SysShopInfo; import com.matrix.system.hive.dao.SysShopInfoDao; import com.matrix.system.hive.plugin.util.CollectionUtils; -import com.matrix.system.hive.pojo.ShoppingCarItem; import com.matrix.system.hive.pojo.ShoppingCarItemsVo; import com.matrix.system.hive.service.ShoppingGoodsCategoryService; import com.matrix.system.hive.service.ShoppingGoodsService; @@ -109,31 +109,26 @@ @ApiOperation(value = "创建订单", notes = "创建订单") @PostMapping(value = "/createOrder") public AjaxResult createOrder(@RequestBody @Validated CreateOrderDto createOrderDto) { - SysUsers user = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - + SysOrder order=new SysOrder(); + order.setVipId(createOrderDto.getVipId()); ShoppingCarItemsVo car = new ShoppingCarItemsVo(); car.setVipId(createOrderDto.getVipId()); if (CollectionUtils.isNotEmpty(createOrderDto.getItems())) { - List<ShoppingCarItem> list = new ArrayList<>(); + List<SysOrderItem> list = new ArrayList<>(); for (CreateOderItemDto item : createOrderDto.getItems()) { - ShoppingCarItem carItem = new ShoppingCarItem(); - carItem.setCount(item.getCount()); - carItem.setGoodsId(item.getGoodsId()); - carItem.setIsFree(item.getIsFree()); - carItem.setType(item.getGoodsType()); - - carItem.setShoppingGoods(shoppingGoodsService.findById(item.getGoodsId())); - list.add(carItem); + SysOrderItem orderItem = new SysOrderItem(); + orderItem.setCount(item.getCount()); + orderItem.setGoodsId(item.getGoodsId()); + orderItem.setIsFree(item.getIsFree()); + //jyytodo 这个字段可以不传 + orderItem.setType(item.getGoodsType()); + list.add(orderItem); } - car.setCarItems(list); + order.setItems(list); } - int i = sysOrderService.createOrder(WebUtil.getSession(), car); - if (i > 0) { - return AjaxResult.buildSuccessInstance("下单成功"); - } - - return AjaxResult.buildFailInstance("下单失败"); + sysOrderService.checkAndSaveOrder(order); + return AjaxResult.buildSuccessInstance("下单成功"); } @ApiOperation(value = "获取订单列表", notes = "获取订单列表") diff --git a/zq-erp/src/main/java/com/matrix/system/constance/Dictionary.java b/zq-erp/src/main/java/com/matrix/system/constance/Dictionary.java index 199d54d..97e3843 100644 --- a/zq-erp/src/main/java/com/matrix/system/constance/Dictionary.java +++ b/zq-erp/src/main/java/com/matrix/system/constance/Dictionary.java @@ -403,10 +403,6 @@ * 商城商品-充值卡 */ String SHOPPING_GOODS_TYPE_CZK = "充值卡"; - /** - * 商城商品-综合卡 - */ - String SHOPPING_GOODS_TYPE_ZHK = "综合卡"; diff --git a/zq-erp/src/main/java/com/matrix/system/hive/action/ShoppingGoodsController.java b/zq-erp/src/main/java/com/matrix/system/hive/action/ShoppingGoodsController.java index 2118f7a..53b2bf6 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/action/ShoppingGoodsController.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/action/ShoppingGoodsController.java @@ -129,7 +129,6 @@ shoppingGoods.setAssembleProj(shoppingGoodsAssembleDao.selectGoodsByShoppingGoodsIdAndType(shoppingGoods.getId(), ShoppingGoods.SHOPPING_GOODS_TYPE_XM)); } else if ( Dictionary.SHOPPING_GOODS_TYPE_XM.equals(shoppingGoods.getGoodType()) - || Dictionary.SHOPPING_GOODS_TYPE_ZHK.equals(shoppingGoods.getGoodType()) ) { shoppingGoods.setAssembleGoods(shoppingGoodsAssembleDao.selectGoodsByShoppingGoodsIdAndType(shoppingGoods.getId(), null)); } else if (Dictionary.SHOPPING_GOODS_TYPE_CZK.equals(shoppingGoods.getGoodType())) { @@ -291,9 +290,6 @@ shoppingGoods.setAssembleGoods(assembleListGoods); List<ShoppingGoodsAssemble> assembleListProj = shoppingGoodsAssembleDao.selectProjByShoppingGoodsId(shoppingGoods.getId()); shoppingGoods.setAssembleProj(assembleListProj); - } else if (Dictionary.SHOPPING_GOODS_TYPE_ZHK.equals(shoppingGoods.getGoodType())) { - List<ShoppingGoodsAssemble> assembleList = shoppingGoodsAssembleDao.selectAssembleShoppingGoodsByShoppingGoodsId(shoppingGoods.getId()); - shoppingGoods.setZongheCarGoods(assembleList); } @@ -322,9 +318,6 @@ // 返回充值卡编辑界面 WebUtil.getRequest().setAttribute("obj", shoppingGoods); return "admin/hive/products/money-card-form"; - } else if (shoppingGoods.getGoodType().equals(Dictionary.SHOPPING_GOODS_TYPE_ZHK)) { - WebUtil.getRequest().setAttribute("obj", shoppingGoods); - return "admin/hive/products/zonghe-card-form"; } diff --git a/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUse.java b/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUse.java index 0787c91..606777c 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUse.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUse.java @@ -88,6 +88,7 @@ /** + * // jyytodo 可以考虑一个已启用未启用的状态,开卡后如果没有使用过就视为未启用 * 状态,有效,无效,转让,冻结,退款 */ private String status; diff --git a/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUseFlow.java b/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUseFlow.java index 8e4359e..15deb13 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUseFlow.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/bean/MoneyCardUseFlow.java @@ -10,6 +10,7 @@ */ public class MoneyCardUseFlow implements Serializable{ + //jyytodo 改成枚举 public static final String USE_TYPE_CONSUMER = "消费扣款"; public static final String USE_TYPE_ORDRE_CANCEL = "取消订单"; diff --git a/zq-erp/src/main/java/com/matrix/system/hive/dao/SysProjUseDao.java b/zq-erp/src/main/java/com/matrix/system/hive/dao/SysProjUseDao.java index cd19d3d..0168346 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/dao/SysProjUseDao.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/dao/SysProjUseDao.java @@ -136,4 +136,6 @@ List<SysProjUse> selectTaoCanListWithProj(@Param("record") SysProjUse sysProjUse); int selectTaocanCountForCourseAndInfinite(@Param("taocanId") Long taocanId, @Param("vipId") Long vipId); + + int selectUseCountByOrderItemId(Long orderItemId); } \ 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 c083f38..b70f7e7 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 @@ -15,7 +15,7 @@ /** - * 修改储值卡余额 + * 扣除储值卡余额 */ void changeMoneyCard(List<MoneyCardPayDto> moneyCardPayDtoList); @@ -129,4 +129,10 @@ public List<MoneyCardUse> findVipCardUse(MoneyCardUse moneyCardUse); + /** + * 根据订单id删除充值卡 + * 只有没有被使用过的储值卡可以删除 + * @param id + */ + void deleteByOrderItemId(Long id); } \ No newline at end of file diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/SysBeauticianStateService.java b/zq-erp/src/main/java/com/matrix/system/hive/service/SysBeauticianStateService.java index 5904b62..5759276 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/service/SysBeauticianStateService.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/service/SysBeauticianStateService.java @@ -1,12 +1,11 @@ package com.matrix.system.hive.service; -import java.util.Date; -import java.util.List; - - import com.matrix.core.pojo.PaginationVO; import com.matrix.system.hive.bean.SysBeauticianState; import com.matrix.system.hive.plugin.util.BaseServices; + +import java.util.Date; +import java.util.List; /** * @@ -75,7 +74,6 @@ public List<SysBeauticianState> findByTimeAndStaff(Long id, Date beginTime, Date endTime); - public List<SysBeauticianState> findBySerId(Long serviceId); } \ 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 9cae7ba..83a8ada 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 @@ -8,10 +8,7 @@ import com.matrix.system.hive.bean.SysOrder; import com.matrix.system.hive.plugin.util.BaseServices; import com.matrix.system.hive.pojo.CzXkVo; -import com.matrix.system.hive.pojo.ShoppingCarItemsVo; -import org.springframework.transaction.annotation.Transactional; -import javax.servlet.http.HttpSession; import java.math.BigDecimal; import java.util.List; @@ -87,14 +84,6 @@ public void refundOrderMoney(SysOrder sysOrder); - /** - * 创建订单 - * @param session - * @param car - * @return - */ - @Transactional(rollbackFor = Exception.class) - public int createOrder(HttpSession session, ShoppingCarItemsVo car); /** * 补交 * @Title: updateAfterMoney diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/SysProjUseService.java b/zq-erp/src/main/java/com/matrix/system/hive/service/SysProjUseService.java index fa92426..ce768cf 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/service/SysProjUseService.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/service/SysProjUseService.java @@ -2,7 +2,6 @@ import com.matrix.core.pojo.AjaxResult; import com.matrix.core.pojo.PaginationVO; -import com.matrix.system.hive.bean.MoneyCardUse; import com.matrix.system.hive.bean.SysProjUse; import com.matrix.system.hive.dto.ProjUseOperationDto; import com.matrix.system.hive.plugin.util.BaseServices; @@ -152,4 +151,11 @@ public List<SysProjUse> findTaocaoProjUseWithProj(SysProjUse sysProjUse); int findTaocanCountForCourseAndInfinite(Long taocanId, Long vipId); + + /** + * 取消订单删除项目 + * 只有没有使用过的才能被删除 + * @param id + */ + void deleteByOrderItemId(Long id); } \ 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 a1b5de0..40b1c48 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 @@ -1,11 +1,13 @@ package com.matrix.system.hive.service.imp; import cn.hutool.core.bean.BeanUtil; +import com.alibaba.fastjson.JSON; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.matrix.core.exception.GlobleException; import com.matrix.core.pojo.PaginationVO; import com.matrix.core.pojo.VerificationResult; import com.matrix.core.tools.DateUtil; +import com.matrix.core.tools.LogUtil; import com.matrix.system.common.validate.ParameterValidate; import com.matrix.system.common.validate.group.Group; import com.matrix.system.constance.Dictionary; @@ -16,7 +18,6 @@ import com.matrix.system.hive.plugin.util.MoneyUtil; import com.matrix.system.hive.service.MoneyCardUseService; import com.matrix.system.hive.service.ShoppingGoodsService; -import com.matrix.system.hive.validation.ProjUseGroup; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -63,7 +64,7 @@ @Override @Transactional(rollbackFor = Exception.class) public void addVipMoneyCard(List<MoneyCardOperationDto> moneyCardOperationDtos) { - moneyCardOperationDtos.forEach(dto->{ + moneyCardOperationDtos.forEach(dto -> { //参数校验 ParameterValidate.ValidResult baseIdResult = ParameterValidate.validateBean(dto, Group.ADD.class); if (baseIdResult.hasErrors()) { @@ -71,7 +72,7 @@ } ShoppingGoods moneyCar = shoppingGoodsDao.selectById(dto.getGoodsId()); MoneyCardUse moneyCardUse = new MoneyCardUse(); - BeanUtil.copyProperties(dto,moneyCardUse); + BeanUtil.copyProperties(dto, moneyCardUse); moneyCardUse.setVipId(dto.getVipId()); moneyCardUse.setGiftMoney(moneyCar.getReferencePice()); moneyCardUse.setRealMoney(moneyCar.getSealPice()); @@ -93,84 +94,137 @@ moneyCardUseDao.insert(moneyCardUse); }); + } - - - - + @Override + public void deleteByOrderItemId(Long id) { + MoneyCardUseFlow moneyCardUseFlow=new MoneyCardUseFlow(); + moneyCardUseFlow.setCarUseId(id); + int i = moneyCardUseFlowDao.selectTotalRecord(moneyCardUseFlow); + if(i>0){ + MoneyCardUse one = getOne(lambdaQuery().eq(MoneyCardUse::getOrderItemId,id)); + throw new GlobleException(one.getCardName()+"储值卡已经被启用无法删除"); + }else { + moneyCardUseDao.deleteByOrderItemId(id); + } } @Override @Transactional(rollbackFor = Exception.class) public void changeMoneyCard(List<MoneyCardPayDto> moneyCardPayDtoList) { - - // 判断商品是否在充值卡的限制购买 - moneyCardPayDtoList.forEach(cardUse -> { - VerificationResult verificationResult = checkIsBangding(cardUse.getCarUseId(), cardUse.getGoodsIds()); - if (!verificationResult.isJudgeResult()) { - throw new GlobleException(verificationResult.getMsg()); - } - }); - - moneyCardPayDtoList.forEach(moneyCardPayDto -> { - MoneyCardUse moneyCardUse = moneyCardUseDao.selectById(moneyCardPayDto.getCarUseId()); - MoneyCardUseFlow moneyCardUseFlow = new MoneyCardUseFlow(); - if (Objects.nonNull(moneyCardPayDto.getGiftMoney()) && moneyCardPayDto.getGiftMoney()>0) { - if (moneyCardUse.getGiftMoney() >= moneyCardPayDto.getGiftMoney()) { - double surplus = MoneyUtil.sub(moneyCardUse.getGiftMoney(), moneyCardPayDto.getGiftMoney()); - moneyCardUse.setGiftMoney(surplus); - moneyCardUseFlow.setGiftMoney(0D - moneyCardPayDto.getGiftMoney()); - } else { - throw new GlobleException(moneyCardUse.getCardName() + "余额不足"); - } - } else { - if (moneyCardUse.getRealMoney() >= moneyCardPayDto.getRealMoney()) { - double surplus = MoneyUtil.sub(moneyCardUse.getRealMoney(), moneyCardPayDto.getRealMoney()); - moneyCardUse.setRealMoney(surplus); - moneyCardUseFlow.setTotal(0 - moneyCardPayDto.getRealMoney()); - } else { - throw new GlobleException(moneyCardUse.getCardName() + "余额不足"); - } + if (MoneyCardUseFlow.USE_TYPE_CONSUMER.equals(moneyCardPayDto.getType())) { + //扣减储值卡余额 + deductMoneyCard(moneyCardPayDto); + } else if (MoneyCardUseFlow.USE_TYPE_ORDRE_CANCEL.equals(moneyCardPayDto.getType())) { + //回退储值卡余额 + returnMoneyCard(moneyCardPayDto); } - - 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 = shoppingGoodsDao.selectById(moneyCardUse.getGoodsId()); - if (shoppingGoods != null) { - Date invalidTime = shoppingGoodsService.calInvalidTime(shoppingGoods, 2, moneyCardUse.getFailTime()); - moneyCardUse.setFailTime(invalidTime); - } - - moneyCardUse.setLastCount(moneyCardUse.getLastCount() - moneyCardPayDto.getCount()); - - // 更新充值卡信息 - moneyCardUseDao.update(moneyCardUse); - //设置卡项使用流水 - moneyCardUseFlow.setCarUseId(moneyCardUse.getId()); - moneyCardUseFlow.setOrderNo(moneyCardPayDto.getOrderNo()); - moneyCardUseFlow.setVipId(moneyCardUse.getVipId()); - moneyCardUseFlow.setTimes(-1); - moneyCardUseFlow.setType(moneyCardPayDto.getType()); - moneyCardUseFlow.setCreateTime(new Date()); - moneyCardUseFlow.setOperationId(moneyCardPayDto.getUpdateUser()); - moneyCardUseFlow.setBalance(moneyCardUse.getGiftMoney() + moneyCardUse.getRealMoney()); - moneyCardUseFlowDao.insert(moneyCardUseFlow); }); + } + + /** + * 回退储值卡余额 + * + * @param moneyCardPayDto + */ + private void returnMoneyCard(MoneyCardPayDto moneyCardPayDto) { + LogUtil.info("回退储值卡余额 {}", JSON.toJSONString(moneyCardPayDto)); + MoneyCardUse moneyCardUse = moneyCardUseDao.selectById(moneyCardPayDto.getCarUseId()); + MoneyCardUseFlow moneyCardUseFlow = new MoneyCardUseFlow(); + + if (Objects.nonNull(moneyCardPayDto.getGiftMoney())) { + //jyytodo 余额余次的修改和新增在数据库层面做加减 + moneyCardUse.setGiftMoney(moneyCardUse.getGiftMoney() + moneyCardPayDto.getGiftMoney()); + } + if (Objects.nonNull(moneyCardPayDto.getRealMoney())) { + moneyCardUse.setRealMoney(moneyCardUse.getRealMoney() + moneyCardPayDto.getRealMoney()); + } + moneyCardUse.setIsOver(Dictionary.FLAG_YES_Y); + moneyCardUse.setStatus(Dictionary.MONEYCARD_STATUS_YX); + moneyCardUseDao.update(moneyCardUse); + //设置卡项使用流水 + moneyCardUseFlow.setCarUseId(moneyCardUse.getId()); + moneyCardUseFlow.setOrderNo(moneyCardPayDto.getOrderNo()); + moneyCardUseFlow.setVipId(moneyCardUse.getVipId()); + moneyCardUseFlow.setTimes(moneyCardUse.getLastCount()); + moneyCardUseFlow.setType(moneyCardPayDto.getType()); + moneyCardUseFlow.setCreateTime(new Date()); + moneyCardUseFlow.setOperationId(moneyCardPayDto.getUpdateUser()); + moneyCardUseFlow.setBalance(moneyCardUse.getGiftMoney() + moneyCardUse.getRealMoney()); + moneyCardUseFlowDao.insert(moneyCardUseFlow); + } + + /** + * 扣减储值余额 + * + * @param moneyCardPayDto + */ + private void deductMoneyCard(MoneyCardPayDto moneyCardPayDto) { + // 判断商品是否在充值卡的限制购买 + VerificationResult verificationResult = checkIsBangding(moneyCardPayDto.getCarUseId(), moneyCardPayDto.getGoodsIds()); + if (!verificationResult.isJudgeResult()) { + throw new GlobleException(verificationResult.getMsg()); + } + LogUtil.info("扣减储值卡余额 {}", JSON.toJSONString(moneyCardPayDto)); + MoneyCardUse moneyCardUse = moneyCardUseDao.selectById(moneyCardPayDto.getCarUseId()); + MoneyCardUseFlow moneyCardUseFlow = new MoneyCardUseFlow(); + if (Objects.nonNull(moneyCardPayDto.getGiftMoney()) && moneyCardPayDto.getGiftMoney() > 0) { + if (moneyCardUse.getGiftMoney() >= moneyCardPayDto.getGiftMoney()) { + double surplus = MoneyUtil.sub(moneyCardUse.getGiftMoney(), moneyCardPayDto.getGiftMoney()); + moneyCardUse.setGiftMoney(surplus); + moneyCardUseFlow.setGiftMoney(0D - moneyCardPayDto.getGiftMoney()); + } else { + throw new GlobleException(moneyCardUse.getCardName() + "余额不足"); + } + } else { + if (moneyCardUse.getRealMoney() >= moneyCardPayDto.getRealMoney()) { + double surplus = MoneyUtil.sub(moneyCardUse.getRealMoney(), moneyCardPayDto.getRealMoney()); + moneyCardUse.setRealMoney(surplus); + moneyCardUseFlow.setTotal(0 - moneyCardPayDto.getRealMoney()); + } 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 = shoppingGoodsDao.selectById(moneyCardUse.getGoodsId()); + if (shoppingGoods != null) { + Date invalidTime = shoppingGoodsService.calInvalidTime(shoppingGoods, 2, moneyCardUse.getFailTime()); + moneyCardUse.setFailTime(invalidTime); + } + + moneyCardUse.setLastCount(moneyCardUse.getLastCount() - moneyCardPayDto.getCount()); + + // 更新充值卡信息 + moneyCardUseDao.update(moneyCardUse); + + //设置卡项使用流水 + moneyCardUseFlow.setCarUseId(moneyCardUse.getId()); + moneyCardUseFlow.setOrderNo(moneyCardPayDto.getOrderNo()); + moneyCardUseFlow.setVipId(moneyCardUse.getVipId()); + moneyCardUseFlow.setTimes(moneyCardUse.getLastCount()); + moneyCardUseFlow.setType(moneyCardPayDto.getType()); + moneyCardUseFlow.setCreateTime(new Date()); + moneyCardUseFlow.setOperationId(moneyCardPayDto.getUpdateUser()); + moneyCardUseFlow.setBalance(moneyCardUse.getGiftMoney() + moneyCardUse.getRealMoney()); + moneyCardUseFlowDao.insert(moneyCardUseFlow); } /** * 检查商品是否在储值卡的消费范围内 + * * @param moneyCardUseId 储值卡id - * @param goodsIds 商品id集合 + * @param goodsIds 商品id集合 * @return */ private VerificationResult checkIsBangding(Long moneyCardUseId, List<Long> goodsIds) { diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/ShoppingGoodsServiceImpl.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/ShoppingGoodsServiceImpl.java index 639beac..287a6a9 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/ShoppingGoodsServiceImpl.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/ShoppingGoodsServiceImpl.java @@ -390,9 +390,6 @@ case Dictionary.SHOPPING_GOODS_TYPE_TC: shoppingGoods.setIsAssemble(Dictionary.FLAG_YES); break; - case Dictionary.SHOPPING_GOODS_TYPE_ZHK: - shoppingGoods.setIsAssemble(Dictionary.FLAG_YES); - break; } } 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 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()); diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java index a464c3d..b3f85c7 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java @@ -10,13 +10,13 @@ import com.matrix.system.common.bean.SysUsers; import com.matrix.system.common.dao.BusParameterSettingsDao; import com.matrix.system.common.validate.ParameterValidate; -import com.matrix.system.common.validate.group.Group; import com.matrix.system.constance.Dictionary; import com.matrix.system.hive.bean.*; import com.matrix.system.hive.dao.*; import com.matrix.system.hive.dto.ProjUseOperationDto; import com.matrix.system.hive.plugin.util.MoneyUtil; import com.matrix.system.hive.service.ShoppingGoodsService; +import com.matrix.system.hive.service.SysBeauticianStateService; import com.matrix.system.hive.service.SysProjServicesService; import com.matrix.system.hive.service.SysProjUseService; import com.matrix.system.hive.validation.ProjUseGroup; @@ -41,6 +41,9 @@ private SysProjUseDao sysProjUseDao; @Autowired SysProjServicesService projServicesService; + + @Autowired + SysBeauticianStateService sysBeauticianStateService; @Autowired private SysProjuseFreezeDao sysProjuseFreezeDao; @@ -770,4 +773,21 @@ public int findTaocanCountForCourseAndInfinite(Long taocanId, Long vipId) { return sysProjUseDao.selectTaocanCountForCourseAndInfinite(taocanId, vipId); } + + @Override + public void deleteByOrderItemId(Long id) { + int count=sysProjUseDao.selectUseCountByOrderItemId(id); + if(count>0){ + SysProjUse query=new SysProjUse(); + query.setOrderItemId(id); + List<SysProjUse> sysProjUses = sysProjUseDao.selectByModel(query); + if(sysProjUses.size()>1){ + throw new GlobleException(sysProjUses.get(0).getProjName()+"套餐已经被使用无法删除"); + }else { + throw new GlobleException(sysProjUses.get(0).getProjName()+"项目已经被使用无法删除"); + } + }else { + sysProjUseDao.deleteByOrderItemId(id); + } + } } \ No newline at end of file diff --git a/zq-erp/src/main/java/com/matrix/system/hiveErp/action/ErpShoppingGoodsController.java b/zq-erp/src/main/java/com/matrix/system/hiveErp/action/ErpShoppingGoodsController.java index 6e78a24..c22f83c 100644 --- a/zq-erp/src/main/java/com/matrix/system/hiveErp/action/ErpShoppingGoodsController.java +++ b/zq-erp/src/main/java/com/matrix/system/hiveErp/action/ErpShoppingGoodsController.java @@ -101,9 +101,6 @@ shoppingGoods.setAssembleGoods(assembleListGoods); List<ShoppingGoodsAssemble> assembleListProj = shoppingGoodsAssembleDao.selectProjByShoppingGoodsId(shoppingGoods.getId()); shoppingGoods.setAssembleProj(assembleListProj); - } else if (Dictionary.SHOPPING_GOODS_TYPE_ZHK.equals(shoppingGoods.getGoodType())) { - List<ShoppingGoodsAssemble> assembleList = shoppingGoodsAssembleDao.selectAssembleShoppingGoodsByShoppingGoodsId(shoppingGoods.getId()); - shoppingGoods.setZongheCarGoods(assembleList); } @@ -132,9 +129,6 @@ // 返回充值卡编辑界面 WebUtil.getRequest().setAttribute("obj", shoppingGoods); return "admin/hive-erp/products/money-card-form"; - } else if (shoppingGoods.getGoodType().equals(Dictionary.SHOPPING_GOODS_TYPE_ZHK)) { - WebUtil.getRequest().setAttribute("obj", shoppingGoods); - return "admin/hive-erp/products/zonghe-card-form"; } diff --git a/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/OrderTask.java b/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/OrderTask.java index 7b2d38e..05086bb 100644 --- a/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/OrderTask.java +++ b/zq-erp/src/main/java/com/matrix/system/shopXcx/mqTask/OrderTask.java @@ -185,17 +185,6 @@ orderItemDao.insert(orderItem); } break; - case Dictionary.SHOPPING_GOODS_TYPE_ZHK: - // 新增明细 - orderItem.setGoodsId(shoppingGoods.getId()); - // 每一个充值卡都看成一个单独的订单条目 - count = orderItem.getCount(); - for (int j = 0; j < count; j++) { - orderItem.setCount(1); - orderItem.setId(null); - orderItemDao.insert(orderItem); - } - break; } } // 处理收款逻辑 diff --git a/zq-erp/src/main/resources/mybatis/mapper/hive/SysProjUseDao.xml b/zq-erp/src/main/resources/mybatis/mapper/hive/SysProjUseDao.xml index 335a873..c0d8efd 100644 --- a/zq-erp/src/main/resources/mybatis/mapper/hive/SysProjUseDao.xml +++ b/zq-erp/src/main/resources/mybatis/mapper/hive/SysProjUseDao.xml @@ -948,4 +948,12 @@ select count(1) from sys_proj_use where taocan_id=#{taocanId} and vip_id=#{vipId} </select> + <select id="selectUseCountByOrderItemId" resultType="java.lang.Integer"> + SELECT count(*) + from sys_beautician_state a + LEFT JOIN sys_proj_use b on a.puse_id=b.ID + left join sys_proj_services c on a.SERVICES_ID=c.id + where b.ORDER_ITEM_ID=#{orderItemId} + and c.STATE !='预约取消'; + </select> </mapper> \ No newline at end of file -- Gitblit v1.9.1