import { Button } from "@/element/button"; import { atoms, getApi } from "@/store/global"; import { useAtomValue } from "jotai"; import { memo, useEffect, useState } from "react"; import "./updatebanner.less"; const UpdateStatusBannerComponent = ({ buttonRef }: { buttonRef: React.RefObject }) => { const appUpdateStatus = useAtomValue(atoms.updaterStatusAtom); const [updateStatusMessage, setUpdateStatusMessage] = useState(); const [dismissBannerTimeout, setDismissBannerTimeout] = useState(); useEffect(() => { let message: string; let dismissBanner = false; switch (appUpdateStatus) { case "ready": message = "Update Available"; break; case "downloading": message = "Downloading Update"; break; case "installing": message = "Installing Update"; break; case "error": message = "Updater Error: Try Checking Again"; dismissBanner = true; break; default: break; } setUpdateStatusMessage(message); // Clear any existing timeout if (dismissBannerTimeout) { clearTimeout(dismissBannerTimeout); } // If we want to dismiss the banner, set the new timeout, otherwise clear the state if (dismissBanner) { setDismissBannerTimeout( setTimeout(() => { setUpdateStatusMessage(null); setDismissBannerTimeout(null); }, 10000) ); } else { setDismissBannerTimeout(null); } }, [appUpdateStatus]); function onClick() { getApi().installAppUpdate(); } if (updateStatusMessage) { return ( ); } }; export const UpdateStatusBanner = memo(UpdateStatusBannerComponent) as typeof UpdateStatusBannerComponent;