From 9dc40f3aa7df3bdd489bd750d59fec8bac741a23 Mon Sep 17 00:00:00 2001
From: peter <14100000001@qq.com>
Date: Thu, 08 Jan 2026 17:48:09 +0800
Subject: [PATCH] 修改

---
 src/main/java/com/nq/service/impl/UserPositionServiceImpl.java |   57 ++++++++++++++++++++++++++++++++-------------------------
 1 files changed, 32 insertions(+), 25 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
index 9fdfc76..d05dfe4 100644
--- a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
@@ -514,6 +514,12 @@
     }
 
 
+    public ServerResponse fee(Integer buyNum,BigDecimal nowPrice){
+        BigDecimal buy_amt = nowPrice.multiply(new BigDecimal(buyNum.intValue()));
+        SiteSetting siteSetting = this.iSiteSettingService.getSiteSetting();
+        BigDecimal buy_fee_amt = buy_amt.multiply(siteSetting.getBuyFee()).setScale(2, 4);
+        return ServerResponse.createBySuccess(buy_fee_amt);
+    }
     @Transactional
     public ServerResponse pending(Integer stockId, Integer buyNum, Integer buyType, Integer lever, BigDecimal profitTarget, BigDecimal stopTarget, HttpServletRequest request) throws Exception {
 
@@ -524,9 +530,7 @@
         /*实名认证开关开启*/
         SiteProduct siteProduct = iSiteProductService.getProductSetting();
         User user = this.iUserService.getCurrentRefreshUser(request);
-        if (!siteProduct.getTranWithdrawDisplay()) {
-            return ServerResponse.createByErrorMsg("当前交易关闭");
-        }
+
         if (siteProduct.getRealNameDisplay() && (StringUtils.isBlank(user.getRealName()) || StringUtils.isBlank(user.getIdCard()))) {
             return ServerResponse.createByErrorMsg("挂单失败,请先实名认证");
         }
@@ -559,9 +563,12 @@
         boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
         log.info("是否在上午交易时间 = {} 是否在下午交易时间 = {}", Boolean.valueOf(am_flag), Boolean.valueOf(pm_flag));
         //TODO
-//        if (!am_flag && !pm_flag) {
-//            return ServerResponse.createByErrorMsg("挂单失败,不在交易时段内");
+//        if (!siteProduct.getTranWithdrawDisplay()) {
+//            return ServerResponse.createByErrorMsg("当前交易关闭");
 //        }
+        if (!am_flag && !pm_flag && siteProduct.getTranWithdrawDisplay()) {
+            return ServerResponse.createByErrorMsg("挂单失败,不在交易时段内");
+        }
         if (siteProduct.getHolidayDisplay()) {
             return ServerResponse.createByErrorMsg("周末或节假日不能交易!");
         }
@@ -573,13 +580,13 @@
 
         List dbPosition = findPositionByStockCodeAndTimes(siteSetting.getBuySameTimes().intValue(), stock
                 .getStockCode(), user.getId());
-        if (dbPosition.size() >= siteSetting.getBuySameNums().intValue()) {
+        if (dbPosition.size() >= siteSetting.getBuySameNums().intValue() && siteProduct.getTranWithdrawDisplay()) {
             return ServerResponse.createByErrorMsg("频繁交易," + siteSetting.getBuySameTimes() + "分钟内同一股票持仓不得超过" + siteSetting
                     .getBuySameNums() + "条");
         }
 
         Integer transNum = findPositionNumByTimes(siteSetting.getBuyNumTimes().intValue(), user.getId());
-        if (transNum.intValue() / 100 >= siteSetting.getBuyNumLots().intValue()) {
+        if (transNum.intValue() / 100 >= siteSetting.getBuyNumLots().intValue() && siteProduct.getTranWithdrawDisplay()) {
             return ServerResponse.createByErrorMsg("频繁交易," + siteSetting
                     .getBuyNumTimes() + "分钟内不能超过" + siteSetting.getBuyNumLots() + "手");
         }
@@ -628,20 +635,20 @@
 
         log.info("当前涨跌幅 = {} % , 涨停幅度 = {} %", Double.valueOf(stock_crease), ztRate);
         if ((new BigDecimal(String.valueOf(stock_crease))).compareTo(ztRate) == 0 && buyType
-                .intValue() == 0) {
+                .intValue() == 0 && siteProduct.getTranWithdrawDisplay()) {
             return ServerResponse.createByErrorMsg("当前股票已涨停不能买涨");
         }
         if (stock.getStockPlate() == null || StringUtils.isEmpty(stock.getStockPlate())) {
 
             int maxcrease = siteSetting.getCreaseMaxPercent().intValue();
             if (stock_crease > 0.0D &&
-                    stock_crease >= maxcrease) {
+                    stock_crease >= maxcrease && siteProduct.getTranWithdrawDisplay()) {
                 return ServerResponse.createByErrorMsg("挂单失败,股票当前涨幅:" + stock_crease + ",大于最大涨幅:" + maxcrease);
             }
 
 
             if (stock_crease < 0.0D &&
-                    -stock_crease > maxcrease) {
+                    -stock_crease > maxcrease && siteProduct.getTranWithdrawDisplay()) {
                 return ServerResponse.createByErrorMsg("挂单失败,股票当前跌幅:" + stock_crease + ",大于最大跌幅:" + maxcrease);
 
             }
@@ -650,26 +657,26 @@
 
             int maxcrease = siteSetting.getCyCreaseMaxPercent().intValue();
             if (stock_crease > 0.0D &&
-                    stock_crease >= maxcrease) {
+                    stock_crease >= maxcrease && siteProduct.getTranWithdrawDisplay()) {
                 return ServerResponse.createByErrorMsg("挂单失败,创业股当前涨幅:" + stock_crease + ",大于最大涨幅:" + maxcrease);
             }
 
 
             if (stock_crease < 0.0D &&
-                    -stock_crease > maxcrease) {
+                    -stock_crease > maxcrease && siteProduct.getTranWithdrawDisplay()) {
                 return ServerResponse.createByErrorMsg("挂单失败,创业股当前跌幅:" + stock_crease + ",大于最大跌幅:" + maxcrease);
             }
         } else {
 
             int maxcrease = siteSetting.getKcCreaseMaxPercent().intValue();
             if (stock_crease > 0.0D &&
-                    stock_crease >= maxcrease) {
+                    stock_crease >= maxcrease && siteProduct.getTranWithdrawDisplay()) {
                 return ServerResponse.createByErrorMsg("挂单失败,科创股当前涨幅:" + stock_crease + ",大于最大涨幅:" + maxcrease);
             }
 
 
             if (stock_crease < 0.0D &&
-                    -stock_crease > maxcrease) {
+                    -stock_crease > maxcrease && siteProduct.getTranWithdrawDisplay()) {
                 return ServerResponse.createByErrorMsg("挂单失败,科创股当前跌幅:" + stock_crease + ",大于最大跌幅:" + maxcrease);
             }
         }
@@ -683,7 +690,7 @@
                 .getStockDays(), daysRate, siteSetting.getStockRate()});
 
         if (daysRate != null &&
-                siteSetting.getStockRate().compareTo(daysRate) == -1) {
+                siteSetting.getStockRate().compareTo(daysRate) == -1 && siteProduct.getTranWithdrawDisplay()) {
             return serverResponse.createByErrorMsg(siteSetting.getStockDays() + "天内涨幅超过 " + siteSetting
                     .getStockRate() + "不能交易");
         }
@@ -860,9 +867,7 @@
         }
 
         SiteProduct siteProduct = iSiteProductService.getProductSetting();
-        if (!siteProduct.getTranWithdrawDisplay()) {
-            return ServerResponse.createByErrorMsg("当前交易关闭");
-        }
+
         UserPosition userPosition = this.userPositionMapper.findPositionBySn(positionSn);
         if (doType != 0) {
             if (userPosition.getStockGid().contains("us")) {
@@ -897,7 +902,8 @@
                 boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
                 boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
                 log.info("是否在上午交易時間 = {} 是否在下午交易時間 = {}", Boolean.valueOf(am_flag), Boolean.valueOf(pm_flag));
-                if (!am_flag && !pm_flag) {
+
+                if (!am_flag && !pm_flag && siteProduct.getTranWithdrawDisplay()) {
                     return ServerResponse.createByErrorMsg("平仓失败,不在交易时段内");
                 }
             }
@@ -929,7 +935,7 @@
             return ServerResponse.createByErrorMsg("平仓失败,此订单已平仓");
         }
 
-        if (DateTimeUtil.isCanSellOneday(userPosition.getBuyOrderTime(), siteSetting.getCantSellTimes().intValue())) {
+        if (DateTimeUtil.isCanSellOneday(userPosition.getBuyOrderTime(), siteSetting.getCantSellTimes().intValue()) && siteProduct.getTranWithdrawDisplay()) {
             // return ServerResponse.createByErrorMsg(siteSetting.getCantSellTimes() + "分鐘內不能平倉");
 
             return ServerResponse.createByErrorMsg("当日成交不可平仓");
@@ -2492,9 +2498,9 @@
         if (siteProduct.getHolidayDisplay()) {
             return ServerResponse.createByErrorMsg("周末或节假日不能交易!");
         }
-        if (!Objects.equals(stockDz.getPassword(), password)) {
-            return ServerResponse.createByErrorMsg("下单失败,密钥错误");
-        }
+//        if (!Objects.equals(stockDz.getPassword(), password)) {
+//            return ServerResponse.createByErrorMsg("下单失败,密钥错误");
+//        }
 
         if (stockDz.getIsLock().intValue() != 0) {
             return ServerResponse.createByErrorMsg("下单失败,当前股票不能交易");
@@ -2515,7 +2521,7 @@
         if (num < stockDz.getStockNum().intValue()) {
             return ServerResponse.createByErrorMsg("下单失败,购买数量最小为" + stockDz.getStockNum() + "股");
         }
-        if (num > stockDz.getStockSurplus().intValue()) {
+        if (num > stockDz.getStockShare().intValue()) {
             return ServerResponse.createByErrorMsg("下单失败,购买数量大于" + stockDz.getStockNum() + "股");
         }
         if (num > siteSetting.getBuyMaxNum()) {
@@ -2720,7 +2726,8 @@
         insertPositionCount = userPosition.getId();
         if (insertPositionCount > 0) {
             //修改大宗剩余
-            stockDz.setStockSurplus(stockDz.getStockSurplus() - num);
+            stockDz.setStockShare(stockDz.getStockShare() - num);
+            stockDz.setStockSurplus(stockDz.getStockSurplus() + num);
             stockDzMapper.updateById(stockDz);
             //修改用戶可用余額= 當前余額-下單金額-買入手續費-印花稅-點差費
             //BigDecimal reckon_enable = user_enable_amt.subtract(buy_amt_autual).subtract(buy_fee_amt).subtract(buy_yhs_amt).subtract(spread_rate_amt);

--
Gitblit v1.9.3