stackswap-front-api-test-02 0.10.1
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 -0
- package/dist/esm/index.d.ts +106 -0
- package/dist/esm/index.js +196 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/stackswap/config.d.ts +172 -0
- package/dist/esm/stackswap/config.js +302 -0
- package/dist/esm/stackswap/config.js.map +1 -0
- package/dist/esm/stackswap/manager/bridge.manager.d.ts +27 -0
- package/dist/esm/stackswap/manager/bridge.manager.js +215 -0
- package/dist/esm/stackswap/manager/bridge.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -0
- package/dist/esm/stackswap/manager/farm.manager.js +293 -0
- package/dist/esm/stackswap/manager/farm.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/farm2.manager.d.ts +106 -0
- package/dist/esm/stackswap/manager/farm2.manager.js +625 -0
- package/dist/esm/stackswap/manager/farm2.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/farm3.manager.d.ts +121 -0
- package/dist/esm/stackswap/manager/farm3.manager.js +557 -0
- package/dist/esm/stackswap/manager/farm3.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -0
- package/dist/esm/stackswap/manager/governance.manager.js +68 -0
- package/dist/esm/stackswap/manager/governance.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/groupfarm.manager.d.ts +70 -0
- package/dist/esm/stackswap/manager/groupfarm.manager.js +379 -0
- package/dist/esm/stackswap/manager/groupfarm.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/launchpad.manager.d.ts +18 -0
- package/dist/esm/stackswap/manager/launchpad.manager.js +253 -0
- package/dist/esm/stackswap/manager/launchpad.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -0
- package/dist/esm/stackswap/manager/lbtc.manager.js +327 -0
- package/dist/esm/stackswap/manager/lbtc.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +61 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js +248 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -0
- package/dist/esm/stackswap/manager/multisig.manager.js +50 -0
- package/dist/esm/stackswap/manager/multisig.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/nft.manager.d.ts +55 -0
- package/dist/esm/stackswap/manager/nft.manager.js +274 -0
- package/dist/esm/stackswap/manager/nft.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -0
- package/dist/esm/stackswap/manager/operator.manager.js +86 -0
- package/dist/esm/stackswap/manager/operator.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/other.manager.d.ts +9 -0
- package/dist/esm/stackswap/manager/other.manager.js +41 -0
- package/dist/esm/stackswap/manager/other.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -0
- package/dist/esm/stackswap/manager/pool.manager.js +172 -0
- package/dist/esm/stackswap/manager/pool.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -0
- package/dist/esm/stackswap/manager/poxl.manager.js +72 -0
- package/dist/esm/stackswap/manager/poxl.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/staking.manager.d.ts +40 -0
- package/dist/esm/stackswap/manager/staking.manager.js +295 -0
- package/dist/esm/stackswap/manager/staking.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/swap.manager.d.ts +71 -0
- package/dist/esm/stackswap/manager/swap.manager.js +730 -0
- package/dist/esm/stackswap/manager/swap.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/token.manager.d.ts +32 -0
- package/dist/esm/stackswap/manager/token.manager.js +142 -0
- package/dist/esm/stackswap/manager/token.manager.js.map +1 -0
- package/dist/esm/stackswap/util.d.ts +35 -0
- package/dist/esm/stackswap/util.js +202 -0
- package/dist/esm/stackswap/util.js.map +1 -0
- package/dist/index.d.ts +106 -0
- package/dist/index.js +206 -0
- package/dist/index.js.map +1 -0
- package/dist/index.umd.js +2 -0
- package/dist/index.umd.js.LICENSE.txt +25 -0
- package/dist/stackswap/config.d.ts +172 -0
- package/dist/stackswap/config.js +308 -0
- package/dist/stackswap/config.js.map +1 -0
- package/dist/stackswap/manager/bridge.manager.d.ts +27 -0
- package/dist/stackswap/manager/bridge.manager.js +222 -0
- package/dist/stackswap/manager/bridge.manager.js.map +1 -0
- package/dist/stackswap/manager/farm.manager.d.ts +41 -0
- package/dist/stackswap/manager/farm.manager.js +301 -0
- package/dist/stackswap/manager/farm.manager.js.map +1 -0
- package/dist/stackswap/manager/farm2.manager.d.ts +106 -0
- package/dist/stackswap/manager/farm2.manager.js +632 -0
- package/dist/stackswap/manager/farm2.manager.js.map +1 -0
- package/dist/stackswap/manager/farm3.manager.d.ts +121 -0
- package/dist/stackswap/manager/farm3.manager.js +564 -0
- package/dist/stackswap/manager/farm3.manager.js.map +1 -0
- package/dist/stackswap/manager/governance.manager.d.ts +9 -0
- package/dist/stackswap/manager/governance.manager.js +75 -0
- package/dist/stackswap/manager/governance.manager.js.map +1 -0
- package/dist/stackswap/manager/groupfarm.manager.d.ts +70 -0
- package/dist/stackswap/manager/groupfarm.manager.js +386 -0
- package/dist/stackswap/manager/groupfarm.manager.js.map +1 -0
- package/dist/stackswap/manager/launchpad.manager.d.ts +18 -0
- package/dist/stackswap/manager/launchpad.manager.js +257 -0
- package/dist/stackswap/manager/launchpad.manager.js.map +1 -0
- package/dist/stackswap/manager/lbtc.manager.d.ts +31 -0
- package/dist/stackswap/manager/lbtc.manager.js +334 -0
- package/dist/stackswap/manager/lbtc.manager.js.map +1 -0
- package/dist/stackswap/manager/lbtcstaking.manager.d.ts +61 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js +255 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/stackswap/manager/multisig.manager.d.ts +11 -0
- package/dist/stackswap/manager/multisig.manager.js +54 -0
- package/dist/stackswap/manager/multisig.manager.js.map +1 -0
- package/dist/stackswap/manager/nft.manager.d.ts +55 -0
- package/dist/stackswap/manager/nft.manager.js +281 -0
- package/dist/stackswap/manager/nft.manager.js.map +1 -0
- package/dist/stackswap/manager/operator.manager.d.ts +17 -0
- package/dist/stackswap/manager/operator.manager.js +93 -0
- package/dist/stackswap/manager/operator.manager.js.map +1 -0
- package/dist/stackswap/manager/other.manager.d.ts +9 -0
- package/dist/stackswap/manager/other.manager.js +45 -0
- package/dist/stackswap/manager/other.manager.js.map +1 -0
- package/dist/stackswap/manager/pool.manager.d.ts +34 -0
- package/dist/stackswap/manager/pool.manager.js +180 -0
- package/dist/stackswap/manager/pool.manager.js.map +1 -0
- package/dist/stackswap/manager/poxl.manager.d.ts +16 -0
- package/dist/stackswap/manager/poxl.manager.js +79 -0
- package/dist/stackswap/manager/poxl.manager.js.map +1 -0
- package/dist/stackswap/manager/staking.manager.d.ts +40 -0
- package/dist/stackswap/manager/staking.manager.js +302 -0
- package/dist/stackswap/manager/staking.manager.js.map +1 -0
- package/dist/stackswap/manager/swap.manager.d.ts +71 -0
- package/dist/stackswap/manager/swap.manager.js +737 -0
- package/dist/stackswap/manager/swap.manager.js.map +1 -0
- package/dist/stackswap/manager/token.manager.d.ts +32 -0
- package/dist/stackswap/manager/token.manager.js +150 -0
- package/dist/stackswap/manager/token.manager.js.map +1 -0
- package/dist/stackswap/util.d.ts +35 -0
- package/dist/stackswap/util.js +219 -0
- package/dist/stackswap/util.js.map +1 -0
- package/package.json +45 -0
- package/src/index.ts +279 -0
- package/src/stackswap/config.ts +456 -0
- package/src/stackswap/manager/bridge.manager.ts +313 -0
- package/src/stackswap/manager/farm.manager.ts +399 -0
- package/src/stackswap/manager/farm2.manager.ts +733 -0
- package/src/stackswap/manager/farm3.manager.ts +690 -0
- package/src/stackswap/manager/governance.manager.ts +112 -0
- package/src/stackswap/manager/groupfarm.manager.ts +474 -0
- package/src/stackswap/manager/launchpad.manager.ts +307 -0
- package/src/stackswap/manager/lbtc.manager.ts +566 -0
- package/src/stackswap/manager/lbtcstaking.manager.ts +360 -0
- package/src/stackswap/manager/multisig.manager.ts +87 -0
- package/src/stackswap/manager/nft.manager.ts +352 -0
- package/src/stackswap/manager/operator.manager.ts +123 -0
- package/src/stackswap/manager/other.manager.ts +72 -0
- package/src/stackswap/manager/pool.manager.ts +202 -0
- package/src/stackswap/manager/poxl.manager.ts +99 -0
- package/src/stackswap/manager/staking.manager.ts +402 -0
- package/src/stackswap/manager/swap.manager.ts +902 -0
- package/src/stackswap/manager/token.manager.ts +177 -0
- package/src/stackswap/util.ts +275 -0
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import {
|
|
2
|
+
callReadOnlyFunction, contractPrincipalCV,
|
|
3
|
+
cvToValue,
|
|
4
|
+
FungibleConditionCode, noneCV,
|
|
5
|
+
standardPrincipalCV,
|
|
6
|
+
uintCV
|
|
7
|
+
} from "@stacks/transactions";
|
|
8
|
+
import axios from "axios";
|
|
9
|
+
import {openContractCall} from "@stacks/connect";
|
|
10
|
+
import {StackswapAPI} from "../../index";
|
|
11
|
+
import {getPostConditionFromAsset, getReadOptions, getWriteOptions, parseAddressToCV} from "../util";
|
|
12
|
+
|
|
13
|
+
export enum TokenType {
|
|
14
|
+
VERIFIED = 1,
|
|
15
|
+
COMMUNITY = 2,
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export enum BaseToken {
|
|
19
|
+
STX,
|
|
20
|
+
STSW,
|
|
21
|
+
vSTSW,
|
|
22
|
+
lBTC,
|
|
23
|
+
NULL,
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export class Token {
|
|
27
|
+
name: string;
|
|
28
|
+
decimal : number;
|
|
29
|
+
icon : string;
|
|
30
|
+
addr : string;
|
|
31
|
+
symbol : string;
|
|
32
|
+
// private tokenManager: TokenManager;
|
|
33
|
+
|
|
34
|
+
constructor(name: string, decimal: number, icon: string, addr: string, symbol: string) {
|
|
35
|
+
this.name = name;
|
|
36
|
+
this.decimal = decimal;
|
|
37
|
+
this.icon = icon;
|
|
38
|
+
this.addr = addr;
|
|
39
|
+
this.symbol = symbol;
|
|
40
|
+
// this.tokenManager = tokenManager
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
toString() : string{
|
|
44
|
+
return '' + {name: this.name, decimal: this.decimal, icon: this.icon, addr: this.addr, symbol: this.symbol};
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
static parseTokenFromJson(data: any) : Token{
|
|
48
|
+
return new Token(data.name, data.decimal, data.icon, data.addr, data.symbol);
|
|
49
|
+
}
|
|
50
|
+
static parseTokenFromJsonList(datas: any) : Token[]{
|
|
51
|
+
const temp_list : Token[] = [];
|
|
52
|
+
for (const data of datas) {
|
|
53
|
+
temp_list.push(Token.parseTokenFromJson(data));
|
|
54
|
+
}
|
|
55
|
+
return temp_list;
|
|
56
|
+
}
|
|
57
|
+
static getBaseTokens(stackswap: StackswapAPI, baseToken : BaseToken) : Token{
|
|
58
|
+
switch (baseToken) {
|
|
59
|
+
case BaseToken.STX:
|
|
60
|
+
return Token.parseTokenFromJson(stackswap.config.BASE_WSTX_DATA());
|
|
61
|
+
case BaseToken.STSW:
|
|
62
|
+
return Token.parseTokenFromJson(stackswap.config.BASE_STSW_DATA());
|
|
63
|
+
case BaseToken.vSTSW:
|
|
64
|
+
return Token.parseTokenFromJson(stackswap.config.BASE_vSTSW_DATA());
|
|
65
|
+
case BaseToken.lBTC:
|
|
66
|
+
return Token.parseTokenFromJson(stackswap.config.BASE_LBTC_DATA());
|
|
67
|
+
case BaseToken.NULL:
|
|
68
|
+
return Token.parseTokenFromJson(stackswap.config.BASE_NULL_TOKEN_DATA());
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export class TokenManager {
|
|
74
|
+
stackswap: StackswapAPI;
|
|
75
|
+
|
|
76
|
+
constructor(stackswap: StackswapAPI) {
|
|
77
|
+
this.stackswap = stackswap;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
async getTokenLists(type: TokenType = TokenType.VERIFIED) : Promise<Token[]>{
|
|
81
|
+
switch (type) {
|
|
82
|
+
case TokenType.COMMUNITY:
|
|
83
|
+
const url1 = this.stackswap.config.STACKS_BACKEND_URL() + '/stacks/communitytokens/' + this.stackswap.config.STACKS_BACKEND_PARAM();
|
|
84
|
+
const res1 = await axios.get ( url1, {
|
|
85
|
+
timeout: 30000, // 해당시간안에 응답이 오지않는다면 에러처리된다.
|
|
86
|
+
});
|
|
87
|
+
return Token.parseTokenFromJsonList(res1.data);
|
|
88
|
+
case TokenType.VERIFIED:
|
|
89
|
+
const url2 = this.stackswap.config.STACKS_BACKEND_URL() + '/stacks/tokens/' + this.stackswap.config.STACKS_BACKEND_PARAM();
|
|
90
|
+
const res2 = await axios.get ( url2, {
|
|
91
|
+
timeout: 30000, // 해당시간안에 응답이 오지않는다면 에러처리된다.
|
|
92
|
+
});
|
|
93
|
+
return Token.parseTokenFromJsonList(res2.data);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
async transferSTSW( toAddr: string, amount: string, callback : any = null){
|
|
98
|
+
|
|
99
|
+
// // console.log({amount});
|
|
100
|
+
const post_condition = [await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
|
|
101
|
+
const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.BASE_STSW_DATA().addr, 'transfer', [
|
|
102
|
+
uintCV(amount), standardPrincipalCV(this.stackswap.getSenderAddress()), contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), toAddr), noneCV()
|
|
103
|
+
], post_condition, callback);
|
|
104
|
+
await openContractCall(function_option);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
async getTokenData( token_addr: string) : Promise<Token | null> {
|
|
108
|
+
// // console.log('finding '+ tokenstr);
|
|
109
|
+
try {
|
|
110
|
+
const name_result = await callReadOnlyFunction( getReadOptions(this.stackswap, token_addr, 'get-name', []));
|
|
111
|
+
// // console.log(cvToValue(name_result));
|
|
112
|
+
let token_name = cvToValue(name_result).value;
|
|
113
|
+
|
|
114
|
+
const symbol_result = await callReadOnlyFunction( getReadOptions(this.stackswap, token_addr, 'get-symbol', []));
|
|
115
|
+
const token_symbol = cvToValue(symbol_result).value;
|
|
116
|
+
|
|
117
|
+
const decimal_result = await callReadOnlyFunction( getReadOptions(this.stackswap, token_addr, 'get-decimals', []));
|
|
118
|
+
const token_decimal = Number(cvToValue(decimal_result).value);
|
|
119
|
+
|
|
120
|
+
const uri_result = await callReadOnlyFunction( getReadOptions(this.stackswap, token_addr, 'get-token-uri', []));
|
|
121
|
+
const token_uri = cvToValue(uri_result).value.value;
|
|
122
|
+
// console.log('uri', cvToValue(uri_result));
|
|
123
|
+
// console.log('uri v v', cvToValue(uri_result).value.value);
|
|
124
|
+
let token_icon = 'https://app.stackswap.org/icon/blank.svg';
|
|
125
|
+
try {
|
|
126
|
+
const uri_result = await axios.get(token_uri);
|
|
127
|
+
// console.log(uri_result);
|
|
128
|
+
// console.log(uri_result.data);
|
|
129
|
+
// console.log(uri_result.data.properties);
|
|
130
|
+
if(token_icon)
|
|
131
|
+
try {
|
|
132
|
+
if (uri_result.data.image)
|
|
133
|
+
token_icon = uri_result.data.image;
|
|
134
|
+
} catch (e) {
|
|
135
|
+
// // console.log('no img file');
|
|
136
|
+
}
|
|
137
|
+
try {
|
|
138
|
+
if (uri_result.data.vector)
|
|
139
|
+
token_icon = uri_result.data.vector;
|
|
140
|
+
} catch (e) {
|
|
141
|
+
// // console.log('no svg file');
|
|
142
|
+
}
|
|
143
|
+
try {
|
|
144
|
+
if (uri_result.data.properties.image.description)
|
|
145
|
+
token_icon = uri_result.data.properties.image.description;
|
|
146
|
+
} catch (e) {
|
|
147
|
+
// // console.log('no img file');
|
|
148
|
+
}
|
|
149
|
+
try {
|
|
150
|
+
if (uri_result.data.properties.vector.description)
|
|
151
|
+
token_icon = uri_result.data.properties.vector.description;
|
|
152
|
+
} catch (e) {
|
|
153
|
+
// // console.log('no svg file');
|
|
154
|
+
}
|
|
155
|
+
} catch (e) {
|
|
156
|
+
// // console.log(e);
|
|
157
|
+
}
|
|
158
|
+
if (token_name === 'wSTX') {token_name = 'STX'; }
|
|
159
|
+
return new Token(token_name, token_decimal, token_icon, token_addr, token_symbol);
|
|
160
|
+
} catch (e) {
|
|
161
|
+
// console.log(e);
|
|
162
|
+
return null;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
async getBalanceOf( token: Token, address: string) : Promise<string> {
|
|
167
|
+
// // console.log("getBalance", token)
|
|
168
|
+
const pair_details_options : any = getReadOptions(this.stackswap, token.addr, 'get-balance',
|
|
169
|
+
[parseAddressToCV(address) ]);
|
|
170
|
+
try {
|
|
171
|
+
const result = await callReadOnlyFunction(pair_details_options);
|
|
172
|
+
return cvToValue(result).value;
|
|
173
|
+
} catch (e) {
|
|
174
|
+
return '0';
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
import BigNumber from 'bignumber.js';
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
AnchorMode,
|
|
5
|
+
ClarityValue,
|
|
6
|
+
contractPrincipalCV, createFungiblePostCondition, createSTXPostCondition,
|
|
7
|
+
FungibleConditionCode,
|
|
8
|
+
PostConditionMode,
|
|
9
|
+
standardPrincipalCV
|
|
10
|
+
} from '@stacks/transactions';
|
|
11
|
+
import axios from 'axios';
|
|
12
|
+
import {StackswapAPI} from "../index";
|
|
13
|
+
import {LiquidityPool} from "./manager/pool.manager";
|
|
14
|
+
|
|
15
|
+
export function parseAddressToCV(addr: string){
|
|
16
|
+
if (addr.includes('.')) {
|
|
17
|
+
const [address, contractName] = addr.split('.');
|
|
18
|
+
return contractPrincipalCV(address, contractName);
|
|
19
|
+
} else {
|
|
20
|
+
return standardPrincipalCV(addr);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export function getReadOptions(stackswap: StackswapAPI, contractName: string, functionName: string, functionArgs: ClarityValue[]) : any {
|
|
25
|
+
if (contractName.includes('.')){
|
|
26
|
+
const parsedAddress = contractName.split('.');
|
|
27
|
+
return {
|
|
28
|
+
contractAddress: parsedAddress[0],
|
|
29
|
+
contractName: parsedAddress[1],
|
|
30
|
+
functionName,
|
|
31
|
+
functionArgs,
|
|
32
|
+
network: stackswap.network,
|
|
33
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
34
|
+
};
|
|
35
|
+
} else {
|
|
36
|
+
return {
|
|
37
|
+
contractAddress: stackswap.config.STACKSWAP_ADDRESS(),
|
|
38
|
+
contractName,
|
|
39
|
+
functionName,
|
|
40
|
+
functionArgs,
|
|
41
|
+
network: stackswap.network,
|
|
42
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
export function getWriteOptions(stackswap: StackswapAPI, contractName: string, functionName: string, functionArgs: any, postConditions: any = [], callback: any = null, conditionMode: boolean = false) {
|
|
50
|
+
if ( contractName.includes('.')){
|
|
51
|
+
const parsedAddress = contractName.split('.');
|
|
52
|
+
return {
|
|
53
|
+
contractAddress: parsedAddress[0],
|
|
54
|
+
contractName: parsedAddress[1],
|
|
55
|
+
functionName,
|
|
56
|
+
functionArgs,
|
|
57
|
+
network: stackswap.network,
|
|
58
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
59
|
+
postConditionMode: conditionMode? PostConditionMode.Allow: PostConditionMode.Deny,
|
|
60
|
+
postConditions,
|
|
61
|
+
appDetails : {
|
|
62
|
+
name: 'Stackswap',
|
|
63
|
+
icon: window.location.origin + '/public/favicon.ico',
|
|
64
|
+
},
|
|
65
|
+
anchorMode: AnchorMode.Any, // speedup
|
|
66
|
+
sponsored: false,
|
|
67
|
+
onFinish : (data: any) => {
|
|
68
|
+
// console.log(data);
|
|
69
|
+
try {
|
|
70
|
+
callback(null, data);
|
|
71
|
+
} catch (e) {
|
|
72
|
+
callback(e, null);
|
|
73
|
+
// console.log(e);
|
|
74
|
+
}
|
|
75
|
+
},
|
|
76
|
+
onCancel : () => {
|
|
77
|
+
try{
|
|
78
|
+
callback('canceled', null);
|
|
79
|
+
} catch (e) {
|
|
80
|
+
callback(e, null);
|
|
81
|
+
}
|
|
82
|
+
},
|
|
83
|
+
};
|
|
84
|
+
} else {
|
|
85
|
+
return {
|
|
86
|
+
contractAddress: stackswap.config.STACKSWAP_ADDRESS(),
|
|
87
|
+
contractName,
|
|
88
|
+
functionName,
|
|
89
|
+
functionArgs,
|
|
90
|
+
network: stackswap.network,
|
|
91
|
+
senderAddress: stackswap.getSenderAddress(),
|
|
92
|
+
postConditionMode: conditionMode? PostConditionMode.Allow: PostConditionMode.Deny,
|
|
93
|
+
postConditions,
|
|
94
|
+
appDetails : {
|
|
95
|
+
name: 'Stackswap',
|
|
96
|
+
icon: window.location.origin + '/public/favicon.ico',
|
|
97
|
+
},
|
|
98
|
+
anchorMode: AnchorMode.Any, // speedup
|
|
99
|
+
sponsored: false,
|
|
100
|
+
onFinish : (data: any) => {
|
|
101
|
+
// console.log(data);
|
|
102
|
+
try {
|
|
103
|
+
callback(null, data);
|
|
104
|
+
} catch (e) {
|
|
105
|
+
callback(e, null);
|
|
106
|
+
// console.log(e);
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
onCancel : () => {
|
|
110
|
+
try{
|
|
111
|
+
callback('canceled', null);
|
|
112
|
+
} catch (e) {
|
|
113
|
+
callback(e, null);
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
async function getFTAsset(stackswap: StackswapAPI, tokenStr: string) {
|
|
122
|
+
// console.log(tokenStr);
|
|
123
|
+
const token_addr = tokenStr.split('.');
|
|
124
|
+
const url = stackswap.config.STACKS_API_URL() + '/v2/contracts/interface/' + token_addr[0] + '/' + token_addr[1];
|
|
125
|
+
const result = await axios.get(url);
|
|
126
|
+
// console.log(tokenStr,result);
|
|
127
|
+
if (result.data.fungible_tokens.length === 1) {
|
|
128
|
+
// console.log(tokenStr+'::'+result.data.fungible_tokens[0].name);
|
|
129
|
+
return tokenStr + '::' + result.data.fungible_tokens[0].name;
|
|
130
|
+
} else if (result.data.fungible_tokens.length === 0) {
|
|
131
|
+
return 'wstx';
|
|
132
|
+
} else {
|
|
133
|
+
// TODO one contract with more than one ft
|
|
134
|
+
// console.log(tokenStr+'::'+result.data.fungible_tokens[0].name);
|
|
135
|
+
return tokenStr + '::' + result.data.fungible_tokens[0].name;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
export async function getPostConditionFromAsset(stackswap: StackswapAPI, account: string, tokenStr: string, tokenAmount: any, condition: FungibleConditionCode) {
|
|
140
|
+
const assetString = await getFTAsset(stackswap, tokenStr);
|
|
141
|
+
if (assetString === 'wstx') {
|
|
142
|
+
// console.log('tokenamount',tokenAmount.toNumber());
|
|
143
|
+
return createSTXPostCondition(account, condition, tokenAmount);
|
|
144
|
+
} else {
|
|
145
|
+
return createFungiblePostCondition(account, condition, tokenAmount, assetString);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
|
|
150
|
+
export function num2decimal(input:any, decimal:number){
|
|
151
|
+
return (new BigNumber(input)).dividedBy(10 ** decimal);
|
|
152
|
+
}
|
|
153
|
+
export function decimal2integer(input:any, decimal:number = 6){
|
|
154
|
+
return (new BigNumber(input)).multipliedBy(10 ** decimal).toFixed(0);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
|
|
158
|
+
export function numWithComma(input:any, decimal:number) {
|
|
159
|
+
if(typeof (input) === 'string'){
|
|
160
|
+
return new BigNumber(input).toNumber().toLocaleString(undefined, { maximumFractionDigits: decimal });
|
|
161
|
+
// return input.replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
162
|
+
}else if(typeof (input) === 'number'){
|
|
163
|
+
return new BigNumber(input).toNumber().toLocaleString(undefined, { maximumFractionDigits: decimal });
|
|
164
|
+
// return input.toString().replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
165
|
+
}else if(BigNumber.isBigNumber(input)){
|
|
166
|
+
return input.toNumber().toLocaleString(undefined, { maximumFractionDigits: decimal });
|
|
167
|
+
// return input.toString().replace(/\B(?<!\.\d*)(?=(\d{3})+(?!\d))/g, ',');
|
|
168
|
+
}else{
|
|
169
|
+
return 'ERROR';
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
|
|
174
|
+
|
|
175
|
+
export function numFormat_ (input:any, decimal:number = 6){
|
|
176
|
+
const input_bn = new BigNumber(input);
|
|
177
|
+
if(input_bn.isInteger()){
|
|
178
|
+
return numWithComma(input_bn, 0);
|
|
179
|
+
}
|
|
180
|
+
else{
|
|
181
|
+
return numWithComma(input_bn.toFixed(decimal, 1), decimal);
|
|
182
|
+
// if(new BigNumber(10 ** (decimal*-1)) < input_bn) {
|
|
183
|
+
//
|
|
184
|
+
// }else{
|
|
185
|
+
// return numWithComma(input_bn.toFixed(6, 1));
|
|
186
|
+
// }
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
export function getPriceAndDY(pair: LiquidityPool, amount: string = '-1', x_to_y: boolean = true) : {dy: string, output_price: string} {
|
|
191
|
+
|
|
192
|
+
try {
|
|
193
|
+
const balance_x = x_to_y ? pair.balance_x : pair.balance_y;
|
|
194
|
+
|
|
195
|
+
const balance_y = x_to_y ? pair.balance_y : pair.balance_x;
|
|
196
|
+
const decimal_x = x_to_y ? pair.token_x.decimal : pair.token_y.decimal;
|
|
197
|
+
const decimal_y = x_to_y ? pair.token_y.decimal : pair.token_x.decimal;
|
|
198
|
+
let dx2 = new BigNumber(10).exponentiatedBy(decimal_x).multipliedBy(amount).multipliedBy(0.997);
|
|
199
|
+
if(amount == '-1'){
|
|
200
|
+
dx2 = new BigNumber(1);
|
|
201
|
+
}
|
|
202
|
+
if (dx2.comparedTo(balance_x) >= 0) {
|
|
203
|
+
// console.log('dx is bigger than dy');
|
|
204
|
+
return {dy: '0', output_price: '0'};
|
|
205
|
+
}
|
|
206
|
+
const dy2 = (new BigNumber(balance_y).multipliedBy(dx2)).dividedBy(new BigNumber(balance_x).plus(dx2));
|
|
207
|
+
const output_price2 = ((new BigNumber(10).exponentiatedBy(decimal_y)).dividedBy(new BigNumber(10).exponentiatedBy(decimal_x))).toNumber() * ((dx2).toNumber()/(dy2).toNumber());
|
|
208
|
+
const output_price_final = output_price2.toString()
|
|
209
|
+
const dy_final = dy2.dividedBy(new BigNumber(10).exponentiatedBy(decimal_y)).toString()
|
|
210
|
+
|
|
211
|
+
if(amount == '-1'){
|
|
212
|
+
return {dy: '0', output_price: output_price_final};
|
|
213
|
+
}
|
|
214
|
+
return {dy: dy_final, output_price: output_price_final};
|
|
215
|
+
} catch (e) {
|
|
216
|
+
return {dy: '0', output_price: '0'};
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
export function getAmountWithDecimalString(amount: number, decimal: number) {
|
|
221
|
+
BigNumber.config({ EXPONENTIAL_AT: 40 })
|
|
222
|
+
try{
|
|
223
|
+
return new BigNumber(10 ** decimal).multipliedBy(amount).toString();
|
|
224
|
+
} catch (e) {
|
|
225
|
+
return new BigNumber(10 ** decimal).multipliedBy(new BigNumber(amount)).toString();
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
export function getAmountStringWithDecimal(amount: string, decimal: number) {
|
|
229
|
+
// console.log(new BigNumber(10 ** decimal).toString());
|
|
230
|
+
try{
|
|
231
|
+
return new BigNumber(10 ** decimal).multipliedBy(amount).toString();
|
|
232
|
+
} catch (e) {
|
|
233
|
+
return new BigNumber(10 ** decimal).multipliedBy(new BigNumber(amount)).toString();
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
//
|
|
237
|
+
// export function createNonFungiblePostCondition(account: string, condition: NonFungibleConditionCode, assetString: AssetString, assetIdCV: ClarityValue) : NonFungiblePostCondition {
|
|
238
|
+
// let conditionComparator: NonFungibleComparator = 'sent';
|
|
239
|
+
// switch (condition) {
|
|
240
|
+
// case NonFungibleConditionCode.Sends:
|
|
241
|
+
// conditionComparator = 'sent';
|
|
242
|
+
// break
|
|
243
|
+
// case NonFungibleConditionCode.DoesNotSend:
|
|
244
|
+
// conditionComparator = 'not-sent';
|
|
245
|
+
// break
|
|
246
|
+
// }
|
|
247
|
+
// return {
|
|
248
|
+
// type: 'nft-postcondition',
|
|
249
|
+
// address: account,
|
|
250
|
+
// condition: conditionComparator,
|
|
251
|
+
// asset: assetString,
|
|
252
|
+
// assetId: assetIdCV,
|
|
253
|
+
// };
|
|
254
|
+
// }
|
|
255
|
+
//
|
|
256
|
+
// export function createFungiblePostCondition(account: any, condition: FungibleComparator, assetString: AssetString, amount: string | bigint | number): FungiblePostCondition {
|
|
257
|
+
// return {
|
|
258
|
+
// type: 'ft-postcondition',
|
|
259
|
+
// address: account,
|
|
260
|
+
// condition: condition,
|
|
261
|
+
// asset: assetString,
|
|
262
|
+
// amount: amount,
|
|
263
|
+
// };
|
|
264
|
+
//
|
|
265
|
+
// }
|
|
266
|
+
//
|
|
267
|
+
// export function createSTXPostCondition(account: any, condition: FungibleComparator, amount: string | bigint | number): StxPostCondition {
|
|
268
|
+
// return {
|
|
269
|
+
// type: 'stx-postcondition',
|
|
270
|
+
// address: account,
|
|
271
|
+
// condition: condition,
|
|
272
|
+
// amount: amount,
|
|
273
|
+
// };
|
|
274
|
+
//
|
|
275
|
+
// }
|