procsi 0.2.6
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/LICENSE +665 -0
- package/README.md +587 -0
- package/dist/cli/commands/clear.d.ts +3 -0
- package/dist/cli/commands/clear.d.ts.map +1 -0
- package/dist/cli/commands/clear.js +30 -0
- package/dist/cli/commands/clear.js.map +1 -0
- package/dist/cli/commands/daemon.d.ts +3 -0
- package/dist/cli/commands/daemon.d.ts.map +1 -0
- package/dist/cli/commands/daemon.js +59 -0
- package/dist/cli/commands/daemon.js.map +1 -0
- package/dist/cli/commands/debug-dump.d.ts +27 -0
- package/dist/cli/commands/debug-dump.d.ts.map +1 -0
- package/dist/cli/commands/debug-dump.js +102 -0
- package/dist/cli/commands/debug-dump.js.map +1 -0
- package/dist/cli/commands/helpers.d.ts +18 -0
- package/dist/cli/commands/helpers.d.ts.map +1 -0
- package/dist/cli/commands/helpers.js +34 -0
- package/dist/cli/commands/helpers.js.map +1 -0
- package/dist/cli/commands/init.d.ts +9 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +28 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/intercept.d.ts +9 -0
- package/dist/cli/commands/intercept.d.ts.map +1 -0
- package/dist/cli/commands/intercept.js +121 -0
- package/dist/cli/commands/intercept.js.map +1 -0
- package/dist/cli/commands/interceptors.d.ts +3 -0
- package/dist/cli/commands/interceptors.d.ts.map +1 -0
- package/dist/cli/commands/interceptors.js +163 -0
- package/dist/cli/commands/interceptors.js.map +1 -0
- package/dist/cli/commands/mcp.d.ts +3 -0
- package/dist/cli/commands/mcp.d.ts.map +1 -0
- package/dist/cli/commands/mcp.js +24 -0
- package/dist/cli/commands/mcp.js.map +1 -0
- package/dist/cli/commands/off.d.ts +8 -0
- package/dist/cli/commands/off.d.ts.map +1 -0
- package/dist/cli/commands/off.js +34 -0
- package/dist/cli/commands/off.js.map +1 -0
- package/dist/cli/commands/on.d.ts +9 -0
- package/dist/cli/commands/on.d.ts.map +1 -0
- package/dist/cli/commands/on.js +121 -0
- package/dist/cli/commands/on.js.map +1 -0
- package/dist/cli/commands/project.d.ts +3 -0
- package/dist/cli/commands/project.d.ts.map +1 -0
- package/dist/cli/commands/project.js +15 -0
- package/dist/cli/commands/project.js.map +1 -0
- package/dist/cli/commands/restart.d.ts +3 -0
- package/dist/cli/commands/restart.d.ts.map +1 -0
- package/dist/cli/commands/restart.js +35 -0
- package/dist/cli/commands/restart.js.map +1 -0
- package/dist/cli/commands/status.d.ts +3 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +66 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/stop.d.ts +3 -0
- package/dist/cli/commands/stop.d.ts.map +1 -0
- package/dist/cli/commands/stop.js +24 -0
- package/dist/cli/commands/stop.js.map +1 -0
- package/dist/cli/commands/tui.d.ts +3 -0
- package/dist/cli/commands/tui.d.ts.map +1 -0
- package/dist/cli/commands/tui.js +36 -0
- package/dist/cli/commands/tui.js.map +1 -0
- package/dist/cli/commands/vars.d.ts +36 -0
- package/dist/cli/commands/vars.d.ts.map +1 -0
- package/dist/cli/commands/vars.js +207 -0
- package/dist/cli/commands/vars.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +37 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/tui/App.d.ts +15 -0
- package/dist/cli/tui/App.d.ts.map +1 -0
- package/dist/cli/tui/App.js +544 -0
- package/dist/cli/tui/App.js.map +1 -0
- package/dist/cli/tui/components/AccordionContent.d.ts +28 -0
- package/dist/cli/tui/components/AccordionContent.d.ts.map +1 -0
- package/dist/cli/tui/components/AccordionContent.js +87 -0
- package/dist/cli/tui/components/AccordionContent.js.map +1 -0
- package/dist/cli/tui/components/AccordionPanel.d.ts +38 -0
- package/dist/cli/tui/components/AccordionPanel.d.ts.map +1 -0
- package/dist/cli/tui/components/AccordionPanel.js +110 -0
- package/dist/cli/tui/components/AccordionPanel.js.map +1 -0
- package/dist/cli/tui/components/AccordionSection.d.ts +32 -0
- package/dist/cli/tui/components/AccordionSection.d.ts.map +1 -0
- package/dist/cli/tui/components/AccordionSection.js +41 -0
- package/dist/cli/tui/components/AccordionSection.js.map +1 -0
- package/dist/cli/tui/components/BodyView.d.ts +14 -0
- package/dist/cli/tui/components/BodyView.d.ts.map +1 -0
- package/dist/cli/tui/components/BodyView.js +39 -0
- package/dist/cli/tui/components/BodyView.js.map +1 -0
- package/dist/cli/tui/components/ExportModal.d.ts +34 -0
- package/dist/cli/tui/components/ExportModal.d.ts.map +1 -0
- package/dist/cli/tui/components/ExportModal.js +109 -0
- package/dist/cli/tui/components/ExportModal.js.map +1 -0
- package/dist/cli/tui/components/FilterBar.d.ts +21 -0
- package/dist/cli/tui/components/FilterBar.d.ts.map +1 -0
- package/dist/cli/tui/components/FilterBar.js +155 -0
- package/dist/cli/tui/components/FilterBar.js.map +1 -0
- package/dist/cli/tui/components/HeadersView.d.ts +13 -0
- package/dist/cli/tui/components/HeadersView.d.ts.map +1 -0
- package/dist/cli/tui/components/HeadersView.js +8 -0
- package/dist/cli/tui/components/HeadersView.js.map +1 -0
- package/dist/cli/tui/components/HelpModal.d.ts +13 -0
- package/dist/cli/tui/components/HelpModal.d.ts.map +1 -0
- package/dist/cli/tui/components/HelpModal.js +78 -0
- package/dist/cli/tui/components/HelpModal.js.map +1 -0
- package/dist/cli/tui/components/HintContent.d.ts +25 -0
- package/dist/cli/tui/components/HintContent.d.ts.map +1 -0
- package/dist/cli/tui/components/HintContent.js +44 -0
- package/dist/cli/tui/components/HintContent.js.map +1 -0
- package/dist/cli/tui/components/InfoModal.d.ts +15 -0
- package/dist/cli/tui/components/InfoModal.d.ts.map +1 -0
- package/dist/cli/tui/components/InfoModal.js +17 -0
- package/dist/cli/tui/components/InfoModal.js.map +1 -0
- package/dist/cli/tui/components/JsonExplorerModal.d.ts +24 -0
- package/dist/cli/tui/components/JsonExplorerModal.d.ts.map +1 -0
- package/dist/cli/tui/components/JsonExplorerModal.js +311 -0
- package/dist/cli/tui/components/JsonExplorerModal.js.map +1 -0
- package/dist/cli/tui/components/Modal.d.ts +26 -0
- package/dist/cli/tui/components/Modal.d.ts.map +1 -0
- package/dist/cli/tui/components/Modal.js +15 -0
- package/dist/cli/tui/components/Modal.js.map +1 -0
- package/dist/cli/tui/components/Panel.d.ts +19 -0
- package/dist/cli/tui/components/Panel.d.ts.map +1 -0
- package/dist/cli/tui/components/Panel.js +37 -0
- package/dist/cli/tui/components/Panel.js.map +1 -0
- package/dist/cli/tui/components/RequestDetails.d.ts +16 -0
- package/dist/cli/tui/components/RequestDetails.d.ts.map +1 -0
- package/dist/cli/tui/components/RequestDetails.js +23 -0
- package/dist/cli/tui/components/RequestDetails.js.map +1 -0
- package/dist/cli/tui/components/RequestList.d.ts +21 -0
- package/dist/cli/tui/components/RequestList.d.ts.map +1 -0
- package/dist/cli/tui/components/RequestList.js +30 -0
- package/dist/cli/tui/components/RequestList.js.map +1 -0
- package/dist/cli/tui/components/RequestListItem.d.ts +36 -0
- package/dist/cli/tui/components/RequestListItem.d.ts.map +1 -0
- package/dist/cli/tui/components/RequestListItem.js +130 -0
- package/dist/cli/tui/components/RequestListItem.js.map +1 -0
- package/dist/cli/tui/components/SaveModal.d.ts +30 -0
- package/dist/cli/tui/components/SaveModal.d.ts.map +1 -0
- package/dist/cli/tui/components/SaveModal.js +95 -0
- package/dist/cli/tui/components/SaveModal.js.map +1 -0
- package/dist/cli/tui/components/StatusBar.d.ts +39 -0
- package/dist/cli/tui/components/StatusBar.d.ts.map +1 -0
- package/dist/cli/tui/components/StatusBar.js +53 -0
- package/dist/cli/tui/components/StatusBar.js.map +1 -0
- package/dist/cli/tui/components/TextViewerModal.d.ts +19 -0
- package/dist/cli/tui/components/TextViewerModal.d.ts.map +1 -0
- package/dist/cli/tui/components/TextViewerModal.js +227 -0
- package/dist/cli/tui/components/TextViewerModal.js.map +1 -0
- package/dist/cli/tui/hooks/useBodyExport.d.ts +26 -0
- package/dist/cli/tui/hooks/useBodyExport.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useBodyExport.js +173 -0
- package/dist/cli/tui/hooks/useBodyExport.js.map +1 -0
- package/dist/cli/tui/hooks/useExport.d.ts +29 -0
- package/dist/cli/tui/hooks/useExport.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useExport.js +64 -0
- package/dist/cli/tui/hooks/useExport.js.map +1 -0
- package/dist/cli/tui/hooks/useRequests.d.ts +26 -0
- package/dist/cli/tui/hooks/useRequests.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useRequests.js +131 -0
- package/dist/cli/tui/hooks/useRequests.js.map +1 -0
- package/dist/cli/tui/hooks/useSaveBinary.d.ts +26 -0
- package/dist/cli/tui/hooks/useSaveBinary.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useSaveBinary.js +165 -0
- package/dist/cli/tui/hooks/useSaveBinary.js.map +1 -0
- package/dist/cli/tui/hooks/useSpinner.d.ts +5 -0
- package/dist/cli/tui/hooks/useSpinner.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useSpinner.js +25 -0
- package/dist/cli/tui/hooks/useSpinner.js.map +1 -0
- package/dist/cli/tui/hooks/useStdoutDimensions.d.ts +11 -0
- package/dist/cli/tui/hooks/useStdoutDimensions.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useStdoutDimensions.js +29 -0
- package/dist/cli/tui/hooks/useStdoutDimensions.js.map +1 -0
- package/dist/cli/tui/utils/binary.d.ts +24 -0
- package/dist/cli/tui/utils/binary.d.ts.map +1 -0
- package/dist/cli/tui/utils/binary.js +152 -0
- package/dist/cli/tui/utils/binary.js.map +1 -0
- package/dist/cli/tui/utils/clipboard.d.ts +9 -0
- package/dist/cli/tui/utils/clipboard.d.ts.map +1 -0
- package/dist/cli/tui/utils/clipboard.js +58 -0
- package/dist/cli/tui/utils/clipboard.js.map +1 -0
- package/dist/cli/tui/utils/content-type.d.ts +8 -0
- package/dist/cli/tui/utils/content-type.d.ts.map +1 -0
- package/dist/cli/tui/utils/content-type.js +10 -0
- package/dist/cli/tui/utils/content-type.js.map +1 -0
- package/dist/cli/tui/utils/curl.d.ts +9 -0
- package/dist/cli/tui/utils/curl.d.ts.map +1 -0
- package/dist/cli/tui/utils/curl.js +54 -0
- package/dist/cli/tui/utils/curl.js.map +1 -0
- package/dist/cli/tui/utils/filters.d.ts +6 -0
- package/dist/cli/tui/utils/filters.d.ts.map +1 -0
- package/dist/cli/tui/utils/filters.js +13 -0
- package/dist/cli/tui/utils/filters.js.map +1 -0
- package/dist/cli/tui/utils/formatters.d.ts +49 -0
- package/dist/cli/tui/utils/formatters.d.ts.map +1 -0
- package/dist/cli/tui/utils/formatters.js +200 -0
- package/dist/cli/tui/utils/formatters.js.map +1 -0
- package/dist/cli/tui/utils/har.d.ts +75 -0
- package/dist/cli/tui/utils/har.d.ts.map +1 -0
- package/dist/cli/tui/utils/har.js +117 -0
- package/dist/cli/tui/utils/har.js.map +1 -0
- package/dist/cli/tui/utils/json-tree.d.ts +69 -0
- package/dist/cli/tui/utils/json-tree.d.ts.map +1 -0
- package/dist/cli/tui/utils/json-tree.js +339 -0
- package/dist/cli/tui/utils/json-tree.js.map +1 -0
- package/dist/cli/tui/utils/open-external.d.ts +17 -0
- package/dist/cli/tui/utils/open-external.d.ts.map +1 -0
- package/dist/cli/tui/utils/open-external.js +57 -0
- package/dist/cli/tui/utils/open-external.js.map +1 -0
- package/dist/cli/tui/utils/syntax-highlight.d.ts +16 -0
- package/dist/cli/tui/utils/syntax-highlight.d.ts.map +1 -0
- package/dist/cli/tui/utils/syntax-highlight.js +64 -0
- package/dist/cli/tui/utils/syntax-highlight.js.map +1 -0
- package/dist/daemon/control.d.ts +21 -0
- package/dist/daemon/control.d.ts.map +1 -0
- package/dist/daemon/control.js +311 -0
- package/dist/daemon/control.js.map +1 -0
- package/dist/daemon/htpx-client.d.ts +8 -0
- package/dist/daemon/htpx-client.d.ts.map +1 -0
- package/dist/daemon/htpx-client.js +25 -0
- package/dist/daemon/htpx-client.js.map +1 -0
- package/dist/daemon/index.d.ts +3 -0
- package/dist/daemon/index.d.ts.map +1 -0
- package/dist/daemon/index.js +178 -0
- package/dist/daemon/index.js.map +1 -0
- package/dist/daemon/interceptor-loader.d.ts +30 -0
- package/dist/daemon/interceptor-loader.d.ts.map +1 -0
- package/dist/daemon/interceptor-loader.js +249 -0
- package/dist/daemon/interceptor-loader.js.map +1 -0
- package/dist/daemon/interceptor-runner.d.ts +39 -0
- package/dist/daemon/interceptor-runner.d.ts.map +1 -0
- package/dist/daemon/interceptor-runner.js +312 -0
- package/dist/daemon/interceptor-runner.js.map +1 -0
- package/dist/daemon/procsi-client.d.ts +8 -0
- package/dist/daemon/procsi-client.d.ts.map +1 -0
- package/dist/daemon/procsi-client.js +25 -0
- package/dist/daemon/procsi-client.js.map +1 -0
- package/dist/daemon/proxy.d.ts +34 -0
- package/dist/daemon/proxy.d.ts.map +1 -0
- package/dist/daemon/proxy.js +213 -0
- package/dist/daemon/proxy.js.map +1 -0
- package/dist/daemon/storage.d.ts +130 -0
- package/dist/daemon/storage.d.ts.map +1 -0
- package/dist/daemon/storage.js +761 -0
- package/dist/daemon/storage.js.map +1 -0
- package/dist/interceptors.d.ts +2 -0
- package/dist/interceptors.d.ts.map +1 -0
- package/dist/interceptors.js +2 -0
- package/dist/interceptors.js.map +1 -0
- package/dist/mcp/server.d.ts +110 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +806 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/overrides/node.d.ts +30 -0
- package/dist/overrides/node.d.ts.map +1 -0
- package/dist/overrides/node.js +66 -0
- package/dist/overrides/node.js.map +1 -0
- package/dist/shared/config.d.ts +21 -0
- package/dist/shared/config.d.ts.map +1 -0
- package/dist/shared/config.js +83 -0
- package/dist/shared/config.js.map +1 -0
- package/dist/shared/content-type.d.ts +64 -0
- package/dist/shared/content-type.d.ts.map +1 -0
- package/dist/shared/content-type.js +145 -0
- package/dist/shared/content-type.js.map +1 -0
- package/dist/shared/control-client.d.ts +144 -0
- package/dist/shared/control-client.d.ts.map +1 -0
- package/dist/shared/control-client.js +272 -0
- package/dist/shared/control-client.js.map +1 -0
- package/dist/shared/daemon.d.ts +33 -0
- package/dist/shared/daemon.d.ts.map +1 -0
- package/dist/shared/daemon.js +231 -0
- package/dist/shared/daemon.js.map +1 -0
- package/dist/shared/logger.d.ts +47 -0
- package/dist/shared/logger.d.ts.map +1 -0
- package/dist/shared/logger.js +200 -0
- package/dist/shared/logger.js.map +1 -0
- package/dist/shared/project.d.ts +76 -0
- package/dist/shared/project.d.ts.map +1 -0
- package/dist/shared/project.js +185 -0
- package/dist/shared/project.js.map +1 -0
- package/dist/shared/proxy-info.d.ts +10 -0
- package/dist/shared/proxy-info.d.ts.map +1 -0
- package/dist/shared/proxy-info.js +15 -0
- package/dist/shared/proxy-info.js.map +1 -0
- package/dist/shared/types.d.ts +128 -0
- package/dist/shared/types.d.ts.map +1 -0
- package/dist/shared/types.js +5 -0
- package/dist/shared/types.js.map +1 -0
- package/dist/shared/version.d.ts +5 -0
- package/dist/shared/version.d.ts.map +1 -0
- package/dist/shared/version.js +21 -0
- package/dist/shared/version.js.map +1 -0
- package/package.json +113 -0
- package/skills/procsi/SKILL.md +228 -0
|
@@ -0,0 +1,311 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Full-screen modal for exploring JSON bodies as a collapsible tree.
|
|
4
|
+
* Replaces the main TUI when active (terminals don't support true overlays).
|
|
5
|
+
*/
|
|
6
|
+
import React, { useState, useMemo, useCallback, useRef, useEffect } from "react";
|
|
7
|
+
import { Box, Text, useInput } from "ink";
|
|
8
|
+
import { buildVisibleNodes, toggleNode, defaultExpansion, expandAll, collapseAll, filterByPath, getValueAtPath, buildBreadcrumb, parentPath, } from "../utils/json-tree.js";
|
|
9
|
+
import { formatSize } from "../utils/formatters.js";
|
|
10
|
+
import { copyToClipboard } from "../utils/clipboard.js";
|
|
11
|
+
import { HintContent } from "./HintContent.js";
|
|
12
|
+
const JSON_EXPLORER_HINTS = [
|
|
13
|
+
{ key: "j/k", action: "nav" },
|
|
14
|
+
{ key: "^f/^b", action: "page" },
|
|
15
|
+
{ key: "Enter/l", action: "toggle" },
|
|
16
|
+
{ key: "h", action: "collapse" },
|
|
17
|
+
{ key: "e/c", action: "expand/collapse all" },
|
|
18
|
+
{ key: "/", action: "filter" },
|
|
19
|
+
{ key: "n/N", action: "match" },
|
|
20
|
+
{ key: "y", action: "copy" },
|
|
21
|
+
{ key: "q/Esc", action: "close" },
|
|
22
|
+
];
|
|
23
|
+
const STATUS_MESSAGE_TIMEOUT_MS = 3000;
|
|
24
|
+
const FILTER_DEBOUNCE_MS = 150;
|
|
25
|
+
/** Rows reserved for header (title + breadcrumb + divider), hint bar, and borders */
|
|
26
|
+
const HEADER_ROWS = 3;
|
|
27
|
+
const FOOTER_ROWS = 2;
|
|
28
|
+
const INDENT_SIZE = 2;
|
|
29
|
+
const PrimitiveValue = React.memo(function PrimitiveValue({ value }) {
|
|
30
|
+
if (value === "null")
|
|
31
|
+
return _jsx(Text, { dimColor: true, children: "null" });
|
|
32
|
+
if (value === "true" || value === "false")
|
|
33
|
+
return _jsx(Text, { color: "magenta", children: value });
|
|
34
|
+
if (value.startsWith('"'))
|
|
35
|
+
return _jsx(Text, { color: "green", children: value });
|
|
36
|
+
// Numbers
|
|
37
|
+
return _jsx(Text, { color: "yellow", children: value });
|
|
38
|
+
});
|
|
39
|
+
export function JsonExplorerModal({ data, title, contentType, bodySize, width, height, onClose, isActive = true, onStatus, }) {
|
|
40
|
+
const [expandedPaths, setExpandedPaths] = useState(() => defaultExpansion(data));
|
|
41
|
+
const [cursorIndex, setCursorIndex] = useState(0);
|
|
42
|
+
const [scrollOffset, setScrollOffset] = useState(0);
|
|
43
|
+
const [filterText, setFilterText] = useState("");
|
|
44
|
+
const [filterMode, setFilterMode] = useState(false);
|
|
45
|
+
const [matchingPaths, setMatchingPaths] = useState(new Set());
|
|
46
|
+
const [preFilterExpansion, setPreFilterExpansion] = useState(null);
|
|
47
|
+
const [statusMessage, setStatusMessage] = useState();
|
|
48
|
+
const statusTimeoutRef = useRef(null);
|
|
49
|
+
const filterDebounceRef = useRef(null);
|
|
50
|
+
// Cleanup timers on unmount
|
|
51
|
+
useEffect(() => {
|
|
52
|
+
return () => {
|
|
53
|
+
if (statusTimeoutRef.current) {
|
|
54
|
+
clearTimeout(statusTimeoutRef.current);
|
|
55
|
+
}
|
|
56
|
+
if (filterDebounceRef.current) {
|
|
57
|
+
clearTimeout(filterDebounceRef.current);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
}, []);
|
|
61
|
+
const showLocalStatus = useCallback((message) => {
|
|
62
|
+
if (statusTimeoutRef.current) {
|
|
63
|
+
clearTimeout(statusTimeoutRef.current);
|
|
64
|
+
}
|
|
65
|
+
setStatusMessage(message);
|
|
66
|
+
statusTimeoutRef.current = setTimeout(() => setStatusMessage(undefined), STATUS_MESSAGE_TIMEOUT_MS);
|
|
67
|
+
}, []);
|
|
68
|
+
// Live filter: debounce filterText changes while in filter mode
|
|
69
|
+
useEffect(() => {
|
|
70
|
+
if (!filterMode)
|
|
71
|
+
return;
|
|
72
|
+
if (filterDebounceRef.current) {
|
|
73
|
+
clearTimeout(filterDebounceRef.current);
|
|
74
|
+
}
|
|
75
|
+
filterDebounceRef.current = setTimeout(() => {
|
|
76
|
+
if (!filterText) {
|
|
77
|
+
// Empty filter — restore pre-filter expansion
|
|
78
|
+
setMatchingPaths(new Set());
|
|
79
|
+
if (preFilterExpansion) {
|
|
80
|
+
setExpandedPaths(preFilterExpansion);
|
|
81
|
+
}
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const result = filterByPath(data, filterText);
|
|
85
|
+
if (result) {
|
|
86
|
+
setMatchingPaths(result.matchingPaths);
|
|
87
|
+
setExpandedPaths(result.expandedPaths);
|
|
88
|
+
// Move cursor to first matching node
|
|
89
|
+
const newNodes = buildVisibleNodes(data, result.expandedPaths);
|
|
90
|
+
const firstMatchIdx = newNodes.findIndex((n) => result.matchingPaths.has(n.path));
|
|
91
|
+
if (firstMatchIdx !== -1) {
|
|
92
|
+
setCursorIndex(firstMatchIdx);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
setMatchingPaths(new Set());
|
|
97
|
+
if (preFilterExpansion) {
|
|
98
|
+
setExpandedPaths(preFilterExpansion);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}, FILTER_DEBOUNCE_MS);
|
|
102
|
+
return () => {
|
|
103
|
+
if (filterDebounceRef.current) {
|
|
104
|
+
clearTimeout(filterDebounceRef.current);
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
}, [filterText, filterMode, data, preFilterExpansion]);
|
|
108
|
+
const visibleNodes = useMemo(() => buildVisibleNodes(data, expandedPaths), [data, expandedPaths]);
|
|
109
|
+
// Keep cursor in bounds when visible nodes change
|
|
110
|
+
useEffect(() => {
|
|
111
|
+
if (cursorIndex >= visibleNodes.length && visibleNodes.length > 0) {
|
|
112
|
+
setCursorIndex(visibleNodes.length - 1);
|
|
113
|
+
}
|
|
114
|
+
}, [visibleNodes.length, cursorIndex]);
|
|
115
|
+
const availableHeight = height - HEADER_ROWS - FOOTER_ROWS;
|
|
116
|
+
// Auto-scroll to keep cursor visible
|
|
117
|
+
useEffect(() => {
|
|
118
|
+
if (cursorIndex < scrollOffset) {
|
|
119
|
+
setScrollOffset(cursorIndex);
|
|
120
|
+
}
|
|
121
|
+
else if (cursorIndex >= scrollOffset + availableHeight) {
|
|
122
|
+
setScrollOffset(cursorIndex - availableHeight + 1);
|
|
123
|
+
}
|
|
124
|
+
}, [cursorIndex, scrollOffset, availableHeight]);
|
|
125
|
+
const cursorNode = visibleNodes[cursorIndex];
|
|
126
|
+
const breadcrumb = useMemo(() => (cursorNode ? buildBreadcrumb(cursorNode.path) : ["(root)"]), [cursorNode?.path]);
|
|
127
|
+
useInput((input, key) => {
|
|
128
|
+
if (filterMode) {
|
|
129
|
+
if (key.escape) {
|
|
130
|
+
// Close filter, restore pre-filter expansion
|
|
131
|
+
setFilterMode(false);
|
|
132
|
+
setFilterText("");
|
|
133
|
+
setMatchingPaths(new Set());
|
|
134
|
+
if (preFilterExpansion) {
|
|
135
|
+
setExpandedPaths(preFilterExpansion);
|
|
136
|
+
setPreFilterExpansion(null);
|
|
137
|
+
}
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
if (key.return) {
|
|
141
|
+
// Close filter mode — filter already applied live
|
|
142
|
+
setFilterMode(false);
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
if (key.backspace || key.delete) {
|
|
146
|
+
setFilterText((prev) => prev.slice(0, -1));
|
|
147
|
+
return;
|
|
148
|
+
}
|
|
149
|
+
// Only accept single characters to filter out mouse escape sequences
|
|
150
|
+
if (input && input.length === 1 && !key.ctrl && !key.meta) {
|
|
151
|
+
setFilterText((prev) => prev + input);
|
|
152
|
+
}
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
// Normal mode
|
|
156
|
+
if (key.escape || input === "q") {
|
|
157
|
+
onClose();
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
if (input === "j" || key.downArrow) {
|
|
161
|
+
setCursorIndex((prev) => Math.min(prev + 1, visibleNodes.length - 1));
|
|
162
|
+
}
|
|
163
|
+
else if (input === "k" || key.upArrow) {
|
|
164
|
+
setCursorIndex((prev) => Math.max(prev - 1, 0));
|
|
165
|
+
}
|
|
166
|
+
else if (input === "d" && key.ctrl) {
|
|
167
|
+
// Half-page down
|
|
168
|
+
const halfPage = Math.floor(availableHeight / 2);
|
|
169
|
+
setCursorIndex((prev) => Math.min(prev + halfPage, visibleNodes.length - 1));
|
|
170
|
+
}
|
|
171
|
+
else if (input === "u" && key.ctrl) {
|
|
172
|
+
// Half-page up
|
|
173
|
+
const halfPage = Math.floor(availableHeight / 2);
|
|
174
|
+
setCursorIndex((prev) => Math.max(prev - halfPage, 0));
|
|
175
|
+
}
|
|
176
|
+
else if (input === "f" && key.ctrl) {
|
|
177
|
+
// Full-page down
|
|
178
|
+
setCursorIndex((prev) => Math.min(prev + availableHeight, visibleNodes.length - 1));
|
|
179
|
+
}
|
|
180
|
+
else if (input === "b" && key.ctrl) {
|
|
181
|
+
// Full-page up
|
|
182
|
+
setCursorIndex((prev) => Math.max(prev - availableHeight, 0));
|
|
183
|
+
}
|
|
184
|
+
else if (key.return || input === "l") {
|
|
185
|
+
// Toggle expand/collapse on node at cursor
|
|
186
|
+
if (cursorNode?.expandable) {
|
|
187
|
+
setExpandedPaths((prev) => toggleNode(prev, cursorNode.path));
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
else if (input === "h") {
|
|
191
|
+
// Collapse node at cursor, or jump to parent if leaf/already collapsed
|
|
192
|
+
if (cursorNode) {
|
|
193
|
+
if (cursorNode.expandable && expandedPaths.has(cursorNode.path)) {
|
|
194
|
+
setExpandedPaths((prev) => toggleNode(prev, cursorNode.path));
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
// Jump to parent
|
|
198
|
+
const parent = parentPath(cursorNode.path);
|
|
199
|
+
if (parent) {
|
|
200
|
+
const parentIdx = visibleNodes.findIndex((n) => n.path === parent);
|
|
201
|
+
if (parentIdx !== -1) {
|
|
202
|
+
setCursorIndex(parentIdx);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
else if (input === "g" && !key.shift) {
|
|
209
|
+
setCursorIndex(0);
|
|
210
|
+
}
|
|
211
|
+
else if (input === "G") {
|
|
212
|
+
setCursorIndex(Math.max(0, visibleNodes.length - 1));
|
|
213
|
+
}
|
|
214
|
+
else if (input === "/") {
|
|
215
|
+
// Save current expansion before filtering
|
|
216
|
+
setPreFilterExpansion(new Set(expandedPaths));
|
|
217
|
+
setFilterMode(true);
|
|
218
|
+
setFilterText("");
|
|
219
|
+
}
|
|
220
|
+
else if (input === "e") {
|
|
221
|
+
setExpandedPaths(expandAll(data));
|
|
222
|
+
}
|
|
223
|
+
else if (input === "c") {
|
|
224
|
+
setExpandedPaths(collapseAll());
|
|
225
|
+
}
|
|
226
|
+
else if (input === "n") {
|
|
227
|
+
// Jump to next filter match
|
|
228
|
+
if (matchingPaths.size > 0) {
|
|
229
|
+
const matchIndices = visibleNodes
|
|
230
|
+
.map((n, i) => (matchingPaths.has(n.path) ? i : -1))
|
|
231
|
+
.filter((i) => i !== -1);
|
|
232
|
+
if (matchIndices.length > 0) {
|
|
233
|
+
const nextIdx = matchIndices.find((i) => i > cursorIndex) ?? matchIndices[0];
|
|
234
|
+
if (nextIdx !== undefined) {
|
|
235
|
+
setCursorIndex(nextIdx);
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
else if (input === "N") {
|
|
241
|
+
// Jump to previous filter match
|
|
242
|
+
if (matchingPaths.size > 0) {
|
|
243
|
+
const matchIndices = visibleNodes
|
|
244
|
+
.map((n, i) => (matchingPaths.has(n.path) ? i : -1))
|
|
245
|
+
.filter((i) => i !== -1);
|
|
246
|
+
if (matchIndices.length > 0) {
|
|
247
|
+
const prevIdx = [...matchIndices].reverse().find((i) => i < cursorIndex)
|
|
248
|
+
?? matchIndices[matchIndices.length - 1];
|
|
249
|
+
if (prevIdx !== undefined) {
|
|
250
|
+
setCursorIndex(prevIdx);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
else if (input === "y") {
|
|
256
|
+
if (cursorNode) {
|
|
257
|
+
const value = getValueAtPath(data, cursorNode.path);
|
|
258
|
+
const text = typeof value === "string" ? value : JSON.stringify(value, null, 2);
|
|
259
|
+
void copyToClipboard(text).then(() => {
|
|
260
|
+
const msg = "Value copied to clipboard";
|
|
261
|
+
showLocalStatus(msg);
|
|
262
|
+
onStatus?.(msg);
|
|
263
|
+
}, () => {
|
|
264
|
+
const msg = "Failed to copy to clipboard";
|
|
265
|
+
showLocalStatus(msg);
|
|
266
|
+
onStatus?.(msg);
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
}, { isActive });
|
|
271
|
+
// Content type short display
|
|
272
|
+
const shortCt = contentType.split(";")[0]?.trim() ?? "";
|
|
273
|
+
// Build visible row slice
|
|
274
|
+
const visibleSlice = visibleNodes.slice(scrollOffset, scrollOffset + availableHeight);
|
|
275
|
+
// Header border
|
|
276
|
+
const headerRight = ` ${shortCt} ${formatSize(bodySize)} `;
|
|
277
|
+
const titlePart = ` ${title} `;
|
|
278
|
+
const headerBorderWidth = width - titlePart.length - headerRight.length - 4;
|
|
279
|
+
const headerBorder = `┌─${titlePart}${"─".repeat(Math.max(0, headerBorderWidth))}${headerRight}─┐`;
|
|
280
|
+
// Divider
|
|
281
|
+
const divider = `├${"─".repeat(width - 2)}┤`;
|
|
282
|
+
// Footer border
|
|
283
|
+
const footerBorder = `└${"─".repeat(width - 2)}┘`;
|
|
284
|
+
return (_jsxs(Box, { flexDirection: "column", width: width, height: height, children: [_jsx(Text, { color: "cyan", children: headerBorder }), _jsx(Box, { paddingX: 1, height: 1, children: filterMode ? (_jsxs(Text, { children: [_jsx(Text, { color: "yellow", children: "filter: " }), _jsx(Text, { children: filterText }), _jsx(Text, { color: "gray", children: "\u2588" })] })) : (_jsx(Text, { dimColor: true, wrap: "truncate", children: breadcrumb.join(" > ") })) }), _jsx(Text, { color: "cyan", children: divider }), _jsxs(Box, { flexDirection: "column", flexGrow: 1, paddingX: 1, children: [visibleSlice.map((node, idx) => {
|
|
285
|
+
const globalIdx = scrollOffset + idx;
|
|
286
|
+
const isCursor = globalIdx === cursorIndex;
|
|
287
|
+
const isMatch = matchingPaths.has(node.path);
|
|
288
|
+
const isExpanded = node.expandable ? expandedPaths.has(node.path) : undefined;
|
|
289
|
+
return (_jsx(TreeNodeRowWithArrow, { node: node, isCursor: isCursor, isMatch: isMatch, isExpanded: isExpanded, maxWidth: width - 4 }, node.path));
|
|
290
|
+
}), visibleSlice.length < availableHeight && (_jsx(Box, { flexGrow: 1 }))] }), _jsx(Text, { color: "cyan", children: divider }), _jsx(Box, { paddingX: 1, height: 1, children: statusMessage ? (_jsx(Text, { color: "green", children: statusMessage })) : (_jsx(HintContent, { hints: JSON_EXPLORER_HINTS, availableWidth: width - 4 })) }), _jsx(Text, { color: "cyan", children: footerBorder })] }));
|
|
291
|
+
}
|
|
292
|
+
/**
|
|
293
|
+
* Tree node row that correctly shows ▶/▼ based on expansion state.
|
|
294
|
+
*/
|
|
295
|
+
const TreeNodeRowWithArrow = React.memo(function TreeNodeRowWithArrow({ node, isCursor, isMatch, isExpanded, maxWidth, }) {
|
|
296
|
+
const indent = " ".repeat(node.depth * INDENT_SIZE);
|
|
297
|
+
const cursor = isCursor ? "❯ " : " ";
|
|
298
|
+
let arrow = " ";
|
|
299
|
+
if (node.expandable) {
|
|
300
|
+
arrow = isExpanded ? "▼ " : "▶ ";
|
|
301
|
+
}
|
|
302
|
+
const keyPart = node.key;
|
|
303
|
+
const valuePart = node.value;
|
|
304
|
+
// Check if the line would exceed available width
|
|
305
|
+
const prefix = `${cursor}${indent}${arrow}`;
|
|
306
|
+
const fullLine = `${keyPart}: ${valuePart}`;
|
|
307
|
+
const availableWidth = maxWidth - prefix.length;
|
|
308
|
+
const isTruncated = fullLine.length > availableWidth;
|
|
309
|
+
return (_jsxs(Text, { bold: isCursor, children: [_jsx(Text, { children: cursor }), _jsx(Text, { children: indent }), _jsx(Text, { children: arrow }), isTruncated ? (_jsxs(Text, { children: [fullLine.substring(0, Math.max(0, availableWidth - 1)), "\u2026"] })) : (_jsxs(_Fragment, { children: [_jsx(Text, { color: "cyan", bold: isCursor, underline: isMatch, children: keyPart }), _jsx(Text, { children: ": " }), node.type === "primitive" ? (_jsx(PrimitiveValue, { value: valuePart })) : (_jsx(Text, { dimColor: true, children: valuePart }))] }))] }));
|
|
310
|
+
});
|
|
311
|
+
//# sourceMappingURL=JsonExplorerModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JsonExplorerModal.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/JsonExplorerModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generic modal overlay component.
|
|
3
|
+
*
|
|
4
|
+
* Renders a centred box with a border over the main content.
|
|
5
|
+
*/
|
|
6
|
+
import React from "react";
|
|
7
|
+
export interface ModalProps {
|
|
8
|
+
/** Modal title shown in the header */
|
|
9
|
+
title: string;
|
|
10
|
+
/** Modal width in columns */
|
|
11
|
+
width: number;
|
|
12
|
+
/** Modal height in rows */
|
|
13
|
+
height: number;
|
|
14
|
+
/** Total screen width */
|
|
15
|
+
screenWidth: number;
|
|
16
|
+
/** Total screen height */
|
|
17
|
+
screenHeight: number;
|
|
18
|
+
/** Called when modal should close (Escape pressed) */
|
|
19
|
+
onClose: () => void;
|
|
20
|
+
/** Modal content */
|
|
21
|
+
children: React.ReactNode;
|
|
22
|
+
/** Whether input is active (for testing) */
|
|
23
|
+
isActive?: boolean;
|
|
24
|
+
}
|
|
25
|
+
export declare function Modal({ title, width, height, screenWidth, screenHeight, onClose, children, isActive, }: ModalProps): React.ReactElement;
|
|
26
|
+
//# sourceMappingURL=Modal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Modal.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/Modal.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,MAAM,WAAW,UAAU;IACzB,sCAAsC;IACtC,KAAK,EAAE,MAAM,CAAC;IACd,6BAA6B;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,2BAA2B;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,yBAAyB;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,0BAA0B;IAC1B,YAAY,EAAE,MAAM,CAAC;IACrB,sDAAsD;IACtD,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,oBAAoB;IACpB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,4CAA4C;IAC5C,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,KAAK,CAAC,EACpB,KAAK,EACL,KAAK,EACL,MAAM,EACN,WAAW,EACX,YAAY,EACZ,OAAO,EACP,QAAQ,EACR,QAAe,GAChB,EAAE,UAAU,GAAG,KAAK,CAAC,YAAY,CA0CjC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text, useInput } from "ink";
|
|
3
|
+
export function Modal({ title, width, height, screenWidth, screenHeight, onClose, children, isActive = true, }) {
|
|
4
|
+
// Handle escape to close
|
|
5
|
+
useInput((input, key) => {
|
|
6
|
+
if (key.escape) {
|
|
7
|
+
onClose();
|
|
8
|
+
}
|
|
9
|
+
}, { isActive });
|
|
10
|
+
// Calculate centering offsets
|
|
11
|
+
const marginLeft = Math.max(0, Math.floor((screenWidth - width) / 2));
|
|
12
|
+
const marginTop = Math.max(0, Math.floor((screenHeight - height) / 2));
|
|
13
|
+
return (_jsxs(Box, { position: "absolute", marginLeft: marginLeft, marginTop: marginTop, flexDirection: "column", width: width, height: height, borderStyle: "single", borderColor: "cyan", children: [_jsx(Text, { color: "cyan", bold: true, children: title }), _jsx(Box, { flexDirection: "column", flexGrow: 1, paddingX: 1, marginTop: 1, children: children }), _jsx(Box, { paddingX: 1, children: _jsx(Text, { dimColor: true, children: "Press Escape to cancel" }) })] }));
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=Modal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Modal.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/Modal.tsx"],"names":[],"mappings":";AAOA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAqB1C,MAAM,UAAU,KAAK,CAAC,EACpB,KAAK,EACL,KAAK,EACL,MAAM,EACN,WAAW,EACX,YAAY,EACZ,OAAO,EACP,QAAQ,EACR,QAAQ,GAAG,IAAI,GACJ;IACX,yBAAyB;IACzB,QAAQ,CACN,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACb,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACf,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,EACD,EAAE,QAAQ,EAAE,CACb,CAAC;IAEF,8BAA8B;IAC9B,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,WAAW,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACtE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,YAAY,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAEvE,OAAO,CACL,MAAC,GAAG,IACF,QAAQ,EAAC,UAAU,EACnB,UAAU,EAAE,UAAU,EACtB,SAAS,EAAE,SAAS,EACpB,aAAa,EAAC,QAAQ,EACtB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAC,MAAM,aAGlB,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,IAAI,kBACpB,KAAK,GACD,EAGP,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,YAC/D,QAAQ,GACL,EAGN,KAAC,GAAG,IAAC,QAAQ,EAAE,CAAC,YACd,KAAC,IAAI,IAAC,QAAQ,6CAA8B,GACxC,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Reusable panel component with lazygit-style border titles.
|
|
3
|
+
* The title is embedded in the top border line: ┌─ Title ─────┐
|
|
4
|
+
*/
|
|
5
|
+
import React from "react";
|
|
6
|
+
import { type DOMElement } from "ink";
|
|
7
|
+
interface PanelProps {
|
|
8
|
+
title: string;
|
|
9
|
+
/** Optional value to display right-aligned in the title bar */
|
|
10
|
+
rightValue?: string | number;
|
|
11
|
+
children: React.ReactNode;
|
|
12
|
+
isActive: boolean;
|
|
13
|
+
isHovered?: boolean;
|
|
14
|
+
width: number;
|
|
15
|
+
height: number;
|
|
16
|
+
}
|
|
17
|
+
export declare const Panel: React.ForwardRefExoticComponent<PanelProps & React.RefAttributes<DOMElement>>;
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=Panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Panel.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/Panel.tsx"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAqB,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAa,KAAK,UAAU,EAAE,MAAM,KAAK,CAAC;AASjD,UAAU,UAAU;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,+DAA+D;IAC/D,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAmBD,eAAO,MAAM,KAAK,+EAgChB,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Reusable panel component with lazygit-style border titles.
|
|
4
|
+
* The title is embedded in the top border line: ┌─ Title ─────┐
|
|
5
|
+
*/
|
|
6
|
+
import { forwardRef } from "react";
|
|
7
|
+
import { Box, Text } from "ink";
|
|
8
|
+
// Box drawing characters (single line style)
|
|
9
|
+
const BOX = {
|
|
10
|
+
topLeft: "┌",
|
|
11
|
+
topRight: "┐",
|
|
12
|
+
horizontal: "─",
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* Creates the top border line with embedded title and optional right value.
|
|
16
|
+
* Format: ┌─ Title ─────────── 3 ─┐
|
|
17
|
+
*/
|
|
18
|
+
function buildTitleLine(title, totalWidth, rightValue) {
|
|
19
|
+
const titleWithSpaces = ` ${title} `;
|
|
20
|
+
const leftPart = `${BOX.topLeft}${BOX.horizontal}`;
|
|
21
|
+
const rightValueStr = rightValue !== undefined ? ` ${rightValue} ${BOX.horizontal}` : "";
|
|
22
|
+
const rightPart = BOX.topRight;
|
|
23
|
+
const usedWidth = leftPart.length + titleWithSpaces.length + rightValueStr.length + rightPart.length;
|
|
24
|
+
const remainingWidth = Math.max(1, totalWidth - usedWidth);
|
|
25
|
+
const dashes = BOX.horizontal.repeat(remainingWidth);
|
|
26
|
+
return `${leftPart}${titleWithSpaces}${dashes}${rightValueStr}${rightPart}`;
|
|
27
|
+
}
|
|
28
|
+
export const Panel = forwardRef(function Panel({ title, rightValue, children, isActive, isHovered, width, height }, ref) {
|
|
29
|
+
// Border colour: active > hovered > default
|
|
30
|
+
const borderColour = isActive ? "cyan" : isHovered ? "white" : "gray";
|
|
31
|
+
const titleLine = buildTitleLine(title, width, rightValue);
|
|
32
|
+
// Height for the bordered box (everything except the custom title line)
|
|
33
|
+
// This box will have left, right, and bottom borders via Ink's borderStyle
|
|
34
|
+
const innerBoxHeight = height - 1;
|
|
35
|
+
return (_jsxs(Box, { ref: ref, flexDirection: "column", width: width, height: height, children: [_jsx(Text, { color: borderColour, children: titleLine }), _jsx(Box, { flexDirection: "column", width: width, height: innerBoxHeight, borderStyle: "single", borderColor: borderColour, borderTop: false, overflowY: "hidden", children: children })] }));
|
|
36
|
+
});
|
|
37
|
+
//# sourceMappingURL=Panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Panel.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/Panel.tsx"],"names":[],"mappings":";AAAA;;;GAGG;AAEH,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,GAAG,EAAE,IAAI,EAAmB,MAAM,KAAK,CAAC;AAEjD,6CAA6C;AAC7C,MAAM,GAAG,GAAG;IACV,OAAO,EAAE,GAAG;IACZ,QAAQ,EAAE,GAAG;IACb,UAAU,EAAE,GAAG;CACP,CAAC;AAaX;;;GAGG;AACH,SAAS,cAAc,CAAC,KAAa,EAAE,UAAkB,EAAE,UAA4B;IACrF,MAAM,eAAe,GAAG,IAAI,KAAK,GAAG,CAAC;IACrC,MAAM,QAAQ,GAAG,GAAG,GAAG,CAAC,OAAO,GAAG,GAAG,CAAC,UAAU,EAAE,CAAC;IACnD,MAAM,aAAa,GAAG,UAAU,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,UAAU,IAAI,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACzF,MAAM,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC;IAE/B,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,GAAG,eAAe,CAAC,MAAM,GAAG,aAAa,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;IACrG,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,SAAS,CAAC,CAAC;IAC3D,MAAM,MAAM,GAAG,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;IAErD,OAAO,GAAG,QAAQ,GAAG,eAAe,GAAG,MAAM,GAAG,aAAa,GAAG,SAAS,EAAE,CAAC;AAC9E,CAAC;AAED,MAAM,CAAC,MAAM,KAAK,GAAG,UAAU,CAAyB,SAAS,KAAK,CACpE,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,EACnE,GAAG;IAEH,4CAA4C;IAC5C,MAAM,YAAY,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;IAEtE,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC;IAE3D,wEAAwE;IACxE,2EAA2E;IAC3E,MAAM,cAAc,GAAG,MAAM,GAAG,CAAC,CAAC;IAElC,OAAO,CACL,MAAC,GAAG,IAAC,GAAG,EAAE,GAAG,EAAE,aAAa,EAAC,QAAQ,EAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,aAEhE,KAAC,IAAI,IAAC,KAAK,EAAE,YAAY,YAAG,SAAS,GAAQ,EAG7C,KAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,cAAc,EACtB,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAE,YAAY,EACzB,SAAS,EAAE,KAAK,EAChB,SAAS,EAAC,QAAQ,YAEjB,QAAQ,GACL,IACF,CACP,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Right panel: detailed view of the selected request.
|
|
3
|
+
*/
|
|
4
|
+
import React from "react";
|
|
5
|
+
import { type DOMElement } from "ink";
|
|
6
|
+
import type { CapturedRequest } from "../../../shared/types.js";
|
|
7
|
+
interface RequestDetailsProps {
|
|
8
|
+
request: CapturedRequest | undefined;
|
|
9
|
+
isActive: boolean;
|
|
10
|
+
isHovered?: boolean;
|
|
11
|
+
width: number;
|
|
12
|
+
height: number;
|
|
13
|
+
}
|
|
14
|
+
export declare const RequestDetails: React.ForwardRefExoticComponent<RequestDetailsProps & React.RefAttributes<DOMElement>>;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=RequestDetails.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestDetails.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/RequestDetails.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAqB,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAa,KAAK,UAAU,EAAE,MAAM,KAAK,CAAC;AACjD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAMhE,UAAU,mBAAmB;IAC3B,OAAO,EAAE,eAAe,GAAG,SAAS,CAAC;IACrC,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,cAAc,wFAoGzB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Right panel: detailed view of the selected request.
|
|
4
|
+
*/
|
|
5
|
+
import { forwardRef } from "react";
|
|
6
|
+
import { Box, Text } from "ink";
|
|
7
|
+
import { HeadersView } from "./HeadersView.js";
|
|
8
|
+
import { BodyView } from "./BodyView.js";
|
|
9
|
+
import { formatRelativeTime, formatDuration } from "../utils/formatters.js";
|
|
10
|
+
import { Panel } from "./Panel.js";
|
|
11
|
+
export const RequestDetails = forwardRef(function RequestDetails({ request, isActive, isHovered, width, height }, ref) {
|
|
12
|
+
if (!request) {
|
|
13
|
+
return (_jsx(Panel, { ref: ref, title: "[2] Details", isActive: isActive, isHovered: isHovered, width: width, height: height, children: _jsx(Box, { flexGrow: 1, alignItems: "center", justifyContent: "center", children: _jsx(Text, { dimColor: true, children: "Select a request to view details" }) }) }));
|
|
14
|
+
}
|
|
15
|
+
// Calculate how much space we have for each section
|
|
16
|
+
const headerHeight = 6; // URL line + timing + separators
|
|
17
|
+
const availableHeight = Math.max(8, height - headerHeight);
|
|
18
|
+
const sectionHeight = Math.floor(availableHeight / 4);
|
|
19
|
+
const reqContentType = request.requestHeaders["content-type"];
|
|
20
|
+
const resContentType = request.responseHeaders?.["content-type"];
|
|
21
|
+
return (_jsxs(Panel, { ref: ref, title: "[2] Details", isActive: isActive, isHovered: isHovered, width: width, height: height, children: [_jsxs(Box, { marginBottom: 1, children: [_jsx(Text, { color: "green", bold: true, children: request.method }), _jsx(Text, { children: " " }), _jsx(Text, { children: request.url })] }), _jsxs(Box, { marginBottom: 1, children: [_jsx(Text, { dimColor: true, children: "Status: " }), _jsx(Text, { color: request.responseStatus && request.responseStatus < 400 ? "green" : "red", children: request.responseStatus ?? "pending" }), _jsx(Text, { dimColor: true, children: " \u2502 Duration: " }), _jsx(Text, { children: formatDuration(request.durationMs) }), _jsx(Text, { dimColor: true, children: " \u2502 " }), _jsx(Text, { dimColor: true, children: formatRelativeTime(request.timestamp) })] }), _jsx(Box, { marginBottom: 1, children: _jsx(HeadersView, { title: "Request Headers", headers: request.requestHeaders, maxLines: sectionHeight }) }), request.requestBody && request.requestBody.length > 0 && (_jsx(Box, { marginBottom: 1, children: _jsx(BodyView, { title: "Request Body", body: request.requestBody, contentType: reqContentType, maxLines: sectionHeight }) })), request.responseHeaders && (_jsx(Box, { marginBottom: 1, children: _jsx(HeadersView, { title: "Response Headers", headers: request.responseHeaders, maxLines: sectionHeight }) })), request.responseBody && request.responseBody.length > 0 && (_jsx(Box, { marginBottom: 1, children: _jsx(BodyView, { title: "Response Body", body: request.responseBody, contentType: resContentType, maxLines: sectionHeight }) }))] }));
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=RequestDetails.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestDetails.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/RequestDetails.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Left panel: scrollable list of captured requests.
|
|
3
|
+
*/
|
|
4
|
+
import React from "react";
|
|
5
|
+
import { type DOMElement } from "ink";
|
|
6
|
+
import type { CapturedRequestSummary } from "../../../shared/types.js";
|
|
7
|
+
interface RequestListProps {
|
|
8
|
+
requests: CapturedRequestSummary[];
|
|
9
|
+
selectedIndex: number;
|
|
10
|
+
isActive: boolean;
|
|
11
|
+
isHovered?: boolean;
|
|
12
|
+
width: number;
|
|
13
|
+
height: number;
|
|
14
|
+
showFullUrl?: boolean;
|
|
15
|
+
onItemClick?: (index: number) => void;
|
|
16
|
+
scrollOffset?: number;
|
|
17
|
+
searchTerm?: string;
|
|
18
|
+
}
|
|
19
|
+
export declare const RequestList: React.ForwardRefExoticComponent<RequestListProps & React.RefAttributes<DOMElement>>;
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=RequestList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestList.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/RequestList.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAqB,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAa,KAAK,UAAU,EAAE,MAAM,KAAK,CAAC;AACjD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAIvE,UAAU,gBAAgB;IACxB,QAAQ,EAAE,sBAAsB,EAAE,CAAC;IACnC,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,eAAO,MAAM,WAAW,qFA4DtB,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Left panel: scrollable list of captured requests.
|
|
4
|
+
*/
|
|
5
|
+
import { forwardRef } from "react";
|
|
6
|
+
import { Box, Text } from "ink";
|
|
7
|
+
import { RequestListItem } from "./RequestListItem.js";
|
|
8
|
+
import { Panel } from "./Panel.js";
|
|
9
|
+
export const RequestList = forwardRef(function RequestList({ requests, selectedIndex, isActive, isHovered, width, height, showFullUrl, onItemClick, scrollOffset: providedScrollOffset, searchTerm }, ref) {
|
|
10
|
+
// Calculate visible window (accounting for border - 2 lines for top/bottom)
|
|
11
|
+
const visibleHeight = Math.max(1, height - 2);
|
|
12
|
+
const halfWindow = Math.floor(visibleHeight / 2);
|
|
13
|
+
// Use provided scroll offset, or fall back to selection-centred behaviour
|
|
14
|
+
let effectiveScrollOffset = providedScrollOffset ?? 0;
|
|
15
|
+
if (providedScrollOffset === undefined && requests.length > visibleHeight) {
|
|
16
|
+
effectiveScrollOffset = Math.max(0, Math.min(selectedIndex - halfWindow, requests.length - visibleHeight));
|
|
17
|
+
}
|
|
18
|
+
const visibleRequests = requests.slice(effectiveScrollOffset, effectiveScrollOffset + visibleHeight);
|
|
19
|
+
// Build title and right value
|
|
20
|
+
const title = "[1] Requests";
|
|
21
|
+
let rightValue = requests.length;
|
|
22
|
+
if (requests.length > visibleHeight) {
|
|
23
|
+
rightValue = `${effectiveScrollOffset + 1}-${Math.min(effectiveScrollOffset + visibleHeight, requests.length)}/${requests.length}`;
|
|
24
|
+
}
|
|
25
|
+
return (_jsx(Panel, { ref: ref, title: title, rightValue: rightValue, isActive: isActive, isHovered: isHovered, width: width, height: height, children: requests.length === 0 ? (_jsxs(Box, { paddingX: 1, paddingY: 1, flexDirection: "column", children: [_jsx(Text, { dimColor: true, children: "No requests captured yet." }), _jsx(Text, { dimColor: true, children: " " }), _jsxs(Text, { children: ["Run ", _jsx(Text, { color: "cyan", children: "eval $(procsi vars)" }), " in another terminal"] }), _jsx(Text, { dimColor: true, children: "to start capturing traffic." })] })) : (_jsx(Box, { flexDirection: "column", paddingX: 1, children: visibleRequests.map((request, index) => {
|
|
26
|
+
const absoluteIndex = effectiveScrollOffset + index;
|
|
27
|
+
return (_jsx(RequestListItem, { request: request, isSelected: absoluteIndex === selectedIndex, width: width - 4, showFullUrl: showFullUrl, onClick: onItemClick ? () => onItemClick(absoluteIndex) : undefined, searchTerm: searchTerm }, request.id));
|
|
28
|
+
}) })) }));
|
|
29
|
+
});
|
|
30
|
+
//# sourceMappingURL=RequestList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestList.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/RequestList.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Single request row in the request list.
|
|
3
|
+
*/
|
|
4
|
+
import React from "react";
|
|
5
|
+
import type { CapturedRequestSummary, InterceptionType } from "../../../shared/types.js";
|
|
6
|
+
/**
|
|
7
|
+
* Get the 2-character interception indicator and its colour.
|
|
8
|
+
* Returns "M " for mocked, "I " for modified, or " " for normal requests.
|
|
9
|
+
*/
|
|
10
|
+
export declare function getInterceptionIndicator(type?: InterceptionType): {
|
|
11
|
+
text: string;
|
|
12
|
+
colour?: string;
|
|
13
|
+
};
|
|
14
|
+
interface RequestListItemProps {
|
|
15
|
+
request: CapturedRequestSummary;
|
|
16
|
+
isSelected: boolean;
|
|
17
|
+
width: number;
|
|
18
|
+
showFullUrl?: boolean;
|
|
19
|
+
onClick?: () => void;
|
|
20
|
+
searchTerm?: string;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Get colour for HTTP status code.
|
|
24
|
+
*/
|
|
25
|
+
export declare function getStatusColour(status: number | undefined): string;
|
|
26
|
+
/**
|
|
27
|
+
* Get a visual indicator character for an HTTP status code.
|
|
28
|
+
*/
|
|
29
|
+
export declare function getStatusIndicator(status: number | undefined): string;
|
|
30
|
+
/**
|
|
31
|
+
* Get colour for HTTP method.
|
|
32
|
+
*/
|
|
33
|
+
export declare function getMethodColour(method: string): string;
|
|
34
|
+
export declare const RequestListItem: React.NamedExoticComponent<RequestListItemProps>;
|
|
35
|
+
export {};
|
|
36
|
+
//# sourceMappingURL=RequestListItem.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestListItem.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/RequestListItem.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAuB,MAAM,OAAO,CAAC;AAG5C,OAAO,KAAK,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAGzF;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,IAAI,CAAC,EAAE,gBAAgB,GAAG;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,CASnG;AAED,UAAU,oBAAoB;IAC5B,OAAO,EAAE,sBAAsB,CAAC;IAChC,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,MAAM,CAclE;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,MAAM,CAWrE;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAetD;AA8BD,eAAO,MAAM,eAAe,kDAqE1B,CAAC"}
|