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.
Files changed (81) hide show
  1. package/bin/run.js +14 -2
  2. package/dist/commands/start.d.ts +13 -0
  3. package/dist/commands/start.d.ts.map +1 -0
  4. package/dist/commands/start.js +79 -0
  5. package/dist/commands/start.js.map +1 -0
  6. package/dist/hooks/prerun.js +1 -1
  7. package/dist/hooks/prerun.js.map +1 -1
  8. package/dist/lib/start/daemon-binary-exists.d.ts +2 -0
  9. package/dist/lib/start/daemon-binary-exists.d.ts.map +1 -0
  10. package/dist/lib/start/daemon-binary-exists.js +10 -0
  11. package/dist/lib/start/daemon-binary-exists.js.map +1 -0
  12. package/dist/lib/start/find-daemon-binary.d.ts +2 -0
  13. package/dist/lib/start/find-daemon-binary.d.ts.map +1 -0
  14. package/dist/lib/start/find-daemon-binary.js +25 -0
  15. package/dist/lib/start/find-daemon-binary.js.map +1 -0
  16. package/dist/lib/start/wait-for-daemon.d.ts +7 -0
  17. package/dist/lib/start/wait-for-daemon.d.ts.map +1 -0
  18. package/dist/lib/start/wait-for-daemon.js +20 -0
  19. package/dist/lib/start/wait-for-daemon.js.map +1 -0
  20. package/dist/tui/App.d.ts +6 -0
  21. package/dist/tui/App.d.ts.map +1 -0
  22. package/dist/tui/App.js +63 -0
  23. package/dist/tui/App.js.map +1 -0
  24. package/dist/tui/components/domain/IssueList.d.ts +2 -0
  25. package/dist/tui/components/domain/IssueList.d.ts.map +1 -0
  26. package/dist/tui/components/domain/IssueList.js +52 -0
  27. package/dist/tui/components/domain/IssueList.js.map +1 -0
  28. package/dist/tui/components/domain/ProjectList.d.ts +2 -0
  29. package/dist/tui/components/domain/ProjectList.d.ts.map +1 -0
  30. package/dist/tui/components/domain/ProjectList.js +54 -0
  31. package/dist/tui/components/domain/ProjectList.js.map +1 -0
  32. package/dist/tui/components/layout/Header.d.ts +7 -0
  33. package/dist/tui/components/layout/Header.d.ts.map +1 -0
  34. package/dist/tui/components/layout/Header.js +7 -0
  35. package/dist/tui/components/layout/Header.js.map +1 -0
  36. package/dist/tui/components/layout/MainPanel.d.ts +8 -0
  37. package/dist/tui/components/layout/MainPanel.d.ts.map +1 -0
  38. package/dist/tui/components/layout/MainPanel.js +5 -0
  39. package/dist/tui/components/layout/MainPanel.js.map +1 -0
  40. package/dist/tui/components/layout/Sidebar.d.ts +9 -0
  41. package/dist/tui/components/layout/Sidebar.d.ts.map +1 -0
  42. package/dist/tui/components/layout/Sidebar.js +11 -0
  43. package/dist/tui/components/layout/Sidebar.js.map +1 -0
  44. package/dist/tui/components/layout/StatusBar.d.ts +11 -0
  45. package/dist/tui/components/layout/StatusBar.d.ts.map +1 -0
  46. package/dist/tui/components/layout/StatusBar.js +8 -0
  47. package/dist/tui/components/layout/StatusBar.js.map +1 -0
  48. package/dist/tui/hooks/useDaemonConnection.d.ts +5 -0
  49. package/dist/tui/hooks/useDaemonConnection.d.ts.map +1 -0
  50. package/dist/tui/hooks/useDaemonConnection.js +24 -0
  51. package/dist/tui/hooks/useDaemonConnection.js.map +1 -0
  52. package/dist/tui/hooks/useIssues.d.ts +8 -0
  53. package/dist/tui/hooks/useIssues.d.ts.map +1 -0
  54. package/dist/tui/hooks/useIssues.js +36 -0
  55. package/dist/tui/hooks/useIssues.js.map +1 -0
  56. package/dist/tui/hooks/useNavigation.d.ts +11 -0
  57. package/dist/tui/hooks/useNavigation.d.ts.map +1 -0
  58. package/dist/tui/hooks/useNavigation.js +24 -0
  59. package/dist/tui/hooks/useNavigation.js.map +1 -0
  60. package/dist/tui/hooks/useProjects.d.ts +8 -0
  61. package/dist/tui/hooks/useProjects.d.ts.map +1 -0
  62. package/dist/tui/hooks/useProjects.js +36 -0
  63. package/dist/tui/hooks/useProjects.js.map +1 -0
  64. package/dist/tui/index.d.ts +2 -0
  65. package/dist/tui/index.d.ts.map +1 -0
  66. package/dist/tui/index.js +39 -0
  67. package/dist/tui/index.js.map +1 -0
  68. package/dist/tui/services/daemon-service.d.ts +26 -0
  69. package/dist/tui/services/daemon-service.d.ts.map +1 -0
  70. package/dist/tui/services/daemon-service.js +81 -0
  71. package/dist/tui/services/daemon-service.js.map +1 -0
  72. package/dist/tui/state/app-state.d.ts +78 -0
  73. package/dist/tui/state/app-state.d.ts.map +1 -0
  74. package/dist/tui/state/app-state.js +93 -0
  75. package/dist/tui/state/app-state.js.map +1 -0
  76. package/dist/tui/types/views.d.ts +11 -0
  77. package/dist/tui/types/views.d.ts.map +1 -0
  78. package/dist/tui/types/views.js +25 -0
  79. package/dist/tui/types/views.js.map +1 -0
  80. package/oclif.manifest.json +34 -1
  81. 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,2 @@
1
+ export declare function startTUI(): Promise<void>;
2
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}
@@ -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.5"
1153
+ "version": "0.0.7"
1121
1154
  }