@defisaver/positions-sdk 2.1.23 → 2.1.24-dev-savings-2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (159) hide show
  1. package/.mocharc.json +4 -4
  2. package/.nvmrc +1 -1
  3. package/README.md +64 -64
  4. package/cjs/config/contracts.d.ts +173 -0
  5. package/cjs/config/contracts.js +23 -1
  6. package/cjs/contracts.d.ts +1650 -0
  7. package/cjs/contracts.js +22 -1
  8. package/cjs/helpers/morphoBlueHelpers/index.js +66 -66
  9. package/cjs/index.d.ts +2 -1
  10. package/cjs/index.js +3 -1
  11. package/cjs/markets/aave/marketAssets.js +1 -1
  12. package/cjs/savings/index.d.ts +7 -0
  13. package/cjs/savings/index.js +75 -0
  14. package/cjs/savings/makerDSR/index.d.ts +7 -0
  15. package/cjs/savings/makerDSR/index.js +94 -0
  16. package/cjs/savings/makerDSR/options.d.ts +2 -0
  17. package/cjs/savings/makerDSR/options.js +11 -0
  18. package/cjs/savings/morphoVaults/index.d.ts +7 -0
  19. package/cjs/savings/morphoVaults/index.js +118 -0
  20. package/cjs/savings/morphoVaults/options.d.ts +16 -0
  21. package/cjs/savings/morphoVaults/options.js +112 -0
  22. package/cjs/savings/yearnVaults/index.d.ts +9 -0
  23. package/cjs/savings/yearnVaults/index.js +113 -0
  24. package/cjs/savings/yearnVaults/options.d.ts +6 -0
  25. package/cjs/savings/yearnVaults/options.js +29 -0
  26. package/cjs/types/index.d.ts +1 -0
  27. package/cjs/types/index.js +1 -0
  28. package/cjs/types/savings/index.d.ts +15 -0
  29. package/cjs/types/savings/index.js +19 -0
  30. package/cjs/types/savings/makerDsr.d.ts +11 -0
  31. package/cjs/types/savings/makerDsr.js +7 -0
  32. package/cjs/types/savings/morphoVaults.d.ts +23 -0
  33. package/cjs/types/savings/morphoVaults.js +19 -0
  34. package/cjs/types/savings/yearnVaults.d.ts +12 -0
  35. package/cjs/types/savings/yearnVaults.js +9 -0
  36. package/esm/config/contracts.d.ts +173 -0
  37. package/esm/config/contracts.js +22 -0
  38. package/esm/contracts.d.ts +1650 -0
  39. package/esm/contracts.js +18 -0
  40. package/esm/helpers/morphoBlueHelpers/index.js +66 -66
  41. package/esm/index.d.ts +2 -1
  42. package/esm/index.js +2 -1
  43. package/esm/markets/aave/marketAssets.js +1 -1
  44. package/esm/savings/index.d.ts +7 -0
  45. package/esm/savings/index.js +36 -0
  46. package/esm/savings/makerDSR/index.d.ts +7 -0
  47. package/esm/savings/makerDSR/index.js +53 -0
  48. package/esm/savings/makerDSR/options.d.ts +2 -0
  49. package/esm/savings/makerDSR/options.js +8 -0
  50. package/esm/savings/morphoVaults/index.d.ts +7 -0
  51. package/esm/savings/morphoVaults/index.js +77 -0
  52. package/esm/savings/morphoVaults/options.d.ts +16 -0
  53. package/esm/savings/morphoVaults/options.js +108 -0
  54. package/esm/savings/yearnVaults/index.d.ts +9 -0
  55. package/esm/savings/yearnVaults/index.js +70 -0
  56. package/esm/savings/yearnVaults/options.d.ts +6 -0
  57. package/esm/savings/yearnVaults/options.js +25 -0
  58. package/esm/types/index.d.ts +1 -0
  59. package/esm/types/index.js +1 -0
  60. package/esm/types/savings/index.d.ts +15 -0
  61. package/esm/types/savings/index.js +3 -0
  62. package/esm/types/savings/makerDsr.d.ts +11 -0
  63. package/esm/types/savings/makerDsr.js +4 -0
  64. package/esm/types/savings/morphoVaults.d.ts +23 -0
  65. package/esm/types/savings/morphoVaults.js +16 -0
  66. package/esm/types/savings/yearnVaults.d.ts +12 -0
  67. package/esm/types/savings/yearnVaults.js +6 -0
  68. package/package.json +48 -47
  69. package/src/aaveV2/index.ts +240 -240
  70. package/src/aaveV3/index.ts +614 -614
  71. package/src/aaveV3/merit.ts +97 -97
  72. package/src/aaveV3/merkl.ts +74 -74
  73. package/src/claiming/aaveV3.ts +154 -154
  74. package/src/claiming/compV3.ts +22 -22
  75. package/src/claiming/ethena.ts +61 -61
  76. package/src/claiming/index.ts +12 -12
  77. package/src/claiming/king.ts +66 -66
  78. package/src/claiming/morphoBlue.ts +118 -118
  79. package/src/claiming/spark.ts +225 -225
  80. package/src/compoundV2/index.ts +244 -244
  81. package/src/compoundV3/index.ts +274 -274
  82. package/src/config/contracts.ts +1282 -1260
  83. package/src/constants/index.ts +10 -10
  84. package/src/contracts.ts +143 -121
  85. package/src/curveUsd/index.ts +254 -254
  86. package/src/eulerV2/index.ts +324 -324
  87. package/src/exchange/index.ts +25 -25
  88. package/src/fluid/index.ts +1774 -1774
  89. package/src/helpers/aaveHelpers/index.ts +187 -187
  90. package/src/helpers/compoundHelpers/index.ts +283 -283
  91. package/src/helpers/curveUsdHelpers/index.ts +40 -40
  92. package/src/helpers/eulerHelpers/index.ts +222 -222
  93. package/src/helpers/fluidHelpers/index.ts +326 -326
  94. package/src/helpers/index.ts +10 -10
  95. package/src/helpers/liquityV2Helpers/index.ts +82 -82
  96. package/src/helpers/llamaLendHelpers/index.ts +53 -53
  97. package/src/helpers/makerHelpers/index.ts +52 -52
  98. package/src/helpers/morphoBlueHelpers/index.ts +396 -396
  99. package/src/helpers/sparkHelpers/index.ts +158 -158
  100. package/src/index.ts +49 -47
  101. package/src/liquity/index.ts +159 -159
  102. package/src/liquityV2/index.ts +703 -703
  103. package/src/llamaLend/index.ts +305 -305
  104. package/src/maker/index.ts +223 -223
  105. package/src/markets/aave/index.ts +116 -116
  106. package/src/markets/aave/marketAssets.ts +54 -54
  107. package/src/markets/compound/index.ts +238 -238
  108. package/src/markets/compound/marketsAssets.ts +97 -97
  109. package/src/markets/curveUsd/index.ts +69 -69
  110. package/src/markets/euler/index.ts +26 -26
  111. package/src/markets/fluid/index.ts +2900 -2900
  112. package/src/markets/index.ts +25 -25
  113. package/src/markets/liquityV2/index.ts +102 -102
  114. package/src/markets/llamaLend/contractAddresses.ts +141 -141
  115. package/src/markets/llamaLend/index.ts +235 -235
  116. package/src/markets/morphoBlue/index.ts +971 -971
  117. package/src/markets/spark/index.ts +29 -29
  118. package/src/markets/spark/marketAssets.ts +12 -12
  119. package/src/moneymarket/moneymarketCommonService.ts +84 -84
  120. package/src/morphoBlue/index.ts +274 -274
  121. package/src/portfolio/index.ts +598 -598
  122. package/src/savings/index.ts +43 -0
  123. package/src/savings/makerDsr/index.ts +54 -0
  124. package/src/savings/makerDsr/options.ts +9 -0
  125. package/src/savings/morphoVaults/index.ts +81 -0
  126. package/src/savings/morphoVaults/options.ts +123 -0
  127. package/src/savings/yearnVaults/index.ts +74 -0
  128. package/src/savings/yearnVaults/options.ts +30 -0
  129. package/src/services/priceService.ts +278 -278
  130. package/src/services/utils.ts +115 -115
  131. package/src/services/viem.ts +34 -34
  132. package/src/setup.ts +8 -8
  133. package/src/spark/index.ts +456 -456
  134. package/src/staking/eligibility.ts +53 -53
  135. package/src/staking/index.ts +1 -1
  136. package/src/staking/staking.ts +183 -183
  137. package/src/types/aave.ts +189 -189
  138. package/src/types/claiming.ts +114 -114
  139. package/src/types/common.ts +107 -107
  140. package/src/types/compound.ts +136 -136
  141. package/src/types/curveUsd.ts +123 -123
  142. package/src/types/euler.ts +175 -175
  143. package/src/types/fluid.ts +483 -483
  144. package/src/types/index.ts +15 -14
  145. package/src/types/liquity.ts +30 -30
  146. package/src/types/liquityV2.ts +126 -126
  147. package/src/types/llamaLend.ts +159 -159
  148. package/src/types/maker.ts +63 -63
  149. package/src/types/merit.ts +1 -1
  150. package/src/types/merkl.ts +70 -70
  151. package/src/types/morphoBlue.ts +200 -200
  152. package/src/types/portfolio.ts +60 -60
  153. package/src/types/savings/index.ts +18 -0
  154. package/src/types/savings/makerDsr.ts +13 -0
  155. package/src/types/savings/morphoVaults.ts +25 -0
  156. package/src/types/savings/yearnVaults.ts +14 -0
  157. package/src/types/spark.ts +133 -133
  158. package/src/umbrella/index.ts +69 -69
  159. package/src/umbrella/umbrellaUtils.ts +29 -29
@@ -1,160 +1,160 @@
1
- import Dec from 'decimal.js';
2
- import { assetAmountInEth, getAssetInfo } from '@defisaver/tokens';
3
- import { Client } from 'viem';
4
- import {
5
- Blockish, EthAddress, EthereumProvider, NetworkNumber, PositionBalances,
6
- } from '../types/common';
7
- import {
8
- LiquityActivePoolContractViem,
9
- LiquityCollSurplusPoolContractViem,
10
- LiquityLQTYStakingViem,
11
- LiquityPriceFeedContractViem,
12
- LiquityStabilityPoolViem,
13
- LiquityTroveManagerContractViem,
14
- LiquityViewContractViem,
15
- } from '../contracts';
16
- import { LIQUITY_TROVE_STATUS_ENUM, LiquityTroveInfo } from '../types';
17
- import { ZERO_ADDRESS } from '../constants';
18
- import { getViemProvider, setViemBlockNumber } from '../services/viem';
19
- import { getEthAmountForDecimals } from '../services/utils';
20
-
21
- export const LIQUITY_NORMAL_MODE_RATIO = 110; // MCR
22
- export const LIQUITY_RECOVERY_MODE_RATIO = 150; // CCR
23
-
24
- export const _getLiquityAccountBalances = async (provider: Client, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => {
25
- let balances: PositionBalances = {
26
- collateral: {},
27
- debt: {},
28
- };
29
-
30
- if (!address) {
31
- return balances;
32
- }
33
-
34
- const viewContract = LiquityViewContractViem(provider, network, block);
35
- const troveInfo = await viewContract.read.getTroveInfo([address], setViemBlockNumber(block));
36
-
37
- balances = {
38
- collateral: {
39
- [addressMapping ? getAssetInfo('ETH', network).address.toLowerCase() : 'ETH']: troveInfo[1].toString(),
40
- },
41
- debt: {
42
- [addressMapping ? getAssetInfo('LUSD', network).address.toLowerCase() : 'LUSD']: troveInfo[2].toString(),
43
- },
44
- };
45
-
46
- return balances;
47
- };
48
-
49
- export const getLiquityAccountBalances = async (provider: EthereumProvider, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => _getLiquityAccountBalances(getViemProvider(provider, network), network, block, addressMapping, address);
50
-
51
- const _getDebtInFront = async (viewContract: any, address: EthAddress, accumulatedSum = '0', iterations = 2000): Promise<string> => {
52
- const res = await viewContract.read.getDebtInFront([address, accumulatedSum, iterations]);
53
- const debt = res[1].toString();
54
- const next = res[0];
55
- if (next === ZERO_ADDRESS) return assetAmountInEth(debt, 'LUSD');
56
- return _getDebtInFront(viewContract, next, debt, iterations);
57
- };
58
-
59
- export const getDebtInFront = async (provider: EthereumProvider, address: EthAddress): Promise<string> => {
60
- const client = getViemProvider(provider, NetworkNumber.Eth);
61
- const viewContract = LiquityViewContractViem(client, NetworkNumber.Eth);
62
- return _getDebtInFront(viewContract, address);
63
- };
64
-
65
- export const _getLiquityTroveInfo = async (provider: Client, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => {
66
- const viewContract = LiquityViewContractViem(provider, network);
67
- const collSurplusPoolContract = LiquityCollSurplusPoolContractViem(provider, network);
68
- const troveManagerContract = LiquityTroveManagerContractViem(provider, network);
69
- const priceFeedContract = LiquityPriceFeedContractViem(provider, network);
70
- const activePoolContract = LiquityActivePoolContractViem(provider, network);
71
-
72
- const [
73
- troveInfo,
74
- collSurplusInfo,
75
- borrowingRateWithDecay,
76
- assetPrice,
77
- totalETH,
78
- totalLUSD,
79
- debtInFront,
80
- ] = await Promise.all([
81
- viewContract.read.getTroveInfo([address]),
82
- collSurplusPoolContract.read.getCollateral([address]),
83
- troveManagerContract.read.getBorrowingRateWithDecay(),
84
- priceFeedContract.read.fetchPrice(),
85
- activePoolContract.read.getETH(),
86
- activePoolContract.read.getLUSDDebt(),
87
- _getDebtInFront(viewContract, address),
88
- ]);
89
-
90
- const recoveryMode = troveInfo[6];
91
-
92
- const payload = {
93
- troveStatus: LIQUITY_TROVE_STATUS_ENUM[+(troveInfo[0].toString())],
94
- collateral: assetAmountInEth(troveInfo[1].toString()),
95
- debtInAsset: assetAmountInEth(troveInfo[2].toString()),
96
- TCRatio: assetAmountInEth(troveInfo[4].toString()),
97
- recoveryMode,
98
- claimableCollateral: assetAmountInEth(collSurplusInfo.toString()),
99
- borrowingRateWithDecay: assetAmountInEth(borrowingRateWithDecay.toString()),
100
- assetPrice: assetAmountInEth(assetPrice.toString()),
101
- totalETH: totalETH.toString(),
102
- totalLUSD: totalLUSD.toString(),
103
- debtInFront: debtInFront.toString(),
104
- minCollateralRatio: recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO,
105
- priceForRecovery: new Dec(recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO).mul(totalLUSD).div(totalETH).div(100)
106
- .toString(),
107
- };
108
-
109
- return payload;
110
- };
111
-
112
- export const getLiquityTroveInfo = async (provider: EthereumProvider, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => _getLiquityTroveInfo(getViemProvider(provider, network, { batch: { multicall: true } }), network, address);
113
-
114
- export const getLiquityStakingData = async (provider: Client, network: NetworkNumber, address: EthAddress) => {
115
- const lqtyStakingView = LiquityLQTYStakingViem(provider, network);
116
- const stabilityPoolView = LiquityStabilityPoolViem(provider, network);
117
- const [
118
- stakes,
119
- pendingETHGain,
120
- pendingLUSDGain,
121
- totalLQTYStakes,
122
- stabilityPoolETHGain,
123
- stabilityPoolLQTYGain,
124
- compoundedLUSDDeposit,
125
- totalLUSDDeposits,
126
- ] = await Promise.all([
127
- lqtyStakingView.read.stakes([address]),
128
- lqtyStakingView.read.getPendingETHGain([address]),
129
- lqtyStakingView.read.getPendingLUSDGain([address]),
130
- lqtyStakingView.read.totalLQTYStaked(),
131
- stabilityPoolView.read.getDepositorETHGain([address]),
132
- stabilityPoolView.read.getDepositorLQTYGain([address]),
133
- stabilityPoolView.read.getCompoundedLUSDDeposit([address]),
134
- stabilityPoolView.read.getTotalLUSDDeposits(),
135
- ]);
136
- const totalLUSDDeposited = getEthAmountForDecimals(totalLUSDDeposits as string, 18);
137
- const totalLQTYStaked = getEthAmountForDecimals(totalLQTYStakes as string, 18);
138
- const stakedLQTY = getEthAmountForDecimals(stakes as string, 18);
139
- const stakedLUSDBalance = getEthAmountForDecimals(compoundedLUSDDeposit as string, 18);
140
- const rewardETH = getEthAmountForDecimals(pendingETHGain as string, 18);
141
- const rewardLUSD = getEthAmountForDecimals(pendingLUSDGain as string, 18);
142
- const stabilityRewardETH = getEthAmountForDecimals(stabilityPoolETHGain as string, 18);
143
- const stabilityRewardLQTY = getEthAmountForDecimals(stabilityPoolLQTYGain as string, 18);
144
-
145
- const showStakingBalances = !!(+stakedLQTY || +stakedLUSDBalance
146
- || +rewardETH || +rewardLUSD
147
- || +stabilityRewardETH || +stabilityRewardLQTY);
148
-
149
- return {
150
- totalLUSDDeposited,
151
- totalLQTYStaked,
152
- stakedLQTY,
153
- stakedLUSDBalance,
154
- rewardETH,
155
- rewardLUSD,
156
- stabilityRewardETH,
157
- stabilityRewardLQTY,
158
- showStakingBalances,
159
- };
1
+ import Dec from 'decimal.js';
2
+ import { assetAmountInEth, getAssetInfo } from '@defisaver/tokens';
3
+ import { Client } from 'viem';
4
+ import {
5
+ Blockish, EthAddress, EthereumProvider, NetworkNumber, PositionBalances,
6
+ } from '../types/common';
7
+ import {
8
+ LiquityActivePoolContractViem,
9
+ LiquityCollSurplusPoolContractViem,
10
+ LiquityLQTYStakingViem,
11
+ LiquityPriceFeedContractViem,
12
+ LiquityStabilityPoolViem,
13
+ LiquityTroveManagerContractViem,
14
+ LiquityViewContractViem,
15
+ } from '../contracts';
16
+ import { LIQUITY_TROVE_STATUS_ENUM, LiquityTroveInfo } from '../types';
17
+ import { ZERO_ADDRESS } from '../constants';
18
+ import { getViemProvider, setViemBlockNumber } from '../services/viem';
19
+ import { getEthAmountForDecimals } from '../services/utils';
20
+
21
+ export const LIQUITY_NORMAL_MODE_RATIO = 110; // MCR
22
+ export const LIQUITY_RECOVERY_MODE_RATIO = 150; // CCR
23
+
24
+ export const _getLiquityAccountBalances = async (provider: Client, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => {
25
+ let balances: PositionBalances = {
26
+ collateral: {},
27
+ debt: {},
28
+ };
29
+
30
+ if (!address) {
31
+ return balances;
32
+ }
33
+
34
+ const viewContract = LiquityViewContractViem(provider, network, block);
35
+ const troveInfo = await viewContract.read.getTroveInfo([address], setViemBlockNumber(block));
36
+
37
+ balances = {
38
+ collateral: {
39
+ [addressMapping ? getAssetInfo('ETH', network).address.toLowerCase() : 'ETH']: troveInfo[1].toString(),
40
+ },
41
+ debt: {
42
+ [addressMapping ? getAssetInfo('LUSD', network).address.toLowerCase() : 'LUSD']: troveInfo[2].toString(),
43
+ },
44
+ };
45
+
46
+ return balances;
47
+ };
48
+
49
+ export const getLiquityAccountBalances = async (provider: EthereumProvider, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress): Promise<PositionBalances> => _getLiquityAccountBalances(getViemProvider(provider, network), network, block, addressMapping, address);
50
+
51
+ const _getDebtInFront = async (viewContract: any, address: EthAddress, accumulatedSum = '0', iterations = 2000): Promise<string> => {
52
+ const res = await viewContract.read.getDebtInFront([address, accumulatedSum, iterations]);
53
+ const debt = res[1].toString();
54
+ const next = res[0];
55
+ if (next === ZERO_ADDRESS) return assetAmountInEth(debt, 'LUSD');
56
+ return _getDebtInFront(viewContract, next, debt, iterations);
57
+ };
58
+
59
+ export const getDebtInFront = async (provider: EthereumProvider, address: EthAddress): Promise<string> => {
60
+ const client = getViemProvider(provider, NetworkNumber.Eth);
61
+ const viewContract = LiquityViewContractViem(client, NetworkNumber.Eth);
62
+ return _getDebtInFront(viewContract, address);
63
+ };
64
+
65
+ export const _getLiquityTroveInfo = async (provider: Client, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => {
66
+ const viewContract = LiquityViewContractViem(provider, network);
67
+ const collSurplusPoolContract = LiquityCollSurplusPoolContractViem(provider, network);
68
+ const troveManagerContract = LiquityTroveManagerContractViem(provider, network);
69
+ const priceFeedContract = LiquityPriceFeedContractViem(provider, network);
70
+ const activePoolContract = LiquityActivePoolContractViem(provider, network);
71
+
72
+ const [
73
+ troveInfo,
74
+ collSurplusInfo,
75
+ borrowingRateWithDecay,
76
+ assetPrice,
77
+ totalETH,
78
+ totalLUSD,
79
+ debtInFront,
80
+ ] = await Promise.all([
81
+ viewContract.read.getTroveInfo([address]),
82
+ collSurplusPoolContract.read.getCollateral([address]),
83
+ troveManagerContract.read.getBorrowingRateWithDecay(),
84
+ priceFeedContract.read.fetchPrice(),
85
+ activePoolContract.read.getETH(),
86
+ activePoolContract.read.getLUSDDebt(),
87
+ _getDebtInFront(viewContract, address),
88
+ ]);
89
+
90
+ const recoveryMode = troveInfo[6];
91
+
92
+ const payload = {
93
+ troveStatus: LIQUITY_TROVE_STATUS_ENUM[+(troveInfo[0].toString())],
94
+ collateral: assetAmountInEth(troveInfo[1].toString()),
95
+ debtInAsset: assetAmountInEth(troveInfo[2].toString()),
96
+ TCRatio: assetAmountInEth(troveInfo[4].toString()),
97
+ recoveryMode,
98
+ claimableCollateral: assetAmountInEth(collSurplusInfo.toString()),
99
+ borrowingRateWithDecay: assetAmountInEth(borrowingRateWithDecay.toString()),
100
+ assetPrice: assetAmountInEth(assetPrice.toString()),
101
+ totalETH: totalETH.toString(),
102
+ totalLUSD: totalLUSD.toString(),
103
+ debtInFront: debtInFront.toString(),
104
+ minCollateralRatio: recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO,
105
+ priceForRecovery: new Dec(recoveryMode ? LIQUITY_RECOVERY_MODE_RATIO : LIQUITY_NORMAL_MODE_RATIO).mul(totalLUSD).div(totalETH).div(100)
106
+ .toString(),
107
+ };
108
+
109
+ return payload;
110
+ };
111
+
112
+ export const getLiquityTroveInfo = async (provider: EthereumProvider, network: NetworkNumber, address: EthAddress): Promise<LiquityTroveInfo> => _getLiquityTroveInfo(getViemProvider(provider, network, { batch: { multicall: true } }), network, address);
113
+
114
+ export const getLiquityStakingData = async (provider: Client, network: NetworkNumber, address: EthAddress) => {
115
+ const lqtyStakingView = LiquityLQTYStakingViem(provider, network);
116
+ const stabilityPoolView = LiquityStabilityPoolViem(provider, network);
117
+ const [
118
+ stakes,
119
+ pendingETHGain,
120
+ pendingLUSDGain,
121
+ totalLQTYStakes,
122
+ stabilityPoolETHGain,
123
+ stabilityPoolLQTYGain,
124
+ compoundedLUSDDeposit,
125
+ totalLUSDDeposits,
126
+ ] = await Promise.all([
127
+ lqtyStakingView.read.stakes([address]),
128
+ lqtyStakingView.read.getPendingETHGain([address]),
129
+ lqtyStakingView.read.getPendingLUSDGain([address]),
130
+ lqtyStakingView.read.totalLQTYStaked(),
131
+ stabilityPoolView.read.getDepositorETHGain([address]),
132
+ stabilityPoolView.read.getDepositorLQTYGain([address]),
133
+ stabilityPoolView.read.getCompoundedLUSDDeposit([address]),
134
+ stabilityPoolView.read.getTotalLUSDDeposits(),
135
+ ]);
136
+ const totalLUSDDeposited = getEthAmountForDecimals(totalLUSDDeposits as string, 18);
137
+ const totalLQTYStaked = getEthAmountForDecimals(totalLQTYStakes as string, 18);
138
+ const stakedLQTY = getEthAmountForDecimals(stakes as string, 18);
139
+ const stakedLUSDBalance = getEthAmountForDecimals(compoundedLUSDDeposit as string, 18);
140
+ const rewardETH = getEthAmountForDecimals(pendingETHGain as string, 18);
141
+ const rewardLUSD = getEthAmountForDecimals(pendingLUSDGain as string, 18);
142
+ const stabilityRewardETH = getEthAmountForDecimals(stabilityPoolETHGain as string, 18);
143
+ const stabilityRewardLQTY = getEthAmountForDecimals(stabilityPoolLQTYGain as string, 18);
144
+
145
+ const showStakingBalances = !!(+stakedLQTY || +stakedLUSDBalance
146
+ || +rewardETH || +rewardLUSD
147
+ || +stabilityRewardETH || +stabilityRewardLQTY);
148
+
149
+ return {
150
+ totalLUSDDeposited,
151
+ totalLQTYStaked,
152
+ stakedLQTY,
153
+ stakedLUSDBalance,
154
+ rewardETH,
155
+ rewardLUSD,
156
+ stabilityRewardETH,
157
+ stabilityRewardLQTY,
158
+ showStakingBalances,
159
+ };
160
160
  };