wallet-connect-web-examples/dapps/universal-provider-solana/src/App.tsx

112 lines
2.7 KiB
TypeScript
Raw Normal View History

import UniversalProvider from "@walletconnect/universal-provider";
import { WalletConnectModal } from "@walletconnect/modal";
import { useState } from "react";
import { signMessage, sendTransaction, SolanaChains } from "./utils/helpers";
const projectId = import.meta.env.VITE_PROJECT_ID;
const events: string[] = [];
// 1. select chains (solana)
const chains = [`solana:${SolanaChains.MainnetBeta}`];
// 2. select methods (solana)
const methods = ["solana_signMessage", "solana_signTransaction"];
// 3. create modal instance
const modal = new WalletConnectModal({
projectId,
chains,
});
// 4. create provider instance
const provider = await UniversalProvider.init({
logger: "error",
projectId: projectId,
metadata: {
name: "WalletConnect x Solana",
description: "Solana integration with WalletConnect's Universal Provider",
url: "https://walletconnect.com/",
icons: ["https://avatars.githubusercontent.com/u/37784886"],
},
});
const App = () => {
const [isConnected, setIsConnected] = useState(false);
// 5. get address once loaded
const address =
provider.session?.namespaces.solana?.accounts[0].split(":")[2];
// 6. handle display_uri event and open modal
provider.on("display_uri", async (uri: string) => {
console.log("uri", uri);
await modal.openModal({
uri,
});
});
// 7. handle connect event
const connect = async () => {
try {
await provider.connect({
namespaces: {
solana: {
methods,
chains,
events,
},
},
});
setIsConnected(true);
console.log("session", provider.session);
} catch {
console.log("Something went wrong, request cancelled");
}
modal.closeModal();
};
// 8. handle disconnect event
const disconnect = async () => {
await provider.disconnect();
setIsConnected(false);
};
// 9. handle signMessage and sendTransaction
const handleSign = async () => {
const res = await signMessage(
`Can i have authorize this request pls bossman - ${Date.now()}`,
provider,
address!
);
console.log(res);
};
const handleSend = async () => {
const res = await sendTransaction(address!, 1000, provider, address!);
console.log(res);
};
return (
<div className="App">
{isConnected ? (
<>
<p>
<b>Public Key: </b>
{address}
</p>
<div className="btn-container">
<button onClick={handleSign}>Sign</button>
<button onClick={handleSend}>Send</button>
<button onClick={disconnect}>Disconnect</button>
</div>
</>
) : (
<button onClick={connect}>Connect</button>
)}
</div>
);
};
export default App;