From 40c28097ce9c83435da1ce8a714f083caf6130ea Mon Sep 17 00:00:00 2001 From: felix Date: Tue, 9 Jan 2024 21:48:42 +0800 Subject: [PATCH] feat: add position info --- sdk/packages/instaswap-core/src/wrap.ts | 2 +- .../interface/src/components/Query.tsx | 37 ++++++++++++++++--- 2 files changed, 32 insertions(+), 7 deletions(-) diff --git a/sdk/packages/instaswap-core/src/wrap.ts b/sdk/packages/instaswap-core/src/wrap.ts index 96da834..bc57157 100644 --- a/sdk/packages/instaswap-core/src/wrap.ts +++ b/sdk/packages/instaswap-core/src/wrap.ts @@ -443,7 +443,7 @@ export class Wrap { public static getNFTTokenUri = async ( tokenId: BigNumberish, - ): Promise => { + ): Promise => { const tokenIdCairo = cairo.uint256(tokenId); return await Wrap.EkuboNFTContract.token_uri(tokenIdCairo); } diff --git a/sdk/packages/interface/src/components/Query.tsx b/sdk/packages/interface/src/components/Query.tsx index 659b2db..8453003 100644 --- a/sdk/packages/interface/src/components/Query.tsx +++ b/sdk/packages/interface/src/components/Query.tsx @@ -1,6 +1,8 @@ import React, { useEffect, useState } from 'react'; import { useQuery, gql } from '@apollo/client'; import { Wrap } from "instaswap-core"; +import { Provider, constants, cairo, shortString, num } from "starknet"; + // Define the TypeScript types for the GraphQL response type ListLiquidityResponse = { @@ -40,13 +42,32 @@ const LiquidityList: React.FC = ({ account }) => { // State to store additional token data const [tokenDetails, setTokenDetails] = useState<{ [key: number]: TokenDetails }>({}); + // State to store the fetched JSON data + const [tokenInfo, setTokenInfo] = useState<{ [key: number]: any }>({}); + + useEffect(() => { if (data) { (async () => { try { for (const liquidity of data.list_liquidity) { - const ret = await Wrap.getNFTTokenUri(liquidity.token_id); - console.log(ret.toString()); + const res = await Wrap.getNFTTokenUri(liquidity.token_id); + const longString = res.map((shortStr: bigint) => { + return shortString.decodeShortString(num.toHex(shortStr)); + }).join(""); + + // Fetch the JSON from the URL + const response = await fetch(longString); + const jsonData = await response.json(); + + // Update the tokenInfo state with the fetched data + setTokenInfo((prevTokenInfo) => ({ + ...prevTokenInfo, + [liquidity.token_id]: jsonData + })); + + // You can also update your tokenDetails state here if you need to + // setTokenDetails(...) } } catch (error) { console.error('Error fetching token details:', error); @@ -54,7 +75,6 @@ const LiquidityList: React.FC = ({ account }) => { })(); } }, [data]); - if (loading) return

Loading...

; if (error) return

An error occurred: {error.message}

; @@ -63,10 +83,15 @@ const LiquidityList: React.FC = ({ account }) => { {data && data.list_liquidity.map((liquidity, index) => (
  • Token ID: {liquidity.token_id} - {tokenDetails[liquidity.token_id] && ( + {tokenInfo[liquidity.token_id] && (
    -

    Name: {tokenDetails[liquidity.token_id].name}

    - {/* Add more details here as required */} +

    Name: {tokenInfo[liquidity.token_id].name}

    +

    Description: {tokenInfo[liquidity.token_id].description}

    + Token + {/* Map over the attributes array */} + {tokenInfo[liquidity.token_id].attributes.map((attribute, attrIndex) => ( +

    {attribute.trait_type}: {attribute.value}

    + ))}
    )}