2024-10-04 14:45:54 +05:30
|
|
|
import React, { useEffect } from "react";
|
|
|
|
import UpscaylSVGLogo from "@/components/icons/upscayl-logo-svg";
|
2024-09-01 17:31:45 +05:30
|
|
|
import { useAtomValue } from "jotai";
|
|
|
|
import { translationAtom } from "@/atoms/translations-atom";
|
2024-10-04 14:45:54 +05:30
|
|
|
import { ELECTRON_COMMANDS } from "@common/electron-commands";
|
|
|
|
import useLogger from "../hooks/use-logger";
|
2022-11-12 02:09:28 +05:30
|
|
|
|
2023-07-23 14:37:18 +05:30
|
|
|
function ProgressBar({
|
|
|
|
progress,
|
|
|
|
doubleUpscaylCounter,
|
|
|
|
batchMode,
|
2024-10-04 14:45:54 +05:30
|
|
|
resetImagePaths,
|
2023-10-21 19:13:03 +05:30
|
|
|
}: {
|
|
|
|
progress: string;
|
|
|
|
doubleUpscaylCounter: number;
|
|
|
|
batchMode: boolean;
|
2024-10-04 14:45:54 +05:30
|
|
|
resetImagePaths: () => void;
|
2023-07-23 14:37:18 +05:30
|
|
|
}) {
|
2023-09-09 17:48:00 +05:30
|
|
|
const [batchProgress, setBatchProgress] = React.useState(0);
|
2024-09-01 17:31:45 +05:30
|
|
|
const t = useAtomValue(translationAtom);
|
2024-10-04 14:45:54 +05:30
|
|
|
const logit = useLogger();
|
2023-09-09 17:48:00 +05:30
|
|
|
|
2023-10-21 19:44:42 +05:30
|
|
|
useEffect(() => {
|
2023-10-21 19:13:03 +05:30
|
|
|
const progressString = progress.trim().replace(/\n/g, "");
|
|
|
|
// Remove trailing and leading spaces
|
2023-10-21 19:44:42 +05:30
|
|
|
if (progressString.includes("Successful")) {
|
2023-09-09 17:48:00 +05:30
|
|
|
setBatchProgress((prev) => prev + 1);
|
|
|
|
}
|
|
|
|
}, [progress]);
|
|
|
|
|
2024-10-04 14:45:54 +05:30
|
|
|
const stopHandler = () => {
|
|
|
|
window.electron.send(ELECTRON_COMMANDS.STOP);
|
|
|
|
logit("🛑 Stopping Upscayl");
|
|
|
|
resetImagePaths();
|
|
|
|
};
|
|
|
|
|
2024-08-31 16:35:53 +05:30
|
|
|
// const progressStyle = useMemo(() => {
|
|
|
|
// if (progress.includes("%")) {
|
|
|
|
// return {
|
|
|
|
// "--value": parseFloat(progress.replace("%", "")),
|
|
|
|
// };
|
|
|
|
// } else if (progress.includes("Success")) {
|
|
|
|
// return {
|
|
|
|
// "--value": 100,
|
|
|
|
// };
|
|
|
|
// }
|
|
|
|
// return {
|
|
|
|
// "--value": 0,
|
|
|
|
// };
|
|
|
|
// }, [progress]);
|
|
|
|
|
2022-11-12 02:09:28 +05:30
|
|
|
return (
|
2024-02-15 13:47:11 +05:30
|
|
|
<div className="absolute z-50 flex h-full w-full flex-col items-center justify-center bg-base-300/50 backdrop-blur-lg">
|
2024-08-31 16:35:53 +05:30
|
|
|
<div className="flex flex-col items-center gap-2 rounded-btn bg-base-100/50 p-4 backdrop-blur-lg">
|
2024-10-04 14:45:54 +05:30
|
|
|
<UpscaylSVGLogo className="spinner h-12 w-12" />
|
|
|
|
|
2024-06-07 21:13:16 +05:30
|
|
|
<p className="rounded-full px-2 pb-2 font-bold">
|
2024-09-01 17:31:45 +05:30
|
|
|
{batchMode &&
|
2024-09-03 13:04:58 +05:30
|
|
|
`${t("APP.PROGRESS_BAR.BATCH_UPSCAYL_IN_PROGRESS_TITLE")} ${batchProgress}`}
|
2023-03-12 13:29:07 +05:30
|
|
|
</p>
|
2024-10-04 14:45:54 +05:30
|
|
|
|
2024-08-31 16:35:53 +05:30
|
|
|
<div className="flex flex-col items-center gap-1">
|
|
|
|
{progress !== "Hold on..." ? (
|
|
|
|
<p className="text-sm font-bold">
|
|
|
|
{progress}
|
|
|
|
{!batchMode &&
|
|
|
|
doubleUpscaylCounter > 0 &&
|
|
|
|
"\nPass " + doubleUpscaylCounter}
|
|
|
|
</p>
|
|
|
|
) : (
|
|
|
|
<p className="text-sm font-bold">{progress}</p>
|
|
|
|
)}
|
2024-10-04 14:45:54 +05:30
|
|
|
|
2024-08-31 16:35:53 +05:30
|
|
|
<p className="animate-pulse rounded-full px-2 pb-3 text-xs font-medium text-neutral-content/50">
|
2024-09-03 13:04:58 +05:30
|
|
|
{t("APP.PROGRESS_BAR.IN_PROGRESS_TITLE")}
|
2024-08-31 16:35:53 +05:30
|
|
|
</p>
|
|
|
|
</div>
|
2024-10-04 14:45:54 +05:30
|
|
|
|
2024-02-15 13:47:11 +05:30
|
|
|
<button onClick={stopHandler} className="btn btn-outline">
|
2024-09-03 13:04:58 +05:30
|
|
|
{t("APP.PROGRESS_BAR.STOP_BUTTON_TITLE")}
|
2023-04-29 22:42:40 +05:30
|
|
|
</button>
|
2022-11-12 02:09:28 +05:30
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ProgressBar;
|