ts-sdk-wallet-adapter
Original:🇺🇸 English
Not Translated
How to integrate wallet connection in React frontends using @aptos-labs/wallet-adapter-react. Covers AptosWalletAdapterProvider setup, useWallet() hook, frontend transaction submission, and wallet connection UI. Triggers on: 'wallet adapter', 'connect wallet', 'useWallet', 'AptosWalletAdapterProvider', 'wallet-adapter-react', 'wallet connection'.
2installs
Added on
NPX Install
npx skill4agent add aptos-labs/aptos-agent-skills ts-sdk-wallet-adapterSKILL.md Content
TypeScript SDK: Wallet Adapter (React)
Purpose
Guide wallet connection and frontend transaction submission in React using . End
users sign transactions via their browser wallet (Petra, Nightly, etc.) — never via raw private keys.
@aptos-labs/wallet-adapter-reactALWAYS
- Use for frontend wallet integration — this is the standard React adapter.
@aptos-labs/wallet-adapter-react - Wrap your app root with — all
AptosWalletAdapterProvidercalls require this context.useWallet() - Use hook to access wallet functions in React components.
useWallet() - Use the wallet adapter's (from
signAndSubmitTransaction) in frontend — NOT the SDK's directuseWallet().aptos.signAndSubmitTransaction - Always call after submit — the wallet returns when the tx is accepted, not committed.
aptos.waitForTransaction({ transactionHash })
NEVER
- Do not use or raw private keys in browser/frontend — use wallet adapter for end users.
Account.generate() - Do not use the SDK's in React components — use the wallet adapter's version from
aptos.signAndSubmitTransaction.useWallet() - Do not hardcode wallet names — use the array from
walletsfor a dynamic list.useWallet()
Installation
bash
npm install @aptos-labs/wallet-adapter-reactModern AIP-62 standard wallets (Petra, Nightly, etc.) are autodetected and do NOT require additional packages. Legacy
wallets need their plugin package installed separately.
Provider setup
Wrap your app root with :
AptosWalletAdapterProvidertsx
// main.tsx or App.tsx
import { AptosWalletAdapterProvider } from "@aptos-labs/wallet-adapter-react";
import { Network } from "@aptos-labs/ts-sdk";
function App() {
return (
<AptosWalletAdapterProvider
autoConnect={true}
dappConfig={{
network: Network.TESTNET
}}
onError={(error) => console.error("Wallet error:", error)}
>
<YourApp />
</AptosWalletAdapterProvider>
);
}useWallet() hook
tsx
import { useWallet } from "@aptos-labs/wallet-adapter-react";
function MyComponent() {
const {
account, // Current connected account { address, publicKey }
connected, // Boolean: is wallet connected?
wallet, // Current wallet info { name, icon, url }
wallets, // Array of available wallets
connect, // (walletName) => Promise<void>
disconnect, // () => Promise<void>
signAndSubmitTransaction, // Submit entry function calls (use THIS in frontend)
signTransaction, // Sign without submitting
submitTransaction, // Submit a signed transaction
signMessage, // Sign an arbitrary message
signMessageAndVerify, // Sign and verify a message
changeNetwork, // Switch networks (not all wallets support this)
network // Current network info
} = useWallet();
}Frontend transaction pattern
Use typed payloads with :
InputTransactionDatatsx
// entry-functions/increment.ts
import { InputTransactionData } from "@aptos-labs/wallet-adapter-react";
import { MODULE_ADDRESS } from "../lib/aptos";
export function buildIncrementPayload(): InputTransactionData {
return {
data: {
function: `${MODULE_ADDRESS}::counter::increment`,
functionArguments: []
}
};
}tsx
// components/IncrementButton.tsx
import { useWallet } from "@aptos-labs/wallet-adapter-react";
import { aptos } from "../lib/aptos";
import { buildIncrementPayload } from "../entry-functions/increment";
function IncrementButton() {
const { signAndSubmitTransaction } = useWallet();
const handleClick = async () => {
try {
const response = await signAndSubmitTransaction(buildIncrementPayload());
await aptos.waitForTransaction({
transactionHash: response.hash
});
} catch (error) {
console.error("Transaction failed:", error);
}
};
return <button onClick={handleClick}>Increment</button>;
}Wallet connection UI
tsx
import { useWallet } from "@aptos-labs/wallet-adapter-react";
function WalletInfo() {
const { account, connected, connect, disconnect, wallet, wallets } = useWallet();
if (!connected) {
return (
<div>
{wallets.map((w) => (
<button key={w.name} onClick={() => connect(w.name)}>
Connect {w.name}
</button>
))}
</div>
);
}
return (
<div>
<p>Connected: {account?.address}</p>
<p>Wallet: {wallet?.name}</p>
<button onClick={disconnect}>Disconnect</button>
</div>
);
}Common mistakes
| Mistake | Correct approach |
|---|---|
Missing | Wrap app root with the provider |
| Not waiting for transaction after submit | Always call |
Using SDK | Use the wallet adapter's |
Using | Use wallet adapter; generate only in server/scripts |
| Not handling user rejection | Catch and check for rejection-related error messages |
| Hardcoding wallet names | Use |
References
- Wallet Adapter: https://aptos.dev/build/sdks/wallet-adapter/dapp
- Pattern: TYPESCRIPT_SDK.md
- Related: ts-sdk-transactions, ts-sdk-client, use-ts-sdk