From 68b9175323a2f9b40ffcc48bb01af1d8279e5d01 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 22 Aug 2025 10:21:51 +0800
Subject: [PATCH] 平仓返回保证金修改

---
 src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java |   53 +++++++++++++++++++++++++++++++++++------------------
 1 files changed, 35 insertions(+), 18 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java b/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
index 1cb8054..027f2a9 100644
--- a/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
@@ -281,10 +281,12 @@
                             return ServerResponse.createByErrorMsg("客户资金账户不存在");
                         }
                         int applyNumber = userStockSubscribe.getApplyNums() - model.getApplyNumber();
+                        BigDecimal refundPrice = BigDecimal.ZERO;
+                        String before = userAssets.getAvailableBalance().toString();
                         if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) <= 0){
                             if(applyNumber > 0){
                                 //需要退回的资金
-                                BigDecimal refundPrice = userStockSubscribe.getBuyPrice().multiply(new BigDecimal(applyNumber));
+                                refundPrice = userStockSubscribe.getBuyPrice().multiply(new BigDecimal(applyNumber));
                                 //如果不是墨西哥币需要转换金额
                                 if (!stockSubscribe.getStockType().equals(EStockType.MX.getCode())) {
                                     refundPrice = iUserAssetsServices.exchangeAmountByRate(stockSubscribe.getStockType(), refundPrice);
@@ -294,7 +296,7 @@
                             }
                         }else{
                             if(applyNumber > 0){
-                                BigDecimal refundPrice = userStockSubscribe.getBuyPrice().multiply(new BigDecimal(applyNumber));
+                                refundPrice = userStockSubscribe.getBuyPrice().multiply(new BigDecimal(applyNumber));
                                 //如果不是墨西哥币需要转换金额
                                 if (!stockSubscribe.getStockType().equals(EStockType.MX.getCode())) {
                                     refundPrice = iUserAssetsServices.exchangeAmountByRate(stockSubscribe.getStockType(), refundPrice);
@@ -308,6 +310,21 @@
                                     userAssets.setAvailableBalance(subtract);
                                 }
                             }
+                        }
+                        //如果退回资金 add交易记录MEX
+                        if (refundPrice.compareTo(BigDecimal.ZERO) > 0) {
+                            MoneyLog moneyLog = new MoneyLog();
+                            EUserAssets eUserAssets = EUserAssets.BUY_RT;
+                            moneyLog.setDescs(eUserAssets.getDesc());
+                            moneyLog.setBeFore(before);
+                            moneyLog.setAfter(userAssets.getAvailableBalance().toString());
+                            moneyLog.setAmount(refundPrice.toString());
+                            moneyLog.setAccectType(EStockType.MX.getCode());
+                            moneyLog.setType(eUserAssets.getCode());
+                            moneyLog.setUserId(userAssets.getUserId()+"");
+                            moneyLog.setSymbol(EStockType.MX.getSymbol());
+                            moneyLog.setCreateTime(new Date());
+                            moneyLogMapper.insert(moneyLog);
                         }
                         ret = userStockSubscribeMapper.update1(model);
                         userAssetsMapper.updateById(userAssets);
@@ -482,26 +499,26 @@
         String header = request.getHeader(property);
         if (header != null) {
              User user = iUserService.getCurrentRefreshUser(request);
-
             List<UserStockSubscribeVo> userStockSubscribe = this.userStockSubscribeMapper.getListByParam(user.getId(), type, status);
-            /*if (type==null||type.equals("")){
-                userStockSubscribe = this.userStockSubscribeMapper.selectList(new QueryWrapper<>(new UserStockSubscribe()).eq("user_id", user.getId()).orderByDesc("add_time"));
-            }else{
-                userStockSubscribe = this.userStockSubscribeMapper.selectList(new QueryWrapper<>(new UserStockSubscribe()).eq("user_id", user.getId()).eq("type", type).orderByDesc("add_time"));
-            }*/
-
-            List<UserStockSubscribeVo> list = new ArrayList<>();
-            for (UserStockSubscribeVo userStockSubscribe1 : userStockSubscribe) {
-                StockSubscribe stockSubscribe = stockSubscribeMapper.selectOne(new QueryWrapper<>(new StockSubscribe())
-                        .eq("newlist_id", userStockSubscribe1.getNewStockId()));
-                if (stockSubscribe != null) {
-                    list.add(userStockSubscribe1);
-                }
-            }
-            return ServerResponse.createBySuccess(list);
+            return ServerResponse.createBySuccess(userStockSubscribe);
         }
         return ServerResponse.createByErrorCodeMsg(ResponseCode.NEED_LOGIN.getCode(),"请先登录");
     }
+
+    @Override
+    public ServerResponse getOneSubscribeByUserIdPage(int pageNum,int pageSize,String type, Integer status, HttpServletRequest request) {
+        String property = PropertiesUtil.getProperty("user.cookie.name");
+        String header = request.getHeader(property);
+        if (header != null) {
+            User user = iUserService.getCurrentRefreshUser(request);
+            PageHelper.startPage(pageNum, pageSize);
+            List<UserStockSubscribeVo> userStockSubscribe = this.userStockSubscribeMapper.getListByParam(user.getId(), type, status);
+            PageInfo<UserStockSubscribeVo>  pageInfo = new PageInfo<>(userStockSubscribe);
+            return ServerResponse.createBySuccess(pageInfo);
+        }
+        return ServerResponse.createByErrorCodeMsg(ResponseCode.NEED_LOGIN.getCode(),"请先登录");
+    }
+
     /**
      * 新股申购-用户提交金额
      */

--
Gitblit v1.9.3