centy 0.0.5 → 0.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +299 -0
- package/bin/run.js +14 -2
- package/dist/commands/install/daemon.d.ts +12 -0
- package/dist/commands/install/daemon.d.ts.map +1 -0
- package/dist/commands/install/daemon.js +41 -0
- package/dist/commands/install/daemon.js.map +1 -0
- package/dist/commands/shutdown.d.ts.map +1 -1
- package/dist/commands/shutdown.js +5 -0
- package/dist/commands/shutdown.js.map +1 -1
- package/dist/commands/start.d.ts +13 -0
- package/dist/commands/start.d.ts.map +1 -0
- package/dist/commands/start.js +79 -0
- package/dist/commands/start.js.map +1 -0
- package/dist/hooks/prerun.js +1 -1
- package/dist/hooks/prerun.js.map +1 -1
- package/dist/lib/install-daemon/checksum.d.ts +2 -0
- package/dist/lib/install-daemon/checksum.d.ts.map +1 -0
- package/dist/lib/install-daemon/checksum.js +31 -0
- package/dist/lib/install-daemon/checksum.js.map +1 -0
- package/dist/lib/install-daemon/download.d.ts +8 -0
- package/dist/lib/install-daemon/download.d.ts.map +1 -0
- package/dist/lib/install-daemon/download.js +40 -0
- package/dist/lib/install-daemon/download.js.map +1 -0
- package/dist/lib/install-daemon/errors.d.ts +23 -0
- package/dist/lib/install-daemon/errors.d.ts.map +1 -0
- package/dist/lib/install-daemon/errors.js +42 -0
- package/dist/lib/install-daemon/errors.js.map +1 -0
- package/dist/lib/install-daemon/extract.d.ts +2 -0
- package/dist/lib/install-daemon/extract.d.ts.map +1 -0
- package/dist/lib/install-daemon/extract.js +38 -0
- package/dist/lib/install-daemon/extract.js.map +1 -0
- package/dist/lib/install-daemon/github-api.d.ts +9 -0
- package/dist/lib/install-daemon/github-api.d.ts.map +1 -0
- package/dist/lib/install-daemon/github-api.js +60 -0
- package/dist/lib/install-daemon/github-api.js.map +1 -0
- package/dist/lib/install-daemon/index.d.ts +3 -0
- package/dist/lib/install-daemon/index.d.ts.map +1 -0
- package/dist/lib/install-daemon/index.js +2 -0
- package/dist/lib/install-daemon/index.js.map +1 -0
- package/dist/lib/install-daemon/install-daemon.d.ts +3 -0
- package/dist/lib/install-daemon/install-daemon.d.ts.map +1 -0
- package/dist/lib/install-daemon/install-daemon.js +100 -0
- package/dist/lib/install-daemon/install-daemon.js.map +1 -0
- package/dist/lib/install-daemon/platform.d.ts +3 -0
- package/dist/lib/install-daemon/platform.d.ts.map +1 -0
- package/dist/lib/install-daemon/platform.js +24 -0
- package/dist/lib/install-daemon/platform.js.map +1 -0
- package/dist/lib/install-daemon/types.d.ts +34 -0
- package/dist/lib/install-daemon/types.d.ts.map +1 -0
- package/dist/lib/install-daemon/types.js +7 -0
- package/dist/lib/install-daemon/types.js.map +1 -0
- package/dist/lib/start/daemon-binary-exists.d.ts +2 -0
- package/dist/lib/start/daemon-binary-exists.d.ts.map +1 -0
- package/dist/lib/start/daemon-binary-exists.js +10 -0
- package/dist/lib/start/daemon-binary-exists.js.map +1 -0
- package/dist/lib/start/find-daemon-binary.d.ts +2 -0
- package/dist/lib/start/find-daemon-binary.d.ts.map +1 -0
- package/dist/lib/start/find-daemon-binary.js +31 -0
- package/dist/lib/start/find-daemon-binary.js.map +1 -0
- package/dist/lib/start/wait-for-daemon.d.ts +7 -0
- package/dist/lib/start/wait-for-daemon.d.ts.map +1 -0
- package/dist/lib/start/wait-for-daemon.js +20 -0
- package/dist/lib/start/wait-for-daemon.js.map +1 -0
- package/dist/tui/App.d.ts +6 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +64 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/components/domain/DaemonPanel.d.ts +2 -0
- package/dist/tui/components/domain/DaemonPanel.d.ts.map +1 -0
- package/dist/tui/components/domain/DaemonPanel.js +35 -0
- package/dist/tui/components/domain/DaemonPanel.js.map +1 -0
- package/dist/tui/components/domain/IssueList.d.ts +2 -0
- package/dist/tui/components/domain/IssueList.d.ts.map +1 -0
- package/dist/tui/components/domain/IssueList.js +52 -0
- package/dist/tui/components/domain/IssueList.js.map +1 -0
- package/dist/tui/components/domain/ProjectList.d.ts +2 -0
- package/dist/tui/components/domain/ProjectList.d.ts.map +1 -0
- package/dist/tui/components/domain/ProjectList.js +54 -0
- package/dist/tui/components/domain/ProjectList.js.map +1 -0
- package/dist/tui/components/layout/Header.d.ts +7 -0
- package/dist/tui/components/layout/Header.d.ts.map +1 -0
- package/dist/tui/components/layout/Header.js +7 -0
- package/dist/tui/components/layout/Header.js.map +1 -0
- package/dist/tui/components/layout/MainPanel.d.ts +8 -0
- package/dist/tui/components/layout/MainPanel.d.ts.map +1 -0
- package/dist/tui/components/layout/MainPanel.js +5 -0
- package/dist/tui/components/layout/MainPanel.js.map +1 -0
- package/dist/tui/components/layout/Sidebar.d.ts +9 -0
- package/dist/tui/components/layout/Sidebar.d.ts.map +1 -0
- package/dist/tui/components/layout/Sidebar.js +11 -0
- package/dist/tui/components/layout/Sidebar.js.map +1 -0
- package/dist/tui/components/layout/StatusBar.d.ts +11 -0
- package/dist/tui/components/layout/StatusBar.d.ts.map +1 -0
- package/dist/tui/components/layout/StatusBar.js +8 -0
- package/dist/tui/components/layout/StatusBar.js.map +1 -0
- package/dist/tui/hooks/useDaemonActions.d.ts +12 -0
- package/dist/tui/hooks/useDaemonActions.d.ts.map +1 -0
- package/dist/tui/hooks/useDaemonActions.js +77 -0
- package/dist/tui/hooks/useDaemonActions.js.map +1 -0
- package/dist/tui/hooks/useDaemonConnection.d.ts +5 -0
- package/dist/tui/hooks/useDaemonConnection.d.ts.map +1 -0
- package/dist/tui/hooks/useDaemonConnection.js +24 -0
- package/dist/tui/hooks/useDaemonConnection.js.map +1 -0
- package/dist/tui/hooks/useDaemonInfo.d.ts +10 -0
- package/dist/tui/hooks/useDaemonInfo.d.ts.map +1 -0
- package/dist/tui/hooks/useDaemonInfo.js +26 -0
- package/dist/tui/hooks/useDaemonInfo.js.map +1 -0
- package/dist/tui/hooks/useIssues.d.ts +8 -0
- package/dist/tui/hooks/useIssues.d.ts.map +1 -0
- package/dist/tui/hooks/useIssues.js +36 -0
- package/dist/tui/hooks/useIssues.js.map +1 -0
- package/dist/tui/hooks/useNavigation.d.ts +11 -0
- package/dist/tui/hooks/useNavigation.d.ts.map +1 -0
- package/dist/tui/hooks/useNavigation.js +24 -0
- package/dist/tui/hooks/useNavigation.js.map +1 -0
- package/dist/tui/hooks/useProjects.d.ts +8 -0
- package/dist/tui/hooks/useProjects.d.ts.map +1 -0
- package/dist/tui/hooks/useProjects.js +36 -0
- package/dist/tui/hooks/useProjects.js.map +1 -0
- package/dist/tui/index.d.ts +2 -0
- package/dist/tui/index.d.ts.map +1 -0
- package/dist/tui/index.js +39 -0
- package/dist/tui/index.js.map +1 -0
- package/dist/tui/services/daemon-service.d.ts +28 -0
- package/dist/tui/services/daemon-service.d.ts.map +1 -0
- package/dist/tui/services/daemon-service.js +107 -0
- package/dist/tui/services/daemon-service.js.map +1 -0
- package/dist/tui/state/app-state.d.ts +78 -0
- package/dist/tui/state/app-state.d.ts.map +1 -0
- package/dist/tui/state/app-state.js +93 -0
- package/dist/tui/state/app-state.js.map +1 -0
- package/dist/tui/types/views.d.ts +11 -0
- package/dist/tui/types/views.d.ts.map +1 -0
- package/dist/tui/types/views.js +25 -0
- package/dist/tui/types/views.js.map +1 -0
- package/oclif.manifest.json +83 -1
- package/package.json +10 -3
|
@@ -0,0 +1,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":"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"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAE5C,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAA;AAU7D,KAAK,UAAU,aAAa,CAAC,MAAoB;IAC/C,OAAO,MAAM,KAAK,UAAU;QAC1B,CAAC,CAAC,aAAa,CAAC,QAAQ,EAAE;QAC1B,CAAC,CAAC,aAAa,CAAC,OAAO,EAAE,CAAA;AAC7B,CAAC;AAED,SAAS,iBAAiB,CAAC,MAAoB;IAC7C,OAAO;QACL,SAAS,EAAE,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,eAAe;QACvE,OAAO,EACL,MAAM,KAAK,UAAU;YACnB,CAAC,CAAC,+BAA+B;YACjC,CAAC,CAAC,sBAAsB;QAC5B,OAAO,EACL,MAAM,KAAK,UAAU;YACnB,CAAC,CAAC,wBAAwB;YAC1B,CAAC,CAAC,uBAAuB;KAC9B,CAAA;AACH,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAE,SAAS,EAAE,KAAK,EAA0B;IAC3E,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAc,MAAM,CAAC,CAAA;IACnE,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAsB,IAAI,CAAC,CAAA;IAC7E,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAA;IAEvE,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE;QAClC,cAAc,CAAC,MAAM,CAAC,CAAA;QACtB,gBAAgB,CAAC,IAAI,CAAC,CAAA;IACxB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,aAAa,GAAG,WAAW,CAC/B,KAAK,EAAE,MAAoB,EAAE,EAAE;QAC7B,MAAM,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAA;QAC1C,cAAc,CAAC,WAAW,CAAC,CAAA;QAC3B,gBAAgB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;QAEpC,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,MAAM,CAAC,CAAA;QAC1C,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;YACnB,gBAAgB,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAA;YAC1D,UAAU,CAAC,GAAG,EAAE;gBACd,KAAK,EAAE,CAAA;gBACP,UAAU,EAAE,CAAA;YACd,CAAC,EAAE,IAAI,CAAC,CAAA;QACV,CAAC;aAAM,CAAC;YACN,gBAAgB,CAAC,UAAU,MAAM,CAAC,KAAK,EAAE,CAAC,CAAA;YAC1C,UAAU,EAAE,CAAA;QACd,CAAC;IACH,CAAC,EACD,CAAC,KAAK,EAAE,UAAU,CAAC,CACpB,CAAA;IAED,WAAW,CAAC,CAAC,KAAe,EAAE,EAAE;QAC9B,IAAI,WAAW,KAAK,WAAW;YAAE,OAAM;QAEvC,IAAI,WAAW,KAAK,YAAY,EAAE,CAAC;YACjC,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,KAAK,GAAG,IAAI,KAAK,CAAC,IAAI,KAAK,GAAG,CAAA;YAC1D,MAAM,QAAQ,GACZ,KAAK,CAAC,IAAI,KAAK,GAAG,IAAI,KAAK,CAAC,IAAI,KAAK,GAAG,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,CAAA;YACrE,IAAI,SAAS,IAAI,aAAa;gBAAE,aAAa,CAAC,aAAa,CAAC,CAAA;YAC5D,IAAI,QAAQ,EAAE,CAAC;gBACb,UAAU,EAAE,CAAA;gBACZ,gBAAgB,CAAC,IAAI,CAAC,CAAA;YACxB,CAAC;YACD,OAAM;QACR,CAAC;QAED,IAAI,KAAK,CAAC,IAAI,KAAK,GAAG,IAAI,SAAS,EAAE,CAAC;YACpC,cAAc,CAAC,YAAY,CAAC,CAAA;YAC5B,gBAAgB,CAAC,UAAU,CAAC,CAAA;YAC5B,gBAAgB,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAA;QACzD,CAAC;aAAM,IAAI,KAAK,CAAC,IAAI,KAAK,GAAG,IAAI,SAAS,EAAE,CAAC;YAC3C,cAAc,CAAC,YAAY,CAAC,CAAA;YAC5B,gBAAgB,CAAC,SAAS,CAAC,CAAA;YAC3B,gBAAgB,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAA;QACxD,CAAC;aAAM,IAAI,KAAK,CAAC,IAAI,KAAK,GAAG,EAAE,CAAC;YAC9B,KAAK,EAAE,CAAA;YACP,gBAAgB,CAAC,wBAAwB,CAAC,CAAA;YAC1C,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAA;QAChD,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,CAAA;AACvC,CAAC"}
|
|
@@ -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"}
|