From be493e8be045f25f38e619b79730f437839752a8 Mon Sep 17 00:00:00 2001 From: Adam <2363879+adamdotdevin@users.noreply.github.com> Date: Tue, 20 Jan 2026 10:20:43 -0600 Subject: wip(app): i18n --- packages/app/src/components/session-context-usage.tsx | 16 ++++++++++------ .../app/src/components/session/session-context-tab.tsx | 15 ++++++++------- .../app/src/components/session/session-new-view.tsx | 18 +++++++++++------- packages/app/src/i18n/en.ts | 10 ++++++++++ packages/app/src/i18n/zh.ts | 10 ++++++++++ 5 files changed, 49 insertions(+), 20 deletions(-) (limited to 'packages') diff --git a/packages/app/src/components/session-context-usage.tsx b/packages/app/src/components/session-context-usage.tsx index 680f32713..53148d416 100644 --- a/packages/app/src/components/session-context-usage.tsx +++ b/packages/app/src/components/session-context-usage.tsx @@ -7,6 +7,7 @@ import { AssistantMessage } from "@opencode-ai/sdk/v2/client" import { useLayout } from "@/context/layout" import { useSync } from "@/context/sync" +import { useLanguage } from "@/context/language" interface SessionContextUsageProps { variant?: "button" | "indicator" @@ -16,6 +17,7 @@ export function SessionContextUsage(props: SessionContextUsageProps) { const sync = useSync() const params = useParams() const layout = useLayout() + const language = useLanguage() const variant = createMemo(() => props.variant ?? "button") const sessionKey = createMemo(() => `${params.dir}${params.id ? "/" + params.id : ""}`) @@ -24,14 +26,16 @@ export function SessionContextUsage(props: SessionContextUsageProps) { const messages = createMemo(() => (params.id ? (sync.data.message[params.id] ?? []) : [])) const cost = createMemo(() => { + const locale = language.locale() const total = messages().reduce((sum, x) => sum + (x.role === "assistant" ? x.cost : 0), 0) - return new Intl.NumberFormat("en-US", { + return new Intl.NumberFormat(locale, { style: "currency", currency: "USD", }).format(total) }) const context = createMemo(() => { + const locale = language.locale() const last = messages().findLast((x) => { if (x.role !== "assistant") return false const total = x.tokens.input + x.tokens.output + x.tokens.reasoning + x.tokens.cache.read + x.tokens.cache.write @@ -42,7 +46,7 @@ export function SessionContextUsage(props: SessionContextUsageProps) { last.tokens.input + last.tokens.output + last.tokens.reasoning + last.tokens.cache.read + last.tokens.cache.write const model = sync.data.provider.all.find((x) => x.id === last.providerID)?.models[last.modelID] return { - tokens: total.toLocaleString(), + tokens: total.toLocaleString(locale), percentage: model?.limit.context ? Math.round((total / model.limit.context) * 100) : null, } }) @@ -67,21 +71,21 @@ export function SessionContextUsage(props: SessionContextUsageProps) { <>