PartnersPage.tsx
1.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
import { useEffect, useState } from 'react'
import { Link } from 'react-router-dom'
import { partners } from '@/api/client'
import type { Partner } from '@/types/api'
import { PageHeader } from '@/components/PageHeader'
import { Loading } from '@/components/Loading'
import { ErrorBox } from '@/components/ErrorBox'
import { DataTable, type Column } from '@/components/DataTable'
import { useT } from '@/i18n/LocaleContext'
export function PartnersPage() {
const t = useT()
const [rows, setRows] = useState<Partner[]>([])
const [error, setError] = useState<Error | null>(null)
const [loading, setLoading] = useState(true)
useEffect(() => {
partners
.list()
.then(setRows)
.catch((e: unknown) => setError(e instanceof Error ? e : new Error(String(e))))
.finally(() => setLoading(false))
}, [])
const columns: Column<Partner>[] = [
{
header: t('label.code'),
key: 'code',
render: (r) => (
<Link to={`/partners/${r.id}/edit`} className="font-mono text-brand-600 hover:underline">{r.code}</Link>
),
},
{ header: t('label.name'), key: 'name' },
{ header: t('label.type'), key: 'type' },
{ header: t('label.email'), key: 'email', render: (r) => r.email ?? '\u2014' },
{ header: t('label.phone'), key: 'phone', render: (r) => r.phone ?? '\u2014' },
{
header: t('label.active'),
key: 'active',
render: (r) => (r.active ? <span className="text-emerald-600">{'\u25CF'}</span> : <span className="text-slate-300">{'\u25CF'}</span>),
},
]
return (
<div>
<PageHeader
title={t('page.partners.title')}
subtitle={t('page.partners.subtitle')}
actions={<Link to="/partners/new" className="btn-primary">{t('action.newPartner')}</Link>}
/>
{loading && <Loading />}
{error && <ErrorBox error={error} />}
{!loading && !error && <DataTable rows={rows} columns={columns} />}
</div>
)
}