- Copy complete source code packages from original CodeNomad project - Add root package.json with npm workspace configuration - Include electron-app, server, ui, tauri-app, and opencode-config packages - Fix Launch-Windows.bat and Launch-Dev-Windows.bat to work with correct npm scripts - Fix Launch-Unix.sh to work with correct npm scripts - Launchers now correctly call npm run dev:electron which launches Electron app
66 lines
2.0 KiB
TypeScript
66 lines
2.0 KiB
TypeScript
import { BrowserWindow, dialog, ipcMain, type OpenDialogOptions } from "electron"
|
|
import type { CliProcessManager, CliStatus } from "./process-manager"
|
|
|
|
interface DialogOpenRequest {
|
|
mode: "directory" | "file"
|
|
title?: string
|
|
defaultPath?: string
|
|
filters?: Array<{ name?: string; extensions: string[] }>
|
|
}
|
|
|
|
interface DialogOpenResult {
|
|
canceled: boolean
|
|
paths: string[]
|
|
}
|
|
|
|
export function setupCliIPC(mainWindow: BrowserWindow, cliManager: CliProcessManager) {
|
|
cliManager.on("status", (status: CliStatus) => {
|
|
if (!mainWindow.isDestroyed()) {
|
|
mainWindow.webContents.send("cli:status", status)
|
|
}
|
|
})
|
|
|
|
cliManager.on("ready", (status: CliStatus) => {
|
|
if (!mainWindow.isDestroyed()) {
|
|
mainWindow.webContents.send("cli:ready", status)
|
|
}
|
|
})
|
|
|
|
cliManager.on("error", (error: Error) => {
|
|
if (!mainWindow.isDestroyed()) {
|
|
mainWindow.webContents.send("cli:error", { message: error.message })
|
|
}
|
|
})
|
|
|
|
ipcMain.handle("cli:getStatus", async () => cliManager.getStatus())
|
|
|
|
ipcMain.handle("cli:restart", async () => {
|
|
const devMode = process.env.NODE_ENV === "development"
|
|
await cliManager.stop()
|
|
return cliManager.start({ dev: devMode })
|
|
})
|
|
|
|
ipcMain.handle("dialog:open", async (_, request: DialogOpenRequest): Promise<DialogOpenResult> => {
|
|
const properties: OpenDialogOptions["properties"] =
|
|
request.mode === "directory" ? ["openDirectory", "createDirectory"] : ["openFile"]
|
|
|
|
const filters = request.filters?.map((filter) => ({
|
|
name: filter.name ?? "Files",
|
|
extensions: filter.extensions,
|
|
}))
|
|
|
|
const windowTarget = mainWindow.isDestroyed() ? undefined : mainWindow
|
|
const dialogOptions: OpenDialogOptions = {
|
|
title: request.title,
|
|
defaultPath: request.defaultPath,
|
|
properties,
|
|
filters,
|
|
}
|
|
const result = windowTarget
|
|
? await dialog.showOpenDialog(windowTarget, dialogOptions)
|
|
: await dialog.showOpenDialog(dialogOptions)
|
|
|
|
return { canceled: result.canceled, paths: result.filePaths }
|
|
})
|
|
}
|