mirror of
https://github.com/swissmakers/swiss-datashare.git
synced 2026-04-11 10:27:01 +02:00
58 lines
1.5 KiB
TypeScript
58 lines
1.5 KiB
TypeScript
import { Button } from "@mantine/core";
|
|
import { useEffect, useState } from "react";
|
|
import { FormattedMessage } from "react-intl";
|
|
import useTranslate from "../../hooks/useTranslate.hook";
|
|
import shareService from "../../services/share.service";
|
|
import toast from "../../utils/toast.util";
|
|
|
|
const DownloadAllButton = ({ shareId }: { shareId: string }) => {
|
|
const [isZipReady, setIsZipReady] = useState(false);
|
|
const [isLoading, setIsLoading] = useState(false);
|
|
const t = useTranslate();
|
|
|
|
const downloadAll = async () => {
|
|
setIsLoading(true);
|
|
await shareService
|
|
.downloadFile(shareId, "zip")
|
|
.then(() => setIsLoading(false));
|
|
};
|
|
|
|
useEffect(() => {
|
|
shareService
|
|
.getMetaData(shareId)
|
|
.then((share) => setIsZipReady(share.isZipReady))
|
|
.catch(() => {});
|
|
|
|
const timer = setInterval(() => {
|
|
shareService
|
|
.getMetaData(shareId)
|
|
.then((share) => {
|
|
setIsZipReady(share.isZipReady);
|
|
if (share.isZipReady) clearInterval(timer);
|
|
})
|
|
.catch(() => clearInterval(timer));
|
|
}, 5000);
|
|
return () => {
|
|
clearInterval(timer);
|
|
};
|
|
}, []);
|
|
|
|
return (
|
|
<Button
|
|
variant="outline"
|
|
loading={isLoading}
|
|
onClick={() => {
|
|
if (!isZipReady) {
|
|
toast.error(t("share.notify.download-all-preparing"));
|
|
} else {
|
|
downloadAll();
|
|
}
|
|
}}
|
|
>
|
|
<FormattedMessage id="share.button.download-all" />
|
|
</Button>
|
|
);
|
|
};
|
|
|
|
export default DownloadAllButton;
|