centy 0.0.5 → 0.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +299 -0
- package/bin/run.js +14 -2
- package/dist/commands/install/daemon.d.ts +12 -0
- package/dist/commands/install/daemon.d.ts.map +1 -0
- package/dist/commands/install/daemon.js +41 -0
- package/dist/commands/install/daemon.js.map +1 -0
- package/dist/commands/shutdown.d.ts.map +1 -1
- package/dist/commands/shutdown.js +5 -0
- package/dist/commands/shutdown.js.map +1 -1
- package/dist/commands/start.d.ts +13 -0
- package/dist/commands/start.d.ts.map +1 -0
- package/dist/commands/start.js +79 -0
- package/dist/commands/start.js.map +1 -0
- package/dist/hooks/prerun.js +1 -1
- package/dist/hooks/prerun.js.map +1 -1
- package/dist/lib/install-daemon/checksum.d.ts +2 -0
- package/dist/lib/install-daemon/checksum.d.ts.map +1 -0
- package/dist/lib/install-daemon/checksum.js +31 -0
- package/dist/lib/install-daemon/checksum.js.map +1 -0
- package/dist/lib/install-daemon/download.d.ts +8 -0
- package/dist/lib/install-daemon/download.d.ts.map +1 -0
- package/dist/lib/install-daemon/download.js +40 -0
- package/dist/lib/install-daemon/download.js.map +1 -0
- package/dist/lib/install-daemon/errors.d.ts +23 -0
- package/dist/lib/install-daemon/errors.d.ts.map +1 -0
- package/dist/lib/install-daemon/errors.js +42 -0
- package/dist/lib/install-daemon/errors.js.map +1 -0
- package/dist/lib/install-daemon/extract.d.ts +2 -0
- package/dist/lib/install-daemon/extract.d.ts.map +1 -0
- package/dist/lib/install-daemon/extract.js +38 -0
- package/dist/lib/install-daemon/extract.js.map +1 -0
- package/dist/lib/install-daemon/github-api.d.ts +9 -0
- package/dist/lib/install-daemon/github-api.d.ts.map +1 -0
- package/dist/lib/install-daemon/github-api.js +60 -0
- package/dist/lib/install-daemon/github-api.js.map +1 -0
- package/dist/lib/install-daemon/index.d.ts +3 -0
- package/dist/lib/install-daemon/index.d.ts.map +1 -0
- package/dist/lib/install-daemon/index.js +2 -0
- package/dist/lib/install-daemon/index.js.map +1 -0
- package/dist/lib/install-daemon/install-daemon.d.ts +3 -0
- package/dist/lib/install-daemon/install-daemon.d.ts.map +1 -0
- package/dist/lib/install-daemon/install-daemon.js +100 -0
- package/dist/lib/install-daemon/install-daemon.js.map +1 -0
- package/dist/lib/install-daemon/platform.d.ts +3 -0
- package/dist/lib/install-daemon/platform.d.ts.map +1 -0
- package/dist/lib/install-daemon/platform.js +24 -0
- package/dist/lib/install-daemon/platform.js.map +1 -0
- package/dist/lib/install-daemon/types.d.ts +34 -0
- package/dist/lib/install-daemon/types.d.ts.map +1 -0
- package/dist/lib/install-daemon/types.js +7 -0
- package/dist/lib/install-daemon/types.js.map +1 -0
- package/dist/lib/start/daemon-binary-exists.d.ts +2 -0
- package/dist/lib/start/daemon-binary-exists.d.ts.map +1 -0
- package/dist/lib/start/daemon-binary-exists.js +10 -0
- package/dist/lib/start/daemon-binary-exists.js.map +1 -0
- package/dist/lib/start/find-daemon-binary.d.ts +2 -0
- package/dist/lib/start/find-daemon-binary.d.ts.map +1 -0
- package/dist/lib/start/find-daemon-binary.js +31 -0
- package/dist/lib/start/find-daemon-binary.js.map +1 -0
- package/dist/lib/start/wait-for-daemon.d.ts +7 -0
- package/dist/lib/start/wait-for-daemon.d.ts.map +1 -0
- package/dist/lib/start/wait-for-daemon.js +20 -0
- package/dist/lib/start/wait-for-daemon.js.map +1 -0
- package/dist/tui/App.d.ts +6 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +64 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/components/domain/DaemonPanel.d.ts +2 -0
- package/dist/tui/components/domain/DaemonPanel.d.ts.map +1 -0
- package/dist/tui/components/domain/DaemonPanel.js +35 -0
- package/dist/tui/components/domain/DaemonPanel.js.map +1 -0
- package/dist/tui/components/domain/IssueList.d.ts +2 -0
- package/dist/tui/components/domain/IssueList.d.ts.map +1 -0
- package/dist/tui/components/domain/IssueList.js +52 -0
- package/dist/tui/components/domain/IssueList.js.map +1 -0
- package/dist/tui/components/domain/ProjectList.d.ts +2 -0
- package/dist/tui/components/domain/ProjectList.d.ts.map +1 -0
- package/dist/tui/components/domain/ProjectList.js +54 -0
- package/dist/tui/components/domain/ProjectList.js.map +1 -0
- package/dist/tui/components/layout/Header.d.ts +7 -0
- package/dist/tui/components/layout/Header.d.ts.map +1 -0
- package/dist/tui/components/layout/Header.js +7 -0
- package/dist/tui/components/layout/Header.js.map +1 -0
- package/dist/tui/components/layout/MainPanel.d.ts +8 -0
- package/dist/tui/components/layout/MainPanel.d.ts.map +1 -0
- package/dist/tui/components/layout/MainPanel.js +5 -0
- package/dist/tui/components/layout/MainPanel.js.map +1 -0
- package/dist/tui/components/layout/Sidebar.d.ts +9 -0
- package/dist/tui/components/layout/Sidebar.d.ts.map +1 -0
- package/dist/tui/components/layout/Sidebar.js +11 -0
- package/dist/tui/components/layout/Sidebar.js.map +1 -0
- package/dist/tui/components/layout/StatusBar.d.ts +11 -0
- package/dist/tui/components/layout/StatusBar.d.ts.map +1 -0
- package/dist/tui/components/layout/StatusBar.js +8 -0
- package/dist/tui/components/layout/StatusBar.js.map +1 -0
- package/dist/tui/hooks/useDaemonActions.d.ts +12 -0
- package/dist/tui/hooks/useDaemonActions.d.ts.map +1 -0
- package/dist/tui/hooks/useDaemonActions.js +77 -0
- package/dist/tui/hooks/useDaemonActions.js.map +1 -0
- package/dist/tui/hooks/useDaemonConnection.d.ts +5 -0
- package/dist/tui/hooks/useDaemonConnection.d.ts.map +1 -0
- package/dist/tui/hooks/useDaemonConnection.js +24 -0
- package/dist/tui/hooks/useDaemonConnection.js.map +1 -0
- package/dist/tui/hooks/useDaemonInfo.d.ts +10 -0
- package/dist/tui/hooks/useDaemonInfo.d.ts.map +1 -0
- package/dist/tui/hooks/useDaemonInfo.js +26 -0
- package/dist/tui/hooks/useDaemonInfo.js.map +1 -0
- package/dist/tui/hooks/useIssues.d.ts +8 -0
- package/dist/tui/hooks/useIssues.d.ts.map +1 -0
- package/dist/tui/hooks/useIssues.js +36 -0
- package/dist/tui/hooks/useIssues.js.map +1 -0
- package/dist/tui/hooks/useNavigation.d.ts +11 -0
- package/dist/tui/hooks/useNavigation.d.ts.map +1 -0
- package/dist/tui/hooks/useNavigation.js +24 -0
- package/dist/tui/hooks/useNavigation.js.map +1 -0
- package/dist/tui/hooks/useProjects.d.ts +8 -0
- package/dist/tui/hooks/useProjects.d.ts.map +1 -0
- package/dist/tui/hooks/useProjects.js +36 -0
- package/dist/tui/hooks/useProjects.js.map +1 -0
- package/dist/tui/index.d.ts +2 -0
- package/dist/tui/index.d.ts.map +1 -0
- package/dist/tui/index.js +39 -0
- package/dist/tui/index.js.map +1 -0
- package/dist/tui/services/daemon-service.d.ts +28 -0
- package/dist/tui/services/daemon-service.d.ts.map +1 -0
- package/dist/tui/services/daemon-service.js +107 -0
- package/dist/tui/services/daemon-service.js.map +1 -0
- package/dist/tui/state/app-state.d.ts +78 -0
- package/dist/tui/state/app-state.d.ts.map +1 -0
- package/dist/tui/state/app-state.js +93 -0
- package/dist/tui/state/app-state.js.map +1 -0
- package/dist/tui/types/views.d.ts +11 -0
- package/dist/tui/types/views.d.ts.map +1 -0
- package/dist/tui/types/views.js +25 -0
- package/dist/tui/types/views.js.map +1 -0
- package/oclif.manifest.json +83 -1
- package/package.json +10 -3
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { useCallback, useEffect } from 'react';
|
|
2
|
+
import { useAppState } from '../state/app-state.js';
|
|
3
|
+
import { daemonService } from '../services/daemon-service.js';
|
|
4
|
+
export function useProjects() {
|
|
5
|
+
const { state, dispatch } = useAppState();
|
|
6
|
+
const loadProjects = useCallback(async () => {
|
|
7
|
+
if (!state.daemonConnected)
|
|
8
|
+
return;
|
|
9
|
+
dispatch({ type: 'SET_LOADING', loading: true });
|
|
10
|
+
const result = await daemonService.listProjects(true);
|
|
11
|
+
dispatch({ type: 'SET_LOADING', loading: false });
|
|
12
|
+
if (result.success && result.data) {
|
|
13
|
+
dispatch({ type: 'SET_PROJECTS', projects: result.data });
|
|
14
|
+
}
|
|
15
|
+
else if (result.error) {
|
|
16
|
+
dispatch({ type: 'SET_ERROR', error: result.error });
|
|
17
|
+
}
|
|
18
|
+
}, [state.daemonConnected, dispatch]);
|
|
19
|
+
const selectProject = useCallback((path) => {
|
|
20
|
+
dispatch({ type: 'SELECT_PROJECT', path });
|
|
21
|
+
}, [dispatch]);
|
|
22
|
+
// Load projects when daemon connects
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (state.daemonConnected && state.projects.length === 0) {
|
|
25
|
+
loadProjects();
|
|
26
|
+
}
|
|
27
|
+
}, [state.daemonConnected, state.projects.length, loadProjects]);
|
|
28
|
+
return {
|
|
29
|
+
projects: state.projects,
|
|
30
|
+
selectedProjectPath: state.selectedProjectPath,
|
|
31
|
+
isLoading: state.isLoading,
|
|
32
|
+
loadProjects,
|
|
33
|
+
selectProject,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=useProjects.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useProjects.js","sourceRoot":"","sources":["../../../src/tui/hooks/useProjects.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAA;AAE7D,MAAM,UAAU,WAAW;IACzB,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,WAAW,EAAE,CAAA;IAEzC,MAAM,YAAY,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAC1C,IAAI,CAAC,KAAK,CAAC,eAAe;YAAE,OAAM;QAElC,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAChD,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;QACrD,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAA;QAEjD,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;YAClC,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;QAC3D,CAAC;aAAM,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;YACxB,QAAQ,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAA;QACtD,CAAC;IACH,CAAC,EAAE,CAAC,KAAK,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC,CAAA;IAErC,MAAM,aAAa,GAAG,WAAW,CAC/B,CAAC,IAAY,EAAE,EAAE;QACf,QAAQ,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC,CAAA;IAC5C,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,qCAAqC;IACrC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,KAAK,CAAC,eAAe,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzD,YAAY,EAAE,CAAA;QAChB,CAAC;IACH,CAAC,EAAE,CAAC,KAAK,CAAC,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAA;IAEhE,OAAO;QACL,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;QAC9C,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,YAAY;QACZ,aAAa;KACd,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tui/index.ts"],"names":[],"mappings":"AAOA,wBAAsB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC,CAwC9C"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { createCliRenderer } from '@opentui/core';
|
|
2
|
+
import { createRoot } from '@opentui/react';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { App } from './App.js';
|
|
5
|
+
import { AppProvider } from './state/app-state.js';
|
|
6
|
+
import { checkDaemonConnection } from '../daemon/check-daemon-connection.js';
|
|
7
|
+
export async function startTUI() {
|
|
8
|
+
// Check daemon connection first
|
|
9
|
+
const connectionStatus = await checkDaemonConnection();
|
|
10
|
+
if (!connectionStatus.connected) {
|
|
11
|
+
console.log('\x1b[33mWarning: Centy daemon is not running.\x1b[0m');
|
|
12
|
+
console.log('Some features will be unavailable.');
|
|
13
|
+
console.log('Run "centy start" to start the daemon.\n');
|
|
14
|
+
}
|
|
15
|
+
// Create renderer
|
|
16
|
+
const renderer = await createCliRenderer({
|
|
17
|
+
useAlternateScreen: true,
|
|
18
|
+
exitOnCtrlC: false,
|
|
19
|
+
});
|
|
20
|
+
// Create React root
|
|
21
|
+
const root = createRoot(renderer);
|
|
22
|
+
// Exit handler
|
|
23
|
+
const handleExit = () => {
|
|
24
|
+
root.unmount();
|
|
25
|
+
renderer.destroy();
|
|
26
|
+
process.exit(0);
|
|
27
|
+
};
|
|
28
|
+
// Render the app
|
|
29
|
+
root.render(React.createElement(AppProvider, {
|
|
30
|
+
initialDaemonConnected: connectionStatus.connected,
|
|
31
|
+
children: React.createElement(App, { onExit: handleExit }),
|
|
32
|
+
}));
|
|
33
|
+
// Start the renderer
|
|
34
|
+
renderer.start();
|
|
35
|
+
// Handle process signals
|
|
36
|
+
process.on('SIGINT', handleExit);
|
|
37
|
+
process.on('SIGTERM', handleExit);
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tui/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAoB,MAAM,eAAe,CAAA;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAC3C,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAA;AAC9B,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAA;AAE5E,MAAM,CAAC,KAAK,UAAU,QAAQ;IAC5B,gCAAgC;IAChC,MAAM,gBAAgB,GAAG,MAAM,qBAAqB,EAAE,CAAA;IAEtD,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC;QAChC,OAAO,CAAC,GAAG,CAAC,sDAAsD,CAAC,CAAA;QACnE,OAAO,CAAC,GAAG,CAAC,oCAAoC,CAAC,CAAA;QACjD,OAAO,CAAC,GAAG,CAAC,0CAA0C,CAAC,CAAA;IACzD,CAAC;IAED,kBAAkB;IAClB,MAAM,QAAQ,GAAgB,MAAM,iBAAiB,CAAC;QACpD,kBAAkB,EAAE,IAAI;QACxB,WAAW,EAAE,KAAK;KACnB,CAAC,CAAA;IAEF,oBAAoB;IACpB,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAA;IAEjC,eAAe;IACf,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,IAAI,CAAC,OAAO,EAAE,CAAA;QACd,QAAQ,CAAC,OAAO,EAAE,CAAA;QAClB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC,CAAA;IAED,iBAAiB;IACjB,IAAI,CAAC,MAAM,CACT,KAAK,CAAC,aAAa,CAAC,WAAW,EAAE;QAC/B,sBAAsB,EAAE,gBAAgB,CAAC,SAAS;QAClD,QAAQ,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;KAC3D,CAAC,CACH,CAAA;IAED,qBAAqB;IACrB,QAAQ,CAAC,KAAK,EAAE,CAAA;IAEhB,yBAAyB;IACzB,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAA;IAChC,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,UAAU,CAAC,CAAA;AACnC,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified daemon service layer for TUI
|
|
3
|
+
* Wraps existing daemon functions with a cleaner API
|
|
4
|
+
*/
|
|
5
|
+
import type { ProjectInfo, Issue, Doc, Config, DaemonInfo, ShutdownResponse, RestartResponse } from '../../daemon/types.js';
|
|
6
|
+
export interface DaemonServiceResult<T> {
|
|
7
|
+
success: boolean;
|
|
8
|
+
data?: T;
|
|
9
|
+
error?: string;
|
|
10
|
+
}
|
|
11
|
+
export declare class DaemonService {
|
|
12
|
+
checkConnection(): Promise<{
|
|
13
|
+
connected: boolean;
|
|
14
|
+
error?: string;
|
|
15
|
+
}>;
|
|
16
|
+
listProjects(includeStale?: boolean): Promise<DaemonServiceResult<ProjectInfo[]>>;
|
|
17
|
+
listIssues(projectPath: string, filters?: {
|
|
18
|
+
status?: string;
|
|
19
|
+
priority?: number;
|
|
20
|
+
}): Promise<DaemonServiceResult<Issue[]>>;
|
|
21
|
+
listDocs(projectPath: string): Promise<DaemonServiceResult<Doc[]>>;
|
|
22
|
+
getConfig(projectPath: string): Promise<DaemonServiceResult<Config>>;
|
|
23
|
+
getDaemonInfo(): Promise<DaemonServiceResult<DaemonInfo>>;
|
|
24
|
+
shutdown(delaySeconds?: number): Promise<DaemonServiceResult<ShutdownResponse>>;
|
|
25
|
+
restart(delaySeconds?: number): Promise<DaemonServiceResult<RestartResponse>>;
|
|
26
|
+
}
|
|
27
|
+
export declare const daemonService: DaemonService;
|
|
28
|
+
//# sourceMappingURL=daemon-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-service.d.ts","sourceRoot":"","sources":["../../../src/tui/services/daemon-service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAUH,OAAO,KAAK,EACV,WAAW,EACX,KAAK,EACL,GAAG,EACH,MAAM,EACN,UAAU,EACV,gBAAgB,EAChB,eAAe,EAChB,MAAM,uBAAuB,CAAA;AAE9B,MAAM,WAAW,mBAAmB,CAAC,CAAC;IACpC,OAAO,EAAE,OAAO,CAAA;IAChB,IAAI,CAAC,EAAE,CAAC,CAAA;IACR,KAAK,CAAC,EAAE,MAAM,CAAA;CACf;AAED,qBAAa,aAAa;IAClB,eAAe,IAAI,OAAO,CAAC;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAIlE,YAAY,CAChB,YAAY,UAAQ,GACnB,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC,CAAC;IAaxC,UAAU,CACd,WAAW,EAAE,MAAM,EACnB,OAAO,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE,GAC/C,OAAO,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CAAC;IAgBlC,QAAQ,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC,GAAG,EAAE,CAAC,CAAC;IAYlE,SAAS,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IAYpE,aAAa,IAAI,OAAO,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;IAazD,QAAQ,CACZ,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;IAa3C,OAAO,CACX,YAAY,CAAC,EAAE,MAAM,GACpB,OAAO,CAAC,mBAAmB,CAAC,eAAe,CAAC,CAAC;CAYjD;AAED,eAAO,MAAM,aAAa,eAAsB,CAAA"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified daemon service layer for TUI
|
|
3
|
+
* Wraps existing daemon functions with a cleaner API
|
|
4
|
+
*/
|
|
5
|
+
import { daemonListProjects } from '../../daemon/daemon-list-projects.js';
|
|
6
|
+
import { daemonListIssues } from '../../daemon/daemon-list-issues.js';
|
|
7
|
+
import { daemonListDocs } from '../../daemon/daemon-list-docs.js';
|
|
8
|
+
import { daemonGetConfig } from '../../daemon/daemon-get-config.js';
|
|
9
|
+
import { daemonGetDaemonInfo } from '../../daemon/daemon-get-daemon-info.js';
|
|
10
|
+
import { daemonShutdown } from '../../daemon/daemon-shutdown.js';
|
|
11
|
+
import { daemonRestart } from '../../daemon/daemon-restart.js';
|
|
12
|
+
import { checkDaemonConnection } from '../../daemon/check-daemon-connection.js';
|
|
13
|
+
export class DaemonService {
|
|
14
|
+
async checkConnection() {
|
|
15
|
+
return checkDaemonConnection();
|
|
16
|
+
}
|
|
17
|
+
async listProjects(includeStale = false) {
|
|
18
|
+
try {
|
|
19
|
+
const response = await daemonListProjects({ includeStale });
|
|
20
|
+
return { success: true, data: response.projects };
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
return {
|
|
24
|
+
success: false,
|
|
25
|
+
error: error instanceof Error ? error.message : 'Failed to list projects',
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
async listIssues(projectPath, filters) {
|
|
30
|
+
try {
|
|
31
|
+
const response = await daemonListIssues({
|
|
32
|
+
projectPath,
|
|
33
|
+
status: filters?.status,
|
|
34
|
+
priority: filters?.priority,
|
|
35
|
+
});
|
|
36
|
+
return { success: true, data: response.issues };
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
return {
|
|
40
|
+
success: false,
|
|
41
|
+
error: error instanceof Error ? error.message : 'Failed to list issues',
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
async listDocs(projectPath) {
|
|
46
|
+
try {
|
|
47
|
+
const response = await daemonListDocs({ projectPath });
|
|
48
|
+
return { success: true, data: response.docs };
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
return {
|
|
52
|
+
success: false,
|
|
53
|
+
error: error instanceof Error ? error.message : 'Failed to list docs',
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
async getConfig(projectPath) {
|
|
58
|
+
try {
|
|
59
|
+
const response = await daemonGetConfig({ projectPath });
|
|
60
|
+
return { success: true, data: response };
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
return {
|
|
64
|
+
success: false,
|
|
65
|
+
error: error instanceof Error ? error.message : 'Failed to get config',
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
async getDaemonInfo() {
|
|
70
|
+
try {
|
|
71
|
+
const response = await daemonGetDaemonInfo({});
|
|
72
|
+
return { success: true, data: response };
|
|
73
|
+
}
|
|
74
|
+
catch (error) {
|
|
75
|
+
return {
|
|
76
|
+
success: false,
|
|
77
|
+
error: error instanceof Error ? error.message : 'Failed to get daemon info',
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
async shutdown(delaySeconds) {
|
|
82
|
+
try {
|
|
83
|
+
const response = await daemonShutdown({ delaySeconds });
|
|
84
|
+
return { success: true, data: response };
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
return {
|
|
88
|
+
success: false,
|
|
89
|
+
error: error instanceof Error ? error.message : 'Failed to shutdown daemon',
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
async restart(delaySeconds) {
|
|
94
|
+
try {
|
|
95
|
+
const response = await daemonRestart({ delaySeconds });
|
|
96
|
+
return { success: true, data: response };
|
|
97
|
+
}
|
|
98
|
+
catch (error) {
|
|
99
|
+
return {
|
|
100
|
+
success: false,
|
|
101
|
+
error: error instanceof Error ? error.message : 'Failed to restart daemon',
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
export const daemonService = new DaemonService();
|
|
107
|
+
//# sourceMappingURL=daemon-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-service.js","sourceRoot":"","sources":["../../../src/tui/services/daemon-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { type ReactNode, type Dispatch } from 'react';
|
|
2
|
+
import type { ViewId, ViewParams } from '../types/views.js';
|
|
3
|
+
import type { Issue, Doc, ProjectInfo, Config, DaemonInfo } from '../../daemon/types.js';
|
|
4
|
+
export interface AppState {
|
|
5
|
+
currentView: ViewId;
|
|
6
|
+
viewParams: ViewParams;
|
|
7
|
+
viewHistory: Array<{
|
|
8
|
+
view: ViewId;
|
|
9
|
+
params: ViewParams;
|
|
10
|
+
}>;
|
|
11
|
+
projects: ProjectInfo[];
|
|
12
|
+
selectedProjectPath: string | null;
|
|
13
|
+
issues: Issue[];
|
|
14
|
+
docs: Doc[];
|
|
15
|
+
config: Config | null;
|
|
16
|
+
daemonInfo: DaemonInfo | null;
|
|
17
|
+
selectedIssueId: string | null;
|
|
18
|
+
selectedDocSlug: string | null;
|
|
19
|
+
sidebarIndex: number;
|
|
20
|
+
isLoading: boolean;
|
|
21
|
+
error: string | null;
|
|
22
|
+
daemonConnected: boolean;
|
|
23
|
+
}
|
|
24
|
+
export type AppAction = {
|
|
25
|
+
type: 'NAVIGATE';
|
|
26
|
+
view: ViewId;
|
|
27
|
+
params?: ViewParams;
|
|
28
|
+
} | {
|
|
29
|
+
type: 'GO_BACK';
|
|
30
|
+
} | {
|
|
31
|
+
type: 'SET_PROJECTS';
|
|
32
|
+
projects: ProjectInfo[];
|
|
33
|
+
} | {
|
|
34
|
+
type: 'SELECT_PROJECT';
|
|
35
|
+
path: string;
|
|
36
|
+
} | {
|
|
37
|
+
type: 'SET_ISSUES';
|
|
38
|
+
issues: Issue[];
|
|
39
|
+
} | {
|
|
40
|
+
type: 'SET_DOCS';
|
|
41
|
+
docs: Doc[];
|
|
42
|
+
} | {
|
|
43
|
+
type: 'SET_CONFIG';
|
|
44
|
+
config: Config;
|
|
45
|
+
} | {
|
|
46
|
+
type: 'SET_DAEMON_INFO';
|
|
47
|
+
info: DaemonInfo;
|
|
48
|
+
} | {
|
|
49
|
+
type: 'SELECT_ISSUE';
|
|
50
|
+
id: string | null;
|
|
51
|
+
} | {
|
|
52
|
+
type: 'SELECT_DOC';
|
|
53
|
+
slug: string | null;
|
|
54
|
+
} | {
|
|
55
|
+
type: 'SET_SIDEBAR_INDEX';
|
|
56
|
+
index: number;
|
|
57
|
+
} | {
|
|
58
|
+
type: 'SET_LOADING';
|
|
59
|
+
loading: boolean;
|
|
60
|
+
} | {
|
|
61
|
+
type: 'SET_ERROR';
|
|
62
|
+
error: string | null;
|
|
63
|
+
} | {
|
|
64
|
+
type: 'SET_DAEMON_STATUS';
|
|
65
|
+
connected: boolean;
|
|
66
|
+
};
|
|
67
|
+
interface AppContextValue {
|
|
68
|
+
state: AppState;
|
|
69
|
+
dispatch: Dispatch<AppAction>;
|
|
70
|
+
}
|
|
71
|
+
interface AppProviderProps {
|
|
72
|
+
children: ReactNode;
|
|
73
|
+
initialDaemonConnected?: boolean;
|
|
74
|
+
}
|
|
75
|
+
export declare function AppProvider({ children, initialDaemonConnected, }: AppProviderProps): ReactNode;
|
|
76
|
+
export declare function useAppState(): AppContextValue;
|
|
77
|
+
export {};
|
|
78
|
+
//# sourceMappingURL=app-state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-state.d.ts","sourceRoot":"","sources":["../../../src/tui/state/app-state.tsx"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,SAAS,EACd,KAAK,QAAQ,EACd,MAAM,OAAO,CAAA;AACd,OAAO,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC3D,OAAO,KAAK,EACV,KAAK,EACL,GAAG,EACH,WAAW,EACX,MAAM,EACN,UAAU,EACX,MAAM,uBAAuB,CAAA;AAE9B,MAAM,WAAW,QAAQ;IAEvB,WAAW,EAAE,MAAM,CAAA;IACnB,UAAU,EAAE,UAAU,CAAA;IACtB,WAAW,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,UAAU,CAAA;KAAE,CAAC,CAAA;IAGxD,QAAQ,EAAE,WAAW,EAAE,CAAA;IACvB,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAA;IAGlC,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,IAAI,EAAE,GAAG,EAAE,CAAA;IACX,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,UAAU,EAAE,UAAU,GAAG,IAAI,CAAA;IAG7B,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,YAAY,EAAE,MAAM,CAAA;IAGpB,SAAS,EAAE,OAAO,CAAA;IAClB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IAGpB,eAAe,EAAE,OAAO,CAAA;CACzB;AAED,MAAM,MAAM,SAAS,GACjB;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,UAAU,CAAA;CAAE,GACvD;IAAE,IAAI,EAAE,SAAS,CAAA;CAAE,GACnB;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,QAAQ,EAAE,WAAW,EAAE,CAAA;CAAE,GACjD;IAAE,IAAI,EAAE,gBAAgB,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GACxC;IAAE,IAAI,EAAE,YAAY,CAAC;IAAC,MAAM,EAAE,KAAK,EAAE,CAAA;CAAE,GACvC;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,IAAI,EAAE,GAAG,EAAE,CAAA;CAAE,GACjC;IAAE,IAAI,EAAE,YAAY,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACtC;IAAE,IAAI,EAAE,iBAAiB,CAAC;IAAC,IAAI,EAAE,UAAU,CAAA;CAAE,GAC7C;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,GAC3C;IAAE,IAAI,EAAE,YAAY,CAAC;IAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,GAC3C;IAAE,IAAI,EAAE,mBAAmB,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GAC5C;IAAE,IAAI,EAAE,aAAa,CAAC;IAAC,OAAO,EAAE,OAAO,CAAA;CAAE,GACzC;IAAE,IAAI,EAAE,WAAW,CAAC;IAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,GAC3C;IAAE,IAAI,EAAE,mBAAmB,CAAC;IAAC,SAAS,EAAE,OAAO,CAAA;CAAE,CAAA;AA4FrD,UAAU,eAAe;IACvB,KAAK,EAAE,QAAQ,CAAA;IACf,QAAQ,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAA;CAC9B;AAID,UAAU,gBAAgB;IACxB,QAAQ,EAAE,SAAS,CAAA;IACnB,sBAAsB,CAAC,EAAE,OAAO,CAAA;CACjC;AAED,wBAAgB,WAAW,CAAC,EAC1B,QAAQ,EACR,sBAA8B,GAC/B,EAAE,gBAAgB,aAWlB;AAED,wBAAgB,WAAW,oBAM1B"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { jsx as _jsx } from "@opentui/react/jsx-runtime";
|
|
2
|
+
import { createContext, useContext, useReducer, } from 'react';
|
|
3
|
+
const initialState = {
|
|
4
|
+
currentView: 'projects',
|
|
5
|
+
viewParams: {},
|
|
6
|
+
viewHistory: [],
|
|
7
|
+
projects: [],
|
|
8
|
+
selectedProjectPath: null,
|
|
9
|
+
issues: [],
|
|
10
|
+
docs: [],
|
|
11
|
+
config: null,
|
|
12
|
+
daemonInfo: null,
|
|
13
|
+
selectedIssueId: null,
|
|
14
|
+
selectedDocSlug: null,
|
|
15
|
+
sidebarIndex: 0,
|
|
16
|
+
isLoading: false,
|
|
17
|
+
error: null,
|
|
18
|
+
daemonConnected: false,
|
|
19
|
+
};
|
|
20
|
+
function appReducer(state, action) {
|
|
21
|
+
switch (action.type) {
|
|
22
|
+
case 'NAVIGATE':
|
|
23
|
+
return {
|
|
24
|
+
...state,
|
|
25
|
+
viewHistory: [
|
|
26
|
+
...state.viewHistory,
|
|
27
|
+
{ view: state.currentView, params: state.viewParams },
|
|
28
|
+
],
|
|
29
|
+
currentView: action.view,
|
|
30
|
+
viewParams: action.params ?? {},
|
|
31
|
+
};
|
|
32
|
+
case 'GO_BACK': {
|
|
33
|
+
if (state.viewHistory.length === 0)
|
|
34
|
+
return state;
|
|
35
|
+
const prev = state.viewHistory[state.viewHistory.length - 1];
|
|
36
|
+
return {
|
|
37
|
+
...state,
|
|
38
|
+
viewHistory: state.viewHistory.slice(0, -1),
|
|
39
|
+
currentView: prev.view,
|
|
40
|
+
viewParams: prev.params,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
case 'SET_PROJECTS':
|
|
44
|
+
return { ...state, projects: action.projects };
|
|
45
|
+
case 'SELECT_PROJECT':
|
|
46
|
+
return {
|
|
47
|
+
...state,
|
|
48
|
+
selectedProjectPath: action.path,
|
|
49
|
+
// Reset data when switching projects
|
|
50
|
+
issues: [],
|
|
51
|
+
docs: [],
|
|
52
|
+
config: null,
|
|
53
|
+
};
|
|
54
|
+
case 'SET_ISSUES':
|
|
55
|
+
return { ...state, issues: action.issues };
|
|
56
|
+
case 'SET_DOCS':
|
|
57
|
+
return { ...state, docs: action.docs };
|
|
58
|
+
case 'SET_CONFIG':
|
|
59
|
+
return { ...state, config: action.config };
|
|
60
|
+
case 'SET_DAEMON_INFO':
|
|
61
|
+
return { ...state, daemonInfo: action.info };
|
|
62
|
+
case 'SELECT_ISSUE':
|
|
63
|
+
return { ...state, selectedIssueId: action.id };
|
|
64
|
+
case 'SELECT_DOC':
|
|
65
|
+
return { ...state, selectedDocSlug: action.slug };
|
|
66
|
+
case 'SET_SIDEBAR_INDEX':
|
|
67
|
+
return { ...state, sidebarIndex: action.index };
|
|
68
|
+
case 'SET_LOADING':
|
|
69
|
+
return { ...state, isLoading: action.loading };
|
|
70
|
+
case 'SET_ERROR':
|
|
71
|
+
return { ...state, error: action.error };
|
|
72
|
+
case 'SET_DAEMON_STATUS':
|
|
73
|
+
return { ...state, daemonConnected: action.connected };
|
|
74
|
+
default:
|
|
75
|
+
return state;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
const AppContext = createContext(null);
|
|
79
|
+
export function AppProvider({ children, initialDaemonConnected = false, }) {
|
|
80
|
+
const [state, dispatch] = useReducer(appReducer, {
|
|
81
|
+
...initialState,
|
|
82
|
+
daemonConnected: initialDaemonConnected,
|
|
83
|
+
});
|
|
84
|
+
return (_jsx(AppContext.Provider, { value: { state, dispatch }, children: children }));
|
|
85
|
+
}
|
|
86
|
+
export function useAppState() {
|
|
87
|
+
const context = useContext(AppContext);
|
|
88
|
+
if (!context) {
|
|
89
|
+
throw new Error('useAppState must be used within AppProvider');
|
|
90
|
+
}
|
|
91
|
+
return context;
|
|
92
|
+
}
|
|
93
|
+
//# sourceMappingURL=app-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-state.js","sourceRoot":"","sources":["../../../src/tui/state/app-state.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* View/route definitions for the TUI
|
|
3
|
+
*/
|
|
4
|
+
export type ViewId = 'projects' | 'issues' | 'issue-detail' | 'issue-create' | 'docs' | 'doc-detail' | 'doc-create' | 'assets' | 'config' | 'daemon' | 'help';
|
|
5
|
+
export interface ViewParams {
|
|
6
|
+
issueId?: string;
|
|
7
|
+
docSlug?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare const VIEW_LABELS: Record<ViewId, string>;
|
|
10
|
+
export declare const SIDEBAR_VIEWS: ViewId[];
|
|
11
|
+
//# sourceMappingURL=views.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"views.d.ts","sourceRoot":"","sources":["../../../src/tui/types/views.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,MAAM,MAAM,GACd,UAAU,GACV,QAAQ,GACR,cAAc,GACd,cAAc,GACd,MAAM,GACN,YAAY,GACZ,YAAY,GACZ,QAAQ,GACR,QAAQ,GACR,QAAQ,GACR,MAAM,CAAA;AAEV,MAAM,WAAW,UAAU;IACzB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,eAAO,MAAM,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAY9C,CAAA;AAED,eAAO,MAAM,aAAa,EAAE,MAAM,EAOjC,CAAA"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* View/route definitions for the TUI
|
|
3
|
+
*/
|
|
4
|
+
export const VIEW_LABELS = {
|
|
5
|
+
projects: 'Projects',
|
|
6
|
+
issues: 'Issues',
|
|
7
|
+
'issue-detail': 'Issue Detail',
|
|
8
|
+
'issue-create': 'New Issue',
|
|
9
|
+
docs: 'Docs',
|
|
10
|
+
'doc-detail': 'Doc Detail',
|
|
11
|
+
'doc-create': 'New Doc',
|
|
12
|
+
assets: 'Assets',
|
|
13
|
+
config: 'Config',
|
|
14
|
+
daemon: 'Daemon',
|
|
15
|
+
help: 'Help',
|
|
16
|
+
};
|
|
17
|
+
export const SIDEBAR_VIEWS = [
|
|
18
|
+
'projects',
|
|
19
|
+
'issues',
|
|
20
|
+
'docs',
|
|
21
|
+
'assets',
|
|
22
|
+
'config',
|
|
23
|
+
'daemon',
|
|
24
|
+
];
|
|
25
|
+
//# sourceMappingURL=views.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"views.js","sourceRoot":"","sources":["../../../src/tui/types/views.ts"],"names":[],"mappings":"AAAA;;GAEG;AAoBH,MAAM,CAAC,MAAM,WAAW,GAA2B;IACjD,QAAQ,EAAE,UAAU;IACpB,MAAM,EAAE,QAAQ;IAChB,cAAc,EAAE,cAAc;IAC9B,cAAc,EAAE,WAAW;IAC3B,IAAI,EAAE,MAAM;IACZ,YAAY,EAAE,YAAY;IAC1B,YAAY,EAAE,SAAS;IACvB,MAAM,EAAE,QAAQ;IAChB,MAAM,EAAE,QAAQ;IAChB,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,MAAM;CACb,CAAA;AAED,MAAM,CAAC,MAAM,aAAa,GAAa;IACrC,UAAU;IACV,QAAQ;IACR,MAAM;IACN,QAAQ;IACR,QAAQ;IACR,QAAQ;CACT,CAAA"}
|
package/oclif.manifest.json
CHANGED
|
@@ -193,6 +193,39 @@
|
|
|
193
193
|
"shutdown.js"
|
|
194
194
|
]
|
|
195
195
|
},
|
|
196
|
+
"start": {
|
|
197
|
+
"aliases": [],
|
|
198
|
+
"args": {},
|
|
199
|
+
"description": "Start the centy daemon",
|
|
200
|
+
"examples": [
|
|
201
|
+
"<%= config.bin %> start",
|
|
202
|
+
"<%= config.bin %> start --foreground",
|
|
203
|
+
"<%= config.bin %> start -f"
|
|
204
|
+
],
|
|
205
|
+
"flags": {
|
|
206
|
+
"foreground": {
|
|
207
|
+
"char": "f",
|
|
208
|
+
"description": "Run daemon in foreground (blocks terminal)",
|
|
209
|
+
"name": "foreground",
|
|
210
|
+
"allowNo": false,
|
|
211
|
+
"type": "boolean"
|
|
212
|
+
}
|
|
213
|
+
},
|
|
214
|
+
"hasDynamicHelp": false,
|
|
215
|
+
"hiddenAliases": [],
|
|
216
|
+
"id": "start",
|
|
217
|
+
"pluginAlias": "centy",
|
|
218
|
+
"pluginName": "centy",
|
|
219
|
+
"pluginType": "core",
|
|
220
|
+
"strict": true,
|
|
221
|
+
"enableJsonFlag": false,
|
|
222
|
+
"isESM": true,
|
|
223
|
+
"relativePath": [
|
|
224
|
+
"dist",
|
|
225
|
+
"commands",
|
|
226
|
+
"start.js"
|
|
227
|
+
]
|
|
228
|
+
},
|
|
196
229
|
"update": {
|
|
197
230
|
"aliases": [],
|
|
198
231
|
"args": {},
|
|
@@ -750,6 +783,55 @@
|
|
|
750
783
|
"project.js"
|
|
751
784
|
]
|
|
752
785
|
},
|
|
786
|
+
"install:daemon": {
|
|
787
|
+
"aliases": [],
|
|
788
|
+
"args": {},
|
|
789
|
+
"description": "Download and install the centy daemon binary",
|
|
790
|
+
"examples": [
|
|
791
|
+
"<%= config.bin %> install daemon",
|
|
792
|
+
"<%= config.bin %> install daemon --version 0.1.0",
|
|
793
|
+
"<%= config.bin %> install daemon --force",
|
|
794
|
+
"<%= config.bin %> install daemon --skip-checksum"
|
|
795
|
+
],
|
|
796
|
+
"flags": {
|
|
797
|
+
"version": {
|
|
798
|
+
"char": "v",
|
|
799
|
+
"description": "Specific version to install (default: latest)",
|
|
800
|
+
"name": "version",
|
|
801
|
+
"hasDynamicHelp": false,
|
|
802
|
+
"multiple": false,
|
|
803
|
+
"type": "option"
|
|
804
|
+
},
|
|
805
|
+
"force": {
|
|
806
|
+
"char": "f",
|
|
807
|
+
"description": "Force reinstall even if already installed",
|
|
808
|
+
"name": "force",
|
|
809
|
+
"allowNo": false,
|
|
810
|
+
"type": "boolean"
|
|
811
|
+
},
|
|
812
|
+
"skip-checksum": {
|
|
813
|
+
"description": "Skip SHA256 checksum verification",
|
|
814
|
+
"name": "skip-checksum",
|
|
815
|
+
"allowNo": false,
|
|
816
|
+
"type": "boolean"
|
|
817
|
+
}
|
|
818
|
+
},
|
|
819
|
+
"hasDynamicHelp": false,
|
|
820
|
+
"hiddenAliases": [],
|
|
821
|
+
"id": "install:daemon",
|
|
822
|
+
"pluginAlias": "centy",
|
|
823
|
+
"pluginName": "centy",
|
|
824
|
+
"pluginType": "core",
|
|
825
|
+
"strict": true,
|
|
826
|
+
"enableJsonFlag": false,
|
|
827
|
+
"isESM": true,
|
|
828
|
+
"relativePath": [
|
|
829
|
+
"dist",
|
|
830
|
+
"commands",
|
|
831
|
+
"install",
|
|
832
|
+
"daemon.js"
|
|
833
|
+
]
|
|
834
|
+
},
|
|
753
835
|
"list:assets": {
|
|
754
836
|
"aliases": [],
|
|
755
837
|
"args": {},
|
|
@@ -1117,5 +1199,5 @@
|
|
|
1117
1199
|
]
|
|
1118
1200
|
}
|
|
1119
1201
|
},
|
|
1120
|
-
"version": "0.0.
|
|
1202
|
+
"version": "0.0.9"
|
|
1121
1203
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "centy",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.9",
|
|
4
4
|
"description": "CLI for managing project issues and docs via code in the .centy folder",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -56,7 +56,9 @@
|
|
|
56
56
|
"@commitlint/config-conventional": "^20.0.0",
|
|
57
57
|
"@cspell/dict-he": "^4.0.5",
|
|
58
58
|
"@types/node": "^24.10.1",
|
|
59
|
+
"@types/react": "^19.2.7",
|
|
59
60
|
"@vitest/coverage-v8": "^4.0.15",
|
|
61
|
+
"bun-types": "^1.3.3",
|
|
60
62
|
"cspell": "^9.4.0",
|
|
61
63
|
"eslint": "^9.39.1",
|
|
62
64
|
"eslint-config-agent": "^1.8.9",
|
|
@@ -76,10 +78,15 @@
|
|
|
76
78
|
"@grpc/grpc-js": "^1.12.2",
|
|
77
79
|
"@grpc/proto-loader": "^0.7.13",
|
|
78
80
|
"@oclif/core": "^4.8.0",
|
|
79
|
-
"@oclif/plugin-help": "^6.2.36"
|
|
81
|
+
"@oclif/plugin-help": "^6.2.36",
|
|
82
|
+
"@opentui/core": "^0.1.56",
|
|
83
|
+
"@opentui/react": "^0.1.56",
|
|
84
|
+
"react": "^19.2.1",
|
|
85
|
+
"tar": "^7.5.2"
|
|
80
86
|
},
|
|
81
87
|
"scripts": {
|
|
82
|
-
"build": "tsc && pnpm run manifest",
|
|
88
|
+
"build": "pnpm run build:tsc && pnpm run manifest",
|
|
89
|
+
"build:tsc": "tsc",
|
|
83
90
|
"dev": "tsc --watch",
|
|
84
91
|
"manifest": "oclif manifest",
|
|
85
92
|
"test": "vitest",
|