Hi I am following your video guide here: https://www.youtube.com/watch?v=WZWCzsB1xUE and currently stuck on step where you enable TokenId function and display tokens of certain collections under âexploreâ menu tab ( min 14-19 in video) . I have perfromed all the steps but still unable to load TokenIds. When visiting my page getting error in console :
chain Object
NFTBalance.jsx:64 NFTBalances null
NFTBalance.jsx:64 NFTBalances Object
NFTBalance.jsx:64 NFTBalances Object
75.png:1 Failed to load resource: the server responded with a status of 504 ()
NFTTokenIds.jsx:65 NFTTokenIds undefined
useNFTTokenIds.js:18 0x1
Blockquote
import React, { useState } from âreactâ;
import { useMoralis } from âreact-moralisâ;
import { Card, Image, Tooltip, Modal, Input, Skeleton } from âantdâ;
import { FileSearchOutlined, SendOutlined, ShoppingCartOutlined } from â@ant-design/iconsâ;
import { getExplorer } from âhelpers/networksâ;
import AddressInput from â./AddressInputâ;
import { useNFTTokenIds } from âhooks/useNFTTokenIdsâ;
const { Meta } = Card;
const styles = {
NFTs: {
display: "flex",
flexWrap: "wrap",
WebkitBoxPack: "start",
justifyContent: "flex-start",
margin: "0 auto",
maxWidth: "1000px",
width: "100%",
gap: "10px",
},
};
function NFTTokenIds() {
const { data: NFTTokenIds } = useNFTTokenIds();
const { Moralis, chainId } = useMoralis();
const [visible, setVisibility] = useState(false);
const [receiverToSend, setReceiver] = useState(null);
const [amountToSend, setAmount] = useState(null);
const [nftToSend, setNftToSend] = useState(null);
const [isPending, setIsPending] = useState(false);
async function transfer(nft, amount, receiver) {
const options = {
type: nft.contract_type,
tokenId: nft.token_id,
receiver: receiver,
contractAddress: nft.token_address,
};
if (options.type === "erc1155") {
options.amount = amount;
}
setIsPending(true);
await Moralis.transfer(options)
.then((tx) => {
console.log(tx);
setIsPending(false);
})
.catch((e) => {
alert(e.message);
setIsPending(false);
});
}
const handleTransferClick = (nft) => {
setNftToSend(nft);
setVisibility(true);
};
const handleChange = (e) => {
setAmount(e.target.value);
};
console.log(âNFTTokenIdsâ, NFTTokenIds);
return (
<>
<div style={styles.NFTs}>
<Skeleton loading={!NFTTokenIds?.result}>
{NFTTokenIds?.result &&
NFTTokenIds.result.map((nft, index) => (
<Card
hoverable
actions={[
<Tooltip title="Etherscan">
<FileSearchOutlined
onClick={() => window.open(`${getExplorer(chainId)}address/${nft.token_address}`, "_blank")}
/>
</Tooltip>,
<Tooltip title="List this NFT">
<ShoppingCartOutlined onClick={() => alert("Add Marketplace smartcontract integrations")} />
</Tooltip>,
]}
style={{ width: 240, 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.token_address} />
</Card>
))}
</Skeleton>
</div>
<Modal
title={`Transfer ${nftToSend?.name || "NFT"}`}
visible={visible}
onCancel={() => setVisibility(false)}
onOk={() => transfer(nftToSend, amountToSend, receiverToSend)}
confirmLoading={isPending}
okText="Send"
>
<AddressInput autoFocus placeholder="Receiver" onChange={setReceiver} />
{nftToSend && nftToSend.contract_type === "erc1155" && (
<Input placeholder="amount to send" onChange={(e) => handleChange(e)} />
)}
</Modal>
</>
);
}
export default NFTTokenIds;
Blockquote