From 560228ac3c15cccce0b2a5994d44e4e81b5b3b73 Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Tue, 24 May 2022 11:12:22 +0800 Subject: [PATCH] 合并服务单订单改造分支 --- zq-erp/src/main/java/com/matrix/system/hive/service/imp/ShoppingGoodsServiceImpl.java | 78 +++++++++++++++++++++++++++++---------- 1 files changed, 58 insertions(+), 20 deletions(-) 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 a9adf31..57ce97f 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 @@ -4,9 +4,7 @@ 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.StringUtils; -import com.matrix.core.tools.WebUtil; +import com.matrix.core.tools.*; import com.matrix.system.app.dto.ShoppingGoodsListDto; import com.matrix.system.app.vo.ShoppingGoodsDetailVo; import com.matrix.system.app.vo.ShoppingGoodsListVo; @@ -19,10 +17,9 @@ import com.matrix.system.hive.bean.ShoppingGoodsAssemble; import com.matrix.system.hive.bean.ShoppingGoodsCategory; import com.matrix.system.hive.bean.SysShopInfo; -import com.matrix.system.hive.dao.MoneyCardAssembleDao; -import com.matrix.system.hive.dao.ShoppingGoodsAssembleDao; -import com.matrix.system.hive.dao.ShoppingGoodsDao; -import com.matrix.system.hive.dao.SysShopInfoDao; +import com.matrix.system.hive.dao.*; +import com.matrix.system.hive.dto.GoodsSealLimitDto; +import com.matrix.system.hive.dto.SysOrderItemDto; import com.matrix.system.hive.service.ShoppingGoodsService; import org.apache.commons.collections.CollectionUtils; import org.springframework.beans.factory.annotation.Autowired; @@ -32,6 +29,7 @@ import javax.validation.constraints.NotNull; import java.math.BigDecimal; import java.util.ArrayList; +import java.util.Arrays; import java.util.Date; import java.util.List; import java.util.Objects; @@ -60,7 +58,52 @@ @Autowired private SysShopInfoDao shopInfoDao; + @Autowired + private SysOrderItemDao orderItemDao; + @Override + public void checkGoodsSealLimit(GoodsSealLimitDto goodsSealLimitDto) { + LogUtil.info("开始检测商品销售限制:{}", goodsSealLimitDto.toString()); + //校验参数不能为空 + checkGoodsSelLimtParam(goodsSealLimitDto); + + goodsSealLimitDto.getSysOrderItemDtoList().forEach(item -> { + ShoppingGoods shopGoods = shoppingGoodsDao.selectById(item.getGoodsId()); + //最大销售次数检测 + Integer maxNum = shopGoods.getCarMaxSaleCount(); + if (maxNum != null && maxNum != 0) { + Integer buyNum = orderItemDao.selectByGoodsId(shopGoods.getId(), null); + if (buyNum.equals(maxNum)) { + if (!shopGoods.getStaus().equals(Dictionary.BUSINESS_STATE_DOWN)) { + shopGoods.setStaus(Dictionary.BUSINESS_STATE_DOWN); + shoppingGoodsDao.update(shopGoods); + LogUtil.info("商品达到最大销售数量自动下架:{}", shopGoods.getName()); + } + } else if ((buyNum + item.getCount()) > maxNum) { + throw new GlobleException(shopGoods.getName() + "已超过最大销售数量"); + } + } + //每人限购次数检测 + Integer onceCount = shopGoods.getIsOnce(); + if (onceCount != null && onceCount != 0) { + Integer buyOnceCount = orderItemDao.selectByGoodsId(shopGoods.getId(), goodsSealLimitDto.getVipId()); + if ((buyOnceCount + item.getCount()) > onceCount) { + throw new GlobleException(shopGoods.getName() + "每人限购" + onceCount + "次"); + } + } + }); + } + + + private void checkGoodsSelLimtParam(GoodsSealLimitDto goodsSealLimitDto) { + ParamCheckUtil.requireNonNulls(goodsSealLimitDto, + goodsSealLimitDto.getVipId(), + goodsSealLimitDto.getSysOrderItemDtoList()); + + + ParamCheckUtil.requireListElementNonNull(goodsSealLimitDto.getSysOrderItemDtoList(), + Arrays.asList(SysOrderItemDto::getCount, SysOrderItemDto::getGoodsId)); + } @Override @Transactional(rollbackFor = Exception.class) @@ -69,9 +112,9 @@ SysShopInfo shopInfo = shopInfoDao.selectById(sysUsers.getShopId()); - if(shopInfo.getShopType()==SysShopInfo.SHOP_TYPE_ZONGBU){ + if(shopInfo.getShopType() == SysShopInfo.SHOP_TYPE_ZONGBU){ shoppingGoods.setHeadquarters(1); - }else{ + } else { shoppingGoods.setHeadquarters(2); } @@ -111,7 +154,7 @@ if (shoppingGoods.getReferencePice() == null) { shoppingGoods.setReferencePice(0d); } - shoppingGoods.setZjm(StringUtils.toHanyuPinyin(shoppingGoods.getName())+","+StringUtils.toHeadWordHanyuPinyin(shoppingGoods.getName())); + shoppingGoods.setZjm(StringUtils.toHanyuPinyin(shoppingGoods.getName()) + "," + StringUtils.toHeadWordHanyuPinyin(shoppingGoods.getName())); shoppingGoods.setIsDel(ShoppingGoods.NORMAL); //新增销售产品 int i = shoppingGoodsDao.insert(shoppingGoods); @@ -121,7 +164,6 @@ } else { setGoodsAssembles(shoppingGoods); } - return i; @@ -209,17 +251,17 @@ if (ShoppingGoods.SHOPPING_GOODS_TYPE_CZK.equals(shoppingGoods.getGoodType())) { setCardAssemble(shoppingGoods); - }else{ + } else { //清除原有绑定关系 shoppingGoodsAssembleDao.deleteByGoodsId(shoppingGoods.getId()); //合并绑定的产品和项目 List<ShoppingGoodsAssemble> assembles = new ArrayList<>(); - if(CollectionUtils.isNotEmpty(shoppingGoods.getAssembleGoods())){ + if (CollectionUtils.isNotEmpty(shoppingGoods.getAssembleGoods())) { assembles.addAll(shoppingGoods.getAssembleGoods()); } //如果是套餐叠加套餐绑定的项目部分 - if (Dictionary.SHOPPING_GOODS_TYPE_TC.equals(shoppingGoods.getGoodType())){ + if (Dictionary.SHOPPING_GOODS_TYPE_TC.equals(shoppingGoods.getGoodType())) { assembles.addAll(shoppingGoods.getAssembleProj()); } @@ -365,9 +407,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; } } @@ -386,7 +425,6 @@ shoppingGoods.setWeiImg(Dictionary.DEFAULT_IMG); } } - /** @@ -441,8 +479,8 @@ * 计算失效时间 * * @param shoppingGoods - * @param type 1 - 购买时 2 - 消耗时 - * @param buyDate 购买日期, 当计算消耗日期时,不能为空 + * @param type 1 - 购买时 2 - 消耗时 + * @param buyDate 购买日期, 当计算消耗日期时,不能为空 * @return */ @Override -- Gitblit v1.9.1