Skip to content

pingrishabh/thirdweb-edition-drop-embed

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Customisable Thirdweb Edition Drop Embed

Why?

I released my first NFT drop a few weeks ago using Thirdweb. I loved the experience - especially, the embed! But I wanted to make a few customisations, to make it fit well with my app and to increase the UX. Unfortuanately, I got to know that it wasn't possible.

So I decided to write my own. While I was at it, I figured that this can save a lot of time for people who don't wanna get into code for minor customisations. So I added a few more options which I think might be useful.

Features

  • Plug & Play
  • Visually similar
  • Functionally similar
  • Deployed on IPFS
  • 50+ customisation params
  • No code level involvement required

Here's a sample demo with a few customisations.

Thirdweb Embed Custom Embed

How?

  • Copy https://cloudflare-ipfs.com/ipfs/QmQ7WyTtyzxNdG6NeFg5epUMTNWuRo5VdEMUhUVU9XNqG9/
  • Go to this website and paste the copied link in the Base URL field.
  • Then tap the Add Query Pair button to add a key/value pair.
  • Choose the params that you wish to customise from the table below and assign a suitable value. Example 👇

  • Copy the generated Encoded URL. Here's an example.
  • Replace the URL in the src field of the embed code given by thirdweb, with the URL copied in the last step.
  <iframe
    src="Enter copied URL here"
    width="600px"
    height="600px"
    style="max-width:100%;"
    frameborder="0"
  ></iframe>
  • Place this embed wherever you wish (Wix, Bubble, Dorik, Carrd etc) and you're good to go! 🚀

Customisations

Param Description Default Value Required
backgroundImage to add a background image to the embed null No
backgroundRepeat to set the repeat mode of the background image no-repeat No
borderRadius to change the border radius of the container 15 No
borderColor to change the border color of the container rgba(0,0,0,0.1) No
chainId to specify the chain where your contract is deployed 1 (Ethereum) Yes
claimCountColor to change the color of the claim count text #00742E No
connectText to change the text of the connect wallet button Connect Wallet No
contract your contract id null Yes
description to override the description text description in your contract No
descriptionTextAlign to change the alignment of the description text center No
descriptionColor to change the color of the description text #272E36 No
fallbackImage to change the image that shows while NFT is loading https://i.imgur.com/Wg2ESNp.png No
footerImage to change the logo in the bottom right corner https://i.imgur.com/vsz2mTP.png No
footerUrl to change the hyperlink of the footer logo https://thirdweb.com No
imageBorderRadius to change the border radius of the image 20 No
imageHeight to change the height of the image 178 No
imageWidth to change the width of the image 178 No
inventoryTitle to override the title text inside 'Inventory' tab title in your contract No
inventoryImageHeight to change the height of the image inside 'Inventory' 318 No
inventoryImageWidth to change the width of the image inside 'Inventory' 318 No
loaderColor to change the color of the loader #1A202C No
mintAllowedPerWallet to specify how many NFTs can each wallet mint in total 1 No
mintSuccessText to change the text shown after a successful mint Minted successfully! No
mintText to change the text of the mint button Mint (Free) No
overrideInventory to change the title of the 'Inventory' tab Inventory No
overrideMint to change the title of the 'Mint' tab Mint No
primaryActiveColor to change the active state color of primary components #0369A1 No
primaryBorderRadius to change the border radius of primary components 6 No
primaryButtonMt to give margin top to the primary button 5 No
primaryColor to change the color of primary components (connect/mint button) #0EA5E9 No
primaryHoverColor to change the hover state color of primary components #0284C7 No
secondaryColor to change the color of components (text, icon etc) inside primary components #FFFFFF No
relayer to specify relayer url to enable gasless transactions null No
rpcUrl to use a custom RPC based on chainId No
showBalance to show balance of the connected wallet in popup true No
showClaimCount to show the counter that shows claim status true No
showDescription to show the description text true No
showDivider to show the divider true No
showImage to show NFT image true No
showInventory to show the inventory tab true No
showInventoryTitle to show inventory title text true No
showMintIcon to show the diamond icon on the 'Mint' button true No
showRemainingMints to show the remaining mints in the 'Mint' tab true No
showThirdwebLogo to show the Thirdweb logo in the footer true No
showTitle to show the title text title in your contract No
showWallet to show the wallet options when connected true No
tabActiveTextColor to change the text color of the tab in active state #3A3A3C No
tabInactiveTextColor to change the text color of the tab in inactive state #AEAEB2 No
title to override the title text title in your contract No
titleColor to change the color of the title text #272E36 No
tokenId to specify the token id null Yes
useMetamask to show Metamask in the connect options true No
useWalletConnect to show WalletConnect in the connect options true No
useWalletLink to show WalletLink in the connect options true No
walletlinkAppName to change app name for walletlink test No
walletlinkAppUrl to change app url for walletlink https://test.com No
walletlinkDarkMode to change dark mode for walletlink true No

Don't see your customisation in the table?

You have 2 options:

  1. Create an issue and describe the customisation that you want. I'll try my best to add it as soon as possible. If someone else has created an issue already, just upvote it. This will help me prioritise.

  2. Fork this repository. Make your customisations, push changes and deploy your own build. I suggest Fleek as I have deployed there myself. It can pick your fork from GitHub directly and deploy to IPFS with your changes. 🔥

Troubleshooting

Something not working as expected? Here are your options:

  1. Double check the values of chainId, contract and tokenId, as they are required parameters.
  2. Check for typos in parameter names and their values. Refer to the table above to know their default values.
  3. Open an issue and describe the problem. I will look into it.

Common Issues

  1. Issue: Initial load, NFT load and minting process is really slow.
    Reason: Public RPCs are used by default. Sometimes, there's a lot of traffic and hence, the response time is slow.
    Fix:

    • Go to Alchemy or Infura.
    • Register and get a dedicated RPC URL for the desired chain.
    • Pass that to the rpcUrl param to override the default RPC URL.
    • Done! 🚀
  2. Issue: Transactions are not gasless.
    Reason: A transaction relayer is required for gasless transactions. It is null by default.
    Fix:

    • Thirdweb has written a comprehensive guide on this. Obtain relayer URL using that.
    • Pass the relayer URL to the relayer param.
    • You transactions should be gasless now! 🚀

What Next?

Thirdweb team is already working on a customisable embed as this is one of the most requested features but as of now there's no ETA. So I will maintain this project for as long as I can (hard to keep up with Thirdweb as they ship really fast! 😬) until they release. Hopefully this will fulfil majority of the customisation needs in the meantime. If this project helped you in anyway, consider starring it and sharing it with anyone who might need it. Adios! 👋

About

Customisable Thirdweb Edition Drop Embed

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published