'use client'; import { getSiteConfig, updateSiteConfig } from '@/services/admin/system'; import { useQuery } from '@tanstack/react-query'; import { Label } from '@workspace/ui/components/label'; import { Table, TableBody, TableCell, TableRow } from '@workspace/ui/components/table'; import { Textarea } from '@workspace/ui/components/textarea'; import { EnhancedInput } from '@workspace/ui/custom-components/enhanced-input'; import { useTranslations } from 'next-intl'; import { toast } from 'sonner'; export default function Site() { const t = useTranslations('system.site'); const { data, refetch } = useQuery({ queryKey: ['getSiteConfig'], queryFn: async () => { const { data } = await getSiteConfig(); return data.data; }, }); async function updateConfig(key: string, value: unknown) { if (data?.[key] === value) return; try { await updateSiteConfig({ ...data, [key]: value, } as API.SiteConfig); toast.success(t('saveSuccess')); refetch(); } catch (error) { /* empty */ } } return (

{t('logoDescription')}

updateConfig('site_logo', value)} />

{t('siteNameDescription')}

updateConfig('site_name', value)} />

{t('siteDescDescription')}

updateConfig('site_desc', value)} />

{t('siteDomainDescription')}