* TitleBar Component
* macOS: empty drag region (native traffic lights handled by hiddenInset).
* Windows: drag region with custom minimize/maximize/close controls; uses
* `bg-surface-sidebar` so the frameless strip matches the sidebar rail.
* Linux: use native window chrome (no custom title bar).
*/
import { useState, useEffect } from 'react';
import { Minus, Square, X, Copy } from 'lucide-react';
import { invokeIpc } from '@/lib/api-client';
export function TitleBar() {
const platform = window.electron?.platform;
if (platform === 'darwin') {
return null;
}
if (platform !== 'win32') {
return null;
}
return <WindowsTitleBar />;
}
function WindowsTitleBar() {
const [maximized, setMaximized] = useState(false);
useEffect(() => {
invokeIpc('window:isMaximized').then((val) => {
setMaximized(val as boolean);
});
}, []);
const handleMinimize = () => {
invokeIpc('window:minimize');
};
const handleMaximize = () => {
invokeIpc('window:maximize').then(() => {
invokeIpc('window:isMaximized').then((val) => {
setMaximized(val as boolean);
});
});
};
const handleClose = () => {
invokeIpc('window:close');
};
return (
<div
data-testid="windows-titlebar"
className="drag-region flex h-10 shrink-0 items-center justify-end bg-surface-sidebar"
>
{/* Right: Window Controls */}
<div className="no-drag flex h-full">
<button
onClick={handleMinimize}
className="flex h-full w-11 items-center justify-center text-muted-foreground hover:bg-accent transition-colors"
title="Minimize"
>
<Minus className="h-4 w-4" />
</button>
<button
onClick={handleMaximize}
className="flex h-full w-11 items-center justify-center text-muted-foreground hover:bg-accent transition-colors"
title={maximized ? 'Restore' : 'Maximize'}
>
{maximized ? <Copy className="h-3.5 w-3.5" /> : <Square className="h-3.5 w-3.5" />}
</button>
<button
onClick={handleClose}
className="flex h-full w-11 items-center justify-center text-muted-foreground hover:bg-red-500 hover:text-white transition-colors"
title="Close"
>
<X className="h-4 w-4" />
</button>
</div>
</div>
);
}