A simple invoicing template for creating, paying, and viewing requests in Request Network.
Built with:
npm install
npm run start
cp .env.example .env.local
npm run dev
Deploy with Vercel:
We deploy to an EasyPanel server using Github Actions and Heroku Buildpacks. You could easily deploy to Vercel, Netlify, or any other platform.
- deploy-to-staging.yml - Deploy to Staging on push to
main
branch. - deploy-to-production.yml - Deploy to Production on release published in Github.
Before deploying, ensure you have created a .env
or .env.local
file in the root of your project. Below is a list of available environment variables. You can also take a look at the .env.example file for reference.
⚠️ WARNING: The defaultPAYMENTS_SUBGRAPH_URL
s are rate-limited and can be replaced with your own subgraph URLs.
Variable Name | Description | Required |
---|---|---|
NEXT_PUBLIC_WALLET_CONNECT_PROJECT_ID | Your Wallet Connect Project ID | ✅ |
NEXT_PUBLIC_RPC_URL_ARBITRUM_ONE | RPC URL for Arbitrum One | ❌ |
NEXT_PUBLIC_RPC_URL_AVALANCHE | RPC URL for Avalanche | ❌ |
NEXT_PUBLIC_RPC_URL_BASE | RPC URL for Base | ❌ |
NEXT_PUBLIC_RPC_URL_BSC | RPC URL for Binance Smart Chain | ❌ |
NEXT_PUBLIC_RPC_URL_CELO | RPC URL for Celo | ❌ |
NEXT_PUBLIC_RPC_URL_CORE | RPC URL for Core | ❌ |
NEXT_PUBLIC_RPC_URL_FANTOM | RPC URL for Fantom | ❌ |
NEXT_PUBLIC_RPC_URL_FUSE | RPC URL for Fuse | ❌ |
NEXT_PUBLIC_RPC_URL_ETHEREUM | RPC URL for Ethereum | ❌ |
NEXT_PUBLIC_RPC_URL_POLYGON | RPC URL for Polygon | ❌ |
NEXT_PUBLIC_RPC_URL_MOONBEAM | RPC URL for Moonbeam | ❌ |
NEXT_PUBLIC_RPC_URL_OPTIMISM | RPC URL for Optimism | ❌ |
NEXT_PUBLIC_RPC_URL_SEPOLIA | RPC URL for Sepolia | ❌ |
NEXT_PUBLIC_RPC_URL_XDAI | RPC URL for Gnosis | ❌ |
NEXT_PUBLIC_RPC_URL_ZKSYNCERA | RPC URL for ZkSyncEra | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_ARBITRUM_ONE | Subgraph URL for Arbitrum One | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_AVALANCHE | Subgraph URL for Avalanche | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_BASE | Subgraph URL for Base | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_BSC | Subgraph URL for Binance Smart Chain | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_CELO | Subgraph URL for Celo | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_CORE | Subgraph URL for Core | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_FANTOM | Subgraph URL for Fantom | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_FUSE | Subgraph URL for Fuse | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_MAINNET | Subgraph URL for Mainnet | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_MATIC | Subgraph URL for Matic | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_MOONBEAM | Subgraph URL for Moonbeam | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_OPTIMISM | Subgraph URL for Optimism | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_SEPOLIA | Subgraph URL for Sepolia | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_XDAI | Subgraph URL for Gnosis | ❌ |
NEXT_PUBLIC_PAYMENTS_SUBGRAPH_URL_ZKSYNCERA | Subgraph URL for ZkSyncEra | ❌ |
NEXT_PUBLIC_GTM_ID | Google Tag Manager ID | ❌ |
NEXT_PUBLIC_LIT_PROTOCOL_CHAIN | Lit Protocol Chain | ❌ |
NEXT_PUBLIC_LIT_PROTOCOL_NETWORK | Lit Protocol Network | ❌ |
NEXT_PUBLIC_REQUEST_NODE | Request Node URL | ❌ |
This configuration file (wagmiConfig.ts
) is used to set up the wallet connection functionality for the Request Invoicing platform, leveraging wagmi
and RainbowKit
.
It supports multiple blockchain networks and a wide variety of wallet providers. The configuration is structured to allow easy integration of wallet connections in a React or Next.js app.
The following chains are supported in the current setup:
- Binance Smart Chain (BSC)
- Celo
- Base
- Fuse
- zkSync
- Fantom
- CoreDAO
- Polygon
- Ethereum Mainnet
- Sepolia
- Arbitrum
- Moonbeam
- Optimism
- Avalanche
- Gnosis
- The currencies prop is optional.
- If provided, it overrides the default list of supported currencies.
- To retain the default list of currencies, simply omit the currencies prop.
To override the default currencies, provide a custom list in the correct format:
export const currencies: CurrencyTypes.CurrencyInput[] = [
{
symbol: "FAU",
address: "0x370DE27fdb7D1Ff1e1BaA7D11c5820a324Cf623C",
network: "sepolia",
decimals: 18,
type: RequestLogicTypes.CURRENCY.ERC20,
},
{
symbol: "ETH",
network: "sepolia",
decimals: 18,
type: RequestLogicTypes.CURRENCY.ETH,
},
];
When added, this will replace the default currencies list. To retain the defaults, do not include the currencies
prop.
The following wallets are grouped into two categories:
-
Recommended Wallets:
- Injected Wallets
- MetaMask
- WalletConnect
-
Other Wallets:
- Safe Wallet
- Coinbase Wallet
- Ledger Wallet
- Trust Wallet
Each chain is assigned an RPC URL, either from environment variables or using a default public RPC. You can configure these in your .env
file using variables like NEXT_PUBLIC_RPC_URL_<CHAIN_NAME>
.