From 68000e03cee9417da3611a8f6cb62a67420b560d Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 13 Aug 2025 18:20:41 +0800
Subject: [PATCH] 1

---
 src/main/java/com/nq/controller/backend/SmartIntradayController.java |   57 +++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 41 insertions(+), 16 deletions(-)

diff --git a/src/main/java/com/nq/controller/backend/SmartIntradayController.java b/src/main/java/com/nq/controller/backend/SmartIntradayController.java
index d274597..4d505c1 100644
--- a/src/main/java/com/nq/controller/backend/SmartIntradayController.java
+++ b/src/main/java/com/nq/controller/backend/SmartIntradayController.java
@@ -11,6 +11,7 @@
 import com.nq.dao.*;
 import com.nq.enums.EConfigKey;
 import com.nq.enums.EStockType;
+import com.nq.enums.EUserAssets;
 import com.nq.pojo.*;
 import com.nq.service.*;
 import com.nq.service.impl.IntradayOrderSerivceImpl;
@@ -72,7 +73,8 @@
 
     @Autowired
     private UserPositionMapper userPositionMapper;
-
+    @Autowired
+    IStockConfigServices iStockConfigServices;
 
     /**
      * 添加智能日内
@@ -183,27 +185,26 @@
         intradayOrder.setStockQuantity(vo.getStockQuantity());
         intradayOrder.setPriceType(vo.getPriceType());
         intradayOrder.setStockPrice(new BigDecimal(vo.getStockPrice()));
-        intradayOrder.setAuditStatus(vo.getAuditStatus());
+        intradayOrder.setAuditStatus(1);
         intradayOrder.setOrderTime(DateUtil.parse(vo.getOrderTime(),"yyyy-MM-dd HH:mm:ss"));
         intradayOrder.setIsLocked(vo.getIsLocked());
         intradayOrder.setStockId(stock.getId());
 
-        if(vo.getAuditStatus() == 2){
-            UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId(EStockType.JP.getCode(), intradayOrder.getUserId());
-            BigDecimal orderAmount = vo.getOrderAmount();
-            userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(orderAmount));
-            userAssetsMapper.updateById(userAssets);
-            return ServerResponse.createBySuccessMsg("操作成功");
-        }
+        // 手续费率
+        BigDecimal siteSettingBuyFee = new BigDecimal(iStockConfigServices.queryByKey(EConfigKey.BUY_HANDLING_CHARGE.getCode()).getCValue()) ;
+
         BigDecimal stockQuantity = new BigDecimal(intradayOrder.getStockQuantity());//股票数量
-        BigDecimal totalPrice = intradayOrder.getStockPrice().multiply(stockQuantity);//订单总价
+        BigDecimal orderTotalPrice = intradayOrder.getStockPrice().multiply(stockQuantity);//订单总价
+
+        //手续费
+        BigDecimal orderFree = siteSettingBuyFee.multiply(orderTotalPrice);
+        BigDecimal totalPrice = orderFree.add(orderTotalPrice);
+
         if(intradayOrder.getOrderAmount().compareTo(totalPrice) < 0){
             return ServerResponse.createByErrorMsg("股票总价超过订单金额!");
         }
 
-
         User user = userMapper.selectById(intradayOrder.getUserId());
-
 
         //结余资金返还账户
         BigDecimal surplusAmount = intradayOrder.getOrderAmount().subtract(totalPrice);//结余
@@ -222,16 +223,16 @@
         userPosition.setBuyOrderId(GeneratePosition.getPositionId());
         userPosition.setBuyOrderTime(new Date());
         userPosition.setBuyOrderPrice(intradayOrder.getStockPrice());
-        userPosition.setOrderDirection((intradayOrder.getPriceType() == 0) ? "买涨" : "买跌");
+        userPosition.setOrderDirection((intradayOrder.getPriceType() == 1) ? "买涨" : "买跌");
         userPosition.setOrderNum(intradayOrder.getStockQuantity());
         if (stock.getStockPlate() != null) {
             userPosition.setStockPlate(stock.getStockPlate());
         }
         userPosition.setIsLock(intradayOrder.getIsLocked());
         userPosition.setOrderLever(1);
-        userPosition.setOrderTotalPrice(totalPrice);
+        userPosition.setOrderTotalPrice(orderTotalPrice);
         // 手续费
-        userPosition.setOrderFee(BigDecimal.ZERO);
+        userPosition.setOrderFee(orderFree);
         userPosition.setOrderSpread(BigDecimal.ZERO);
         userPosition.setSpreadRatePrice(BigDecimal.ZERO);
         BigDecimal profit_and_lose = new BigDecimal("0");
@@ -241,12 +242,32 @@
         userPosition.setOrderStayFee(BigDecimal.ZERO);
         userPositionMapper.insert(userPosition);
 
-        //结余资金返还账户
         UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId(EStockType.JP.getCode(), intradayOrder.getUserId());
         userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(surplusAmount));
+        userAssets.setFreezeMoney(userAssets.getFreezeMoney().add(userPosition.getOrderTotalPrice()));
         userAssetsMapper.updateById(userAssets);
         intradayOrder.setPositionOrder(userPosition.getId());
         intradayOrder.setPurchaseAmount(totalPrice);
+        intradayOrderMapper.updateById(intradayOrder);
+        return ServerResponse.createBySuccessMsg("操作成功");
+    }
+
+    /**
+     * 驳回订单
+     * @return
+     */
+    @RequestMapping(value = {"rejectIntraday.do"}, method = {RequestMethod.POST})
+    @ResponseBody
+    @Transactional(rollbackFor = Exception.class) // 异常时回滚
+    public ServerResponse rejectIntraday(@RequestParam("id") Integer id) {
+        IntradayOrder intradayOrder = intradayOrderSerivce.getById(id);
+        if(intradayOrder.getAuditStatus() != 0){
+            return ServerResponse.createByErrorMsg("订单已操作");
+        }
+        UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId(EStockType.JP.getCode(), intradayOrder.getUserId());
+        userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(intradayOrder.getOrderAmount()));
+        userAssetsMapper.updateById(userAssets);
+        intradayOrder.setAuditStatus(2);
         intradayOrderMapper.updateById(intradayOrder);
         return ServerResponse.createBySuccessMsg("操作成功");
     }
@@ -279,6 +300,10 @@
     @RequestMapping(value = {"deleteIntraday.do"}, method = {RequestMethod.POST})
     @ResponseBody
     public ServerResponse deleteIntraday( @RequestParam("id") Integer id) {
+        IntradayOrder orderSerivceById = intradayOrderSerivce.getById(id);
+        if(orderSerivceById.getAuditStatus() == 0){
+            return ServerResponse.createByErrorMsg("订单状态未审核,不允许删除");
+        }
         intradayOrderSerivce.removeById(id);
         return ServerResponse.createBySuccessMsg("删除成功");
     }

--
Gitblit v1.9.3