diff --git a/src/api/item.ts b/src/api/item.ts index 9f614561..c0d20a1b 100644 --- a/src/api/item.ts +++ b/src/api/item.ts @@ -248,6 +248,25 @@ export const getFileContent = async ( }), ); +export const getFileContentWithUrl = async ( + { id, replyUrl }: { id: UUID, replyUrl: boolean }, + { API_HOST }: QueryClientConfig, +) => + fallbackToPublic( + () => + axios.get(`${API_HOST}/${buildDownloadFilesRoute(id)}`, { + params: { + replyUrl + }, + }).then(({ data }) => data), + () => + axios.get(`${API_HOST}/${buildPublicDownloadFilesRoute(id)}`, { + params: { + replyUrl + }, + }), + ); + export const getRecycledItems = async ({ API_HOST }: QueryClientConfig) => verifyAuthentication(() => axios diff --git a/src/hooks/item.ts b/src/hooks/item.ts index 47335535..21c7ca6e 100644 --- a/src/hooks/item.ts +++ b/src/hooks/item.ts @@ -332,7 +332,7 @@ export default ( useFileContent: ( id?: UUID, - { enabled = true }: { enabled?: boolean } = {}, + { enabled = true, replyUrl }: { enabled?: boolean, replyUrl?: boolean } = {}, ) => useQuery({ queryKey: buildFileContentKey(id), @@ -340,6 +340,9 @@ export default ( if (!id) { throw new UndefinedArgument(); } + if (replyUrl) { + return Api.getFileContentWithUrl({ id, replyUrl }, queryConfig).then((data) => convertJs(data)); + }; return Api.getFileContent({ id }, queryConfig).then((data) => data); }, enabled: Boolean(id) && enabled,