arc402-cli 0.8.0 → 0.9.1
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/INK6-UX-SPEC.md +446 -0
- package/dist/tui/App.d.ts.map +1 -1
- package/dist/tui/App.js +23 -7
- package/dist/tui/App.js.map +1 -1
- package/dist/tui/Header.d.ts +1 -1
- package/dist/tui/Header.d.ts.map +1 -1
- package/dist/tui/Header.js +6 -5
- package/dist/tui/Header.js.map +1 -1
- package/dist/tui/InputLine.d.ts +1 -2
- package/dist/tui/InputLine.d.ts.map +1 -1
- package/dist/tui/InputLine.js +76 -24
- package/dist/tui/InputLine.js.map +1 -1
- package/dist/tui/Viewport.d.ts.map +1 -1
- package/dist/tui/Viewport.js +4 -7
- package/dist/tui/Viewport.js.map +1 -1
- package/dist/tui/components/Button.d.ts +7 -0
- package/dist/tui/components/Button.d.ts.map +1 -0
- package/dist/tui/components/Button.js +18 -0
- package/dist/tui/components/Button.js.map +1 -0
- package/dist/tui/components/CeremonyView.d.ts +13 -0
- package/dist/tui/components/CeremonyView.d.ts.map +1 -0
- package/dist/tui/components/CeremonyView.js +7 -0
- package/dist/tui/components/CeremonyView.js.map +1 -0
- package/dist/tui/components/CompletionDropdown.d.ts +7 -0
- package/dist/tui/components/CompletionDropdown.d.ts.map +1 -0
- package/dist/tui/components/CompletionDropdown.js +20 -0
- package/dist/tui/components/CompletionDropdown.js.map +1 -0
- package/dist/tui/components/ConfirmPrompt.d.ts +9 -0
- package/dist/tui/components/ConfirmPrompt.d.ts.map +1 -0
- package/dist/tui/components/ConfirmPrompt.js +7 -0
- package/dist/tui/components/ConfirmPrompt.js.map +1 -0
- package/dist/tui/components/InteractiveTable.d.ts +14 -0
- package/dist/tui/components/InteractiveTable.d.ts.map +1 -0
- package/dist/tui/components/InteractiveTable.js +58 -0
- package/dist/tui/components/InteractiveTable.js.map +1 -0
- package/dist/tui/components/StepSpinner.d.ts +11 -0
- package/dist/tui/components/StepSpinner.d.ts.map +1 -0
- package/dist/tui/components/StepSpinner.js +29 -0
- package/dist/tui/components/StepSpinner.js.map +1 -0
- package/dist/tui/components/Toast.d.ts +18 -0
- package/dist/tui/components/Toast.d.ts.map +1 -0
- package/dist/tui/components/Toast.js +25 -0
- package/dist/tui/components/Toast.js.map +1 -0
- package/dist/tui/index.d.ts.map +1 -1
- package/dist/tui/index.js +15 -1
- package/dist/tui/index.js.map +1 -1
- package/dist/tui/useCommand.d.ts +3 -2
- package/dist/tui/useCommand.d.ts.map +1 -1
- package/dist/tui/useCommand.js +89 -7
- package/dist/tui/useCommand.js.map +1 -1
- package/dist/tui/useNotifications.d.ts +9 -0
- package/dist/tui/useNotifications.d.ts.map +1 -0
- package/dist/tui/useNotifications.js +14 -0
- package/dist/tui/useNotifications.js.map +1 -0
- package/dist/ui/banner.d.ts +12 -0
- package/dist/ui/banner.d.ts.map +1 -1
- package/dist/ui/banner.js +23 -0
- package/dist/ui/banner.js.map +1 -1
- package/package.json +1 -1
- package/src/tui/App.tsx +36 -17
- package/src/tui/Header.tsx +26 -5
- package/src/tui/InputLine.tsx +107 -32
- package/src/tui/Viewport.tsx +4 -7
- package/src/tui/components/Button.tsx +38 -0
- package/src/tui/components/CeremonyView.tsx +39 -0
- package/src/tui/components/CompletionDropdown.tsx +59 -0
- package/src/tui/components/ConfirmPrompt.tsx +36 -0
- package/src/tui/components/InteractiveTable.tsx +112 -0
- package/src/tui/components/StepSpinner.tsx +84 -0
- package/src/tui/components/Toast.tsx +59 -0
- package/src/tui/index.tsx +20 -1
- package/src/tui/useCommand.ts +98 -8
- package/src/tui/useNotifications.ts +28 -0
- package/src/ui/banner.ts +27 -0
package/dist/tui/InputLine.js
CHANGED
|
@@ -3,16 +3,20 @@ import { useState, useCallback } from "react";
|
|
|
3
3
|
import { Box, Text, useInput } from "ink";
|
|
4
4
|
import TextInput from "ink-text-input";
|
|
5
5
|
import { createProgram } from "../program.js";
|
|
6
|
+
import { CompletionDropdown } from "./components/CompletionDropdown.js";
|
|
6
7
|
const BUILTIN_CMDS = ["help", "exit", "quit", "clear", "status"];
|
|
7
8
|
/**
|
|
8
|
-
* Input line with command history navigation
|
|
9
|
-
* Uses ink-text-input for text input with cursor.
|
|
9
|
+
* Input line with command history navigation, tab completion, and dropdown.
|
|
10
10
|
*/
|
|
11
11
|
export function InputLine({ onSubmit, isDisabled = false }) {
|
|
12
12
|
const [value, setValue] = useState("");
|
|
13
13
|
const [history, setHistory] = useState([]);
|
|
14
14
|
const [historyIdx, setHistoryIdx] = useState(-1);
|
|
15
15
|
const [historyTemp, setHistoryTemp] = useState("");
|
|
16
|
+
// Dropdown state
|
|
17
|
+
const [showDropdown, setShowDropdown] = useState(false);
|
|
18
|
+
const [dropdownIdx, setDropdownIdx] = useState(0);
|
|
19
|
+
const [dropdownCandidates, setDropdownCandidates] = useState([]);
|
|
16
20
|
// Lazily build command list for tab completion
|
|
17
21
|
const [topCmds] = useState(() => {
|
|
18
22
|
try {
|
|
@@ -38,11 +42,24 @@ export function InputLine({ onSubmit, isDisabled = false }) {
|
|
|
38
42
|
return new Map();
|
|
39
43
|
}
|
|
40
44
|
});
|
|
45
|
+
const getCompletions = useCallback((input) => {
|
|
46
|
+
const allTop = [...BUILTIN_CMDS, ...topCmds];
|
|
47
|
+
const trimmed = input.trimStart();
|
|
48
|
+
const spaceIdx = trimmed.indexOf(" ");
|
|
49
|
+
if (spaceIdx === -1) {
|
|
50
|
+
return allTop.filter((cmd) => cmd.startsWith(trimmed));
|
|
51
|
+
}
|
|
52
|
+
const parent = trimmed.slice(0, spaceIdx);
|
|
53
|
+
const rest = trimmed.slice(spaceIdx + 1);
|
|
54
|
+
const subs = subCmds.get(parent) ?? [];
|
|
55
|
+
return subs
|
|
56
|
+
.filter((s) => s.startsWith(rest))
|
|
57
|
+
.map((s) => `${parent} ${s}`);
|
|
58
|
+
}, [topCmds, subCmds]);
|
|
41
59
|
const handleSubmit = useCallback((val) => {
|
|
42
60
|
const trimmed = val.trim();
|
|
43
61
|
if (!trimmed)
|
|
44
62
|
return;
|
|
45
|
-
// Add to history (avoid duplicate of last entry)
|
|
46
63
|
setHistory((prev) => {
|
|
47
64
|
if (prev[prev.length - 1] === trimmed)
|
|
48
65
|
return prev;
|
|
@@ -51,12 +68,36 @@ export function InputLine({ onSubmit, isDisabled = false }) {
|
|
|
51
68
|
setHistoryIdx(-1);
|
|
52
69
|
setHistoryTemp("");
|
|
53
70
|
setValue("");
|
|
71
|
+
setShowDropdown(false);
|
|
54
72
|
onSubmit(trimmed);
|
|
55
73
|
}, [onSubmit]);
|
|
56
74
|
useInput((_input, key) => {
|
|
57
75
|
if (isDisabled)
|
|
58
76
|
return;
|
|
59
|
-
//
|
|
77
|
+
// ── Dropdown navigation ───────────────────────────────────────────
|
|
78
|
+
if (showDropdown) {
|
|
79
|
+
if (key.upArrow) {
|
|
80
|
+
setDropdownIdx((i) => Math.max(0, i - 1));
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
if (key.downArrow) {
|
|
84
|
+
setDropdownIdx((i) => Math.min(dropdownCandidates.length - 1, i + 1));
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (key.return) {
|
|
88
|
+
// Select the highlighted candidate
|
|
89
|
+
if (dropdownCandidates[dropdownIdx]) {
|
|
90
|
+
setValue(dropdownCandidates[dropdownIdx] + " ");
|
|
91
|
+
}
|
|
92
|
+
setShowDropdown(false);
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
if (key.escape) {
|
|
96
|
+
setShowDropdown(false);
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
// ── History navigation ────────────────────────────────────────────
|
|
60
101
|
if (key.upArrow) {
|
|
61
102
|
setHistory((hist) => {
|
|
62
103
|
setHistoryIdx((idx) => {
|
|
@@ -78,7 +119,6 @@ export function InputLine({ onSubmit, isDisabled = false }) {
|
|
|
78
119
|
});
|
|
79
120
|
return;
|
|
80
121
|
}
|
|
81
|
-
// Down arrow — history next
|
|
82
122
|
if (key.downArrow) {
|
|
83
123
|
setHistory((hist) => {
|
|
84
124
|
setHistoryIdx((idx) => {
|
|
@@ -99,30 +139,23 @@ export function InputLine({ onSubmit, isDisabled = false }) {
|
|
|
99
139
|
});
|
|
100
140
|
return;
|
|
101
141
|
}
|
|
102
|
-
// Tab — completion
|
|
142
|
+
// ── Tab — completion / dropdown ───────────────────────────────────
|
|
103
143
|
if (_input === "\t") {
|
|
104
|
-
const
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
let completions;
|
|
108
|
-
if (spaceIdx === -1) {
|
|
109
|
-
completions = allTop.filter((cmd) => cmd.startsWith(trimmed));
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
const parent = trimmed.slice(0, spaceIdx);
|
|
113
|
-
const rest = trimmed.slice(spaceIdx + 1);
|
|
114
|
-
const subs = subCmds.get(parent) ?? [];
|
|
115
|
-
completions = subs
|
|
116
|
-
.filter((s) => s.startsWith(rest))
|
|
117
|
-
.map((s) => `${parent} ${s}`);
|
|
118
|
-
}
|
|
119
|
-
if (completions.length === 0)
|
|
144
|
+
const completions = getCompletions(value);
|
|
145
|
+
if (completions.length === 0) {
|
|
146
|
+
setShowDropdown(false);
|
|
120
147
|
return;
|
|
148
|
+
}
|
|
121
149
|
if (completions.length === 1) {
|
|
122
150
|
setValue(completions[0] + " ");
|
|
151
|
+
setShowDropdown(false);
|
|
123
152
|
return;
|
|
124
153
|
}
|
|
125
|
-
//
|
|
154
|
+
// Show dropdown with multiple candidates
|
|
155
|
+
setDropdownCandidates(completions);
|
|
156
|
+
setDropdownIdx(0);
|
|
157
|
+
setShowDropdown(true);
|
|
158
|
+
// Also advance to common prefix
|
|
126
159
|
const common = completions.reduce((a, b) => {
|
|
127
160
|
let i = 0;
|
|
128
161
|
while (i < a.length && i < b.length && a[i] === b[i])
|
|
@@ -133,7 +166,26 @@ export function InputLine({ onSubmit, isDisabled = false }) {
|
|
|
133
166
|
setValue(common);
|
|
134
167
|
}
|
|
135
168
|
}
|
|
169
|
+
// ── Escape — dismiss dropdown ─────────────────────────────────────
|
|
170
|
+
if (key.escape) {
|
|
171
|
+
setShowDropdown(false);
|
|
172
|
+
}
|
|
136
173
|
}, { isActive: !isDisabled });
|
|
137
|
-
|
|
174
|
+
// Dismiss dropdown when value changes (user types more)
|
|
175
|
+
const handleChange = useCallback((newVal) => {
|
|
176
|
+
setValue(newVal);
|
|
177
|
+
// If dropdown is open, update candidates live
|
|
178
|
+
if (showDropdown) {
|
|
179
|
+
const completions = getCompletions(newVal);
|
|
180
|
+
if (completions.length <= 1) {
|
|
181
|
+
setShowDropdown(false);
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
setDropdownCandidates(completions);
|
|
185
|
+
setDropdownIdx(0);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}, [showDropdown, getCompletions]);
|
|
189
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(CompletionDropdown, { candidates: dropdownCandidates, selectedIndex: dropdownIdx, visible: showDropdown }), _jsxs(Box, { children: [_jsx(Text, { color: "cyan", children: "\u25C8" }), _jsx(Text, { dimColor: true, children: " arc402 " }), _jsxs(Text, { color: "white", children: [">", " "] }), _jsx(TextInput, { value: value, onChange: handleChange, onSubmit: handleSubmit, focus: !isDisabled })] })] }));
|
|
138
190
|
}
|
|
139
191
|
//# sourceMappingURL=InputLine.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InputLine.js","sourceRoot":"","sources":["../../src/tui/InputLine.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"InputLine.js","sourceRoot":"","sources":["../../src/tui/InputLine.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,WAAW,EAAW,MAAM,OAAO,CAAC;AAC9D,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAC1C,OAAO,SAAS,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AAExE,MAAM,YAAY,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;AAOjE;;GAEG;AACH,MAAM,UAAU,SAAS,CAAC,EAAE,QAAQ,EAAE,UAAU,GAAG,KAAK,EAAkB;IACxE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvC,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAC;IACrD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IACjD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAEnD,iBAAiB;IACjB,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAClD,MAAM,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAC;IAE3E,+CAA+C;IAC/C,MAAM,CAAC,OAAO,CAAC,GAAG,QAAQ,CAAW,GAAG,EAAE;QACxC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,aAAa,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QAChD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,CAAC,CAAC;IACH,MAAM,CAAC,OAAO,CAAC,GAAG,QAAQ,CAAwB,GAAG,EAAE;QACrD,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,aAAa,EAAE,CAAC;YAC7B,MAAM,GAAG,GAAG,IAAI,GAAG,EAAoB,CAAC;YACxC,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChC,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC5B,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;gBACzD,CAAC;YACH,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,GAAG,EAAE,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,MAAM,cAAc,GAAG,WAAW,CAChC,CAAC,KAAa,EAAY,EAAE;QAC1B,MAAM,MAAM,GAAG,CAAC,GAAG,YAAY,EAAE,GAAG,OAAO,CAAC,CAAC;QAC7C,MAAM,OAAO,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAEtC,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE,CAAC;YACpB,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;QACzD,CAAC;QACD,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;QAC1C,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;QACzC,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACvC,OAAO,IAAI;aACR,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;aACjC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC,EACD,CAAC,OAAO,EAAE,OAAO,CAAC,CACnB,CAAC;IAEF,MAAM,YAAY,GAAG,WAAW,CAC9B,CAAC,GAAW,EAAE,EAAE;QACd,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,UAAU,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,OAAO;gBAAE,OAAO,IAAI,CAAC;YACnD,OAAO,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;QACH,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QAClB,cAAc,CAAC,EAAE,CAAC,CAAC;QACnB,QAAQ,CAAC,EAAE,CAAC,CAAC;QACb,eAAe,CAAC,KAAK,CAAC,CAAC;QAEvB,QAAQ,CAAC,OAAO,CAAC,CAAC;IACpB,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAC;IAEF,QAAQ,CACN,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;QACd,IAAI,UAAU;YAAE,OAAO;QAEvB,qEAAqE;QACrE,IAAI,YAAY,EAAE,CAAC;YACjB,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;gBAChB,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBAC1C,OAAO;YACT,CAAC;YACD,IAAI,GAAG,CAAC,SAAS,EAAE,CAAC;gBAClB,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,CACnB,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAC/C,CAAC;gBACF,OAAO;YACT,CAAC;YACD,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;gBACf,mCAAmC;gBACnC,IAAI,kBAAkB,CAAC,WAAW,CAAC,EAAE,CAAC;oBACpC,QAAQ,CAAC,kBAAkB,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC,CAAC;gBAClD,CAAC;gBACD,eAAe,CAAC,KAAK,CAAC,CAAC;gBACvB,OAAO;YACT,CAAC;YACD,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;gBACf,eAAe,CAAC,KAAK,CAAC,CAAC;gBACvB,OAAO;YACT,CAAC;QACH,CAAC;QAED,qEAAqE;QACrE,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;YAChB,UAAU,CAAC,CAAC,IAAI,EAAE,EAAE;gBAClB,aAAa,CAAC,CAAC,GAAG,EAAE,EAAE;oBACpB,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC;wBACf,cAAc,CAAC,KAAK,CAAC,CAAC;wBACtB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;wBAC/B,IAAI,MAAM,IAAI,CAAC;4BAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;wBACxC,OAAO,MAAM,CAAC;oBAChB,CAAC;yBAAM,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;wBACnB,MAAM,MAAM,GAAG,GAAG,GAAG,CAAC,CAAC;wBACvB,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;wBACvB,OAAO,MAAM,CAAC;oBAChB,CAAC;oBACD,OAAO,GAAG,CAAC;gBACb,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,IAAI,GAAG,CAAC,SAAS,EAAE,CAAC;YAClB,UAAU,CAAC,CAAC,IAAI,EAAE,EAAE;gBAClB,aAAa,CAAC,CAAC,GAAG,EAAE,EAAE;oBACpB,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC;wBACb,MAAM,MAAM,GAAG,GAAG,GAAG,CAAC,CAAC;wBACvB,IAAI,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;4BAC1B,QAAQ,CAAC,WAAW,CAAC,CAAC;4BACtB,OAAO,CAAC,CAAC,CAAC;wBACZ,CAAC;6BAAM,CAAC;4BACN,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;4BACvB,OAAO,MAAM,CAAC;wBAChB,CAAC;oBACH,CAAC;oBACD,OAAO,GAAG,CAAC;gBACb,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,qEAAqE;QACrE,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;YACpB,MAAM,WAAW,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;YAE1C,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7B,eAAe,CAAC,KAAK,CAAC,CAAC;gBACvB,OAAO;YACT,CAAC;YAED,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7B,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;gBAC/B,eAAe,CAAC,KAAK,CAAC,CAAC;gBACvB,OAAO;YACT,CAAC;YAED,yCAAyC;YACzC,qBAAqB,CAAC,WAAW,CAAC,CAAC;YACnC,cAAc,CAAC,CAAC,CAAC,CAAC;YAClB,eAAe,CAAC,IAAI,CAAC,CAAC;YAEtB,gCAAgC;YAChC,MAAM,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBACzC,IAAI,CAAC,GAAG,CAAC,CAAC;gBACV,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oBAAE,CAAC,EAAE,CAAC;gBAC1D,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;YACH,IAAI,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC,MAAM,EAAE,CAAC;gBAC7C,QAAQ,CAAC,MAAM,CAAC,CAAC;YACnB,CAAC;QACH,CAAC;QAED,qEAAqE;QACrE,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACf,eAAe,CAAC,KAAK,CAAC,CAAC;QACzB,CAAC;IACH,CAAC,EACD,EAAE,QAAQ,EAAE,CAAC,UAAU,EAAE,CAC1B,CAAC;IAEF,wDAAwD;IACxD,MAAM,YAAY,GAAG,WAAW,CAC9B,CAAC,MAAc,EAAE,EAAE;QACjB,QAAQ,CAAC,MAAM,CAAC,CAAC;QACjB,8CAA8C;QAC9C,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;YAC3C,IAAI,WAAW,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gBAC5B,eAAe,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC;iBAAM,CAAC;gBACN,qBAAqB,CAAC,WAAW,CAAC,CAAC;gBACnC,cAAc,CAAC,CAAC,CAAC,CAAC;YACpB,CAAC;QACH,CAAC;IACH,CAAC,EACD,CAAC,YAAY,EAAE,cAAc,CAAC,CAC/B,CAAC;IAEF,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aAEzB,KAAC,kBAAkB,IACjB,UAAU,EAAE,kBAAkB,EAC9B,aAAa,EAAE,WAAW,EAC1B,OAAO,EAAE,YAAY,GACrB,EACF,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,uBAAS,EAC3B,KAAC,IAAI,IAAC,QAAQ,+BAAgB,EAC9B,MAAC,IAAI,IAAC,KAAK,EAAC,OAAO,aAAE,GAAG,SAAS,EACjC,KAAC,SAAS,IACR,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,YAAY,EACtB,QAAQ,EAAE,YAAY,EACtB,KAAK,EAAE,CAAC,UAAU,GAClB,IACE,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Viewport.d.ts","sourceRoot":"","sources":["../../src/tui/Viewport.tsx"],"names":[],"mappings":"AAGA,UAAU,aAAa;IACrB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED;;;;;GAKG;AACH,wBAAgB,QAAQ,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,EAAE,aAAa,
|
|
1
|
+
{"version":3,"file":"Viewport.d.ts","sourceRoot":"","sources":["../../src/tui/Viewport.tsx"],"names":[],"mappings":"AAGA,UAAU,aAAa;IACrB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED;;;;;GAKG;AACH,wBAAgB,QAAQ,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,EAAE,aAAa,2CAmD5E"}
|
package/dist/tui/Viewport.js
CHANGED
|
@@ -9,13 +9,10 @@ import { Box, Text, useStdout } from "ink";
|
|
|
9
9
|
export function Viewport({ lines, scrollOffset, isAutoScroll }) {
|
|
10
10
|
const { stdout } = useStdout();
|
|
11
11
|
const termRows = stdout?.rows ?? 24;
|
|
12
|
-
//
|
|
13
|
-
//
|
|
14
|
-
//
|
|
15
|
-
|
|
16
|
-
const HEADER_ROWS = 15; // approximate
|
|
17
|
-
const FOOTER_ROWS = 1;
|
|
18
|
-
const viewportHeight = Math.max(1, termRows - HEADER_ROWS - FOOTER_ROWS);
|
|
12
|
+
// Approximate viewport height for scroll slicing.
|
|
13
|
+
// The actual flex layout handles visual sizing; this is for computing
|
|
14
|
+
// which lines to show in the scroll window.
|
|
15
|
+
const viewportHeight = Math.max(1, termRows - 18);
|
|
19
16
|
// Compute the window slice
|
|
20
17
|
// scrollOffset=0 → show last viewportHeight lines
|
|
21
18
|
// scrollOffset=N → show lines ending viewportHeight+N from end
|
package/dist/tui/Viewport.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Viewport.js","sourceRoot":"","sources":["../../src/tui/Viewport.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,KAAK,CAAC;AAQ3C;;;;;GAKG;AACH,MAAM,UAAU,QAAQ,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,YAAY,EAAiB;IAC3E,MAAM,EAAE,MAAM,EAAE,GAAG,SAAS,EAAE,CAAC;IAC/B,MAAM,QAAQ,GAAG,MAAM,EAAE,IAAI,IAAI,EAAE,CAAC;IAEpC,
|
|
1
|
+
{"version":3,"file":"Viewport.js","sourceRoot":"","sources":["../../src/tui/Viewport.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,KAAK,CAAC;AAQ3C;;;;;GAKG;AACH,MAAM,UAAU,QAAQ,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,YAAY,EAAiB;IAC3E,MAAM,EAAE,MAAM,EAAE,GAAG,SAAS,EAAE,CAAC;IAC/B,MAAM,QAAQ,GAAG,MAAM,EAAE,IAAI,IAAI,EAAE,CAAC;IAEpC,kDAAkD;IAClD,sEAAsE;IACtE,4CAA4C;IAC5C,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,GAAG,EAAE,CAAC,CAAC;IAElD,2BAA2B;IAC3B,kDAAkD;IAClD,+DAA+D;IAC/D,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC;IAChC,IAAI,MAAc,CAAC;IACnB,IAAI,QAAgB,CAAC;IAErB,IAAI,YAAY,KAAK,CAAC,EAAE,CAAC;QACvB,gCAAgC;QAChC,MAAM,GAAG,UAAU,CAAC;QACpB,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,cAAc,CAAC,CAAC;IAClD,CAAC;SAAM,CAAC;QACN,8CAA8C;QAC9C,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,YAAY,CAAC,CAAC;QAChD,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,cAAc,CAAC,CAAC;IAClD,CAAC;IAED,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAEnD,oDAAoD;IACpD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,cAAc,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;IACnE,MAAM,WAAW,GAAG;QAClB,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;QAC3B,GAAG,YAAY;KAChB,CAAC;IAEF,MAAM,aAAa,GAAG,YAAY,GAAG,CAAC,CAAC;IAEvC,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,aACrC,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,YACpC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAC5B,KAAC,IAAI,cAAU,IAAI,IAAR,CAAC,CAAe,CAC5B,CAAC,GACE,EACL,aAAa,IAAI,CAAC,YAAY,IAAI,CACjC,KAAC,GAAG,IAAC,cAAc,EAAC,UAAU,YAC5B,KAAC,IAAI,IAAC,QAAQ,kCAAc,GACxB,CACP,IACG,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface ButtonProps {
|
|
2
|
+
label: string;
|
|
3
|
+
onPress: () => void;
|
|
4
|
+
variant?: "primary" | "danger" | "dim";
|
|
5
|
+
}
|
|
6
|
+
export declare function Button({ label, onPress, variant }: ButtonProps): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
//# sourceMappingURL=Button.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../../src/tui/components/Button.tsx"],"names":[],"mappings":"AAGA,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,OAAO,CAAC,EAAE,SAAS,GAAG,QAAQ,GAAG,KAAK,CAAC;CACxC;AAQD,wBAAgB,MAAM,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,OAAmB,EAAE,EAAE,WAAW,2CAsB1E"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text, useFocus, useInput } from "ink";
|
|
3
|
+
const VARIANT_COLORS = {
|
|
4
|
+
primary: "cyan",
|
|
5
|
+
danger: "red",
|
|
6
|
+
dim: "gray",
|
|
7
|
+
};
|
|
8
|
+
export function Button({ label, onPress, variant = "primary" }) {
|
|
9
|
+
const { isFocused } = useFocus();
|
|
10
|
+
useInput((_input, key) => {
|
|
11
|
+
if (key.return) {
|
|
12
|
+
onPress();
|
|
13
|
+
}
|
|
14
|
+
}, { isActive: isFocused });
|
|
15
|
+
const color = isFocused ? VARIANT_COLORS[variant] ?? "cyan" : "white";
|
|
16
|
+
return (_jsx(Box, { children: _jsxs(Text, { color: color, bold: isFocused, children: [isFocused ? "▸ " : " ", label] }) }));
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=Button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../../src/tui/components/Button.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAQpD,MAAM,cAAc,GAA2B;IAC7C,OAAO,EAAE,MAAM;IACf,MAAM,EAAE,KAAK;IACb,GAAG,EAAE,MAAM;CACZ,CAAC;AAEF,MAAM,UAAU,MAAM,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,GAAG,SAAS,EAAe;IACzE,MAAM,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,CAAC;IAEjC,QAAQ,CACN,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;QACd,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACf,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,EACD,EAAE,QAAQ,EAAE,SAAS,EAAE,CACxB,CAAC;IAEF,MAAM,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;IAEtE,OAAO,CACL,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,aAChC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EACvB,KAAK,IACD,GACH,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { StepStatus } from "./StepSpinner.js";
|
|
2
|
+
export interface CeremonyStep {
|
|
3
|
+
label: string;
|
|
4
|
+
status: StepStatus;
|
|
5
|
+
detail?: string;
|
|
6
|
+
error?: string;
|
|
7
|
+
}
|
|
8
|
+
export interface CeremonyViewProps {
|
|
9
|
+
title: string;
|
|
10
|
+
steps: CeremonyStep[];
|
|
11
|
+
}
|
|
12
|
+
export declare function CeremonyView({ title, steps }: CeremonyViewProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
//# sourceMappingURL=CeremonyView.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CeremonyView.d.ts","sourceRoot":"","sources":["../../../src/tui/components/CeremonyView.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,UAAU,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,YAAY,EAAE,CAAC;CACvB;AAED,wBAAgB,YAAY,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,iBAAiB,2CAqB/D"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
import { StepSpinner } from "./StepSpinner.js";
|
|
4
|
+
export function CeremonyView({ title, steps }) {
|
|
5
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { marginBottom: 1, children: _jsxs(Text, { bold: true, color: "cyan", children: ["\u25C8 ", title] }) }), steps.map((step, i) => (_jsx(StepSpinner, { step: i + 1, total: steps.length, label: step.label, status: step.status, detail: step.detail, error: step.error }, i)))] }));
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=CeremonyView.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CeremonyView.js","sourceRoot":"","sources":["../../../src/tui/components/CeremonyView.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAe/C,MAAM,UAAU,YAAY,CAAC,EAAE,KAAK,EAAE,KAAK,EAAqB;IAC9D,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aACzB,KAAC,GAAG,IAAC,YAAY,EAAE,CAAC,YAClB,MAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,MAAM,wBAClB,KAAK,IACH,GACH,EACL,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CACtB,KAAC,WAAW,IAEV,IAAI,EAAE,CAAC,GAAG,CAAC,EACX,KAAK,EAAE,KAAK,CAAC,MAAM,EACnB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,MAAM,EAAE,IAAI,CAAC,MAAM,EACnB,MAAM,EAAE,IAAI,CAAC,MAAM,EACnB,KAAK,EAAE,IAAI,CAAC,KAAK,IANZ,CAAC,CAON,CACH,CAAC,IACE,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface CompletionDropdownProps {
|
|
2
|
+
candidates: string[];
|
|
3
|
+
selectedIndex: number;
|
|
4
|
+
visible: boolean;
|
|
5
|
+
}
|
|
6
|
+
export declare function CompletionDropdown({ candidates, selectedIndex, visible, }: CompletionDropdownProps): import("react/jsx-runtime").JSX.Element | null;
|
|
7
|
+
//# sourceMappingURL=CompletionDropdown.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CompletionDropdown.d.ts","sourceRoot":"","sources":["../../../src/tui/components/CompletionDropdown.tsx"],"names":[],"mappings":"AAGA,MAAM,WAAW,uBAAuB;IACtC,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;CAClB;AAID,wBAAgB,kBAAkB,CAAC,EACjC,UAAU,EACV,aAAa,EACb,OAAO,GACR,EAAE,uBAAuB,kDA2CzB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
const MAX_VISIBLE = 8;
|
|
4
|
+
export function CompletionDropdown({ candidates, selectedIndex, visible, }) {
|
|
5
|
+
if (!visible || candidates.length === 0)
|
|
6
|
+
return null;
|
|
7
|
+
// Window the list if there are too many candidates
|
|
8
|
+
let startIdx = 0;
|
|
9
|
+
if (candidates.length > MAX_VISIBLE) {
|
|
10
|
+
startIdx = Math.max(0, selectedIndex - Math.floor(MAX_VISIBLE / 2));
|
|
11
|
+
startIdx = Math.min(startIdx, candidates.length - MAX_VISIBLE);
|
|
12
|
+
}
|
|
13
|
+
const visibleCandidates = candidates.slice(startIdx, startIdx + MAX_VISIBLE);
|
|
14
|
+
return (_jsxs(Box, { flexDirection: "column", marginLeft: 4, children: [_jsx(Box, { children: _jsx(Text, { dimColor: true, children: "┌─ completions ─" }) }), visibleCandidates.map((candidate, i) => {
|
|
15
|
+
const actualIdx = startIdx + i;
|
|
16
|
+
const isSelected = actualIdx === selectedIndex;
|
|
17
|
+
return (_jsxs(Box, { children: [_jsx(Text, { dimColor: true, children: "│" }), _jsxs(Text, { color: isSelected ? "cyan" : "white", bold: isSelected, children: [isSelected ? " ▸ " : " ", candidate] })] }, candidate));
|
|
18
|
+
}), _jsxs(Box, { children: [_jsx(Text, { dimColor: true, children: "└─" }), candidates.length > MAX_VISIBLE && (_jsxs(Text, { dimColor: true, children: [" ", "(", candidates.length, " total)"] }))] })] }));
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=CompletionDropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CompletionDropdown.js","sourceRoot":"","sources":["../../../src/tui/components/CompletionDropdown.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAQhC,MAAM,WAAW,GAAG,CAAC,CAAC;AAEtB,MAAM,UAAU,kBAAkB,CAAC,EACjC,UAAU,EACV,aAAa,EACb,OAAO,GACiB;IACxB,IAAI,CAAC,OAAO,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAErD,mDAAmD;IACnD,IAAI,QAAQ,GAAG,CAAC,CAAC;IACjB,IAAI,UAAU,CAAC,MAAM,GAAG,WAAW,EAAE,CAAC;QACpC,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC;QACpE,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,CAAC;IACjE,CAAC;IACD,MAAM,iBAAiB,GAAG,UAAU,CAAC,KAAK,CACxC,QAAQ,EACR,QAAQ,GAAG,WAAW,CACvB,CAAC;IAEF,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,UAAU,EAAE,CAAC,aACvC,KAAC,GAAG,cACF,KAAC,IAAI,IAAC,QAAQ,kBAAE,kBAAkB,GAAQ,GACtC,EACL,iBAAiB,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;gBACtC,MAAM,SAAS,GAAG,QAAQ,GAAG,CAAC,CAAC;gBAC/B,MAAM,UAAU,GAAG,SAAS,KAAK,aAAa,CAAC;gBAC/C,OAAO,CACL,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,QAAQ,kBAAE,GAAG,GAAQ,EAC3B,MAAC,IAAI,IAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,UAAU,aACzD,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,EAC1B,SAAS,IACL,KALC,SAAS,CAMb,CACP,CAAC;YACJ,CAAC,CAAC,EACF,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,QAAQ,kBAAE,IAAI,GAAQ,EAC3B,UAAU,CAAC,MAAM,GAAG,WAAW,IAAI,CAClC,MAAC,IAAI,IAAC,QAAQ,mBACX,GAAG,OACF,UAAU,CAAC,MAAM,eACd,CACR,IACG,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export interface ConfirmPromptProps {
|
|
2
|
+
message: string;
|
|
3
|
+
onConfirm: () => void;
|
|
4
|
+
onCancel: () => void;
|
|
5
|
+
confirmLabel?: string;
|
|
6
|
+
cancelLabel?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function ConfirmPrompt({ message, onConfirm, onCancel, confirmLabel, cancelLabel, }: ConfirmPromptProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=ConfirmPrompt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConfirmPrompt.d.ts","sourceRoot":"","sources":["../../../src/tui/components/ConfirmPrompt.tsx"],"names":[],"mappings":"AAIA,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,wBAAgB,aAAa,CAAC,EAC5B,OAAO,EACP,SAAS,EACT,QAAQ,EACR,YAAwB,EACxB,WAAsB,GACvB,EAAE,kBAAkB,2CAiBpB"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
import { Button } from "./Button.js";
|
|
4
|
+
export function ConfirmPrompt({ message, onConfirm, onCancel, confirmLabel = "Confirm", cancelLabel = "Cancel", }) {
|
|
5
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { marginBottom: 1, children: _jsxs(Text, { bold: true, color: "cyan", children: ["\u25C8 ", message] }) }), _jsxs(Box, { gap: 2, children: [_jsx(Button, { label: confirmLabel, onPress: onConfirm, variant: "primary" }), _jsx(Button, { label: cancelLabel, onPress: onCancel, variant: "dim" })] }), _jsx(Box, { marginTop: 1, children: _jsx(Text, { dimColor: true, children: "Tab to switch \u00B7 Enter to select" }) })] }));
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=ConfirmPrompt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConfirmPrompt.js","sourceRoot":"","sources":["../../../src/tui/components/ConfirmPrompt.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAUrC,MAAM,UAAU,aAAa,CAAC,EAC5B,OAAO,EACP,SAAS,EACT,QAAQ,EACR,YAAY,GAAG,SAAS,EACxB,WAAW,GAAG,QAAQ,GACH;IACnB,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aACzB,KAAC,GAAG,IAAC,YAAY,EAAE,CAAC,YAClB,MAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,MAAM,wBAClB,OAAO,IACL,GACH,EACN,MAAC,GAAG,IAAC,GAAG,EAAE,CAAC,aACT,KAAC,MAAM,IAAC,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAC,SAAS,GAAG,EACrE,KAAC,MAAM,IAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAC,KAAK,GAAG,IAC3D,EACN,KAAC,GAAG,IAAC,SAAS,EAAE,CAAC,YACf,KAAC,IAAI,IAAC,QAAQ,2DAAuC,GACjD,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface Column {
|
|
2
|
+
header: string;
|
|
3
|
+
key: string;
|
|
4
|
+
width?: number;
|
|
5
|
+
align?: "left" | "right";
|
|
6
|
+
}
|
|
7
|
+
export interface InteractiveTableProps {
|
|
8
|
+
columns: Column[];
|
|
9
|
+
rows: Record<string, string>[];
|
|
10
|
+
onSelect?: (row: Record<string, string>, index: number) => void;
|
|
11
|
+
selectedIndex?: number;
|
|
12
|
+
}
|
|
13
|
+
export declare function InteractiveTable({ columns, rows, onSelect, selectedIndex: controlledIdx, }: InteractiveTableProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
//# sourceMappingURL=InteractiveTable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InteractiveTable.d.ts","sourceRoot":"","sources":["../../../src/tui/components/InteractiveTable.tsx"],"names":[],"mappings":"AAGA,MAAM,WAAW,MAAM;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B;AAED,MAAM,WAAW,qBAAqB;IACpC,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;IAC/B,QAAQ,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAChE,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAID,wBAAgB,gBAAgB,CAAC,EAC/B,OAAO,EACP,IAAI,EACJ,QAAQ,EACR,aAAa,EAAE,aAAa,GAC7B,EAAE,qBAAqB,2CAuFvB"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from "react";
|
|
3
|
+
import { Box, Text, useInput } from "ink";
|
|
4
|
+
const MAX_VISIBLE_ROWS = 15;
|
|
5
|
+
export function InteractiveTable({ columns, rows, onSelect, selectedIndex: controlledIdx, }) {
|
|
6
|
+
const [internalIdx, setInternalIdx] = useState(0);
|
|
7
|
+
const selectedIndex = controlledIdx ?? internalIdx;
|
|
8
|
+
useInput((_input, key) => {
|
|
9
|
+
if (key.upArrow) {
|
|
10
|
+
setInternalIdx((i) => Math.max(0, i - 1));
|
|
11
|
+
}
|
|
12
|
+
if (key.downArrow) {
|
|
13
|
+
setInternalIdx((i) => Math.min(rows.length - 1, i + 1));
|
|
14
|
+
}
|
|
15
|
+
if (key.return && onSelect && rows[selectedIndex]) {
|
|
16
|
+
onSelect(rows[selectedIndex], selectedIndex);
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
// Compute column widths
|
|
20
|
+
const colWidths = columns.map((col) => {
|
|
21
|
+
if (col.width)
|
|
22
|
+
return col.width;
|
|
23
|
+
let max = col.header.length;
|
|
24
|
+
for (const row of rows) {
|
|
25
|
+
const val = row[col.key] ?? "";
|
|
26
|
+
if (val.length > max)
|
|
27
|
+
max = val.length;
|
|
28
|
+
}
|
|
29
|
+
return Math.min(max + 2, 30);
|
|
30
|
+
});
|
|
31
|
+
const pad = (text, width, align = "left") => {
|
|
32
|
+
const truncated = text.length > width ? text.slice(0, width - 1) + "…" : text;
|
|
33
|
+
if (align === "right")
|
|
34
|
+
return truncated.padStart(width);
|
|
35
|
+
return truncated.padEnd(width);
|
|
36
|
+
};
|
|
37
|
+
// Window visible rows
|
|
38
|
+
let startRow = 0;
|
|
39
|
+
if (rows.length > MAX_VISIBLE_ROWS) {
|
|
40
|
+
startRow = Math.max(0, selectedIndex - Math.floor(MAX_VISIBLE_ROWS / 2));
|
|
41
|
+
startRow = Math.min(startRow, rows.length - MAX_VISIBLE_ROWS);
|
|
42
|
+
}
|
|
43
|
+
const visibleRows = rows.slice(startRow, startRow + MAX_VISIBLE_ROWS);
|
|
44
|
+
// Header
|
|
45
|
+
const headerLine = columns
|
|
46
|
+
.map((col, i) => pad(col.header, colWidths[i], col.align))
|
|
47
|
+
.join(" ");
|
|
48
|
+
const separatorLine = "─".repeat(headerLine.length);
|
|
49
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { children: _jsxs(Text, { bold: true, color: "white", children: [" ", headerLine] }) }), _jsx(Box, { children: _jsxs(Text, { dimColor: true, children: [" ", separatorLine] }) }), visibleRows.map((row, vi) => {
|
|
50
|
+
const actualIdx = startRow + vi;
|
|
51
|
+
const isSelected = actualIdx === selectedIndex;
|
|
52
|
+
const line = columns
|
|
53
|
+
.map((col, i) => pad(row[col.key] ?? "", colWidths[i], col.align))
|
|
54
|
+
.join(" ");
|
|
55
|
+
return (_jsx(Box, { children: _jsxs(Text, { color: isSelected ? "cyan" : "white", bold: isSelected, children: [isSelected ? "▸" : " ", " ", line] }) }, actualIdx));
|
|
56
|
+
}), rows.length > MAX_VISIBLE_ROWS && (_jsx(Box, { children: _jsxs(Text, { dimColor: true, children: [" ", "(", rows.length, " rows \u00B7 \u2191\u2193 navigate \u00B7 Enter select)"] }) })), rows.length <= MAX_VISIBLE_ROWS && rows.length > 0 && (_jsx(Box, { children: _jsx(Text, { dimColor: true, children: " (\u2191\u2193 navigate \u00B7 Enter select)" }) }))] }));
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=InteractiveTable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InteractiveTable.js","sourceRoot":"","sources":["../../../src/tui/components/InteractiveTable.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export type StepStatus = "pending" | "running" | "done" | "error";
|
|
2
|
+
export interface StepSpinnerProps {
|
|
3
|
+
step: number;
|
|
4
|
+
total: number;
|
|
5
|
+
label: string;
|
|
6
|
+
status: StepStatus;
|
|
7
|
+
detail?: string;
|
|
8
|
+
error?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare function StepSpinner({ step, total, label, status, detail, error, }: StepSpinnerProps): import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
//# sourceMappingURL=StepSpinner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StepSpinner.d.ts","sourceRoot":"","sources":["../../../src/tui/components/StepSpinner.tsx"],"names":[],"mappings":"AAMA,MAAM,MAAM,UAAU,GAAG,SAAS,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC;AAElE,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,UAAU,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,WAAW,CAAC,EAC1B,IAAI,EACJ,KAAK,EACL,KAAK,EACL,MAAM,EACN,MAAM,EACN,KAAK,GACN,EAAE,gBAAgB,2CA2DlB"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect } from "react";
|
|
3
|
+
import { Box, Text } from "ink";
|
|
4
|
+
const SPINNER_FRAMES = ["◈", "◇", "◆", "◇"];
|
|
5
|
+
const SPINNER_INTERVAL = 120;
|
|
6
|
+
export function StepSpinner({ step, total, label, status, detail, error, }) {
|
|
7
|
+
const [frame, setFrame] = useState(0);
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
if (status !== "running")
|
|
10
|
+
return;
|
|
11
|
+
const timer = setInterval(() => {
|
|
12
|
+
setFrame((f) => (f + 1) % SPINNER_FRAMES.length);
|
|
13
|
+
}, SPINNER_INTERVAL);
|
|
14
|
+
return () => clearInterval(timer);
|
|
15
|
+
}, [status]);
|
|
16
|
+
const prefix = `Step ${step}/${total}`;
|
|
17
|
+
if (status === "pending") {
|
|
18
|
+
return (_jsx(Box, { children: _jsxs(Text, { dimColor: true, children: [" ", prefix, " \u2014 ", label] }) }));
|
|
19
|
+
}
|
|
20
|
+
if (status === "running") {
|
|
21
|
+
return (_jsx(Box, { flexDirection: "column", children: _jsx(Box, { children: _jsxs(Text, { color: "cyan", children: [" ", SPINNER_FRAMES[frame], " ", prefix, " \u2014 ", label, "..."] }) }) }));
|
|
22
|
+
}
|
|
23
|
+
if (status === "done") {
|
|
24
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { children: _jsxs(Text, { color: "green", children: [" \u2713 ", prefix, " \u2014 ", label] }) }), detail && (_jsx(Box, { children: _jsxs(Text, { dimColor: true, children: [" \u2514 ", detail] }) }))] }));
|
|
25
|
+
}
|
|
26
|
+
// error
|
|
27
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { children: _jsxs(Text, { color: "red", children: [" \u2717 ", prefix, " \u2014 ", label] }) }), error && (_jsx(Box, { children: _jsxs(Text, { color: "red", children: [" \u2514 ", error] }) }))] }));
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=StepSpinner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StepSpinner.js","sourceRoot":"","sources":["../../../src/tui/components/StepSpinner.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAEhC,MAAM,cAAc,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AAC5C,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAa7B,MAAM,UAAU,WAAW,CAAC,EAC1B,IAAI,EACJ,KAAK,EACL,KAAK,EACL,MAAM,EACN,MAAM,EACN,KAAK,GACY;IACjB,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAEtC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,MAAM,KAAK,SAAS;YAAE,OAAO;QACjC,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;YAC7B,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;QACnD,CAAC,EAAE,gBAAgB,CAAC,CAAC;QACrB,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,MAAM,MAAM,GAAG,QAAQ,IAAI,IAAI,KAAK,EAAE,CAAC;IAEvC,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;QACzB,OAAO,CACL,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,QAAQ,yBAAI,MAAM,cAAK,KAAK,IAAQ,GACtC,CACP,CAAC;IACJ,CAAC;IAED,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;QACzB,OAAO,CACL,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,YACzB,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,kBAAG,cAAc,CAAC,KAAK,CAAC,OAAG,MAAM,cAAK,KAAK,WAAW,GACpE,GACF,CACP,CAAC;IACJ,CAAC;IAED,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aACzB,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,KAAK,EAAC,OAAO,yBAAK,MAAM,cAAK,KAAK,IAAQ,GAC5C,EACL,MAAM,IAAI,CACT,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,QAAQ,iCAAO,MAAM,IAAQ,GAC/B,CACP,IACG,CACP,CAAC;IACJ,CAAC;IAED,QAAQ;IACR,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aACzB,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,KAAK,EAAC,KAAK,yBAAK,MAAM,cAAK,KAAK,IAAQ,GAC1C,EACL,KAAK,IAAI,CACR,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,KAAK,EAAC,KAAK,2BAAO,KAAK,IAAQ,GACjC,CACP,IACG,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export type ToastVariant = "info" | "success" | "warning" | "error";
|
|
2
|
+
export interface ToastData {
|
|
3
|
+
id: string;
|
|
4
|
+
message: string;
|
|
5
|
+
variant: ToastVariant;
|
|
6
|
+
duration?: number;
|
|
7
|
+
}
|
|
8
|
+
export interface ToastProps {
|
|
9
|
+
toast: ToastData;
|
|
10
|
+
onDismiss: (id: string) => void;
|
|
11
|
+
}
|
|
12
|
+
export declare function Toast({ toast, onDismiss }: ToastProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export interface ToastContainerProps {
|
|
14
|
+
toasts: ToastData[];
|
|
15
|
+
onDismiss: (id: string) => void;
|
|
16
|
+
}
|
|
17
|
+
export declare function ToastContainer({ toasts, onDismiss }: ToastContainerProps): import("react/jsx-runtime").JSX.Element | null;
|
|
18
|
+
//# sourceMappingURL=Toast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Toast.d.ts","sourceRoot":"","sources":["../../../src/tui/components/Toast.tsx"],"names":[],"mappings":"AAGA,MAAM,MAAM,YAAY,GAAG,MAAM,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,CAAC;AAEpE,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,YAAY,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,UAAU;IACzB,KAAK,EAAE,SAAS,CAAC;IACjB,SAAS,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;CACjC;AASD,wBAAgB,KAAK,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,UAAU,2CAiBrD;AAED,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,SAAS,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;CACjC;AAED,wBAAgB,cAAc,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,mBAAmB,kDAUxE"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect } from "react";
|
|
3
|
+
import { Box, Text } from "ink";
|
|
4
|
+
const VARIANT_CONFIG = {
|
|
5
|
+
info: { icon: "◈", color: "cyan" },
|
|
6
|
+
success: { icon: "✓", color: "green" },
|
|
7
|
+
warning: { icon: "⚠", color: "yellow" },
|
|
8
|
+
error: { icon: "✗", color: "red" },
|
|
9
|
+
};
|
|
10
|
+
export function Toast({ toast, onDismiss }) {
|
|
11
|
+
const { icon, color } = VARIANT_CONFIG[toast.variant];
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
const timer = setTimeout(() => {
|
|
14
|
+
onDismiss(toast.id);
|
|
15
|
+
}, toast.duration ?? 5000);
|
|
16
|
+
return () => clearTimeout(timer);
|
|
17
|
+
}, [toast.id, toast.duration, onDismiss]);
|
|
18
|
+
return (_jsx(Box, { children: _jsxs(Text, { color: color, children: [icon, " ", toast.message] }) }));
|
|
19
|
+
}
|
|
20
|
+
export function ToastContainer({ toasts, onDismiss }) {
|
|
21
|
+
if (toasts.length === 0)
|
|
22
|
+
return null;
|
|
23
|
+
return (_jsx(Box, { flexDirection: "column", children: toasts.map((toast) => (_jsx(Toast, { toast: toast, onDismiss: onDismiss }, toast.id))) }));
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=Toast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Toast.js","sourceRoot":"","sources":["../../../src/tui/components/Toast.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAgBhC,MAAM,cAAc,GAA0D;IAC5E,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE;IAClC,OAAO,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE;IACtC,OAAO,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE;IACvC,KAAK,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE;CACnC,CAAC;AAEF,MAAM,UAAU,KAAK,CAAC,EAAE,KAAK,EAAE,SAAS,EAAc;IACpD,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAEtD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACtB,CAAC,EAAE,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC;QAC3B,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;IAE1C,OAAO,CACL,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,KAAK,EAAE,KAAK,aACf,IAAI,OAAG,KAAK,CAAC,OAAO,IAChB,GACH,CACP,CAAC;AACJ,CAAC;AAOD,MAAM,UAAU,cAAc,CAAC,EAAE,MAAM,EAAE,SAAS,EAAuB;IACvE,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAErC,OAAO,CACL,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,YACxB,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CACrB,KAAC,KAAK,IAAgB,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,IAA5C,KAAK,CAAC,EAAE,CAAwC,CAC7D,CAAC,GACE,CACP,CAAC;AACJ,CAAC"}
|
package/dist/tui/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tui/index.tsx"],"names":[],"mappings":"AA8CA,wBAAsB,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tui/index.tsx"],"names":[],"mappings":"AA8CA,wBAAsB,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC,CA2C/C"}
|
package/dist/tui/index.js
CHANGED
|
@@ -42,7 +42,21 @@ export async function launchTUI() {
|
|
|
42
42
|
if (config.rpcUrl && config.walletContractAddress) {
|
|
43
43
|
balance = await getBalance(config.rpcUrl, config.walletContractAddress);
|
|
44
44
|
}
|
|
45
|
-
|
|
45
|
+
// Enter alternate screen buffer (full-screen mode)
|
|
46
|
+
process.stdout.write("\x1b[?1049h");
|
|
47
|
+
// Hide cursor initially — Ink manages it
|
|
48
|
+
process.stdout.write("\x1b[?25l");
|
|
49
|
+
const restore = () => {
|
|
50
|
+
process.stdout.write("\x1b[?25h"); // show cursor
|
|
51
|
+
process.stdout.write("\x1b[?1049l"); // leave alternate buffer
|
|
52
|
+
};
|
|
53
|
+
// Ensure restore on unexpected exit
|
|
54
|
+
process.on("exit", restore);
|
|
55
|
+
process.on("SIGINT", restore);
|
|
56
|
+
process.on("SIGTERM", restore);
|
|
57
|
+
const { waitUntilExit } = render(_jsx(App, { version: pkg.version, network: config.network, wallet: walletDisplay, balance: balance }), { exitOnCtrlC: true });
|
|
46
58
|
await waitUntilExit();
|
|
59
|
+
// Clean restore
|
|
60
|
+
restore();
|
|
47
61
|
}
|
|
48
62
|
//# sourceMappingURL=index.js.map
|