From 1751a5ea0bf0e7f7db3990330ddae5e0be16b536 Mon Sep 17 00:00:00 2001 From: 0xExp-po Date: Fri, 22 Nov 2024 09:26:21 +0900 Subject: [PATCH] fix: fetch image from ipfs error --- dapp/src/components/page/proposal/ProposalPage.tsx | 1 - dapp/src/service/ProposalService.ts | 11 +++++++++-- dapp/src/utils/utils.ts | 4 ++++ 3 files changed, 13 insertions(+), 3 deletions(-) diff --git a/dapp/src/components/page/proposal/ProposalPage.tsx b/dapp/src/components/page/proposal/ProposalPage.tsx index 0a19651..b88d318 100644 --- a/dapp/src/components/page/proposal/ProposalPage.tsx +++ b/dapp/src/components/page/proposal/ProposalPage.tsx @@ -15,7 +15,6 @@ import { } from "@service/ProposalService"; import type { ProposalOutcome, - Proposal, ProposalView, ProposalViewStatus, VoteType, diff --git a/dapp/src/service/ProposalService.ts b/dapp/src/service/ProposalService.ts index 4c96a9d..023ca79 100644 --- a/dapp/src/service/ProposalService.ts +++ b/dapp/src/service/ProposalService.ts @@ -1,15 +1,22 @@ import axios from "axios"; -import { getOutcomeLinkFromIpfs, getProposalLinkFromIpfs } from "utils/utils"; +import { + getIpfsBasicLink, + getOutcomeLinkFromIpfs, + getProposalLinkFromIpfs, +} from "utils/utils"; async function fetchProposalFromIPFS(url: string) { try { const proposalUrl = getProposalLinkFromIpfs(url); const response = await axios.get(proposalUrl); let content = response.data; + + const basicUrl = getIpfsBasicLink(url); content = content.replace( /!\[([^\]]*)\]\(([^http][^)]+)\)/g, - `![$1](${url}$2)`, + `![$1](${basicUrl}$2)`, ); + return content; } catch (error) { console.error("Error fetching the IPFS file:", error); diff --git a/dapp/src/utils/utils.ts b/dapp/src/utils/utils.ts index a72931b..aa0bc28 100644 --- a/dapp/src/utils/utils.ts +++ b/dapp/src/utils/utils.ts @@ -64,6 +64,10 @@ export const modifySlashInXdr = (xdr: string) => { return xdr.replaceAll("/", "//"); }; +export const getIpfsBasicLink = (ipfsLink: string) => { + return `https://${ipfsLink}.ipfs.w3s.link/`; +}; + export const getProposalLinkFromIpfs = (ipfsLink: string) => { return `https://${ipfsLink}.ipfs.w3s.link/proposal.md`; };