Files
claude-hud/dist/render/lines/identity.js
2026-04-04 02:52:13 +00:00

62 lines
2.7 KiB
JavaScript

import { getContextPercent, getBufferedPercent, getTotalTokens, } from "../../stdin.js";
import { coloredBar, label, getContextColor, RESET } from "../colors.js";
import { getAdaptiveBarWidth } from "../../utils/terminal.js";
import { t } from "../../i18n/index.js";
const DEBUG = process.env.DEBUG?.includes("claude-hud") || process.env.DEBUG === "*";
export function renderIdentityLine(ctx) {
const rawPercent = getContextPercent(ctx.stdin);
const bufferedPercent = getBufferedPercent(ctx.stdin);
const autocompactMode = ctx.config?.display?.autocompactBuffer ?? "enabled";
const percent = autocompactMode === "disabled" ? rawPercent : bufferedPercent;
const colors = ctx.config?.colors;
if (DEBUG && autocompactMode === "disabled") {
console.error(`[claude-hud:context] autocompactBuffer=disabled, showing raw ${rawPercent}% (buffered would be ${bufferedPercent}%)`);
}
const display = ctx.config?.display;
const contextValueMode = display?.contextValue ?? "percent";
const contextValue = formatContextValue(ctx, percent, contextValueMode);
const contextValueDisplay = `${getContextColor(percent, colors)}${contextValue}${RESET}`;
let line = display?.showContextBar !== false
? `${label(t("label.context"), colors)} ${coloredBar(percent, getAdaptiveBarWidth(), colors)} ${contextValueDisplay}`
: `${label(t("label.context"), colors)} ${contextValueDisplay}`;
if (display?.showTokenBreakdown !== false && percent >= 85) {
const usage = ctx.stdin.context_window?.current_usage;
if (usage) {
const input = formatTokens(usage.input_tokens ?? 0);
const cache = formatTokens((usage.cache_creation_input_tokens ?? 0) +
(usage.cache_read_input_tokens ?? 0));
line += label(` (${t("format.in")}: ${input}, ${t("format.cache")}: ${cache})`, colors);
}
}
return line;
}
function formatTokens(n) {
if (n >= 1000000) {
return `${(n / 1000000).toFixed(1)}M`;
}
if (n >= 1000) {
return `${(n / 1000).toFixed(0)}k`;
}
return n.toString();
}
function formatContextValue(ctx, percent, mode) {
const totalTokens = getTotalTokens(ctx.stdin);
const size = ctx.stdin.context_window?.context_window_size ?? 0;
if (mode === "tokens") {
if (size > 0) {
return `${formatTokens(totalTokens)}/${formatTokens(size)}`;
}
return formatTokens(totalTokens);
}
if (mode === "both") {
if (size > 0) {
return `${percent}% (${formatTokens(totalTokens)}/${formatTokens(size)})`;
}
return `${percent}%`;
}
if (mode === "remaining") {
return `${Math.max(0, 100 - percent)}%`;
}
return `${percent}%`;
}
//# sourceMappingURL=identity.js.map