From 11ec1c23a9f47ed70b124e413e33e3696897390f Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 14 二月 2025 15:04:41 +0800
Subject: [PATCH] bug修改

---
 manage/src/main/java/com/jilongda/manage/controller/TOrderController.java |   60 +++++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 51 insertions(+), 9 deletions(-)

diff --git a/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java b/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java
index 7669b06..b977a7c 100644
--- a/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java
+++ b/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java
@@ -2,6 +2,9 @@
 
 
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.jilongda.common.Ticket.TAddOptometryVO;
+import com.jilongda.common.Ticket.TOrderGoodsPrintVO;
+import com.jilongda.common.Ticket.TicketUtil;
 import com.jilongda.common.basic.ApiResult;
 import com.jilongda.common.basic.PageInfo;
 import com.jilongda.manage.authority.model.SecUser;
@@ -14,12 +17,10 @@
 import com.jilongda.manage.service.*;
 import com.jilongda.manage.utils.LoginInfoUtil;
 import com.jilongda.manage.utils.OssUploadUtil;
-import com.jilongda.manage.vo.TModelVO;
-import com.jilongda.manage.vo.TOptometryVO;
-import com.jilongda.manage.vo.TOrderListVO;
-import com.jilongda.manage.vo.TOrderVO;
+import com.jilongda.manage.vo.*;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.StringUtils;
@@ -28,6 +29,7 @@
 import org.springframework.web.multipart.MultipartFile;
 
 import java.math.BigDecimal;
+import java.text.SimpleDateFormat;
 import java.time.LocalDateTime;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -178,7 +180,8 @@
 
         return ApiResult.success(tCouponReceives);
     }
-
+    @Autowired
+    private TTicketService tTicketService;
     @ApiOperation(value = "添加订单")
     @PostMapping(value = "/addOrder")
     public ApiResult addOrder(@RequestBody TOrderDTO dto) {
@@ -210,13 +213,16 @@
                 String[] split = null;
                 if(StringUtils.hasLength(rLens)){
                     split = rLens.split(",");
+                    if (split.length == 1){
+
+                    }
                 }else {
                     split = orderGood.getLLens().split(",");
                 }
-                TBrand one1 = brandService.lambdaQuery().eq(TBrand::getName, orderGood.getBrandName())
+                TBrand brand = brandService.lambdaQuery().eq(TBrand::getName, orderGood.getBrandName())
                         .eq(TBrand::getType, 2).one();
                 TLensSeries lensSeries = lensSeriesService.lambdaQuery().eq(TLensSeries::getName, orderGood.getSeriesName())
-                        .eq(TLensSeries::getBrandId, one1.getId()).one();
+                        .eq(TLensSeries::getBrandId, brand.getId()).one();
                 TLensGoods one = lensGoodsService.lambdaQuery()
                         .eq(StringUtils.hasLength(orderGood.getSeriesName()),TLensGoods::getSeriesId, lensSeries.getId())
                         .eq(StringUtils.hasLength(orderGood.getRefractiveIndex()),TLensGoods::getRefractiveIndex, orderGood.getRefractiveIndex())
@@ -225,7 +231,7 @@
                         .eq(split.length>=2,TLensGoods::getColumnMirror, split[1])
                         .one();
                 if (one!=null){
-                    if (one.getTotal()-1<0){
+                    if (one.getTotal()-1<0 && lensSeries.getType()==1 ){
                         return ApiResult.failed("库存不足");
                     }
                     // 减少对应库存
@@ -325,7 +331,7 @@
                     return ApiResult.failed("优惠券不存在");
                 }
                 List<TCouponReceive> couponReceives = couponReceiveService.lambdaQuery()
-                        .eq(TCouponReceive::getId, dto.getUserId())
+                        .eq(TCouponReceive::getUserId, dto.getUserId())
                         .eq(TCouponReceive::getCouponId, couponReceive.getCouponId())
                         .orderByDesc(TCouponReceive::getCreateTime).list();
                 if (couponReceives.isEmpty())return ApiResult.failed("优惠券不存在");
@@ -366,6 +372,42 @@
         orderGoodsService.saveBatch(orderGoods);
         lensGoodsService.updateBatchById(tLensGoods);
         frameGoodsService.updateBatchById(tFrameGoods);
+        TAddOptometryVO tAddOptometryVO = new TAddOptometryVO();
+        TTicket tTicket = tTicketService.lambdaQuery().eq(TTicket::getStoreId, dto.getStoreId())
+                .eq(TTicket::getType,1)
+                .eq(TTicket::getStatus, 1).list().stream().findFirst().orElse(null);
+        if (tTicket==null){
+            return ApiResult.failed("当前门店未绑定小票机");
+        }
+        tAddOptometryVO.setSn(tTicket.getCloudId()+"");
+        tAddOptometryVO.setPhone(dto.getPhone());
+        List<TOrderGoods> orderGoods1 = dto.getOrderGoods();
+        ArrayList<TOrderGoodsPrintVO> tOrderGoodsPrintVOS = new ArrayList<>();
+        // 复制
+        for (TOrderGoods orderGood : orderGoods1) {
+            TOrderGoodsPrintVO tOrderGoodsPrintVO = new TOrderGoodsPrintVO();
+            BeanUtils.copyProperties(orderGood,tOrderGoodsPrintVO);
+            if (orderGood.getModelId()!=null){
+                TModel byId = modelService.getById(orderGood.getModelId());
+                if (byId!=null){
+                    TMaterial byId1 = materialService.getById(byId.getMaterialId());
+                    if (byId1!=null){
+                        tOrderGoodsPrintVO.setMaterial(byId1.getName());
+                    }
+                }
+            }
+            tOrderGoodsPrintVOS.add(tOrderGoodsPrintVO);
+        }
+        tAddOptometryVO.setOrderGoods(tOrderGoodsPrintVOS);
+        tAddOptometryVO.setRemark(dto.getRemark());
+        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+        String format = simpleDateFormat.format(new Date());
+        tAddOptometryVO.setTime(format);
+        tAddOptometryVO.setMachiningCode(dto.getMachiningCode());
+        if (dto.getIsMachining()==1){
+            // 打印加工单
+            TicketUtil.printMatch(tAddOptometryVO);
+        }
         return ApiResult.success(dto.getId());
     }
 

--
Gitblit v1.7.1