From 1498b23be871aec99314da998569a94c9ab53607 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Thu, 29 Oct 2020 17:56:37 +0800
Subject: [PATCH] modify

---
 src/main/java/com/xcong/excoin/utils/CalculateUtil.java |   21 ++++++++-------------
 1 files changed, 8 insertions(+), 13 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
index 4e3c023..d4e47b5 100644
--- a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
+++ b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
@@ -46,21 +46,15 @@
         MemberSettingDao memberSettingDao = SpringContextHolder.getBean(MemberSettingDao.class);
         BigDecimal forcePrice = BigDecimal.ZERO;
         BigDecimal money = bondAmount.divide(new BigDecimal(symbolSkuNumber).multiply(lotNumber), 8, BigDecimal.ROUND_DOWN);
+        if (member.getIsForce() == 1) {
+            MemberSettingEntity memberSetting = memberSettingDao.selectMemberSettingByMemberId(member.getId());
+            money = money.multiply(memberSetting.getForceParam().multiply(BigDecimal.valueOf(100)));
+        }
         //卖空
         if (type == 2) {
             forcePrice = money.add(openPrice);
-            if (member.getIsForce() == 1) {
-                MemberSettingEntity memberSetting = memberSettingDao.selectMemberSettingByMemberId(member.getId());
-                //预估强平价 = 预估强平价-预估强平价*系数
-                forcePrice = forcePrice.subtract(forcePrice.multiply(memberSetting.getForceParam() == null ? BigDecimal.ZERO : memberSetting.getForceParam()));
-            }
         } else {//开多
             forcePrice = openPrice.subtract(money);
-            if (member.getIsForce() == 1) {
-                MemberSettingEntity memberSetting = memberSettingDao.selectMemberSettingByMemberId(member.getId());
-                //预估强平价 = 预估强平价-预估强平价*系数
-                forcePrice = forcePrice.add(forcePrice.multiply(memberSetting.getForceParam() == null ? BigDecimal.ZERO : memberSetting.getForceParam()));
-            }
         }
         if (forcePrice.compareTo(BigDecimal.ZERO) < 0) {
             forcePrice = BigDecimal.ZERO;
@@ -99,7 +93,7 @@
             int subCnt = 0;
             BigDecimal openPrice = BigDecimal.ZERO;
             int type = 1;
-            BigDecimal feeAmount = BigDecimal.ZERO;
+            BigDecimal bondAmount = BigDecimal.ZERO;
             BigDecimal sku = BigDecimal.ZERO;
 
             Long id = 0L;
@@ -118,12 +112,13 @@
                     subCnt = maxCnt - holdOrderEntity.getSymbolCntSale();
                 }
 
-                feeAmount = feeAmount.add(holdOrderEntity.getOpeningFeeAmount());
+                bondAmount = bondAmount.add(holdOrderEntity.getBondAmount().subtract(holdOrderEntity.getOpeningFeeAmount()));
                 sku = holdOrderEntity.getSymbolSku();
             }
             BigDecimal forceSetPrice = BigDecimal.ZERO;
             if (subCnt != 0) {
-                forceSetPrice = getForceSetPrice(walletContract.getTotalBalance().subtract(feeAmount), openPrice, subCnt, sku, type, memberEntity);
+                log.info("---->{}, {}", walletContract.getAvailableBalance(), bondAmount);
+                forceSetPrice = getForceSetPrice(walletContract.getAvailableBalance().add(bondAmount), openPrice, subCnt, sku, type, memberEntity);
             }
 
             log.info("强平价:{}", forceSetPrice);

--
Gitblit v1.9.1