NFT marketplace bootstrap on Ethererum

This repo provides you a NFT marketplace bootstrap on Ethereum.

The technologies used in this project are React, Next.js, Tailwind CSS, HardHat, Solidity, and Ethers.js.

The flow diagram of the project

diagram

Getting Started

First, clone the repo and install the dependencies:

git clone https://github.com/reddio-com/ethereum-nft-marketplace.git
cd ethereum-nft-marketplace
yarn

Next, run a local Ethereum node:

npx hardhat node

Deploy the smart contract to the local node:

npx hardhat run scripts/deploy.js --network localhost

Running the above command should print out the addresses where the contract was deployed. Update .evn.local with those values:

NEXT_PUBLIC_NFTMARKET_ADDRESS="your-nft-market-address"
NEXT_PUBLIC_NFT_ADDRESS="your-nft-address"

Create an account at Infura, create a project and enable Dedicated Gateways, update the values below in '.evn.local' accordingly.

NEXT_PUBLIC_IPFS_PROJECT_ID="your-infura-project-id"
NEXT_PUBLIC_API_KEY_SECRET="your-infura-project-secret"

Next, run the development server:

yarn dev

Notes: Make sure you choose the right network on your Metamask

Deploy production to Vercel

  1. Fork this repo
  2. Add Sepolia network to your hardhat.config.js file with the following information,
    sepolia: {
      url: `https://sepolia.infura.io/v3/${INFURA_API_KEY}`,
      accounts: [SEPOLIA_PRIVATE_KEY]
    }
  1. Log in to Vercel
  2. Import from your repo
  3. For 'Build and Output Settings', overide 'Build Command' with
yarn next build
  1. Set environment variables under your project, include NEXT_PUBLIC_IPFS_PROJECT_ID, NEXT_PUBLIC_API_KEY_SECRET and NEXT_PUBLIC_SEPOLIA_API_KEY_SECRET
  2. Deploy