Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: NFTCard Displayed images that should not be displayed after swit… #549

Merged
merged 6 commits into from
Feb 18, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .changeset/pink-planes-wait.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@ant-design/web3': patch
---

fix: NFTCard Displayed images that should not be displayed after switch chain
18 changes: 16 additions & 2 deletions packages/web3/src/hooks/useNFT.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { useEffect, useState } from 'react';
import type { NFTMetadata, Web3ConfigProviderProps } from '@ant-design/web3-common';
import type { Chain, NFTMetadata, Web3ConfigProviderProps } from '@ant-design/web3-common';

import useProvider from './useProvider';

Expand All @@ -11,10 +11,21 @@ export default function useNFT(
const [metadata, setMetadata] = useState<NFTMetadata>({});
const [loading, setLoading] = useState<boolean>(false);
const [error, setError] = useState<Error>();
const { getNFTMetadata: getNFTMetadataFunc } = useProvider({
const {
getNFTMetadata: getNFTMetadataFunc,
availableChains,
chain,
} = useProvider({
getNFTMetadata,
});

const findChainIndex = (availableChains: Chain[], chain: Chain) => {
const index = availableChains?.findIndex((chainItem) => {
return chainItem?.id === chain?.id;
});
return index + 1;
};

useEffect(() => {
if (!address || !tokenId) {
return;
Expand All @@ -26,6 +37,9 @@ export default function useNFT(
tokenId: BigInt(tokenId),
})
.then((data) => {
if (findChainIndex(availableChains as Chain[], chain as Chain) > 1) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

感觉这样实现不是很好,应该这样搞:

  • 链切换的时候 chain 发生改变,这个时候重新调用 getNFTMetadata 请求新的数据
  • 调用 getNFTMetadata 失败后显示 fallback image 就行

这样从逻辑上更符合实际情况。

Copy link
Contributor Author

@shanchuan1 shanchuan1 Feb 3, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

但是getNFTMetadata 的入参address与tokenId是固定的如何控制使getNFTMetadata 失败呢

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

没失败的情况就正常显示就好,一般切换链的情况下 address 如果不修改的话就请求不到数据了,就会失败。

不是我们要控制 getNFTMetadata 去失败,是 getNFTMetadata 失败的情况下显示 fallback 的图片就行。

你随便写一个错误的 address 应该就能模拟这种情况。

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done

data.image = '';
}
setMetadata(data);
})
.catch((err) => {
Expand Down
42 changes: 24 additions & 18 deletions packages/web3/src/nft-card/NFTCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -66,23 +66,24 @@ const CardSkeleton: React.FC<PropsWithChildren<{ loading: boolean; prefixCls: st
return <>{children}</>;
};

const NFTCard: React.FC<NFTCardProps> = ({
style,
antdImageProps,
className,
type = 'default',
address,
tokenId,
price,
like: likeConfig,
showAction,
actionText,
footer,
onActionClick,
getNFTMetadata,
locale,
...metadataProps
}) => {
const NFTCard: React.FC<NFTCardProps> = (props) => {
const {
style,
antdImageProps,
className,
type = 'default',
address,
tokenId,
price,
like: likeConfig,
showAction,
actionText,
footer,
onActionClick,
getNFTMetadata,
locale,
...metadataProps
} = props;
const { liked, totalLikes = 0, onLikeChange } = likeConfig || {};
const { token } = useToken();
const { metadata, loading } = useNFT(address, parseNumberToBigint(tokenId), getNFTMetadata);
Expand Down Expand Up @@ -160,7 +161,12 @@ const NFTCard: React.FC<NFTCardProps> = ({
<div className={`${prefixCls}-serial-number`}>{`#${tokenId}`}</div>
) : null}
{typeof image === 'string' ? (
<Image width="100%" src={getWeb3AssetUrl(image)} {...antdImageProps} />
<Image
width="100%"
src={getWeb3AssetUrl(image)}
{...antdImageProps}
fallback=""
/>
) : (
image
)}
Expand Down
Loading