summaryrefslogtreecommitdiff
path: root/makima/frontend/src
diff options
context:
space:
mode:
authorsoryu <soryu@soryu.co>2026-01-18 19:17:03 +0000
committersoryu <soryu@soryu.co>2026-01-18 19:17:03 +0000
commitd5d3502a40ecc302bb21e91bccda8c8a4a7b6d6d (patch)
tree440a48721ce5907a53fe9609c076dd6cd1c66f6a /makima/frontend/src
parentae9819b5ba1a0beb52acf558c3dd6b59a6c25a5e (diff)
parenta7670b20bfb44802b6b03b03065ab2817e3b9a44 (diff)
downloadsoryu-d5d3502a40ecc302bb21e91bccda8c8a4a7b6d6d.tar.gz
soryu-d5d3502a40ecc302bb21e91bccda8c8a4a7b6d6d.zip
Merge: Add supervisor task button on board page
Diffstat (limited to 'makima/frontend/src')
-rw-r--r--makima/frontend/src/components/workflow/WorkflowContractCard.tsx26
-rw-r--r--makima/frontend/src/lib/api.ts2
2 files changed, 25 insertions, 3 deletions
diff --git a/makima/frontend/src/components/workflow/WorkflowContractCard.tsx b/makima/frontend/src/components/workflow/WorkflowContractCard.tsx
index e6c8a1c..61e6d17 100644
--- a/makima/frontend/src/components/workflow/WorkflowContractCard.tsx
+++ b/makima/frontend/src/components/workflow/WorkflowContractCard.tsx
@@ -1,3 +1,4 @@
+import { useNavigate } from "react-router";
import type { ContractSummary, ContractStatus } from "../../lib/api";
interface WorkflowContractCardProps {
@@ -17,8 +18,16 @@ export function WorkflowContractCard({
onClick,
onDragStart,
}: WorkflowContractCardProps) {
+ const navigate = useNavigate();
const status = statusConfig[contract.status] || statusConfig.active;
+ const handleSupervisorClick = (e: React.MouseEvent) => {
+ e.stopPropagation();
+ if (contract.supervisorTaskId) {
+ navigate(`/mesh/${contract.supervisorTaskId}`);
+ }
+ };
+
return (
<div
draggable
@@ -26,9 +35,20 @@ export function WorkflowContractCard({
onClick={onClick}
className="p-3 bg-[rgba(9,13,20,0.8)] border border-[rgba(117,170,252,0.2)] hover:border-[rgba(117,170,252,0.4)] cursor-pointer transition-colors select-none"
>
- {/* Name */}
- <div className="font-mono text-sm text-[#dbe7ff] truncate mb-1">
- {contract.name}
+ {/* Header row with name and supervisor button */}
+ <div className="flex items-center justify-between gap-2 mb-1">
+ <div className="font-mono text-sm text-[#dbe7ff] truncate flex-1">
+ {contract.name}
+ </div>
+ {contract.supervisorTaskId && (
+ <button
+ onClick={handleSupervisorClick}
+ title="Open Supervisor Task"
+ className="flex-shrink-0 px-1.5 py-0.5 font-mono text-[10px] text-[#75aafc] hover:text-[#9bc3ff] border border-[rgba(117,170,252,0.25)] hover:border-[#3f6fb3] hover:bg-[rgba(117,170,252,0.1)] transition-colors"
+ >
+ ▶
+ </button>
+ )}
</div>
{/* Status and counts row */}
diff --git a/makima/frontend/src/lib/api.ts b/makima/frontend/src/lib/api.ts
index 4652347..8393d34 100644
--- a/makima/frontend/src/lib/api.ts
+++ b/makima/frontend/src/lib/api.ts
@@ -1462,6 +1462,8 @@ export interface ContractSummary {
contractType: ContractType;
phase: ContractPhase;
status: ContractStatus;
+ /** Supervisor task ID for contract orchestration */
+ supervisorTaskId: string | null;
fileCount: number;
taskCount: number;
repositoryCount: number;