stackswap-front-api-test-02 1.0.35

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 (131) hide show
  1. package/README.md +10 -0
  2. package/dist/506.index.umd.js +1 -0
  3. package/dist/esm/index.d.ts +77 -0
  4. package/dist/esm/index.js +110 -0
  5. package/dist/esm/index.js.map +1 -0
  6. package/dist/esm/stackswap/config.d.ts +84 -0
  7. package/dist/esm/stackswap/config.js +123 -0
  8. package/dist/esm/stackswap/config.js.map +1 -0
  9. package/dist/esm/stackswap/main.d.ts +1 -0
  10. package/dist/esm/stackswap/main.js +5 -0
  11. package/dist/esm/stackswap/main.js.map +1 -0
  12. package/dist/esm/stackswap/manager/farm.manager.d.ts +37 -0
  13. package/dist/esm/stackswap/manager/farm.manager.js +220 -0
  14. package/dist/esm/stackswap/manager/farm.manager.js.map +1 -0
  15. package/dist/esm/stackswap/manager/farm2.manager.d.ts +37 -0
  16. package/dist/esm/stackswap/manager/farm2.manager.js +294 -0
  17. package/dist/esm/stackswap/manager/farm2.manager.js.map +1 -0
  18. package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -0
  19. package/dist/esm/stackswap/manager/governance.manager.js +54 -0
  20. package/dist/esm/stackswap/manager/governance.manager.js.map +1 -0
  21. package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -0
  22. package/dist/esm/stackswap/manager/launchpad.manager.js +148 -0
  23. package/dist/esm/stackswap/manager/launchpad.manager.js.map +1 -0
  24. package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -0
  25. package/dist/esm/stackswap/manager/lbtc.manager.js +327 -0
  26. package/dist/esm/stackswap/manager/lbtc.manager.js.map +1 -0
  27. package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -0
  28. package/dist/esm/stackswap/manager/multisig.manager.js +52 -0
  29. package/dist/esm/stackswap/manager/multisig.manager.js.map +1 -0
  30. package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -0
  31. package/dist/esm/stackswap/manager/nft.manager.js +244 -0
  32. package/dist/esm/stackswap/manager/nft.manager.js.map +1 -0
  33. package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -0
  34. package/dist/esm/stackswap/manager/operator.manager.js +86 -0
  35. package/dist/esm/stackswap/manager/operator.manager.js.map +1 -0
  36. package/dist/esm/stackswap/manager/other.manager.d.ts +9 -0
  37. package/dist/esm/stackswap/manager/other.manager.js +48 -0
  38. package/dist/esm/stackswap/manager/other.manager.js.map +1 -0
  39. package/dist/esm/stackswap/manager/pool.manager.d.ts +33 -0
  40. package/dist/esm/stackswap/manager/pool.manager.js +160 -0
  41. package/dist/esm/stackswap/manager/pool.manager.js.map +1 -0
  42. package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -0
  43. package/dist/esm/stackswap/manager/poxl.manager.js +72 -0
  44. package/dist/esm/stackswap/manager/poxl.manager.js.map +1 -0
  45. package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -0
  46. package/dist/esm/stackswap/manager/staking.manager.js +234 -0
  47. package/dist/esm/stackswap/manager/staking.manager.js.map +1 -0
  48. package/dist/esm/stackswap/manager/swap.manager.d.ts +35 -0
  49. package/dist/esm/stackswap/manager/swap.manager.js +291 -0
  50. package/dist/esm/stackswap/manager/swap.manager.js.map +1 -0
  51. package/dist/esm/stackswap/manager/token.manager.d.ts +31 -0
  52. package/dist/esm/stackswap/manager/token.manager.js +126 -0
  53. package/dist/esm/stackswap/manager/token.manager.js.map +1 -0
  54. package/dist/esm/stackswap/util.d.ts +37 -0
  55. package/dist/esm/stackswap/util.js +240 -0
  56. package/dist/esm/stackswap/util.js.map +1 -0
  57. package/dist/index.d.ts +77 -0
  58. package/dist/index.js +117 -0
  59. package/dist/index.js.map +1 -0
  60. package/dist/index.umd.js +2 -0
  61. package/dist/index.umd.js.LICENSE.txt +10 -0
  62. package/dist/stackswap/config.d.ts +84 -0
  63. package/dist/stackswap/config.js +127 -0
  64. package/dist/stackswap/config.js.map +1 -0
  65. package/dist/stackswap/main.d.ts +1 -0
  66. package/dist/stackswap/main.js +7 -0
  67. package/dist/stackswap/main.js.map +1 -0
  68. package/dist/stackswap/manager/farm.manager.d.ts +37 -0
  69. package/dist/stackswap/manager/farm.manager.js +228 -0
  70. package/dist/stackswap/manager/farm.manager.js.map +1 -0
  71. package/dist/stackswap/manager/farm2.manager.d.ts +37 -0
  72. package/dist/stackswap/manager/farm2.manager.js +301 -0
  73. package/dist/stackswap/manager/farm2.manager.js.map +1 -0
  74. package/dist/stackswap/manager/governance.manager.d.ts +9 -0
  75. package/dist/stackswap/manager/governance.manager.js +61 -0
  76. package/dist/stackswap/manager/governance.manager.js.map +1 -0
  77. package/dist/stackswap/manager/launchpad.manager.d.ts +13 -0
  78. package/dist/stackswap/manager/launchpad.manager.js +152 -0
  79. package/dist/stackswap/manager/launchpad.manager.js.map +1 -0
  80. package/dist/stackswap/manager/lbtc.manager.d.ts +31 -0
  81. package/dist/stackswap/manager/lbtc.manager.js +334 -0
  82. package/dist/stackswap/manager/lbtc.manager.js.map +1 -0
  83. package/dist/stackswap/manager/multisig.manager.d.ts +11 -0
  84. package/dist/stackswap/manager/multisig.manager.js +56 -0
  85. package/dist/stackswap/manager/multisig.manager.js.map +1 -0
  86. package/dist/stackswap/manager/nft.manager.d.ts +52 -0
  87. package/dist/stackswap/manager/nft.manager.js +251 -0
  88. package/dist/stackswap/manager/nft.manager.js.map +1 -0
  89. package/dist/stackswap/manager/operator.manager.d.ts +17 -0
  90. package/dist/stackswap/manager/operator.manager.js +93 -0
  91. package/dist/stackswap/manager/operator.manager.js.map +1 -0
  92. package/dist/stackswap/manager/other.manager.d.ts +9 -0
  93. package/dist/stackswap/manager/other.manager.js +55 -0
  94. package/dist/stackswap/manager/other.manager.js.map +1 -0
  95. package/dist/stackswap/manager/pool.manager.d.ts +33 -0
  96. package/dist/stackswap/manager/pool.manager.js +168 -0
  97. package/dist/stackswap/manager/pool.manager.js.map +1 -0
  98. package/dist/stackswap/manager/poxl.manager.d.ts +16 -0
  99. package/dist/stackswap/manager/poxl.manager.js +79 -0
  100. package/dist/stackswap/manager/poxl.manager.js.map +1 -0
  101. package/dist/stackswap/manager/staking.manager.d.ts +25 -0
  102. package/dist/stackswap/manager/staking.manager.js +241 -0
  103. package/dist/stackswap/manager/staking.manager.js.map +1 -0
  104. package/dist/stackswap/manager/swap.manager.d.ts +35 -0
  105. package/dist/stackswap/manager/swap.manager.js +298 -0
  106. package/dist/stackswap/manager/swap.manager.js.map +1 -0
  107. package/dist/stackswap/manager/token.manager.d.ts +31 -0
  108. package/dist/stackswap/manager/token.manager.js +134 -0
  109. package/dist/stackswap/manager/token.manager.js.map +1 -0
  110. package/dist/stackswap/util.d.ts +37 -0
  111. package/dist/stackswap/util.js +259 -0
  112. package/dist/stackswap/util.js.map +1 -0
  113. package/package.json +43 -0
  114. package/src/index.ts +165 -0
  115. package/src/stackswap/config.ts +202 -0
  116. package/src/stackswap/main.ts +6 -0
  117. package/src/stackswap/manager/farm.manager.ts +310 -0
  118. package/src/stackswap/manager/farm2.manager.ts +407 -0
  119. package/src/stackswap/manager/governance.manager.ts +95 -0
  120. package/src/stackswap/manager/launchpad.manager.ts +190 -0
  121. package/src/stackswap/manager/lbtc.manager.ts +566 -0
  122. package/src/stackswap/manager/multisig.manager.ts +87 -0
  123. package/src/stackswap/manager/nft.manager.ts +311 -0
  124. package/src/stackswap/manager/operator.manager.ts +123 -0
  125. package/src/stackswap/manager/other.manager.ts +71 -0
  126. package/src/stackswap/manager/pool.manager.ts +188 -0
  127. package/src/stackswap/manager/poxl.manager.ts +99 -0
  128. package/src/stackswap/manager/staking.manager.ts +321 -0
  129. package/src/stackswap/manager/swap.manager.ts +351 -0
  130. package/src/stackswap/manager/token.manager.ts +156 -0
  131. package/src/stackswap/util.ts +269 -0
@@ -0,0 +1,6 @@
1
+ import {StackswapMainnetAPI} from "../index";
2
+
3
+ const stackswap = new StackswapMainnetAPI('SP3DEN0AZXRZV9ZBMQ7NB65V9NV4Y9TMF87NNP4RF');
4
+
5
+ const lists = stackswap.tokenManager.getTokenLists();
6
+ console.log(lists);
@@ -0,0 +1,310 @@
1
+
2
+ import {
3
+ callReadOnlyFunction,
4
+ contractPrincipalCV,
5
+ cvToValue, FungibleConditionCode,
6
+ listCV,
7
+ standardPrincipalCV,
8
+ uintCV
9
+ } from '@stacks/transactions';
10
+ import BigNumber from 'bignumber.js';
11
+ import {openContractCall} from '@stacks/connect';
12
+ import {getPostConditionFromAsset, getReadOptions, getWriteOptions, num2decimal, numFormat_} from "../util";
13
+ import {StackswapAPI} from "../../index";
14
+ import {LiquidityPool} from "./pool.manager";
15
+
16
+ export class Farm {
17
+ pool : LiquidityPool;
18
+ locked_token : string;
19
+ TVL : string;
20
+ APR : string;
21
+ in_contract : string;
22
+ cur_round: number;
23
+
24
+ constructor(pool: LiquidityPool, locked_token: string, TVL : string, APR: string, in_contract : string, cur_round : number) {
25
+ this.pool = pool;
26
+ this.locked_token = locked_token;
27
+ this.TVL = TVL;
28
+ this.APR = APR;
29
+ this.in_contract = in_contract;
30
+ this.cur_round = cur_round;
31
+ }
32
+
33
+ }
34
+
35
+
36
+ export class FarmManager {
37
+ stackswap: StackswapAPI;
38
+
39
+ constructor(stackswap: StackswapAPI) {
40
+ this.stackswap = stackswap;
41
+ }
42
+
43
+
44
+ async getFarmingRound(bh: number | string){
45
+ try{
46
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-reward-cycle', [
47
+ uintCV(bh)
48
+ ]);
49
+ const result_raw = await callReadOnlyFunction(function_option);
50
+ const result = cvToValue(result_raw);
51
+ return result.value;
52
+ } catch (e) {
53
+ return 0;
54
+ }
55
+ }
56
+
57
+ async getFarmingRoundFirstBlock( cycle: number){
58
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-first-stacks-block-in-reward-cycle', [
59
+ uintCV(cycle)
60
+ ]);
61
+ const result_raw = await callReadOnlyFunction(function_option);
62
+ const result = cvToValue(result_raw);
63
+ // console.log(result);
64
+ return result;
65
+ }
66
+
67
+ async getFarmingStakerStatus( pool_address: string, cur_round: number){
68
+ const address = pool_address.split('.');
69
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker', [
70
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
71
+ contractPrincipalCV(address[0],address[1]),
72
+ ]);
73
+ const result_raw = await callReadOnlyFunction(function_option);
74
+ const result = cvToValue(result_raw);
75
+ try{
76
+ // console.log('getFarmingStakerStatus', result);
77
+ const pooledToken = result.value.amountUstx.value;
78
+ const unclaimedList = [];
79
+ const stakedList = []
80
+ for (const unclaimedElement of result.value.unclaimedList.value) {
81
+ if( unclaimedElement.value < cur_round && unclaimedElement.value <= this.stackswap.config.FARM_V1_END_CYCLE()){
82
+ unclaimedList.push(unclaimedElement.value);
83
+ }
84
+ stakedList.push(unclaimedElement.value);
85
+ }
86
+ return {pooledToken, unclaimedList, stakedList}
87
+ } catch (e) {
88
+ // console.log(e);
89
+ return {pooledToken: 0, unclaimedList: [], stakedList: []}
90
+ }
91
+ }
92
+
93
+
94
+ async getFarmBalance( token: any) {
95
+ // console.log("getBalance", token)
96
+ const pair_details_options : any = getReadOptions(this.stackswap, token.addr, 'get-balance',
97
+ [contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING()) ]);
98
+ try {
99
+ const result = await callReadOnlyFunction(pair_details_options);
100
+ return cvToValue(result).value;
101
+ } catch (e) {
102
+ return 0;
103
+ }
104
+ }
105
+
106
+ async getPoolSTXPriceFarm(pair: any ,token_x: any, token_y: any, farm_total: any){
107
+ // BigNumber.config({ DECIMAL_PLACES: 6});
108
+ const x_token_addr = token_x.addr;
109
+ // console.log(token_x.addr);
110
+ const y_token_addr = token_y.addr;
111
+ // console.log(token_y.addr);
112
+ let total_balacne = new BigNumber(-1);
113
+ if(x_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr){
114
+ total_balacne = (new BigNumber(pair['balance-x'].value).multipliedBy(farm_total).dividedBy(pair['shares-total'].value).dividedBy(new BigNumber(10 ** token_x.decimal))).multipliedBy(2);
115
+ }else if(y_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr){
116
+ total_balacne = (new BigNumber(pair['balance-y'].value).multipliedBy(farm_total).dividedBy(pair['shares-total'].value).dividedBy(new BigNumber(10 ** token_y.decimal))).multipliedBy(2);
117
+ }
118
+ // console.log('pool_stx_price', token_x.addr, token_y.addr,token_x.balance, token_y.balance,total_balacne.toNumber());
119
+ // console.log(pair["balance-x"].value, pair["balance-y"].value, total_balacne.toNumber());
120
+ return total_balacne;
121
+ }
122
+
123
+ async getFarmingTotalStatusCycle( cycle: number){
124
+ // console.log(cycle);
125
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-stats-at-cycle', [
126
+ uintCV(cycle),
127
+ ]);
128
+ const result_raw = await callReadOnlyFunction(function_option);
129
+ const result = cvToValue(result_raw);
130
+ // console.log(result.value.amountUstx.value);
131
+ try{
132
+ return new BigNumber(result.value.amountUstx.value).multipliedBy(2).toFixed(0).toString();
133
+ } catch (e) {
134
+ return '0';
135
+ }
136
+ }
137
+
138
+ async getFarmingTotalValue( pool_address: string){
139
+ try{
140
+ const address = pool_address.split('.');
141
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farm-info', [
142
+ contractPrincipalCV(address[0],address[1]),
143
+ ]);
144
+ const result_raw = await callReadOnlyFunction(function_option);
145
+ const result = cvToValue(result_raw);
146
+ // console.log('get_farming_total',result.value);
147
+ return result.value;
148
+ } catch (e) {
149
+ return 0;
150
+ }
151
+ }
152
+
153
+
154
+ async getFarmingUserRewardPerCycle( pool_address: string, cycle: number){
155
+ const address = pool_address.split('.');
156
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-reward-per-user', [
157
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
158
+ contractPrincipalCV(address[0],address[1]),
159
+ uintCV(cycle),
160
+ ]);
161
+ const result_raw = await callReadOnlyFunction(function_option);
162
+ const result = cvToValue(result_raw);
163
+ // console.log(result_raw);
164
+ return result;
165
+ }
166
+
167
+ async getFarmingUserRewardTotal( pool_address: string){
168
+ const address = pool_address.split('.');
169
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-total', [
170
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
171
+ contractPrincipalCV(address[0],address[1]),
172
+ ]);
173
+ const result_raw = await callReadOnlyFunction(function_option);
174
+ const result = cvToValue(result_raw);
175
+ // console.log('getFarmingUserRewardTotal', result);
176
+ return result;
177
+ }
178
+
179
+
180
+ async getFarmingUserRewardList( pool_address: string, unclaimed_list: any){
181
+ const address = pool_address.split('.');
182
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-from-list', [
183
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
184
+ contractPrincipalCV(address[0],address[1]),
185
+ listCV(unclaimed_list),
186
+ ]);
187
+ const result_raw = await callReadOnlyFunction(function_option);
188
+ const result = cvToValue(result_raw);
189
+ // console.log('getFarmingUserRewardTotal', result);
190
+ return result;
191
+ }
192
+
193
+ async getFarmingRewardInfo( pool_address: string, cycle: number){
194
+ const address = pool_address.split('.');
195
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker-at-cycle', [
196
+ uintCV(cycle),
197
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
198
+ contractPrincipalCV(address[0],address[1]),
199
+ ]);
200
+ const result_raw = await callReadOnlyFunction(function_option);
201
+ try{
202
+ const result = cvToValue(result_raw);
203
+ // console.log(result);
204
+ return result.value.toReturn.value;
205
+ } catch (e) {
206
+ return '0';
207
+ }
208
+ }
209
+
210
+
211
+ async stakeFarmingContract( pool_address: string, amountTokens: string, lockPeriod: number, callback: any = null){
212
+ const address = pool_address.split('.');
213
+ // console.log(amountTokens);
214
+ const amount = new BigNumber(amountTokens).multipliedBy(10 ** 6).toFixed(0).toString();
215
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'stake-tokens', [
216
+ uintCV(amount),
217
+ contractPrincipalCV(address[0],address[1]),
218
+ uintCV(lockPeriod),
219
+ ],[await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), pool_address, amount, FungibleConditionCode.Equal)], callback);
220
+ await openContractCall(function_option);
221
+ }
222
+
223
+ async claimFarmingContract( pool_address: string, cycle: number, amount_STSW: string, amount_LP: string, callback: any = null){
224
+ const address = pool_address.split('.');
225
+ const post_condition = [];
226
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), this.stackswap.config.BASE_STSW_DATA().addr, amount_STSW, FungibleConditionCode.Equal));
227
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), pool_address, amount_LP, FungibleConditionCode.Equal));
228
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'claim-staking-reward', [
229
+ uintCV(cycle),
230
+ contractPrincipalCV(address[0],address[1]),
231
+ ], post_condition, callback);
232
+ await openContractCall(function_option);
233
+ }
234
+
235
+
236
+ async unstakeFarmingContract( pool_address: string, cycle: number, amount_LP: string, callback: any = null){
237
+ const address = pool_address.split('.');
238
+ const post_condition = [];
239
+ // post_condition.push(await getPostConditionFromAsset(STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), BASE_STSW_DATA().addr, amount_STSW, FungibleConditionCode.Equal));
240
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), pool_address, amount_LP, FungibleConditionCode.Equal));
241
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'unstake-from-farming', [
242
+ uintCV(cycle),
243
+ contractPrincipalCV(address[0],address[1]),
244
+ ], post_condition, callback);
245
+ await openContractCall(function_option);
246
+ }
247
+
248
+
249
+ async getCurrentFarmingRound() {
250
+ const bh = await this.stackswap.getCurrentBlock();
251
+ return await this.getFarmingRound(bh);
252
+ }
253
+
254
+
255
+ async getRewardBalanceFromFarming( pool_addr: string, unclaimed_list: any){
256
+ // let reward_balance = new BigNumber(0);
257
+ const num_list = [];
258
+ for (const unclaimed of unclaimed_list) {
259
+ num_list.push(uintCV(unclaimed));
260
+ }
261
+ const result = await this.getFarmingUserRewardList(pool_addr, num_list)
262
+ // rewardSum.value;
263
+ // console.log(result);
264
+ const reward = numFormat_(num2decimal(result.rewardSum.value, 6));
265
+ // console.log({reward, reward_list, reward_balance});
266
+ return reward;
267
+ }
268
+
269
+ // async getRewardBalanceFromFarming( pool_addr: string, unclaimed_list: any) {
270
+ // // let reward_balance = new BigNumber(0);
271
+ // const num_list = [];
272
+ // for (const unclaimed of unclaimed_list) {
273
+ // num_list.push(uintCV(unclaimed));
274
+ // }
275
+ // let reward_num = new BigNumber(0);
276
+ //
277
+ // try {
278
+ // for (let i = 0; i < num_list.length; i += 8) {
279
+ // // console.log(i, num_list.slice(i, i+4 < num_list.length ? i + 4 : num_list.length));
280
+ // const result = await this.getFarmingUserRewardList(pool_addr, num_list.slice(i, i + 8 < num_list.length ? i + 8 : num_list.length));
281
+ // // rewardSum.value;
282
+ // // console.log('temp result', result);
283
+ // reward_num = reward_num.plus(new BigNumber(result.rewardSum.value));
284
+ // }
285
+ // return numFormat_(num2decimal(reward_num.toString(), 6));
286
+ // } catch (e) {
287
+ // // console.log(e);
288
+ // return numFormat_(num2decimal(reward_num.toString(), 6));
289
+ // }
290
+ // }
291
+
292
+
293
+ getFarmingAPR(tvl : string, stsw_price : string){
294
+ if( new BigNumber(tvl) <= new BigNumber(0) ){
295
+ const temp = new BigNumber(671731.200000).multipliedBy(52).multipliedBy(new BigNumber(stsw_price));
296
+ return temp.toFixed(3).toString();
297
+ }else{
298
+ BigNumber.config({ DECIMAL_PLACES: 10});
299
+ // const temp = new BigNumber(671731.200000).multipliedBy(52).div(tvl).multipliedBy(new BigNumber(stsw_price));
300
+ // const my_invest = new BigNumber(1);
301
+ const tvl_bn = new BigNumber(tvl);
302
+ const reward_stx = new BigNumber(671731.2).multipliedBy(new BigNumber(stsw_price));
303
+ // const new_invest = tvl_bn.plus(my_invest);
304
+ const new_reward = reward_stx.div(tvl_bn);
305
+ const new_reward_apr = new_reward.multipliedBy(5200);
306
+ return new_reward_apr.toFixed(3).toString();
307
+ }
308
+ }
309
+
310
+ }