-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfrontend_component.tsx
35 lines (29 loc) · 958 Bytes
/
frontend_component.tsx
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
// PhantomConnect.tsx
import { useConnection, useWallet } from '@solana/wallet-adapter-react';
const PhantomButton = () => {
const { connect, connected, publicKey } = useWallet();
// Signing a transaction via Phantom
const signAndSend = async (tx: Transaction) => {
try {
const { connection } = useConnection();
const { signTransaction } = useWallet();
tx.feePayer = publicKey!;
tx.recentBlockhash = (await connection.getLatestBlockhash()).blockhash;
const signed = await signTransaction(tx);
const txid = await connection.sendRawTransaction(signed.serialize());
return txid;
} catch (err) {
console.error("User rejected via Phantom");
return null;
}
};
return (
<div>
{!connected ? (
<button onClick={() => connect()}>Connect Phantom</button>
) : (
<div>Connected: {publicKey?.toBase58()}</div>
)}
</div>
);
};