diff --git a/src/pages/AgentList.tsx b/src/pages/AgentList.tsx index d2e33d9..ba564b9 100644 --- a/src/pages/AgentList.tsx +++ b/src/pages/AgentList.tsx @@ -37,6 +37,41 @@ export default function AgentList() { }; const isImageUrl = (url: string) => url?.startsWith('http') || url?.startsWith('/'); + const getModelLabel = (value: unknown) => { + if (Array.isArray(value)) { + const names = value + .map((item: any) => (typeof item === 'string' ? item : item?.name)) + .map((v) => String(v || '').trim()) + .filter(Boolean); + return names.join('、'); + } + if (typeof value !== 'string') { + return ''; + } + const raw = value.trim(); + if (!raw) { + return ''; + } + try { + const parsed = JSON.parse(raw); + if (Array.isArray(parsed)) { + const names = parsed + .map((item: any) => (typeof item === 'string' ? item : item?.name)) + .map((v) => String(v || '').trim()) + .filter(Boolean); + return names.join('、'); + } + } catch { + } + if (raw.includes(',')) { + return raw + .split(',') + .map((s) => s.trim()) + .filter(Boolean) + .join('、'); + } + return raw; + }; const publicCount = useMemo(() => list.filter((a) => a.visibility === 'public').length, [list]); const teamCount = useMemo(() => list.filter((a) => a.visibility === 'team').length, [list]); @@ -208,10 +243,10 @@ export default function AgentList() { 私有 )} - {a.model && ( + {getModelLabel(a.model) && ( - {a.model} + {getModelLabel(a.model)} )}