Files
claude-hud/dist/render/lines/project.js
Jarrod Watts ffef15fc33 feat: redesign default layout to clean 2-line display (#112)
New default: model+project on line 1, context+usage bars combined on line 2.
All optional features (tools, agents, todos) hidden by default with
setup onboarding step to enable them.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-06 13:17:23 +11:00

58 lines
2.5 KiB
JavaScript

import { getModelName, getProviderLabel } from '../../stdin.js';
import { cyan, magenta, yellow } from '../colors.js';
export function renderProjectLine(ctx) {
const display = ctx.config?.display;
const parts = [];
if (display?.showModel !== false) {
const model = getModelName(ctx.stdin);
const providerLabel = getProviderLabel(ctx.stdin);
const planName = display?.showUsage !== false ? ctx.usageData?.planName : undefined;
const planDisplay = providerLabel ?? planName;
const modelDisplay = planDisplay ? `${model} | ${planDisplay}` : model;
parts.push(cyan(`[${modelDisplay}]`));
}
if (ctx.stdin.cwd) {
const segments = ctx.stdin.cwd.split(/[/\\]/).filter(Boolean);
const pathLevels = ctx.config?.pathLevels ?? 1;
const projectPath = segments.length > 0 ? segments.slice(-pathLevels).join('/') : '/';
let gitPart = '';
const gitConfig = ctx.config?.gitStatus;
const showGit = gitConfig?.enabled ?? true;
if (showGit && ctx.gitStatus) {
const gitParts = [ctx.gitStatus.branch];
if ((gitConfig?.showDirty ?? true) && ctx.gitStatus.isDirty) {
gitParts.push('*');
}
if (gitConfig?.showAheadBehind) {
if (ctx.gitStatus.ahead > 0) {
gitParts.push(`${ctx.gitStatus.ahead}`);
}
if (ctx.gitStatus.behind > 0) {
gitParts.push(`${ctx.gitStatus.behind}`);
}
}
if (gitConfig?.showFileStats && ctx.gitStatus.fileStats) {
const { modified, added, deleted, untracked } = ctx.gitStatus.fileStats;
const statParts = [];
if (modified > 0)
statParts.push(`!${modified}`);
if (added > 0)
statParts.push(`+${added}`);
if (deleted > 0)
statParts.push(`${deleted}`);
if (untracked > 0)
statParts.push(`?${untracked}`);
if (statParts.length > 0) {
gitParts.push(` ${statParts.join(' ')}`);
}
}
gitPart = ` ${magenta('git:(')}${cyan(gitParts.join(''))}${magenta(')')}`;
}
parts.push(`${yellow(projectPath)}${gitPart}`);
}
if (parts.length === 0) {
return null;
}
return parts.join(' \u2502 ');
}
//# sourceMappingURL=project.js.map