forked from clbrge/svelte-web3
-
Notifications
You must be signed in to change notification settings - Fork 0
/
svelte-web3.d.ts
129 lines (122 loc) · 4.3 KB
/
svelte-web3.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
import { Readable } from "svelte/store";
import Web3 from "web3";
declare module "svelte-web3" {
/**
* JavaScript CAIP-2 representation object.
* @see https://github.com/ChainAgnostic/CAIPs/blob/master/CAIPs/caip-2.md
*/
interface ChainData {
name: string;
chain: string;
network: string;
rpc: string[];
faucets: string[];
nativeCurrency: {
name: string;
symbol: string;
decimals: number;
};
infoURL: string;
shortName: string;
chainId: number;
networkId: number;
icon: string;
explorers: {
name: string;
url: string;
icon: string;
standard: string;
}[];
}
interface DefaultChainStore {
/**
* Enables a connection with the current window provider
* Note that your code need to be in browser context when setBrowserProvider is running.
* So you may want to use onMount when using Sapper or Sveltekit. Similarly, you cannot use setBrowserProvider in SSR context.
*/
readonly setBrowserProvider(): Promise<void>;
/**
* To enable connection using a custom provider.
* @param provider An url string or a valid provider object (as returned by web3Modal or WalletConnect for example)
*/
readonly setProvider(provider: string): Promise<void>;
/**
* Forces a disconnect (and event subscriptions from a provider)
*/
readonly close(): Promise<void>;
}
// ---------- CUSTOM CHAIN STORE PROPERTIES ----------
interface ChainStore extends DefaultChainStore {
/**
* The whole Web3.js API. It must be references as `$web3` and not `web3` since it is a Svelte store.
* @see https://web3js.readthedocs.io/en/v1.5.2/web3.html
*/
readonly web3: Readable<Web3>;
/**
* Current selected account address if connected, `null` otherwise.
*/
readonly selectedAccount: Readable<string | null>;
/**
* `true` if connection to the provider was successful.
*/
readonly connected: Readable<boolean>;
/**
* The current blockchain CAIP-2 data if connected, empty object otherwise.
*/
readonly chainData: Readable<ChainData>;
/**
* The current chainId (if connected).
*/
readonly chainId: Readable<number>;
}
// ---------- DEFAULT CHAIN STORE EXPORTS ----------
/**
* The main connection helper and derived Svelte stores
*/
const defaultChainStore: DefaultChainStore;
/**
* The whole Web3.js API for the `defaultChainStore`. It must be references as `$web3` and not `web3` since it is a Svelte store.
* @see https://web3js.readthedocs.io/en/v1.5.2/web3.html
*/
const web3: Readable<Web3>;
/**
* Current selected account address of the `defaultChainStore` if connected, `null` otherwise.
*/
const selectedAccount: Readable<string | null>;
/**
* `true` if connection to the provider was successful for `defaultChainStore`.
*/
const connected: Readable<boolean>;
/**
* The current blockchain CAIP-2 data of `defaultChainStore` if connected, empty object otherwise.
*/
const chainData: Readable<ChainData>;
/**
* The current chainId of `defaultChainStore` if connected.
*/
const chainId: Readable<number>;
/**
* This can be used to create several stores, each connected to different providers.
* This lets you manage different chains at the same time.
* @param name Unique name for the newly created store. The name `default` is used to create `defaultChainStore` so you shouldn't use it unless you want to override the default store.
*/
function makeChainStore(name: string): ChainStore;
/**
* Retrieves the store without re-initializing the connection:
* @param name Name of the previously created store.
*/
function getChainStore(name: string): ChainStore;
export {
ChainData,
DefaultChainStore,
ChainStore,
web3,
selectedAccount,
connected,
chainId,
chainData,
defaultChainStore,
makeChainStore,
getChainStore,
};
}