"use client"; import { useState } 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, initialData }: { handleUpdateSetting: (key: string, value: unknown) => Promise; initialData: Record | null }) { const { t } = useTranslation(); const [prowlarrUrl, setProwlarrUrl] = useState(initialData?.url ? String(initialData.url) : ""); const [prowlarrApiKey, setProwlarrApiKey] = useState(initialData?.api_key ? String(initialData.api_key) : ""); const [prowlarrCategories, setProwlarrCategories] = useState( Array.isArray(initialData?.categories) ? (initialData.categories as number[]).join(", ") : "7030, 7020" ); const [isTesting, setIsTesting] = useState(false); const [testResult, setTestResult] = useState<{ success: boolean; message: string } | null>(null); 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} )}
); }