Vendor all 4 Pi packages (tui, ai, agent-core, coding-agent) from pi-mono v0.57.1 as @gsd/* workspace packages under packages/. This replaces the compiled npm dependency (@mariozechner/pi-coding-agent) and patch-package workflow, giving direct source access for modifications. - Copy Pi source from pi-mono v0.57.1 into packages/ - Create workspace package.json + tsconfig.json for each package - Rename ~240 imports from @mariozechner/pi-* to @gsd/pi-* - Apply existing patches as source edits (setModel persist, VT input) - Remove @mariozechner/pi-coding-agent dep and patch-package - Update build pipeline to build packages in dependency order - Add pi-upstream git remote for future selective syncing Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
/**
|
|
* TUI config selector for `pi config` command
|
|
*/
|
|
|
|
import { ProcessTerminal, TUI } from "@gsd/pi-tui";
|
|
import type { ResolvedPaths } from "../core/package-manager.js";
|
|
import type { SettingsManager } from "../core/settings-manager.js";
|
|
import { ConfigSelectorComponent } from "../modes/interactive/components/config-selector.js";
|
|
import { initTheme, stopThemeWatcher } from "../modes/interactive/theme/theme.js";
|
|
|
|
export interface ConfigSelectorOptions {
|
|
resolvedPaths: ResolvedPaths;
|
|
settingsManager: SettingsManager;
|
|
cwd: string;
|
|
agentDir: string;
|
|
}
|
|
|
|
/** Show TUI config selector and return when closed */
|
|
export async function selectConfig(options: ConfigSelectorOptions): Promise<void> {
|
|
// Initialize theme before showing TUI
|
|
initTheme(options.settingsManager.getTheme(), true);
|
|
|
|
return new Promise((resolve) => {
|
|
const ui = new TUI(new ProcessTerminal());
|
|
let resolved = false;
|
|
|
|
const selector = new ConfigSelectorComponent(
|
|
options.resolvedPaths,
|
|
options.settingsManager,
|
|
options.cwd,
|
|
options.agentDir,
|
|
() => {
|
|
if (!resolved) {
|
|
resolved = true;
|
|
ui.stop();
|
|
stopThemeWatcher();
|
|
resolve();
|
|
}
|
|
},
|
|
() => {
|
|
ui.stop();
|
|
stopThemeWatcher();
|
|
process.exit(0);
|
|
},
|
|
() => ui.requestRender(),
|
|
);
|
|
|
|
ui.addChild(selector);
|
|
ui.setFocus(selector.getResourceList());
|
|
ui.start();
|
|
});
|
|
}
|