centy 0.0.5 → 0.0.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/README.md +299 -0
  2. package/bin/run.js +14 -2
  3. package/dist/commands/install/daemon.d.ts +12 -0
  4. package/dist/commands/install/daemon.d.ts.map +1 -0
  5. package/dist/commands/install/daemon.js +41 -0
  6. package/dist/commands/install/daemon.js.map +1 -0
  7. package/dist/commands/shutdown.d.ts.map +1 -1
  8. package/dist/commands/shutdown.js +5 -0
  9. package/dist/commands/shutdown.js.map +1 -1
  10. package/dist/commands/start.d.ts +13 -0
  11. package/dist/commands/start.d.ts.map +1 -0
  12. package/dist/commands/start.js +79 -0
  13. package/dist/commands/start.js.map +1 -0
  14. package/dist/hooks/prerun.js +1 -1
  15. package/dist/hooks/prerun.js.map +1 -1
  16. package/dist/lib/install-daemon/checksum.d.ts +2 -0
  17. package/dist/lib/install-daemon/checksum.d.ts.map +1 -0
  18. package/dist/lib/install-daemon/checksum.js +31 -0
  19. package/dist/lib/install-daemon/checksum.js.map +1 -0
  20. package/dist/lib/install-daemon/download.d.ts +8 -0
  21. package/dist/lib/install-daemon/download.d.ts.map +1 -0
  22. package/dist/lib/install-daemon/download.js +40 -0
  23. package/dist/lib/install-daemon/download.js.map +1 -0
  24. package/dist/lib/install-daemon/errors.d.ts +23 -0
  25. package/dist/lib/install-daemon/errors.d.ts.map +1 -0
  26. package/dist/lib/install-daemon/errors.js +42 -0
  27. package/dist/lib/install-daemon/errors.js.map +1 -0
  28. package/dist/lib/install-daemon/extract.d.ts +2 -0
  29. package/dist/lib/install-daemon/extract.d.ts.map +1 -0
  30. package/dist/lib/install-daemon/extract.js +38 -0
  31. package/dist/lib/install-daemon/extract.js.map +1 -0
  32. package/dist/lib/install-daemon/github-api.d.ts +9 -0
  33. package/dist/lib/install-daemon/github-api.d.ts.map +1 -0
  34. package/dist/lib/install-daemon/github-api.js +60 -0
  35. package/dist/lib/install-daemon/github-api.js.map +1 -0
  36. package/dist/lib/install-daemon/index.d.ts +3 -0
  37. package/dist/lib/install-daemon/index.d.ts.map +1 -0
  38. package/dist/lib/install-daemon/index.js +2 -0
  39. package/dist/lib/install-daemon/index.js.map +1 -0
  40. package/dist/lib/install-daemon/install-daemon.d.ts +3 -0
  41. package/dist/lib/install-daemon/install-daemon.d.ts.map +1 -0
  42. package/dist/lib/install-daemon/install-daemon.js +100 -0
  43. package/dist/lib/install-daemon/install-daemon.js.map +1 -0
  44. package/dist/lib/install-daemon/platform.d.ts +3 -0
  45. package/dist/lib/install-daemon/platform.d.ts.map +1 -0
  46. package/dist/lib/install-daemon/platform.js +24 -0
  47. package/dist/lib/install-daemon/platform.js.map +1 -0
  48. package/dist/lib/install-daemon/types.d.ts +34 -0
  49. package/dist/lib/install-daemon/types.d.ts.map +1 -0
  50. package/dist/lib/install-daemon/types.js +7 -0
  51. package/dist/lib/install-daemon/types.js.map +1 -0
  52. package/dist/lib/start/daemon-binary-exists.d.ts +2 -0
  53. package/dist/lib/start/daemon-binary-exists.d.ts.map +1 -0
  54. package/dist/lib/start/daemon-binary-exists.js +10 -0
  55. package/dist/lib/start/daemon-binary-exists.js.map +1 -0
  56. package/dist/lib/start/find-daemon-binary.d.ts +2 -0
  57. package/dist/lib/start/find-daemon-binary.d.ts.map +1 -0
  58. package/dist/lib/start/find-daemon-binary.js +31 -0
  59. package/dist/lib/start/find-daemon-binary.js.map +1 -0
  60. package/dist/lib/start/wait-for-daemon.d.ts +7 -0
  61. package/dist/lib/start/wait-for-daemon.d.ts.map +1 -0
  62. package/dist/lib/start/wait-for-daemon.js +20 -0
  63. package/dist/lib/start/wait-for-daemon.js.map +1 -0
  64. package/dist/tui/App.d.ts +6 -0
  65. package/dist/tui/App.d.ts.map +1 -0
  66. package/dist/tui/App.js +64 -0
  67. package/dist/tui/App.js.map +1 -0
  68. package/dist/tui/components/domain/DaemonPanel.d.ts +2 -0
  69. package/dist/tui/components/domain/DaemonPanel.d.ts.map +1 -0
  70. package/dist/tui/components/domain/DaemonPanel.js +35 -0
  71. package/dist/tui/components/domain/DaemonPanel.js.map +1 -0
  72. package/dist/tui/components/domain/IssueList.d.ts +2 -0
  73. package/dist/tui/components/domain/IssueList.d.ts.map +1 -0
  74. package/dist/tui/components/domain/IssueList.js +52 -0
  75. package/dist/tui/components/domain/IssueList.js.map +1 -0
  76. package/dist/tui/components/domain/ProjectList.d.ts +2 -0
  77. package/dist/tui/components/domain/ProjectList.d.ts.map +1 -0
  78. package/dist/tui/components/domain/ProjectList.js +54 -0
  79. package/dist/tui/components/domain/ProjectList.js.map +1 -0
  80. package/dist/tui/components/layout/Header.d.ts +7 -0
  81. package/dist/tui/components/layout/Header.d.ts.map +1 -0
  82. package/dist/tui/components/layout/Header.js +7 -0
  83. package/dist/tui/components/layout/Header.js.map +1 -0
  84. package/dist/tui/components/layout/MainPanel.d.ts +8 -0
  85. package/dist/tui/components/layout/MainPanel.d.ts.map +1 -0
  86. package/dist/tui/components/layout/MainPanel.js +5 -0
  87. package/dist/tui/components/layout/MainPanel.js.map +1 -0
  88. package/dist/tui/components/layout/Sidebar.d.ts +9 -0
  89. package/dist/tui/components/layout/Sidebar.d.ts.map +1 -0
  90. package/dist/tui/components/layout/Sidebar.js +11 -0
  91. package/dist/tui/components/layout/Sidebar.js.map +1 -0
  92. package/dist/tui/components/layout/StatusBar.d.ts +11 -0
  93. package/dist/tui/components/layout/StatusBar.d.ts.map +1 -0
  94. package/dist/tui/components/layout/StatusBar.js +8 -0
  95. package/dist/tui/components/layout/StatusBar.js.map +1 -0
  96. package/dist/tui/hooks/useDaemonActions.d.ts +12 -0
  97. package/dist/tui/hooks/useDaemonActions.d.ts.map +1 -0
  98. package/dist/tui/hooks/useDaemonActions.js +77 -0
  99. package/dist/tui/hooks/useDaemonActions.js.map +1 -0
  100. package/dist/tui/hooks/useDaemonConnection.d.ts +5 -0
  101. package/dist/tui/hooks/useDaemonConnection.d.ts.map +1 -0
  102. package/dist/tui/hooks/useDaemonConnection.js +24 -0
  103. package/dist/tui/hooks/useDaemonConnection.js.map +1 -0
  104. package/dist/tui/hooks/useDaemonInfo.d.ts +10 -0
  105. package/dist/tui/hooks/useDaemonInfo.d.ts.map +1 -0
  106. package/dist/tui/hooks/useDaemonInfo.js +26 -0
  107. package/dist/tui/hooks/useDaemonInfo.js.map +1 -0
  108. package/dist/tui/hooks/useIssues.d.ts +8 -0
  109. package/dist/tui/hooks/useIssues.d.ts.map +1 -0
  110. package/dist/tui/hooks/useIssues.js +36 -0
  111. package/dist/tui/hooks/useIssues.js.map +1 -0
  112. package/dist/tui/hooks/useNavigation.d.ts +11 -0
  113. package/dist/tui/hooks/useNavigation.d.ts.map +1 -0
  114. package/dist/tui/hooks/useNavigation.js +24 -0
  115. package/dist/tui/hooks/useNavigation.js.map +1 -0
  116. package/dist/tui/hooks/useProjects.d.ts +8 -0
  117. package/dist/tui/hooks/useProjects.d.ts.map +1 -0
  118. package/dist/tui/hooks/useProjects.js +36 -0
  119. package/dist/tui/hooks/useProjects.js.map +1 -0
  120. package/dist/tui/index.d.ts +2 -0
  121. package/dist/tui/index.d.ts.map +1 -0
  122. package/dist/tui/index.js +39 -0
  123. package/dist/tui/index.js.map +1 -0
  124. package/dist/tui/services/daemon-service.d.ts +28 -0
  125. package/dist/tui/services/daemon-service.d.ts.map +1 -0
  126. package/dist/tui/services/daemon-service.js +107 -0
  127. package/dist/tui/services/daemon-service.js.map +1 -0
  128. package/dist/tui/state/app-state.d.ts +78 -0
  129. package/dist/tui/state/app-state.d.ts.map +1 -0
  130. package/dist/tui/state/app-state.js +93 -0
  131. package/dist/tui/state/app-state.js.map +1 -0
  132. package/dist/tui/types/views.d.ts +11 -0
  133. package/dist/tui/types/views.d.ts.map +1 -0
  134. package/dist/tui/types/views.js +25 -0
  135. package/dist/tui/types/views.js.map +1 -0
  136. package/oclif.manifest.json +83 -1
  137. package/package.json +10 -3
@@ -0,0 +1,35 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "@opentui/react/jsx-runtime";
2
+ import { MainPanel } from '../layout/MainPanel.js';
3
+ import { useDaemonConnection } from '../../hooks/useDaemonConnection.js';
4
+ import { useDaemonInfo } from '../../hooks/useDaemonInfo.js';
5
+ import { useDaemonActions, } from '../../hooks/useDaemonActions.js';
6
+ function DaemonInfoDisplay({ daemonInfo }) {
7
+ return (_jsxs(_Fragment, { children: [_jsxs("box", { flexDirection: "row", children: [_jsx("text", { children: "Version: " }), _jsx("text", { fg: "cyan", children: daemonInfo.version })] }), daemonInfo.availableVersions.length > 0 && (_jsxs("box", { flexDirection: "column", children: [_jsx("text", { fg: "gray", children: "Available versions:" }), _jsx("box", { paddingLeft: 2, children: _jsx("text", { fg: "gray", children: daemonInfo.availableVersions.join(', ') }) })] }))] }));
8
+ }
9
+ function DaemonControls() {
10
+ return (_jsxs("box", { marginTop: 1, flexDirection: "column", children: [_jsx("text", { children: _jsx("b", { children: "Controls" }) }), _jsxs("box", { paddingLeft: 1, flexDirection: "column", children: [_jsx("text", { fg: "gray", children: "[s] Shutdown daemon" }), _jsx("text", { fg: "gray", children: "[r] Restart daemon" }), _jsx("text", { fg: "gray", children: "[c] Check connection" })] })] }));
11
+ }
12
+ function ActionMessage({ message, actionState }) {
13
+ const color = actionState === 'confirming'
14
+ ? 'yellow'
15
+ : message.startsWith('Error')
16
+ ? 'red'
17
+ : 'green';
18
+ return (_jsx("box", { marginTop: 1, children: _jsx("text", { fg: color, children: message }) }));
19
+ }
20
+ function DisconnectedView({ actionMessage }) {
21
+ return (_jsx(MainPanel, { title: "Daemon", children: _jsxs("box", { flexDirection: "column", gap: 1, children: [_jsxs("box", { flexDirection: "row", children: [_jsx("text", { children: "Status: " }), _jsx("text", { fg: "red", children: "Disconnected" })] }), _jsx("text", { fg: "gray", children: "The daemon is not running or cannot be reached." }), _jsx("box", { marginTop: 1, children: _jsx("text", { fg: "gray", children: "[c] Check connection" }) }), actionMessage && (_jsx("box", { marginTop: 1, children: _jsx("text", { fg: "yellow", children: actionMessage }) }))] }) }));
22
+ }
23
+ export function DaemonPanel() {
24
+ const { connected, retry } = useDaemonConnection();
25
+ const { daemonInfo, isLoading } = useDaemonInfo({ connected });
26
+ const { actionState, actionMessage } = useDaemonActions({ connected, retry });
27
+ if (!connected) {
28
+ return _jsx(DisconnectedView, { actionMessage: actionMessage });
29
+ }
30
+ if (isLoading) {
31
+ return (_jsx(MainPanel, { title: "Daemon", children: _jsx("text", { fg: "gray", children: "Loading daemon info..." }) }));
32
+ }
33
+ return (_jsx(MainPanel, { title: "Daemon", children: _jsxs("box", { flexDirection: "column", gap: 1, children: [_jsxs("box", { flexDirection: "row", children: [_jsx("text", { children: "Status: " }), _jsx("text", { fg: "green", children: "Connected" })] }), daemonInfo && _jsx(DaemonInfoDisplay, { daemonInfo: daemonInfo }), _jsx(DaemonControls, {}), actionMessage && (_jsx(ActionMessage, { message: actionMessage, actionState: actionState }))] }) }));
34
+ }
35
+ //# sourceMappingURL=DaemonPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DaemonPanel.js","sourceRoot":"","sources":["../../../../src/tui/components/domain/DaemonPanel.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAA;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAA;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAA;AAC5D,OAAO,EACL,gBAAgB,GAEjB,MAAM,iCAAiC,CAAA;AAOxC,SAAS,iBAAiB,CAAC,EAAE,UAAU,EAA0B;IAC/D,OAAO,CACL,8BACE,eAAK,aAAa,EAAC,KAAK,aACtB,uCAAsB,EACtB,eAAM,EAAE,EAAC,MAAM,YAAE,UAAU,CAAC,OAAO,GAAQ,IACvC,EACL,UAAU,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,IAAI,CAC1C,eAAK,aAAa,EAAC,QAAQ,aACzB,eAAM,EAAE,EAAC,MAAM,oCAA2B,EAC1C,cAAK,WAAW,EAAE,CAAC,YACjB,eAAM,EAAE,EAAC,MAAM,YAAE,UAAU,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,GAAQ,GAC5D,IACF,CACP,IACA,CACJ,CAAA;AACH,CAAC;AAED,SAAS,cAAc;IACrB,OAAO,CACL,eAAK,SAAS,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ,aACvC,yBACE,mCAAe,GACV,EACP,eAAK,WAAW,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ,aACzC,eAAM,EAAE,EAAC,MAAM,oCAA2B,EAC1C,eAAM,EAAE,EAAC,MAAM,mCAA0B,EACzC,eAAM,EAAE,EAAC,MAAM,qCAA4B,IACvC,IACF,CACP,CAAA;AACH,CAAC;AAOD,SAAS,aAAa,CAAC,EAAE,OAAO,EAAE,WAAW,EAAsB;IACjE,MAAM,KAAK,GACT,WAAW,KAAK,YAAY;QAC1B,CAAC,CAAC,QAAQ;QACV,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC;YAC3B,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,OAAO,CAAA;IAEf,OAAO,CACL,cAAK,SAAS,EAAE,CAAC,YACf,eAAM,EAAE,EAAE,KAAK,YAAG,OAAO,GAAQ,GAC7B,CACP,CAAA;AACH,CAAC;AAMD,SAAS,gBAAgB,CAAC,EAAE,aAAa,EAAyB;IAChE,OAAO,CACL,KAAC,SAAS,IAAC,KAAK,EAAC,QAAQ,YACvB,eAAK,aAAa,EAAC,QAAQ,EAAC,GAAG,EAAE,CAAC,aAChC,eAAK,aAAa,EAAC,KAAK,aACtB,sCAAqB,EACrB,eAAM,EAAE,EAAC,KAAK,6BAAoB,IAC9B,EACN,eAAM,EAAE,EAAC,MAAM,gEAAuD,EACtE,cAAK,SAAS,EAAE,CAAC,YACf,eAAM,EAAE,EAAC,MAAM,qCAA4B,GACvC,EACL,aAAa,IAAI,CAChB,cAAK,SAAS,EAAE,CAAC,YACf,eAAM,EAAE,EAAC,QAAQ,YAAE,aAAa,GAAQ,GACpC,CACP,IACG,GACI,CACb,CAAA;AACH,CAAC;AAED,MAAM,UAAU,WAAW;IACzB,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,mBAAmB,EAAE,CAAA;IAClD,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC,EAAE,SAAS,EAAE,CAAC,CAAA;IAC9D,MAAM,EAAE,WAAW,EAAE,aAAa,EAAE,GAAG,gBAAgB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;IAE7E,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,OAAO,KAAC,gBAAgB,IAAC,aAAa,EAAE,aAAa,GAAI,CAAA;IAC3D,CAAC;IAED,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,CACL,KAAC,SAAS,IAAC,KAAK,EAAC,QAAQ,YACvB,eAAM,EAAE,EAAC,MAAM,uCAA8B,GACnC,CACb,CAAA;IACH,CAAC;IAED,OAAO,CACL,KAAC,SAAS,IAAC,KAAK,EAAC,QAAQ,YACvB,eAAK,aAAa,EAAC,QAAQ,EAAC,GAAG,EAAE,CAAC,aAChC,eAAK,aAAa,EAAC,KAAK,aACtB,sCAAqB,EACrB,eAAM,EAAE,EAAC,OAAO,0BAAiB,IAC7B,EACL,UAAU,IAAI,KAAC,iBAAiB,IAAC,UAAU,EAAE,UAAU,GAAI,EAC5D,KAAC,cAAc,KAAG,EACjB,aAAa,IAAI,CAChB,KAAC,aAAa,IAAC,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,GAAI,CACpE,IACG,GACI,CACb,CAAA;AACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function IssueList(): import("react").ReactNode;
2
+ //# sourceMappingURL=IssueList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IssueList.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/domain/IssueList.tsx"],"names":[],"mappings":"AAqBA,wBAAgB,SAAS,8BAmExB"}
@@ -0,0 +1,52 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "@opentui/react/jsx-runtime";
2
+ import { useState } from 'react';
3
+ import { useKeyboard } from '@opentui/react';
4
+ import { MainPanel } from '../layout/MainPanel.js';
5
+ import { useIssues } from '../../hooks/useIssues.js';
6
+ import { useAppState } from '../../state/app-state.js';
7
+ function getPriorityColor(priority) {
8
+ if (priority === 1)
9
+ return 'red';
10
+ if (priority === 2)
11
+ return 'yellow';
12
+ return 'green';
13
+ }
14
+ function getPriorityLabel(priority, label) {
15
+ if (label)
16
+ return label;
17
+ if (priority === 1)
18
+ return 'high';
19
+ if (priority === 2)
20
+ return 'med';
21
+ return 'low';
22
+ }
23
+ export function IssueList() {
24
+ const { issues, isLoading } = useIssues();
25
+ const { state } = useAppState();
26
+ const [selectedIndex, setSelectedIndex] = useState(0);
27
+ useKeyboard((event) => {
28
+ if (event.name === 'j' || event.name === 'down') {
29
+ setSelectedIndex((prev) => Math.min(prev + 1, issues.length - 1));
30
+ }
31
+ else if (event.name === 'k' || event.name === 'up') {
32
+ setSelectedIndex((prev) => Math.max(prev - 1, 0));
33
+ }
34
+ });
35
+ const projectName = state.selectedProjectPath?.split('/').pop() || 'Project';
36
+ if (!state.selectedProjectPath) {
37
+ return (_jsx(MainPanel, { title: "Issues", children: _jsx("text", { fg: "gray", children: "Select a project first." }) }));
38
+ }
39
+ if (isLoading) {
40
+ return (_jsx(MainPanel, { title: `Issues - ${projectName}`, children: _jsx("text", { fg: "gray", children: "Loading issues..." }) }));
41
+ }
42
+ if (issues.length === 0) {
43
+ return (_jsxs(MainPanel, { title: `Issues - ${projectName}`, children: [_jsx("text", { fg: "gray", children: "No issues found." }), _jsx("text", { fg: "gray", children: "Press `n` to create a new issue." })] }));
44
+ }
45
+ return (_jsx(MainPanel, { title: `Issues - ${projectName}`, children: issues.map((issue, index) => {
46
+ const isSelected = index === selectedIndex;
47
+ const priorityColor = getPriorityColor(issue.metadata.priority);
48
+ const priorityLabel = getPriorityLabel(issue.metadata.priority, issue.metadata.priorityLabel);
49
+ return (_jsxs("box", { height: 1, flexDirection: "row", children: [_jsx("text", { bg: isSelected ? 'gray' : undefined, children: isSelected ? _jsx("b", { children: '>' }) : ' ' }), _jsxs("text", { fg: "cyan", children: ["#", issue.displayNumber] }), _jsx("text", { children: " " }), _jsxs("text", { fg: priorityColor, children: ["[", priorityLabel, "]"] }), _jsx("text", { children: " " }), _jsxs("text", { fg: "gray", children: ["[", issue.metadata.status, "]"] }), _jsx("text", { children: " " }), _jsx("text", { bg: isSelected ? 'gray' : undefined, children: issue.title })] }, issue.id));
50
+ }) }));
51
+ }
52
+ //# sourceMappingURL=IssueList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IssueList.js","sourceRoot":"","sources":["../../../../src/tui/components/domain/IssueList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function ProjectList(): import("react").ReactNode;
2
+ //# sourceMappingURL=ProjectList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProjectList.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/domain/ProjectList.tsx"],"names":[],"mappings":"AAyCA,wBAAgB,WAAW,8BAuE1B"}
@@ -0,0 +1,54 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "@opentui/react/jsx-runtime";
2
+ import { useState, useRef, useEffect } from 'react';
3
+ import { useKeyboard } from '@opentui/react';
4
+ import { MainPanel } from '../layout/MainPanel.js';
5
+ import { useProjects } from '../../hooks/useProjects.js';
6
+ import { useNavigation } from '../../hooks/useNavigation.js';
7
+ const ITEM_HEIGHT = 2;
8
+ function ProjectItem({ project, isSelected }) {
9
+ const name = project.name || project.path.split('/').pop() || project.path;
10
+ return (_jsxs("box", { height: ITEM_HEIGHT, flexDirection: "column", children: [_jsx("box", { flexDirection: "row", children: _jsx("text", { bg: isSelected ? 'gray' : undefined, children: isSelected ? (_jsxs("b", { children: ['>', " ", name] })) : (` ${name}`) }) }), _jsxs("box", { flexDirection: "row", paddingLeft: 3, children: [_jsxs("text", { fg: "gray", children: [project.issueCount, " issues, ", project.docCount, " docs"] }), !project.initialized && _jsx("text", { fg: "yellow", children: " (not initialized)" })] })] }, project.path));
11
+ }
12
+ export function ProjectList() {
13
+ const { projects, isLoading, selectProject } = useProjects();
14
+ const { navigate } = useNavigation();
15
+ const [selectedIndex, setSelectedIndex] = useState(0);
16
+ const scrollBoxRef = useRef(null);
17
+ useEffect(() => {
18
+ if (scrollBoxRef.current) {
19
+ const targetScrollTop = selectedIndex * ITEM_HEIGHT;
20
+ const viewportHeight = scrollBoxRef.current.viewport.height;
21
+ const currentScrollTop = scrollBoxRef.current.scrollTop;
22
+ if (targetScrollTop < currentScrollTop) {
23
+ scrollBoxRef.current.scrollTo(targetScrollTop);
24
+ }
25
+ else if (targetScrollTop + ITEM_HEIGHT >
26
+ currentScrollTop + viewportHeight) {
27
+ scrollBoxRef.current.scrollTo(targetScrollTop - viewportHeight + ITEM_HEIGHT);
28
+ }
29
+ }
30
+ }, [selectedIndex]);
31
+ useKeyboard((event) => {
32
+ if (event.name === 'j' || event.name === 'down') {
33
+ setSelectedIndex((prev) => Math.min(prev + 1, projects.length - 1));
34
+ }
35
+ else if (event.name === 'k' || event.name === 'up') {
36
+ setSelectedIndex((prev) => Math.max(prev - 1, 0));
37
+ }
38
+ else if (event.name === 'return') {
39
+ const project = projects[selectedIndex];
40
+ if (project) {
41
+ selectProject(project.path);
42
+ navigate('issues');
43
+ }
44
+ }
45
+ });
46
+ if (isLoading) {
47
+ return (_jsx(MainPanel, { title: "Projects", children: _jsx("text", { fg: "gray", children: "Loading projects..." }) }));
48
+ }
49
+ if (projects.length === 0) {
50
+ return (_jsxs(MainPanel, { title: "Projects", children: [_jsx("text", { fg: "gray", children: "No projects found." }), _jsx("text", { fg: "gray", children: "Use `centy register project` to add a project." })] }));
51
+ }
52
+ return (_jsx(MainPanel, { title: "Projects", children: _jsx("scrollbox", { ref: scrollBoxRef, flexGrow: 1, scrollY: true, children: projects.map((project, index) => (_jsx(ProjectItem, { project: project, isSelected: index === selectedIndex }, project.path))) }) }));
53
+ }
54
+ //# sourceMappingURL=ProjectList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProjectList.js","sourceRoot":"","sources":["../../../../src/tui/components/domain/ProjectList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ interface HeaderProps {
2
+ title: string;
3
+ daemonConnected: boolean;
4
+ }
5
+ export declare function Header({ title, daemonConnected }: HeaderProps): import("react").ReactNode;
6
+ export {};
7
+ //# sourceMappingURL=Header.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Header.d.ts","sourceRoot":"","sources":["../../../../src/tui/components/layout/Header.tsx"],"names":[],"mappings":"AAAA,UAAU,WAAW;IACnB,KAAK,EAAE,MAAM,CAAA;IACb,eAAe,EAAE,OAAO,CAAA;CACzB;AAED,wBAAgB,MAAM,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,EAAE,WAAW,6BAqB7D"}
@@ -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,12 @@
1
+ export type ActionState = 'idle' | 'confirming' | 'executing';
2
+ export type DaemonAction = 'shutdown' | 'restart';
3
+ interface UseDaemonActionsParams {
4
+ connected: boolean;
5
+ retry: () => void;
6
+ }
7
+ export declare function useDaemonActions({ connected, retry }: UseDaemonActionsParams): {
8
+ actionState: ActionState;
9
+ actionMessage: string | null;
10
+ };
11
+ export {};
12
+ //# sourceMappingURL=useDaemonActions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDaemonActions.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/useDaemonActions.ts"],"names":[],"mappings":"AAKA,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,YAAY,GAAG,WAAW,CAAA;AAC7D,MAAM,MAAM,YAAY,GAAG,UAAU,GAAG,SAAS,CAAA;AAEjD,UAAU,sBAAsB;IAC9B,SAAS,EAAE,OAAO,CAAA;IAClB,KAAK,EAAE,MAAM,IAAI,CAAA;CAClB;AAsBD,wBAAgB,gBAAgB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,sBAAsB;;;EA8D5E"}
@@ -0,0 +1,77 @@
1
+ import { useState, useCallback } from 'react';
2
+ import { useKeyboard } from '@opentui/react';
3
+ import { daemonService } from '../services/daemon-service.js';
4
+ async function performAction(action) {
5
+ return action === 'shutdown'
6
+ ? daemonService.shutdown()
7
+ : daemonService.restart();
8
+ }
9
+ function getActionMessages(action) {
10
+ return {
11
+ executing: action === 'shutdown' ? 'Shutting down...' : 'Restarting...',
12
+ success: action === 'shutdown'
13
+ ? 'Daemon shut down successfully'
14
+ : 'Daemon restarting...',
15
+ confirm: action === 'shutdown'
16
+ ? 'Shutdown daemon? (y/n)'
17
+ : 'Restart daemon? (y/n)',
18
+ };
19
+ }
20
+ export function useDaemonActions({ connected, retry }) {
21
+ const [actionState, setActionState] = useState('idle');
22
+ const [pendingAction, setPendingAction] = useState(null);
23
+ const [actionMessage, setActionMessage] = useState(null);
24
+ const resetState = useCallback(() => {
25
+ setActionState('idle');
26
+ setPendingAction(null);
27
+ }, []);
28
+ const executeAction = useCallback(async (action) => {
29
+ const messages = getActionMessages(action);
30
+ setActionState('executing');
31
+ setActionMessage(messages.executing);
32
+ const result = await performAction(action);
33
+ if (result.success) {
34
+ setActionMessage(result.data?.message || messages.success);
35
+ setTimeout(() => {
36
+ retry();
37
+ resetState();
38
+ }, 2000);
39
+ }
40
+ else {
41
+ setActionMessage(`Error: ${result.error}`);
42
+ resetState();
43
+ }
44
+ }, [retry, resetState]);
45
+ useKeyboard((event) => {
46
+ if (actionState === 'executing')
47
+ return;
48
+ if (actionState === 'confirming') {
49
+ const isConfirm = event.name === 'y' || event.name === 'Y';
50
+ const isCancel = event.name === 'n' || event.name === 'N' || event.name === 'escape';
51
+ if (isConfirm && pendingAction)
52
+ executeAction(pendingAction);
53
+ if (isCancel) {
54
+ resetState();
55
+ setActionMessage(null);
56
+ }
57
+ return;
58
+ }
59
+ if (event.name === 's' && connected) {
60
+ setActionState('confirming');
61
+ setPendingAction('shutdown');
62
+ setActionMessage(getActionMessages('shutdown').confirm);
63
+ }
64
+ else if (event.name === 'r' && connected) {
65
+ setActionState('confirming');
66
+ setPendingAction('restart');
67
+ setActionMessage(getActionMessages('restart').confirm);
68
+ }
69
+ else if (event.name === 'c') {
70
+ retry();
71
+ setActionMessage('Checking connection...');
72
+ setTimeout(() => setActionMessage(null), 1500);
73
+ }
74
+ });
75
+ return { actionState, actionMessage };
76
+ }
77
+ //# sourceMappingURL=useDaemonActions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDaemonActions.js","sourceRoot":"","sources":["../../../src/tui/hooks/useDaemonActions.ts"],"names":[],"mappings":"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"}
@@ -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,10 @@
1
+ import type { DaemonInfo } from '../../daemon/types.js';
2
+ interface UseDaemonInfoParams {
3
+ connected: boolean;
4
+ }
5
+ export declare function useDaemonInfo({ connected }: UseDaemonInfoParams): {
6
+ daemonInfo: DaemonInfo | null;
7
+ isLoading: boolean;
8
+ };
9
+ export {};
10
+ //# sourceMappingURL=useDaemonInfo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDaemonInfo.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/useDaemonInfo.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAA;AAEvD,UAAU,mBAAmB;IAC3B,SAAS,EAAE,OAAO,CAAA;CACnB;AAED,wBAAgB,aAAa,CAAC,EAAE,SAAS,EAAE,EAAE,mBAAmB;;;EAyB/D"}
@@ -0,0 +1,26 @@
1
+ import { useState, useCallback, useEffect } from 'react';
2
+ import { daemonService } from '../services/daemon-service.js';
3
+ export function useDaemonInfo({ connected }) {
4
+ const [daemonInfo, setDaemonInfo] = useState(null);
5
+ const [isLoading, setIsLoading] = useState(true);
6
+ const loadDaemonInfo = useCallback(async () => {
7
+ if (!connected) {
8
+ setIsLoading(false);
9
+ return;
10
+ }
11
+ setIsLoading(true);
12
+ const result = await daemonService.getDaemonInfo();
13
+ if (result.success && result.data) {
14
+ setDaemonInfo(result.data);
15
+ }
16
+ setIsLoading(false);
17
+ }, [connected]);
18
+ useEffect(() => {
19
+ loadDaemonInfo();
20
+ }, [loadDaemonInfo]);
21
+ return {
22
+ daemonInfo,
23
+ isLoading,
24
+ };
25
+ }
26
+ //# sourceMappingURL=useDaemonInfo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDaemonInfo.js","sourceRoot":"","sources":["../../../src/tui/hooks/useDaemonInfo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAA;AAO7D,MAAM,UAAU,aAAa,CAAC,EAAE,SAAS,EAAuB;IAC9D,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAoB,IAAI,CAAC,CAAA;IACrE,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAA;IAEhD,MAAM,cAAc,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAC5C,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,YAAY,CAAC,KAAK,CAAC,CAAA;YACnB,OAAM;QACR,CAAC;QACD,YAAY,CAAC,IAAI,CAAC,CAAA;QAClB,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,aAAa,EAAE,CAAA;QAClD,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;YAClC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAC5B,CAAC;QACD,YAAY,CAAC,KAAK,CAAC,CAAA;IACrB,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,SAAS,CAAC,GAAG,EAAE;QACb,cAAc,EAAE,CAAA;IAClB,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAA;IAEpB,OAAO;QACL,UAAU;QACV,SAAS;KACV,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"}