React Firebase Hooks provides convenience listeners for files stored within
Firebase Cloud Storage. The hooks wrap around the getDownloadURL(...)
method.
In addition to returning the download URL, the hooks provide an error
and loading
property
to give a complete lifecycle for loading from Cloud Storage.
All hooks can be imported from react-firebase-hooks/storage
, e.g.
import { useDownloadURL } from 'react-firebase-hooks/storage';
List of Cloud Storage hooks:
const [downloadUrl, loading, error] = useDownloadURL(reference);
Retrieve the download URL for a storage reference.
The useDownloadURL
hook takes the following parameters:
reference
: (optional)storage.Reference
that you would like the download URL for
Returns:
downloadUrl
: Astring
download URL, orundefined
if no storage reference is suppliedloading
: Aboolean
to indicate whether the the download URL is still being loadederror
: Anystorage.StorageError
returned by Firebase when trying to load the user, orundefined
if there is no error
import { ref, getStorage } from 'firebase/storage';
import { useDownloadURL } from 'react-firebase-hooks/storage';
const storage = getStorage(firebaseApp);
const DownloadURL = () => {
const [value, loading, error] = useDownloadURL(
ref(storage, 'path/to/file')
);
return (
<div>
<p>
{error && <strong>Error: {error}</strong>}
{loading && <span>Download URL: Loading...</span>}
{!loading && value && (
<React.Fragment>
<span>Download URL: {value}</span>
</React.Fragment>
)}
</p>
</div>
);
};