mirror of
https://github.com/HKUDS/nanobot.git
synced 2026-05-19 16:12:30 +00:00
Align the WebUI sidebar and chat chrome with the updated design, and generate WebUI session titles asynchronously without blocking turns. Co-authored-by: Cursor <cursoragent@cursor.com>
57 lines
1.6 KiB
TypeScript
57 lines
1.6 KiB
TypeScript
import { useEffect, useState } from "react";
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
import { cn } from "@/lib/utils";
|
|
import { useClient } from "@/providers/ClientProvider";
|
|
import type { ConnectionStatus } from "@/lib/types";
|
|
|
|
const COPY: Record<ConnectionStatus, { color: string }> = {
|
|
idle: { color: "text-muted-foreground" },
|
|
connecting: {
|
|
color: "text-amber-700 dark:text-amber-300",
|
|
},
|
|
open: {
|
|
color: "text-emerald-700 dark:text-emerald-400",
|
|
},
|
|
reconnecting: {
|
|
color: "text-amber-700 dark:text-amber-300",
|
|
},
|
|
closed: {
|
|
color: "text-muted-foreground",
|
|
},
|
|
error: {
|
|
color: "text-destructive",
|
|
},
|
|
};
|
|
|
|
export function ConnectionBadge() {
|
|
const { t } = useTranslation();
|
|
const { client } = useClient();
|
|
const [status, setStatus] = useState<ConnectionStatus>(client.status);
|
|
|
|
useEffect(() => client.onStatus(setStatus), [client]);
|
|
|
|
const meta = COPY[status];
|
|
const pulsing =
|
|
status === "connecting" ||
|
|
status === "reconnecting" ||
|
|
status === "error";
|
|
return (
|
|
<span
|
|
className={cn(
|
|
"inline-flex min-w-0 items-center gap-1.5 rounded-md px-1.5 py-1 text-[11px] font-medium transition-colors",
|
|
meta.color,
|
|
)}
|
|
aria-live="polite"
|
|
>
|
|
<span className="relative flex h-1.5 w-1.5" aria-hidden>
|
|
{pulsing && (
|
|
<span className="absolute inline-flex h-full w-full animate-ping rounded-full bg-current opacity-75" />
|
|
)}
|
|
<span className="relative inline-flex h-1.5 w-1.5 rounded-full bg-current" />
|
|
</span>
|
|
{t(`connection.${status}`)}
|
|
</span>
|
|
);
|
|
}
|