2026-02-28 20:42:40 +00:00
|
|
|
import { useShallow } from "zustand/react/shallow";
|
2026-02-27 04:29:51 +00:00
|
|
|
import TerminalTabs from "../terminal/TerminalTabs";
|
|
|
|
|
import { useAppState } from "../../store/appState";
|
|
|
|
|
|
|
|
|
|
export default function TopBar() {
|
2026-02-28 20:42:40 +00:00
|
|
|
const { dockerAvailable, imageExists } = useAppState(
|
|
|
|
|
useShallow(s => ({ dockerAvailable: s.dockerAvailable, imageExists: s.imageExists }))
|
|
|
|
|
);
|
2026-02-27 04:29:51 +00:00
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className="flex items-center h-10 bg-[var(--bg-secondary)] border border-[var(--border-color)] rounded-lg overflow-hidden">
|
2026-02-27 10:31:27 -08:00
|
|
|
<div className="flex-1 overflow-x-auto pl-2">
|
2026-02-27 04:29:51 +00:00
|
|
|
<TerminalTabs />
|
|
|
|
|
</div>
|
2026-02-27 10:31:27 -08:00
|
|
|
<div className="flex items-center gap-2 px-4 flex-shrink-0 text-xs text-[var(--text-secondary)]">
|
2026-02-27 04:29:51 +00:00
|
|
|
<StatusDot ok={dockerAvailable === true} label="Docker" />
|
|
|
|
|
<StatusDot ok={imageExists === true} label="Image" />
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function StatusDot({ ok, label }: { ok: boolean; label: string }) {
|
|
|
|
|
return (
|
|
|
|
|
<span className="flex items-center gap-1">
|
|
|
|
|
<span
|
|
|
|
|
className={`inline-block w-2 h-2 rounded-full ${
|
|
|
|
|
ok ? "bg-[var(--success)]" : "bg-[var(--text-secondary)]"
|
|
|
|
|
}`}
|
|
|
|
|
/>
|
|
|
|
|
{label}
|
|
|
|
|
</span>
|
|
|
|
|
);
|
|
|
|
|
}
|