From b1bc403ef56a871e483e7ad91905e204a04541ec Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 14 Jan 2026 22:04:08 +0800
Subject: [PATCH] 修改申购

---
 src/main/java/com/nq/service/impl/UserAssetsServices.java |   14 ++++++++++++--
 1 files changed, 12 insertions(+), 2 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserAssetsServices.java b/src/main/java/com/nq/service/impl/UserAssetsServices.java
index 85bcaa8..975cc10 100644
--- a/src/main/java/com/nq/service/impl/UserAssetsServices.java
+++ b/src/main/java/com/nq/service/impl/UserAssetsServices.java
@@ -320,6 +320,16 @@
                userAssets.setCumulativeProfitAndLoss(userAssets.getCumulativeProfitAndLoss().add(amount));
            }
            extracted(userAssets);
+        }else if(Objects.equals(eUserAssets.getCode(), EUserAssets.PENDING_ORDER_FREEZE.getCode())){
+            // 挂单冻结资金:从可用余额转到冻结金额
+            // amount 是负数,表示扣除
+            userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(amount));
+            userAssets.setFreezeMoney(userAssets.getFreezeMoney().add(amount.negate()));
+        }else if(Objects.equals(eUserAssets.getCode(), EUserAssets.PENDING_ORDER_UNFREEZE.getCode())){
+            // 取消挂单解冻资金:从冻结金额转回可用余额
+            // amount 是正数,表示增加
+            userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(amount));
+            userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(amount));
         }
 
         /*if(null != userPosition){
@@ -431,8 +441,8 @@
 
     @Override
     public BigDecimal exchangeAmountByRate(String fromType, String toType, BigDecimal amount) throws Exception {
-        EStockType stockType = EStockType.getEStockTypeByCode(fromType);
-        EStockType toStockType = EStockType.getEStockTypeByCode(toType);
+        EStockType stockType = EStockType.getEStockTypeBySymbol(fromType);
+        EStockType toStockType = EStockType.getEStockTypeBySymbol(toType);
         ExchangeRate exchangeRate = exchangeRateRepository.findExchangeRateByCurrencyAndConversionCurrency(
                 stockType.getSymbol(), toStockType.getSymbol()).orElse(null);
         if (exchangeRate != null) {

--
Gitblit v1.9.3