Skip to main content

Build A Web3 App

Use the CLI to create a web application with the React and JavaScript SDKs pre-configured:

npx thirdweb create app --evm

This will kick off an interactive series of questions to help you get started:

  • Give your project a name
  • Select Create React App as the framework
  • Select JavaScript or TypeScript as the language

Exploring The Project

The create command generates a new directory with your project name. Open this directory in your text editor.

Inside the index.js file, you'll find the ThirdwebProvider wrapping the entire application.

This wrapper allows us to use all of the React SDK's hooks and UI Components throughout the application, as well as configure an activeChain; which declares which chain our smart contracts are deployed to.

Since we deployed our smart contract to the Goerli network, we'll set the activeChain to "goerli":

Interact With Contracts

To connect to your smart contract in the application, provide your smart contract address (which you can get from the dashboard) to the useContract hook like so:

src/App.js
import { useContract } from "@thirdweb-dev/react";

export default function Home() {
const { contract } = useContract("<CONTRACT_ADDRESS>");

// Now you can use the contract in the rest of the component!
}

You can now call any function on your smart contract with useContractRead and useContractWrite hooks. Each extension you implemented in your smart contract also unlocks a new functionality for you to use in the SDK.

Let's look at how this works by reading our smart contract's NFTs and then minting new ones.

Reading Data

The NFT Collection contract we built earlier implements the ERC721 and ERC721Supply extensions.

By doing so, we can use the "View All" functionality in our application! In the React SDK, that is available through the useNFTs hook, which we can use by providing the contract object to the hook like so:

src/App.js
import { useContract, useNFTs } from "@thirdweb-dev/react";

export default function Home() {
const { contract } = useContract("<CONTRACT_ADDRESS>");
const { data: nfts, isLoading: isReadingNfts } = useNFTs(contract);
}

Displaying Data

Use the NFT Media Renderer component to render each of the NFTs loaded from the useNFTs hook, making use of the loading state in a conditional statement:

src/App.js
import { useContract, useNFTs, ThirdwebNftMedia } from "@thirdweb-dev/react";

export default function Home() {
const { contract } = useContract("<CONTRACT_ADDRESS>");
const { data: nfts, isLoading: isReadingNfts } = useNFTs(contract);

return (
<>
{isReadingNfts ? (
<p>Loading...</p>
) : (
<div>
{nfts?.map((nft) => (
<ThirdwebNftMedia metadata={nft.metadata} key={nft.metadata.id} />
))}
</div>
)}
</>
);
}

Writing Transactions

Since our smart contract implements the ERC721Mintable extension, the mint feature is available to us in the SDK.

Use the Web3Button component to perform a mint transaction; which ensures the user has their wallet connected and is on the right network before calling the function:

src/App.js
// Place this import at the top of the file
import { Web3Button } from "@thirdweb-dev/react";

// ...

// Place this beneath your existing NFT display logic:
<Web3Button
contractAddress={"<CONTRACT_ADDRESS>"}
action={(contract) =>
contract.erc721.mint({
name: "Hello world!",
// Place any URL or file here!
image: "<your-image-url-here>",
})
}
>
Mint NFT
</Web3Button>;

Deploy Your App

To host your application on IPFS and share it with the world, run the following command:

yarn deploy

That's it! 🥳 This command uses Storage to:

  • Create a production build of your application
  • Upload the build to IPFS
  • Generate a URL where your app is permanently hosted.
Share your app with us on Twitter!

What's Next?

Congratulations on making it this far! 🎉

Now you've learned the basics, take your skills to the next level by building on top of our templates.