stackswap-front-api-test-02 1.0.104 → 1.0.105
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.
- package/README.md +10 -10
- package/dist/esm/index.d.ts +86 -86
- package/dist/esm/index.js +145 -145
- package/dist/esm/stackswap/config.d.ts +117 -117
- package/dist/esm/stackswap/config.js +194 -194
- package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/esm/stackswap/manager/farm.manager.js +293 -293
- package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
- package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/governance.manager.js +53 -53
- package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
- package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
- package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js +191 -191
- package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
- package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/esm/stackswap/manager/nft.manager.js +243 -243
- package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/esm/stackswap/manager/operator.manager.js +85 -85
- package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/other.manager.js +47 -47
- package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/esm/stackswap/manager/pool.manager.js +171 -171
- package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
- package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/esm/stackswap/manager/staking.manager.js +233 -233
- package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/esm/stackswap/manager/swap.manager.js +332 -332
- package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
- package/dist/esm/stackswap/manager/token.manager.js +133 -133
- package/dist/esm/stackswap/util.d.ts +35 -35
- package/dist/esm/stackswap/util.js +201 -201
- package/dist/esm/stackswap/util.js.map +1 -1
- package/dist/index.d.ts +86 -86
- package/dist/index.js +154 -154
- package/dist/index.umd.js +1 -1
- package/dist/stackswap/config.d.ts +117 -117
- package/dist/stackswap/config.js +199 -199
- package/dist/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/stackswap/manager/farm.manager.js +301 -301
- package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/stackswap/manager/farm2.manager.js +410 -410
- package/dist/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/stackswap/manager/governance.manager.js +60 -60
- package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/stackswap/manager/launchpad.manager.js +151 -151
- package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/stackswap/manager/lbtc.manager.js +333 -333
- package/dist/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
- package/dist/stackswap/manager/lbtcstaking.manager.js +198 -198
- package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/stackswap/manager/multisig.manager.js +55 -55
- package/dist/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/stackswap/manager/nft.manager.js +250 -250
- package/dist/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/stackswap/manager/operator.manager.js +92 -92
- package/dist/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/stackswap/manager/other.manager.js +54 -54
- package/dist/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/stackswap/manager/pool.manager.js +179 -179
- package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/stackswap/manager/poxl.manager.js +78 -78
- package/dist/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/stackswap/manager/staking.manager.js +240 -240
- package/dist/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/stackswap/manager/swap.manager.js +339 -339
- package/dist/stackswap/manager/token.manager.d.ts +31 -31
- package/dist/stackswap/manager/token.manager.js +141 -141
- package/dist/stackswap/util.d.ts +35 -35
- package/dist/stackswap/util.js +218 -218
- package/dist/stackswap/util.js.map +1 -1
- package/package.json +43 -43
- package/src/index.ts +207 -207
- package/src/stackswap/config.ts +305 -305
- package/src/stackswap/manager/farm.manager.ts +399 -399
- package/src/stackswap/manager/farm2.manager.ts +463 -463
- package/src/stackswap/manager/governance.manager.ts +95 -95
- package/src/stackswap/manager/launchpad.manager.ts +190 -190
- package/src/stackswap/manager/lbtcstaking.manager.ts +277 -277
- package/src/stackswap/manager/multisig.manager.ts +87 -87
- package/src/stackswap/manager/nft.manager.ts +307 -307
- package/src/stackswap/manager/operator.manager.ts +123 -123
- package/src/stackswap/manager/other.manager.ts +71 -71
- package/src/stackswap/manager/pool.manager.ts +202 -202
- package/src/stackswap/manager/poxl.manager.ts +99 -99
- package/src/stackswap/manager/staking.manager.ts +321 -321
- package/src/stackswap/manager/swap.manager.ts +392 -392
- package/src/stackswap/manager/token.manager.ts +167 -167
- package/src/stackswap/util.ts +237 -237
package/src/stackswap/util.ts
CHANGED
|
@@ -1,237 +1,237 @@
|
|
|
1
|
-
import BigNumber from 'bignumber.js';
|
|
2
|
-
|
|
3
|
-
import {
|
|
4
|
-
AnchorMode,
|
|
5
|
-
ClarityValue,
|
|
6
|
-
contractPrincipalCV,
|
|
7
|
-
createFungiblePostCondition,
|
|
8
|
-
createSTXPostCondition,
|
|
9
|
-
FungibleConditionCode,
|
|
10
|
-
PostConditionMode,
|
|
11
|
-
standardPrincipalCV
|
|
12
|
-
} from '@stacks/transactions';
|
|
13
|
-
import axios from 'axios';
|
|
14
|
-
import {StackswapAPI} from "../index";
|
|
15
|
-
import {LiquidityPool} from "./manager/pool.manager";
|
|
16
|
-
|
|
17
|
-
export function parseAddressToCV(addr: string){
|
|
18
|
-
if (addr.includes('.')) {
|
|
19
|
-
const [address, contractName] = addr.split('.');
|
|
20
|
-
return contractPrincipalCV(address, contractName);
|
|
21
|
-
} else {
|
|
22
|
-
return standardPrincipalCV(addr);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export function getReadOptions(stackswap: StackswapAPI, contractName: string, functionName: string, functionArgs: ClarityValue[]) : any {
|
|
27
|
-
if (contractName.includes('.')){
|
|
28
|
-
const parsedAddress = contractName.split('.');
|
|
29
|
-
return {
|
|
30
|
-
contractAddress: parsedAddress[0],
|
|
31
|
-
contractName: parsedAddress[1],
|
|
32
|
-
functionName,
|
|
33
|
-
functionArgs,
|
|
34
|
-
network: stackswap.network,
|
|
35
|
-
senderAddress: stackswap.getSenderAddress(),
|
|
36
|
-
};
|
|
37
|
-
} else {
|
|
38
|
-
return {
|
|
39
|
-
contractAddress: stackswap.config.STACKSWAP_ADDRESS(),
|
|
40
|
-
contractName,
|
|
41
|
-
functionName,
|
|
42
|
-
functionArgs,
|
|
43
|
-
network: stackswap.network,
|
|
44
|
-
senderAddress: stackswap.getSenderAddress(),
|
|
45
|
-
};
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
export function getWriteOptions(stackswap: StackswapAPI, contractName: string, functionName: string, functionArgs: any, postConditions: any = [], callback: any = null, conditionMode: boolean = false) {
|
|
52
|
-
if ( contractName.includes('.')){
|
|
53
|
-
const parsedAddress = contractName.split('.');
|
|
54
|
-
return {
|
|
55
|
-
contractAddress: parsedAddress[0],
|
|
56
|
-
contractName: parsedAddress[1],
|
|
57
|
-
functionName,
|
|
58
|
-
functionArgs,
|
|
59
|
-
network: stackswap.network,
|
|
60
|
-
senderAddress: stackswap.getSenderAddress(),
|
|
61
|
-
postConditionMode: conditionMode? PostConditionMode.Allow: PostConditionMode.Deny,
|
|
62
|
-
postConditions,
|
|
63
|
-
appDetails : {
|
|
64
|
-
name: 'Stackswap',
|
|
65
|
-
icon: window.location.origin + '/public/favicon.ico',
|
|
66
|
-
},
|
|
67
|
-
anchorMode: AnchorMode.Any, // speedup
|
|
68
|
-
sponsored: false,
|
|
69
|
-
onFinish : (data: any) => {
|
|
70
|
-
// console.log(data);
|
|
71
|
-
try {
|
|
72
|
-
callback(null, data);
|
|
73
|
-
} catch (e) {
|
|
74
|
-
callback(e, null);
|
|
75
|
-
// console.log(e);
|
|
76
|
-
}
|
|
77
|
-
},
|
|
78
|
-
onCancel : () => {
|
|
79
|
-
try{
|
|
80
|
-
callback('canceled', null);
|
|
81
|
-
} catch (e) {
|
|
82
|
-
callback(e, null);
|
|
83
|
-
}
|
|
84
|
-
},
|
|
85
|
-
};
|
|
86
|
-
} else {
|
|
87
|
-
return {
|
|
88
|
-
contractAddress: stackswap.config.STACKSWAP_ADDRESS(),
|
|
89
|
-
contractName,
|
|
90
|
-
functionName,
|
|
91
|
-
functionArgs,
|
|
92
|
-
network: stackswap.network,
|
|
93
|
-
senderAddress: stackswap.getSenderAddress(),
|
|
94
|
-
postConditionMode: conditionMode? PostConditionMode.Allow: PostConditionMode.Deny,
|
|
95
|
-
postConditions,
|
|
96
|
-
appDetails : {
|
|
97
|
-
name: 'Stackswap',
|
|
98
|
-
icon: window.location.origin + '/public/favicon.ico',
|
|
99
|
-
},
|
|
100
|
-
anchorMode: AnchorMode.Any, // speedup
|
|
101
|
-
sponsored: false,
|
|
102
|
-
onFinish : (data: any) => {
|
|
103
|
-
// console.log(data);
|
|
104
|
-
try {
|
|
105
|
-
callback(null, data);
|
|
106
|
-
} catch (e) {
|
|
107
|
-
callback(e, null);
|
|
108
|
-
// console.log(e);
|
|
109
|
-
}
|
|
110
|
-
},
|
|
111
|
-
onCancel : () => {
|
|
112
|
-
try{
|
|
113
|
-
callback('canceled', null);
|
|
114
|
-
} catch (e) {
|
|
115
|
-
callback(e, null);
|
|
116
|
-
}
|
|
117
|
-
},
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
async function getFTAsset(stackswap: StackswapAPI, tokenStr: string) {
|
|
124
|
-
// console.log(tokenStr);
|
|
125
|
-
const token_addr = tokenStr.split('.');
|
|
126
|
-
const url = stackswap.config.STACKS_API_URL() + '/v2/contracts/interface/' + token_addr[0] + '/' + token_addr[1];
|
|
127
|
-
const result = await axios.get(url);
|
|
128
|
-
// console.log(tokenStr,result);
|
|
129
|
-
if (result.data.fungible_tokens.length === 1) {
|
|
130
|
-
// console.log(tokenStr+'::'+result.data.fungible_tokens[0].name);
|
|
131
|
-
return tokenStr + '::' + result.data.fungible_tokens[0].name;
|
|
132
|
-
} else if (result.data.fungible_tokens.length === 0) {
|
|
133
|
-
return 'wstx';
|
|
134
|
-
} else {
|
|
135
|
-
// TODO one contract with more than one ft
|
|
136
|
-
// console.log(tokenStr+'::'+result.data.fungible_tokens[0].name);
|
|
137
|
-
return tokenStr + '::' + result.data.fungible_tokens[0].name;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
export async function getPostConditionFromAsset(stackswap: StackswapAPI, account: string, tokenStr: string, tokenAmount: any, condition: FungibleConditionCode) {
|
|
142
|
-
const assetString = await getFTAsset(stackswap, tokenStr);
|
|
143
|
-
if (assetString === 'wstx') {
|
|
144
|
-
// console.log('tokenamount',tokenAmount.toNumber());
|
|
145
|
-
return createSTXPostCondition(account, condition, tokenAmount);
|
|
146
|
-
} else {
|
|
147
|
-
return createFungiblePostCondition(account, condition, tokenAmount, assetString);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
export function num2decimal(input:any, decimal:number){
|
|
153
|
-
return (new BigNumber(input)).dividedBy(10 ** decimal);
|
|
154
|
-
}
|
|
155
|
-
export function decimal2integer(input:any, decimal:number = 6){
|
|
156
|
-
return (new BigNumber(input)).multipliedBy(10 ** decimal).toFixed(0);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
export function numWithComma(input:any) {
|
|
161
|
-
if(typeof (input) === 'string'){
|
|
162
|
-
return new BigNumber(input).toNumber().toLocaleString();
|
|
163
|
-
// return input.replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
164
|
-
}else if(typeof (input) === 'number'){
|
|
165
|
-
return new BigNumber(input).toNumber().toLocaleString();
|
|
166
|
-
// return input.toString().replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
167
|
-
}else if(BigNumber.isBigNumber(input)){
|
|
168
|
-
return input.toNumber().toLocaleString();
|
|
169
|
-
// return input.toString().replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
170
|
-
}else{
|
|
171
|
-
return 'ERROR';
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
export function numFormat_ (input:any, decimal:number = 6){
|
|
178
|
-
const input_bn = new BigNumber(input);
|
|
179
|
-
if(input_bn.isInteger()){
|
|
180
|
-
return numWithComma(input_bn);
|
|
181
|
-
}
|
|
182
|
-
else{
|
|
183
|
-
return numWithComma(input_bn.toFixed(decimal, 1));
|
|
184
|
-
// if(new BigNumber(10 ** (decimal*-1)) < input_bn) {
|
|
185
|
-
//
|
|
186
|
-
// }else{
|
|
187
|
-
// return numWithComma(input_bn.toFixed(6, 1));
|
|
188
|
-
// }
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
export function getPriceAndDY(pair: LiquidityPool, amount: string = '-1', x_to_y: boolean = true) : {dy: string, output_price: string} {
|
|
193
|
-
|
|
194
|
-
try {
|
|
195
|
-
const balance_x = x_to_y ? pair.balance_x : pair.balance_y;
|
|
196
|
-
|
|
197
|
-
const balance_y = x_to_y ? pair.balance_y : pair.balance_x;
|
|
198
|
-
const decimal_x = x_to_y ? pair.token_x.decimal : pair.token_y.decimal;
|
|
199
|
-
const decimal_y = x_to_y ? pair.token_y.decimal : pair.token_x.decimal;
|
|
200
|
-
let dx2 = new BigNumber(10).exponentiatedBy(decimal_x).multipliedBy(amount).multipliedBy(0.997);
|
|
201
|
-
if(amount == '-1'){
|
|
202
|
-
dx2 = new BigNumber(1);
|
|
203
|
-
}
|
|
204
|
-
if (dx2.comparedTo(balance_x) >= 0) {
|
|
205
|
-
// console.log('dx is bigger than dy');
|
|
206
|
-
return {dy: '0', output_price: '0'};
|
|
207
|
-
}
|
|
208
|
-
const dy2 = (new BigNumber(balance_y).multipliedBy(dx2)).dividedBy(new BigNumber(balance_x).plus(dx2));
|
|
209
|
-
const output_price2 = ((new BigNumber(10).exponentiatedBy(decimal_y)).dividedBy(new BigNumber(10).exponentiatedBy(decimal_x))).toNumber() * ((dx2).toNumber()/(dy2).toNumber());
|
|
210
|
-
const output_price_final = output_price2.toString()
|
|
211
|
-
const dy_final = dy2.dividedBy(new BigNumber(10).exponentiatedBy(decimal_y)).toString()
|
|
212
|
-
|
|
213
|
-
if(amount == '-1'){
|
|
214
|
-
return {dy: '0', output_price: output_price_final};
|
|
215
|
-
}
|
|
216
|
-
return {dy: dy_final, output_price: output_price_final};
|
|
217
|
-
} catch (e) {
|
|
218
|
-
return {dy: '0', output_price: '0'};
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
export function getAmountWithDecimalString(amount: number, decimal: number) {
|
|
223
|
-
BigNumber.config({ EXPONENTIAL_AT: 40 })
|
|
224
|
-
try{
|
|
225
|
-
return new BigNumber(10 ** decimal).multipliedBy(amount).toString();
|
|
226
|
-
} catch (e) {
|
|
227
|
-
return new BigNumber(10 ** decimal).multipliedBy(new BigNumber(amount)).toString();
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
export function getAmountStringWithDecimal(amount: string, decimal: number) {
|
|
231
|
-
// console.log(new BigNumber(10 ** decimal).toString());
|
|
232
|
-
try{
|
|
233
|
-
return new BigNumber(10 ** decimal).multipliedBy(amount).toString();
|
|
234
|
-
} catch (e) {
|
|
235
|
-
return new BigNumber(10 ** decimal).multipliedBy(new BigNumber(amount)).toString();
|
|
236
|
-
}
|
|
237
|
-
}
|
|
1
|
+
import BigNumber from 'bignumber.js';
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
AnchorMode,
|
|
5
|
+
ClarityValue,
|
|
6
|
+
contractPrincipalCV,
|
|
7
|
+
createFungiblePostCondition,
|
|
8
|
+
createSTXPostCondition,
|
|
9
|
+
FungibleConditionCode,
|
|
10
|
+
PostConditionMode,
|
|
11
|
+
standardPrincipalCV
|
|
12
|
+
} from '@stacks/transactions';
|
|
13
|
+
import axios from 'axios';
|
|
14
|
+
import {StackswapAPI} from "../index";
|
|
15
|
+
import {LiquidityPool} from "./manager/pool.manager";
|
|
16
|
+
|
|
17
|
+
export function parseAddressToCV(addr: string){
|
|
18
|
+
if (addr.includes('.')) {
|
|
19
|
+
const [address, contractName] = addr.split('.');
|
|
20
|
+
return contractPrincipalCV(address, contractName);
|
|
21
|
+
} else {
|
|
22
|
+
return standardPrincipalCV(addr);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export function getReadOptions(stackswap: StackswapAPI, contractName: string, functionName: string, functionArgs: ClarityValue[]) : any {
|
|
27
|
+
if (contractName.includes('.')){
|
|
28
|
+
const parsedAddress = contractName.split('.');
|
|
29
|
+
return {
|
|
30
|
+
contractAddress: parsedAddress[0],
|
|
31
|
+
contractName: parsedAddress[1],
|
|
32
|
+
functionName,
|
|
33
|
+
functionArgs,
|
|
34
|
+
network: stackswap.network,
|
|
35
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
36
|
+
};
|
|
37
|
+
} else {
|
|
38
|
+
return {
|
|
39
|
+
contractAddress: stackswap.config.STACKSWAP_ADDRESS(),
|
|
40
|
+
contractName,
|
|
41
|
+
functionName,
|
|
42
|
+
functionArgs,
|
|
43
|
+
network: stackswap.network,
|
|
44
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
export function getWriteOptions(stackswap: StackswapAPI, contractName: string, functionName: string, functionArgs: any, postConditions: any = [], callback: any = null, conditionMode: boolean = false) {
|
|
52
|
+
if ( contractName.includes('.')){
|
|
53
|
+
const parsedAddress = contractName.split('.');
|
|
54
|
+
return {
|
|
55
|
+
contractAddress: parsedAddress[0],
|
|
56
|
+
contractName: parsedAddress[1],
|
|
57
|
+
functionName,
|
|
58
|
+
functionArgs,
|
|
59
|
+
network: stackswap.network,
|
|
60
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
61
|
+
postConditionMode: conditionMode? PostConditionMode.Allow: PostConditionMode.Deny,
|
|
62
|
+
postConditions,
|
|
63
|
+
appDetails : {
|
|
64
|
+
name: 'Stackswap',
|
|
65
|
+
icon: window.location.origin + '/public/favicon.ico',
|
|
66
|
+
},
|
|
67
|
+
anchorMode: AnchorMode.Any, // speedup
|
|
68
|
+
sponsored: false,
|
|
69
|
+
onFinish : (data: any) => {
|
|
70
|
+
// console.log(data);
|
|
71
|
+
try {
|
|
72
|
+
callback(null, data);
|
|
73
|
+
} catch (e) {
|
|
74
|
+
callback(e, null);
|
|
75
|
+
// console.log(e);
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
onCancel : () => {
|
|
79
|
+
try{
|
|
80
|
+
callback('canceled', null);
|
|
81
|
+
} catch (e) {
|
|
82
|
+
callback(e, null);
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
};
|
|
86
|
+
} else {
|
|
87
|
+
return {
|
|
88
|
+
contractAddress: stackswap.config.STACKSWAP_ADDRESS(),
|
|
89
|
+
contractName,
|
|
90
|
+
functionName,
|
|
91
|
+
functionArgs,
|
|
92
|
+
network: stackswap.network,
|
|
93
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
94
|
+
postConditionMode: conditionMode? PostConditionMode.Allow: PostConditionMode.Deny,
|
|
95
|
+
postConditions,
|
|
96
|
+
appDetails : {
|
|
97
|
+
name: 'Stackswap',
|
|
98
|
+
icon: window.location.origin + '/public/favicon.ico',
|
|
99
|
+
},
|
|
100
|
+
anchorMode: AnchorMode.Any, // speedup
|
|
101
|
+
sponsored: false,
|
|
102
|
+
onFinish : (data: any) => {
|
|
103
|
+
// console.log(data);
|
|
104
|
+
try {
|
|
105
|
+
callback(null, data);
|
|
106
|
+
} catch (e) {
|
|
107
|
+
callback(e, null);
|
|
108
|
+
// console.log(e);
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
onCancel : () => {
|
|
112
|
+
try{
|
|
113
|
+
callback('canceled', null);
|
|
114
|
+
} catch (e) {
|
|
115
|
+
callback(e, null);
|
|
116
|
+
}
|
|
117
|
+
},
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
async function getFTAsset(stackswap: StackswapAPI, tokenStr: string) {
|
|
124
|
+
// console.log(tokenStr);
|
|
125
|
+
const token_addr = tokenStr.split('.');
|
|
126
|
+
const url = stackswap.config.STACKS_API_URL() + '/v2/contracts/interface/' + token_addr[0] + '/' + token_addr[1];
|
|
127
|
+
const result = await axios.get(url);
|
|
128
|
+
// console.log(tokenStr,result);
|
|
129
|
+
if (result.data.fungible_tokens.length === 1) {
|
|
130
|
+
// console.log(tokenStr+'::'+result.data.fungible_tokens[0].name);
|
|
131
|
+
return tokenStr + '::' + result.data.fungible_tokens[0].name;
|
|
132
|
+
} else if (result.data.fungible_tokens.length === 0) {
|
|
133
|
+
return 'wstx';
|
|
134
|
+
} else {
|
|
135
|
+
// TODO one contract with more than one ft
|
|
136
|
+
// console.log(tokenStr+'::'+result.data.fungible_tokens[0].name);
|
|
137
|
+
return tokenStr + '::' + result.data.fungible_tokens[0].name;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
export async function getPostConditionFromAsset(stackswap: StackswapAPI, account: string, tokenStr: string, tokenAmount: any, condition: FungibleConditionCode) {
|
|
142
|
+
const assetString = await getFTAsset(stackswap, tokenStr);
|
|
143
|
+
if (assetString === 'wstx') {
|
|
144
|
+
// console.log('tokenamount',tokenAmount.toNumber());
|
|
145
|
+
return createSTXPostCondition(account, condition, tokenAmount);
|
|
146
|
+
} else {
|
|
147
|
+
return createFungiblePostCondition(account, condition, tokenAmount, assetString);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
|
|
152
|
+
export function num2decimal(input:any, decimal:number){
|
|
153
|
+
return (new BigNumber(input)).dividedBy(10 ** decimal);
|
|
154
|
+
}
|
|
155
|
+
export function decimal2integer(input:any, decimal:number = 6){
|
|
156
|
+
return (new BigNumber(input)).multipliedBy(10 ** decimal).toFixed(0);
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
|
|
160
|
+
export function numWithComma(input:any, decimal:number) {
|
|
161
|
+
if(typeof (input) === 'string'){
|
|
162
|
+
return new BigNumber(input).toNumber().toLocaleString(undefined, { maximumFractionDigits: decimal });
|
|
163
|
+
// return input.replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
164
|
+
}else if(typeof (input) === 'number'){
|
|
165
|
+
return new BigNumber(input).toNumber().toLocaleString(undefined, { maximumFractionDigits: decimal });
|
|
166
|
+
// return input.toString().replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
167
|
+
}else if(BigNumber.isBigNumber(input)){
|
|
168
|
+
return input.toNumber().toLocaleString(undefined, { maximumFractionDigits: decimal });
|
|
169
|
+
// return input.toString().replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
170
|
+
}else{
|
|
171
|
+
return 'ERROR';
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
|
|
177
|
+
export function numFormat_ (input:any, decimal:number = 6){
|
|
178
|
+
const input_bn = new BigNumber(input);
|
|
179
|
+
if(input_bn.isInteger()){
|
|
180
|
+
return numWithComma(input_bn, 0);
|
|
181
|
+
}
|
|
182
|
+
else{
|
|
183
|
+
return numWithComma(input_bn.toFixed(decimal, 1), decimal);
|
|
184
|
+
// if(new BigNumber(10 ** (decimal*-1)) < input_bn) {
|
|
185
|
+
//
|
|
186
|
+
// }else{
|
|
187
|
+
// return numWithComma(input_bn.toFixed(6, 1));
|
|
188
|
+
// }
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
export function getPriceAndDY(pair: LiquidityPool, amount: string = '-1', x_to_y: boolean = true) : {dy: string, output_price: string} {
|
|
193
|
+
|
|
194
|
+
try {
|
|
195
|
+
const balance_x = x_to_y ? pair.balance_x : pair.balance_y;
|
|
196
|
+
|
|
197
|
+
const balance_y = x_to_y ? pair.balance_y : pair.balance_x;
|
|
198
|
+
const decimal_x = x_to_y ? pair.token_x.decimal : pair.token_y.decimal;
|
|
199
|
+
const decimal_y = x_to_y ? pair.token_y.decimal : pair.token_x.decimal;
|
|
200
|
+
let dx2 = new BigNumber(10).exponentiatedBy(decimal_x).multipliedBy(amount).multipliedBy(0.997);
|
|
201
|
+
if(amount == '-1'){
|
|
202
|
+
dx2 = new BigNumber(1);
|
|
203
|
+
}
|
|
204
|
+
if (dx2.comparedTo(balance_x) >= 0) {
|
|
205
|
+
// console.log('dx is bigger than dy');
|
|
206
|
+
return {dy: '0', output_price: '0'};
|
|
207
|
+
}
|
|
208
|
+
const dy2 = (new BigNumber(balance_y).multipliedBy(dx2)).dividedBy(new BigNumber(balance_x).plus(dx2));
|
|
209
|
+
const output_price2 = ((new BigNumber(10).exponentiatedBy(decimal_y)).dividedBy(new BigNumber(10).exponentiatedBy(decimal_x))).toNumber() * ((dx2).toNumber()/(dy2).toNumber());
|
|
210
|
+
const output_price_final = output_price2.toString()
|
|
211
|
+
const dy_final = dy2.dividedBy(new BigNumber(10).exponentiatedBy(decimal_y)).toString()
|
|
212
|
+
|
|
213
|
+
if(amount == '-1'){
|
|
214
|
+
return {dy: '0', output_price: output_price_final};
|
|
215
|
+
}
|
|
216
|
+
return {dy: dy_final, output_price: output_price_final};
|
|
217
|
+
} catch (e) {
|
|
218
|
+
return {dy: '0', output_price: '0'};
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
export function getAmountWithDecimalString(amount: number, decimal: number) {
|
|
223
|
+
BigNumber.config({ EXPONENTIAL_AT: 40 })
|
|
224
|
+
try{
|
|
225
|
+
return new BigNumber(10 ** decimal).multipliedBy(amount).toString();
|
|
226
|
+
} catch (e) {
|
|
227
|
+
return new BigNumber(10 ** decimal).multipliedBy(new BigNumber(amount)).toString();
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
export function getAmountStringWithDecimal(amount: string, decimal: number) {
|
|
231
|
+
// console.log(new BigNumber(10 ** decimal).toString());
|
|
232
|
+
try{
|
|
233
|
+
return new BigNumber(10 ** decimal).multipliedBy(amount).toString();
|
|
234
|
+
} catch (e) {
|
|
235
|
+
return new BigNumber(10 ** decimal).multipliedBy(new BigNumber(amount)).toString();
|
|
236
|
+
}
|
|
237
|
+
}
|