You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-desktop/ts/hooks/useEncryptedFileFetch.ts

31 lines
749 B
TypeScript

import { useEffect, useRef, useState } from 'react';
import { getDecryptedMediaUrl } from '../session/crypto/DecryptedAttachmentsManager';
export const useEncryptedFileFetch = (url: string, contentType: string) => {
// tslint:disable-next-line: no-bitwise
const [urlToLoad, setUrlToLoad] = useState('');
const [loading, setLoading] = useState(true);
const mountedRef = useRef(true);
async function fetchUrl() {
const decryptedUrl = await getDecryptedMediaUrl(url, contentType);
if (mountedRef.current) {
setUrlToLoad(decryptedUrl);
setLoading(false);
}
}
useEffect(() => {
void fetchUrl();
return () => {
mountedRef.current = false;
};
}, [url]);
return { urlToLoad, loading };
};