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.
- package/bin/run.js +14 -2
- package/dist/commands/add/asset.d.ts.map +1 -1
- package/dist/commands/add/asset.js +25 -27
- package/dist/commands/add/asset.js.map +1 -1
- package/dist/commands/config.d.ts.map +1 -1
- package/dist/commands/config.js +26 -35
- package/dist/commands/config.js.map +1 -1
- package/dist/commands/create/doc.d.ts.map +1 -1
- package/dist/commands/create/doc.js +15 -24
- package/dist/commands/create/doc.js.map +1 -1
- package/dist/commands/create/issue.d.ts.map +1 -1
- package/dist/commands/create/issue.js +0 -7
- package/dist/commands/create/issue.js.map +1 -1
- package/dist/commands/delete/asset.d.ts.map +1 -1
- package/dist/commands/delete/asset.js +29 -38
- package/dist/commands/delete/asset.js.map +1 -1
- package/dist/commands/delete/doc.d.ts.map +1 -1
- package/dist/commands/delete/doc.js +23 -32
- package/dist/commands/delete/doc.js.map +1 -1
- package/dist/commands/delete/issue.d.ts.map +1 -1
- package/dist/commands/delete/issue.js +23 -32
- package/dist/commands/delete/issue.js.map +1 -1
- package/dist/commands/get/asset.d.ts.map +1 -1
- package/dist/commands/get/asset.js +20 -29
- package/dist/commands/get/asset.js.map +1 -1
- package/dist/commands/get/doc.d.ts.map +1 -1
- package/dist/commands/get/doc.js +15 -24
- package/dist/commands/get/doc.js.map +1 -1
- package/dist/commands/get/issue.d.ts.map +1 -1
- package/dist/commands/get/issue.js +29 -38
- package/dist/commands/get/issue.js.map +1 -1
- package/dist/commands/get/project.d.ts.map +1 -1
- package/dist/commands/get/project.js +16 -25
- package/dist/commands/get/project.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +0 -7
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/list/assets.d.ts.map +1 -1
- package/dist/commands/list/assets.js +26 -35
- package/dist/commands/list/assets.js.map +1 -1
- package/dist/commands/list/docs.d.ts.map +1 -1
- package/dist/commands/list/docs.js +18 -27
- package/dist/commands/list/docs.js.map +1 -1
- package/dist/commands/list/issues.d.ts.map +1 -1
- package/dist/commands/list/issues.js +27 -36
- package/dist/commands/list/issues.js.map +1 -1
- package/dist/commands/list/projects.d.ts.map +1 -1
- package/dist/commands/list/projects.js +18 -27
- package/dist/commands/list/projects.js.map +1 -1
- package/dist/commands/manifest.d.ts.map +1 -1
- package/dist/commands/manifest.js +14 -28
- package/dist/commands/manifest.js.map +1 -1
- package/dist/commands/register/project.d.ts.map +1 -1
- package/dist/commands/register/project.js +8 -17
- package/dist/commands/register/project.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/commands/untrack/project.d.ts.map +1 -1
- package/dist/commands/untrack/project.js +18 -27
- package/dist/commands/untrack/project.js.map +1 -1
- package/dist/commands/update/doc.d.ts.map +1 -1
- package/dist/commands/update/doc.js +17 -26
- package/dist/commands/update/doc.js.map +1 -1
- package/dist/commands/update/issue.d.ts.map +1 -1
- package/dist/commands/update/issue.js +21 -30
- package/dist/commands/update/issue.js.map +1 -1
- package/dist/commands/update.d.ts.map +1 -1
- package/dist/commands/update.js +35 -44
- package/dist/commands/update.js.map +1 -1
- package/dist/commands/version.d.ts.map +1 -1
- package/dist/commands/version.js +15 -24
- package/dist/commands/version.js.map +1 -1
- package/dist/daemon/types.d.ts +0 -8
- package/dist/daemon/types.d.ts.map +1 -1
- package/dist/hooks/prerun.d.ts +4 -0
- package/dist/hooks/prerun.d.ts.map +1 -0
- package/dist/hooks/prerun.js +16 -0
- package/dist/hooks/prerun.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 +25 -0
- package/dist/lib/start/find-daemon-binary.js.map +1 -0
- package/dist/lib/start/wait-for-daemon.d.ts +7 -0
- package/dist/lib/start/wait-for-daemon.d.ts.map +1 -0
- package/dist/lib/start/wait-for-daemon.js +20 -0
- package/dist/lib/start/wait-for-daemon.js.map +1 -0
- package/dist/tui/App.d.ts +6 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +63 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/components/domain/IssueList.d.ts +2 -0
- package/dist/tui/components/domain/IssueList.d.ts.map +1 -0
- package/dist/tui/components/domain/IssueList.js +52 -0
- package/dist/tui/components/domain/IssueList.js.map +1 -0
- package/dist/tui/components/domain/ProjectList.d.ts +2 -0
- package/dist/tui/components/domain/ProjectList.d.ts.map +1 -0
- package/dist/tui/components/domain/ProjectList.js +54 -0
- package/dist/tui/components/domain/ProjectList.js.map +1 -0
- package/dist/tui/components/layout/Header.d.ts +7 -0
- package/dist/tui/components/layout/Header.d.ts.map +1 -0
- package/dist/tui/components/layout/Header.js +7 -0
- package/dist/tui/components/layout/Header.js.map +1 -0
- package/dist/tui/components/layout/MainPanel.d.ts +8 -0
- package/dist/tui/components/layout/MainPanel.d.ts.map +1 -0
- package/dist/tui/components/layout/MainPanel.js +5 -0
- package/dist/tui/components/layout/MainPanel.js.map +1 -0
- package/dist/tui/components/layout/Sidebar.d.ts +9 -0
- package/dist/tui/components/layout/Sidebar.d.ts.map +1 -0
- package/dist/tui/components/layout/Sidebar.js +11 -0
- package/dist/tui/components/layout/Sidebar.js.map +1 -0
- package/dist/tui/components/layout/StatusBar.d.ts +11 -0
- package/dist/tui/components/layout/StatusBar.d.ts.map +1 -0
- package/dist/tui/components/layout/StatusBar.js +8 -0
- package/dist/tui/components/layout/StatusBar.js.map +1 -0
- package/dist/tui/hooks/useDaemonConnection.d.ts +5 -0
- package/dist/tui/hooks/useDaemonConnection.d.ts.map +1 -0
- package/dist/tui/hooks/useDaemonConnection.js +24 -0
- package/dist/tui/hooks/useDaemonConnection.js.map +1 -0
- package/dist/tui/hooks/useIssues.d.ts +8 -0
- package/dist/tui/hooks/useIssues.d.ts.map +1 -0
- package/dist/tui/hooks/useIssues.js +36 -0
- package/dist/tui/hooks/useIssues.js.map +1 -0
- package/dist/tui/hooks/useNavigation.d.ts +11 -0
- package/dist/tui/hooks/useNavigation.d.ts.map +1 -0
- package/dist/tui/hooks/useNavigation.js +24 -0
- package/dist/tui/hooks/useNavigation.js.map +1 -0
- package/dist/tui/hooks/useProjects.d.ts +8 -0
- package/dist/tui/hooks/useProjects.d.ts.map +1 -0
- package/dist/tui/hooks/useProjects.js +36 -0
- package/dist/tui/hooks/useProjects.js.map +1 -0
- package/dist/tui/index.d.ts +2 -0
- package/dist/tui/index.d.ts.map +1 -0
- package/dist/tui/index.js +39 -0
- package/dist/tui/index.js.map +1 -0
- package/dist/tui/services/daemon-service.d.ts +26 -0
- package/dist/tui/services/daemon-service.d.ts.map +1 -0
- package/dist/tui/services/daemon-service.js +81 -0
- package/dist/tui/services/daemon-service.js.map +1 -0
- package/dist/tui/state/app-state.d.ts +78 -0
- package/dist/tui/state/app-state.d.ts.map +1 -0
- package/dist/tui/state/app-state.js +93 -0
- package/dist/tui/state/app-state.js.map +1 -0
- package/dist/tui/types/views.d.ts +11 -0
- package/dist/tui/types/views.d.ts.map +1 -0
- package/dist/tui/types/views.js +25 -0
- package/dist/tui/types/views.js.map +1 -0
- package/oclif.manifest.json +34 -1
- package/package.json +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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|