import { useState, useEffect } from "react"; import { PanelSection, PanelSectionRow, ButtonItem } from "@decky/ui"; import { runInstallFGMod, runUninstallFGMod } from "../api"; import { OperationResult } from "./ResultDisplay"; import { createAutoCleanupTimer } from "../utils"; import { TIMEOUTS, MESSAGES, STYLES } from "../utils/constants"; 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 !== null ? (
{pathExists ? MESSAGES.modInstalled : MESSAGES.modNotInstalled}
) : null} {pathExists === false ? ( {installing ? MESSAGES.installing : MESSAGES.installButton} ) : null} {pathExists === true ? ( {uninstalling ? MESSAGES.uninstalling : MESSAGES.uninstallButton} ) : null} {pathExists === true ? (
{MESSAGES.instructionTitle}
{MESSAGES.instructionText}
) : null}
); }