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