centy 0.0.4 → 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 (154) hide show
  1. package/bin/run.js +14 -2
  2. package/dist/commands/add/asset.d.ts.map +1 -1
  3. package/dist/commands/add/asset.js +25 -27
  4. package/dist/commands/add/asset.js.map +1 -1
  5. package/dist/commands/config.d.ts.map +1 -1
  6. package/dist/commands/config.js +26 -35
  7. package/dist/commands/config.js.map +1 -1
  8. package/dist/commands/create/doc.d.ts.map +1 -1
  9. package/dist/commands/create/doc.js +15 -24
  10. package/dist/commands/create/doc.js.map +1 -1
  11. package/dist/commands/create/issue.d.ts.map +1 -1
  12. package/dist/commands/create/issue.js +0 -7
  13. package/dist/commands/create/issue.js.map +1 -1
  14. package/dist/commands/delete/asset.d.ts.map +1 -1
  15. package/dist/commands/delete/asset.js +29 -38
  16. package/dist/commands/delete/asset.js.map +1 -1
  17. package/dist/commands/delete/doc.d.ts.map +1 -1
  18. package/dist/commands/delete/doc.js +23 -32
  19. package/dist/commands/delete/doc.js.map +1 -1
  20. package/dist/commands/delete/issue.d.ts.map +1 -1
  21. package/dist/commands/delete/issue.js +23 -32
  22. package/dist/commands/delete/issue.js.map +1 -1
  23. package/dist/commands/get/asset.d.ts.map +1 -1
  24. package/dist/commands/get/asset.js +20 -29
  25. package/dist/commands/get/asset.js.map +1 -1
  26. package/dist/commands/get/doc.d.ts.map +1 -1
  27. package/dist/commands/get/doc.js +15 -24
  28. package/dist/commands/get/doc.js.map +1 -1
  29. package/dist/commands/get/issue.d.ts.map +1 -1
  30. package/dist/commands/get/issue.js +29 -38
  31. package/dist/commands/get/issue.js.map +1 -1
  32. package/dist/commands/get/project.d.ts.map +1 -1
  33. package/dist/commands/get/project.js +16 -25
  34. package/dist/commands/get/project.js.map +1 -1
  35. package/dist/commands/init.d.ts.map +1 -1
  36. package/dist/commands/init.js +0 -7
  37. package/dist/commands/init.js.map +1 -1
  38. package/dist/commands/list/assets.d.ts.map +1 -1
  39. package/dist/commands/list/assets.js +26 -35
  40. package/dist/commands/list/assets.js.map +1 -1
  41. package/dist/commands/list/docs.d.ts.map +1 -1
  42. package/dist/commands/list/docs.js +18 -27
  43. package/dist/commands/list/docs.js.map +1 -1
  44. package/dist/commands/list/issues.d.ts.map +1 -1
  45. package/dist/commands/list/issues.js +27 -36
  46. package/dist/commands/list/issues.js.map +1 -1
  47. package/dist/commands/list/projects.d.ts.map +1 -1
  48. package/dist/commands/list/projects.js +18 -27
  49. package/dist/commands/list/projects.js.map +1 -1
  50. package/dist/commands/manifest.d.ts.map +1 -1
  51. package/dist/commands/manifest.js +14 -28
  52. package/dist/commands/manifest.js.map +1 -1
  53. package/dist/commands/register/project.d.ts.map +1 -1
  54. package/dist/commands/register/project.js +8 -17
  55. package/dist/commands/register/project.js.map +1 -1
  56. package/dist/commands/start.d.ts +13 -0
  57. package/dist/commands/start.d.ts.map +1 -0
  58. package/dist/commands/start.js +79 -0
  59. package/dist/commands/start.js.map +1 -0
  60. package/dist/commands/untrack/project.d.ts.map +1 -1
  61. package/dist/commands/untrack/project.js +18 -27
  62. package/dist/commands/untrack/project.js.map +1 -1
  63. package/dist/commands/update/doc.d.ts.map +1 -1
  64. package/dist/commands/update/doc.js +17 -26
  65. package/dist/commands/update/doc.js.map +1 -1
  66. package/dist/commands/update/issue.d.ts.map +1 -1
  67. package/dist/commands/update/issue.js +21 -30
  68. package/dist/commands/update/issue.js.map +1 -1
  69. package/dist/commands/update.d.ts.map +1 -1
  70. package/dist/commands/update.js +35 -44
  71. package/dist/commands/update.js.map +1 -1
  72. package/dist/commands/version.d.ts.map +1 -1
  73. package/dist/commands/version.js +15 -24
  74. package/dist/commands/version.js.map +1 -1
  75. package/dist/daemon/types.d.ts +0 -8
  76. package/dist/daemon/types.d.ts.map +1 -1
  77. package/dist/hooks/prerun.d.ts +4 -0
  78. package/dist/hooks/prerun.d.ts.map +1 -0
  79. package/dist/hooks/prerun.js +16 -0
  80. package/dist/hooks/prerun.js.map +1 -0
  81. package/dist/lib/start/daemon-binary-exists.d.ts +2 -0
  82. package/dist/lib/start/daemon-binary-exists.d.ts.map +1 -0
  83. package/dist/lib/start/daemon-binary-exists.js +10 -0
  84. package/dist/lib/start/daemon-binary-exists.js.map +1 -0
  85. package/dist/lib/start/find-daemon-binary.d.ts +2 -0
  86. package/dist/lib/start/find-daemon-binary.d.ts.map +1 -0
  87. package/dist/lib/start/find-daemon-binary.js +25 -0
  88. package/dist/lib/start/find-daemon-binary.js.map +1 -0
  89. package/dist/lib/start/wait-for-daemon.d.ts +7 -0
  90. package/dist/lib/start/wait-for-daemon.d.ts.map +1 -0
  91. package/dist/lib/start/wait-for-daemon.js +20 -0
  92. package/dist/lib/start/wait-for-daemon.js.map +1 -0
  93. package/dist/tui/App.d.ts +6 -0
  94. package/dist/tui/App.d.ts.map +1 -0
  95. package/dist/tui/App.js +63 -0
  96. package/dist/tui/App.js.map +1 -0
  97. package/dist/tui/components/domain/IssueList.d.ts +2 -0
  98. package/dist/tui/components/domain/IssueList.d.ts.map +1 -0
  99. package/dist/tui/components/domain/IssueList.js +52 -0
  100. package/dist/tui/components/domain/IssueList.js.map +1 -0
  101. package/dist/tui/components/domain/ProjectList.d.ts +2 -0
  102. package/dist/tui/components/domain/ProjectList.d.ts.map +1 -0
  103. package/dist/tui/components/domain/ProjectList.js +54 -0
  104. package/dist/tui/components/domain/ProjectList.js.map +1 -0
  105. package/dist/tui/components/layout/Header.d.ts +7 -0
  106. package/dist/tui/components/layout/Header.d.ts.map +1 -0
  107. package/dist/tui/components/layout/Header.js +7 -0
  108. package/dist/tui/components/layout/Header.js.map +1 -0
  109. package/dist/tui/components/layout/MainPanel.d.ts +8 -0
  110. package/dist/tui/components/layout/MainPanel.d.ts.map +1 -0
  111. package/dist/tui/components/layout/MainPanel.js +5 -0
  112. package/dist/tui/components/layout/MainPanel.js.map +1 -0
  113. package/dist/tui/components/layout/Sidebar.d.ts +9 -0
  114. package/dist/tui/components/layout/Sidebar.d.ts.map +1 -0
  115. package/dist/tui/components/layout/Sidebar.js +11 -0
  116. package/dist/tui/components/layout/Sidebar.js.map +1 -0
  117. package/dist/tui/components/layout/StatusBar.d.ts +11 -0
  118. package/dist/tui/components/layout/StatusBar.d.ts.map +1 -0
  119. package/dist/tui/components/layout/StatusBar.js +8 -0
  120. package/dist/tui/components/layout/StatusBar.js.map +1 -0
  121. package/dist/tui/hooks/useDaemonConnection.d.ts +5 -0
  122. package/dist/tui/hooks/useDaemonConnection.d.ts.map +1 -0
  123. package/dist/tui/hooks/useDaemonConnection.js +24 -0
  124. package/dist/tui/hooks/useDaemonConnection.js.map +1 -0
  125. package/dist/tui/hooks/useIssues.d.ts +8 -0
  126. package/dist/tui/hooks/useIssues.d.ts.map +1 -0
  127. package/dist/tui/hooks/useIssues.js +36 -0
  128. package/dist/tui/hooks/useIssues.js.map +1 -0
  129. package/dist/tui/hooks/useNavigation.d.ts +11 -0
  130. package/dist/tui/hooks/useNavigation.d.ts.map +1 -0
  131. package/dist/tui/hooks/useNavigation.js +24 -0
  132. package/dist/tui/hooks/useNavigation.js.map +1 -0
  133. package/dist/tui/hooks/useProjects.d.ts +8 -0
  134. package/dist/tui/hooks/useProjects.d.ts.map +1 -0
  135. package/dist/tui/hooks/useProjects.js +36 -0
  136. package/dist/tui/hooks/useProjects.js.map +1 -0
  137. package/dist/tui/index.d.ts +2 -0
  138. package/dist/tui/index.d.ts.map +1 -0
  139. package/dist/tui/index.js +39 -0
  140. package/dist/tui/index.js.map +1 -0
  141. package/dist/tui/services/daemon-service.d.ts +26 -0
  142. package/dist/tui/services/daemon-service.d.ts.map +1 -0
  143. package/dist/tui/services/daemon-service.js +81 -0
  144. package/dist/tui/services/daemon-service.js.map +1 -0
  145. package/dist/tui/state/app-state.d.ts +78 -0
  146. package/dist/tui/state/app-state.d.ts.map +1 -0
  147. package/dist/tui/state/app-state.js +93 -0
  148. package/dist/tui/state/app-state.js.map +1 -0
  149. package/dist/tui/types/views.d.ts +11 -0
  150. package/dist/tui/types/views.d.ts.map +1 -0
  151. package/dist/tui/types/views.js +25 -0
  152. package/dist/tui/types/views.js.map +1 -0
  153. package/oclif.manifest.json +34 -1
  154. package/package.json +12 -3
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "@opentui/react/jsx-runtime";
2
+ export function Header({ title, daemonConnected }) {
3
+ const statusColor = daemonConnected ? 'green' : 'red';
4
+ const statusText = daemonConnected ? 'Connected' : 'Disconnected';
5
+ return (_jsxs("box", { height: 1, width: "100%", flexDirection: "row", justifyContent: "space-between", children: [_jsx("text", { fg: "cyan", children: _jsx("b", { children: title }) }), _jsxs("box", { flexDirection: "row", children: [_jsx("text", { fg: statusColor, children: "\u25CF" }), _jsx("text", { children: " Daemon: " }), _jsx("text", { fg: statusColor, children: statusText })] })] }));
6
+ }
7
+ //# sourceMappingURL=Header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/Header.tsx"],"names":[],"mappings":";AAKA,MAAM,UAAU,MAAM,CAAC,EAAE,KAAK,EAAE,eAAe,EAAe;IAC5D,MAAM,WAAW,GAAG,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAA;IACrD,MAAM,UAAU,GAAG,eAAe,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,CAAA;IAEjE,OAAO,CACL,eACE,MAAM,EAAE,CAAC,EACT,KAAK,EAAC,MAAM,EACZ,aAAa,EAAC,KAAK,EACnB,cAAc,EAAC,eAAe,aAE9B,eAAM,EAAE,EAAC,MAAM,YACb,sBAAI,KAAK,GAAK,GACT,EACP,eAAK,aAAa,EAAC,KAAK,aACtB,eAAM,EAAE,EAAE,WAAW,uBAAU,EAC/B,uCAAsB,EACtB,eAAM,EAAE,EAAE,WAAW,YAAG,UAAU,GAAQ,IACtC,IACF,CACP,CAAA;AACH,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { ReactNode } from 'react';
2
+ interface MainPanelProps {
3
+ title: string;
4
+ children: ReactNode;
5
+ }
6
+ export declare function MainPanel({ title, children }: MainPanelProps): ReactNode;
7
+ export {};
8
+ //# sourceMappingURL=MainPanel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MainPanel.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/MainPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAEtC,UAAU,cAAc;IACtB,KAAK,EAAE,MAAM,CAAA;IACb,QAAQ,EAAE,SAAS,CAAA;CACpB;AAED,wBAAgB,SAAS,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,cAAc,aAmB5D"}
@@ -0,0 +1,5 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "@opentui/react/jsx-runtime";
2
+ export function MainPanel({ title, children }) {
3
+ return (_jsxs("box", { flexGrow: 1, flexDirection: "column", borderStyle: "single", children: [_jsx("box", { height: 1, justifyContent: "center", children: _jsx("text", { children: _jsx("b", { children: title }) }) }), _jsx("box", { flexGrow: 1, flexDirection: "column", paddingTop: 1, paddingLeft: 1, paddingRight: 1, children: children })] }));
4
+ }
5
+ //# sourceMappingURL=MainPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MainPanel.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/MainPanel.tsx"],"names":[],"mappings":";AAOA,MAAM,UAAU,SAAS,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAkB;IAC3D,OAAO,CACL,eAAK,QAAQ,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAC,QAAQ,aAC3D,cAAK,MAAM,EAAE,CAAC,EAAE,cAAc,EAAC,QAAQ,YACrC,yBACE,sBAAI,KAAK,GAAK,GACT,GACH,EACN,cACE,QAAQ,EAAE,CAAC,EACX,aAAa,EAAC,QAAQ,EACtB,UAAU,EAAE,CAAC,EACb,WAAW,EAAE,CAAC,EACd,YAAY,EAAE,CAAC,YAEd,QAAQ,GACL,IACF,CACP,CAAA;AACH,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { ViewId } from '../../types/views.js';
2
+ interface SidebarProps {
3
+ currentView: ViewId;
4
+ selectedIndex: number;
5
+ onNavigate: (view: ViewId) => void;
6
+ }
7
+ export declare function Sidebar({ currentView, selectedIndex }: SidebarProps): import("react").ReactNode;
8
+ export {};
9
+ //# sourceMappingURL=Sidebar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Sidebar.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/Sidebar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAA;AAGlD,UAAU,YAAY;IACpB,WAAW,EAAE,MAAM,CAAA;IACnB,aAAa,EAAE,MAAM,CAAA;IACrB,UAAU,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;CACnC;AAED,wBAAgB,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,EAAE,YAAY,6BA4BnE"}
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "@opentui/react/jsx-runtime";
2
+ import { SIDEBAR_VIEWS, VIEW_LABELS } from '../../types/views.js';
3
+ export function Sidebar({ currentView, selectedIndex }) {
4
+ return (_jsxs("box", { width: 20, flexDirection: "column", borderStyle: "single", children: [_jsx("box", { height: 1, justifyContent: "center", children: _jsx("text", { children: _jsx("b", { children: "Navigation" }) }) }), _jsx("box", { flexDirection: "column", paddingTop: 1, children: SIDEBAR_VIEWS.map((view, index) => {
5
+ const isSelected = index === selectedIndex;
6
+ const isCurrent = view === currentView;
7
+ const label = `${isSelected ? '>' : ' '} ${VIEW_LABELS[view]}`;
8
+ return (_jsx("box", { height: 1, children: _jsx("text", { fg: isCurrent ? 'cyan' : isSelected ? 'white' : 'gray', bg: isSelected ? 'gray' : undefined, children: isCurrent ? _jsx("b", { children: label }) : label }) }, view));
9
+ }) })] }));
10
+ }
11
+ //# sourceMappingURL=Sidebar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Sidebar.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/Sidebar.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAQjE,MAAM,UAAU,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAgB;IAClE,OAAO,CACL,eAAK,KAAK,EAAE,EAAE,EAAE,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAC,QAAQ,aACzD,cAAK,MAAM,EAAE,CAAC,EAAE,cAAc,EAAC,QAAQ,YACrC,yBACE,qCAAiB,GACZ,GACH,EACN,cAAK,aAAa,EAAC,QAAQ,EAAC,UAAU,EAAE,CAAC,YACtC,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;oBACjC,MAAM,UAAU,GAAG,KAAK,KAAK,aAAa,CAAA;oBAC1C,MAAM,SAAS,GAAG,IAAI,KAAK,WAAW,CAAA;oBACtC,MAAM,KAAK,GAAG,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,EAAE,CAAA;oBAE9D,OAAO,CACL,cAAgB,MAAM,EAAE,CAAC,YACvB,eACE,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EACtD,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,YAElC,SAAS,CAAC,CAAC,CAAC,sBAAI,KAAK,GAAK,CAAC,CAAC,CAAC,KAAK,GAC9B,IANC,IAAI,CAOR,CACP,CAAA;gBACH,CAAC,CAAC,GACE,IACF,CACP,CAAA;AACH,CAAC"}
@@ -0,0 +1,11 @@
1
+ interface Shortcut {
2
+ key: string;
3
+ label: string;
4
+ }
5
+ interface StatusBarProps {
6
+ shortcuts: Shortcut[];
7
+ error?: string | null;
8
+ }
9
+ export declare function StatusBar({ shortcuts, error }: StatusBarProps): import("react").ReactNode;
10
+ export {};
11
+ //# sourceMappingURL=StatusBar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusBar.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/StatusBar.tsx"],"names":[],"mappings":"AAAA,UAAU,QAAQ;IAChB,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,MAAM,CAAA;CACd;AAED,UAAU,cAAc;IACtB,SAAS,EAAE,QAAQ,EAAE,CAAA;IACrB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CACtB;AAED,wBAAgB,SAAS,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,cAAc,6BAqB7D"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "@opentui/react/jsx-runtime";
2
+ export function StatusBar({ shortcuts, error }) {
3
+ if (error) {
4
+ return (_jsx("box", { height: 1, width: "100%", children: _jsx("text", { fg: "red", children: error }) }));
5
+ }
6
+ return (_jsx("box", { height: 1, width: "100%", flexDirection: "row", gap: 2, children: shortcuts.map((shortcut, index) => (_jsxs("box", { flexDirection: "row", children: [_jsx("text", { fg: "yellow", children: _jsx("b", { children: shortcut.key }) }), _jsxs("text", { children: [": ", shortcut.label] })] }, index))) }));
7
+ }
8
+ //# sourceMappingURL=StatusBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusBar.js","sourceRoot":"","sources":["../../../../src/tui/components/layout/StatusBar.tsx"],"names":[],"mappings":";AAUA,MAAM,UAAU,SAAS,CAAC,EAAE,SAAS,EAAE,KAAK,EAAkB;IAC5D,IAAI,KAAK,EAAE,CAAC;QACV,OAAO,CACL,cAAK,MAAM,EAAE,CAAC,EAAE,KAAK,EAAC,MAAM,YAC1B,eAAM,EAAE,EAAC,KAAK,YAAE,KAAK,GAAQ,GACzB,CACP,CAAA;IACH,CAAC;IAED,OAAO,CACL,cAAK,MAAM,EAAE,CAAC,EAAE,KAAK,EAAC,MAAM,EAAC,aAAa,EAAC,KAAK,EAAC,GAAG,EAAE,CAAC,YACpD,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CAClC,eAAiB,aAAa,EAAC,KAAK,aAClC,eAAM,EAAE,EAAC,QAAQ,YACf,sBAAI,QAAQ,CAAC,GAAG,GAAK,GAChB,EACP,iCAAS,QAAQ,CAAC,KAAK,IAAQ,KAJvB,KAAK,CAKT,CACP,CAAC,GACE,CACP,CAAA;AACH,CAAC"}
@@ -0,0 +1,5 @@
1
+ export declare function useDaemonConnection(): {
2
+ connected: boolean;
3
+ retry: () => Promise<void>;
4
+ };
5
+ //# sourceMappingURL=useDaemonConnection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDaemonConnection.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/useDaemonConnection.ts"],"names":[],"mappings":"AAIA,wBAAgB,mBAAmB;;;EAsBlC"}
@@ -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"}