I only learned React 3 days ago. It’s very alien to me cos I come from a beginner’s PHP background.
I’m given a GitHub code that looks like below called NFTBalance.jsx
which displays the JSON. It calls useNFTBalance.js
which parses the JSON.
I wish to display the attributes each in a meta element like <Meta title={nft.name} description={nft.contract_type} />
I’ve been reading about this and more but I still failed to efficiently render the JSON attributes
objects array.
I could do like NFT.type = data.attributes[0].value;
but I find that’s very inefficient because I need to name each object and the attributes’ objects will change.
Could we use map function or something?
NFTBalance.jsx
...
)}
{NFTBalance &&
NFTBalance.map((nft, index) => (
<Card
hoverable
actions={[
<Tooltip title="View On Blockexplorer">
<FileSearchOutlined
onClick={() =>
window.open(
`${getExplorer(chainId)}address/${nft.token_address}`,
"_blank"
)
}
/>
</Tooltip>,
<Tooltip title="List NFT for sale">
<ShoppingCartOutlined onClick={() => handleSellClick(nft)} />
</Tooltip>,
]}
style={{ width: 300, border: "2px solid #e7eaf3" }}
cover={
<Image
preview={false}
src={nft?.image || "error"}
fallback=""
alt=""
style={{ height: "300px" }}
/>
}
key={index}
>
<Meta title={nft.name} description={nft.contract_type} />
...
...
export const useNFTBalance = (options) => {
const { account } = useMoralisWeb3Api();
const { chainId } = useMoralisDapp();
const { resolveLink } = useIPFS();
const [NFTBalance, setNFTBalance] = useState([]);
const {
fetch: getNFTBalance,
data,
error,
isLoading,
} = useMoralisWeb3ApiCall(account.getNFTs, { chain: chainId, ...options });
const [fetchSuccess, setFetchSuccess] = useState(true);
useEffect(() => {
async function fetchData() {
if (data?.result) {
const NFTs = data.result;
setFetchSuccess(true);
for (let NFT of NFTs) {
if (NFT?.metadata) {
NFT.metadata = JSON.parse(NFT.metadata);
NFT.image = resolveLink(NFT.metadata?.image);
} else if (NFT?.token_uri) {
try {
await fetch(NFT.token_uri)
.then((response) => response.json())
.then((data) => {
NFT.image = resolveLink(data.image);
{/*I think this is how I suppose to grab the JSON attributes object*/}
NFT.itemName = data.name;
NFT.description = data.description;
NFT.type = data.attributes;
});
} catch (error) {
setFetchSuccess(false);
}
}
}
setNFTBalance(NFTs);
}
}
fetchData();
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [data]);
return { getNFTBalance, NFTBalance, fetchSuccess, error, isLoading };
};
The JSON file is like this..
{
"description": "Windsor my cat is found dead. An investigation is being carried out. My neighbor? A car? He goes up to heaven and we are saddened. By Guive Khosravi",
"name": "The Incredible Windsor",
"attributes": [
{
"trait_type": "Type",
"value": "Acrylic, Spray paint on Linen"
},
{
"trait_type": "Year",
"value": "2020"
},
{
"trait_type": "Style",
"value": "Contemporary"
},
{
"trait_type": "Location",
"value": "Paris, France"
}
]
}