2022-11-12 02:09:28 +05:30
|
|
|
import React from "react";
|
2023-07-22 16:37:53 +05:30
|
|
|
import Spinner from "../../icons/Spinner";
|
2022-11-12 02:09:28 +05:30
|
|
|
|
2023-07-23 14:37:18 +05:30
|
|
|
function ProgressBar({
|
|
|
|
progress,
|
|
|
|
doubleUpscaylCounter,
|
|
|
|
stopHandler,
|
|
|
|
batchMode,
|
|
|
|
}) {
|
2023-09-09 17:48:00 +05:30
|
|
|
const [batchProgress, setBatchProgress] = React.useState(0);
|
|
|
|
|
|
|
|
React.useEffect(() => {
|
|
|
|
if (progress.includes("0.00%")) {
|
|
|
|
setBatchProgress((prev) => prev + 1);
|
|
|
|
}
|
|
|
|
}, [progress]);
|
|
|
|
|
2022-11-12 02:09:28 +05:30
|
|
|
return (
|
2023-03-12 13:29:07 +05:30
|
|
|
<div className="absolute flex h-full w-full flex-col items-center justify-center bg-base-300/50 backdrop-blur-lg">
|
2022-11-12 02:09:28 +05:30
|
|
|
<div className="flex flex-col items-center gap-2">
|
2023-03-12 13:29:07 +05:30
|
|
|
<Spinner />
|
2023-03-12 14:10:16 +05:30
|
|
|
<p className="rounded-full bg-base-300 px-2 py-1 font-bold">
|
2023-09-09 17:48:00 +05:30
|
|
|
{batchMode && "Batch Upscale In Progress: " + batchProgress}
|
2023-07-23 14:37:18 +05:30
|
|
|
{!batchMode &&
|
|
|
|
(doubleUpscaylCounter > 0
|
|
|
|
? `${progress}\nPass ${doubleUpscaylCounter}`
|
|
|
|
: `${progress}`)}
|
2022-11-12 02:09:28 +05:30
|
|
|
</p>
|
2023-03-12 13:29:07 +05:30
|
|
|
<p className="rounded-full bg-base-300 px-2 py-1 text-sm font-medium">
|
|
|
|
Doing the Upscayl magic...
|
|
|
|
</p>
|
2023-08-12 11:56:05 -04:00
|
|
|
<button onClick={stopHandler} className="btn-danger btn">
|
2023-04-29 22:42:40 +05:30
|
|
|
STOP
|
|
|
|
</button>
|
2022-11-12 02:09:28 +05:30
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ProgressBar;
|