@gzeoneth/gov-tracker 0.2.1-beta.03fa52b → 0.2.1-beta.11b2e86
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +18 -18
- package/dist/cli/cli.js +32 -0
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/tui/App.d.ts +11 -0
- package/dist/cli/tui/App.d.ts.map +1 -0
- package/dist/cli/tui/App.js +123 -0
- package/dist/cli/tui/App.js.map +1 -0
- package/dist/cli/tui/components/CopyableText.d.ts +23 -0
- package/dist/cli/tui/components/CopyableText.d.ts.map +1 -0
- package/dist/cli/tui/components/CopyableText.js +49 -0
- package/dist/cli/tui/components/CopyableText.js.map +1 -0
- package/dist/cli/tui/components/Header.d.ts +20 -0
- package/dist/cli/tui/components/Header.d.ts.map +1 -0
- package/dist/cli/tui/components/Header.js +47 -0
- package/dist/cli/tui/components/Header.js.map +1 -0
- package/dist/cli/tui/components/KeyHelp.d.ts +19 -0
- package/dist/cli/tui/components/KeyHelp.d.ts.map +1 -0
- package/dist/cli/tui/components/KeyHelp.js +60 -0
- package/dist/cli/tui/components/KeyHelp.js.map +1 -0
- package/dist/cli/tui/components/ProposalRow.d.ts +11 -0
- package/dist/cli/tui/components/ProposalRow.d.ts.map +1 -0
- package/dist/cli/tui/components/ProposalRow.js +92 -0
- package/dist/cli/tui/components/ProposalRow.js.map +1 -0
- package/dist/cli/tui/components/ScrollIndicator.d.ts +19 -0
- package/dist/cli/tui/components/ScrollIndicator.d.ts.map +1 -0
- package/dist/cli/tui/components/ScrollIndicator.js +50 -0
- package/dist/cli/tui/components/ScrollIndicator.js.map +1 -0
- package/dist/cli/tui/components/SearchBar.d.ts +12 -0
- package/dist/cli/tui/components/SearchBar.d.ts.map +1 -0
- package/dist/cli/tui/components/SearchBar.js +36 -0
- package/dist/cli/tui/components/SearchBar.js.map +1 -0
- package/dist/cli/tui/components/Spinner.d.ts +10 -0
- package/dist/cli/tui/components/Spinner.d.ts.map +1 -0
- package/dist/cli/tui/components/Spinner.js +24 -0
- package/dist/cli/tui/components/Spinner.js.map +1 -0
- package/dist/cli/tui/components/StageProgress.d.ts +12 -0
- package/dist/cli/tui/components/StageProgress.d.ts.map +1 -0
- package/dist/cli/tui/components/StageProgress.js +41 -0
- package/dist/cli/tui/components/StageProgress.js.map +1 -0
- package/dist/cli/tui/components/StageRow.d.ts +12 -0
- package/dist/cli/tui/components/StageRow.d.ts.map +1 -0
- package/dist/cli/tui/components/StageRow.js +80 -0
- package/dist/cli/tui/components/StageRow.js.map +1 -0
- package/dist/cli/tui/components/StatusBadge.d.ts +12 -0
- package/dist/cli/tui/components/StatusBadge.d.ts.map +1 -0
- package/dist/cli/tui/components/StatusBadge.js +27 -0
- package/dist/cli/tui/components/StatusBadge.js.map +1 -0
- package/dist/cli/tui/components/ViewLayout.d.ts +22 -0
- package/dist/cli/tui/components/ViewLayout.d.ts.map +1 -0
- package/dist/cli/tui/components/ViewLayout.js +24 -0
- package/dist/cli/tui/components/ViewLayout.js.map +1 -0
- package/dist/cli/tui/components/VotingStats.d.ts +11 -0
- package/dist/cli/tui/components/VotingStats.d.ts.map +1 -0
- package/dist/cli/tui/components/VotingStats.js +87 -0
- package/dist/cli/tui/components/VotingStats.js.map +1 -0
- package/dist/cli/tui/hooks/index.d.ts +11 -0
- package/dist/cli/tui/hooks/index.d.ts.map +1 -0
- package/dist/cli/tui/hooks/index.js +18 -0
- package/dist/cli/tui/hooks/index.js.map +1 -0
- package/dist/cli/tui/hooks/useCache.d.ts +12 -0
- package/dist/cli/tui/hooks/useCache.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useCache.js +52 -0
- package/dist/cli/tui/hooks/useCache.js.map +1 -0
- package/dist/cli/tui/hooks/useElectionData.d.ts +22 -0
- package/dist/cli/tui/hooks/useElectionData.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useElectionData.js +133 -0
- package/dist/cli/tui/hooks/useElectionData.js.map +1 -0
- package/dist/cli/tui/hooks/useNavigation.d.ts +39 -0
- package/dist/cli/tui/hooks/useNavigation.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useNavigation.js +173 -0
- package/dist/cli/tui/hooks/useNavigation.js.map +1 -0
- package/dist/cli/tui/hooks/useProposals.d.ts +10 -0
- package/dist/cli/tui/hooks/useProposals.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useProposals.js +201 -0
- package/dist/cli/tui/hooks/useProposals.js.map +1 -0
- package/dist/cli/tui/hooks/useScrollableInput.d.ts +14 -0
- package/dist/cli/tui/hooks/useScrollableInput.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useScrollableInput.js +44 -0
- package/dist/cli/tui/hooks/useScrollableInput.js.map +1 -0
- package/dist/cli/tui/hooks/useStageCalldata.d.ts +17 -0
- package/dist/cli/tui/hooks/useStageCalldata.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useStageCalldata.js +77 -0
- package/dist/cli/tui/hooks/useStageCalldata.js.map +1 -0
- package/dist/cli/tui/index.d.ts +13 -0
- package/dist/cli/tui/index.d.ts.map +1 -0
- package/dist/cli/tui/index.js +96 -0
- package/dist/cli/tui/index.js.map +1 -0
- package/dist/cli/tui/ink-wrapper.d.ts +43 -0
- package/dist/cli/tui/ink-wrapper.d.ts.map +1 -0
- package/dist/cli/tui/ink-wrapper.js +41 -0
- package/dist/cli/tui/ink-wrapper.js.map +1 -0
- package/dist/cli/tui/types.d.ts +38 -0
- package/dist/cli/tui/types.d.ts.map +1 -0
- package/dist/cli/tui/types.js +6 -0
- package/dist/cli/tui/types.js.map +1 -0
- package/dist/cli/tui/utils/calldata-formatter.d.ts +7 -0
- package/dist/cli/tui/utils/calldata-formatter.d.ts.map +1 -0
- package/dist/cli/tui/utils/calldata-formatter.js +14 -0
- package/dist/cli/tui/utils/calldata-formatter.js.map +1 -0
- package/dist/cli/tui/utils/clipboard.d.ts +7 -0
- package/dist/cli/tui/utils/clipboard.d.ts.map +1 -0
- package/dist/cli/tui/utils/clipboard.js +46 -0
- package/dist/cli/tui/utils/clipboard.js.map +1 -0
- package/dist/cli/tui/utils/index.d.ts +16 -0
- package/dist/cli/tui/utils/index.d.ts.map +1 -0
- package/dist/cli/tui/utils/index.js +52 -0
- package/dist/cli/tui/utils/index.js.map +1 -0
- package/dist/cli/tui/utils/markdown-parser.d.ts +11 -0
- package/dist/cli/tui/utils/markdown-parser.d.ts.map +1 -0
- package/dist/cli/tui/utils/markdown-parser.js +77 -0
- package/dist/cli/tui/utils/markdown-parser.js.map +1 -0
- package/dist/cli/tui/utils/navigation.d.ts +17 -0
- package/dist/cli/tui/utils/navigation.d.ts.map +1 -0
- package/dist/cli/tui/utils/navigation.js +75 -0
- package/dist/cli/tui/utils/navigation.js.map +1 -0
- package/dist/cli/tui/utils/proposal-detail-helpers.d.ts +9 -0
- package/dist/cli/tui/utils/proposal-detail-helpers.d.ts.map +1 -0
- package/dist/cli/tui/utils/proposal-detail-helpers.js +21 -0
- package/dist/cli/tui/utils/proposal-detail-helpers.js.map +1 -0
- package/dist/cli/tui/utils/shortcuts.d.ts +17 -0
- package/dist/cli/tui/utils/shortcuts.d.ts.map +1 -0
- package/dist/cli/tui/utils/shortcuts.js +100 -0
- package/dist/cli/tui/utils/shortcuts.js.map +1 -0
- package/dist/cli/tui/utils/stage-formatter.d.ts +7 -0
- package/dist/cli/tui/utils/stage-formatter.d.ts.map +1 -0
- package/dist/cli/tui/utils/stage-formatter.js +14 -0
- package/dist/cli/tui/utils/stage-formatter.js.map +1 -0
- package/dist/cli/tui/utils/stage-status.d.ts +10 -0
- package/dist/cli/tui/utils/stage-status.d.ts.map +1 -0
- package/dist/cli/tui/utils/stage-status.js +64 -0
- package/dist/cli/tui/utils/stage-status.js.map +1 -0
- package/dist/cli/tui/utils/terminal.d.ts +18 -0
- package/dist/cli/tui/utils/terminal.d.ts.map +1 -0
- package/dist/cli/tui/utils/terminal.js +26 -0
- package/dist/cli/tui/utils/terminal.js.map +1 -0
- package/dist/cli/tui/utils/text.d.ts +7 -0
- package/dist/cli/tui/utils/text.d.ts.map +1 -0
- package/dist/cli/tui/utils/text.js +12 -0
- package/dist/cli/tui/utils/text.js.map +1 -0
- package/dist/cli/tui/utils/time.d.ts +19 -0
- package/dist/cli/tui/utils/time.d.ts.map +1 -0
- package/dist/cli/tui/utils/time.js +43 -0
- package/dist/cli/tui/utils/time.js.map +1 -0
- package/dist/cli/tui/views/CalldataView.d.ts +12 -0
- package/dist/cli/tui/views/CalldataView.d.ts.map +1 -0
- package/dist/cli/tui/views/CalldataView.js +110 -0
- package/dist/cli/tui/views/CalldataView.js.map +1 -0
- package/dist/cli/tui/views/DescriptionView.d.ts +12 -0
- package/dist/cli/tui/views/DescriptionView.d.ts.map +1 -0
- package/dist/cli/tui/views/DescriptionView.js +75 -0
- package/dist/cli/tui/views/DescriptionView.js.map +1 -0
- package/dist/cli/tui/views/ElectionView.d.ts +11 -0
- package/dist/cli/tui/views/ElectionView.d.ts.map +1 -0
- package/dist/cli/tui/views/ElectionView.js +193 -0
- package/dist/cli/tui/views/ElectionView.js.map +1 -0
- package/dist/cli/tui/views/HelpView.d.ts +10 -0
- package/dist/cli/tui/views/HelpView.d.ts.map +1 -0
- package/dist/cli/tui/views/HelpView.js +75 -0
- package/dist/cli/tui/views/HelpView.js.map +1 -0
- package/dist/cli/tui/views/ProposalDetail.d.ts +12 -0
- package/dist/cli/tui/views/ProposalDetail.d.ts.map +1 -0
- package/dist/cli/tui/views/ProposalDetail.js +103 -0
- package/dist/cli/tui/views/ProposalDetail.js.map +1 -0
- package/dist/cli/tui/views/ProposalList.d.ts +15 -0
- package/dist/cli/tui/views/ProposalList.d.ts.map +1 -0
- package/dist/cli/tui/views/ProposalList.js +154 -0
- package/dist/cli/tui/views/ProposalList.js.map +1 -0
- package/dist/cli/tui/views/SimulationView.d.ts +12 -0
- package/dist/cli/tui/views/SimulationView.d.ts.map +1 -0
- package/dist/cli/tui/views/SimulationView.js +110 -0
- package/dist/cli/tui/views/SimulationView.js.map +1 -0
- package/dist/cli/tui/views/StageView.d.ts +12 -0
- package/dist/cli/tui/views/StageView.d.ts.map +1 -0
- package/dist/cli/tui/views/StageView.js +109 -0
- package/dist/cli/tui/views/StageView.js.map +1 -0
- package/dist/cli/tui/views/registry.d.ts +18 -0
- package/dist/cli/tui/views/registry.d.ts.map +1 -0
- package/dist/cli/tui/views/registry.js +34 -0
- package/dist/cli/tui/views/registry.js.map +1 -0
- package/dist/constants.d.ts +14 -9
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +16 -11
- package/dist/constants.js.map +1 -1
- package/dist/data/bundled-cache.json +225 -225
- package/dist/election/status.d.ts.map +1 -1
- package/dist/election/status.js +4 -1
- package/dist/election/status.js.map +1 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/tracker/checkpoint-helpers.d.ts +0 -1
- package/dist/tracker/checkpoint-helpers.d.ts.map +1 -1
- package/dist/tracker/checkpoint-helpers.js +1 -2
- package/dist/tracker/checkpoint-helpers.js.map +1 -1
- package/dist/types/election.d.ts +1 -1
- package/dist/types/election.d.ts.map +1 -1
- package/dist/utils/rpc-utils.d.ts.map +1 -1
- package/dist/utils/rpc-utils.js +2 -1
- package/dist/utils/rpc-utils.js.map +1 -1
- package/package.json +6 -2
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Keyboard shortcuts help footer (cache-only mode)
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.KeyHelp = KeyHelp;
|
|
7
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
8
|
+
const shortcuts_js_1 = require("../utils/shortcuts.js");
|
|
9
|
+
const index_js_1 = require("../utils/index.js");
|
|
10
|
+
function ContextIndicators({ view, context }) {
|
|
11
|
+
if (view !== "list" || !context)
|
|
12
|
+
return null;
|
|
13
|
+
const indicators = [];
|
|
14
|
+
if (context.isSearching) {
|
|
15
|
+
indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { key: "search", color: "yellow" }, "[SEARCHING] "));
|
|
16
|
+
}
|
|
17
|
+
else if (context.hasSearch) {
|
|
18
|
+
indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: "search-active", marginRight: 1 },
|
|
19
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, "\u26B2 "),
|
|
20
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "Esc:Clear")));
|
|
21
|
+
}
|
|
22
|
+
if (context.filter && context.filter !== "all") {
|
|
23
|
+
indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: "filter", marginRight: 1 },
|
|
24
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "magenta" }, context.filter.toUpperCase())));
|
|
25
|
+
}
|
|
26
|
+
if (context.sort && context.sort !== "newest") {
|
|
27
|
+
indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: "sort", marginRight: 1 },
|
|
28
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "blue" },
|
|
29
|
+
"\u2195",
|
|
30
|
+
index_js_1.SORT_LABELS[context.sort])));
|
|
31
|
+
}
|
|
32
|
+
if (indicators.length === 0)
|
|
33
|
+
return null;
|
|
34
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginRight: 2 },
|
|
35
|
+
indicators,
|
|
36
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2502")));
|
|
37
|
+
}
|
|
38
|
+
function CalldataIndicator({ context }) {
|
|
39
|
+
if (!context?.calldataActionCount || context.calldataActionCount <= 1)
|
|
40
|
+
return null;
|
|
41
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginRight: 2 },
|
|
42
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" },
|
|
43
|
+
"Action ",
|
|
44
|
+
(context.currentActionIndex ?? 0) + 1,
|
|
45
|
+
"/",
|
|
46
|
+
context.calldataActionCount),
|
|
47
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " \u2502")));
|
|
48
|
+
}
|
|
49
|
+
function KeyHelp({ view, context }) {
|
|
50
|
+
const shortcuts = (0, shortcuts_js_1.getShortcutsForView)(view);
|
|
51
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { borderStyle: "single", borderColor: "gray", paddingX: 1 },
|
|
52
|
+
ink_wrapper_js_1.React.createElement(ContextIndicators, { view: view, context: context }),
|
|
53
|
+
view === "calldata" && ink_wrapper_js_1.React.createElement(CalldataIndicator, { context: context }),
|
|
54
|
+
shortcuts.map((s) => (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: s.key, marginRight: 2 },
|
|
55
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, s.key),
|
|
56
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
|
|
57
|
+
": ",
|
|
58
|
+
s.action))))));
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=KeyHelp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KeyHelp.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/KeyHelp.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Single proposal row in the list view
|
|
3
|
+
*/
|
|
4
|
+
import type { ProposalListItem } from "../types.js";
|
|
5
|
+
interface ProposalRowProps {
|
|
6
|
+
item: ProposalListItem;
|
|
7
|
+
isSelected: boolean;
|
|
8
|
+
}
|
|
9
|
+
export declare function ProposalRow({ item, isSelected }: ProposalRowProps): React.ReactElement;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=ProposalRow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProposalRow.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/ProposalRow.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAIpD,UAAU,gBAAgB;IACxB,IAAI,EAAE,gBAAgB,CAAC;IACvB,UAAU,EAAE,OAAO,CAAC;CACrB;AAyCD,wBAAgB,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,gBAAgB,GAAG,KAAK,CAAC,YAAY,CA2CtF"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Single proposal row in the list view
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ProposalRow = ProposalRow;
|
|
7
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
8
|
+
const StatusBadge_js_1 = require("./StatusBadge.js");
|
|
9
|
+
const index_js_1 = require("../utils/index.js");
|
|
10
|
+
function getTypeLabel(item) {
|
|
11
|
+
if (item.type === "election")
|
|
12
|
+
return "EL";
|
|
13
|
+
if (item.type === "timelock")
|
|
14
|
+
return "TL";
|
|
15
|
+
if (item.proposalType === "CONSTITUTIONAL")
|
|
16
|
+
return "CO";
|
|
17
|
+
if (item.proposalType === "NON_CONSTITUTIONAL")
|
|
18
|
+
return "TR";
|
|
19
|
+
return "PR";
|
|
20
|
+
}
|
|
21
|
+
function getTypeColor(item) {
|
|
22
|
+
if (item.type === "election")
|
|
23
|
+
return "magenta";
|
|
24
|
+
if (item.type === "timelock")
|
|
25
|
+
return "blue";
|
|
26
|
+
if (item.proposalType === "CONSTITUTIONAL")
|
|
27
|
+
return "cyan";
|
|
28
|
+
return "green";
|
|
29
|
+
}
|
|
30
|
+
function formatAge(timestamp) {
|
|
31
|
+
if (timestamp === null)
|
|
32
|
+
return "--";
|
|
33
|
+
const diffMs = Date.now() - timestamp;
|
|
34
|
+
const diffDays = Math.floor(diffMs / index_js_1.MS_PER_DAY);
|
|
35
|
+
if (diffDays < 0)
|
|
36
|
+
return "future";
|
|
37
|
+
if (diffDays === 0)
|
|
38
|
+
return "today";
|
|
39
|
+
if (diffDays === 1)
|
|
40
|
+
return "1d ago";
|
|
41
|
+
if (diffDays < 30)
|
|
42
|
+
return `${diffDays}d ago`;
|
|
43
|
+
if (diffDays < 365)
|
|
44
|
+
return `${Math.floor(diffDays / 30)}mo ago`;
|
|
45
|
+
return `${Math.floor(diffDays / 365)}y ago`;
|
|
46
|
+
}
|
|
47
|
+
function renderProgressBar(progress) {
|
|
48
|
+
const filled = Math.max(0, Math.min(progress.current, progress.total));
|
|
49
|
+
const empty = Math.max(0, progress.total - filled);
|
|
50
|
+
return "█".repeat(filled) + "░".repeat(empty);
|
|
51
|
+
}
|
|
52
|
+
const FIXED_COLS_WIDTH = 1 + 4 + 1 + 1 + 8 + 1 + 1 + 1 + 7 + 2;
|
|
53
|
+
const SAFETY_MARGIN = 4;
|
|
54
|
+
const MIN_COMPACT_WIDTH = 50;
|
|
55
|
+
function ProposalRow({ item, isSelected }) {
|
|
56
|
+
const typeLabel = getTypeLabel(item);
|
|
57
|
+
const typeColor = getTypeColor(item);
|
|
58
|
+
const age = formatAge(item.createdAt);
|
|
59
|
+
const progress = (0, index_js_1.parseProgress)(item.stageProgress);
|
|
60
|
+
const progressBar = progress ? renderProgressBar(progress) : null;
|
|
61
|
+
const { width } = (0, index_js_1.getTerminalSize)();
|
|
62
|
+
const isNarrow = width < MIN_COMPACT_WIDTH;
|
|
63
|
+
// In narrow mode, hide age and progress columns to prevent overflow
|
|
64
|
+
const effectiveFixedWidth = isNarrow ? 1 + 4 + 1 + 1 + 1 + 2 : FIXED_COLS_WIDTH;
|
|
65
|
+
const maxTitleWidth = Math.max(10, width - effectiveFixedWidth - SAFETY_MARGIN);
|
|
66
|
+
const title = (0, index_js_1.truncate)(item.title, maxTitleWidth);
|
|
67
|
+
const titlePadded = title.padEnd(maxTitleWidth);
|
|
68
|
+
const progressDisplay = progressBar ?? item.stageProgress;
|
|
69
|
+
const progressColor = progressBar
|
|
70
|
+
? item.status === "complete"
|
|
71
|
+
? "green"
|
|
72
|
+
: "yellow"
|
|
73
|
+
: "gray";
|
|
74
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
|
|
75
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : undefined, bold: isSelected }, isSelected ? ">" : " "),
|
|
76
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: typeColor },
|
|
77
|
+
"[",
|
|
78
|
+
typeLabel,
|
|
79
|
+
"]"),
|
|
80
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, " "),
|
|
81
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : undefined }, titlePadded),
|
|
82
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, " "),
|
|
83
|
+
!isNarrow && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.React.Fragment, null,
|
|
84
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, age.padStart(8)),
|
|
85
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, " "))),
|
|
86
|
+
ink_wrapper_js_1.React.createElement(StatusBadge_js_1.StatusBadge, { status: item.status, compact: true }),
|
|
87
|
+
!isNarrow && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: progressColor },
|
|
88
|
+
" ",
|
|
89
|
+
progressDisplay.padEnd(7)),
|
|
90
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, item.hasExecutable ? " ▶" : " ")));
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=ProposalRow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProposalRow.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/ProposalRow.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Scroll indicator component for views with scrollable content
|
|
3
|
+
*/
|
|
4
|
+
interface ScrollIndicatorProps {
|
|
5
|
+
scrollOffset: number;
|
|
6
|
+
visibleRows: number;
|
|
7
|
+
totalItems: number;
|
|
8
|
+
unit?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare function ScrollIndicatorTop({ scrollOffset, unit, }: Pick<ScrollIndicatorProps, "scrollOffset" | "unit">): React.ReactElement | null;
|
|
11
|
+
export declare function ScrollIndicatorBottom({ scrollOffset, visibleRows, totalItems, unit, }: ScrollIndicatorProps): React.ReactElement | null;
|
|
12
|
+
interface ScrollPositionProps {
|
|
13
|
+
scrollOffset: number;
|
|
14
|
+
visibleRows: number;
|
|
15
|
+
totalItems: number;
|
|
16
|
+
}
|
|
17
|
+
export declare function ScrollPosition({ scrollOffset, visibleRows, totalItems, }: ScrollPositionProps): React.ReactElement | null;
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=ScrollIndicator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollIndicator.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/ScrollIndicator.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAIH,UAAU,oBAAoB;IAC5B,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,wBAAgB,kBAAkB,CAAC,EACjC,YAAY,EACZ,IAAc,GACf,EAAE,IAAI,CAAC,oBAAoB,EAAE,cAAc,GAAG,MAAM,CAAC,GAAG,KAAK,CAAC,YAAY,GAAG,IAAI,CAUjF;AAED,wBAAgB,qBAAqB,CAAC,EACpC,YAAY,EACZ,WAAW,EACX,UAAU,EACV,IAAc,GACf,EAAE,oBAAoB,GAAG,KAAK,CAAC,YAAY,GAAG,IAAI,CAWlD;AAED,UAAU,mBAAmB;IAC3B,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,cAAc,CAAC,EAC7B,YAAY,EACZ,WAAW,EACX,UAAU,GACX,EAAE,mBAAmB,GAAG,KAAK,CAAC,YAAY,GAAG,IAAI,CAkBjD"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Scroll indicator component for views with scrollable content
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ScrollIndicatorTop = ScrollIndicatorTop;
|
|
7
|
+
exports.ScrollIndicatorBottom = ScrollIndicatorBottom;
|
|
8
|
+
exports.ScrollPosition = ScrollPosition;
|
|
9
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
10
|
+
function ScrollIndicatorTop({ scrollOffset, unit = "items", }) {
|
|
11
|
+
if (scrollOffset <= 0)
|
|
12
|
+
return null;
|
|
13
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
|
|
14
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2191 "),
|
|
15
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, scrollOffset),
|
|
16
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
|
|
17
|
+
" ",
|
|
18
|
+
unit,
|
|
19
|
+
" above")));
|
|
20
|
+
}
|
|
21
|
+
function ScrollIndicatorBottom({ scrollOffset, visibleRows, totalItems, unit = "items", }) {
|
|
22
|
+
const remaining = totalItems - scrollOffset - visibleRows;
|
|
23
|
+
if (remaining <= 0)
|
|
24
|
+
return null;
|
|
25
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
|
|
26
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2193 "),
|
|
27
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, remaining),
|
|
28
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
|
|
29
|
+
" ",
|
|
30
|
+
unit,
|
|
31
|
+
" below")));
|
|
32
|
+
}
|
|
33
|
+
function ScrollPosition({ scrollOffset, visibleRows, totalItems, }) {
|
|
34
|
+
if (totalItems <= visibleRows)
|
|
35
|
+
return null;
|
|
36
|
+
const current = Math.min(scrollOffset + visibleRows, totalItems);
|
|
37
|
+
const percentage = Math.round((current / totalItems) * 100);
|
|
38
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
|
|
39
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "["),
|
|
40
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, scrollOffset + 1),
|
|
41
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "-"),
|
|
42
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, current),
|
|
43
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"),
|
|
44
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, totalItems),
|
|
45
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "] "),
|
|
46
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: percentage === 100 ? "green" : "yellow" },
|
|
47
|
+
percentage,
|
|
48
|
+
"%")));
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=ScrollIndicator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollIndicator.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/ScrollIndicator.tsx"],"names":[],"mappings":";AAAA;;GAEG;;AAWH,gDAaC;AAED,sDAgBC;AAQD,wCAsBC;AAtED,sDAAqD;AASrD,SAAgB,kBAAkB,CAAC,EACjC,YAAY,EACZ,IAAI,GAAG,OAAO,GACsC;IACpD,IAAI,YAAY,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAEnC,OAAO,CACL,qCAAC,oBAAG;QACF,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,cAAU;QAC5B,qCAAC,qBAAI,IAAC,KAAK,EAAC,QAAQ,IAAE,YAAY,CAAQ;QAC1C,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM;;YAAG,IAAI;qBAAc,CACnC,CACP,CAAC;AACJ,CAAC;AAED,SAAgB,qBAAqB,CAAC,EACpC,YAAY,EACZ,WAAW,EACX,UAAU,EACV,IAAI,GAAG,OAAO,GACO;IACrB,MAAM,SAAS,GAAG,UAAU,GAAG,YAAY,GAAG,WAAW,CAAC;IAC1D,IAAI,SAAS,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAEhC,OAAO,CACL,qCAAC,oBAAG;QACF,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,cAAU;QAC5B,qCAAC,qBAAI,IAAC,KAAK,EAAC,QAAQ,IAAE,SAAS,CAAQ;QACvC,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM;;YAAG,IAAI;qBAAc,CACnC,CACP,CAAC;AACJ,CAAC;AAQD,SAAgB,cAAc,CAAC,EAC7B,YAAY,EACZ,WAAW,EACX,UAAU,GACU;IACpB,IAAI,UAAU,IAAI,WAAW;QAAE,OAAO,IAAI,CAAC;IAE3C,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,GAAG,WAAW,EAAE,UAAU,CAAC,CAAC;IACjE,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,GAAG,CAAC,CAAC;IAE5D,OAAO,CACL,qCAAC,oBAAG;QACF,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,QAAS;QAC3B,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,IAAE,YAAY,GAAG,CAAC,CAAQ;QAC5C,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,QAAS;QAC3B,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,IAAE,OAAO,CAAQ;QACnC,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,QAAS;QAC3B,qCAAC,qBAAI,QAAE,UAAU,CAAQ;QACzB,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,SAAU;QAC5B,qCAAC,qBAAI,IAAC,KAAK,EAAE,UAAU,KAAK,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ;YAAG,UAAU;gBAAS,CACtE,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Search bar component with visual feedback
|
|
3
|
+
*/
|
|
4
|
+
interface SearchBarProps {
|
|
5
|
+
query: string;
|
|
6
|
+
isActive: boolean;
|
|
7
|
+
resultCount?: number;
|
|
8
|
+
placeholder?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare function SearchBar({ query, isActive, resultCount, placeholder, }: SearchBarProps): React.ReactElement | null;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=SearchBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SearchBar.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/SearchBar.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAIH,UAAU,cAAc;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,wBAAgB,SAAS,CAAC,EACxB,KAAK,EACL,QAAQ,EACR,WAAW,EACX,WAAiC,GAClC,EAAE,cAAc,GAAG,KAAK,CAAC,YAAY,GAAG,IAAI,CA2B5C"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Search bar component with visual feedback
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SearchBar = SearchBar;
|
|
7
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
8
|
+
function SearchBar({ query, isActive, resultCount, placeholder = "Type to search...", }) {
|
|
9
|
+
if (!isActive && !query) {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
if (isActive) {
|
|
13
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginBottom: 1 },
|
|
14
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan", bold: true }, "/ "),
|
|
15
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, query),
|
|
16
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan", inverse: true }, " "),
|
|
17
|
+
!query && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
|
|
18
|
+
" ",
|
|
19
|
+
placeholder),
|
|
20
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " (Enter to confirm, Esc to cancel)")));
|
|
21
|
+
}
|
|
22
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginBottom: 1 },
|
|
23
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "Filter: "),
|
|
24
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" },
|
|
25
|
+
"\"",
|
|
26
|
+
query,
|
|
27
|
+
"\""),
|
|
28
|
+
resultCount !== undefined && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
|
|
29
|
+
" (",
|
|
30
|
+
resultCount,
|
|
31
|
+
" result",
|
|
32
|
+
resultCount !== 1 ? "s" : "",
|
|
33
|
+
")")),
|
|
34
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " (/ to search, Esc to clear)")));
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=SearchBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SearchBar.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/SearchBar.tsx"],"names":[],"mappings":";AAAA;;GAEG;;AAWH,8BAgCC;AAzCD,sDAAqD;AASrD,SAAgB,SAAS,CAAC,EACxB,KAAK,EACL,QAAQ,EACR,WAAW,EACX,WAAW,GAAG,mBAAmB,GAClB;IACf,IAAI,CAAC,QAAQ,IAAI,CAAC,KAAK,EAAE,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,CACL,qCAAC,oBAAG,IAAC,YAAY,EAAE,CAAC;YAClB,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,EAAC,IAAI,eAAU;YACjC,qCAAC,qBAAI,QAAE,KAAK,CAAQ;YACpB,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,EAAC,OAAO,cAAS;YAClC,CAAC,KAAK,IAAI,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM;;gBAAG,WAAW,CAAQ;YACnD,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,yCAA0C,CACxD,CACP,CAAC;IACJ,CAAC;IAED,OAAO,CACL,qCAAC,oBAAG,IAAC,YAAY,EAAE,CAAC;QAClB,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,eAAgB;QAClC,qCAAC,qBAAI,IAAC,KAAK,EAAC,QAAQ;;YAAG,KAAK;iBAAS;QACpC,WAAW,KAAK,SAAS,IAAI,CAC5B,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM;;YAAI,WAAW;;YAAS,WAAW,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBAAS,CAChF;QACD,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,mCAAoC,CAClD,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Animated spinner component for loading states
|
|
3
|
+
*/
|
|
4
|
+
interface SpinnerProps {
|
|
5
|
+
text?: string;
|
|
6
|
+
color?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function Spinner({ text, color }: SpinnerProps): React.ReactElement;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=Spinner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Spinner.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/Spinner.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAIH,UAAU,YAAY;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAKD,wBAAgB,OAAO,CAAC,EAAE,IAAI,EAAE,KAAgB,EAAE,EAAE,YAAY,GAAG,KAAK,CAAC,YAAY,CAiBpF"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Animated spinner component for loading states
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Spinner = Spinner;
|
|
7
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
8
|
+
const SPINNER_FRAMES = ["⠋", "⠙", "⠹", "⠸", "⠼", "⠴", "⠦", "⠧", "⠇", "⠏"];
|
|
9
|
+
const FRAME_INTERVAL = 80;
|
|
10
|
+
function Spinner({ text, color = "yellow" }) {
|
|
11
|
+
const [frameIndex, setFrameIndex] = (0, ink_wrapper_js_1.useState)(0);
|
|
12
|
+
(0, ink_wrapper_js_1.useEffect)(() => {
|
|
13
|
+
const timer = setInterval(() => {
|
|
14
|
+
setFrameIndex((prev) => (prev + 1) % SPINNER_FRAMES.length);
|
|
15
|
+
}, FRAME_INTERVAL);
|
|
16
|
+
return () => clearInterval(timer);
|
|
17
|
+
}, []);
|
|
18
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null,
|
|
19
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: color }, SPINNER_FRAMES[frameIndex]),
|
|
20
|
+
text ? ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
|
|
21
|
+
" ",
|
|
22
|
+
text) : null));
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=Spinner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Spinner.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/Spinner.tsx"],"names":[],"mappings":";AAAA;;GAEG;;AAYH,0BAiBC;AA3BD,sDAAqE;AAOrE,MAAM,cAAc,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AAC1E,MAAM,cAAc,GAAG,EAAE,CAAC;AAE1B,SAAgB,OAAO,CAAC,EAAE,IAAI,EAAE,KAAK,GAAG,QAAQ,EAAgB;IAC9D,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,IAAA,yBAAQ,EAAC,CAAC,CAAC,CAAC;IAEhD,IAAA,0BAAS,EAAC,GAAG,EAAE;QACb,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;YAC7B,aAAa,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;QAC9D,CAAC,EAAE,cAAc,CAAC,CAAC;QAEnB,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,qCAAC,qBAAI;QACH,qCAAC,qBAAI,IAAC,KAAK,EAAE,KAAK,IAAG,cAAc,CAAC,UAAU,CAAC,CAAQ;QACtD,IAAI,CAAC,CAAC,CAAC,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM;;YAAG,IAAI,CAAQ,CAAC,CAAC,CAAC,IAAI,CAC3C,CACR,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Stage progress indicator with number key hints
|
|
3
|
+
*/
|
|
4
|
+
import type { TrackedStage } from "../../../types/index.js";
|
|
5
|
+
interface StageProgressProps {
|
|
6
|
+
stages: TrackedStage[];
|
|
7
|
+
currentIndex: number;
|
|
8
|
+
totalStages?: number;
|
|
9
|
+
}
|
|
10
|
+
export declare function StageProgress({ stages, currentIndex, totalStages, }: StageProgressProps): React.ReactElement;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=StageProgress.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StageProgress.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/StageProgress.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAG5D,UAAU,kBAAkB;IAC1B,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,wBAAgB,aAAa,CAAC,EAC5B,MAAM,EACN,YAAY,EACZ,WAAe,GAChB,EAAE,kBAAkB,GAAG,KAAK,CAAC,YAAY,CA+CzC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Stage progress indicator with number key hints
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.StageProgress = StageProgress;
|
|
7
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
8
|
+
const index_js_1 = require("../utils/index.js");
|
|
9
|
+
function StageProgress({ stages, currentIndex, totalStages = 7, }) {
|
|
10
|
+
const completedCount = stages.filter(s => s.status === "COMPLETED").length;
|
|
11
|
+
const readyCount = stages.filter(s => s.status === "READY").length;
|
|
12
|
+
const pendingCount = stages.filter(s => s.status === "PENDING").length;
|
|
13
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { flexDirection: "column" },
|
|
14
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginBottom: 1 },
|
|
15
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "Progress: "),
|
|
16
|
+
index_js_1.STAGE_TYPES.map((type, i) => {
|
|
17
|
+
const stage = stages.find(s => s.type === type);
|
|
18
|
+
const icon = (0, index_js_1.getStatusIcon)(stage);
|
|
19
|
+
const color = (0, index_js_1.getStatusColor)(stage);
|
|
20
|
+
const isSelected = i === currentIndex;
|
|
21
|
+
const keyNum = i + 1;
|
|
22
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: type },
|
|
23
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : color, bold: isSelected },
|
|
24
|
+
isSelected ? "[" : " ",
|
|
25
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "white" : "gray" }, keyNum),
|
|
26
|
+
icon,
|
|
27
|
+
isSelected ? "]" : " "),
|
|
28
|
+
i < totalStages - 1 && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2500")));
|
|
29
|
+
}),
|
|
30
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " "),
|
|
31
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, completedCount),
|
|
32
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"),
|
|
33
|
+
readyCount > 0 && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.React.Fragment, null,
|
|
34
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, readyCount),
|
|
35
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"))),
|
|
36
|
+
pendingCount > 0 && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.React.Fragment, null,
|
|
37
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, pendingCount),
|
|
38
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"))),
|
|
39
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, totalStages))));
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=StageProgress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StageProgress.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/StageProgress.tsx"],"names":[],"mappings":";AAAA;;GAEG;;AAYH,sCAmDC;AA7DD,sDAAqD;AAErD,gDAA+E;AAQ/E,SAAgB,aAAa,CAAC,EAC5B,MAAM,EACN,YAAY,EACZ,WAAW,GAAG,CAAC,GACI;IACnB,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,MAAM,CAAC;IAC3E,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,MAAM,CAAC;IACnE,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,MAAM,CAAC;IAEvE,OAAO,CACL,qCAAC,oBAAG,IAAC,aAAa,EAAC,QAAQ;QACzB,qCAAC,oBAAG,IAAC,YAAY,EAAE,CAAC;YAClB,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,iBAAkB;YACnC,sBAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE;gBAC3B,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;gBAChD,MAAM,IAAI,GAAG,IAAA,wBAAa,EAAC,KAAK,CAAC,CAAC;gBAClC,MAAM,KAAK,GAAG,IAAA,yBAAc,EAAC,KAAK,CAAC,CAAC;gBACpC,MAAM,UAAU,GAAG,CAAC,KAAK,YAAY,CAAC;gBACtC,MAAM,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;gBAErB,OAAO,CACL,qCAAC,oBAAG,IAAC,GAAG,EAAE,IAAI;oBACZ,qCAAC,qBAAI,IAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,UAAU;wBACvD,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG;wBACvB,qCAAC,qBAAI,IAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,IAAG,MAAM,CAAQ;wBAC1D,IAAI;wBACJ,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAClB;oBACN,CAAC,GAAG,WAAW,GAAG,CAAC,IAAI,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,aAAS,CAC/C,CACP,CAAC;YACJ,CAAC,CAAC;YACF,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,QAAS;YAC3B,qCAAC,qBAAI,IAAC,KAAK,EAAC,OAAO,IAAE,cAAc,CAAQ;YAC3C,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,QAAS;YAC1B,UAAU,GAAG,CAAC,IAAI,CACjB;gBACE,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,IAAE,UAAU,CAAQ;gBACtC,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,QAAS,CAC1B,CACJ;YACA,YAAY,GAAG,CAAC,IAAI,CACnB;gBACE,qCAAC,qBAAI,IAAC,KAAK,EAAC,QAAQ,IAAE,YAAY,CAAQ;gBAC1C,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,QAAS,CAC1B,CACJ;YACD,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,IAAE,WAAW,CAAQ,CACnC,CACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Single stage row component for proposal detail view
|
|
3
|
+
*/
|
|
4
|
+
import type { TrackedStage } from "../../../types/index.js";
|
|
5
|
+
interface StageRowProps {
|
|
6
|
+
stage: TrackedStage;
|
|
7
|
+
index: number;
|
|
8
|
+
isSelected: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare function StageRow({ stage, index, isSelected }: StageRowProps): React.ReactElement;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=StageRow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StageRow.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/StageRow.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAK5D,UAAU,aAAa;IACrB,KAAK,EAAE,YAAY,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,OAAO,CAAC;CACrB;AAsED,wBAAgB,QAAQ,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,aAAa,GAAG,KAAK,CAAC,YAAY,CAwBxF"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Single stage row component for proposal detail view
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.StageRow = StageRow;
|
|
7
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
8
|
+
const stage_metadata_js_1 = require("../../../utils/stage-metadata.js");
|
|
9
|
+
const StatusBadge_js_1 = require("./StatusBadge.js");
|
|
10
|
+
const index_js_1 = require("../utils/index.js");
|
|
11
|
+
function formatTiming(stage) {
|
|
12
|
+
if (stage.timing?.eta) {
|
|
13
|
+
const etaMs = stage.timing.eta * 1000;
|
|
14
|
+
const diff = etaMs - Date.now();
|
|
15
|
+
if (diff > 0) {
|
|
16
|
+
const result = (0, index_js_1.formatDurationMs)(diff);
|
|
17
|
+
return { ...result, isCountdown: true };
|
|
18
|
+
}
|
|
19
|
+
return { text: new Date(etaMs).toLocaleDateString(), color: "gray", isCountdown: false };
|
|
20
|
+
}
|
|
21
|
+
const tx = stage.transactions[0];
|
|
22
|
+
if (tx?.timestamp) {
|
|
23
|
+
const date = new Date(tx.timestamp * 1000);
|
|
24
|
+
const result = (0, index_js_1.formatElapsedMs)(Date.now() - tx.timestamp * 1000, date);
|
|
25
|
+
return { ...result, isCountdown: false };
|
|
26
|
+
}
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
function getStageExtra(stage) {
|
|
30
|
+
if (stage.type === "VOTING_ACTIVE" && stage.data) {
|
|
31
|
+
const data = stage.data;
|
|
32
|
+
if (data.proposalState) {
|
|
33
|
+
return data.proposalState;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
if (stage.type === "RETRYABLE_EXECUTED" && stage.data) {
|
|
37
|
+
const data = stage.data;
|
|
38
|
+
if (data.ticketCount !== undefined) {
|
|
39
|
+
const redeemed = data.redeemedCount ?? 0;
|
|
40
|
+
return `${redeemed}/${data.ticketCount} tickets`;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
if ((stage.type === "L2_TIMELOCK" || stage.type === "L1_TIMELOCK") &&
|
|
44
|
+
stage.data) {
|
|
45
|
+
const data = stage.data;
|
|
46
|
+
if (data.state)
|
|
47
|
+
return data.state;
|
|
48
|
+
}
|
|
49
|
+
if (stage.type === "L2_TO_L1_MESSAGE" && stage.data) {
|
|
50
|
+
const data = stage.data;
|
|
51
|
+
if (data.messageCount) {
|
|
52
|
+
const status = data.status ?? "pending";
|
|
53
|
+
return `${data.messageCount} msg${data.messageCount > 1 ? "s" : ""} (${status})`;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
function StageRow({ stage, index, isSelected }) {
|
|
59
|
+
const title = (0, stage_metadata_js_1.formatStageTitle)(stage.type);
|
|
60
|
+
const timing = formatTiming(stage);
|
|
61
|
+
const extra = getStageExtra(stage);
|
|
62
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
|
|
63
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : undefined, bold: isSelected },
|
|
64
|
+
isSelected ? ">" : " ",
|
|
65
|
+
" ",
|
|
66
|
+
index + 1,
|
|
67
|
+
".",
|
|
68
|
+
" "),
|
|
69
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : undefined, bold: isSelected }, title.padEnd(18)),
|
|
70
|
+
ink_wrapper_js_1.React.createElement(StatusBadge_js_1.StatusBadge, { status: stage.status, padded: true }),
|
|
71
|
+
ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, stage.chain.padEnd(10)),
|
|
72
|
+
timing ? (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: timing.color },
|
|
73
|
+
timing.isCountdown && "⏱ ",
|
|
74
|
+
timing.text.padEnd(timing.isCountdown ? 10 : 12))) : (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " ".repeat(12))),
|
|
75
|
+
extra && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
|
|
76
|
+
"[",
|
|
77
|
+
extra,
|
|
78
|
+
"]")));
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=StageRow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StageRow.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/StageRow.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Status badge component for displaying stage/proposal status
|
|
3
|
+
*/
|
|
4
|
+
import type { StageStatus } from "../../../types/index.js";
|
|
5
|
+
interface StatusBadgeProps {
|
|
6
|
+
status: StageStatus | "active" | "complete" | "failed";
|
|
7
|
+
compact?: boolean;
|
|
8
|
+
padded?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare function StatusBadge({ status, compact, padded }: StatusBadgeProps): React.ReactElement;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=StatusBadge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusBadge.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/StatusBadge.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAE3D,UAAU,gBAAgB;IACxB,MAAM,EAAE,WAAW,GAAG,QAAQ,GAAG,UAAU,GAAG,QAAQ,CAAC;IACvD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAcD,wBAAgB,WAAW,CAAC,EAAE,MAAM,EAAE,OAAe,EAAE,MAAc,EAAE,EAAE,gBAAgB,GAAG,KAAK,CAAC,YAAY,CAa7G"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Status badge component for displaying stage/proposal status
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.StatusBadge = StatusBadge;
|
|
7
|
+
const ink_wrapper_js_1 = require("../ink-wrapper.js");
|
|
8
|
+
const STATUS_CONFIG = {
|
|
9
|
+
NOT_STARTED: { icon: "·", color: "gray", label: "Not Started" },
|
|
10
|
+
PENDING: { icon: "◐", color: "yellow", label: "Pending" },
|
|
11
|
+
READY: { icon: "▶", color: "green", label: "Ready" },
|
|
12
|
+
COMPLETED: { icon: "✓", color: "green", label: "Complete" },
|
|
13
|
+
FAILED: { icon: "✗", color: "red", label: "Failed" },
|
|
14
|
+
SKIPPED: { icon: "○", color: "gray", label: "Skipped" },
|
|
15
|
+
active: { icon: "●", color: "yellow", label: "Active" },
|
|
16
|
+
complete: { icon: "✓", color: "green", label: "Complete" },
|
|
17
|
+
failed: { icon: "✗", color: "red", label: "Failed" },
|
|
18
|
+
};
|
|
19
|
+
function StatusBadge({ status, compact = false, padded = false }) {
|
|
20
|
+
const config = STATUS_CONFIG[status] ?? STATUS_CONFIG.NOT_STARTED;
|
|
21
|
+
if (compact) {
|
|
22
|
+
return ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: config.color }, config.icon);
|
|
23
|
+
}
|
|
24
|
+
const text = `${config.icon} ${config.label}`;
|
|
25
|
+
return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: config.color }, padded ? text.padEnd(14) : text));
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=StatusBadge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusBadge.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/StatusBadge.tsx"],"names":[],"mappings":";AAAA;;GAEG;;AAuBH,kCAaC;AAlCD,sDAAgD;AAShD,MAAM,aAAa,GAAmE;IACpF,WAAW,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,aAAa,EAAE;IAC/D,OAAO,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE;IACzD,KAAK,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE;IACpD,SAAS,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE;IAC3D,MAAM,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE;IACpD,OAAO,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE;IACvD,MAAM,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE;IACvD,QAAQ,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE;IAC1D,MAAM,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE;CACrD,CAAC;AAEF,SAAgB,WAAW,CAAC,EAAE,MAAM,EAAE,OAAO,GAAG,KAAK,EAAE,MAAM,GAAG,KAAK,EAAoB;IACvF,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,aAAa,CAAC,WAAW,CAAC;IAElE,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,qCAAC,qBAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,IAAG,MAAM,CAAC,IAAI,CAAQ,CAAC;IACzD,CAAC;IAED,MAAM,IAAI,GAAG,GAAG,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;IAC9C,OAAO,CACL,qCAAC,qBAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,IACtB,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAC3B,CACR,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared view layout component
|
|
3
|
+
*/
|
|
4
|
+
import type { ViewType, FilterType } from "../types.js";
|
|
5
|
+
interface KeyHelpContext {
|
|
6
|
+
calldataActionCount?: number;
|
|
7
|
+
currentActionIndex?: number;
|
|
8
|
+
}
|
|
9
|
+
interface ViewLayoutProps {
|
|
10
|
+
view: ViewType;
|
|
11
|
+
filter?: FilterType;
|
|
12
|
+
title?: string;
|
|
13
|
+
loading?: boolean;
|
|
14
|
+
loadingText?: string;
|
|
15
|
+
error?: string | null;
|
|
16
|
+
breadcrumb?: string[];
|
|
17
|
+
keyHelpContext?: KeyHelpContext;
|
|
18
|
+
children: React.ReactNode;
|
|
19
|
+
}
|
|
20
|
+
export declare function ViewLayout({ view, filter, title, loading, loadingText, error, breadcrumb, keyHelpContext, children, }: ViewLayoutProps): React.ReactElement;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=ViewLayout.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ViewLayout.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/ViewLayout.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAKxD,UAAU,cAAc;IACtB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED,UAAU,eAAe;IACvB,IAAI,EAAE,QAAQ,CAAC;IACf,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B;AAED,wBAAgB,UAAU,CAAC,EACzB,IAAI,EACJ,MAAc,EACd,KAAK,EACL,OAAe,EACf,WAA0B,EAC1B,KAAY,EACZ,UAAU,EACV,cAAc,EACd,QAAQ,GACT,EAAE,eAAe,GAAG,KAAK,CAAC,YAAY,CAyBtC"}
|