Ready-to-use UI components for Algorand wallet integration, built as a companion to @txnlab/use-wallet.
- 🔌 Simple Integration: Drop-in components for wallet connection
- 🧠 Smart Components: Automatic detection of connected state
- 🎨 Styling Options: Works with or without Tailwind CSS
- 🏷️ NFD Support: Built-in NFD integration
- 🔄 Account Management: Switch between accounts and wallets
- 🌓 Dark Mode: Automatic light/dark theme support
- 🚀 Framework Support: Currently React, with Vue and SolidJS coming soon
npm install @txnlab/use-wallet-ui-reactimport {
  NetworkId,
  WalletId,
  WalletManager,
  WalletProvider,
} from '@txnlab/use-wallet-react'
import { WalletUIProvider, WalletButton } from '@txnlab/use-wallet-ui-react'
// Optional: Import pre-built styles if not using Tailwind
// import '@txnlab/use-wallet-ui-react/dist/style.css'
// Configure the wallets you want to use
const walletManager = new WalletManager({
  wallets: [
    WalletId.PERA,
    WalletId.DEFLY,
    WalletId.LUTE,
    // Add more wallets as needed
  ],
  defaultNetwork: NetworkId.TESTNET,
})
function App() {
  return (
    <WalletProvider manager={walletManager}>
      <WalletUIProvider>
        {/* Add data-wallet-ui attribute if NOT using Tailwind */}
        <div data-wallet-ui>
          <WalletButton />
        </div>
      </WalletUIProvider>
    </WalletProvider>
  )
}That's it! You now have a fully functional wallet connection system.
For complete documentation, see React Package Documentation.
- @txnlab/use-wallet-ui-react - React components for use-wallet UI
Check out our working examples:
- Tailwind CSS Example - Integration with Tailwind CSS
- CSS-only Example - Integration without Tailwind CSS
For detailed documentation, please see:
This project uses PNPM workspaces. To get started:
# Install dependencies
pnpm install
# Build all packages
pnpm build
# Lint code
pnpm lint
# Format code
pnpm formatPlease see our Contributing Guidelines for more details on how to get involved.
- Fork the repository
- Create your feature branch (git checkout -b feat/amazing-feature)
- Commit your changes following our commit message guidelines
- Push to the branch (git push origin feat/amazing-feature)
- Open a Pull Request
MIT License
