@xoxno/sdk-js 0.1.13-alpha → 0.1.14-alpha
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/dist/staking/index.d.ts +7 -1
- package/dist/staking/index.js +9 -0
- package/dist/staking/index.js.map +1 -1
- package/dist/types/staking.d.ts +65 -2
- package/dist/types/staking.js.map +1 -1
- package/dist/users/index.d.ts +15 -0
- package/dist/users/index.js +27 -0
- package/dist/users/index.js.map +1 -1
- package/package.json +1 -1
package/dist/staking/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { StakingPool } from '../types/staking';
|
|
1
|
+
import { GetGroupedStakingPools, StakingPool } from '../types/staking';
|
|
2
2
|
import { Nfts } from '../types/user';
|
|
3
3
|
export default class StakingModule {
|
|
4
4
|
private api;
|
|
@@ -21,6 +21,12 @@ export default class StakingModule {
|
|
|
21
21
|
* @returns {StakingPool}
|
|
22
22
|
*/
|
|
23
23
|
getStakingPoolInfo: (poolId: number) => Promise<StakingPool>;
|
|
24
|
+
/**
|
|
25
|
+
* Returns the staking pools grouped by collection
|
|
26
|
+
*
|
|
27
|
+
* @returns {GetGroupedStakingPools[]}
|
|
28
|
+
*/
|
|
29
|
+
getGroupedStakingPools: () => Promise<GetGroupedStakingPools[]>;
|
|
24
30
|
/**
|
|
25
31
|
* Returns the staking pool by id
|
|
26
32
|
* @param poolId - The pool id
|
package/dist/staking/index.js
CHANGED
|
@@ -49,6 +49,15 @@ class StakingModule {
|
|
|
49
49
|
const response = yield this.api.fetchWithTimeout(`/getPoolDetails/${poolId}`);
|
|
50
50
|
return response;
|
|
51
51
|
});
|
|
52
|
+
/**
|
|
53
|
+
* Returns the staking pools grouped by collection
|
|
54
|
+
*
|
|
55
|
+
* @returns {GetGroupedStakingPools[]}
|
|
56
|
+
*/
|
|
57
|
+
this.getGroupedStakingPools = () => __awaiter(this, void 0, void 0, function* () {
|
|
58
|
+
const response = yield this.api.fetchWithTimeout(`/getGroupedStakingPools`);
|
|
59
|
+
return response;
|
|
60
|
+
});
|
|
52
61
|
/**
|
|
53
62
|
* Returns the staking pool by id
|
|
54
63
|
* @param poolId - The pool id
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/staking/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAEA,uDAAuC;AACvC,8CAAkD;AAClD,0CAAyD;AAEzD,MAAqB,aAAa;IAEhC;QAIA;;;;WAIG;QACI,uBAAkB,GAAG,GAAiC,EAAE;YAC7D,MAAM,QAAQ,GACZ,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAgB,kBAAkB,CAAC,CAAC;YACrE,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;WAIG;QACI,qBAAgB,GAAG,CACxB,UAAkB,EACM,EAAE;YAC1B,IAAI,CAAC,IAAA,+BAAuB,EAAC,UAAU,CAAC,EAAE,CAAC;gBACzC,MAAM,IAAI,KAAK,CAAC,6BAA6B,GAAG,UAAU,CAAC,CAAC;YAC9D,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAC9C,qBAAqB,UAAU,EAAE,CAClC,CAAC;YACF,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;WAIG;QACI,uBAAkB,GAAG,CAAO,MAAc,EAAwB,EAAE;YACzE,IAAI,OAAO,MAAM,KAAK,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACnE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAC9C,mBAAmB,MAAM,EAAE,CAC5B,CAAC;YACF,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;;;;;;;;YAWI;QACG,4BAAuB,GAAG,CAC/B,MAAc,EACd,OAAe,EACf,OAAiB,EACF,EAAE;YACjB,IAAI,OAAO,MAAM,KAAK,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACnE,IAAI,CAAC,IAAA,wBAAc,EAAC,OAAO,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACjE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAO,kBAAkB,EAAE;gBACzE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,MAAM;oBACN,OAAO;oBACP,OAAO;iBACR,CAAC;aACH,CAAC,CAAC;YACH,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;;;;;;;;YAWI;QACG,wBAAmB,GAAG,CAC3B,MAAc,EACd,OAAe,EACf,OAAiB,EACF,EAAE;YACjB,IAAI,OAAO,MAAM,KAAK,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACnE,IAAI,CAAC,IAAA,wBAAc,EAAC,OAAO,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACjE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAO,iBAAiB,EAAE;gBACxE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,MAAM;oBACN,OAAO;oBACP,OAAO;iBACR,CAAC;aACH,CAAC,CAAC;YACH,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/staking/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAEA,uDAAuC;AACvC,8CAAkD;AAClD,0CAAyD;AAEzD,MAAqB,aAAa;IAEhC;QAIA;;;;WAIG;QACI,uBAAkB,GAAG,GAAiC,EAAE;YAC7D,MAAM,QAAQ,GACZ,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAgB,kBAAkB,CAAC,CAAC;YACrE,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;WAIG;QACI,qBAAgB,GAAG,CACxB,UAAkB,EACM,EAAE;YAC1B,IAAI,CAAC,IAAA,+BAAuB,EAAC,UAAU,CAAC,EAAE,CAAC;gBACzC,MAAM,IAAI,KAAK,CAAC,6BAA6B,GAAG,UAAU,CAAC,CAAC;YAC9D,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAC9C,qBAAqB,UAAU,EAAE,CAClC,CAAC;YACF,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;WAIG;QACI,uBAAkB,GAAG,CAAO,MAAc,EAAwB,EAAE;YACzE,IAAI,OAAO,MAAM,KAAK,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACnE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAC9C,mBAAmB,MAAM,EAAE,CAC5B,CAAC;YACF,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;WAIG;QACI,2BAAsB,GAAG,GAE9B,EAAE;YACF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAC9C,yBAAyB,CAC1B,CAAC;YACF,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;;;;;;;;YAWI;QACG,4BAAuB,GAAG,CAC/B,MAAc,EACd,OAAe,EACf,OAAiB,EACF,EAAE;YACjB,IAAI,OAAO,MAAM,KAAK,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACnE,IAAI,CAAC,IAAA,wBAAc,EAAC,OAAO,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACjE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAO,kBAAkB,EAAE;gBACzE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,MAAM;oBACN,OAAO;oBACP,OAAO;iBACR,CAAC;aACH,CAAC,CAAC;YACH,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QAEF;;;;;;;;;;;YAWI;QACG,wBAAmB,GAAG,CAC3B,MAAc,EACd,OAAe,EACf,OAAiB,EACF,EAAE;YACjB,IAAI,OAAO,MAAM,KAAK,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACnE,IAAI,CAAC,IAAA,wBAAc,EAAC,OAAO,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACjE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAO,iBAAiB,EAAE;gBACxE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,MAAM;oBACN,OAAO;oBACP,OAAO;iBACR,CAAC;aACH,CAAC,CAAC;YACH,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA,CAAC;QApHA,IAAI,CAAC,GAAG,GAAG,aAAW,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;CAoHF;AAxHD,gCAwHC"}
|
package/dist/types/staking.d.ts
CHANGED
|
@@ -30,6 +30,10 @@ export type StakingPool = {
|
|
|
30
30
|
currentEpoch: number;
|
|
31
31
|
owner: string;
|
|
32
32
|
};
|
|
33
|
+
export type Reward = {
|
|
34
|
+
value: number;
|
|
35
|
+
ticker: string;
|
|
36
|
+
};
|
|
33
37
|
export declare enum IssuingType {
|
|
34
38
|
Dynamic = "Dynamic",
|
|
35
39
|
Fixed = "Fixed"
|
|
@@ -39,7 +43,66 @@ export declare enum PoolType {
|
|
|
39
43
|
Single = "Single",
|
|
40
44
|
Perk = "Perk"
|
|
41
45
|
}
|
|
42
|
-
export type
|
|
43
|
-
|
|
46
|
+
export type GroupStakingInfo = {
|
|
47
|
+
ticker: string;
|
|
48
|
+
name: string;
|
|
49
|
+
isVerified: boolean;
|
|
50
|
+
profile: string;
|
|
51
|
+
banner: string;
|
|
52
|
+
totalStakedNfts: number;
|
|
53
|
+
pools: Pool[];
|
|
54
|
+
rewards: UnClaimedReward[];
|
|
55
|
+
};
|
|
56
|
+
export type Pool = {
|
|
57
|
+
pool_id: number;
|
|
58
|
+
total_staked: number;
|
|
59
|
+
name: string;
|
|
60
|
+
collections: Collection[];
|
|
61
|
+
pool_type: string;
|
|
62
|
+
issuing_type: string;
|
|
63
|
+
pool_total_staked: number;
|
|
64
|
+
whitelist_pool: boolean;
|
|
65
|
+
is_active: boolean;
|
|
66
|
+
is_stake_enabled: boolean;
|
|
67
|
+
expiration_in_days: number;
|
|
68
|
+
profile: string;
|
|
69
|
+
unbound_period: number;
|
|
70
|
+
reward_per_epoch: Reward[];
|
|
71
|
+
reward_balance: any[];
|
|
72
|
+
start_issuing: number;
|
|
73
|
+
start_issuing_timestamp: number;
|
|
74
|
+
deadline_issuing: number;
|
|
75
|
+
deadline_issuing_timestamp: number;
|
|
76
|
+
cut_fees: number;
|
|
77
|
+
max_stake_per_pool: number;
|
|
78
|
+
reward_tokens: string[];
|
|
79
|
+
reward_per_epoch_per_nft: Reward[];
|
|
80
|
+
max_stake_per_wallet: number;
|
|
81
|
+
is_premium: boolean;
|
|
82
|
+
is_verified: boolean;
|
|
83
|
+
percent_filled: number;
|
|
84
|
+
currentEpoch: number;
|
|
85
|
+
owner: string;
|
|
86
|
+
unClaimedReward: UnClaimedReward[];
|
|
87
|
+
dailyRewardPerNFT: Reward[];
|
|
88
|
+
reward_token: string[];
|
|
89
|
+
ticker: string[];
|
|
90
|
+
totalStakedNfts: number;
|
|
91
|
+
};
|
|
92
|
+
export type Collection = {
|
|
44
93
|
ticker: string;
|
|
94
|
+
name: string;
|
|
95
|
+
};
|
|
96
|
+
export type UnClaimedReward = {
|
|
97
|
+
reward_token: string;
|
|
98
|
+
reward_token_nonce: string;
|
|
99
|
+
amount: number;
|
|
100
|
+
pool_id?: number;
|
|
101
|
+
};
|
|
102
|
+
export type GetGroupedStakingPools = {
|
|
103
|
+
ticker: string;
|
|
104
|
+
pools: number;
|
|
105
|
+
name: string;
|
|
106
|
+
profile: string;
|
|
107
|
+
isVerified: boolean;
|
|
45
108
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"staking.js","sourceRoot":"","sources":["../../src/types/staking.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"staking.js","sourceRoot":"","sources":["../../src/types/staking.ts"],"names":[],"mappings":";;;AAuCA,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,kCAAmB,CAAA;IACnB,8BAAe,CAAA;AACjB,CAAC,EAHW,WAAW,2BAAX,WAAW,QAGtB;AAED,IAAY,QAIX;AAJD,WAAY,QAAQ;IAClB,uBAAW,CAAA;IACX,6BAAiB,CAAA;IACjB,yBAAa,CAAA;AACf,CAAC,EAJW,QAAQ,wBAAR,QAAQ,QAInB"}
|
package/dist/users/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { GetNFTsArgs, SearchNFTsResponse, TradincActivityArgs, TradingActivityResponse } from '../types';
|
|
2
|
+
import { GroupStakingInfo } from '../types/staking';
|
|
2
3
|
import { ArgsUserOffers, IUserProfile, UserAccountInfo, UserInventory, UserOffers, UserStakingInfo } from '../types/user';
|
|
3
4
|
export default class UserModule {
|
|
4
5
|
private api;
|
|
@@ -53,4 +54,18 @@ export default class UserModule {
|
|
|
53
54
|
* @example const userStakingInfo = await new UserModule().getUserStakingInfo('erd11...');
|
|
54
55
|
* */
|
|
55
56
|
getUserStakingInfo: (address: string) => Promise<UserStakingInfo[]>;
|
|
57
|
+
/** Gets user's staking info
|
|
58
|
+
* @param {String} address - User's address
|
|
59
|
+
* @returns {GroupStakingInfo[]} User's staking info
|
|
60
|
+
* @throws {Error} Throws an error if the address is invalid
|
|
61
|
+
* @example const userStakingInfo = await new UserModule().getUserStakingInfo('erd11...');
|
|
62
|
+
* */
|
|
63
|
+
getUserStakingInfoGrouped: (address: string) => Promise<GroupStakingInfo[]>;
|
|
64
|
+
/** Gets user's staking info by ticker
|
|
65
|
+
* @param {String} address - User's address
|
|
66
|
+
* @param {String} ticker - Collection's ticker
|
|
67
|
+
* @returns {GroupStakingInfo[]} User's staking info
|
|
68
|
+
* @throws {Error} Throws an error if the address is invalid
|
|
69
|
+
* */
|
|
70
|
+
getUserStakingTickerInfoGrouped: (address: string, ticker: string) => Promise<GroupStakingInfo[]>;
|
|
56
71
|
}
|
package/dist/users/index.js
CHANGED
|
@@ -16,6 +16,7 @@ const collection_1 = __importDefault(require("../collection"));
|
|
|
16
16
|
const api_1 = __importDefault(require("../utils/api"));
|
|
17
17
|
const getActivity_1 = require("../utils/getActivity");
|
|
18
18
|
const helpers_1 = require("../utils/helpers");
|
|
19
|
+
const regex_1 = require("../utils/regex");
|
|
19
20
|
class UserModule {
|
|
20
21
|
constructor() {
|
|
21
22
|
/**
|
|
@@ -96,6 +97,32 @@ class UserModule {
|
|
|
96
97
|
const response = yield this.api.fetchWithTimeout(`/getUserStakingInfo/${address}`);
|
|
97
98
|
return response;
|
|
98
99
|
});
|
|
100
|
+
/** Gets user's staking info
|
|
101
|
+
* @param {String} address - User's address
|
|
102
|
+
* @returns {GroupStakingInfo[]} User's staking info
|
|
103
|
+
* @throws {Error} Throws an error if the address is invalid
|
|
104
|
+
* @example const userStakingInfo = await new UserModule().getUserStakingInfo('erd11...');
|
|
105
|
+
* */
|
|
106
|
+
this.getUserStakingInfoGrouped = (address) => __awaiter(this, void 0, void 0, function* () {
|
|
107
|
+
if (!(0, helpers_1.isAddressValid)(address))
|
|
108
|
+
throw new Error('Invalid address');
|
|
109
|
+
const response = yield this.api.fetchWithTimeout(`/getUserStakingInfo/${address}?groupByTicker=true`);
|
|
110
|
+
return response;
|
|
111
|
+
});
|
|
112
|
+
/** Gets user's staking info by ticker
|
|
113
|
+
* @param {String} address - User's address
|
|
114
|
+
* @param {String} ticker - Collection's ticker
|
|
115
|
+
* @returns {GroupStakingInfo[]} User's staking info
|
|
116
|
+
* @throws {Error} Throws an error if the address is invalid
|
|
117
|
+
* */
|
|
118
|
+
this.getUserStakingTickerInfoGrouped = (address, ticker) => __awaiter(this, void 0, void 0, function* () {
|
|
119
|
+
if (!(0, helpers_1.isAddressValid)(address))
|
|
120
|
+
throw new Error('Invalid address');
|
|
121
|
+
if (!(0, regex_1.isValidCollectionTicker)(ticker))
|
|
122
|
+
throw new Error('Invalid ticker');
|
|
123
|
+
const response = yield this.api.fetchWithTimeout(`/getUserStakingInfo/${address}?groupByTicker=true&ticker=${ticker}`);
|
|
124
|
+
return response;
|
|
125
|
+
});
|
|
99
126
|
this.api = api_1.default.init();
|
|
100
127
|
this.collection = new collection_1.default();
|
|
101
128
|
}
|
package/dist/users/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/users/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,+DAA6C;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/users/index.ts"],"names":[],"mappings":"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"}
|