1
0
mirror of https://github.com/upscayl/upscayl.git synced 2025-01-24 23:13:45 +01:00
upscayl/electron/commands/batch-upscayl.ts

128 lines
3.6 KiB
TypeScript
Raw Normal View History

import fs from "fs";
import { getMainWindow } from "../main-window";
import {
childProcesses,
2024-04-09 23:41:24 +05:30
savedCustomModelsPath,
setStopped,
stopped,
} from "../utils/config-variables";
import logit from "../utils/logit";
import { spawnUpscayl } from "../utils/spawn-upscayl";
import { getBatchArguments } from "../utils/get-arguments";
import slash from "../utils/slash";
import { modelsPath } from "../utils/get-resource-paths";
import COMMAND from "../../common/commands";
2023-11-22 21:24:02 +05:30
import { BatchUpscaylPayload } from "../../common/types/types";
import showNotification from "../utils/show-notification";
import { DEFAULT_MODELS } from "../../common/models-list";
2023-11-22 21:24:02 +05:30
const batchUpscayl = async (event, payload: BatchUpscaylPayload) => {
const mainWindow = getMainWindow();
if (!mainWindow) return;
const tileSize = payload.tileSize;
const compression = payload.compression;
2024-04-09 23:41:24 +05:30
const scale = payload.scale;
2024-04-20 21:14:42 +05:30
const useCustomWidth = payload.useCustomWidth;
const customWidth = useCustomWidth ? payload.customWidth : "";
const model = payload.model;
const gpuId = payload.gpuId;
const saveImageAs = payload.saveImageAs;
// GET THE IMAGE DIRECTORY
let inputDir = decodeURIComponent(payload.batchFolderPath);
// GET THE OUTPUT DIRECTORY
let outputFolderPath = decodeURIComponent(payload.outputPath);
2024-04-21 23:09:13 +05:30
const outputFolderName = `upscayl_${saveImageAs}_${model}_${
useCustomWidth ? `${customWidth}px` : `${scale}x`
}`;
outputFolderPath += slash + outputFolderName;
// CREATE THE OUTPUT DIRECTORY
if (!fs.existsSync(outputFolderPath)) {
fs.mkdirSync(outputFolderPath, { recursive: true });
}
2023-12-03 12:06:00 +05:30
const isDefaultModel = DEFAULT_MODELS.includes(model);
// UPSCALE
const upscayl = spawnUpscayl(
2024-04-09 23:41:24 +05:30
getBatchArguments({
2023-12-03 12:06:00 +05:30
inputDir,
2024-04-09 23:41:24 +05:30
outputDir: outputFolderPath,
modelsPath: isDefaultModel
? modelsPath
: savedCustomModelsPath ?? modelsPath,
model,
gpuId,
saveImageAs,
2024-04-09 23:41:24 +05:30
scale,
2024-04-20 21:14:42 +05:30
customWidth,
compression,
tileSize,
2024-04-09 23:41:24 +05:30
}),
2024-02-08 20:27:35 +05:30
logit,
);
childProcesses.push(upscayl);
setStopped(false);
let failed = false;
let encounteredError = false;
const onData = (data: any) => {
if (!mainWindow) return;
data = data.toString();
mainWindow.webContents.send(
COMMAND.FOLDER_UPSCAYL_PROGRESS,
2024-02-08 20:27:35 +05:30
data.toString(),
);
2024-04-21 19:34:59 +05:30
if ((data as string).includes("Error")) {
logit("❌ ", data);
encounteredError = true;
} else if (data.includes("Resizing")) {
mainWindow.webContents.send(COMMAND.SCALING_AND_CONVERTING);
}
};
const onError = (data: any) => {
if (!mainWindow) return;
mainWindow.setProgressBar(-1);
mainWindow.webContents.send(
COMMAND.FOLDER_UPSCAYL_PROGRESS,
2024-02-08 20:27:35 +05:30
data.toString(),
);
failed = true;
upscayl.kill();
mainWindow &&
mainWindow.webContents.send(
COMMAND.UPSCAYL_ERROR,
`Error upscaling images! ${data}`,
);
return;
};
const onClose = () => {
if (!mainWindow) return;
if (!failed && !stopped) {
logit("💯 Done upscaling");
upscayl.kill();
mainWindow.webContents.send(
COMMAND.FOLDER_UPSCAYL_DONE,
outputFolderPath,
);
if (!encounteredError) {
showNotification("Upscayled", "Images upscayled successfully!");
} else {
showNotification(
"Upscayled",
"Images were upscayled but encountered some errors!",
);
}
} else {
upscayl.kill();
}
};
upscayl.process.stderr.on("data", onData);
upscayl.process.on("error", onError);
upscayl.process.on("close", onClose);
};
export default batchUpscayl;