import { useState, useEffect } from "react"; import { PanelSection, PanelSectionRow, ButtonItem } from "@decky/ui"; import { runInstallFGMod, runUninstallFGMod } from "../api"; import { OperationResult } from "./ResultDisplay"; import { SmartClipboardButton } from "./SmartClipboardButton"; import { createAutoCleanupTimer } from "../utils"; import { TIMEOUTS, MESSAGES, STYLES } from "../utils/constants"; import optiScalerImage from "../../assets/optiscaler.png"; interface FGModInstallerSectionProps { pathExists: boolean | null; setPathExists: (exists: boolean | null) => void; } export function FGModInstallerSection({ pathExists, setPathExists }: FGModInstallerSectionProps) { const [installing, setInstalling] = useState(false); const [uninstalling, setUninstalling] = useState(false); const [installResult, setInstallResult] = useState(null); const [uninstallResult, setUninstallResult] = useState(null); useEffect(() => { if (installResult) { return createAutoCleanupTimer(() => setInstallResult(null), TIMEOUTS.resultDisplay); } return () => {}; // Ensure a cleanup function is always returned }, [installResult]); useEffect(() => { if (uninstallResult) { return createAutoCleanupTimer(() => setUninstallResult(null), TIMEOUTS.resultDisplay); } return () => {}; // Ensure a cleanup function is always returned }, [uninstallResult]); const handleInstallClick = async () => { try { setInstalling(true); const result = await runInstallFGMod(); setInstallResult(result); if (result.status === "success") { setPathExists(true); } } catch (e) { console.error(e); } finally { setInstalling(false); } }; const handleUninstallClick = async () => { try { setUninstalling(true); const result = await runUninstallFGMod(); setUninstallResult(result); if (result.status === "success") { setPathExists(false); } } catch (e) { console.error(e); } finally { setUninstalling(false); } }; return ( {pathExists === false ? (
{MESSAGES.modNotInstalled}
) : null} {pathExists === false ? ( {installing ? MESSAGES.installing : MESSAGES.installButton} ) : null} {pathExists === true ? ( {uninstalling ? MESSAGES.uninstalling : MESSAGES.uninstallButton} ) : null} {pathExists === true ? (
OptiScaler
) : null} {pathExists === true ? (
{MESSAGES.instructionTitle}
{MESSAGES.instructionText}
) : null} {pathExists === true ? ( ) : null} {pathExists === true ? ( ) : null}
); }