Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Issue with multi chain config for my use case #3436

Open
Mouneeswar-Medepally opened this issue Dec 11, 2024 · 11 comments
Open

Issue with multi chain config for my use case #3436

Mouneeswar-Medepally opened this issue Dec 11, 2024 · 11 comments

Comments

@Mouneeswar-Medepally
Copy link

Link to minimal reproducible example

n/a

Summary

Hi Team,

I’m unable to create two separate Web3 modals in the same application for different networks, such as Ethereum and Solana.

Could you please assist with this?

Thanks

List of related npm package versions

"@reown/appkit": "^1.5.3",
"@reown/appkit-adapter-solana": "^1.5.3",
"@reown/appkit-adapter-wagmi": "^1.5.3",

Node.js Version

v20.5.1

Package Manager

[email protected]

@Mouneeswar-Medepally Mouneeswar-Medepally added bug Something isn't working needs review labels Dec 11, 2024
Copy link

linear bot commented Dec 11, 2024

@rtomas
Copy link
Contributor

rtomas commented Dec 11, 2024

Hi @Mouneeswar-Medepally
please share a Minimal reproducible example of your issue

@Mouneeswar-Medepally
Copy link
Author

Hi @rtomas,
I’ve provided the details below. Please let me know if you need any additional information to debug this issue.
When I import both these below configuration files, only one modal is being created with a single configuration.

My Use Case:

  • When the network is Solana, the application should use the Solana Config.
  • When the network is Ethereum or Polygon, it should use the Wagmi Config.

Currently, this behavior is not happening. Can you help me resolve this issue?

Solana config:
`import { createAppKit } from '@reown/appkit/react';
import { SolanaAdapter } from '@reown/appkit-adapter-solana/react';
import { solana, solanaTestnet, solanaDevnet } from '@reown/appkit/networks';
import { PhantomWalletAdapter, SolflareWalletAdapter } from '@solana/wallet-adapter-wallets';

export const solanaWeb3JsAdapter = new SolanaAdapter({
wallets: [new PhantomWalletAdapter(), new SolflareWalletAdapter()],
});

const projectId = import.meta.env.VITE_WEB3_WALLET_ID;

export const solanaNetworks = [solana, solanaTestnet, solanaDevnet];

const metadata = {
name: 'AppKit',
description: 'AppKit Solana Example',
url: 'https://example.com',
icons: ['https://avatars.githubusercontent.com/u/179229932'],
};

createAppKit({
adapters: [solanaWeb3JsAdapter],
networks: [solana, solanaTestnet, solanaDevnet],
metadata,
projectId,
features: {
analytics: false,
socials: [],
email: false,
},
themeMode: 'dark',
themeVariables: {
'--w3m-z-index': 1999,
},
});`

Wagmi config:

`import { createAppKit } from '@reown/appkit/react';
import { mainnet, polygon } from '@reown/appkit/networks';
import { WagmiAdapter } from '@reown/appkit-adapter-wagmi';

const projectId = import.meta.env.VITE_WEB3_WALLET_ID;

const metadata = {
name: 'Multi-chain Web3 Modals',
description: 'Multi-chain Web3 Modals',
url: import.meta.env.VITE_PUBLIC_URL,
icons: ['icon_link'],
};

export const wagmiNetworks = [mainnet, polygon];

export const wagmiAdapter = new WagmiAdapter({
networks: wagmiNetworks,
projectId,
ssr: true,
});

createAppKit({
adapters: [wagmiAdapter],
networks: wagmiNetworks,
projectId,
metadata,
features: {
analytics: false,
socials: [],
email: false,
},
themeMode: 'dark',
themeVariables: {
'--w3m-z-index': 1999,
},
});`

@Mouneeswar-Medepally Mouneeswar-Medepally changed the title Issue with Creating Multiple Web3 Modals Issue with multi chain config for my use case Dec 12, 2024
@rtomas
Copy link
Contributor

rtomas commented Dec 12, 2024

hi @Mouneeswar-Medepally

I don't think that your way is possible. Can I know what are you building ?

Is this example suitable for you https://github.com/reown-com/appkit-web-examples/tree/main/react/react-multichain ?
demo: https://appkit-web-examples-react-multichain.vercel.app/

@rtomas rtomas added feature-request and removed bug Something isn't working needs review labels Dec 12, 2024
@Mouneeswar-Medepally
Copy link
Author

hi @rtomas ,

In the example above, both network wallets are displayed at the same time. However, I want to load them separately. For instance, when you configure Solana with Reown, it only shows wallets supported by Solana. I want to do the same for Ethereum, so each network displays only its related wallets.

I’m working on a proof-of-ownership feature where users need to prove ownership of their address. If a user selects the Ethereum network, I want to show only Ethereum-compatible wallets—not both Solana and Ethereum.

To achieve this, I used createAppKit twice to create modals with different configurations for Ethereum and Solana. However, only the first loaded modal configuration is being displayed right now.

Is there any way to load differently configured modals within the same app?

@arein
Copy link
Contributor

arein commented Dec 17, 2024

I’m working on a proof-of-ownership feature where users need to prove ownership of their address. If a user selects the Ethereum network, I want to show only Ethereum-compatible wallets—not both Solana and Ethereum.

Does the user need to verify ownership of both a Solana and EVM wallet? Or do they click Ethereum first? Please explain better the desired experience so we can assess what the best solution would be

@Mouneeswar-Medepally
Copy link
Author

@arein

There are 2 steps:

In the first step, the user will enter an address and choose a network.
In the second step, only wallets linked to the selected network need to be loaded

So, If the user selects Solana, the appkit should load only Solana-supported wallets.
If the user selects Ethereum, the appkit should load only EVM-supported wallets.

@arein
Copy link
Contributor

arein commented Dec 17, 2024

Why would the user "enter an address"?

@Mouneeswar-Medepally
Copy link
Author

Mouneeswar-Medepally commented Dec 17, 2024

@arein

We are maintaining address book of users
if it's his self account, he will sign the message to prove ownership

@Mouneeswar-Medepally
Copy link
Author

Hi,
Could you please provide an update on the progress of this feature request?

Thank you!

@arein
Copy link
Contributor

arein commented Jan 2, 2025

@Mouneeswar-Medepally we've received a few feature requests for this - let me circle back after catching up internally

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants