Skip to content

RequestNetwork/invoicing-template

Repository files navigation

Request Invoicing (Invoicing Template)

A simple invoicing template for creating, paying, and viewing requests in Request Network.

Built with:

Install

npm install

Run

npm run start

Develop

cp .env.example .env.local
npm run dev

Deploy

Deploy with Vercel:

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.

Environment Variables

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 default PAYMENTS_SUBGRAPH_URLs 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

Configuration

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.

Configuration Details

Chains

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

Currencies

  • 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.

Passing Custom Currencies

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.

Wallets

The following wallets are grouped into two categories:

  • Recommended Wallets:

    • Injected Wallets
    • MetaMask
    • WalletConnect
  • Other Wallets:

    • Safe Wallet
    • Coinbase Wallet
    • Ledger Wallet
    • Trust Wallet

Transports (RPC URLs)

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>.