From 2f8e70ad2884d2b6b7443dfae0af11ae9cfc8b99 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 28 二月 2025 17:44:10 +0800
Subject: [PATCH] bug修改

---
 manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java |   86 +++++++++++++++++++++++++++++++------------
 1 files changed, 62 insertions(+), 24 deletions(-)

diff --git a/manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java b/manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java
index 12cfa49..e1d0aaa 100644
--- a/manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java
+++ b/manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java
@@ -1,12 +1,18 @@
 package com.jilongda.manage.controller;
 
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.jilongda.common.basic.ApiResult;
 import com.jilongda.common.basic.PageInfo;
+import com.jilongda.manage.authority.model.SecUser;
+import com.jilongda.manage.authority.service.SecUserService;
+import com.jilongda.manage.dto.AccountDetailDTO;
 import com.jilongda.manage.model.*;
 import com.jilongda.manage.query.TLineUpQuery;
 import com.jilongda.manage.query.TOrderAccountingQuery;
 import com.jilongda.manage.service.*;
+import com.jilongda.manage.utils.LoginInfoUtil;
 import com.jilongda.manage.vo.TOrderAccountVO;
 import com.jilongda.manage.vo.TOrderVO;
 import io.swagger.annotations.Api;
@@ -16,6 +22,10 @@
 import org.springframework.web.bind.annotation.*;
 
 import java.math.BigDecimal;
+import java.time.LocalDate;
+import java.time.LocalDateTime;
+import java.time.temporal.ChronoUnit;
+import java.util.ArrayList;
 import java.util.List;
 
 /**
@@ -31,6 +41,8 @@
 @RequestMapping("/t-order-accounting")
 public class TOrderAccountingController {
     @Autowired
+    private SecUserService secUserService;
+    @Autowired
     private TStoreService storeService;
     @Autowired
     private TOrderService orderService;
@@ -44,6 +56,11 @@
     private TOrderGoodsService orderGoodsService;
     @Autowired
     private SecFeeItemsService feeItemsService;
+    @Autowired
+    private LoginInfoUtil loginInfoUtil;
+    @Autowired
+    private TOptometryService optometryService;
+
     @ApiOperation(value = "核算订单分页列表")
     @PostMapping(value = "/pageList")
     public ApiResult<PageInfo<TOrderVO>> pageList(@RequestBody TOrderAccountingQuery query) {
@@ -59,28 +76,36 @@
     public ApiResult<TOrderAccountVO> detail(Integer id) {
         TOrderAccountVO res = new TOrderAccountVO();
         TOrder byId = orderService.getById(id);
-        TOrderAccounting one = orderAccountingService.lambdaQuery().eq(TOrderAccounting::getOrderId, id).one();
         if (byId.getUserId()!=null){
             TAppUser byId1 = appUserService.getById(byId.getUserId());
             if(byId1!=null){
                 res.setName(byId1.getName());
                 res.setPhone(byId1.getPhone());
+                res.setRealName(byId1.getRealName());
+                res.setGender(byId1.getGender());
             }
+        }else {
+            res.setPhone(byId.getPhone());
+            res.setAge(byId.getAge());
+            res.setRealName(byId.getRealName());
+            res.setGender(byId.getGender());
         }
-        res.setAge(byId.getAge());
-        res.setRealName(byId.getRealName());
-        res.setGender(byId.getGender());
+        List<TOrderItems> list1 = orderItemsService.lambdaQuery().eq(TOrderItems::getOrderId, id).list();
+        for (TOrderItems orderItems : list1) {
+            SecFeeItems secFeeItems = feeItemsService.getById(orderItems.getItemsId());
+            orderItems.setItemsName(secFeeItems.getName());
+        }
+        res.setItemsId(byId.getItemsId());
+        res.setUserId(byId.getUserId());
+        res.setOptometryId(byId.getOptometryId());
         List<TOptometryDetail> list = optometryDetailService.lambdaQuery().eq(TOptometryDetail::getOrderId, id)
-                .eq(TOptometryDetail::getType, 1).list();
+                .eq(TOptometryDetail::getType,  1).list();
         res.setOptometryDetails(list);
         List<TOrderGoods> orderGoods = orderGoodsService.lambdaQuery()
                 .eq(TOrderGoods::getOrderId, id).list();
         BigDecimal goodsMoney = new BigDecimal("0");
         BigDecimal costMoney = new BigDecimal("0");
         BigDecimal constConfirm = new BigDecimal("0");
-        if (one!=null){
-
-        }
         for (TOrderGoods orderGood : orderGoods) {
             goodsMoney =goodsMoney.add(orderGood.getGoodsMoney());
             costMoney=costMoney.add(orderGood.getCost()==null?new BigDecimal("0"):orderGood.getCost());
@@ -92,28 +117,41 @@
         res.setOrderMoney(goodsMoney);
         res.setCouponMoney(byId.getCouponMoney());
         res.setPayMoney(byId.getPayMoney());
-        res.setPayType(byId.getPayTypeName());
         res.setRealPayMoney(byId.getPayMoney());
-        SecFeeItems one1 = feeItemsService.lambdaQuery().eq(SecFeeItems::getName, byId.getPayTypeName())
+        SecFeeItems one1 = feeItemsService.lambdaQuery().eq(SecFeeItems::getId, byId.getItemsId())
                 .one();
-        BigDecimal percent = one1.getPercent();
-        BigDecimal bigDecimal1 = byId.getPayMoney().multiply(percent).setScale(2, BigDecimal.ROUND_DOWN);
-        res.setCommission(bigDecimal1);
-        if (byId.getIsAccounting()==1){
-            res.setProfitMoney(byId.getPayMoney().subtract(bigDecimal1).subtract(constConfirm));
-            res.setProfitRating(res.getProfitMoney().divide(byId.getPayMoney(),2, BigDecimal.ROUND_DOWN));
-        }
+        res.setPayType(one1.getName());
+        res.setProfitMoney(byId.getProfitMoney());
+        res.setProfitRating(byId.getProfitRating());
+        List<TOrderItems> orderItems = orderItemsService.list(Wrappers.lambdaQuery(TOrderItems.class)
+                .eq(TOrderItems::getOrderId, id));
+        res.setOrderItems(orderItems);
         return ApiResult.success(res);
     }
+    @Autowired
+    private TOrderItemsService orderItemsService;
     @ApiOperation(value = "确认核算操作")
     @PostMapping(value = "/confirm")
-    public ApiResult confirm(@RequestBody TOrderAccountingQuery query) {
-        if (StringUtils.hasLength(query.getStartTime())){
-            query.setStartTime(query.getStartTime()+" 00:00:00");
-            query.setEndTime(query.getEndTime()+" 23:59:59");
-        }
-        PageInfo<TOrderVO> res = orderAccountingService.pageList(query);
-        return ApiResult.success(res);
+    public ApiResult confirm(@RequestBody AccountDetailDTO dto) {
+        List<TOrderGoods> list = dto.getList();
+        orderGoodsService.updateBatchById(list);
+        TOrder byId = orderService.getById(dto.getId());
+        byId.setPayTypeName(dto.getPayTypeName());
+        byId.setPayMoney(dto.getPayMoney());
+        byId.setCommissionMoney(dto.getCommission());
+        byId.setIsAccounting(1);
+        Long userId = loginInfoUtil.getUserId();
+        SecUser byId1 = secUserService.getById(userId);
+        byId.setAccountingName(byId1.getNickName());
+        byId.setAccountingTime(LocalDateTime.now());
+        byId.setProfitRating(dto.getProfitRating());
+        byId.setProfitMoney(dto.getProfitMoney());
+        orderService.updateById(byId);
+        boolean remove = orderItemsService
+                .remove(new LambdaQueryWrapper<TOrderItems>()
+                        .eq(TOrderItems::getOrderId, dto.getId()));
+        orderItemsService.saveBatch(dto.getListItems());
+        return ApiResult.success();
     }
 }
 

--
Gitblit v1.7.1