@gzeoneth/gov-tracker 0.2.1-alpha.cli-preview.375ef6c → 0.2.1-alpha.main.b2eeb41

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.
Files changed (197) hide show
  1. package/README.md +0 -40
  2. package/dist/cli/cli.js +0 -50
  3. package/dist/cli/cli.js.map +1 -1
  4. package/dist/cli/lib/cli.d.ts.map +1 -1
  5. package/dist/cli/lib/cli.js +5 -27
  6. package/dist/cli/lib/cli.js.map +1 -1
  7. package/dist/stages/timelock.d.ts.map +1 -1
  8. package/dist/stages/timelock.js +4 -5
  9. package/dist/stages/timelock.js.map +1 -1
  10. package/dist/tracker/cache.d.ts.map +1 -1
  11. package/dist/tracker/cache.js +0 -4
  12. package/dist/tracker/cache.js.map +1 -1
  13. package/package.json +2 -6
  14. package/dist/cli/tui/App.d.ts +0 -13
  15. package/dist/cli/tui/App.d.ts.map +0 -1
  16. package/dist/cli/tui/App.js +0 -146
  17. package/dist/cli/tui/App.js.map +0 -1
  18. package/dist/cli/tui/components/CollapsibleSection.d.ts +0 -20
  19. package/dist/cli/tui/components/CollapsibleSection.d.ts.map +0 -1
  20. package/dist/cli/tui/components/CollapsibleSection.js +0 -29
  21. package/dist/cli/tui/components/CollapsibleSection.js.map +0 -1
  22. package/dist/cli/tui/components/ConfirmDialog.d.ts +0 -14
  23. package/dist/cli/tui/components/ConfirmDialog.d.ts.map +0 -1
  24. package/dist/cli/tui/components/ConfirmDialog.js +0 -29
  25. package/dist/cli/tui/components/ConfirmDialog.js.map +0 -1
  26. package/dist/cli/tui/components/CopyableText.d.ts +0 -23
  27. package/dist/cli/tui/components/CopyableText.d.ts.map +0 -1
  28. package/dist/cli/tui/components/CopyableText.js +0 -49
  29. package/dist/cli/tui/components/CopyableText.js.map +0 -1
  30. package/dist/cli/tui/components/EmptyState.d.ts +0 -11
  31. package/dist/cli/tui/components/EmptyState.d.ts.map +0 -1
  32. package/dist/cli/tui/components/EmptyState.js +0 -34
  33. package/dist/cli/tui/components/EmptyState.js.map +0 -1
  34. package/dist/cli/tui/components/ErrorDisplay.d.ts +0 -17
  35. package/dist/cli/tui/components/ErrorDisplay.d.ts.map +0 -1
  36. package/dist/cli/tui/components/ErrorDisplay.js +0 -66
  37. package/dist/cli/tui/components/ErrorDisplay.js.map +0 -1
  38. package/dist/cli/tui/components/Header.d.ts +0 -22
  39. package/dist/cli/tui/components/Header.d.ts.map +0 -1
  40. package/dist/cli/tui/components/Header.js +0 -73
  41. package/dist/cli/tui/components/Header.js.map +0 -1
  42. package/dist/cli/tui/components/KeyHelp.d.ts +0 -20
  43. package/dist/cli/tui/components/KeyHelp.d.ts.map +0 -1
  44. package/dist/cli/tui/components/KeyHelp.js +0 -136
  45. package/dist/cli/tui/components/KeyHelp.js.map +0 -1
  46. package/dist/cli/tui/components/ProposalRow.d.ts +0 -11
  47. package/dist/cli/tui/components/ProposalRow.d.ts.map +0 -1
  48. package/dist/cli/tui/components/ProposalRow.js +0 -106
  49. package/dist/cli/tui/components/ProposalRow.js.map +0 -1
  50. package/dist/cli/tui/components/ScrollIndicator.d.ts +0 -26
  51. package/dist/cli/tui/components/ScrollIndicator.d.ts.map +0 -1
  52. package/dist/cli/tui/components/ScrollIndicator.js +0 -59
  53. package/dist/cli/tui/components/ScrollIndicator.js.map +0 -1
  54. package/dist/cli/tui/components/SearchBar.d.ts +0 -12
  55. package/dist/cli/tui/components/SearchBar.d.ts.map +0 -1
  56. package/dist/cli/tui/components/SearchBar.js +0 -36
  57. package/dist/cli/tui/components/SearchBar.js.map +0 -1
  58. package/dist/cli/tui/components/Skeleton.d.ts +0 -22
  59. package/dist/cli/tui/components/Skeleton.d.ts.map +0 -1
  60. package/dist/cli/tui/components/Skeleton.js +0 -35
  61. package/dist/cli/tui/components/Skeleton.js.map +0 -1
  62. package/dist/cli/tui/components/Spinner.d.ts +0 -10
  63. package/dist/cli/tui/components/Spinner.d.ts.map +0 -1
  64. package/dist/cli/tui/components/Spinner.js +0 -24
  65. package/dist/cli/tui/components/Spinner.js.map +0 -1
  66. package/dist/cli/tui/components/StageProgress.d.ts +0 -12
  67. package/dist/cli/tui/components/StageProgress.d.ts.map +0 -1
  68. package/dist/cli/tui/components/StageProgress.js +0 -72
  69. package/dist/cli/tui/components/StageProgress.js.map +0 -1
  70. package/dist/cli/tui/components/StageRow.d.ts +0 -12
  71. package/dist/cli/tui/components/StageRow.d.ts.map +0 -1
  72. package/dist/cli/tui/components/StageRow.js +0 -106
  73. package/dist/cli/tui/components/StageRow.js.map +0 -1
  74. package/dist/cli/tui/components/StatusBadge.d.ts +0 -12
  75. package/dist/cli/tui/components/StatusBadge.d.ts.map +0 -1
  76. package/dist/cli/tui/components/StatusBadge.js +0 -27
  77. package/dist/cli/tui/components/StatusBadge.js.map +0 -1
  78. package/dist/cli/tui/components/StatusBar.d.ts +0 -12
  79. package/dist/cli/tui/components/StatusBar.d.ts.map +0 -1
  80. package/dist/cli/tui/components/StatusBar.js +0 -14
  81. package/dist/cli/tui/components/StatusBar.js.map +0 -1
  82. package/dist/cli/tui/components/Timeline.d.ts +0 -12
  83. package/dist/cli/tui/components/Timeline.d.ts.map +0 -1
  84. package/dist/cli/tui/components/Timeline.js +0 -91
  85. package/dist/cli/tui/components/Timeline.js.map +0 -1
  86. package/dist/cli/tui/components/Toast.d.ts +0 -13
  87. package/dist/cli/tui/components/Toast.d.ts.map +0 -1
  88. package/dist/cli/tui/components/Toast.js +0 -35
  89. package/dist/cli/tui/components/Toast.js.map +0 -1
  90. package/dist/cli/tui/components/TrackingProgress.d.ts +0 -24
  91. package/dist/cli/tui/components/TrackingProgress.d.ts.map +0 -1
  92. package/dist/cli/tui/components/TrackingProgress.js +0 -82
  93. package/dist/cli/tui/components/TrackingProgress.js.map +0 -1
  94. package/dist/cli/tui/components/ViewLayout.d.ts +0 -26
  95. package/dist/cli/tui/components/ViewLayout.d.ts.map +0 -1
  96. package/dist/cli/tui/components/ViewLayout.js +0 -57
  97. package/dist/cli/tui/components/ViewLayout.js.map +0 -1
  98. package/dist/cli/tui/components/VotingStats.d.ts +0 -11
  99. package/dist/cli/tui/components/VotingStats.d.ts.map +0 -1
  100. package/dist/cli/tui/components/VotingStats.js +0 -87
  101. package/dist/cli/tui/components/VotingStats.js.map +0 -1
  102. package/dist/cli/tui/config.d.ts +0 -42
  103. package/dist/cli/tui/config.d.ts.map +0 -1
  104. package/dist/cli/tui/config.js +0 -144
  105. package/dist/cli/tui/config.js.map +0 -1
  106. package/dist/cli/tui/hooks/index.d.ts +0 -12
  107. package/dist/cli/tui/hooks/index.d.ts.map +0 -1
  108. package/dist/cli/tui/hooks/index.js +0 -18
  109. package/dist/cli/tui/hooks/index.js.map +0 -1
  110. package/dist/cli/tui/hooks/useCache.d.ts +0 -12
  111. package/dist/cli/tui/hooks/useCache.d.ts.map +0 -1
  112. package/dist/cli/tui/hooks/useCache.js +0 -110
  113. package/dist/cli/tui/hooks/useCache.js.map +0 -1
  114. package/dist/cli/tui/hooks/useCliProcess.d.ts +0 -19
  115. package/dist/cli/tui/hooks/useCliProcess.d.ts.map +0 -1
  116. package/dist/cli/tui/hooks/useCliProcess.js +0 -135
  117. package/dist/cli/tui/hooks/useCliProcess.js.map +0 -1
  118. package/dist/cli/tui/hooks/useNavigation.d.ts +0 -40
  119. package/dist/cli/tui/hooks/useNavigation.d.ts.map +0 -1
  120. package/dist/cli/tui/hooks/useNavigation.js +0 -283
  121. package/dist/cli/tui/hooks/useNavigation.js.map +0 -1
  122. package/dist/cli/tui/hooks/useProposals.d.ts +0 -10
  123. package/dist/cli/tui/hooks/useProposals.d.ts.map +0 -1
  124. package/dist/cli/tui/hooks/useProposals.js +0 -215
  125. package/dist/cli/tui/hooks/useProposals.js.map +0 -1
  126. package/dist/cli/tui/hooks/useStageCalldata.d.ts +0 -17
  127. package/dist/cli/tui/hooks/useStageCalldata.d.ts.map +0 -1
  128. package/dist/cli/tui/hooks/useStageCalldata.js +0 -77
  129. package/dist/cli/tui/hooks/useStageCalldata.js.map +0 -1
  130. package/dist/cli/tui/hooks/useTracker.d.ts +0 -27
  131. package/dist/cli/tui/hooks/useTracker.d.ts.map +0 -1
  132. package/dist/cli/tui/hooks/useTracker.js +0 -205
  133. package/dist/cli/tui/hooks/useTracker.js.map +0 -1
  134. package/dist/cli/tui/index.d.ts +0 -15
  135. package/dist/cli/tui/index.d.ts.map +0 -1
  136. package/dist/cli/tui/index.js +0 -100
  137. package/dist/cli/tui/index.js.map +0 -1
  138. package/dist/cli/tui/ink-wrapper.d.ts +0 -43
  139. package/dist/cli/tui/ink-wrapper.d.ts.map +0 -1
  140. package/dist/cli/tui/ink-wrapper.js +0 -41
  141. package/dist/cli/tui/ink-wrapper.js.map +0 -1
  142. package/dist/cli/tui/types.d.ts +0 -37
  143. package/dist/cli/tui/types.d.ts.map +0 -1
  144. package/dist/cli/tui/types.js +0 -6
  145. package/dist/cli/tui/types.js.map +0 -1
  146. package/dist/cli/tui/utils/clipboard.d.ts +0 -7
  147. package/dist/cli/tui/utils/clipboard.d.ts.map +0 -1
  148. package/dist/cli/tui/utils/clipboard.js +0 -46
  149. package/dist/cli/tui/utils/clipboard.js.map +0 -1
  150. package/dist/cli/tui/utils/index.d.ts +0 -5
  151. package/dist/cli/tui/utils/index.d.ts.map +0 -1
  152. package/dist/cli/tui/utils/index.js +0 -13
  153. package/dist/cli/tui/utils/index.js.map +0 -1
  154. package/dist/cli/tui/utils/terminal.d.ts +0 -18
  155. package/dist/cli/tui/utils/terminal.d.ts.map +0 -1
  156. package/dist/cli/tui/utils/terminal.js +0 -26
  157. package/dist/cli/tui/utils/terminal.js.map +0 -1
  158. package/dist/cli/tui/utils/text.d.ts +0 -12
  159. package/dist/cli/tui/utils/text.d.ts.map +0 -1
  160. package/dist/cli/tui/utils/text.js +0 -30
  161. package/dist/cli/tui/utils/text.js.map +0 -1
  162. package/dist/cli/tui/views/CalldataView.d.ts +0 -12
  163. package/dist/cli/tui/views/CalldataView.d.ts.map +0 -1
  164. package/dist/cli/tui/views/CalldataView.js +0 -194
  165. package/dist/cli/tui/views/CalldataView.js.map +0 -1
  166. package/dist/cli/tui/views/DescriptionView.d.ts +0 -12
  167. package/dist/cli/tui/views/DescriptionView.d.ts.map +0 -1
  168. package/dist/cli/tui/views/DescriptionView.js +0 -182
  169. package/dist/cli/tui/views/DescriptionView.js.map +0 -1
  170. package/dist/cli/tui/views/ElectionView.d.ts +0 -12
  171. package/dist/cli/tui/views/ElectionView.d.ts.map +0 -1
  172. package/dist/cli/tui/views/ElectionView.js +0 -197
  173. package/dist/cli/tui/views/ElectionView.js.map +0 -1
  174. package/dist/cli/tui/views/HelpView.d.ts +0 -10
  175. package/dist/cli/tui/views/HelpView.d.ts.map +0 -1
  176. package/dist/cli/tui/views/HelpView.js +0 -159
  177. package/dist/cli/tui/views/HelpView.js.map +0 -1
  178. package/dist/cli/tui/views/ProposalDetail.d.ts +0 -14
  179. package/dist/cli/tui/views/ProposalDetail.d.ts.map +0 -1
  180. package/dist/cli/tui/views/ProposalDetail.js +0 -167
  181. package/dist/cli/tui/views/ProposalDetail.js.map +0 -1
  182. package/dist/cli/tui/views/ProposalList.d.ts +0 -17
  183. package/dist/cli/tui/views/ProposalList.d.ts.map +0 -1
  184. package/dist/cli/tui/views/ProposalList.js +0 -126
  185. package/dist/cli/tui/views/ProposalList.js.map +0 -1
  186. package/dist/cli/tui/views/SettingsView.d.ts +0 -12
  187. package/dist/cli/tui/views/SettingsView.d.ts.map +0 -1
  188. package/dist/cli/tui/views/SettingsView.js +0 -203
  189. package/dist/cli/tui/views/SettingsView.js.map +0 -1
  190. package/dist/cli/tui/views/SimulationView.d.ts +0 -12
  191. package/dist/cli/tui/views/SimulationView.d.ts.map +0 -1
  192. package/dist/cli/tui/views/SimulationView.js +0 -112
  193. package/dist/cli/tui/views/SimulationView.js.map +0 -1
  194. package/dist/cli/tui/views/StageView.d.ts +0 -12
  195. package/dist/cli/tui/views/StageView.d.ts.map +0 -1
  196. package/dist/cli/tui/views/StageView.js +0 -215
  197. package/dist/cli/tui/views/StageView.js.map +0 -1
@@ -1,73 +0,0 @@
1
- "use strict";
2
- /**
3
- * Header component showing title and stats
4
- */
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Header = Header;
7
- const ink_wrapper_js_1 = require("../ink-wrapper.js");
8
- const SORT_LABELS = {
9
- newest: "↓New",
10
- oldest: "↑Old",
11
- progress: "↓Prog",
12
- status: "Status",
13
- };
14
- function Header({ view, filter, sort, stats, hasProviders, isTracking, title, position, breadcrumb, }) {
15
- const getViewTitle = () => {
16
- switch (view) {
17
- case "list":
18
- return "Gov-Tracker TUI [PREVIEW]";
19
- case "detail":
20
- return title ?? "Proposal Detail";
21
- case "calldata":
22
- return "Decoded Calldata";
23
- case "stage":
24
- return "Stage Details";
25
- case "simulation":
26
- return title ?? "Simulation Data";
27
- case "description":
28
- return title ?? "Proposal Description";
29
- default:
30
- return "Gov-Tracker";
31
- }
32
- };
33
- const getRightSide = () => {
34
- if (view === "list" && stats) {
35
- const totalActive = stats.proposals.active + stats.timelocks.active + (stats.elections.total - stats.elections.complete);
36
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
37
- stats.total,
38
- " items | ",
39
- totalActive,
40
- " active",
41
- hasProviders && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, " [RPC]"),
42
- isTracking && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, " [Tracking...]")));
43
- }
44
- if (view === "detail" && hasProviders) {
45
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, isTracking ? (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, "Tracking...")) : (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, "[r] to re-track"))));
46
- }
47
- return null;
48
- };
49
- const renderBreadcrumb = () => {
50
- if (!breadcrumb || breadcrumb.length === 0)
51
- return null;
52
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null, breadcrumb.map((item, i) => (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { key: i },
53
- i > 0 && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " \u203A "),
54
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: i === breadcrumb.length - 1 ? "cyan" : "gray" }, item))))));
55
- };
56
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { borderStyle: "single", borderColor: "cyan", paddingX: 1 },
57
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { flexGrow: 1 },
58
- breadcrumb && breadcrumb.length > 0 ? (renderBreadcrumb()) : (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { bold: true, color: "cyan" }, getViewTitle())),
59
- view === "list" && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
60
- " ",
61
- "[",
62
- filter.toUpperCase(),
63
- "] [",
64
- sort ? SORT_LABELS[sort] : "↓New",
65
- "]")),
66
- position && position.total > 0 && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" },
67
- " ",
68
- position.current,
69
- "/",
70
- position.total))),
71
- getRightSide()));
72
- }
73
- //# sourceMappingURL=Header.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/Header.tsx"],"names":[],"mappings":"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"}
@@ -1,20 +0,0 @@
1
- /**
2
- * Keyboard shortcuts help footer
3
- */
4
- import type { ViewType, FilterType, SortType } from "../types.js";
5
- interface ContextInfo {
6
- filter?: FilterType;
7
- sort?: SortType;
8
- isSearching?: boolean;
9
- hasSearch?: boolean;
10
- calldataActionCount?: number;
11
- currentActionIndex?: number;
12
- }
13
- interface KeyHelpProps {
14
- view: ViewType;
15
- hasProviders: boolean;
16
- context?: ContextInfo;
17
- }
18
- export declare function KeyHelp({ view, hasProviders, context }: KeyHelpProps): React.ReactElement;
19
- export {};
20
- //# sourceMappingURL=KeyHelp.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyHelp.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/KeyHelp.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAElE,UAAU,WAAW;IACnB,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB,IAAI,CAAC,EAAE,QAAQ,CAAC;IAChB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED,UAAU,YAAY;IACpB,IAAI,EAAE,QAAQ,CAAC;IACf,YAAY,EAAE,OAAO,CAAC;IACtB,OAAO,CAAC,EAAE,WAAW,CAAC;CACvB;AAsJD,wBAAgB,OAAO,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,EAAE,YAAY,GAAG,KAAK,CAAC,YAAY,CAezF"}
@@ -1,136 +0,0 @@
1
- "use strict";
2
- /**
3
- * Keyboard shortcuts help footer
4
- */
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.KeyHelp = KeyHelp;
7
- const ink_wrapper_js_1 = require("../ink-wrapper.js");
8
- const LIST_KEYS = [
9
- { key: "j/k", action: "Navigate" },
10
- { key: "g/G", action: "Top/Bottom" },
11
- { key: "/", action: "Search" },
12
- { key: "Enter", action: "View" },
13
- { key: "Tab", action: "Filter" },
14
- { key: "o", action: "Sort" },
15
- { key: "R", action: "Reload" },
16
- { key: "e", action: "Elections" },
17
- { key: "d", action: "Discover" },
18
- { key: "S", action: "Settings" },
19
- { key: "?", action: "Help" },
20
- { key: "q", action: "Quit" },
21
- ];
22
- const DETAIL_KEYS_BASE = [
23
- { key: "j/k", action: "Stage" },
24
- { key: "1-7", action: "Jump" },
25
- { key: "Enter", action: "Details" },
26
- { key: "y/Y", action: "Copy ID/TX" },
27
- { key: "d", action: "Description" },
28
- { key: "c", action: "Calldata" },
29
- { key: "s", action: "Simulate" },
30
- { key: "?", action: "Help" },
31
- ];
32
- const DETAIL_RETRACK = { key: "r", action: "Re-track" };
33
- const DETAIL_BACK = { key: "b", action: "Back" };
34
- const CALLDATA_KEYS = [
35
- { key: "←→", action: "Actions" },
36
- { key: "↑↓/PgUp/Dn", action: "Scroll" },
37
- { key: "g/G", action: "Top/Bottom" },
38
- { key: "e/c", action: "Expand/Collapse" },
39
- { key: "b", action: "Back" },
40
- ];
41
- const STAGE_KEYS = [
42
- { key: "↑↓/PgUp/Dn", action: "Scroll" },
43
- { key: "b", action: "Back" },
44
- ];
45
- const SIMULATION_KEYS = [
46
- { key: "↑↓", action: "Navigate" },
47
- { key: "b", action: "Back" },
48
- ];
49
- const DESCRIPTION_KEYS = [
50
- { key: "↑↓/PgUp/Dn", action: "Scroll" },
51
- { key: "b", action: "Back" },
52
- ];
53
- const ELECTION_KEYS = [
54
- { key: "↑↓", action: "Navigate" },
55
- { key: "b", action: "Back" },
56
- ];
57
- function getKeysForView(view, hasProviders) {
58
- switch (view) {
59
- case "list":
60
- // Always show all keys - discover/election use default public RPCs if none configured
61
- return LIST_KEYS;
62
- case "detail":
63
- return hasProviders
64
- ? [...DETAIL_KEYS_BASE, DETAIL_RETRACK, DETAIL_BACK]
65
- : [...DETAIL_KEYS_BASE, DETAIL_BACK];
66
- case "calldata":
67
- return CALLDATA_KEYS;
68
- case "stage":
69
- return STAGE_KEYS;
70
- case "simulation":
71
- return SIMULATION_KEYS;
72
- case "description":
73
- return DESCRIPTION_KEYS;
74
- case "election":
75
- return ELECTION_KEYS;
76
- default:
77
- return [];
78
- }
79
- }
80
- const SORT_DISPLAY = {
81
- newest: "Newest",
82
- oldest: "Oldest",
83
- progress: "Progress",
84
- status: "Status",
85
- };
86
- function ContextIndicators({ view, context }) {
87
- if (view !== "list" || !context)
88
- return null;
89
- const indicators = [];
90
- if (context.isSearching) {
91
- indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { key: "search", color: "yellow" }, "[SEARCHING] "));
92
- }
93
- else if (context.hasSearch) {
94
- indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: "search-active", marginRight: 1 },
95
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, "\u26B2 "),
96
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "Esc:Clear")));
97
- }
98
- if (context.filter && context.filter !== "all") {
99
- indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: "filter", marginRight: 1 },
100
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "magenta" }, context.filter.toUpperCase())));
101
- }
102
- if (context.sort && context.sort !== "newest") {
103
- indicators.push(ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: "sort", marginRight: 1 },
104
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "blue" },
105
- "\u2195",
106
- SORT_DISPLAY[context.sort])));
107
- }
108
- if (indicators.length === 0)
109
- return null;
110
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginRight: 2 },
111
- indicators,
112
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2502")));
113
- }
114
- function CalldataIndicator({ context }) {
115
- if (!context?.calldataActionCount || context.calldataActionCount <= 1)
116
- return null;
117
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginRight: 2 },
118
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" },
119
- "Action ",
120
- (context.currentActionIndex ?? 0) + 1,
121
- "/",
122
- context.calldataActionCount),
123
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " \u2502")));
124
- }
125
- function KeyHelp({ view, hasProviders, context }) {
126
- const keys = getKeysForView(view, hasProviders);
127
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { borderStyle: "single", borderColor: "gray", paddingX: 1 },
128
- ink_wrapper_js_1.React.createElement(ContextIndicators, { view: view, context: context }),
129
- view === "calldata" && ink_wrapper_js_1.React.createElement(CalldataIndicator, { context: context }),
130
- keys.map((binding) => (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: binding.key, marginRight: 2 },
131
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, binding.key),
132
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
133
- ": ",
134
- binding.action))))));
135
- }
136
- //# sourceMappingURL=KeyHelp.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyHelp.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/KeyHelp.tsx"],"names":[],"mappings":"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"}
@@ -1,11 +0,0 @@
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
@@ -1 +0,0 @@
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;AAuDD,wBAAgB,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,gBAAgB,GAAG,KAAK,CAAC,YAAY,CA2CtF"}
@@ -1,106 +0,0 @@
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 now = Date.now();
34
- const diffMs = now - timestamp;
35
- const diffDays = Math.floor(diffMs / (1000 * 60 * 60 * 24));
36
- if (diffDays < 0)
37
- return "future";
38
- if (diffDays === 0)
39
- return "today";
40
- if (diffDays === 1)
41
- return "1d ago";
42
- if (diffDays < 30)
43
- return `${diffDays}d ago`;
44
- if (diffDays < 365) {
45
- const months = Math.floor(diffDays / 30);
46
- return `${months}mo ago`;
47
- }
48
- const years = Math.floor(diffDays / 365);
49
- return `${years}y ago`;
50
- }
51
- function parseProgress(stageProgress) {
52
- const match = stageProgress.match(/(\d+)\/(\d+)/);
53
- if (!match)
54
- return null;
55
- const current = parseInt(match[1], 10);
56
- const total = parseInt(match[2], 10);
57
- if (total <= 0 || current < 0)
58
- return null;
59
- return { current, total };
60
- }
61
- function renderProgressBar(progress) {
62
- const filled = Math.max(0, Math.min(progress.current, progress.total));
63
- const empty = Math.max(0, progress.total - filled);
64
- return "█".repeat(filled) + "░".repeat(empty);
65
- }
66
- const FIXED_COLS_WIDTH = 1 + 4 + 1 + 1 + 8 + 1 + 1 + 1 + 7 + 2;
67
- const SAFETY_MARGIN = 4;
68
- const MIN_COMPACT_WIDTH = 50;
69
- function ProposalRow({ item, isSelected }) {
70
- const typeLabel = getTypeLabel(item);
71
- const typeColor = getTypeColor(item);
72
- const age = formatAge(item.createdAt);
73
- const progress = parseProgress(item.stageProgress);
74
- const progressBar = progress ? renderProgressBar(progress) : null;
75
- const { width } = (0, index_js_1.getTerminalSize)();
76
- const isNarrow = width < MIN_COMPACT_WIDTH;
77
- // In narrow mode, hide age and progress columns to prevent overflow
78
- const effectiveFixedWidth = isNarrow ? 1 + 4 + 1 + 1 + 1 + 2 : FIXED_COLS_WIDTH;
79
- const maxTitleWidth = Math.max(10, width - effectiveFixedWidth - SAFETY_MARGIN);
80
- const title = (0, index_js_1.truncate)(item.title, maxTitleWidth);
81
- const titlePadded = title.padEnd(maxTitleWidth);
82
- const progressDisplay = progressBar ?? item.stageProgress;
83
- const progressColor = progressBar
84
- ? item.status === "complete"
85
- ? "green"
86
- : "yellow"
87
- : "gray";
88
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
89
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : undefined, bold: isSelected }, isSelected ? ">" : " "),
90
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: typeColor },
91
- "[",
92
- typeLabel,
93
- "]"),
94
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, " "),
95
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : undefined }, titlePadded),
96
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, " "),
97
- !isNarrow && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.React.Fragment, null,
98
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, age.padStart(8)),
99
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, " "))),
100
- ink_wrapper_js_1.React.createElement(StatusBadge_js_1.StatusBadge, { status: item.status, compact: true }),
101
- !isNarrow && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: progressColor },
102
- " ",
103
- progressDisplay.padEnd(7)),
104
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, item.hasExecutable ? " ▶" : " ")));
105
- }
106
- //# sourceMappingURL=ProposalRow.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ProposalRow.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/ProposalRow.tsx"],"names":[],"mappings":"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"}
@@ -1,26 +0,0 @@
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 ScrollBarProps {
13
- scrollOffset: number;
14
- visibleRows: number;
15
- totalItems: number;
16
- height?: number;
17
- }
18
- export declare function ScrollBar({ scrollOffset, visibleRows, totalItems, height, }: ScrollBarProps): React.ReactElement | null;
19
- interface ScrollPositionProps {
20
- scrollOffset: number;
21
- visibleRows: number;
22
- totalItems: number;
23
- }
24
- export declare function ScrollPosition({ scrollOffset, visibleRows, totalItems, }: ScrollPositionProps): React.ReactElement | null;
25
- export {};
26
- //# sourceMappingURL=ScrollIndicator.d.ts.map
@@ -1 +0,0 @@
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,cAAc;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,SAAS,CAAC,EACxB,YAAY,EACZ,WAAW,EACX,UAAU,EACV,MAAU,GACX,EAAE,cAAc,GAAG,KAAK,CAAC,YAAY,GAAG,IAAI,CAmB5C;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"}
@@ -1,59 +0,0 @@
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.ScrollBar = ScrollBar;
9
- exports.ScrollPosition = ScrollPosition;
10
- const ink_wrapper_js_1 = require("../ink-wrapper.js");
11
- function ScrollIndicatorTop({ scrollOffset, unit = "items", }) {
12
- if (scrollOffset <= 0)
13
- return null;
14
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
15
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2191 "),
16
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, scrollOffset),
17
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
18
- " ",
19
- unit,
20
- " above")));
21
- }
22
- function ScrollIndicatorBottom({ scrollOffset, visibleRows, totalItems, unit = "items", }) {
23
- const remaining = totalItems - scrollOffset - visibleRows;
24
- if (remaining <= 0)
25
- return null;
26
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
27
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2193 "),
28
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, remaining),
29
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
30
- " ",
31
- unit,
32
- " below")));
33
- }
34
- function ScrollBar({ scrollOffset, visibleRows, totalItems, height = 5, }) {
35
- if (totalItems <= visibleRows)
36
- return null;
37
- const scrollRatio = scrollOffset / Math.max(1, totalItems - visibleRows);
38
- const thumbPosition = Math.min(height - 1, Math.round(scrollRatio * (height - 1)));
39
- const chars = Array.from({ length: height }, (_, i) => i === thumbPosition ? "█" : "░");
40
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { flexDirection: "column" }, chars.map((char, i) => (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { key: i, color: i === thumbPosition ? "cyan" : "gray" }, char)))));
41
- }
42
- function ScrollPosition({ scrollOffset, visibleRows, totalItems, }) {
43
- if (totalItems <= visibleRows)
44
- return null;
45
- const current = Math.min(scrollOffset + visibleRows, totalItems);
46
- const percentage = Math.round((current / totalItems) * 100);
47
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
48
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "["),
49
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, scrollOffset + 1),
50
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "-"),
51
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, current),
52
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"),
53
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, null, totalItems),
54
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "] "),
55
- ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: percentage === 100 ? "green" : "yellow" },
56
- percentage,
57
- "%")));
58
- }
59
- //# sourceMappingURL=ScrollIndicator.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ScrollIndicator.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/ScrollIndicator.tsx"],"names":[],"mappings":"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"}
@@ -1,12 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,36 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,22 +0,0 @@
1
- /**
2
- * Skeleton loading component for perceived performance
3
- */
4
- interface SkeletonProps {
5
- width?: number;
6
- height?: number;
7
- animated?: boolean;
8
- }
9
- export declare function Skeleton({ width, height, animated }: SkeletonProps): React.ReactElement;
10
- interface SkeletonRowProps {
11
- columns: number[];
12
- animated?: boolean;
13
- }
14
- export declare function SkeletonRow({ columns, animated }: SkeletonRowProps): React.ReactElement;
15
- interface SkeletonListProps {
16
- rows?: number;
17
- columns?: number[];
18
- animated?: boolean;
19
- }
20
- export declare function SkeletonList({ rows, columns, animated }: SkeletonListProps): React.ReactElement;
21
- export {};
22
- //# sourceMappingURL=Skeleton.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Skeleton.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/Skeleton.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAIH,UAAU,aAAa;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAID,wBAAgB,QAAQ,CAAC,EAAE,KAAU,EAAE,MAAU,EAAE,QAAe,EAAE,EAAE,aAAa,GAAG,KAAK,CAAC,YAAY,CA2BvG;AAED,UAAU,gBAAgB;IACxB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,WAAW,CAAC,EAAE,OAAO,EAAE,QAAe,EAAE,EAAE,gBAAgB,GAAG,KAAK,CAAC,YAAY,CAU9F;AAED,UAAU,iBAAiB;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,YAAY,CAAC,EAC3B,IAAQ,EACR,OAAwB,EACxB,QAAe,EAChB,EAAE,iBAAiB,GAAG,KAAK,CAAC,YAAY,CAQxC"}
@@ -1,35 +0,0 @@
1
- "use strict";
2
- /**
3
- * Skeleton loading component for perceived performance
4
- */
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Skeleton = Skeleton;
7
- exports.SkeletonRow = SkeletonRow;
8
- exports.SkeletonList = SkeletonList;
9
- const ink_wrapper_js_1 = require("../ink-wrapper.js");
10
- const SKELETON_CHARS = ["░", "▒", "▓", "▒"];
11
- function Skeleton({ width = 20, height = 1, animated = true }) {
12
- const [frame, setFrame] = (0, ink_wrapper_js_1.useState)(0);
13
- (0, ink_wrapper_js_1.useEffect)(() => {
14
- if (!animated)
15
- return undefined;
16
- const interval = setInterval(() => {
17
- setFrame((f) => (f + 1) % SKELETON_CHARS.length);
18
- }, 200);
19
- return () => clearInterval(interval);
20
- }, [animated]);
21
- const char = animated ? SKELETON_CHARS[frame] : "░";
22
- const line = char.repeat(width);
23
- if (height === 1) {
24
- return ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, line);
25
- }
26
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { flexDirection: "column" }, Array.from({ length: height }).map((_, i) => (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { key: i, color: "gray" }, line)))));
27
- }
28
- function SkeletonRow({ columns, animated = true }) {
29
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null, columns.map((width, i) => (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: i, marginRight: 1 },
30
- ink_wrapper_js_1.React.createElement(Skeleton, { width: width, animated: animated }))))));
31
- }
32
- function SkeletonList({ rows = 5, columns = [3, 40, 10, 8], animated = true }) {
33
- return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { flexDirection: "column" }, Array.from({ length: rows }).map((_, i) => (ink_wrapper_js_1.React.createElement(SkeletonRow, { key: i, columns: columns, animated: animated })))));
34
- }
35
- //# sourceMappingURL=Skeleton.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Skeleton.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/Skeleton.tsx"],"names":[],"mappings":";AAAA;;GAEG;;AAYH,4BA2BC;AAOD,kCAUC;AAQD,oCAYC;AA1ED,sDAA0E;AAQ1E,MAAM,cAAc,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AAE5C,SAAgB,QAAQ,CAAC,EAAE,KAAK,GAAG,EAAE,EAAE,MAAM,GAAG,CAAC,EAAE,QAAQ,GAAG,IAAI,EAAiB;IACjF,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,yBAAQ,EAAC,CAAC,CAAC,CAAC;IAEtC,IAAA,0BAAS,EAAC,GAAG,EAAE;QACb,IAAI,CAAC,QAAQ;YAAE,OAAO,SAAS,CAAC;QAEhC,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;YAChC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;QACnD,CAAC,EAAE,GAAG,CAAC,CAAC;QAER,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEf,MAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IACpD,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAEhC,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;QACjB,OAAO,qCAAC,qBAAI,IAAC,KAAK,EAAC,MAAM,IAAE,IAAI,CAAQ,CAAC;IAC1C,CAAC;IAED,OAAO,CACL,qCAAC,oBAAG,IAAC,aAAa,EAAC,QAAQ,IACxB,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAC5C,qCAAC,qBAAI,IAAC,GAAG,EAAE,CAAC,EAAE,KAAK,EAAC,MAAM,IAAE,IAAI,CAAQ,CACzC,CAAC,CACE,CACP,CAAC;AACJ,CAAC;AAOD,SAAgB,WAAW,CAAC,EAAE,OAAO,EAAE,QAAQ,GAAG,IAAI,EAAoB;IACxE,OAAO,CACL,qCAAC,oBAAG,QACD,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,CACzB,qCAAC,oBAAG,IAAC,GAAG,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC;QACzB,qCAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,GAAI,CAC1C,CACP,CAAC,CACE,CACP,CAAC;AACJ,CAAC;AAQD,SAAgB,YAAY,CAAC,EAC3B,IAAI,GAAG,CAAC,EACR,OAAO,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EACxB,QAAQ,GAAG,IAAI,EACG;IAClB,OAAO,CACL,qCAAC,oBAAG,IAAC,aAAa,EAAC,QAAQ,IACxB,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAC1C,qCAAC,WAAW,IAAC,GAAG,EAAE,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,GAAI,CAC9D,CAAC,CACE,CACP,CAAC;AACJ,CAAC"}
@@ -1,10 +0,0 @@
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
@@ -1 +0,0 @@
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"}