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

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 (250) hide show
  1. package/README.md +91 -68
  2. package/dist/calldata/index.d.ts +1 -1
  3. package/dist/calldata/index.d.ts.map +1 -1
  4. package/dist/calldata/index.js.map +1 -1
  5. package/dist/calldata/parameter-decoder.d.ts.map +1 -1
  6. package/dist/calldata/parameter-decoder.js +8 -1
  7. package/dist/calldata/parameter-decoder.js.map +1 -1
  8. package/dist/calldata/signature-lookup.d.ts +17 -2
  9. package/dist/calldata/signature-lookup.d.ts.map +1 -1
  10. package/dist/calldata/signature-lookup.js +20 -2
  11. package/dist/calldata/signature-lookup.js.map +1 -1
  12. package/dist/cli/cli.d.ts +21 -0
  13. package/dist/cli/cli.d.ts.map +1 -0
  14. package/dist/cli/{monitor.js → cli.js} +148 -74
  15. package/dist/cli/cli.js.map +1 -0
  16. package/dist/cli/lib/cli.d.ts +6 -1
  17. package/dist/cli/lib/cli.d.ts.map +1 -1
  18. package/dist/cli/lib/cli.js +58 -20
  19. package/dist/cli/lib/cli.js.map +1 -1
  20. package/dist/cli/lib/concurrency.d.ts +20 -0
  21. package/dist/cli/lib/concurrency.d.ts.map +1 -0
  22. package/dist/cli/lib/concurrency.js +32 -0
  23. package/dist/cli/lib/concurrency.js.map +1 -0
  24. package/dist/cli/tui/App.d.ts +13 -0
  25. package/dist/cli/tui/App.d.ts.map +1 -0
  26. package/dist/cli/tui/App.js +146 -0
  27. package/dist/cli/tui/App.js.map +1 -0
  28. package/dist/cli/tui/components/CollapsibleSection.d.ts +20 -0
  29. package/dist/cli/tui/components/CollapsibleSection.d.ts.map +1 -0
  30. package/dist/cli/tui/components/CollapsibleSection.js +29 -0
  31. package/dist/cli/tui/components/CollapsibleSection.js.map +1 -0
  32. package/dist/cli/tui/components/ConfirmDialog.d.ts +14 -0
  33. package/dist/cli/tui/components/ConfirmDialog.d.ts.map +1 -0
  34. package/dist/cli/tui/components/ConfirmDialog.js +29 -0
  35. package/dist/cli/tui/components/ConfirmDialog.js.map +1 -0
  36. package/dist/cli/tui/components/CopyableText.d.ts +23 -0
  37. package/dist/cli/tui/components/CopyableText.d.ts.map +1 -0
  38. package/dist/cli/tui/components/CopyableText.js +49 -0
  39. package/dist/cli/tui/components/CopyableText.js.map +1 -0
  40. package/dist/cli/tui/components/EmptyState.d.ts +11 -0
  41. package/dist/cli/tui/components/EmptyState.d.ts.map +1 -0
  42. package/dist/cli/tui/components/EmptyState.js +34 -0
  43. package/dist/cli/tui/components/EmptyState.js.map +1 -0
  44. package/dist/cli/tui/components/ErrorDisplay.d.ts +17 -0
  45. package/dist/cli/tui/components/ErrorDisplay.d.ts.map +1 -0
  46. package/dist/cli/tui/components/ErrorDisplay.js +66 -0
  47. package/dist/cli/tui/components/ErrorDisplay.js.map +1 -0
  48. package/dist/cli/tui/components/Header.d.ts +22 -0
  49. package/dist/cli/tui/components/Header.d.ts.map +1 -0
  50. package/dist/cli/tui/components/Header.js +73 -0
  51. package/dist/cli/tui/components/Header.js.map +1 -0
  52. package/dist/cli/tui/components/KeyHelp.d.ts +20 -0
  53. package/dist/cli/tui/components/KeyHelp.d.ts.map +1 -0
  54. package/dist/cli/tui/components/KeyHelp.js +136 -0
  55. package/dist/cli/tui/components/KeyHelp.js.map +1 -0
  56. package/dist/cli/tui/components/ProposalRow.d.ts +11 -0
  57. package/dist/cli/tui/components/ProposalRow.d.ts.map +1 -0
  58. package/dist/cli/tui/components/ProposalRow.js +106 -0
  59. package/dist/cli/tui/components/ProposalRow.js.map +1 -0
  60. package/dist/cli/tui/components/ScrollIndicator.d.ts +26 -0
  61. package/dist/cli/tui/components/ScrollIndicator.d.ts.map +1 -0
  62. package/dist/cli/tui/components/ScrollIndicator.js +59 -0
  63. package/dist/cli/tui/components/ScrollIndicator.js.map +1 -0
  64. package/dist/cli/tui/components/SearchBar.d.ts +12 -0
  65. package/dist/cli/tui/components/SearchBar.d.ts.map +1 -0
  66. package/dist/cli/tui/components/SearchBar.js +36 -0
  67. package/dist/cli/tui/components/SearchBar.js.map +1 -0
  68. package/dist/cli/tui/components/Skeleton.d.ts +22 -0
  69. package/dist/cli/tui/components/Skeleton.d.ts.map +1 -0
  70. package/dist/cli/tui/components/Skeleton.js +35 -0
  71. package/dist/cli/tui/components/Skeleton.js.map +1 -0
  72. package/dist/cli/tui/components/Spinner.d.ts +10 -0
  73. package/dist/cli/tui/components/Spinner.d.ts.map +1 -0
  74. package/dist/cli/tui/components/Spinner.js +24 -0
  75. package/dist/cli/tui/components/Spinner.js.map +1 -0
  76. package/dist/cli/tui/components/StageProgress.d.ts +12 -0
  77. package/dist/cli/tui/components/StageProgress.d.ts.map +1 -0
  78. package/dist/cli/tui/components/StageProgress.js +72 -0
  79. package/dist/cli/tui/components/StageProgress.js.map +1 -0
  80. package/dist/cli/tui/components/StageRow.d.ts +12 -0
  81. package/dist/cli/tui/components/StageRow.d.ts.map +1 -0
  82. package/dist/cli/tui/components/StageRow.js +106 -0
  83. package/dist/cli/tui/components/StageRow.js.map +1 -0
  84. package/dist/cli/tui/components/StatusBadge.d.ts +12 -0
  85. package/dist/cli/tui/components/StatusBadge.d.ts.map +1 -0
  86. package/dist/cli/tui/components/StatusBadge.js +27 -0
  87. package/dist/cli/tui/components/StatusBadge.js.map +1 -0
  88. package/dist/cli/tui/components/StatusBar.d.ts +12 -0
  89. package/dist/cli/tui/components/StatusBar.d.ts.map +1 -0
  90. package/dist/cli/tui/components/StatusBar.js +14 -0
  91. package/dist/cli/tui/components/StatusBar.js.map +1 -0
  92. package/dist/cli/tui/components/Timeline.d.ts +12 -0
  93. package/dist/cli/tui/components/Timeline.d.ts.map +1 -0
  94. package/dist/cli/tui/components/Timeline.js +91 -0
  95. package/dist/cli/tui/components/Timeline.js.map +1 -0
  96. package/dist/cli/tui/components/Toast.d.ts +13 -0
  97. package/dist/cli/tui/components/Toast.d.ts.map +1 -0
  98. package/dist/cli/tui/components/Toast.js +35 -0
  99. package/dist/cli/tui/components/Toast.js.map +1 -0
  100. package/dist/cli/tui/components/TrackingProgress.d.ts +24 -0
  101. package/dist/cli/tui/components/TrackingProgress.d.ts.map +1 -0
  102. package/dist/cli/tui/components/TrackingProgress.js +82 -0
  103. package/dist/cli/tui/components/TrackingProgress.js.map +1 -0
  104. package/dist/cli/tui/components/ViewLayout.d.ts +26 -0
  105. package/dist/cli/tui/components/ViewLayout.d.ts.map +1 -0
  106. package/dist/cli/tui/components/ViewLayout.js +57 -0
  107. package/dist/cli/tui/components/ViewLayout.js.map +1 -0
  108. package/dist/cli/tui/components/VotingStats.d.ts +11 -0
  109. package/dist/cli/tui/components/VotingStats.d.ts.map +1 -0
  110. package/dist/cli/tui/components/VotingStats.js +87 -0
  111. package/dist/cli/tui/components/VotingStats.js.map +1 -0
  112. package/dist/cli/tui/config.d.ts +42 -0
  113. package/dist/cli/tui/config.d.ts.map +1 -0
  114. package/dist/cli/tui/config.js +144 -0
  115. package/dist/cli/tui/config.js.map +1 -0
  116. package/dist/cli/tui/hooks/index.d.ts +12 -0
  117. package/dist/cli/tui/hooks/index.d.ts.map +1 -0
  118. package/dist/cli/tui/hooks/index.js +18 -0
  119. package/dist/cli/tui/hooks/index.js.map +1 -0
  120. package/dist/cli/tui/hooks/useCache.d.ts +12 -0
  121. package/dist/cli/tui/hooks/useCache.d.ts.map +1 -0
  122. package/dist/cli/tui/hooks/useCache.js +110 -0
  123. package/dist/cli/tui/hooks/useCache.js.map +1 -0
  124. package/dist/cli/tui/hooks/useCliProcess.d.ts +19 -0
  125. package/dist/cli/tui/hooks/useCliProcess.d.ts.map +1 -0
  126. package/dist/cli/tui/hooks/useCliProcess.js +135 -0
  127. package/dist/cli/tui/hooks/useCliProcess.js.map +1 -0
  128. package/dist/cli/tui/hooks/useNavigation.d.ts +40 -0
  129. package/dist/cli/tui/hooks/useNavigation.d.ts.map +1 -0
  130. package/dist/cli/tui/hooks/useNavigation.js +283 -0
  131. package/dist/cli/tui/hooks/useNavigation.js.map +1 -0
  132. package/dist/cli/tui/hooks/useProposals.d.ts +10 -0
  133. package/dist/cli/tui/hooks/useProposals.d.ts.map +1 -0
  134. package/dist/cli/tui/hooks/useProposals.js +215 -0
  135. package/dist/cli/tui/hooks/useProposals.js.map +1 -0
  136. package/dist/cli/tui/hooks/useStageCalldata.d.ts +17 -0
  137. package/dist/cli/tui/hooks/useStageCalldata.d.ts.map +1 -0
  138. package/dist/cli/tui/hooks/useStageCalldata.js +77 -0
  139. package/dist/cli/tui/hooks/useStageCalldata.js.map +1 -0
  140. package/dist/cli/tui/hooks/useTracker.d.ts +27 -0
  141. package/dist/cli/tui/hooks/useTracker.d.ts.map +1 -0
  142. package/dist/cli/tui/hooks/useTracker.js +205 -0
  143. package/dist/cli/tui/hooks/useTracker.js.map +1 -0
  144. package/dist/cli/tui/index.d.ts +15 -0
  145. package/dist/cli/tui/index.d.ts.map +1 -0
  146. package/dist/cli/tui/index.js +100 -0
  147. package/dist/cli/tui/index.js.map +1 -0
  148. package/dist/cli/tui/ink-wrapper.d.ts +43 -0
  149. package/dist/cli/tui/ink-wrapper.d.ts.map +1 -0
  150. package/dist/cli/tui/ink-wrapper.js +41 -0
  151. package/dist/cli/tui/ink-wrapper.js.map +1 -0
  152. package/dist/cli/tui/types.d.ts +37 -0
  153. package/dist/cli/tui/types.d.ts.map +1 -0
  154. package/dist/cli/tui/types.js +6 -0
  155. package/dist/cli/tui/types.js.map +1 -0
  156. package/dist/cli/tui/utils/clipboard.d.ts +7 -0
  157. package/dist/cli/tui/utils/clipboard.d.ts.map +1 -0
  158. package/dist/cli/tui/utils/clipboard.js +46 -0
  159. package/dist/cli/tui/utils/clipboard.js.map +1 -0
  160. package/dist/cli/tui/utils/index.d.ts +5 -0
  161. package/dist/cli/tui/utils/index.d.ts.map +1 -0
  162. package/dist/cli/tui/utils/index.js +13 -0
  163. package/dist/cli/tui/utils/index.js.map +1 -0
  164. package/dist/cli/tui/utils/terminal.d.ts +18 -0
  165. package/dist/cli/tui/utils/terminal.d.ts.map +1 -0
  166. package/dist/cli/tui/utils/terminal.js +26 -0
  167. package/dist/cli/tui/utils/terminal.js.map +1 -0
  168. package/dist/cli/tui/utils/text.d.ts +12 -0
  169. package/dist/cli/tui/utils/text.d.ts.map +1 -0
  170. package/dist/cli/tui/utils/text.js +30 -0
  171. package/dist/cli/tui/utils/text.js.map +1 -0
  172. package/dist/cli/tui/views/CalldataView.d.ts +12 -0
  173. package/dist/cli/tui/views/CalldataView.d.ts.map +1 -0
  174. package/dist/cli/tui/views/CalldataView.js +194 -0
  175. package/dist/cli/tui/views/CalldataView.js.map +1 -0
  176. package/dist/cli/tui/views/DescriptionView.d.ts +12 -0
  177. package/dist/cli/tui/views/DescriptionView.d.ts.map +1 -0
  178. package/dist/cli/tui/views/DescriptionView.js +182 -0
  179. package/dist/cli/tui/views/DescriptionView.js.map +1 -0
  180. package/dist/cli/tui/views/ElectionView.d.ts +12 -0
  181. package/dist/cli/tui/views/ElectionView.d.ts.map +1 -0
  182. package/dist/cli/tui/views/ElectionView.js +197 -0
  183. package/dist/cli/tui/views/ElectionView.js.map +1 -0
  184. package/dist/cli/tui/views/HelpView.d.ts +10 -0
  185. package/dist/cli/tui/views/HelpView.d.ts.map +1 -0
  186. package/dist/cli/tui/views/HelpView.js +159 -0
  187. package/dist/cli/tui/views/HelpView.js.map +1 -0
  188. package/dist/cli/tui/views/ProposalDetail.d.ts +14 -0
  189. package/dist/cli/tui/views/ProposalDetail.d.ts.map +1 -0
  190. package/dist/cli/tui/views/ProposalDetail.js +167 -0
  191. package/dist/cli/tui/views/ProposalDetail.js.map +1 -0
  192. package/dist/cli/tui/views/ProposalList.d.ts +17 -0
  193. package/dist/cli/tui/views/ProposalList.d.ts.map +1 -0
  194. package/dist/cli/tui/views/ProposalList.js +126 -0
  195. package/dist/cli/tui/views/ProposalList.js.map +1 -0
  196. package/dist/cli/tui/views/SettingsView.d.ts +12 -0
  197. package/dist/cli/tui/views/SettingsView.d.ts.map +1 -0
  198. package/dist/cli/tui/views/SettingsView.js +203 -0
  199. package/dist/cli/tui/views/SettingsView.js.map +1 -0
  200. package/dist/cli/tui/views/SimulationView.d.ts +12 -0
  201. package/dist/cli/tui/views/SimulationView.d.ts.map +1 -0
  202. package/dist/cli/tui/views/SimulationView.js +112 -0
  203. package/dist/cli/tui/views/SimulationView.js.map +1 -0
  204. package/dist/cli/tui/views/StageView.d.ts +12 -0
  205. package/dist/cli/tui/views/StageView.d.ts.map +1 -0
  206. package/dist/cli/tui/views/StageView.js +215 -0
  207. package/dist/cli/tui/views/StageView.js.map +1 -0
  208. package/dist/constants.d.ts +1 -0
  209. package/dist/constants.d.ts.map +1 -1
  210. package/dist/constants.js +1 -0
  211. package/dist/constants.js.map +1 -1
  212. package/dist/data/bundled-cache.json +6651 -2485
  213. package/dist/discovery/governor-discovery.d.ts.map +1 -1
  214. package/dist/discovery/governor-discovery.js +2 -1
  215. package/dist/discovery/governor-discovery.js.map +1 -1
  216. package/dist/index.d.ts +22 -3
  217. package/dist/index.d.ts.map +1 -1
  218. package/dist/index.js +28 -3
  219. package/dist/index.js.map +1 -1
  220. package/dist/stages/l2-to-l1-message.d.ts +5 -0
  221. package/dist/stages/l2-to-l1-message.d.ts.map +1 -1
  222. package/dist/stages/l2-to-l1-message.js +73 -7
  223. package/dist/stages/l2-to-l1-message.js.map +1 -1
  224. package/dist/stages/timelock.d.ts.map +1 -1
  225. package/dist/stages/timelock.js +10 -3
  226. package/dist/stages/timelock.js.map +1 -1
  227. package/dist/stages/utils.d.ts +5 -2
  228. package/dist/stages/utils.d.ts.map +1 -1
  229. package/dist/stages/utils.js +14 -6
  230. package/dist/stages/utils.js.map +1 -1
  231. package/dist/tracker/cache.d.ts +27 -0
  232. package/dist/tracker/cache.d.ts.map +1 -1
  233. package/dist/tracker/cache.js +50 -2
  234. package/dist/tracker/cache.js.map +1 -1
  235. package/dist/tracker/execute.d.ts.map +1 -1
  236. package/dist/tracker/execute.js +25 -1
  237. package/dist/tracker/execute.js.map +1 -1
  238. package/dist/types/stages.d.ts +15 -2
  239. package/dist/types/stages.d.ts.map +1 -1
  240. package/dist/types/stages.js.map +1 -1
  241. package/dist/types/tracking.d.ts +4 -0
  242. package/dist/types/tracking.d.ts.map +1 -1
  243. package/dist/utils/sanitize.d.ts +28 -0
  244. package/dist/utils/sanitize.d.ts.map +1 -0
  245. package/dist/utils/sanitize.js +52 -0
  246. package/dist/utils/sanitize.js.map +1 -0
  247. package/package.json +28 -16
  248. package/dist/cli/monitor.d.ts +0 -3
  249. package/dist/cli/monitor.d.ts.map +0 -1
  250. package/dist/cli/monitor.js.map +0 -1
@@ -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,22 @@
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
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,35 @@
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
@@ -0,0 +1 @@
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"}
@@ -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;AAE5D,UAAU,kBAAkB;IAC1B,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAmCD,wBAAgB,aAAa,CAAC,EAC5B,MAAM,EACN,YAAY,EACZ,WAAe,GAChB,EAAE,kBAAkB,GAAG,KAAK,CAAC,YAAY,CA+CzC"}
@@ -0,0 +1,72 @@
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 STAGE_TYPES = [
9
+ "PROPOSAL_CREATED",
10
+ "VOTING_ACTIVE",
11
+ "PROPOSAL_QUEUED",
12
+ "L2_TIMELOCK",
13
+ "L2_TO_L1_MESSAGE",
14
+ "L1_TIMELOCK",
15
+ "RETRYABLE_EXECUTED",
16
+ ];
17
+ function getStatusIcon(stage) {
18
+ if (!stage)
19
+ return "○";
20
+ switch (stage.status) {
21
+ case "COMPLETED": return "●";
22
+ case "READY": return "◉";
23
+ case "PENDING": return "◐";
24
+ case "FAILED": return "✗";
25
+ case "SKIPPED": return "○";
26
+ default: return "○";
27
+ }
28
+ }
29
+ function getStatusColor(stage) {
30
+ if (!stage)
31
+ return "gray";
32
+ switch (stage.status) {
33
+ case "COMPLETED": return "green";
34
+ case "READY": return "cyan";
35
+ case "PENDING": return "yellow";
36
+ case "FAILED": return "red";
37
+ default: return "gray";
38
+ }
39
+ }
40
+ function StageProgress({ stages, currentIndex, totalStages = 7, }) {
41
+ const completedCount = stages.filter(s => s.status === "COMPLETED").length;
42
+ const readyCount = stages.filter(s => s.status === "READY").length;
43
+ const pendingCount = stages.filter(s => s.status === "PENDING").length;
44
+ return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { flexDirection: "column" },
45
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginBottom: 1 },
46
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "Progress: "),
47
+ STAGE_TYPES.map((type, i) => {
48
+ const stage = stages.find(s => s.type === type);
49
+ const icon = getStatusIcon(stage);
50
+ const color = getStatusColor(stage);
51
+ const isSelected = i === currentIndex;
52
+ const keyNum = i + 1;
53
+ return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: type },
54
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : color, bold: isSelected },
55
+ isSelected ? "[" : " ",
56
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "white" : "gray" }, keyNum),
57
+ icon,
58
+ isSelected ? "]" : " "),
59
+ i < totalStages - 1 && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2500")));
60
+ }),
61
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " "),
62
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green" }, completedCount),
63
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"),
64
+ readyCount > 0 && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.React.Fragment, null,
65
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "cyan" }, readyCount),
66
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"))),
67
+ pendingCount > 0 && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.React.Fragment, null,
68
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "yellow" }, pendingCount),
69
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "/"))),
70
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, totalStages))));
71
+ }
72
+ //# sourceMappingURL=StageProgress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StageProgress.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/StageProgress.tsx"],"names":[],"mappings":"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"}
@@ -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;AAI5D,UAAU,aAAa;IACrB,KAAK,EAAE,YAAY,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,OAAO,CAAC;CACrB;AAoGD,wBAAgB,QAAQ,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,aAAa,GAAG,KAAK,CAAC,YAAY,CAwBxF"}
@@ -0,0 +1,106 @@
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
+ function formatTiming(stage) {
11
+ if (stage.timing?.eta) {
12
+ const now = Date.now();
13
+ const etaMs = stage.timing.eta * 1000;
14
+ const diff = etaMs - now;
15
+ if (diff > 0) {
16
+ const hours = Math.floor(diff / (1000 * 60 * 60));
17
+ const mins = Math.floor((diff % (1000 * 60 * 60)) / (1000 * 60));
18
+ if (hours > 48) {
19
+ const days = Math.floor(hours / 24);
20
+ return { text: `${days}d ${hours % 24}h`, color: "gray", isCountdown: true };
21
+ }
22
+ if (hours > 24) {
23
+ return { text: `${hours}h ${mins}m`, color: "yellow", isCountdown: true };
24
+ }
25
+ if (hours > 1) {
26
+ return { text: `${hours}h ${mins}m`, color: "yellow", isCountdown: true };
27
+ }
28
+ return { text: `${mins}m`, color: "green", isCountdown: true };
29
+ }
30
+ return {
31
+ text: new Date(etaMs).toLocaleDateString(),
32
+ color: "gray",
33
+ isCountdown: false
34
+ };
35
+ }
36
+ if (stage.transactions.length > 0) {
37
+ const tx = stage.transactions[0];
38
+ if (tx.timestamp) {
39
+ const date = new Date(tx.timestamp * 1000);
40
+ const now = Date.now();
41
+ const elapsed = now - tx.timestamp * 1000;
42
+ if (elapsed < 60 * 60 * 1000) {
43
+ const mins = Math.floor(elapsed / (1000 * 60));
44
+ return { text: `${mins}m ago`, color: "gray", isCountdown: false };
45
+ }
46
+ if (elapsed < 24 * 60 * 60 * 1000) {
47
+ const hours = Math.floor(elapsed / (1000 * 60 * 60));
48
+ return { text: `${hours}h ago`, color: "gray", isCountdown: false };
49
+ }
50
+ return { text: date.toLocaleDateString(), color: "gray", isCountdown: false };
51
+ }
52
+ }
53
+ return null;
54
+ }
55
+ function getStageExtra(stage) {
56
+ if (stage.type === "VOTING_ACTIVE" && stage.data) {
57
+ const data = stage.data;
58
+ if (data.proposalState) {
59
+ return data.proposalState;
60
+ }
61
+ }
62
+ if (stage.type === "RETRYABLE_EXECUTED" && stage.data) {
63
+ const data = stage.data;
64
+ if (data.ticketCount !== undefined) {
65
+ const redeemed = data.redeemedCount ?? 0;
66
+ return `${redeemed}/${data.ticketCount} tickets`;
67
+ }
68
+ }
69
+ if ((stage.type === "L2_TIMELOCK" || stage.type === "L1_TIMELOCK") &&
70
+ stage.data) {
71
+ const data = stage.data;
72
+ if (data.state)
73
+ return data.state;
74
+ }
75
+ if (stage.type === "L2_TO_L1_MESSAGE" && stage.data) {
76
+ const data = stage.data;
77
+ if (data.messageCount) {
78
+ const status = data.status ?? "pending";
79
+ return `${data.messageCount} msg${data.messageCount > 1 ? "s" : ""} (${status})`;
80
+ }
81
+ }
82
+ return null;
83
+ }
84
+ function StageRow({ stage, index, isSelected }) {
85
+ const title = (0, stage_metadata_js_1.formatStageTitle)(stage.type);
86
+ const timing = formatTiming(stage);
87
+ const extra = getStageExtra(stage);
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 },
90
+ isSelected ? ">" : " ",
91
+ " ",
92
+ index + 1,
93
+ ".",
94
+ " "),
95
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : undefined, bold: isSelected }, title.padEnd(18)),
96
+ ink_wrapper_js_1.React.createElement(StatusBadge_js_1.StatusBadge, { status: stage.status, padded: true }),
97
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, stage.chain.padEnd(10)),
98
+ timing ? (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: timing.color },
99
+ timing.isCountdown && "⏱ ",
100
+ timing.text.padEnd(timing.isCountdown ? 10 : 12))) : (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, " ".repeat(12))),
101
+ extra && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" },
102
+ "[",
103
+ extra,
104
+ "]")));
105
+ }
106
+ //# 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,12 @@
1
+ /**
2
+ * Status bar component for displaying contextual information
3
+ */
4
+ interface StatusBarProps {
5
+ left?: string;
6
+ center?: string;
7
+ right?: string;
8
+ color?: string;
9
+ }
10
+ export declare function StatusBar({ left, center, right, color }: StatusBarProps): React.ReactElement;
11
+ export {};
12
+ //# sourceMappingURL=StatusBar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusBar.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/StatusBar.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAIH,UAAU,cAAc;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,SAAS,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAc,EAAE,EAAE,cAAc,GAAG,KAAK,CAAC,YAAY,CAQrG"}
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ /**
3
+ * Status bar component for displaying contextual information
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.StatusBar = StatusBar;
7
+ const ink_wrapper_js_1 = require("../ink-wrapper.js");
8
+ function StatusBar({ left, center, right, color = "gray" }) {
9
+ return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { borderStyle: "single", borderColor: color, paddingX: 1, justifyContent: "space-between" },
10
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: color }, left ?? ""),
11
+ center && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: color }, center),
12
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: color }, right ?? "")));
13
+ }
14
+ //# sourceMappingURL=StatusBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusBar.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/StatusBar.tsx"],"names":[],"mappings":";AAAA;;GAEG;;AAWH,8BAQC;AAjBD,sDAAqD;AASrD,SAAgB,SAAS,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,MAAM,EAAkB;IAC/E,OAAO,CACL,qCAAC,oBAAG,IAAC,WAAW,EAAC,QAAQ,EAAC,WAAW,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,cAAc,EAAC,eAAe;QACvF,qCAAC,qBAAI,IAAC,KAAK,EAAE,KAAK,IAAG,IAAI,IAAI,EAAE,CAAQ;QACtC,MAAM,IAAI,qCAAC,qBAAI,IAAC,KAAK,EAAE,KAAK,IAAG,MAAM,CAAQ;QAC9C,qCAAC,qBAAI,IAAC,KAAK,EAAE,KAAK,IAAG,KAAK,IAAI,EAAE,CAAQ,CACpC,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Timeline visualization component for proposal stages
3
+ */
4
+ import type { TrackedStage } from "../../../types/index.js";
5
+ interface TimelineProps {
6
+ stages: TrackedStage[];
7
+ currentIndex: number;
8
+ compact?: boolean;
9
+ }
10
+ export declare function Timeline({ stages, currentIndex, compact }: TimelineProps): React.ReactElement;
11
+ export {};
12
+ //# sourceMappingURL=Timeline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Timeline.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/Timeline.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAE5D,UAAU,aAAa;IACrB,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AA8CD,wBAAgB,QAAQ,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,OAAe,EAAE,EAAE,aAAa,GAAG,KAAK,CAAC,YAAY,CA2DrG"}
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ /**
3
+ * Timeline visualization component for proposal stages
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Timeline = Timeline;
7
+ const ink_wrapper_js_1 = require("../ink-wrapper.js");
8
+ const STAGE_LABELS = {
9
+ PROPOSAL_CREATED: "Created",
10
+ VOTING_ACTIVE: "Voting",
11
+ PROPOSAL_QUEUED: "Queued",
12
+ L2_TIMELOCK: "L2 Lock",
13
+ L2_TO_L1_MESSAGE: "Bridge",
14
+ L1_TIMELOCK: "L1 Lock",
15
+ RETRYABLE_EXECUTED: "Execute",
16
+ };
17
+ function getStageIcon(stage) {
18
+ switch (stage.status) {
19
+ case "COMPLETED":
20
+ return "●";
21
+ case "READY":
22
+ return "◉";
23
+ case "PENDING":
24
+ return "◐";
25
+ case "FAILED":
26
+ return "✗";
27
+ case "SKIPPED":
28
+ return "○";
29
+ default:
30
+ return "·";
31
+ }
32
+ }
33
+ function getStageColor(stage) {
34
+ switch (stage.status) {
35
+ case "COMPLETED":
36
+ return "green";
37
+ case "READY":
38
+ return "cyan";
39
+ case "PENDING":
40
+ return "yellow";
41
+ case "FAILED":
42
+ return "red";
43
+ case "SKIPPED":
44
+ return "gray";
45
+ default:
46
+ return "gray";
47
+ }
48
+ }
49
+ function Timeline({ stages, currentIndex, compact = false }) {
50
+ const totalStages = 7;
51
+ const stageTypes = [
52
+ "PROPOSAL_CREATED",
53
+ "VOTING_ACTIVE",
54
+ "PROPOSAL_QUEUED",
55
+ "L2_TIMELOCK",
56
+ "L2_TO_L1_MESSAGE",
57
+ "L1_TIMELOCK",
58
+ "RETRYABLE_EXECUTED",
59
+ ];
60
+ if (compact) {
61
+ return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null, stageTypes.map((type, i) => {
62
+ const stage = stages.find(s => s.type === type);
63
+ const icon = stage ? getStageIcon(stage) : "·";
64
+ const color = stage ? getStageColor(stage) : "gray";
65
+ const isSelected = i === currentIndex;
66
+ return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { key: type },
67
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : color, bold: isSelected }, icon),
68
+ i < totalStages - 1 && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2500")));
69
+ })));
70
+ }
71
+ return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { flexDirection: "column" }, stageTypes.map((type, i) => {
72
+ const stage = stages.find(s => s.type === type);
73
+ const icon = stage ? getStageIcon(stage) : "·";
74
+ const color = stage ? getStageColor(stage) : "gray";
75
+ const label = STAGE_LABELS[type] || type;
76
+ const isSelected = i === currentIndex;
77
+ const isLast = i === totalStages - 1;
78
+ return (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { key: type, flexDirection: "column" },
79
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, null,
80
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: isSelected ? "cyan" : color, bold: isSelected },
81
+ isSelected ? ">" : " ",
82
+ " ",
83
+ icon,
84
+ " ",
85
+ label),
86
+ stage?.executable && ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "green", bold: true }, " [READY]")),
87
+ !isLast && (ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Box, { marginLeft: 2 },
88
+ ink_wrapper_js_1.React.createElement(ink_wrapper_js_1.Text, { color: "gray" }, "\u2502")))));
89
+ })));
90
+ }
91
+ //# sourceMappingURL=Timeline.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Timeline.js","sourceRoot":"","sources":["../../../../src/cli/tui/components/Timeline.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Toast notification component
3
+ */
4
+ type ToastType = "success" | "error" | "info" | "warning";
5
+ interface ToastProps {
6
+ message: string;
7
+ type?: ToastType;
8
+ duration?: number;
9
+ onDismiss?: () => void;
10
+ }
11
+ export declare function Toast({ message, type, duration, onDismiss, }: ToastProps): React.ReactElement | null;
12
+ export {};
13
+ //# sourceMappingURL=Toast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/Toast.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAIH,KAAK,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,MAAM,GAAG,SAAS,CAAC;AAE1D,UAAU,UAAU;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;CACxB;AASD,wBAAgB,KAAK,CAAC,EACpB,OAAO,EACP,IAAa,EACb,QAAe,EACf,SAAS,GACV,EAAE,UAAU,GAAG,KAAK,CAAC,YAAY,GAAG,IAAI,CA4BxC"}