This is a full stack project with both frontend and backend connected.
Helping you to see how things are put together and not just writing solidity, or just interacting with a contract, etc but actually building the whole thing and testing it end to end.
Another interesting thing about this project is that we will be working with an Ethereum Scalability Solution like Polygon which helps us achieve things with cheap transaction fees.
We will be working with:
- Hardhat: for the solidity development environmrnt
- Ether: for client library to interact with chain
- IPFS: for files uploads and files downloads
- Web3 module: to enable us choose a wallet to work with...(Metamask etc)
- Chai: for testing
- OpenZeppelin/Contract: to inherit the ERC721 contract functionality.
- NextJS: for our frontend app.
- Tailwing: to simplify our styling.
- Axios: for fetching data from library.
follow the steps bellow:
To run this project locally, follow these steps.
- Clone the project locally, change into the directory, and install the dependencies:
git clone https://github.com/johnchristotle/NFT-Marketplace-Project.git
cd NFT-Marketplace-Project
# install using NPM or Yarn
npm install
# or
yarn
- look at the .gitignore file and find 3 key ignored files: provide yours to enable you run this app e.g
-
a. .infuraId - get an ID from infura and place it here
-
b. .secret - copy the private key of the wallet you intend to use and place it here
-
c. config.js - when you run
npx hardhat run scripts/deploy.js --network localhost/mumbai/mainnet
the contract address will automatically appear there. -
d. NOTE: should the network fails when you using
(`https://polygon-mumbai.infura.io/v3/${infuraId}`)
at your index.js file, please copy and paste the full network including your ID and it will pass through.
- Start the local Hardhat node
npx hardhat node
- With the network running, deploy the contracts to the local network in a separate terminal window
npx hardhat run scripts/deploy.js --network localhost
- Start the app
npm run dev
- Start the local Hardhat node
npx hardhat node
- With the network running, deploy the contracts to the local network in a separate terminal window
npx hardhat run scripts/deploy.js --network mumbai
- Start the app
npm run dev
- Start the local Hardhat node
npx hardhat node
- With the network running, deploy the contracts to the local network in a separate terminal window
npx hardhat run scripts/deploy.js --network mainnet
- Start the app
npm run dev