centy 0.0.5 → 0.0.7
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/bin/run.js +14 -2
- 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/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 +25 -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 +63 -0
- package/dist/tui/App.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/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/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 +26 -0
- package/dist/tui/services/daemon-service.d.ts.map +1 -0
- package/dist/tui/services/daemon-service.js +81 -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 +34 -1
- package/package.json +9 -3
|
@@ -0,0 +1,24 @@
|
|
|
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 useDaemonConnection() {
|
|
5
|
+
const { state, dispatch } = useAppState();
|
|
6
|
+
const checkConnection = useCallback(async () => {
|
|
7
|
+
const result = await daemonService.checkConnection();
|
|
8
|
+
dispatch({ type: 'SET_DAEMON_STATUS', connected: result.connected });
|
|
9
|
+
if (!result.connected && result.error) {
|
|
10
|
+
dispatch({ type: 'SET_ERROR', error: result.error });
|
|
11
|
+
}
|
|
12
|
+
}, [dispatch]);
|
|
13
|
+
// Initial check and periodic polling
|
|
14
|
+
useEffect(() => {
|
|
15
|
+
checkConnection();
|
|
16
|
+
const interval = setInterval(checkConnection, 10000);
|
|
17
|
+
return () => clearInterval(interval);
|
|
18
|
+
}, [checkConnection]);
|
|
19
|
+
return {
|
|
20
|
+
connected: state.daemonConnected,
|
|
21
|
+
retry: checkConnection,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=useDaemonConnection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDaemonConnection.js","sourceRoot":"","sources":["../../../src/tui/hooks/useDaemonConnection.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,mBAAmB;IACjC,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,WAAW,EAAE,CAAA;IAEzC,MAAM,eAAe,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAC7C,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,eAAe,EAAE,CAAA;QACpD,QAAQ,CAAC,EAAE,IAAI,EAAE,mBAAmB,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC,CAAA;QACpE,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;YACtC,QAAQ,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAA;QACtD,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAA;IAEd,qCAAqC;IACrC,SAAS,CAAC,GAAG,EAAE;QACb,eAAe,EAAE,CAAA;QACjB,MAAM,QAAQ,GAAG,WAAW,CAAC,eAAe,EAAE,KAAK,CAAC,CAAA;QACpD,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;IACtC,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC,CAAA;IAErB,OAAO;QACL,SAAS,EAAE,KAAK,CAAC,eAAe;QAChC,KAAK,EAAE,eAAe;KACvB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare function useIssues(): {
|
|
2
|
+
issues: import("../../daemon/types.js").Issue[];
|
|
3
|
+
selectedIssueId: string | null;
|
|
4
|
+
isLoading: boolean;
|
|
5
|
+
loadIssues: () => Promise<void>;
|
|
6
|
+
selectIssue: (id: string | null) => void;
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=useIssues.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useIssues.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/useIssues.ts"],"names":[],"mappings":"AAIA,wBAAgB,SAAS;;;;;sBAkBhB,MAAM,GAAG,IAAI;EAoBrB"}
|
|
@@ -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 useIssues() {
|
|
5
|
+
const { state, dispatch } = useAppState();
|
|
6
|
+
const loadIssues = useCallback(async () => {
|
|
7
|
+
if (!state.daemonConnected || !state.selectedProjectPath)
|
|
8
|
+
return;
|
|
9
|
+
dispatch({ type: 'SET_LOADING', loading: true });
|
|
10
|
+
const result = await daemonService.listIssues(state.selectedProjectPath);
|
|
11
|
+
dispatch({ type: 'SET_LOADING', loading: false });
|
|
12
|
+
if (result.success && result.data) {
|
|
13
|
+
dispatch({ type: 'SET_ISSUES', issues: result.data });
|
|
14
|
+
}
|
|
15
|
+
else if (result.error) {
|
|
16
|
+
dispatch({ type: 'SET_ERROR', error: result.error });
|
|
17
|
+
}
|
|
18
|
+
}, [state.daemonConnected, state.selectedProjectPath, dispatch]);
|
|
19
|
+
const selectIssue = useCallback((id) => {
|
|
20
|
+
dispatch({ type: 'SELECT_ISSUE', id });
|
|
21
|
+
}, [dispatch]);
|
|
22
|
+
// Load issues when project is selected
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (state.selectedProjectPath) {
|
|
25
|
+
loadIssues();
|
|
26
|
+
}
|
|
27
|
+
}, [state.selectedProjectPath, loadIssues]);
|
|
28
|
+
return {
|
|
29
|
+
issues: state.issues,
|
|
30
|
+
selectedIssueId: state.selectedIssueId,
|
|
31
|
+
isLoading: state.isLoading,
|
|
32
|
+
loadIssues,
|
|
33
|
+
selectIssue,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=useIssues.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useIssues.js","sourceRoot":"","sources":["../../../src/tui/hooks/useIssues.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,SAAS;IACvB,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,WAAW,EAAE,CAAA;IAEzC,MAAM,UAAU,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACxC,IAAI,CAAC,KAAK,CAAC,eAAe,IAAI,CAAC,KAAK,CAAC,mBAAmB;YAAE,OAAM;QAEhE,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAChD,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,UAAU,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAA;QACxE,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,YAAY,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;QACvD,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,KAAK,CAAC,mBAAmB,EAAE,QAAQ,CAAC,CAAC,CAAA;IAEhE,MAAM,WAAW,GAAG,WAAW,CAC7B,CAAC,EAAiB,EAAE,EAAE;QACpB,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC,CAAA;IACxC,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,uCAAuC;IACvC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,KAAK,CAAC,mBAAmB,EAAE,CAAC;YAC9B,UAAU,EAAE,CAAA;QACd,CAAC;IACH,CAAC,EAAE,CAAC,KAAK,CAAC,mBAAmB,EAAE,UAAU,CAAC,CAAC,CAAA;IAE3C,OAAO;QACL,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,UAAU;QACV,WAAW;KACZ,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ViewId, ViewParams } from '../types/views.js';
|
|
2
|
+
export declare function useNavigation(): {
|
|
3
|
+
currentView: ViewId;
|
|
4
|
+
viewParams: ViewParams;
|
|
5
|
+
canGoBack: boolean;
|
|
6
|
+
sidebarIndex: number;
|
|
7
|
+
navigate: (view: ViewId, params?: ViewParams) => void;
|
|
8
|
+
goBack: () => void;
|
|
9
|
+
selectSidebarItem: (index: number) => void;
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=useNavigation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useNavigation.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/useNavigation.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAE3D,wBAAgB,aAAa;;;;;qBAIlB,MAAM,WAAW,UAAU;;+BAW1B,MAAM;EAejB"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { useCallback } from 'react';
|
|
2
|
+
import { useAppState } from '../state/app-state.js';
|
|
3
|
+
export function useNavigation() {
|
|
4
|
+
const { state, dispatch } = useAppState();
|
|
5
|
+
const navigate = useCallback((view, params) => {
|
|
6
|
+
dispatch({ type: 'NAVIGATE', view, params });
|
|
7
|
+
}, [dispatch]);
|
|
8
|
+
const goBack = useCallback(() => {
|
|
9
|
+
dispatch({ type: 'GO_BACK' });
|
|
10
|
+
}, [dispatch]);
|
|
11
|
+
const selectSidebarItem = useCallback((index) => {
|
|
12
|
+
dispatch({ type: 'SET_SIDEBAR_INDEX', index });
|
|
13
|
+
}, [dispatch]);
|
|
14
|
+
return {
|
|
15
|
+
currentView: state.currentView,
|
|
16
|
+
viewParams: state.viewParams,
|
|
17
|
+
canGoBack: state.viewHistory.length > 0,
|
|
18
|
+
sidebarIndex: state.sidebarIndex,
|
|
19
|
+
navigate,
|
|
20
|
+
goBack,
|
|
21
|
+
selectSidebarItem,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=useNavigation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useNavigation.js","sourceRoot":"","sources":["../../../src/tui/hooks/useNavigation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AACnC,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AAGnD,MAAM,UAAU,aAAa;IAC3B,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,WAAW,EAAE,CAAA;IAEzC,MAAM,QAAQ,GAAG,WAAW,CAC1B,CAAC,IAAY,EAAE,MAAmB,EAAE,EAAE;QACpC,QAAQ,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAA;IAC9C,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,EAAE;QAC9B,QAAQ,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAA;IAC/B,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAA;IAEd,MAAM,iBAAiB,GAAG,WAAW,CACnC,CAAC,KAAa,EAAE,EAAE;QAChB,QAAQ,CAAC,EAAE,IAAI,EAAE,mBAAmB,EAAE,KAAK,EAAE,CAAC,CAAA;IAChD,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,OAAO;QACL,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,SAAS,EAAE,KAAK,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC;QACvC,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,QAAQ;QACR,MAAM;QACN,iBAAiB;KAClB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare function useProjects(): {
|
|
2
|
+
projects: import("../../daemon/types.js").ProjectInfo[];
|
|
3
|
+
selectedProjectPath: string | null;
|
|
4
|
+
isLoading: boolean;
|
|
5
|
+
loadProjects: () => Promise<void>;
|
|
6
|
+
selectProject: (path: string) => void;
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=useProjects.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useProjects.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/useProjects.ts"],"names":[],"mappings":"AAIA,wBAAgB,WAAW;;;;;0BAkBhB,MAAM;EAoBhB"}
|
|
@@ -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,26 @@
|
|
|
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 } 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
|
+
}
|
|
25
|
+
export declare const daemonService: DaemonService;
|
|
26
|
+
//# 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;AAQH,OAAO,KAAK,EACV,WAAW,EACX,KAAK,EACL,GAAG,EACH,MAAM,EACN,UAAU,EACX,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;CAYhE;AAED,eAAO,MAAM,aAAa,eAAsB,CAAA"}
|
|
@@ -0,0 +1,81 @@
|
|
|
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 { checkDaemonConnection } from '../../daemon/check-daemon-connection.js';
|
|
11
|
+
export class DaemonService {
|
|
12
|
+
async checkConnection() {
|
|
13
|
+
return checkDaemonConnection();
|
|
14
|
+
}
|
|
15
|
+
async listProjects(includeStale = false) {
|
|
16
|
+
try {
|
|
17
|
+
const response = await daemonListProjects({ includeStale });
|
|
18
|
+
return { success: true, data: response.projects };
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
return {
|
|
22
|
+
success: false,
|
|
23
|
+
error: error instanceof Error ? error.message : 'Failed to list projects',
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
async listIssues(projectPath, filters) {
|
|
28
|
+
try {
|
|
29
|
+
const response = await daemonListIssues({
|
|
30
|
+
projectPath,
|
|
31
|
+
status: filters?.status,
|
|
32
|
+
priority: filters?.priority,
|
|
33
|
+
});
|
|
34
|
+
return { success: true, data: response.issues };
|
|
35
|
+
}
|
|
36
|
+
catch (error) {
|
|
37
|
+
return {
|
|
38
|
+
success: false,
|
|
39
|
+
error: error instanceof Error ? error.message : 'Failed to list issues',
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
async listDocs(projectPath) {
|
|
44
|
+
try {
|
|
45
|
+
const response = await daemonListDocs({ projectPath });
|
|
46
|
+
return { success: true, data: response.docs };
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
return {
|
|
50
|
+
success: false,
|
|
51
|
+
error: error instanceof Error ? error.message : 'Failed to list docs',
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
async getConfig(projectPath) {
|
|
56
|
+
try {
|
|
57
|
+
const response = await daemonGetConfig({ projectPath });
|
|
58
|
+
return { success: true, data: response };
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
return {
|
|
62
|
+
success: false,
|
|
63
|
+
error: error instanceof Error ? error.message : 'Failed to get config',
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
async getDaemonInfo() {
|
|
68
|
+
try {
|
|
69
|
+
const response = await daemonGetDaemonInfo({});
|
|
70
|
+
return { success: true, data: response };
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
return {
|
|
74
|
+
success: false,
|
|
75
|
+
error: error instanceof Error ? error.message : 'Failed to get daemon info',
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
export const daemonService = new DaemonService();
|
|
81
|
+
//# 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": {},
|
|
@@ -1117,5 +1150,5 @@
|
|
|
1117
1150
|
]
|
|
1118
1151
|
}
|
|
1119
1152
|
},
|
|
1120
|
-
"version": "0.0.
|
|
1153
|
+
"version": "0.0.7"
|
|
1121
1154
|
}
|