| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- import { createMemo, Show } from "solid-js"
- import { Tooltip } from "@opencode-ai/ui/tooltip"
- import { ProgressCircle } from "@opencode-ai/ui/progress-circle"
- import { useSync } from "@/context/sync"
- import { useParams } from "@solidjs/router"
- import { AssistantMessage } from "@opencode-ai/sdk/v2/client"
- export function SessionContextUsage() {
- const sync = useSync()
- const params = useParams()
- const messages = createMemo(() => (params.id ? (sync.data.message[params.id] ?? []) : []))
- const cost = createMemo(() => {
- const total = messages().reduce((sum, x) => sum + (x.role === "assistant" ? x.cost : 0), 0)
- return new Intl.NumberFormat("en-US", {
- style: "currency",
- currency: "USD",
- }).format(total)
- })
- const context = createMemo(() => {
- const last = messages().findLast((x) => x.role === "assistant" && x.tokens.output > 0) as AssistantMessage
- if (!last) return
- const total =
- 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(),
- percentage: model?.limit.context ? Math.round((total / model.limit.context) * 100) : null,
- }
- })
- return (
- <Show when={context?.()}>
- {(ctx) => (
- <Tooltip
- value={
- <div class="grid grid-cols-2 gap-x-3 gap-y-1">
- <span class="opacity-70 text-right">Tokens</span>
- <span class="text-left">{ctx().tokens}</span>
- <span class="opacity-70 text-right">Usage</span>
- <span class="text-left">{ctx().percentage ?? 0}%</span>
- <span class="opacity-70 text-right">Cost</span>
- <span class="text-left">{cost()}</span>
- </div>
- }
- placement="top"
- >
- <div class="flex items-center gap-1.5">
- <ProgressCircle size={16} strokeWidth={2} percentage={ctx().percentage ?? 0} />
- {/* <span class="text-12-medium text-text-weak">{`${ctx().percentage ?? 0}%`}</span> */}
- </div>
- </Tooltip>
- )}
- </Show>
- )
- }
|