"use client"; import { useState, useEffect } from "react"; import { Card, CardHeader, CardTitle, CardDescription, CardContent, Button, FormField, FormInput, Icon } from "@/app/components/ui"; import { useTranslation } from "@/lib/i18n/context"; export function QBittorrentCard({ handleUpdateSetting }: { handleUpdateSetting: (key: string, value: unknown) => Promise }) { const { t } = useTranslation(); const [qbUrl, setQbUrl] = useState(""); const [qbUsername, setQbUsername] = useState(""); const [qbPassword, setQbPassword] = useState(""); const [isTesting, setIsTesting] = useState(false); const [testResult, setTestResult] = useState<{ success: boolean; message: string } | null>(null); useEffect(() => { fetch("/api/settings/qbittorrent") .then((r) => (r.ok ? r.json() : null)) .then((data) => { if (data) { if (data.url) setQbUrl(data.url); if (data.username) setQbUsername(data.username); if (data.password) setQbPassword(data.password); } }) .catch(() => {}); }, []); function saveQbittorrent() { handleUpdateSetting("qbittorrent", { url: qbUrl, username: qbUsername, password: qbPassword, }); } async function handleTestConnection() { setIsTesting(true); setTestResult(null); try { const resp = await fetch("/api/qbittorrent/test"); const data = await resp.json(); if (data.error) { setTestResult({ success: false, message: data.error }); } else { setTestResult(data); } } catch { setTestResult({ success: false, message: "Failed to connect" }); } finally { setIsTesting(false); } } return ( {t("settings.qbittorrent")} {t("settings.qbittorrentDesc")}
setQbUrl(e.target.value)} onBlur={() => saveQbittorrent()} />
setQbUsername(e.target.value)} onBlur={() => saveQbittorrent()} /> setQbPassword(e.target.value)} onBlur={() => saveQbittorrent()} />
{testResult && ( {testResult.message} )}
); }