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