From ac75512cd7e4e55619dbe77c489a39e5c2f17c0c Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 10 Feb 2023 15:57:17 +0800
Subject: [PATCH] 增加样品功能 增加一个规格为样品

---
 src/main/java/cc/mrbird/febs/mall/mapper/MallOrderItemMapper.java               |    2 
 src/main/java/cc/mrbird/febs/mall/vo/GoodsDetailsSkuVo.java                     |    3 +
 src/main/resources/mapper/modules/MallOrderItemMapper.xml                       |    6 ++
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |  167 +++++++++++++++++--------------------------------------
 4 files changed, 63 insertions(+), 115 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderItemMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderItemMapper.java
index 28ac651..babed24 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderItemMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderItemMapper.java
@@ -10,6 +10,8 @@
 
     List<MallOrderItem> selectItemByGoodsIdUnCancel(@Param("goodsId") Long goodsId, @Param("memberId") Long memberId);
 
+    List<MallOrderItem> selectItemBySkuIdUnCancel(@Param("skuId") Long skuId, @Param("memberId") Long memberId);
+
     List<MallOrderItem> selectListByNotInStateAndOrderId(@Param("state")Integer i, @Param("orderId")Long orderId);
 
     void updateStateByOrderId(@Param("state")Integer i,  @Param("orderId")Long id);
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
index 219705f..f9f34dc 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
@@ -86,35 +86,17 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public Long createOrder(AddOrderDto addOrderDto) {
-//        synchronized(this){
         MallMember member = LoginUserUtil.getLoginUser();
         //验证用户的等级
         if(AgentLevelEnum.ZERO_LEVEL.name().equals(member.getLevel())){
             throw new FebsException("请先申请成为代理人");
         }
-//        String takeUniqueCode = addOrderDto.getTakeUniqueCode();
-//        if(StrUtil.isEmpty(takeUniqueCode)){
-//            throw new FebsException("请选择自提点");
-//        }
-
-//        MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(takeUniqueCode);
-//        if(ObjectUtil.isEmpty(mallTeamLeader)){
-//            throw new FebsException("请重新选择团长");
-//        }
 
         //订单范围内才允许下单
         MallAddressInfo address = mallAddressInfoMapper.selectAddressInfoByMemberIdAndId(member.getId(), addOrderDto.getAddressId());
         if(ObjectUtil.isEmpty(address)){
             throw new FebsException("请重新选择收货地址信息");
         }
-//        MallElectronicFence mallElectronicFence = mallElectronicFenceMapper.selectByTeamLeaderCode(mallTeamLeader.getUniqueCode());
-//        if(ObjectUtil.isNotEmpty(mallElectronicFence)){
-//            String inStr = iMallElectronicFenceService.fenceToLocation(mallElectronicFence.getGKey(),
-//                    mallElectronicFence.getServiceId(), address.getLongitude() + "," + address.getLatitude(), mallElectronicFence.getGid());
-//            if("1".equals(inStr)){
-//                throw new FebsException("不在当前团长的配送范围内");
-//            }
-//        }
 
         String orderNo = MallUtils.getOrderNum();
         MallOrderInfo orderInfo = new MallOrderInfo();
@@ -124,17 +106,13 @@
         orderInfo.setStatus(OrderStatusEnum.WAIT_PAY.getValue());
         orderInfo.setRemark(addOrderDto.getRemark());
         orderInfo.setOrderType(addOrderDto.getOrderType());
-
-//        orderInfo.setTakeUniqueCode(addOrderDto.getTakeUniqueCode());
         orderInfo.setDeliveryType(2);
-
         if (CollUtil.isEmpty(addOrderDto.getItems())) {
             throw new FebsException("参数错误");
         }
-
         this.baseMapper.insert(orderInfo);
+
         BigDecimal total = BigDecimal.ZERO;
-        BigDecimal carriage = BigDecimal.ZERO;
         for (AddOrderItemDto item : addOrderDto.getItems()) {
                 MallOrderItem orderItem = new MallOrderItem();
 
@@ -168,6 +146,14 @@
                         throw new FebsException("购买商品或sku不存在");
                     }
 
+                    if("样品".equals(sku.getSample())){
+                        List<MallOrderItem> items = mallOrderItemMapper.selectItemBySkuIdUnCancel(sku.getId(), member.getId());
+                        if (CollUtil.isNotEmpty(items)) {
+                            throw new FebsException("样品一个用户只能购买一次");
+                        }
+
+                    }
+
                     if (sku.getStock() < item.getCnt()) {
                         throw new FebsException(sku.getSkuName() + "库存不足");
                     }
@@ -184,9 +170,7 @@
                     if (MallGoods.ISSALE_STATUS_DISABLED.equals(mallGoods.getIsSale())) {
                         throw new FebsException(mallGoods.getGoodsName() + "已下架");
                     }
-
-//                    mallGoods.setStock(mallGoods.getStock() - item.getCnt());
-//                    mallGoods.setVolume(mallGoods.getVolume() + item.getCnt());
+                    //商品库存销量计算
                     Integer goodsResult = mallGoodsMapper.upDateStockAndVolumeByGoodsId(mallGoods.getId(), item.getCnt());
                     if(1 != goodsResult){
                         throw new FebsException(mallGoods.getGoodsName() + "库存不足");
@@ -208,11 +192,7 @@
                     orderItem.setCostPrice(sku.getCostPrice());
 
                     total = total.add(amount);
-                    carriage = carriage.add(mallGoods.getCarriage());
-
-//                    sku.setStock(sku.getStock() - item.getCnt());
-//                    sku.setSkuVolume(sku.getSkuVolume() + item.getCnt());
-//                    mallGoodsSkuMapper.updateById(sku);
+                    //规格的库存销量
                     Integer skuResult = mallGoodsSkuMapper.upDateStockAndVolumeBySkuId(sku.getId(),item.getCnt());
                     if(1 != skuResult){
                         throw new FebsException(sku.getSkuName() + "库存不足");
@@ -223,31 +203,27 @@
                 }
                 mallOrderItemMapper.insert(orderItem);
         }
-        //配送费
+        //运费
         BigDecimal delivaryAmount = addOrderDto.getDeliveryAmount() == null ? BigDecimal.ZERO : addOrderDto.getDeliveryAmount();
-        if(BigDecimal.ZERO.compareTo(delivaryAmount) < 0 && 1 == addOrderDto.getIsHome()){
-            total = total.add(delivaryAmount);
-            orderInfo.setCarriage(delivaryAmount);
-        }
+        orderInfo.setCarriage(delivaryAmount);
+
+        total = total.add(delivaryAmount);
         orderInfo.setAmount(total);
         orderInfo.setAddressId(address.getId());
         orderInfo.setName(address.getName());
         orderInfo.setPhone(address.getPhone());
         orderInfo.setIsHome(addOrderDto.getIsHome());
-        //订单金额大于50,且选择送货上门,订单需要选择地址信息
-//        if(1 == addOrderDto.getIsHome()){
-            if (StrUtil.isBlank(address.getLatitude())||StrUtil.isBlank(address.getLongitude())) {
-                throw new FebsException("请添加地址");
-            }
-            orderInfo.setAddress(address.getArea() + address.getAddress());
-            orderInfo.setLatitude(address.getLatitude());
-            orderInfo.setLongitude(address.getLongitude());
-//        }
+
+        if (StrUtil.isBlank(address.getLatitude())||StrUtil.isBlank(address.getLongitude())) {
+            throw new FebsException("请添加地址");
+        }
+        orderInfo.setAddress(address.getArea() + address.getAddress());
+        orderInfo.setLatitude(address.getLatitude());
+        orderInfo.setLongitude(address.getLongitude());
         this.baseMapper.updateById(orderInfo);
 
         agentProducer.sendOrderCancelDelayMsg(orderInfo.getId(), 15 * 60 * 1000L);
         return orderInfo.getId();
-//        }
     }
 
 
@@ -352,8 +328,6 @@
         String wxResultStr = "";
         switch (payOrderDto.getType()) {
             case "1":
-//                orderInfo.setPayOrderNo(payOrderDto.getPayOrderNo());
-//                orderInfo.setPayImage(payOrderDto.getPayImage());
                 BrandWCPayRequestData brandWCPayRequestData = null;
                 try {
                     brandWCPayRequestData = iXcxPayService.startPayment(orderInfo);
@@ -363,7 +337,6 @@
                 wxResultStr = JSONUtil.toJsonStr(brandWCPayRequestData);
                 payResultStr = brandWCPayRequestData.getPrepay_id();
                 orderInfo.setPayMethod("微信支付");
-//                agentProducer.sendOrderReturn(orderInfo.getId());
                 break;
             case "2":
                 if (StrUtil.isNotBlank(orderInfo.getPayOrderNo())) {
@@ -386,43 +359,7 @@
                 orderInfo.setPayResult("1");
                 orderInfo.setDeliveryState(OrderDeliveryStateEnum.DELIVERY_WAIT.getValue());
 
-//                boolean hasTc = false;
-//                // 静态倍数
-//                List<MallOrderItem> orderItems = this.baseMapper.getMallOrderItemByOrderId(orderInfo.getId());
-//                if (CollUtil.isNotEmpty(orderItems)) {
-//                    for (MallOrderItem orderItem : orderItems) {
-//                        MallGoods mallGoods = mallGoodsMapper.selectById(orderItem.getGoodsId());
-//                        BigDecimal score = BigDecimal.ZERO;
-//                        MallGoodsSku sku = mallGoodsSkuMapper.selectById(orderItem.getSkuId());
-//                        if (mallGoods.getIsNormal() == 2) {
-//                            hasTc = true;
-//                            score = sku.getPresentPrice().multiply(mallGoods.getStaticMulti()).multiply(new BigDecimal(orderItem.getCnt()));
-////                            BigDecimal staticMulti = mallGoods.getStaticMulti() == null ? BigDecimal.ZERO : mallGoods.getStaticMulti();
-////                            score = sku.getPresentPrice().multiply(staticMulti);
-//                        }
-//
-//                        if (score.compareTo(BigDecimal.ZERO) > 0) {
-//                            memberWalletService.add(score, member.getId(), "score");
-//                            mallMoneyFlowService.addMoneyFlow(member.getId(), score, MoneyFlowTypeEnum.STATIC_BONUS.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.SCORE.getValue());
-//
-//                            // 添加业绩
-//                            mallAchieveService.add(orderItem.getId());
-//                        }
-//                    }
-//                }
-
-                // 购买套餐后,升级为普通会员
-//                if (hasTc) {
-//                    MallMember mallMember = memberMapper.selectById(member.getId());
-//                    if (AgentLevelEnum.ZERO_LEVEL.name().equals(mallMember.getLevel())) {
-//                        mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name());
-//                        memberMapper.updateById(mallMember);
-//                    }
-//                }
-
                 mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getAmount().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue());
-//                agentProducer.sendAutoLevelUpMsg(member.getId());
-//                agentProducer.sendOrderReturn(orderInfo.getId());
                 break;
             case "4":
                 if (orderInfo.getOrderType() != 2) {
@@ -555,9 +492,9 @@
             throw new FebsException("该状态不能确认收货");
         }
 
-        if (orderInfo.getDeliveryState() != OrderDeliveryStateEnum.DELIVERY_FINISH.getValue()) {
-            throw new FebsException("还未送至自提点");
-        }
+//        if (orderInfo.getDeliveryState() != OrderDeliveryStateEnum.DELIVERY_FINISH.getValue()) {
+//            throw new FebsException("还未送至自提点");
+//        }
 
         List<MallRefundEntity> mallRefundEntities = mallRefundMapper.selectByItemIdAndOrderIdAndState(null, orderInfo.getId(), 3);
         if(CollUtil.isNotEmpty(mallRefundEntities)){
@@ -569,33 +506,33 @@
         this.baseMapper.updateById(orderInfo);
 
         //生成一条团长提成记录
-        Long orderInfoId = orderInfo.getId();
-        List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(orderInfoId);
-        if(CollUtil.isNotEmpty(mallOrderItemList)){
-
-            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(orderInfo.getTakeUniqueCode());
-            Integer profitSwitch = mallTeamLeader.getProfitSwitch()==null?2:mallTeamLeader.getProfitSwitch();
-            BigDecimal bonusPercent =new BigDecimal(mallTeamLeader.getBonusPercent()==null?"0":mallTeamLeader.getBonusPercent());
-
-            if(1 == profitSwitch){
-                for(MallOrderItem mallOrderItem : mallOrderItemList){
-                    Integer state = mallOrderItem.getState() == null ? 1 : mallOrderItem.getState();
-                    if(1 == state){
-                        MallLeaderAchieve mallLeaderAchieve = new MallLeaderAchieve();
-                        mallLeaderAchieve.setMemberId(orderInfo.getMemberId());
-                        mallLeaderAchieve.setOrderNo(orderInfo.getOrderNo());
-                        mallLeaderAchieve.setOrderItemId(mallOrderItem.getId());
-                        BigDecimal itemAmount = mallOrderItem.getAmount();
-                        mallLeaderAchieve.setAmount(itemAmount);
-                        BigDecimal bigDecimal = bonusPercent.multiply(itemAmount).setScale(2, BigDecimal.ROUND_DOWN);
-                        mallLeaderAchieve.setProfitAmount(bigDecimal);
-                        mallLeaderAchieve.setUniqueCode(orderInfo.getTakeUniqueCode());
-                        mallLeaderAchieve.setState(MallLeaderAchieve.STATE_ONE);
-                        mallLeaderAchieveMapper.insert(mallLeaderAchieve);
-                    }
-                }
-            }
-        }
+//        Long orderInfoId = orderInfo.getId();
+//        List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(orderInfoId);
+//        if(CollUtil.isNotEmpty(mallOrderItemList)){
+//
+//            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(orderInfo.getTakeUniqueCode());
+//            Integer profitSwitch = mallTeamLeader.getProfitSwitch()==null?2:mallTeamLeader.getProfitSwitch();
+//            BigDecimal bonusPercent =new BigDecimal(mallTeamLeader.getBonusPercent()==null?"0":mallTeamLeader.getBonusPercent());
+//
+//            if(1 == profitSwitch){
+//                for(MallOrderItem mallOrderItem : mallOrderItemList){
+//                    Integer state = mallOrderItem.getState() == null ? 1 : mallOrderItem.getState();
+//                    if(1 == state){
+//                        MallLeaderAchieve mallLeaderAchieve = new MallLeaderAchieve();
+//                        mallLeaderAchieve.setMemberId(orderInfo.getMemberId());
+//                        mallLeaderAchieve.setOrderNo(orderInfo.getOrderNo());
+//                        mallLeaderAchieve.setOrderItemId(mallOrderItem.getId());
+//                        BigDecimal itemAmount = mallOrderItem.getAmount();
+//                        mallLeaderAchieve.setAmount(itemAmount);
+//                        BigDecimal bigDecimal = bonusPercent.multiply(itemAmount).setScale(2, BigDecimal.ROUND_DOWN);
+//                        mallLeaderAchieve.setProfitAmount(bigDecimal);
+//                        mallLeaderAchieve.setUniqueCode(orderInfo.getTakeUniqueCode());
+//                        mallLeaderAchieve.setState(MallLeaderAchieve.STATE_ONE);
+//                        mallLeaderAchieveMapper.insert(mallLeaderAchieve);
+//                    }
+//                }
+//            }
+//        }
     }
 
     @Override
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/GoodsDetailsSkuVo.java b/src/main/java/cc/mrbird/febs/mall/vo/GoodsDetailsSkuVo.java
index 4479aa1..4914a0c 100644
--- a/src/main/java/cc/mrbird/febs/mall/vo/GoodsDetailsSkuVo.java
+++ b/src/main/java/cc/mrbird/febs/mall/vo/GoodsDetailsSkuVo.java
@@ -34,4 +34,7 @@
 
     @ApiModelProperty(value = "现价")
     private BigDecimal presentPrice;
+
+    @ApiModelProperty(value = "样品,为空则代表不是样品")
+    private String sample;
 }
diff --git a/src/main/resources/mapper/modules/MallOrderItemMapper.xml b/src/main/resources/mapper/modules/MallOrderItemMapper.xml
index 7cf7252..8bfdc43 100644
--- a/src/main/resources/mapper/modules/MallOrderItemMapper.xml
+++ b/src/main/resources/mapper/modules/MallOrderItemMapper.xml
@@ -8,6 +8,12 @@
         where a.goods_id=#{goodsId} and b.member_id=#{memberId}
     </select>
 
+    <select id="selectItemBySkuIdUnCancel" resultType="cc.mrbird.febs.mall.entity.MallOrderItem">
+        select a.* from mall_order_item a
+            inner join mall_order_info b on a.order_id=b.ID and b.status in (1,2,3,4)
+        where a.sku_id = #{skuId} and b.member_id = #{memberId}
+    </select>
+
     <select id="selectListByNotInStateAndOrderId" resultType="cc.mrbird.febs.mall.entity.MallOrderItem">
         select a.* from mall_order_item a
         where a.state != #{state} and a.order_id=#{orderId}

--
Gitblit v1.9.1