diff --git a/web/src/components/button/DownloadVideoButton.tsx b/web/src/components/button/DownloadVideoButton.tsx index ffb50098e2..8a8e541faf 100644 --- a/web/src/components/button/DownloadVideoButton.tsx +++ b/web/src/components/button/DownloadVideoButton.tsx @@ -18,57 +18,47 @@ export function DownloadVideoButton({ }: DownloadVideoButtonProps) { const [isDownloading, setIsDownloading] = useState(false); - const handleDownload = async () => { + const formattedDate = formatUnixTimestampToDateTime(startTime, { + strftime_fmt: "%D-%T", + time_style: "medium", + date_style: "medium", + }); + const filename = `${camera}_${formattedDate}.mp4`; + + const handleDownloadStart = () => { setIsDownloading(true); - const formattedDate = formatUnixTimestampToDateTime(startTime, { - strftime_fmt: "%D-%T", - time_style: "medium", - date_style: "medium", + toast.success("Your review item video has started downloading.", { + position: "top-center", }); - const filename = `${camera}_${formattedDate}.mp4`; + }; - try { - const response = await fetch(source); - const blob = await response.blob(); - const url = window.URL.createObjectURL(blob); - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = filename; - document.body.appendChild(a); - a.click(); - window.URL.revokeObjectURL(url); - toast.success( - "Your review item video has been downloaded successfully.", - { - position: "top-center", - }, - ); - } catch (error) { - toast.error( - "There was an error downloading the review item video. Please try again.", - { - position: "top-center", - }, - ); - } finally { - setIsDownloading(false); - } + const handleDownloadEnd = () => { + setIsDownloading(false); + toast.success("Download completed successfully.", { + position: "top-center", + }); }; return (
);