修复UI展示

This commit is contained in:
2025-08-10 17:00:49 +08:00
parent 36f8ec14fe
commit 24c06dd4a8
4 changed files with 45 additions and 10 deletions

View File

@@ -42,9 +42,10 @@ export const AgentRunsList: React.FC<AgentRunsListProps> = ({
onRunClick,
className,
}) => {
const { t } = useTranslation();
const { t, i18n } = useTranslation();
const [currentPage, setCurrentPage] = useState(1);
const { createAgentTab } = useTabState();
const currentLocale = i18n.language;
// Calculate pagination
const totalPages = Math.ceil(runs.length / ITEMS_PER_PAGE);
@@ -65,9 +66,16 @@ export const AgentRunsList: React.FC<AgentRunsListProps> = ({
const formatDuration = (ms?: number) => {
if (!ms) return "N/A";
const seconds = Math.floor(ms / 1000);
if (seconds < 60) return `${seconds}s`;
const isZhCN = currentLocale.startsWith('zh');
if (seconds < 60) {
return isZhCN ? `${seconds}` : `${seconds}s`;
}
const minutes = Math.floor(seconds / 60);
const remainingSeconds = seconds % 60;
if (isZhCN) {
return `${minutes}${remainingSeconds}`;
}
return `${minutes}m ${remainingSeconds}s`;
};
@@ -79,6 +87,16 @@ export const AgentRunsList: React.FC<AgentRunsListProps> = ({
return tokens.toString();
};
const getStatusLabel = (status: string) => {
const statusLabels: Record<string, string> = {
completed: t('agents.statusCompleted', 'Completed'),
running: t('agents.statusRunning', 'Running'),
failed: t('agents.statusFailed', 'Failed'),
pending: t('agents.statusPending', 'Pending')
};
return statusLabels[status] || status;
};
const handleRunClick = (run: AgentRunWithMetrics) => {
// If there's a callback, use it (for full-page navigation)
if (onRunClick) {
@@ -135,7 +153,7 @@ export const AgentRunsList: React.FC<AgentRunsListProps> = ({
{run.status === "running" && (
<div className="flex items-center gap-1">
<div className="w-2 h-2 bg-green-500 rounded-full animate-pulse"></div>
<span className="text-xs text-green-600 font-medium">Running</span>
<span className="text-xs text-green-600 font-medium">{getStatusLabel('running')}</span>
</div>
)}
</div>
@@ -147,7 +165,7 @@ export const AgentRunsList: React.FC<AgentRunsListProps> = ({
<div className="flex items-center gap-3 text-xs text-muted-foreground">
<div className="flex items-center gap-1">
<Clock className="h-3 w-3" />
<span>{formatISOTimestamp(run.created_at)}</span>
<span>{formatISOTimestamp(run.created_at, currentLocale)}</span>
</div>
{run.metrics?.duration_ms && (
@@ -173,10 +191,7 @@ export const AgentRunsList: React.FC<AgentRunsListProps> = ({
}
className="text-xs"
>
{run.status === "completed" ? "Completed" :
run.status === "running" ? "Running" :
run.status === "failed" ? "Failed" :
"Pending"}
{getStatusLabel(run.status || 'pending')}
</Badge>
</div>
</div>