From 68defbe491894e01c4402922de33c39633fca091 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Tue, 29 Mar 2022 14:25:54 +0800 Subject: [PATCH] 系统名称 --- zq-erp/src/main/java/com/matrix/system/hive/service/imp/ShoppingGoodsServiceImpl.java | 76 +++++++++++++++++++++++++++---------- 1 files changed, 55 insertions(+), 21 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 e13f1f9..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 @@ -3,9 +3,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; @@ -18,10 +16,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; @@ -31,6 +28,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; @@ -57,10 +55,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 @@ -70,10 +110,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); } @@ -109,7 +148,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); @@ -119,7 +158,6 @@ } else { setGoodsAssembles(shoppingGoods); } - return i; @@ -207,17 +245,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()); } @@ -352,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; } } @@ -373,7 +408,6 @@ shoppingGoods.setWeiImg(Dictionary.DEFAULT_IMG); } } - /** @@ -428,8 +462,8 @@ * 计算失效时间 * * @param shoppingGoods - * @param type 1 - 购买时 2 - 消耗时 - * @param buyDate 购买日期, 当计算消耗日期时,不能为空 + * @param type 1 - 购买时 2 - 消耗时 + * @param buyDate 购买日期, 当计算消耗日期时,不能为空 * @return */ @Override -- Gitblit v1.9.1