- Week 3 of Alchemy's Road To Web3 Challenge link
- Made an NFT with On-Chain & Updatable Metadata, SVG Image, and Base64 Encoding
- Minting Inputs:
- Name of your flower (ex: Your name...)
- Background Color (CSS Hex Input, ex: "#8ef6e4")
- Font Color of your flower's name (CSS Hex Input, ex: "#9896f1")
- Seed Color (CSS Hex Input, ex: "#9896f1")
Example Mint Call:
let txn = await contract.mint("Dayana", "#8ef6e4", "#9896f1", "#9896f1");
- Watering Inputs
- Provide your flower's token ID (ex: 1)
- Provide color for the new petal (CSS Hex Input, ex: "#f5c7f7")
- You can only water your flower 8 times for it to complete.
Example Water Call:
txn = await contract.water(1, "#f5c7f7");
- First, Fork & Clone Repository
yarn compile
yarn deploy
yarn test
yarn color
-
To test how your svg image is looking like without deploying to testnet & inspecting opensea eachtime (Been there, done that) I recommend:
- Use this editor to paste your image's Base64 in the src of the img tag: https://www.w3docs.com/tools/code-editor/10848
- How do you get the base64 image?
- console.log() it in your solidity code
- How do you console.log() in Solidity?
- Add
import "hardhat/console.sol";
to your file - Make sure you're running your script on
--network hardhat
- Add
-
Example of pasting the base64 img into the editor above:
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<div>
<img src=""/>
</div>
</body>
</html>
Solidity - console.log(base64img):
function generateFlower(uint256 id) internal returns(string memory){
FlowerStats memory data = idToFlowerStats[id];
bytes memory svg = abi.encodePacked(
'<svg viewBox="13 -4 461 455" xmlns="http://www.w3.org/2000/svg" xmlns:bx="https://www.boxy-svg.com/bx">',
string(abi.encodePacked("<rect width='100%' height='100%' fill='", data.background,"'/>")),
getPetals(id),
string(abi.encodePacked("<ellipse style='fill:", data.seed,";' cx='242.767' cy='223.713' rx='26.285' ry='25.904'/>")),
string(abi.encodePacked("<text x='50%' y='95%' fill='", data.font, "' dominant-baseline='middle' text-anchor='middle'>")),
data.name,
'</text>'
'</svg>'
);
string memory base64img =
string(abi.encodePacked(
"data:image/svg+xml;base64,",
Base64.encode(svg))
);
if (data.level == 8) {
console.log(base64img);
}
return base64img;
}
- Verified Contract
- View The Genesis NFT on OpenSea
- Mint:
- After Mint:
- Water:
- After Watering 3 Times:
- Transaction Fees: