2024-09-20 22:29:37 +02:00
|
|
|
import { Button } from "@/element/button";
|
|
|
|
import { atoms, getApi } from "@/store/global";
|
|
|
|
import { useAtomValue } from "jotai";
|
|
|
|
import { memo, useEffect, useState } from "react";
|
2024-11-22 01:05:04 +01:00
|
|
|
import "./updatebanner.scss";
|
2024-09-20 22:29:37 +02:00
|
|
|
|
|
|
|
const UpdateStatusBannerComponent = ({ buttonRef }: { buttonRef: React.RefObject<HTMLButtonElement> }) => {
|
|
|
|
const appUpdateStatus = useAtomValue(atoms.updaterStatusAtom);
|
2024-10-14 23:57:12 +02:00
|
|
|
let [updateStatusMessage, setUpdateStatusMessage] = useState<string>();
|
2024-09-20 22:29:37 +02:00
|
|
|
const [dismissBannerTimeout, setDismissBannerTimeout] = useState<NodeJS.Timeout>();
|
|
|
|
|
|
|
|
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);
|
2024-09-20 22:31:12 +02:00
|
|
|
}, 10000)
|
2024-09-20 22:29:37 +02:00
|
|
|
);
|
|
|
|
} else {
|
|
|
|
setDismissBannerTimeout(null);
|
|
|
|
}
|
|
|
|
}, [appUpdateStatus]);
|
|
|
|
|
|
|
|
function onClick() {
|
|
|
|
getApi().installAppUpdate();
|
|
|
|
}
|
|
|
|
if (updateStatusMessage) {
|
|
|
|
return (
|
|
|
|
<Button
|
|
|
|
ref={buttonRef}
|
|
|
|
className="update-available-button"
|
|
|
|
title={appUpdateStatus === "ready" ? "Click to Install Update" : updateStatusMessage}
|
|
|
|
onClick={onClick}
|
|
|
|
disabled={appUpdateStatus !== "ready"}
|
|
|
|
>
|
|
|
|
{updateStatusMessage}
|
|
|
|
</Button>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const UpdateStatusBanner = memo(UpdateStatusBannerComponent) as typeof UpdateStatusBannerComponent;
|