"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 ProwlarrCard({ handleUpdateSetting }: { handleUpdateSetting: (key: string, value: unknown) => Promise }) { const { t } = useTranslation(); const [prowlarrUrl, setProwlarrUrl] = useState(""); const [prowlarrApiKey, setProwlarrApiKey] = useState(""); const [prowlarrCategories, setProwlarrCategories] = useState("7030, 7020"); const [isTesting, setIsTesting] = useState(false); const [testResult, setTestResult] = useState<{ success: boolean; message: string } | null>(null); useEffect(() => { fetch("/api/settings/prowlarr") .then((r) => (r.ok ? r.json() : null)) .then((data) => { if (data) { if (data.url) setProwlarrUrl(data.url); if (data.api_key) setProwlarrApiKey(data.api_key); if (data.categories) setProwlarrCategories(data.categories.join(", ")); } }) .catch(() => {}); }, []); function saveProwlarr(url?: string, apiKey?: string, cats?: string) { const categories = (cats ?? prowlarrCategories) .split(",") .map((s) => parseInt(s.trim())) .filter((n) => !isNaN(n)); handleUpdateSetting("prowlarr", { url: url ?? prowlarrUrl, api_key: apiKey ?? prowlarrApiKey, categories, }); } async function handleTestConnection() { setIsTesting(true); setTestResult(null); try { const resp = await fetch("/api/prowlarr/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.prowlarr")} {t("settings.prowlarrDesc")}
setProwlarrUrl(e.target.value)} onBlur={() => saveProwlarr()} />
setProwlarrApiKey(e.target.value)} onBlur={() => saveProwlarr()} />
setProwlarrCategories(e.target.value)} onBlur={() => saveProwlarr()} />

{t("settings.prowlarrCategoriesHelp")}

{testResult && ( {testResult.message} )}
); }