1
0
mirror of https://github.com/upscayl/upscayl.git synced 2025-01-08 12:41:35 +01:00
upscayl/renderer/components/settings-tab/ToggleOverwrite.tsx

44 lines
1.1 KiB
TypeScript
Raw Normal View History

2023-08-11 11:45:27 +02:00
import React, { useEffect } from "react";
2023-08-10 12:17:35 +02:00
type ToggleOverwriteProps = {
overwrite: boolean;
setOverwrite: (arg: any) => void;
};
const ToggleOverwrite = ({ overwrite, setOverwrite }: ToggleOverwriteProps) => {
2023-08-11 11:45:27 +02:00
useEffect(() => {
if (!localStorage.getItem("overwrite")) {
localStorage.setItem("overwrite", JSON.stringify(overwrite));
} else {
2023-08-30 06:54:16 +02:00
const currentlySavedOverwrite = localStorage.getItem("overwrite");
if (currentlySavedOverwrite) {
setOverwrite(JSON.parse(currentlySavedOverwrite));
}
2023-08-11 11:45:27 +02:00
}
}, []);
2023-08-30 06:54:16 +02:00
2023-08-10 12:17:35 +02:00
return (
<div className="flex flex-col gap-2">
<p className="text-sm font-medium">OVERWRITE PREVIOUS UPSCALE</p>
<input
type="checkbox"
2023-08-26 09:27:15 +02:00
className="toggle"
2023-08-10 12:17:35 +02:00
checked={overwrite}
onClick={() => {
2023-08-30 06:54:16 +02:00
setOverwrite((oldValue: boolean) => {
if (oldValue) {
2023-08-10 12:17:35 +02:00
localStorage.removeItem("overwrite");
2023-08-30 06:54:16 +02:00
return false;
} else {
return true;
2023-08-10 12:17:35 +02:00
}
});
localStorage.setItem("overwrite", JSON.stringify(!overwrite));
}}
/>
</div>
);
};
export default ToggleOverwrite;