The Aave Umbrella UI is a modern web application that provides a user-friendly interface for interacting with Aave Umbrella. It allows users to view their staked tokens, claim rewards, and manage their positions across multiple blockchain networks.
- Staking: basic supply, withdraw and cooldown from/to Umbrella StakeTokens
- Claiming Rewards: Easily claim rewards across different assets
- Yield Analytics: View aggregated realtime information about net yield and rewards
The application is built using the following technologies:
- Frontend Framework: Next.js 15 with React 19
- Styling: Tailwind CSS with custom components
- State Management: Zustand for global state
- Web3 Integration: wagmi and viem for blockchain interactions
- UI Components: Custom components with Radix UI primitives
- Data Fetching: TanStack Query for efficient data fetching and caching
- Wallet Connection: RainbowKit for seamless wallet integration
- Clone the repository:
git clone https://github.com/bgd-labs/aave-umbrella-ui.git
cd aave-umbrella-ui
- Install dependencies:
npm install
- Set up environment variables:
Copy the .env.example
file to .env.local
and fill in the required RPC endpoints for each network:
cp .env.example .env.local
Edit the .env.local
file to add your RPC endpoints for each supported network.
To start the development server:
npm run dev
The application will be available at http://localhost:3000.
This project supports connecting to a Tenderly virtual forked network for development and testing purposes. For more information on how to set up and manage your Tenderly Virtual TestNet, please refer to the Tenderly Virtual TestNets Quickstart guide.
To enable this feature, you need to configure the following environment variables in your .env
file:
NEXT_PUBLIC_TENDERLY_VNETS_ENABLED
: Set this totrue
to enable the Tenderly virtual network.NEXT_PUBLIC_TENDERLY_VNET_ID
: (Optional) The chain ID of your Tenderly virtual network. Defaults to73571
.NEXT_PUBLIC_TENDERLY_VNET_RPC
: The RPC URL of your Tenderly virtual network.NEXT_PUBLIC_TENDERLY_VNET_EXPLORER
: The block explorer URL for your Tenderly virtual network.
Once these variables are set, you should be able to select the "Virtual Mainnet" (or your custom network name if you changed the ID and related configurations) from the market selector in the application. This will allow you to interact with the Aave protocol on your private, forked instance of the mainnet.
Make sure your Tenderly fork is running and accessible via the RPC URL you provided.
To create a production build:
npm run build
To start the production server:
npm run start
Deploy your own instance of the application effortlessly through Vercel by simply clicking the button below and following the guided setup process:
src/
├── abis/ # Contract ABIs
├── app/ # Next.js app directory
│ ├── components/ # Page-specific components
│ ├── stake/ # Staking functionality
│ ├── withdraw/ # Withdrawal functionality
│ └── claim-*/ # Reward claiming functionality
├── components/ # Shared UI components
├── configs/ # Configuration files
├── constants/ # Application constants
├── hooks/ # Custom React hooks
├── mutations/ # TanStack Query mutations
├── providers/ # React context providers
├── queries/ # TanStack Query queries
├── store/ # Zustand store definitions
├── types/ # TypeScript type definitions
└── utils/ # Utility functions
Copyright © 2025, Aave DAO, represented by its governance smart contracts.
Created by BGD Labs.
The default license of this repository is BUSL1.1.
IMPORTANT. The BUSL1.1 license of this repository allows for any usage of the software, if respecting the Additional Use Grant limitations, forbidding any use case damaging anyhow the Aave DAO's interests.