mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-02-01 08:13:37 +00:00
Add a new interactive graph view alongside the kanban board for visualizing task dependencies. The graph view uses React Flow with dagre auto-layout to display tasks as nodes connected by dependency edges. Key features: - Toggle between kanban and graph view via new control buttons - Custom TaskNode component matching existing card styling/themes - Animated edges that flow when tasks are in progress - Status-aware node colors (backlog, in-progress, waiting, verified) - Blocked tasks show lock icon with dependency count tooltip - MiniMap for navigation in large graphs - Zoom, pan, fit-view, and lock controls - Horizontal/vertical layout options via dagre - Click node to view details, double-click to edit - Respects all 32 themes via CSS variables - Reduced motion support for animations New dependencies: @xyflow/react, dagre
186 lines
6.4 KiB
TypeScript
186 lines
6.4 KiB
TypeScript
import { Button } from '@/components/ui/button';
|
|
import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '@/components/ui/tooltip';
|
|
import { ImageIcon, Archive, Minimize2, Square, Maximize2, Columns3, Network } from 'lucide-react';
|
|
import { cn } from '@/lib/utils';
|
|
import { BoardViewMode } from '@/store/app-store';
|
|
|
|
interface BoardControlsProps {
|
|
isMounted: boolean;
|
|
onShowBoardBackground: () => void;
|
|
onShowCompletedModal: () => void;
|
|
completedCount: number;
|
|
kanbanCardDetailLevel: 'minimal' | 'standard' | 'detailed';
|
|
onDetailLevelChange: (level: 'minimal' | 'standard' | 'detailed') => void;
|
|
boardViewMode: BoardViewMode;
|
|
onBoardViewModeChange: (mode: BoardViewMode) => void;
|
|
}
|
|
|
|
export function BoardControls({
|
|
isMounted,
|
|
onShowBoardBackground,
|
|
onShowCompletedModal,
|
|
completedCount,
|
|
kanbanCardDetailLevel,
|
|
onDetailLevelChange,
|
|
boardViewMode,
|
|
onBoardViewModeChange,
|
|
}: BoardControlsProps) {
|
|
if (!isMounted) return null;
|
|
|
|
return (
|
|
<TooltipProvider>
|
|
<div className="flex items-center gap-2 ml-4">
|
|
{/* View Mode Toggle - Kanban / Graph */}
|
|
<div
|
|
className="flex items-center rounded-lg bg-secondary border border-border"
|
|
data-testid="view-mode-toggle"
|
|
>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<button
|
|
onClick={() => onBoardViewModeChange('kanban')}
|
|
className={cn(
|
|
'p-2 rounded-l-lg transition-colors',
|
|
boardViewMode === 'kanban'
|
|
? 'bg-brand-500/20 text-brand-500'
|
|
: 'text-muted-foreground hover:text-foreground hover:bg-accent'
|
|
)}
|
|
data-testid="view-mode-kanban"
|
|
>
|
|
<Columns3 className="w-4 h-4" />
|
|
</button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Kanban Board View</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<button
|
|
onClick={() => onBoardViewModeChange('graph')}
|
|
className={cn(
|
|
'p-2 rounded-r-lg transition-colors',
|
|
boardViewMode === 'graph'
|
|
? 'bg-brand-500/20 text-brand-500'
|
|
: 'text-muted-foreground hover:text-foreground hover:bg-accent'
|
|
)}
|
|
data-testid="view-mode-graph"
|
|
>
|
|
<Network className="w-4 h-4" />
|
|
</button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Dependency Graph View</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
</div>
|
|
|
|
{/* Board Background Button */}
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button
|
|
variant="outline"
|
|
size="sm"
|
|
onClick={onShowBoardBackground}
|
|
className="h-8 px-2"
|
|
data-testid="board-background-button"
|
|
>
|
|
<ImageIcon className="w-4 h-4" />
|
|
</Button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Board Background Settings</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
|
|
{/* Completed/Archived Features Button */}
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button
|
|
variant="outline"
|
|
size="sm"
|
|
onClick={onShowCompletedModal}
|
|
className="h-8 px-2 relative"
|
|
data-testid="completed-features-button"
|
|
>
|
|
<Archive className="w-4 h-4" />
|
|
{completedCount > 0 && (
|
|
<span className="absolute -top-1 -right-1 bg-brand-500 text-white text-[10px] font-bold rounded-full w-4 h-4 flex items-center justify-center">
|
|
{completedCount > 99 ? '99+' : completedCount}
|
|
</span>
|
|
)}
|
|
</Button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Completed Features ({completedCount})</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
|
|
{/* Kanban Card Detail Level Toggle */}
|
|
<div
|
|
className="flex items-center rounded-lg bg-secondary border border-border"
|
|
data-testid="kanban-detail-toggle"
|
|
>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<button
|
|
onClick={() => onDetailLevelChange('minimal')}
|
|
className={cn(
|
|
'p-2 rounded-l-lg transition-colors',
|
|
kanbanCardDetailLevel === 'minimal'
|
|
? 'bg-brand-500/20 text-brand-500'
|
|
: 'text-muted-foreground hover:text-foreground hover:bg-accent'
|
|
)}
|
|
data-testid="kanban-toggle-minimal"
|
|
>
|
|
<Minimize2 className="w-4 h-4" />
|
|
</button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Minimal - Title & category only</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<button
|
|
onClick={() => onDetailLevelChange('standard')}
|
|
className={cn(
|
|
'p-2 transition-colors',
|
|
kanbanCardDetailLevel === 'standard'
|
|
? 'bg-brand-500/20 text-brand-500'
|
|
: 'text-muted-foreground hover:text-foreground hover:bg-accent'
|
|
)}
|
|
data-testid="kanban-toggle-standard"
|
|
>
|
|
<Square className="w-4 h-4" />
|
|
</button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Standard - Steps & progress</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<button
|
|
onClick={() => onDetailLevelChange('detailed')}
|
|
className={cn(
|
|
'p-2 rounded-r-lg transition-colors',
|
|
kanbanCardDetailLevel === 'detailed'
|
|
? 'bg-brand-500/20 text-brand-500'
|
|
: 'text-muted-foreground hover:text-foreground hover:bg-accent'
|
|
)}
|
|
data-testid="kanban-toggle-detailed"
|
|
>
|
|
<Maximize2 className="w-4 h-4" />
|
|
</button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Detailed - Model, tools & tasks</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
</div>
|
|
</div>
|
|
</TooltipProvider>
|
|
);
|
|
}
|