1
0
mirror of https://github.com/upscayl/upscayl.git synced 2024-12-11 23:36:11 +01:00
upscayl/renderer/components/settings-tab/index.tsx

239 lines
7.0 KiB
TypeScript
Raw Normal View History

2023-07-22 13:07:53 +02:00
import { ThemeSelect } from "./ThemeSelect";
import { SaveOutputFolderToggle } from "./SaveOutputFolderToggle";
import { GpuIdInput } from "./GpuIdInput";
import { CustomModelsFolderSelect } from "./CustomModelsFolderSelect";
import { LogArea } from "./LogArea";
import { ImageScaleSelect } from "./ImageScaleSelect";
import { ImageFormatSelect } from "./ImageFormatSelect";
import { DonateButton } from "./DonateButton";
import React, { useEffect, useState } from "react";
import { themeChange } from "theme-change";
import { useAtom, useAtomValue } from "jotai";
import { customModelsPathAtom, scaleAtom } from "../../atoms/userSettingsAtom";
import { modelsListAtom } from "../../atoms/modelsListAtom";
import useLog from "../hooks/useLog";
import { QualityInput } from "./QualityInput";
2023-08-10 12:17:35 +02:00
import ToggleOverwrite from "./ToggleOverwrite";
2023-09-03 11:16:48 +02:00
import { UpscaylCloudModal } from "../UpscaylCloudModal";
import { ResetSettings } from "./ResetSettings";
2023-07-22 13:07:53 +02:00
interface IProps {
batchMode: boolean;
setModel: React.Dispatch<React.SetStateAction<string>>;
saveImageAs: string;
setSaveImageAs: React.Dispatch<React.SetStateAction<string>>;
2023-09-13 16:07:45 +02:00
compression: number;
setCompression: React.Dispatch<React.SetStateAction<number>>;
2023-07-22 13:07:53 +02:00
gpuId: string;
setGpuId: React.Dispatch<React.SetStateAction<string>>;
logData: string[];
2023-08-10 12:17:35 +02:00
overwrite: boolean;
setOverwrite: (arg: any) => void;
2023-08-14 12:55:30 +02:00
os: "linux" | "mac" | "win" | undefined;
2023-09-03 11:16:48 +02:00
show: boolean;
setShow: React.Dispatch<React.SetStateAction<boolean>>;
setDontShowCloudModal: React.Dispatch<React.SetStateAction<boolean>>;
2023-07-22 13:07:53 +02:00
}
function SettingsTab({
batchMode,
setModel,
2023-09-13 16:07:45 +02:00
compression,
setCompression,
2023-07-22 13:07:53 +02:00
gpuId,
setGpuId,
saveImageAs,
setSaveImageAs,
logData,
2023-08-10 12:17:35 +02:00
overwrite,
setOverwrite,
2023-08-14 12:55:30 +02:00
os,
2023-09-03 11:16:48 +02:00
show,
setShow,
setDontShowCloudModal,
2023-07-22 13:07:53 +02:00
}: IProps) {
// STATES
const [currentModel, setCurrentModel] = useState<{
label: string;
value: string;
}>({
label: null,
value: null,
});
const [rememberOutputFolder, setRememberOutputFolder] = useState(false);
const [isCopied, setIsCopied] = useState(false);
const [customModelsPath, setCustomModelsPath] = useAtom(customModelsPathAtom);
const modelOptions = useAtomValue(modelsListAtom);
const [scale, setScale] = useAtom(scaleAtom);
const { logit } = useLog();
useEffect(() => {
themeChange(false);
if (!localStorage.getItem("saveImageAs")) {
logit("⚙️ Setting saveImageAs to png");
localStorage.setItem("saveImageAs", "png");
} else {
const currentlySavedImageFormat = localStorage.getItem("saveImageAs");
logit(
2023-09-13 16:07:45 +02:00
"⚙️ Getting saveImageAs from localStorage: ",
2023-07-22 13:07:53 +02:00
currentlySavedImageFormat
);
setSaveImageAs(currentlySavedImageFormat);
}
if (!localStorage.getItem("model")) {
setCurrentModel(modelOptions[0]);
setModel(modelOptions[0].value);
localStorage.setItem("model", JSON.stringify(modelOptions[0]));
logit("🔀 Setting model to", modelOptions[0].value);
} else {
const currentlySavedModel = JSON.parse(
localStorage.getItem("model")
) as (typeof modelOptions)[0];
setCurrentModel(currentlySavedModel);
setModel(currentlySavedModel.value);
logit(
2023-09-13 16:07:45 +02:00
"⚙️ Getting model from localStorage: ",
2023-07-22 13:07:53 +02:00
JSON.stringify(currentlySavedModel)
);
}
if (!localStorage.getItem("gpuId")) {
localStorage.setItem("gpuId", "");
logit("⚙️ Setting gpuId to empty string");
} else {
const currentlySavedGpuId = localStorage.getItem("gpuId");
setGpuId(currentlySavedGpuId);
2023-09-13 16:07:45 +02:00
logit("⚙️ Getting gpuId from localStorage: ", currentlySavedGpuId);
2023-07-22 13:07:53 +02:00
}
if (!localStorage.getItem("rememberOutputFolder")) {
logit("⚙️ Setting rememberOutputFolder to false");
localStorage.setItem("rememberOutputFolder", "false");
} else {
const currentlySavedRememberOutputFolder = localStorage.getItem(
"rememberOutputFolder"
);
logit(
2023-09-13 16:07:45 +02:00
"⚙️ Getting rememberOutputFolder from localStorage: ",
2023-07-22 13:07:53 +02:00
currentlySavedRememberOutputFolder
);
setRememberOutputFolder(
currentlySavedRememberOutputFolder === "true" ? true : false
);
}
2023-09-09 12:13:16 +02:00
if (!localStorage.getItem("quality")) {
logit("⚙️ Setting quality to 100%");
2023-09-13 16:07:45 +02:00
localStorage.setItem("quality", JSON.stringify(compression));
2023-09-09 12:13:16 +02:00
} else {
const currentlySavedQuality = localStorage.getItem("quality");
2023-09-13 16:07:45 +02:00
logit("⚙️ Getting quality from localStorage", compression);
2023-09-09 12:13:16 +02:00
if (currentlySavedQuality) {
2023-09-13 16:07:45 +02:00
setCompression(JSON.parse(currentlySavedQuality));
2023-09-09 12:13:16 +02:00
}
}
}, []);
2023-07-22 13:07:53 +02:00
// HANDLERS
const setExportType = (format: string) => {
setSaveImageAs(format);
localStorage.setItem("saveImageAs", format);
};
const handleQualityChange = (e) => {
2023-09-13 16:07:45 +02:00
setCompression(e.target.value);
localStorage.setItem("quality", e.target.value);
};
2023-07-22 13:07:53 +02:00
const handleGpuIdChange = (e) => {
setGpuId(e.target.value);
localStorage.setItem("gpuId", e.target.value);
};
const copyOnClickHandler = () => {
navigator.clipboard.writeText(logData.join("\n"));
setIsCopied(true);
setTimeout(() => {
setIsCopied(false);
}, 2000);
};
return (
<div className="animate-step-in animate flex h-screen flex-col gap-7 overflow-y-auto p-5 overflow-x-hidden">
2023-07-23 08:32:22 +02:00
<div className="flex flex-col gap-2 text-sm font-medium">
<p>Having issues?</p>
<a
className="btn-primary btn"
href="https://github.com/upscayl/upscayl/wiki/"
target="_blank">
Read Wiki Guide
</a>
<DonateButton />
</div>
2023-07-22 13:07:53 +02:00
<LogArea
copyOnClickHandler={copyOnClickHandler}
isCopied={isCopied}
logData={logData}
/>
2023-07-22 13:07:53 +02:00
{/* THEME SELECTOR */}
<ThemeSelect />
{/* IMAGE FORMAT BUTTONS */}
<ImageFormatSelect
batchMode={batchMode}
saveImageAs={saveImageAs}
setExportType={setExportType}
/>
{/* IMAGE SCALE */}
<ImageScaleSelect scale={scale} setScale={setScale} />
<QualityInput
2023-09-13 16:07:45 +02:00
compression={compression}
handleQualityChange={handleQualityChange}
/>
2023-07-22 13:07:53 +02:00
<SaveOutputFolderToggle
rememberOutputFolder={rememberOutputFolder}
setRememberOutputFolder={setRememberOutputFolder}
/>
2023-08-10 12:17:35 +02:00
<ToggleOverwrite overwrite={overwrite} setOverwrite={setOverwrite} />
2023-07-22 13:07:53 +02:00
{/* GPU ID INPUT */}
<GpuIdInput gpuId={gpuId} handleGpuIdChange={handleGpuIdChange} />
{/* CUSTOM MODEL */}
<CustomModelsFolderSelect
customModelsPath={customModelsPath}
setCustomModelsPath={setCustomModelsPath}
/>
2023-09-03 11:16:48 +02:00
{/* RESET SETTINGS */}
<ResetSettings />
<button
className="mb-5 rounded-btn p-1 mx-5 bg-success shadow-lg shadow-success/40 text-slate-50 animate-pulse text-sm"
onClick={() => {
setShow(true);
}}>
Introducing Upscayl Cloud
</button>
<UpscaylCloudModal
show={show}
setShow={setShow}
setDontShowCloudModal={setDontShowCloudModal}
/>
2023-07-22 13:07:53 +02:00
</div>
);
}
export default SettingsTab;