"use client"; import useLogger from "../hooks/use-logger"; import { useState, useMemo } from "react"; import { ELECTRON_COMMANDS } from "@common/electron-commands"; import { useAtomValue, useSetAtom } from "jotai"; import { batchModeAtom, lensSizeAtom, savedOutputPathAtom, progressAtom, viewTypeAtom, rememberOutputFolderAtom, } from "../../atoms/user-settings-atom"; import { useToast } from "@/components/ui/use-toast"; import { sanitizePath } from "@common/sanitize-path"; import getDirectoryFromPath from "@common/get-directory-from-path"; import { FEATURE_FLAGS } from "@common/feature-flags"; import { ImageFormat, VALID_IMAGE_FORMATS } from "@/lib/valid-formats"; import ProgressBar from "./progress-bar"; import InstructionsCard from "./instructions-card"; import ImageViewSettings from "./image-view-settings"; import useUpscaylVersion from "../hooks/use-upscayl-version"; import MacTitlebarDragRegion from "./mac-titlebar-drag-region"; import LensViewer from "./lens-view"; import ImageViewer from "./image-viewer"; import useTranslation from "../hooks/use-translation"; import SliderView from "./slider-view"; type MainContentProps = { imagePath: string; resetImagePaths: () => void; upscaledBatchFolderPath: string; setImagePath: React.Dispatch>; validateImagePath: (path: string) => void; selectFolderHandler: () => void; selectImageHandler: () => void; upscaledImagePath: string; batchFolderPath: string; doubleUpscaylCounter: number; setDimensions: React.Dispatch< React.SetStateAction<{ width: number; height: number; }> >; }; const MainContent = ({ imagePath, resetImagePaths, upscaledBatchFolderPath, setImagePath, validateImagePath, selectFolderHandler, selectImageHandler, upscaledImagePath, batchFolderPath, doubleUpscaylCounter, setDimensions, }: MainContentProps) => { const t = useTranslation(); const logit = useLogger(); const { toast } = useToast(); const version = useUpscaylVersion(); const setOutputPath = useSetAtom(savedOutputPathAtom); const progress = useAtomValue(progressAtom); const batchMode = useAtomValue(batchModeAtom); const viewType = useAtomValue(viewTypeAtom); const lensSize = useAtomValue(lensSizeAtom); const rememberOutputFolder = useAtomValue(rememberOutputFolderAtom); const [zoomAmount, setZoomAmount] = useState("100"); const sanitizedUpscaledImagePath = useMemo( () => sanitizePath(upscaledImagePath), [upscaledImagePath], ); const showInformationCard = useMemo(() => { if (!batchMode) { return imagePath.length === 0 && upscaledImagePath.length === 0; } else { return ( batchFolderPath.length === 0 && upscaledBatchFolderPath.length === 0 ); } }, [ batchMode, imagePath, upscaledImagePath, batchFolderPath, upscaledBatchFolderPath, ]); // DRAG AND DROP HANDLERS const handleDragEnter = (e) => { e.preventDefault(); console.log("drag enter"); }; const handleDragLeave = (e) => { e.preventDefault(); console.log("drag leave"); }; const handleDragOver = (e) => { e.preventDefault(); console.log("drag over"); }; const openFolderHandler = (e) => { const logit = useLogger(); logit("๐Ÿ“‚ OPEN_FOLDER: ", upscaledBatchFolderPath); window.electron.send( ELECTRON_COMMANDS.OPEN_FOLDER, upscaledBatchFolderPath, ); }; const sanitizedImagePath = useMemo( () => sanitizePath(imagePath), [imagePath], ); const handleDrop = (e) => { e.preventDefault(); resetImagePaths(); if ( e.dataTransfer.items.length === 0 || e.dataTransfer.files.length === 0 ) { logit("๐Ÿ‘Ž No valid files dropped"); toast({ title: t("ERRORS.INVALID_IMAGE_ERROR.TITLE"), description: t("ERRORS.INVALID_IMAGE_ERROR.ADDITIONAL_DESCRIPTION"), }); return; } const type = e.dataTransfer.items[0].type; const filePath = e.dataTransfer.files[0].path; const extension = e.dataTransfer.files[0].name.split(".").at(-1); logit("โคต๏ธ Dropped file: ", JSON.stringify({ type, filePath, extension })); if ( !type.includes("image") || !VALID_IMAGE_FORMATS.includes(extension.toLowerCase()) ) { logit("๐Ÿšซ Invalid file dropped"); toast({ title: t("ERRORS.INVALID_IMAGE_ERROR.TITLE"), description: t("ERRORS.INVALID_IMAGE_ERROR.ADDITIONAL_DESCRIPTION"), }); } else { logit("๐Ÿ–ผ Setting image path: ", filePath); setImagePath(filePath); const dirname = getDirectoryFromPath(filePath); logit("๐Ÿ—‚ Setting output path: ", dirname); if (!FEATURE_FLAGS.APP_STORE_BUILD) { if (!rememberOutputFolder) { setOutputPath(dirname); } } validateImagePath(filePath); } }; const handlePaste = (e: React.ClipboardEvent) => { console.log("๐Ÿ“‹ Pasted: ", e); resetImagePaths(); e.preventDefault(); const items = e.clipboardData.items; const files = e.clipboardData.files; console.log("๐Ÿš€ => files:", files); if (items.length === 0 || files.length === 0) { toast({ title: t("ERRORS.INVALID_IMAGE_ERROR.TITLE"), description: t("ERRORS.INVALID_IMAGE_ERROR.ADDITIONAL_DESCRIPTION"), }); return; } const type = items[0].type; const filePath = files[0].path; const extension = files[0].name .split(".") .at(-1) .toLowerCase() as ImageFormat; logit("๐Ÿ“‹ Pasted file: ", JSON.stringify({ type, filePath, extension })); if (!type.includes("image") && !VALID_IMAGE_FORMATS.includes(extension)) { toast({ title: t("ERRORS.INVALID_IMAGE_ERROR.TITLE"), description: t("ERRORS.INVALID_IMAGE_ERROR.ADDITIONAL_DESCRIPTION"), }); } else { setImagePath(filePath); const dirname = getDirectoryFromPath(filePath); logit("๐Ÿ—‚ Setting output path: ", dirname); if (!FEATURE_FLAGS.APP_STORE_BUILD) { if (!rememberOutputFolder) { setOutputPath(dirname); } } validateImagePath(filePath); } }; return (
{progress.length > 0 && upscaledImagePath.length === 0 && upscaledBatchFolderPath.length === 0 && ( )} {/* DEFAULT PANE INFO */} {showInformationCard && ( )} {/* SHOW SELECTED IMAGE */} {!batchMode && upscaledImagePath.length === 0 && imagePath.length > 0 && ( )} {/* BATCH UPSCALE SHOW SELECTED FOLDER */} {batchMode && upscaledBatchFolderPath.length === 0 && batchFolderPath.length > 0 && (

{t("APP.PROGRESS.BATCH.SELECTED_FOLDER_TITLE")} {" "} {batchFolderPath}

)} {/* BATCH UPSCALE DONE INFO */} {batchMode && upscaledBatchFolderPath.length > 0 && (

{t("APP.PROGRESS.BATCH.DONE_TITLE")}

)} {!batchMode && viewType === "lens" && upscaledImagePath && imagePath && ( )} {/* COMPARISON SLIDER */} {!batchMode && viewType === "slider" && imagePath.length > 0 && upscaledImagePath.length > 0 && ( )}
); }; export default MainContent;