-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* feat: update RainbowKit integration docs * feat: add results and theming * chore: remove unnecessary quotes * feat: web3onboard integration guide * feat: CosmosKit docs * add solana documentation
- Loading branch information
1 parent
637866c
commit a7ee036
Showing
15 changed files
with
535 additions
and
98 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,28 +1,310 @@ | ||
# BlockNative XDEFI Integration | ||
|
||
First, your app need to install the core Onboard library, the injected wallets module and optionally ethers js to support browser extension and mobile wallets: | ||
In this tutorial we're going to build dApp which supports multiple wallets using the [Web3-Onboard](https://onboard.blocknative.com) library. | ||
|
||
![image](images/blocknative/blocknative_connect_modal.jpg) | ||
|
||
### Get started | ||
|
||
Create new react app | ||
|
||
```bash | ||
npx create-react-app my-blocknative-app --template typescript | ||
``` | ||
|
||
> It's always good idea to start explore something new with fresh and pristine codebase to make sure that exploration subject does not interferes with your existing codebase. | ||
I | ||
Install web3-onboard core and react packages. | ||
|
||
```bash | ||
yarn add @web3-onboard/core @web3-onboard/injected-wallets ethers | ||
yarn add @web3-onboard/core @web3-onboard/react | ||
``` | ||
|
||
> We'll be using `@web3-onboard/react` which provides some fancy react hooks on top of core package, | ||
Install wallet providers | ||
|
||
```bash | ||
yarn add @web3-onboard/xdefi @web3-onboard/injected-wallets @web3-onboard/walletconnect | ||
``` | ||
|
||
> We'll be using `@web3-onboard/xdefi` package and packages for fallback wallets: `@web3-onboard/walletconnect` and `@web3-onboard/injected-wallets` | ||
### Setting up Web3Onboard provider | ||
|
||
First, we need to configure our Web3Onboard. | ||
Let's make Web3Onboard configuration function and complete it step by step | ||
|
||
```javascript | ||
import { init } from "@web3-onboard/react"; | ||
|
||
export function configureWeb3Onboard() { | ||
const web3Onboard = init({ | ||
wallets: [], | ||
chains: [], | ||
theme: "dark", | ||
appMetadata: { | ||
name: "My App", | ||
description: "My App with Web3Onboard", | ||
recommendedInjectedWallets: [{ name: "XDEFI", url: "https://xdefi.io" }], | ||
}, | ||
}); | ||
|
||
return web3Onboard; | ||
} | ||
``` | ||
|
||
Now we have our configuration function, but it does not do much yet. | ||
Let's provide some wallets | ||
|
||
```javascript | ||
import { init } from "@web3-onboard/react"; | ||
import xdefiWalletModule from "@web3-onboard/xdefi"; // [!code ++] | ||
import walletConnectModule from "@web3-onboard/walletconnect"; // [!code ++] | ||
import injectedModule from "@web3-onboard/injected-wallets"; // [!code ++] | ||
|
||
export function configureWeb3Onboard() { | ||
|
||
const wallets = | ||
const web3Onboard = init({ | ||
wallets:[ | ||
xdefiWalletModule(), // [!code ++] | ||
walletConnectModule({ projectId: "YOUR_PROJECT_ID" }), // [!code ++] | ||
injectedModule(), // [!code ++] | ||
]; | ||
chains: [], | ||
theme: "dark", | ||
appMetadata: { | ||
name: "My App", | ||
description: "My App with Web3Onboard", | ||
recommendedInjectedWallets: [{ name: "XDEFI", url: "https://xdefi.io" }], | ||
}, | ||
}); | ||
|
||
return web3Onboard; | ||
} | ||
``` | ||
|
||
and add supported chains | ||
|
||
```javascript | ||
export function configureWeb3Onboard(chains = defaultChainsList) { | ||
const wallets = [ | ||
xdefiWalletModule(), | ||
walletConnectModule({ projectId: "YOUR_PROJECT_ID" }), | ||
injectedModule(), | ||
]; | ||
const web3Onboard = init({ | ||
wallets, | ||
chains: export function configureWeb3Onboard() { | ||
const web3Onboard = init({ | ||
wallets: [ | ||
xdefiWalletModule(), | ||
walletConnectModule({ projectId: "YOUR_PROJECT_ID" }), | ||
injectedModule(), | ||
], | ||
chains: [// [!code ++] | ||
{// [!code ++] | ||
id: "0x1", // [!code ++] | ||
token: "ETH", // [!code ++] | ||
label: "Ethereum", // [!code ++] | ||
rpcUrl: "https://ethereum-rpc.publicnode.com",// [!code ++] | ||
},// [!code ++] | ||
{// [!code ++] | ||
id: "0x2105", // [!code ++] | ||
token: "ETH", // [!code ++] | ||
label: "Base",// [!code ++] | ||
rpcUrl: "https://mainnet.base.org", // [!code ++] | ||
},// [!code ++] | ||
{// [!code ++] | ||
id: "0x89",// [!code ++] | ||
token: "MATIC",// [!code ++] | ||
label: "Polygon",// [!code ++] | ||
rpcUrl: "https://matic-mainnet.chainstacklabs.com",// [!code ++] | ||
},// [!code ++] | ||
],// [!code ++] | ||
theme: "dark", | ||
appMetadata: { | ||
name: "My App", | ||
description: "My App with Web3Onboard", | ||
recommendedInjectedWallets: [{ name: "XDEFI", url: "https://xdefi.io" }], | ||
}, | ||
}); | ||
|
||
return web3Onboard; | ||
}, | ||
theme: "dark", | ||
appMetadata: { | ||
name: "My App", | ||
description: "My App with Web3Onboard", | ||
recommendedInjectedWallets: [{ name: "XDEFI", url: "https://xdefi.io" }], | ||
}, | ||
}); | ||
|
||
return web3Onboard; | ||
} | ||
``` | ||
|
||
Now, we're ready to set up Web3OnboardProvider. Open your React app enty file and wrap your app with Web3OnboardProvider like on sample below | ||
|
||
```javascript | ||
import React from "react"; | ||
import ReactDOM from "react-dom/client"; | ||
import "./index.css"; | ||
import App from "./App"; | ||
import { Web3OnboardProvider } from "@web3-onboard/react"; | ||
import { configureWeb3Onboard } from "./configureWeb3Onboard"; | ||
|
||
const root = ReactDOM.createRoot( | ||
document.getElementById("root") as HTMLElement | ||
); | ||
|
||
root.render( | ||
<React.StrictMode> | ||
<Web3OnboardProvider web3Onboard={configureWeb3Onboard()}> | ||
<App /> | ||
</Web3OnboardProvider> | ||
</React.StrictMode> | ||
); | ||
``` | ||
|
||
Then initialize in your app: | ||
At this point we're done with Web3OnboardProvider setup and finally can start implement our app! | ||
|
||
### Connect and disconnect wallet buttons | ||
|
||
At this step we will try to achieve following result: | ||
|
||
1. Show connect wallet button if there is no connected wallet yet | ||
![image](images/blocknative/web3-onboard-connect-wallet-btn.jpg) | ||
> Our fancy "connect wallet" button | ||
2. Show Web3Onboard connect wallet modal on "connect wallet" button press | ||
![image](images/blocknative/blocknative_connect_modal.jpg) | ||
|
||
> Web3Onboard connect wallet modal | ||
3. Show disconnect button once we have some wallet connected | ||
![image](images/blocknative/web3onboard-disconnect.jpg) | ||
> Connected wallet state | ||
Let's proceed with implementation. Here it is: | ||
|
||
```tsx | ||
import { useConnectWallet } from "@web3-onboard/react"; | ||
import "./App.css"; | ||
import { useCallback } from "react"; | ||
|
||
function App() { | ||
const [{ wallet, connecting }, connectWallet, disconnectWallet] = | ||
useConnectWallet(); | ||
|
||
const disconnect = useCallback(async () => { | ||
if (wallet) { | ||
await disconnectWallet({ label: wallet.label }); | ||
} | ||
}, [wallet, disconnectWallet]); | ||
const walletConnected = Boolean(wallet); | ||
|
||
```js | ||
import Onboard from "@web3-onboard/core"; | ||
import xdefiWalletModule from "@web3-onboard/xdefi"; | ||
return ( | ||
<div className="App"> | ||
<div className="App-container"> | ||
<section> | ||
<button disabled={connecting} onClick={() => connectWallet()}> | ||
{walletConnected | ||
? `${wallet?.label} connected` | ||
: connecting | ||
? "connecting" | ||
: "connect wallet"} | ||
</button> | ||
{walletConnected ? ( | ||
<button onClick={disconnect}>disconnect</button> | ||
) : null} | ||
</section> | ||
</div> | ||
</div> | ||
); | ||
} | ||
export default App; | ||
``` | ||
|
||
// initialize the module with options | ||
const xdefiWalletSdk = xdefiWalletModule(); | ||
Once wallet connected, you must see Blocknative conrol center at the bottom right corner | ||
![image](images/blocknative/web3onboard-control-center.jpg) | ||
If you don't need it, you can disable it on Web3Onboard configuration step. | ||
|
||
const onboard = Onboard({ | ||
// ... other Onboard options | ||
wallets: [ | ||
xdefiWalletSdk(), | ||
//... other wallets | ||
], | ||
```javascript | ||
const web3Onboard = init({ | ||
accountCenter: { | ||
mobile: { | ||
enabled: false, | ||
}, | ||
desktop: { | ||
enabled: false, | ||
}, | ||
}, | ||
...restOfTheConfig, | ||
}); | ||
``` | ||
|
||
For more detailed information on Account center please visit Web3Onboard docs [for core library](https://onboard.blocknative.com/docs/modules/core#accountcenter) and [for React](https://onboard.blocknative.com/docs/modules/react#useaccountcenter) | ||
|
||
### Show connected chain, address and balance | ||
|
||
const connectedWallets = await onboard.connectWallet(); | ||
console.log(connectedWallets); | ||
`useConnectWallet` hook exposes a wallet object of type `WalletState` which represents connected wallet state. | ||
|
||
Here are some typings which are briefly describe what info we can get from `WalletState` just by taking a quick look | ||
|
||
```typescript | ||
interface WalletState { | ||
label: string; | ||
icon: string; | ||
provider: EIP1193Provider; | ||
accounts: Account[]; | ||
chains: ConnectedChain[]; | ||
instance?: unknown; | ||
} | ||
type Account = { | ||
address: Address; | ||
ens: Ens | null; | ||
uns: Uns | null; | ||
balance: Balances | null; | ||
secondaryTokens?: SecondaryTokenBalances[] | null; | ||
}; | ||
type Balances = Record<TokenSymbol, string> | null; | ||
type ConnectedChain = { | ||
id: Chain["id"]; | ||
namespace: Chain["namespace"]; | ||
}; | ||
``` | ||
|
||
> Some types omited for brevity. Refer to Web3Onboarding documentation for full info. | ||
Taking a brief look shows that we can get all we need: connected chain, account address and current balance. Let's show that info! | ||
|
||
```tsx | ||
{ | ||
walletConnected ? ( | ||
<section> | ||
<section>Network Chain ID: {wallet?.chains?.[0].id}</section> | ||
<section>Account Address: {wallet?.accounts?.[0].address}</section> | ||
<section> | ||
<div>Balance:</div> | ||
|
||
{Object.keys(wallet?.accounts?.[0].balance || {}).map((tokenSymbol) => ( | ||
<div> | ||
{wallet?.accounts?.[0].balance?.[tokenSymbol]} {tokenSymbol} | ||
</div> | ||
))} | ||
</section> | ||
</section> | ||
) : null; | ||
} | ||
``` | ||
|
||
And here is the result | ||
![image](images/blocknative/web3onboard-account-information.jpg) | ||
|
||
> Our UI already looks nice. But it will be your homework to make it look gorgeous | ||
### Additional resources | ||
|
||
- [Web3Onboard docs](https://onboard.blocknative.com/docs/overview/introduction) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+35.7 KB
developers/images/solana/solana-xdefi-integration-nextjs-template.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.