From 0484d97dfbc3b8a2e7878d3ab35a9895decdf467 Mon Sep 17 00:00:00 2001 From: bndw Date: Sat, 28 Feb 2026 21:35:39 -0800 Subject: feat: **1 — `git.ts`:** Add exported `getCurrentBranch` helpe… (+8 more) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - ✅ **1 — `git.ts`:** Add exported `getCurrentBranch` helper after `ensureGitRepo` - ✅ **2a — `ipc/handlers.ts`:** Update git import to include `ensureGitRepo` and `getCurrentBranch` - ✅ **2b — `ipc/handlers.ts`:** Replace `workflow:advance` implement-phase block with branching-toggle logic - ✅ **3 — `GitSettings.tsx`:** Create new settings component with pill toggle - ✅ **4 — `SettingsPage.tsx`:** Add `"git"` section type, import, nav item, content render; fix both unicode glyphs - ✅ **5 — `globals.css`:** Append toggle-row + pill toggle + maximize-btn CSS - ✅ **6 — `index.ts`:** Add `ipcMain` to import; add `window:toggleMaximize` handler + maximize/unmaximize events inside `createWindow()` - ✅ **7 — `preload.ts`:** Add `toggleMaximize` + `onWindowMaximized` to interface and `api` object - ✅ **8 — `Header.tsx`:** Add `isMaximized` state + effect + maximize button in JSX --- renderer/src/components/Header.tsx | 23 ++++++- renderer/src/components/SettingsPage.tsx | 17 ++++-- renderer/src/components/settings/GitSettings.tsx | 78 ++++++++++++++++++++++++ 3 files changed, 113 insertions(+), 5 deletions(-) create mode 100644 renderer/src/components/settings/GitSettings.tsx (limited to 'renderer/src/components') diff --git a/renderer/src/components/Header.tsx b/renderer/src/components/Header.tsx index 3a530d3..1d954ec 100644 --- a/renderer/src/components/Header.tsx +++ b/renderer/src/components/Header.tsx @@ -1,6 +1,8 @@ -import React, { useState } from "react"; +import React, { useState, useEffect } from "react"; import type { Project, Session, Phase } from "../types"; +const api = window.api; + type Theme = "dark" | "light"; interface HeaderProps { @@ -86,6 +88,16 @@ export function Header({ setIsRenamingSession(false); }; + // ── Maximize ───────────────────────────────────────────────── + const [isMaximized, setIsMaximized] = useState(false); + + useEffect(() => { + // Returns the unsubscribe function; React cleanup calls it on unmount. + // On macOS, clicking the native green traffic light also fires this, + // keeping the glyph accurate when native controls are used. + return api.onWindowMaximized(setIsMaximized); + }, []); + // ── Branch copy ────────────────────────────────────────────── const [copied, setCopied] = useState(false); @@ -225,6 +237,15 @@ export function Header({ {theme === "dark" ? "[light]" : "[dark]"} + {/* ── Maximize toggle ── */} + + {/* ── Settings button ── */} @@ -38,12 +39,20 @@ export function SettingsPage({ onClose }: SettingsPageProps) { > System Prompts - {/* Future sections added here */} + {/* Content */}
{activeSection === "system-prompts" && } + {activeSection === "git" && }
diff --git a/renderer/src/components/settings/GitSettings.tsx b/renderer/src/components/settings/GitSettings.tsx new file mode 100644 index 0000000..0ec9875 --- /dev/null +++ b/renderer/src/components/settings/GitSettings.tsx @@ -0,0 +1,78 @@ +import React, { useState, useEffect } from "react"; + +const api = window.api; + +export function GitSettings() { + // null = setting not yet loaded; true/false = loaded value + const [branchingEnabled, setBranchingEnabled] = useState(null); + const [saveStatus, setSaveStatus] = useState<"idle" | "saved">("idle"); + + useEffect(() => { + api.getSettings(["git.branchingEnabled"]).then((settings) => { + // Key absent or any value other than "true" → false (opt-in default) + setBranchingEnabled(settings["git.branchingEnabled"] === "true"); + }); + }, []); + + const handleToggle = async (enabled: boolean) => { + setBranchingEnabled(enabled); + if (enabled) { + await api.setSetting("git.branchingEnabled", "true"); + } else { + await api.deleteSetting("git.branchingEnabled"); + } + setSaveStatus("saved"); + setTimeout(() => setSaveStatus("idle"), 1500); + }; + + if (branchingEnabled === null) { + return ( +
+ Loading... +
+ ); + } + + return ( +
+
Git
+
+ Configure how Claude Flow interacts with your project's git repository + during the implement phase. +
+ +
+ + {saveStatus === "saved" && ( + + saved ✓ + + )} +
+
+ ); +} -- cgit v1.2.3