From de8b3cf7a9b22be7abcb544a53dcea7f1b340760 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Wed, 20 Aug 2025 17:23:14 +0800 Subject: [PATCH] feat(ai): 新增开始答题V2 接口 --- src/main/java/cc/mrbird/febs/mall/service/impl/ApiClothesOrderServiceImpl.java | 192 ++++++++++++++++++++++++++++++++++------------- 1 files changed, 139 insertions(+), 53 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiClothesOrderServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiClothesOrderServiceImpl.java index e4df4fe..ea2ca5e 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiClothesOrderServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiClothesOrderServiceImpl.java @@ -74,6 +74,9 @@ private final IApiMallMemberWalletService apiMallMemberWalletService; private final IMallMoneyFlowService mallMoneyFlowService; + private final ClothesPatternRemarkMapper clothesPatternRemarkMapper; + private final ClothesLocationRemarkMapper clothesLocationRemarkMapper; + @Override public FebsResponse myDraft(ApiMyDraftPageDto dto) { @@ -112,30 +115,50 @@ record.setStatureName(clothesMemberStature.getName()); } - Long patternId = ObjectUtil.defaultIfNull(record.getPatternId(),0L); - List<ClothesTypePattern> clothesTypePatterns = clothesTypePatternMapper.selectList(Wrappers.<ClothesTypePattern>lambdaQuery().eq(ClothesTypePattern::getTypeId, typeId)); - if (CollUtil.isNotEmpty(clothesTypePatterns)){ - Set<Long> patternIds = clothesTypePatterns.stream().map(ClothesTypePattern::getPatternId).collect(Collectors.toSet()); - if(CollUtil.isNotEmpty( patternIds) && patternIds.contains(patternId)){ + BigDecimal totalPatternPrice = BigDecimal.ZERO; + List<ClothesPatternRemark> clothesPatternRemarks = clothesPatternRemarkMapper.selectList( + Wrappers.lambdaQuery(ClothesPatternRemark.class) + .eq(ClothesPatternRemark::getSourceId, record.getId()) + .eq(ClothesPatternRemark::getType, SocialPatternLocationTypeEnum.DRAFT.getValue()) + ); + if(CollUtil.isNotEmpty(clothesPatternRemarks)){ + List<ApiClothesPatternInfoVo> vos = new ArrayList<>(); + for (ClothesPatternRemark entity : clothesPatternRemarks){ + Long patternId = entity.getPatternId(); + ApiClothesPatternInfoVo vo = new ApiClothesPatternInfoVo(); + vo.setPatternId(patternId); ClothesPattern clothesPattern = clothesPatternMapper.selectById(patternId); - if (ObjectUtil.isNotNull(clothesPattern)){ - record.setPatternName(clothesPattern.getName()); - record.setPatternPrice(clothesPattern.getPrice()); - } + vo.setPatternName(clothesPattern.getName()); + vo.setPatternPrice(clothesPattern.getPrice()); + vo.setPatternRemark(entity.getRemark()); + vos.add(vo); + + totalPatternPrice = totalPatternPrice.add(clothesPattern.getPrice()); } + record.setPatternList(vos); } - Long locationId = ObjectUtil.defaultIfNull(record.getLocationId(),0L); - List<ClothesTypeLocation> clothesTypeLocations = clothesTypeLocationMapper.selectList(Wrappers.<ClothesTypeLocation>lambdaQuery().eq(ClothesTypeLocation::getTypeId, typeId)); - if (CollUtil.isNotEmpty(clothesTypeLocations)){ - Set<Long> locationIds = clothesTypeLocations.stream().map(ClothesTypeLocation::getLocationId).collect(Collectors.toSet()); - if(CollUtil.isNotEmpty( locationIds) && locationIds.contains(locationId)){ - ClothesLocation clothesLocation = clothesLocationMapper.selectById(locationId); - if (ObjectUtil.isNotNull(clothesLocation)){ - record.setLocationName(clothesLocation.getName()); - record.setLocationPrice(clothesLocation.getPrice()); - } + BigDecimal totalLocationPrice = BigDecimal.ZERO; + List<ClothesLocationRemark> clothesLocationRemarks = clothesLocationRemarkMapper.selectList( + Wrappers.lambdaQuery(ClothesLocationRemark.class) + .eq(ClothesLocationRemark::getSourceId, record.getId()) + .eq(ClothesLocationRemark::getType, SocialPatternLocationTypeEnum.DRAFT.getValue()) + ); + if(CollUtil.isNotEmpty(clothesLocationRemarks)){ + List<ApiClothesLocationInfoVo> vos = new ArrayList<>(); + for (ClothesLocationRemark entity : clothesLocationRemarks){ + Long locationId = entity.getLocationId(); + ApiClothesLocationInfoVo vo = new ApiClothesLocationInfoVo(); + vo.setLocationId(locationId); + ClothesLocation location = clothesLocationMapper.selectById(locationId); + vo.setLocationName(location.getName()); + vo.setLocationPrice(location.getPrice()); + vo.setLocationRemark(entity.getRemark()); + vos.add(vo); + + totalLocationPrice = totalLocationPrice.add(location.getPrice()); } + record.setLocationList(vos); } Long artId = ObjectUtil.defaultIfNull(record.getArtId(),0L); @@ -165,11 +188,11 @@ } BigDecimal amount = - record.getClothPrice() - .add(record.getLocationPrice()) + record.getClothPrice() + .add(totalPatternPrice) .add(record.getArtPrice()) .add(record.getSizePrice()) - .add(record.getPatternPrice()).setScale(2, RoundingMode.DOWN); + .add(totalLocationPrice).setScale(2, RoundingMode.DOWN); record.setAmount(amount); } } @@ -187,12 +210,13 @@ ClothesOrderDraft clothesOrderDraft = clothesOrderDraftMapper.selectById(id); if (ObjectUtil.isNotNull(clothesOrderDraft)){ + Long draftId = clothesOrderDraft.getId(); + Long typeId = clothesOrderDraft.getTypeId(); ClothesType clothesType = clothesTypeMapper.selectById(typeId); record.setTypeId(typeId); record.setTypeName(clothesType.getName()); record.setTypeImage(clothesType.getImage()); - record.setPatternRemark(clothesOrderDraft.getPatternRemark()); Long sizeId = ObjectUtil.defaultIfNull(clothesOrderDraft.getSizeId(),0L); List<ClothesTypeSize> clothesTypeSizes = clothesTypeSizeMapper.selectList(Wrappers.<ClothesTypeSize>lambdaQuery().eq(ClothesTypeSize::getTypeId, typeId)); @@ -204,6 +228,7 @@ record.setSizeId(sizeId); record.setSizeName(clothesSize.getName()); record.setSizePrice(clothesSize.getPrice()); + record.setSizeImage(clothesSize.getImage()); } } } @@ -215,32 +240,63 @@ record.setStatureName(clothesMemberStature.getName()); } - Long patternId = ObjectUtil.defaultIfNull(clothesOrderDraft.getPatternId(),0L); - List<ClothesTypePattern> clothesTypePatterns = clothesTypePatternMapper.selectList(Wrappers.<ClothesTypePattern>lambdaQuery().eq(ClothesTypePattern::getTypeId, typeId)); - if (CollUtil.isNotEmpty(clothesTypePatterns)){ - Set<Long> patternIds = clothesTypePatterns.stream().map(ClothesTypePattern::getPatternId).collect(Collectors.toSet()); - if(CollUtil.isNotEmpty( patternIds) && patternIds.contains(patternId)){ + BigDecimal totalPatternPrice = BigDecimal.ZERO; + List<ClothesPatternRemark> clothesPatternRemarks = clothesPatternRemarkMapper.selectList( + Wrappers.lambdaQuery(ClothesPatternRemark.class) + .eq(ClothesPatternRemark::getSourceId, draftId) + .eq(ClothesPatternRemark::getType, SocialPatternLocationTypeEnum.DRAFT.getValue()) + ); + if(CollUtil.isNotEmpty(clothesPatternRemarks)){ + List<ApiClothesPatternInfoVo> vos = new ArrayList<>(); + for (ClothesPatternRemark entity : clothesPatternRemarks){ + Long patternId = entity.getPatternId(); + ApiClothesPatternInfoVo vo = new ApiClothesPatternInfoVo(); + vo.setPatternId(patternId); ClothesPattern clothesPattern = clothesPatternMapper.selectById(patternId); - if (ObjectUtil.isNotNull(clothesPattern)){ - record.setPatternId(patternId); - record.setPatternName(clothesPattern.getName()); - record.setPatternPrice(clothesPattern.getPrice()); - } + vo.setPatternName(clothesPattern.getName()); + vo.setPatternPrice(clothesPattern.getPrice()); + vo.setPatternRemark(entity.getRemark()); + vo.setPatternImage(clothesPattern.getImage()); + vo.setBoxHeight(clothesPattern.getBoxHeight()); + vo.setBoxWidth(clothesPattern.getBoxWidth()); + vo.setLeftPercent(clothesPattern.getLeftPercent()); + vo.setTopPercent(clothesPattern.getTopPercent()); + + + vos.add(vo); + + totalPatternPrice = totalPatternPrice.add(clothesPattern.getPrice()); } + record.setPatternList(vos); } - Long locationId = ObjectUtil.defaultIfNull(clothesOrderDraft.getLocationId(),0L); - List<ClothesTypeLocation> clothesTypeLocations = clothesTypeLocationMapper.selectList(Wrappers.<ClothesTypeLocation>lambdaQuery().eq(ClothesTypeLocation::getTypeId, typeId)); - if (CollUtil.isNotEmpty(clothesTypeLocations)){ - Set<Long> locationIds = clothesTypeLocations.stream().map(ClothesTypeLocation::getLocationId).collect(Collectors.toSet()); - if(CollUtil.isNotEmpty( locationIds) && locationIds.contains(locationId)){ - ClothesLocation clothesLocation = clothesLocationMapper.selectById(locationId); - if (ObjectUtil.isNotNull(clothesLocation)){ - record.setLocationId(locationId); - record.setLocationName(clothesLocation.getName()); - record.setLocationPrice(clothesLocation.getPrice()); - } + BigDecimal totalLocationPrice = BigDecimal.ZERO; + List<ClothesLocationRemark> clothesLocationRemarks = clothesLocationRemarkMapper.selectList( + Wrappers.lambdaQuery(ClothesLocationRemark.class) + .eq(ClothesLocationRemark::getSourceId, draftId) + .eq(ClothesLocationRemark::getType, SocialPatternLocationTypeEnum.DRAFT.getValue()) + ); + if(CollUtil.isNotEmpty(clothesLocationRemarks)){ + List<ApiClothesLocationInfoVo> vos = new ArrayList<>(); + for (ClothesLocationRemark entity : clothesLocationRemarks){ + Long locationId = entity.getLocationId(); + ApiClothesLocationInfoVo vo = new ApiClothesLocationInfoVo(); + vo.setLocationId(locationId); + ClothesLocation location = clothesLocationMapper.selectById(locationId); + vo.setLocationName(location.getName()); + vo.setLocationPrice(location.getPrice()); + vo.setLocationRemark(entity.getRemark()); + vo.setLocationImage(location.getImage()); + + vo.setBoxHeight(location.getBoxHeight()); + vo.setBoxWidth(location.getBoxWidth()); + vo.setLeftPercent(location.getLeftPercent()); + vo.setTopPercent(location.getTopPercent()); + vos.add(vo); + + totalLocationPrice = totalLocationPrice.add(location.getPrice()); } + record.setLocationList(vos); } Long artId = ObjectUtil.defaultIfNull(clothesOrderDraft.getArtId(),0L); @@ -253,6 +309,7 @@ record.setArtId(artId); record.setArtName(clothesArt.getName()); record.setArtPrice(clothesArt.getPrice()); + record.setArtImage(clothesArt.getImage()); } } } @@ -267,16 +324,17 @@ record.setClothId(clothId); record.setClothName(clothesCloth.getName()); record.setClothPrice(clothesCloth.getPrice()); + record.setClothImage(clothesCloth.getImage()); } } } BigDecimal amount = record.getClothPrice() - .add(record.getLocationPrice()) + .add(totalPatternPrice) .add(record.getArtPrice()) .add(record.getSizePrice()) - .add(record.getPatternPrice()).setScale(2, RoundingMode.DOWN); + .add(totalLocationPrice).setScale(2, RoundingMode.DOWN); record.setAmount(amount); } @@ -372,6 +430,7 @@ clothesOrderMapper.insert(orderInfo); Long orderId = orderInfo.getId(); + /** * 创建订单子表 */ @@ -387,9 +446,10 @@ if (ObjectUtil.isNull(cloth)) { throw new FebsException("请选择布料"); } + orderItem.setItemId(cloth.getId()); orderItem.setName(cloth.getName()); orderItem.setPrice(cloth.getPrice()); - orderItem.setItemCnt(item.getCnt()); + orderItem.setItemCnt(orderItem.getItemCnt()); orderItem.setAmount(cloth.getPrice().multiply(new BigDecimal(orderItem.getItemCnt())).setScale(2, RoundingMode.DOWN)); clothesOrderItemMapper.insert(orderItem); @@ -400,9 +460,10 @@ if (ObjectUtil.isNull(size)) { throw new FebsException("请选择尺寸"); } + orderItem.setItemId(size.getId()); orderItem.setName(size.getName()); orderItem.setPrice(size.getPrice()); - orderItem.setItemCnt(item.getCnt()); + orderItem.setItemCnt(orderItem.getItemCnt()); orderItem.setAmount(orderItem.getPrice().multiply(new BigDecimal(orderItem.getItemCnt())).setScale(2, RoundingMode.DOWN)); clothesOrderItemMapper.insert(orderItem); @@ -413,10 +474,12 @@ if (ObjectUtil.isNull(location)) { throw new FebsException("请选择图案位置"); } + orderItem.setItemId(location.getId()); orderItem.setName(location.getName()); orderItem.setPrice(location.getPrice()); - orderItem.setItemCnt(item.getCnt()); + orderItem.setItemCnt(orderItem.getItemCnt()); orderItem.setAmount(orderItem.getPrice().multiply(new BigDecimal(orderItem.getItemCnt())).setScale(2, RoundingMode.DOWN)); + orderItem.setRemark(item.getPatternRemark()); clothesOrderItemMapper.insert(orderItem); total = total.add(orderItem.getAmount()); @@ -426,10 +489,12 @@ if (ObjectUtil.isNull(pattern)) { throw new FebsException("请选择图案"); } + orderItem.setItemId(pattern.getId()); orderItem.setRemark(item.getPatternRemark()); orderItem.setName(pattern.getName()); orderItem.setPrice(pattern.getPrice()); - orderItem.setItemCnt(item.getCnt()); + orderItem.setItemCnt(orderItem.getItemCnt()); + orderItem.setRemark(item.getPatternRemark()); orderItem.setAmount(orderItem.getPrice().multiply(new BigDecimal(orderItem.getItemCnt())).setScale(2, RoundingMode.DOWN)); clothesOrderItemMapper.insert(orderItem); @@ -440,9 +505,10 @@ if (ObjectUtil.isNull(art)) { throw new FebsException("请选择工艺"); } + orderItem.setItemId(art.getId()); orderItem.setName(art.getName()); orderItem.setPrice(art.getPrice()); - orderItem.setItemCnt(item.getCnt()); + orderItem.setItemCnt(orderItem.getItemCnt()); orderItem.setAmount(orderItem.getPrice().multiply(new BigDecimal(orderItem.getItemCnt())).setScale(2, RoundingMode.DOWN)); clothesOrderItemMapper.insert(orderItem); @@ -450,9 +516,13 @@ continue; } else if (ClothesOrderItemEnum.CUSTOMIZE.getCode() == item.getType()) { ClothesMemberStature clothesMemberStature = clothesMemberStatureMapper.selectById(item.getSkuId()); + if (ObjectUtil.isNull(clothesMemberStature)){ + throw new FebsException("请选择您的自定义尺码"); + } + orderItem.setItemId(clothesMemberStature.getId()); orderItem.setName(clothesMemberStature.getName()); orderItem.setPrice(BigDecimal.ZERO); - orderItem.setItemCnt(item.getCnt()); + orderItem.setItemCnt(orderItem.getItemCnt()); orderItem.setAmount(orderItem.getPrice().multiply(new BigDecimal(orderItem.getItemCnt())).setScale(2, RoundingMode.DOWN)); clothesOrderItemMapper.insert(orderItem); @@ -698,6 +768,22 @@ return new FebsResponse().success().data(voPage); } + @Override + public FebsResponse findMarkCnt() { + Long memberId = LoginUserUtil.getLoginUser().getId(); + + List<Map<String, Integer>> maps = clothesOrderMapper.selectOrderStatusCnt(memberId); + Map<Integer, Integer> orderCnt = new HashMap<>(); + if (CollUtil.isNotEmpty(maps)) { + for (Map<String, Integer> map : maps) { + orderCnt.put(map.get("status"), map.get("cnt")); + } + } + + Map<String, Object> result = new HashMap<>(); + result.put("order", orderCnt); + return new FebsResponse().success().data(result); + } private List<ApiClothesOrderItemInfoVo> buildOrderItemInfo(Long id) { @@ -790,7 +876,7 @@ if(ObjectUtil.isNull(orderInfo)){ throw new FebsException("订单不存在"); } - if (member.getId() != orderInfo.getMemberId()) { + if (!ObjectUtil.equal(member.getId(), orderInfo.getMemberId())) { throw new FebsException("无权限操作"); } if (ClothesEnum.UP.getCode() == orderInfo.getDelFlag()) { -- Gitblit v1.9.1