From 8d0c63d2f96cc31dd45581ac21b8c900c200e134 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 27 十二月 2024 16:44:35 +0800
Subject: [PATCH] 验光师

---
 manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java |   57 +++++++++++++++++++++++++++++++++++----------------------
 1 files changed, 35 insertions(+), 22 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 cebff63..07d8138 100644
--- a/manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java
+++ b/manage/src/main/java/com/jilongda/manage/controller/TOrderAccountingController.java
@@ -15,6 +15,7 @@
 import org.springframework.util.StringUtils;
 import org.springframework.web.bind.annotation.*;
 
+import java.math.BigDecimal;
 import java.util.List;
 
 /**
@@ -39,6 +40,10 @@
     private TAppUserService appUserService;
     @Autowired
     private TOptometryDetailService optometryDetailService;
+    @Autowired
+    private TOrderGoodsService orderGoodsService;
+    @Autowired
+    private SecFeeItemsService feeItemsService;
     @ApiOperation(value = "核算订单分页列表")
     @PostMapping(value = "/pageList")
     public ApiResult<PageInfo<TOrderVO>> pageList(@RequestBody TOrderAccountingQuery query) {
@@ -54,7 +59,6 @@
     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){
@@ -68,30 +72,39 @@
         List<TOptometryDetail> list = optometryDetailService.lambdaQuery().eq(TOptometryDetail::getOrderId, id)
                 .eq(TOptometryDetail::getType, 1).list();
         res.setOptometryDetails(list);
-//        res.setOrderGoods();
-//        res.setStoreName();
-//        res.setOrderMoney();
-//        res.setCouponMoney();
-//        res.setPayMoney();
-//        res.setPayType();
-//        res.setRealPayMoney();
-//        res.setCommission();
-//        res.setProfitMoney();
-//        res.setProfitRating();
-
-
-
+        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");
+        for (TOrderGoods orderGood : orderGoods) {
+            goodsMoney =goodsMoney.add(orderGood.getGoodsMoney());
+            costMoney=costMoney.add(orderGood.getCost()==null?new BigDecimal("0"):orderGood.getCost());
+            constConfirm=constConfirm.add(orderGood.getConstConfirm()==null?new BigDecimal("0"):orderGood.getConstConfirm());
+        }
+        res.setOrderGoods(orderGoods);
+        TStore byId1 = storeService.getById(byId.getStoreId());
+        res.setStoreName(byId1.getName());
+        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())
+                .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));
+        }
         return ApiResult.success(res);
     }
     @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);
+    @GetMapping(value = "/confirm")
+    public ApiResult confirm() {
+        return ApiResult.success();
     }
 }
 

--
Gitblit v1.7.1