claudeup 0.6.4 → 1.0.0

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 (205) hide show
  1. package/bin/claudeup.js +1 -1
  2. package/dist/data/marketplaces.d.ts +2 -0
  3. package/dist/data/marketplaces.d.ts.map +1 -1
  4. package/dist/data/marketplaces.js +51 -8
  5. package/dist/data/marketplaces.js.map +1 -1
  6. package/dist/data/mcp-servers.d.ts.map +1 -1
  7. package/dist/data/mcp-servers.js +82 -0
  8. package/dist/data/mcp-servers.js.map +1 -1
  9. package/dist/index.js +8 -5
  10. package/dist/index.js.map +1 -1
  11. package/dist/main.d.ts +3 -0
  12. package/dist/main.d.ts.map +1 -0
  13. package/dist/main.js +79 -0
  14. package/dist/main.js.map +1 -0
  15. package/dist/services/claude-settings.d.ts +8 -1
  16. package/dist/services/claude-settings.d.ts.map +1 -1
  17. package/dist/services/claude-settings.js +79 -0
  18. package/dist/services/claude-settings.js.map +1 -1
  19. package/dist/services/local-marketplace.d.ts +76 -0
  20. package/dist/services/local-marketplace.d.ts.map +1 -0
  21. package/dist/services/local-marketplace.js +340 -0
  22. package/dist/services/local-marketplace.js.map +1 -0
  23. package/dist/services/plugin-manager.d.ts +39 -2
  24. package/dist/services/plugin-manager.d.ts.map +1 -1
  25. package/dist/services/plugin-manager.js +259 -9
  26. package/dist/services/plugin-manager.js.map +1 -1
  27. package/dist/types/index.d.ts +6 -1
  28. package/dist/types/index.d.ts.map +1 -1
  29. package/dist/ui/InkApp.d.ts +5 -0
  30. package/dist/ui/InkApp.d.ts.map +1 -0
  31. package/dist/ui/InkApp.js +175 -0
  32. package/dist/ui/InkApp.js.map +1 -0
  33. package/dist/ui/components/CategoryHeader.d.ts +16 -0
  34. package/dist/ui/components/CategoryHeader.d.ts.map +1 -0
  35. package/dist/ui/components/CategoryHeader.js +11 -0
  36. package/dist/ui/components/CategoryHeader.js.map +1 -0
  37. package/dist/ui/components/ScrollableList.d.ts +16 -0
  38. package/dist/ui/components/ScrollableList.d.ts.map +1 -0
  39. package/dist/ui/components/ScrollableList.js +35 -0
  40. package/dist/ui/components/ScrollableList.js.map +1 -0
  41. package/dist/ui/components/SearchInput.d.ts +18 -0
  42. package/dist/ui/components/SearchInput.d.ts.map +1 -0
  43. package/dist/ui/components/SearchInput.js +30 -0
  44. package/dist/ui/components/SearchInput.js.map +1 -0
  45. package/dist/ui/components/TabBar.d.ts +8 -0
  46. package/dist/ui/components/TabBar.d.ts.map +1 -0
  47. package/dist/ui/components/TabBar.js +18 -0
  48. package/dist/ui/components/TabBar.js.map +1 -0
  49. package/dist/ui/components/layout/Footer.d.ts +14 -0
  50. package/dist/ui/components/layout/Footer.d.ts.map +1 -0
  51. package/dist/ui/components/layout/Footer.js +23 -0
  52. package/dist/ui/components/layout/Footer.js.map +1 -0
  53. package/dist/ui/components/layout/Header.d.ts +4 -0
  54. package/dist/ui/components/layout/Header.d.ts.map +1 -0
  55. package/dist/ui/components/layout/Header.js +25 -0
  56. package/dist/ui/components/layout/Header.js.map +1 -0
  57. package/dist/ui/components/layout/Panel.d.ts +22 -0
  58. package/dist/ui/components/layout/Panel.d.ts.map +1 -0
  59. package/dist/ui/components/layout/Panel.js +8 -0
  60. package/dist/ui/components/layout/Panel.js.map +1 -0
  61. package/dist/ui/components/layout/ProgressBar.d.ts +12 -0
  62. package/dist/ui/components/layout/ProgressBar.d.ts.map +1 -0
  63. package/dist/ui/components/layout/ProgressBar.js +16 -0
  64. package/dist/ui/components/layout/ProgressBar.js.map +1 -0
  65. package/dist/ui/components/layout/ScopeTabs.d.ts +12 -0
  66. package/dist/ui/components/layout/ScopeTabs.d.ts.map +1 -0
  67. package/dist/ui/components/layout/ScopeTabs.js +8 -0
  68. package/dist/ui/components/layout/ScopeTabs.js.map +1 -0
  69. package/dist/ui/components/layout/ScreenLayout.d.ts +30 -0
  70. package/dist/ui/components/layout/ScreenLayout.d.ts.map +1 -0
  71. package/dist/ui/components/layout/ScreenLayout.js +23 -0
  72. package/dist/ui/components/layout/ScreenLayout.js.map +1 -0
  73. package/dist/ui/components/layout/index.d.ts +7 -0
  74. package/dist/ui/components/layout/index.d.ts.map +1 -0
  75. package/dist/ui/components/layout/index.js +7 -0
  76. package/dist/ui/components/layout/index.js.map +1 -0
  77. package/dist/ui/components/modals/ConfirmModal.d.ts +14 -0
  78. package/dist/ui/components/modals/ConfirmModal.d.ts.map +1 -0
  79. package/dist/ui/components/modals/ConfirmModal.js +15 -0
  80. package/dist/ui/components/modals/ConfirmModal.js.map +1 -0
  81. package/dist/ui/components/modals/InputModal.d.ts +16 -0
  82. package/dist/ui/components/modals/InputModal.d.ts.map +1 -0
  83. package/dist/ui/components/modals/InputModal.js +23 -0
  84. package/dist/ui/components/modals/InputModal.js.map +1 -0
  85. package/dist/ui/components/modals/LoadingModal.d.ts +8 -0
  86. package/dist/ui/components/modals/LoadingModal.d.ts.map +1 -0
  87. package/dist/ui/components/modals/LoadingModal.js +8 -0
  88. package/dist/ui/components/modals/LoadingModal.js.map +1 -0
  89. package/dist/ui/components/modals/MessageModal.d.ts +14 -0
  90. package/dist/ui/components/modals/MessageModal.d.ts.map +1 -0
  91. package/dist/ui/components/modals/MessageModal.js +17 -0
  92. package/dist/ui/components/modals/MessageModal.js.map +1 -0
  93. package/dist/ui/components/modals/ModalContainer.d.ts +7 -0
  94. package/dist/ui/components/modals/ModalContainer.d.ts.map +1 -0
  95. package/dist/ui/components/modals/ModalContainer.js +38 -0
  96. package/dist/ui/components/modals/ModalContainer.js.map +1 -0
  97. package/dist/ui/components/modals/SelectModal.d.ts +17 -0
  98. package/dist/ui/components/modals/SelectModal.d.ts.map +1 -0
  99. package/dist/ui/components/modals/SelectModal.js +33 -0
  100. package/dist/ui/components/modals/SelectModal.js.map +1 -0
  101. package/dist/ui/components/modals/index.d.ts +7 -0
  102. package/dist/ui/components/modals/index.d.ts.map +1 -0
  103. package/dist/ui/components/modals/index.js +7 -0
  104. package/dist/ui/components/modals/index.js.map +1 -0
  105. package/dist/ui/hooks/index.d.ts +3 -0
  106. package/dist/ui/hooks/index.d.ts.map +1 -0
  107. package/dist/ui/hooks/index.js +3 -0
  108. package/dist/ui/hooks/index.js.map +1 -0
  109. package/dist/ui/hooks/useAsyncData.d.ts +40 -0
  110. package/dist/ui/hooks/useAsyncData.d.ts.map +1 -0
  111. package/dist/ui/hooks/useAsyncData.js +78 -0
  112. package/dist/ui/hooks/useAsyncData.js.map +1 -0
  113. package/dist/ui/hooks/useKeyboardNavigation.d.ts +27 -0
  114. package/dist/ui/hooks/useKeyboardNavigation.d.ts.map +1 -0
  115. package/dist/ui/hooks/useKeyboardNavigation.js +82 -0
  116. package/dist/ui/hooks/useKeyboardNavigation.js.map +1 -0
  117. package/dist/ui/screens/CliToolsScreen.d.ts +4 -0
  118. package/dist/ui/screens/CliToolsScreen.d.ts.map +1 -0
  119. package/dist/ui/screens/CliToolsScreen.js +268 -0
  120. package/dist/ui/screens/CliToolsScreen.js.map +1 -0
  121. package/dist/ui/screens/EnvVarsScreen.d.ts +4 -0
  122. package/dist/ui/screens/EnvVarsScreen.d.ts.map +1 -0
  123. package/dist/ui/screens/EnvVarsScreen.js +145 -0
  124. package/dist/ui/screens/EnvVarsScreen.js.map +1 -0
  125. package/dist/ui/screens/McpRegistryScreen.d.ts +4 -0
  126. package/dist/ui/screens/McpRegistryScreen.d.ts.map +1 -0
  127. package/dist/ui/screens/McpRegistryScreen.js +226 -0
  128. package/dist/ui/screens/McpRegistryScreen.js.map +1 -0
  129. package/dist/ui/screens/McpScreen.d.ts +4 -0
  130. package/dist/ui/screens/McpScreen.d.ts.map +1 -0
  131. package/dist/ui/screens/McpScreen.js +222 -0
  132. package/dist/ui/screens/McpScreen.js.map +1 -0
  133. package/dist/ui/screens/ModelSelectorScreen.d.ts +4 -0
  134. package/dist/ui/screens/ModelSelectorScreen.d.ts.map +1 -0
  135. package/dist/ui/screens/ModelSelectorScreen.js +143 -0
  136. package/dist/ui/screens/ModelSelectorScreen.js.map +1 -0
  137. package/dist/ui/screens/PluginsScreen.d.ts +4 -0
  138. package/dist/ui/screens/PluginsScreen.d.ts.map +1 -0
  139. package/dist/ui/screens/PluginsScreen.js +747 -0
  140. package/dist/ui/screens/PluginsScreen.js.map +1 -0
  141. package/dist/ui/screens/StatusLineScreen.d.ts +4 -0
  142. package/dist/ui/screens/StatusLineScreen.d.ts.map +1 -0
  143. package/dist/ui/screens/StatusLineScreen.js +197 -0
  144. package/dist/ui/screens/StatusLineScreen.js.map +1 -0
  145. package/dist/ui/screens/index.d.ts +8 -0
  146. package/dist/ui/screens/index.d.ts.map +1 -0
  147. package/dist/ui/screens/index.js +8 -0
  148. package/dist/ui/screens/index.js.map +1 -0
  149. package/dist/ui/state/AppContext.d.ts +40 -0
  150. package/dist/ui/state/AppContext.d.ts.map +1 -0
  151. package/dist/ui/state/AppContext.js +162 -0
  152. package/dist/ui/state/AppContext.js.map +1 -0
  153. package/dist/ui/state/DimensionsContext.d.ts +25 -0
  154. package/dist/ui/state/DimensionsContext.d.ts.map +1 -0
  155. package/dist/ui/state/DimensionsContext.js +68 -0
  156. package/dist/ui/state/DimensionsContext.js.map +1 -0
  157. package/dist/ui/state/reducer.d.ts +4 -0
  158. package/dist/ui/state/reducer.d.ts.map +1 -0
  159. package/dist/ui/state/reducer.js +412 -0
  160. package/dist/ui/state/reducer.js.map +1 -0
  161. package/dist/ui/state/types.d.ts +266 -0
  162. package/dist/ui/state/types.d.ts.map +1 -0
  163. package/dist/ui/state/types.js +2 -0
  164. package/dist/ui/state/types.js.map +1 -0
  165. package/dist/utils/fuzzy-search.d.ts +33 -0
  166. package/dist/utils/fuzzy-search.d.ts.map +1 -0
  167. package/dist/utils/fuzzy-search.js +102 -0
  168. package/dist/utils/fuzzy-search.js.map +1 -0
  169. package/dist/utils/string-utils.d.ts +24 -0
  170. package/dist/utils/string-utils.d.ts.map +1 -0
  171. package/dist/utils/string-utils.js +62 -0
  172. package/dist/utils/string-utils.js.map +1 -0
  173. package/package.json +19 -7
  174. package/dist/ui/app.d.ts +0 -38
  175. package/dist/ui/app.d.ts.map +0 -1
  176. package/dist/ui/app.js +0 -590
  177. package/dist/ui/app.js.map +0 -1
  178. package/dist/ui/screens/cli-tools.d.ts +0 -4
  179. package/dist/ui/screens/cli-tools.d.ts.map +0 -1
  180. package/dist/ui/screens/cli-tools.js +0 -369
  181. package/dist/ui/screens/cli-tools.js.map +0 -1
  182. package/dist/ui/screens/env-vars.d.ts +0 -3
  183. package/dist/ui/screens/env-vars.d.ts.map +0 -1
  184. package/dist/ui/screens/env-vars.js +0 -119
  185. package/dist/ui/screens/env-vars.js.map +0 -1
  186. package/dist/ui/screens/main-menu.d.ts +0 -3
  187. package/dist/ui/screens/main-menu.d.ts.map +0 -1
  188. package/dist/ui/screens/main-menu.js +0 -110
  189. package/dist/ui/screens/main-menu.js.map +0 -1
  190. package/dist/ui/screens/mcp-registry.d.ts +0 -10
  191. package/dist/ui/screens/mcp-registry.d.ts.map +0 -1
  192. package/dist/ui/screens/mcp-registry.js +0 -310
  193. package/dist/ui/screens/mcp-registry.js.map +0 -1
  194. package/dist/ui/screens/mcp-setup.d.ts +0 -4
  195. package/dist/ui/screens/mcp-setup.d.ts.map +0 -1
  196. package/dist/ui/screens/mcp-setup.js +0 -492
  197. package/dist/ui/screens/mcp-setup.js.map +0 -1
  198. package/dist/ui/screens/plugins.d.ts +0 -3
  199. package/dist/ui/screens/plugins.d.ts.map +0 -1
  200. package/dist/ui/screens/plugins.js +0 -443
  201. package/dist/ui/screens/plugins.js.map +0 -1
  202. package/dist/ui/screens/statusline.d.ts +0 -5
  203. package/dist/ui/screens/statusline.d.ts.map +0 -1
  204. package/dist/ui/screens/statusline.js +0 -235
  205. package/dist/ui/screens/statusline.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CategoryHeader.d.ts","sourceRoot":"","sources":["../../../src/ui/components/CategoryHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,mBAAmB;IAC3B,qBAAqB;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,yBAAyB;IACzB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,mCAAmC;IACnC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,kCAAkC;IAClC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,MAAM,EACN,WAAqB,EACrB,QAAe,EACf,KAAK,GACN,EAAE,mBAAmB,GAAG,KAAK,CAAC,YAAY,CAe1C;AAED,eAAe,cAAc,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Text } from 'ink';
3
+ export function CategoryHeader({ title, status, statusColor = 'green', expanded = true, count, }) {
4
+ const expandIcon = expanded ? '▼' : '▶';
5
+ const countBadge = count !== undefined ? ` (${count})` : '';
6
+ const statusText = status ? ` ${status}` : '';
7
+ // Simple format without dynamic line calculation
8
+ return (_jsxs(Text, { children: [_jsx(Text, { color: "gray", dimColor: true, children: expandIcon }), _jsxs(Text, { color: "white", bold: true, children: [" ", title] }), _jsx(Text, { color: "gray", dimColor: true, children: countBadge }), _jsx(Text, { color: "gray", dimColor: true, children: " \u2500\u2500\u2500\u2500" }), _jsx(Text, { color: statusColor, children: statusText })] }));
9
+ }
10
+ export default CategoryHeader;
11
+ //# sourceMappingURL=CategoryHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CategoryHeader.js","sourceRoot":"","sources":["../../../src/ui/components/CategoryHeader.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAe3B,MAAM,UAAU,cAAc,CAAC,EAC7B,KAAK,EACL,MAAM,EACN,WAAW,GAAG,OAAO,EACrB,QAAQ,GAAG,IAAI,EACf,KAAK,GACe;IACpB,MAAM,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IACxC,MAAM,UAAU,GAAG,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IAC5D,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAE9C,iDAAiD;IACjD,OAAO,CACL,MAAC,IAAI,eACH,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,QAAQ,kBAAE,UAAU,GAAQ,EAC/C,MAAC,IAAI,IAAC,KAAK,EAAC,OAAO,EAAC,IAAI,wBAAG,KAAK,IAAQ,EACxC,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,QAAQ,kBAAE,UAAU,GAAQ,EAC/C,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,QAAQ,gDAAa,EACxC,KAAC,IAAI,IAAC,KAAK,EAAE,WAAW,YAAG,UAAU,GAAQ,IACxC,CACR,CAAC;AACJ,CAAC;AAED,eAAe,cAAc,CAAC"}
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ interface ScrollableListProps<T> {
3
+ /** Array of items to display */
4
+ items: T[];
5
+ /** Currently selected index */
6
+ selectedIndex: number;
7
+ /** Render function for each item */
8
+ renderItem: (item: T, index: number, isSelected: boolean) => React.ReactNode;
9
+ /** Maximum visible height (number of lines) - REQUIRED for proper rendering */
10
+ maxHeight: number;
11
+ /** Show scroll indicators */
12
+ showScrollIndicators?: boolean;
13
+ }
14
+ export declare function ScrollableList<T>({ items, selectedIndex, renderItem, maxHeight, showScrollIndicators, }: ScrollableListProps<T>): React.ReactElement;
15
+ export default ScrollableList;
16
+ //# sourceMappingURL=ScrollableList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableList.d.ts","sourceRoot":"","sources":["../../../src/ui/components/ScrollableList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAuC,MAAM,OAAO,CAAC;AAG5D,UAAU,mBAAmB,CAAC,CAAC;IAC7B,gCAAgC;IAChC,KAAK,EAAE,CAAC,EAAE,CAAC;IACX,+BAA+B;IAC/B,aAAa,EAAE,MAAM,CAAC;IACtB,oCAAoC;IACpC,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,KAAK,KAAK,CAAC,SAAS,CAAC;IAC7E,+EAA+E;IAC/E,SAAS,EAAE,MAAM,CAAC;IAClB,6BAA6B;IAC7B,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAED,wBAAgB,cAAc,CAAC,CAAC,EAAE,EAChC,KAAK,EACL,aAAa,EACb,UAAU,EACV,SAAS,EACT,oBAA2B,GAC5B,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,YAAY,CAoD7C;AAED,eAAe,cAAc,CAAC"}
@@ -0,0 +1,35 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import { useState, useEffect, useMemo } from 'react';
3
+ import { Box, Text } from 'ink';
4
+ export function ScrollableList({ items, selectedIndex, renderItem, maxHeight, showScrollIndicators = true, }) {
5
+ const [scrollOffset, setScrollOffset] = useState(0);
6
+ // Account for scroll indicators in available space
7
+ const hasItemsAbove = scrollOffset > 0;
8
+ const hasItemsBelow = scrollOffset + maxHeight < items.length;
9
+ const indicatorLines = (showScrollIndicators && hasItemsAbove ? 1 : 0) + (showScrollIndicators && hasItemsBelow ? 1 : 0);
10
+ const effectiveMaxHeight = Math.max(1, maxHeight - indicatorLines);
11
+ // Adjust scroll offset to keep selected item visible
12
+ useEffect(() => {
13
+ if (selectedIndex < scrollOffset) {
14
+ // Selected is above viewport - scroll up
15
+ setScrollOffset(selectedIndex);
16
+ }
17
+ else if (selectedIndex >= scrollOffset + effectiveMaxHeight) {
18
+ // Selected is below viewport - scroll down
19
+ setScrollOffset(selectedIndex - effectiveMaxHeight + 1);
20
+ }
21
+ }, [selectedIndex, effectiveMaxHeight, scrollOffset]);
22
+ // Calculate visible items - strictly limited to effectiveMaxHeight
23
+ const visibleItems = useMemo(() => {
24
+ const start = scrollOffset;
25
+ const end = Math.min(scrollOffset + effectiveMaxHeight, items.length);
26
+ return items.slice(start, end).map((item, idx) => ({
27
+ item,
28
+ originalIndex: start + idx,
29
+ }));
30
+ }, [items, scrollOffset, effectiveMaxHeight]);
31
+ const itemsBelow = items.length - scrollOffset - effectiveMaxHeight;
32
+ return (_jsxs(Box, { flexDirection: "column", children: [showScrollIndicators && hasItemsAbove && (_jsxs(Text, { color: "cyan", children: ["\u2191 ", scrollOffset, " more"] })), visibleItems.map(({ item, originalIndex }) => (_jsx(Box, { width: "100%", overflow: "hidden", children: renderItem(item, originalIndex, originalIndex === selectedIndex) }, originalIndex))), showScrollIndicators && hasItemsBelow && (_jsxs(Text, { color: "cyan", children: ["\u2193 ", itemsBelow, " more"] }))] }));
33
+ }
34
+ export default ScrollableList;
35
+ //# sourceMappingURL=ScrollableList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableList.js","sourceRoot":"","sources":["../../../src/ui/components/ScrollableList.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAehC,MAAM,UAAU,cAAc,CAAI,EAChC,KAAK,EACL,aAAa,EACb,UAAU,EACV,SAAS,EACT,oBAAoB,GAAG,IAAI,GACJ;IACvB,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAEpD,mDAAmD;IACnD,MAAM,aAAa,GAAG,YAAY,GAAG,CAAC,CAAC;IACvC,MAAM,aAAa,GAAG,YAAY,GAAG,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC;IAC9D,MAAM,cAAc,GAAG,CAAC,oBAAoB,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,oBAAoB,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACzH,MAAM,kBAAkB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,GAAG,cAAc,CAAC,CAAC;IAEnE,qDAAqD;IACrD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,aAAa,GAAG,YAAY,EAAE,CAAC;YACjC,yCAAyC;YACzC,eAAe,CAAC,aAAa,CAAC,CAAC;QACjC,CAAC;aAAM,IAAI,aAAa,IAAI,YAAY,GAAG,kBAAkB,EAAE,CAAC;YAC9D,2CAA2C;YAC3C,eAAe,CAAC,aAAa,GAAG,kBAAkB,GAAG,CAAC,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC,EAAE,CAAC,aAAa,EAAE,kBAAkB,EAAE,YAAY,CAAC,CAAC,CAAC;IAEtD,mEAAmE;IACnE,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,EAAE;QAChC,MAAM,KAAK,GAAG,YAAY,CAAC;QAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,GAAG,kBAAkB,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QACtE,OAAO,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;YACjD,IAAI;YACJ,aAAa,EAAE,KAAK,GAAG,GAAG;SAC3B,CAAC,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,KAAK,EAAE,YAAY,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAE9C,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,GAAG,YAAY,GAAG,kBAAkB,CAAC;IAEpE,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aAExB,oBAAoB,IAAI,aAAa,IAAI,CACxC,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,wBAAI,YAAY,aAAa,CAChD,EAGA,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,CAC7C,KAAC,GAAG,IAAqB,KAAK,EAAC,MAAM,EAAC,QAAQ,EAAC,QAAQ,YACpD,UAAU,CAAC,IAAI,EAAE,aAAa,EAAE,aAAa,KAAK,aAAa,CAAC,IADzD,aAAa,CAEjB,CACP,CAAC,EAGD,oBAAoB,IAAI,aAAa,IAAI,CACxC,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,wBAAI,UAAU,aAAa,CAC9C,IACG,CACP,CAAC;AACJ,CAAC;AAED,eAAe,cAAc,CAAC"}
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ interface SearchInputProps {
3
+ /** Current search value */
4
+ value: string;
5
+ /** Called when value changes */
6
+ onChange: (value: string) => void;
7
+ /** Placeholder text when empty */
8
+ placeholder?: string;
9
+ /** Whether the input is focused/active */
10
+ isActive: boolean;
11
+ /** Called when user presses escape to exit search */
12
+ onExit?: () => void;
13
+ /** Called when user presses enter */
14
+ onSubmit?: () => void;
15
+ }
16
+ export declare function SearchInput({ value, onChange, placeholder, isActive, onExit, onSubmit, }: SearchInputProps): React.ReactElement;
17
+ export default SearchInput;
18
+ //# sourceMappingURL=SearchInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchInput.d.ts","sourceRoot":"","sources":["../../../src/ui/components/SearchInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,gBAAgB;IACxB,2BAA2B;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,gCAAgC;IAChC,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,0CAA0C;IAC1C,QAAQ,EAAE,OAAO,CAAC;IAClB,qDAAqD;IACrD,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,qCAAqC;IACrC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;CACvB;AAED,wBAAgB,WAAW,CAAC,EAC1B,KAAK,EACL,QAAQ,EACR,WAAyB,EACzB,QAAQ,EACR,MAAM,EACN,QAAQ,GACT,EAAE,gBAAgB,GAAG,KAAK,CAAC,YAAY,CAuCvC;AAED,eAAe,WAAW,CAAC"}
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text, useInput } from 'ink';
3
+ export function SearchInput({ value, onChange, placeholder = 'Search...', isActive, onExit, onSubmit, }) {
4
+ useInput((input, key) => {
5
+ if (!isActive)
6
+ return;
7
+ if (key.escape) {
8
+ onExit?.();
9
+ return;
10
+ }
11
+ if (key.return) {
12
+ onSubmit?.();
13
+ return;
14
+ }
15
+ if (key.backspace || key.delete) {
16
+ onChange(value.slice(0, -1));
17
+ return;
18
+ }
19
+ // Only accept printable characters
20
+ if (input && !key.ctrl && !key.meta) {
21
+ onChange(value + input);
22
+ }
23
+ }, { isActive });
24
+ const displayValue = value || (isActive ? '' : placeholder);
25
+ const showCursor = isActive;
26
+ const textColor = value ? 'white' : 'gray';
27
+ return (_jsxs(Box, { children: [_jsx(Text, { color: "cyan", children: "\u276F " }), _jsx(Text, { color: textColor, children: displayValue }), showCursor && _jsx(Text, { color: "cyan", children: "\u258B" })] }));
28
+ }
29
+ export default SearchInput;
30
+ //# sourceMappingURL=SearchInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchInput.js","sourceRoot":"","sources":["../../../src/ui/components/SearchInput.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAiB1C,MAAM,UAAU,WAAW,CAAC,EAC1B,KAAK,EACL,QAAQ,EACR,WAAW,GAAG,WAAW,EACzB,QAAQ,EACR,MAAM,EACN,QAAQ,GACS;IACjB,QAAQ,CACN,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACb,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACf,MAAM,EAAE,EAAE,CAAC;YACX,OAAO;QACT,CAAC;QAED,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACf,QAAQ,EAAE,EAAE,CAAC;YACb,OAAO;QACT,CAAC;QAED,IAAI,GAAG,CAAC,SAAS,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YAChC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,mCAAmC;QACnC,IAAI,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YACpC,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC,EACD,EAAE,QAAQ,EAAE,CACb,CAAC;IAEF,MAAM,YAAY,GAAG,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IAC5D,MAAM,UAAU,GAAG,QAAQ,CAAC;IAC5B,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;IAE3C,OAAO,CACL,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,wBAAU,EAC5B,KAAC,IAAI,IAAC,KAAK,EAAE,SAAS,YAAG,YAAY,GAAQ,EAC5C,UAAU,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,uBAAS,IACtC,CACP,CAAC;AACJ,CAAC;AAED,eAAe,WAAW,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import type { Screen } from '../state/types.js';
3
+ interface TabBarProps {
4
+ currentScreen: Screen;
5
+ }
6
+ export declare function TabBar({ currentScreen }: TabBarProps): React.ReactElement;
7
+ export default TabBar;
8
+ //# sourceMappingURL=TabBar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabBar.d.ts","sourceRoot":"","sources":["../../../src/ui/components/TabBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAgBhD,UAAU,WAAW;IACnB,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,wBAAgB,MAAM,CAAC,EAAE,aAAa,EAAE,EAAE,WAAW,GAAG,KAAK,CAAC,YAAY,CA8BzE;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ const TABS = [
4
+ { key: '1', label: 'Plugins', screen: 'plugins' },
5
+ { key: '2', label: 'MCP', screen: 'mcp' },
6
+ { key: '3', label: 'Status', screen: 'statusline' },
7
+ { key: '4', label: 'Env', screen: 'env-vars' },
8
+ { key: '5', label: 'CLI', screen: 'cli-tools' },
9
+ ];
10
+ export function TabBar({ currentScreen }) {
11
+ return (_jsx(Box, { flexDirection: "row", gap: 0, children: TABS.map((tab, index) => {
12
+ const isSelected = tab.screen === currentScreen;
13
+ const isLast = index === TABS.length - 1;
14
+ return (_jsxs(Box, { flexDirection: "row", children: [isSelected ? (_jsx(Box, { children: _jsxs(Text, { backgroundColor: "#7e57c2", color: "white", bold: true, children: [' ', tab.key, ":", tab.label, ' '] }) })) : (_jsx(Box, { children: _jsxs(Text, { color: "gray", children: [' ', tab.key, ":", tab.label, ' '] }) })), !isLast && _jsx(Text, { color: "gray", dimColor: true, children: "\u2502" })] }, tab.key));
15
+ }) }));
16
+ }
17
+ export default TabBar;
18
+ //# sourceMappingURL=TabBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabBar.js","sourceRoot":"","sources":["../../../src/ui/components/TabBar.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAShC,MAAM,IAAI,GAAU;IAClB,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE;IACjD,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;IACzC,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE;IACnD,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE;IAC9C,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE;CAChD,CAAC;AAMF,MAAM,UAAU,MAAM,CAAC,EAAE,aAAa,EAAe;IACnD,OAAO,CACL,KAAC,GAAG,IAAC,aAAa,EAAC,KAAK,EAAC,GAAG,EAAE,CAAC,YAC5B,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;YACvB,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,KAAK,aAAa,CAAC;YAChD,MAAM,MAAM,GAAG,KAAK,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAEzC,OAAO,CACL,MAAC,GAAG,IAAe,aAAa,EAAC,KAAK,aAEnC,UAAU,CAAC,CAAC,CAAC,CACZ,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,eAAe,EAAC,SAAS,EAAC,KAAK,EAAC,OAAO,EAAC,IAAI,mBAC/C,GAAG,EAAE,GAAG,CAAC,GAAG,OAAG,GAAG,CAAC,KAAK,EAAE,GAAG,IACzB,GACH,CACP,CAAC,CAAC,CAAC,CACF,KAAC,GAAG,cACF,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,aACf,GAAG,EAAE,GAAG,CAAC,GAAG,OAAG,GAAG,CAAC,KAAK,EAAE,GAAG,IACzB,GACH,CACP,EAEA,CAAC,MAAM,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,QAAQ,6BAAS,KAhBxC,GAAG,CAAC,GAAG,CAiBX,CACP,CAAC;QACJ,CAAC,CAAC,GACE,CACP,CAAC;AACJ,CAAC;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ interface KeyHint {
3
+ key: string;
4
+ label: string;
5
+ }
6
+ interface FooterProps {
7
+ /** Keyboard hints to display - either as string or structured array */
8
+ hints?: string;
9
+ /** Structured keyboard hints */
10
+ keys?: KeyHint[];
11
+ }
12
+ export declare function Footer({ hints, keys }: FooterProps): React.ReactElement;
13
+ export default Footer;
14
+ //# sourceMappingURL=Footer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Footer.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/layout/Footer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,OAAO;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;CACf;AAED,UAAU,WAAW;IACnB,uEAAuE;IACvE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,gCAAgC;IAChC,IAAI,CAAC,EAAE,OAAO,EAAE,CAAC;CAClB;AAED,wBAAgB,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,WAAW,GAAG,KAAK,CAAC,YAAY,CA2DvE;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { Box, Text } from 'ink';
4
+ export function Footer({ hints, keys }) {
5
+ // If using structured keys
6
+ if (keys && keys.length > 0) {
7
+ return (_jsx(Box, { borderStyle: "single", borderColor: "gray", borderTop: true, borderLeft: false, borderRight: false, borderBottom: false, paddingX: 1, marginTop: 1, children: keys.map((hint, idx) => (_jsxs(React.Fragment, { children: [_jsx(Text, { color: "yellow", bold: true, children: hint.key }), _jsxs(Text, { color: "gray", children: [" ", hint.label] }), idx < keys.length - 1 && _jsx(Text, { color: "gray", children: " \u00B7 " })] }, hint.key))) }));
8
+ }
9
+ // Parse string hints like "↑↓ Navigate │ Enter Apply │ q Back"
10
+ if (hints) {
11
+ const parts = hints.split('│').map((s) => s.trim());
12
+ return (_jsx(Box, { borderStyle: "single", borderColor: "gray", borderTop: true, borderLeft: false, borderRight: false, borderBottom: false, paddingX: 1, marginTop: 1, children: parts.map((part, idx) => {
13
+ // Split on first space to get key and label
14
+ const spaceIdx = part.indexOf(' ');
15
+ const key = spaceIdx > 0 ? part.substring(0, spaceIdx) : part;
16
+ const label = spaceIdx > 0 ? part.substring(spaceIdx + 1) : '';
17
+ return (_jsxs(React.Fragment, { children: [_jsx(Text, { color: "yellow", bold: true, children: key }), _jsxs(Text, { color: "gray", children: [" ", label] }), idx < parts.length - 1 && _jsx(Text, { color: "gray", children: " \u00B7 " })] }, idx));
18
+ }) }));
19
+ }
20
+ return _jsx(Box, {});
21
+ }
22
+ export default Footer;
23
+ //# sourceMappingURL=Footer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Footer.js","sourceRoot":"","sources":["../../../../src/ui/components/layout/Footer.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAchC,MAAM,UAAU,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAe;IACjD,2BAA2B;IAC3B,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC5B,OAAO,CACL,KAAC,GAAG,IACF,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAC,MAAM,EAClB,SAAS,QACT,UAAU,EAAE,KAAK,EACjB,WAAW,EAAE,KAAK,EAClB,YAAY,EAAE,KAAK,EACnB,QAAQ,EAAE,CAAC,EACX,SAAS,EAAE,CAAC,YAEX,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CACvB,MAAC,KAAK,CAAC,QAAQ,eACb,KAAC,IAAI,IAAC,KAAK,EAAC,QAAQ,EAAC,IAAI,kBAAE,IAAI,CAAC,GAAG,GAAQ,EAC3C,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,kBAAG,IAAI,CAAC,KAAK,IAAQ,EACtC,GAAG,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,2BAAa,KAHtC,IAAI,CAAC,GAAG,CAIZ,CAClB,CAAC,GACE,CACP,CAAC;IACJ,CAAC;IAED,+DAA+D;IAC/D,IAAI,KAAK,EAAE,CAAC;QACV,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QAEpD,OAAO,CACL,KAAC,GAAG,IACF,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAC,MAAM,EAClB,SAAS,QACT,UAAU,EAAE,KAAK,EACjB,WAAW,EAAE,KAAK,EAClB,YAAY,EAAE,KAAK,EACnB,QAAQ,EAAE,CAAC,EACX,SAAS,EAAE,CAAC,YAEX,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;gBACvB,4CAA4C;gBAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;gBACnC,MAAM,GAAG,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gBAC9D,MAAM,KAAK,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBAE/D,OAAO,CACL,MAAC,KAAK,CAAC,QAAQ,eACb,KAAC,IAAI,IAAC,KAAK,EAAC,QAAQ,EAAC,IAAI,kBAAE,GAAG,GAAQ,EACtC,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,kBAAG,KAAK,IAAQ,EACjC,GAAG,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,2BAAa,KAHvC,GAAG,CAIP,CAClB,CAAC;YACJ,CAAC,CAAC,GACE,CACP,CAAC;IACJ,CAAC;IAED,OAAO,KAAC,GAAG,KAAG,CAAC;AACjB,CAAC;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ export declare function Header(): React.ReactElement;
3
+ export default Header;
4
+ //# sourceMappingURL=Header.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Header.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/layout/Header.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAsB1B,wBAAgB,MAAM,IAAI,KAAK,CAAC,YAAY,CA+C3C;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { Box, Text } from 'ink';
4
+ import { useNavigation } from '../../state/AppContext.js';
5
+ const VERSION = '0.7.0';
6
+ const tabs = [
7
+ { key: '1', label: 'Plugins', screen: 'plugins', icon: '◈' },
8
+ { key: '2', label: 'MCP', screen: 'mcp', icon: '⚡' },
9
+ { key: '3', label: 'Status', screen: 'statusline', icon: '◐' },
10
+ { key: '4', label: 'Env', screen: 'env-vars', icon: '◉' },
11
+ { key: '5', label: 'Tools', screen: 'cli-tools', icon: '⚙' },
12
+ ];
13
+ export function Header() {
14
+ const { currentScreen } = useNavigation();
15
+ return (_jsx(Box, { flexDirection: "column", borderStyle: "round", borderColor: "magenta", paddingX: 1, children: _jsxs(Box, { justifyContent: "space-between", children: [_jsxs(Box, { children: [_jsx(Text, { bold: true, color: "magenta", children: "claudeup" }), _jsxs(Text, { color: "gray", children: [" v", VERSION] })] }), _jsx(Box, { children: tabs.map((tab, idx) => {
16
+ const isActive = currentScreen === tab.screen;
17
+ const isLast = idx === tabs.length - 1;
18
+ if (isActive) {
19
+ return (_jsxs(React.Fragment, { children: [_jsxs(Text, { backgroundColor: "magenta", color: "white", bold: true, children: [' ', tab.icon, " ", tab.key, ":", tab.label, ' '] }), !isLast && _jsx(Text, { color: "gray", children: " " })] }, tab.key));
20
+ }
21
+ return (_jsxs(React.Fragment, { children: [_jsxs(Text, { color: "gray", children: [tab.icon, " "] }), _jsxs(Text, { color: "white", dimColor: true, children: [tab.key, ":", tab.label] }), !isLast && _jsx(Text, { color: "gray", children: " " })] }, tab.key));
22
+ }) })] }) }));
23
+ }
24
+ export default Header;
25
+ //# sourceMappingURL=Header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../../src/ui/components/layout/Header.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAG1D,MAAM,OAAO,GAAG,OAAO,CAAC;AASxB,MAAM,IAAI,GAAU;IAClB,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE;IAC5D,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE;IACpD,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,EAAE,GAAG,EAAE;IAC9D,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAE;IACzD,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,EAAE;CAC7D,CAAC;AAEF,MAAM,UAAU,MAAM;IACpB,MAAM,EAAE,aAAa,EAAE,GAAG,aAAa,EAAE,CAAC;IAE1C,OAAO,CACL,KAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,WAAW,EAAC,OAAO,EACnB,WAAW,EAAC,SAAS,EACrB,QAAQ,EAAE,CAAC,YAGX,MAAC,GAAG,IAAC,cAAc,EAAC,eAAe,aAEjC,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,SAAS,yBAAgB,EAC1C,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,mBAAI,OAAO,IAAQ,IACjC,EAGN,KAAC,GAAG,cACD,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;wBACrB,MAAM,QAAQ,GAAG,aAAa,KAAK,GAAG,CAAC,MAAM,CAAC;wBAC9C,MAAM,MAAM,GAAG,GAAG,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;wBAEvC,IAAI,QAAQ,EAAE,CAAC;4BACb,OAAO,CACL,MAAC,KAAK,CAAC,QAAQ,eACb,MAAC,IAAI,IAAC,eAAe,EAAC,SAAS,EAAC,KAAK,EAAC,OAAO,EAAC,IAAI,mBAC/C,GAAG,EAAE,GAAG,CAAC,IAAI,OAAG,GAAG,CAAC,GAAG,OAAG,GAAG,CAAC,KAAK,EAAE,GAAG,IACpC,EACN,CAAC,MAAM,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,kBAAS,KAJpB,GAAG,CAAC,GAAG,CAKX,CAClB,CAAC;wBACJ,CAAC;wBAED,OAAO,CACL,MAAC,KAAK,CAAC,QAAQ,eACb,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,aAAE,GAAG,CAAC,IAAI,SAAS,EACrC,MAAC,IAAI,IAAC,KAAK,EAAC,OAAO,EAAC,QAAQ,mBAAE,GAAG,CAAC,GAAG,OAAG,GAAG,CAAC,KAAK,IAAQ,EACxD,CAAC,MAAM,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,mBAAU,KAHrB,GAAG,CAAC,GAAG,CAIX,CAClB,CAAC;oBACJ,CAAC,CAAC,GACE,IACF,GACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,MAAM,CAAC"}
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ interface PanelProps {
3
+ /** Panel title */
4
+ title?: string;
5
+ /** Panel content */
6
+ children: React.ReactNode;
7
+ /** Border color */
8
+ borderColor?: string;
9
+ /** Title color */
10
+ titleColor?: string;
11
+ /** Panel width */
12
+ width?: number | string;
13
+ /** Panel height */
14
+ height?: number | string;
15
+ /** Whether to use flexGrow */
16
+ flexGrow?: number;
17
+ /** Whether panel is focused/active */
18
+ focused?: boolean;
19
+ }
20
+ export declare function Panel({ title, children, borderColor, titleColor, width, height, flexGrow, focused, }: PanelProps): React.ReactElement;
21
+ export default Panel;
22
+ //# sourceMappingURL=Panel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Panel.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/layout/Panel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,UAAU;IAClB,kBAAkB;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,oBAAoB;IACpB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,mBAAmB;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kBAAkB;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,kBAAkB;IAClB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxB,mBAAmB;IACnB,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACzB,8BAA8B;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,sCAAsC;IACtC,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,KAAK,CAAC,EACpB,KAAK,EACL,QAAQ,EACR,WAAuB,EACvB,UAAsB,EACtB,KAAK,EACL,MAAM,EACN,QAAY,EACZ,OAAe,GAChB,EAAE,UAAU,GAAG,KAAK,CAAC,YAAY,CA6BjC;AAED,eAAe,KAAK,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ export function Panel({ title, children, borderColor = '#7e57c2', titleColor = '#7e57c2', width, height, flexGrow = 1, focused = false, }) {
4
+ const activeColor = focused ? '#7e57c2' : borderColor;
5
+ return (_jsxs(Box, { flexDirection: "column", width: width, height: height, flexGrow: flexGrow, borderStyle: "single", borderColor: activeColor, paddingX: 1, overflow: "hidden", children: [title && (_jsx(Box, { marginBottom: 0, children: _jsx(Text, { color: titleColor, bold: true, children: title }) })), _jsx(Box, { flexDirection: "column", flexGrow: 1, overflow: "hidden", children: children })] }));
6
+ }
7
+ export default Panel;
8
+ //# sourceMappingURL=Panel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Panel.js","sourceRoot":"","sources":["../../../../src/ui/components/layout/Panel.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAqBhC,MAAM,UAAU,KAAK,CAAC,EACpB,KAAK,EACL,QAAQ,EACR,WAAW,GAAG,SAAS,EACvB,UAAU,GAAG,SAAS,EACtB,KAAK,EACL,MAAM,EACN,QAAQ,GAAG,CAAC,EACZ,OAAO,GAAG,KAAK,GACJ;IACX,MAAM,WAAW,GAAG,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;IAEtD,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,QAAQ,EAClB,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,CAAC,EACX,QAAQ,EAAC,QAAQ,aAGhB,KAAK,IAAI,CACR,KAAC,GAAG,IAAC,YAAY,EAAE,CAAC,YAClB,KAAC,IAAI,IAAC,KAAK,EAAE,UAAU,EAAE,IAAI,kBAC1B,KAAK,GACD,GACH,CACP,EAGD,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAC,QAAQ,YACvD,QAAQ,GACL,IACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,KAAK,CAAC"}
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ interface ProgressBarProps {
3
+ /** Progress message */
4
+ message: string;
5
+ /** Current progress (if determinate) */
6
+ current?: number;
7
+ /** Total items (if determinate) */
8
+ total?: number;
9
+ }
10
+ export declare function ProgressBar({ message, current, total }: ProgressBarProps): React.ReactElement;
11
+ export default ProgressBar;
12
+ //# sourceMappingURL=ProgressBar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/layout/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,gBAAgB;IACxB,uBAAuB;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,wCAAwC;IACxC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,mCAAmC;IACnC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,WAAW,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,KAAK,CAAC,YAAY,CA4B7F;AAED,eAAe,WAAW,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ export function ProgressBar({ message, current, total }) {
4
+ const isDeterminate = current !== undefined && total !== undefined && total > 0;
5
+ if (isDeterminate) {
6
+ const barWidth = 20;
7
+ const filled = Math.round((current / total) * barWidth);
8
+ const empty = barWidth - filled;
9
+ const bar = '█'.repeat(filled) + '░'.repeat(empty);
10
+ return (_jsxs(Box, { children: [_jsx(Text, { color: "cyan", children: "\u27F3" }), _jsxs(Text, { children: [" ", message, " "] }), _jsxs(Text, { color: "cyan", children: ["[", bar, "] ", current, "/", total] })] }));
11
+ }
12
+ // Indeterminate progress
13
+ return (_jsxs(Box, { children: [_jsx(Text, { color: "cyan", children: "\u27F3" }), _jsxs(Text, { children: [" ", message] }), _jsx(Text, { color: "gray", children: " ..." })] }));
14
+ }
15
+ export default ProgressBar;
16
+ //# sourceMappingURL=ProgressBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../../../src/ui/components/layout/ProgressBar.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAWhC,MAAM,UAAU,WAAW,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAoB;IACvE,MAAM,aAAa,GAAG,OAAO,KAAK,SAAS,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,GAAG,CAAC,CAAC;IAEhF,IAAI,aAAa,EAAE,CAAC;QAClB,MAAM,QAAQ,GAAG,EAAE,CAAC;QACpB,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC,GAAG,QAAQ,CAAC,CAAC;QACxD,MAAM,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAC;QAChC,MAAM,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAEnD,OAAO,CACL,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,uBAAS,EAC3B,MAAC,IAAI,oBAAG,OAAO,SAAS,EACxB,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,kBACd,GAAG,QAAI,OAAO,OAAG,KAAK,IACnB,IACH,CACP,CAAC;IACJ,CAAC;IAED,yBAAyB;IACzB,OAAO,CACL,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,uBAAS,EAC3B,MAAC,IAAI,oBAAG,OAAO,IAAQ,EACvB,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,qBAAY,IAC1B,CACP,CAAC;AACJ,CAAC;AAED,eAAe,WAAW,CAAC"}
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ interface ScopeTabsProps {
3
+ /** Current scope */
4
+ scope: 'project' | 'global';
5
+ /** Callback when scope changes */
6
+ onToggle?: () => void;
7
+ /** Hint text for toggle key */
8
+ toggleHint?: string;
9
+ }
10
+ export declare function ScopeTabs({ scope, onToggle: _onToggle, toggleHint, }: ScopeTabsProps): React.ReactElement;
11
+ export default ScopeTabs;
12
+ //# sourceMappingURL=ScopeTabs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScopeTabs.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/layout/ScopeTabs.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,cAAc;IACtB,oBAAoB;IACpB,KAAK,EAAE,SAAS,GAAG,QAAQ,CAAC;IAC5B,kCAAkC;IAClC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,+BAA+B;IAC/B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,wBAAgB,SAAS,CAAC,EACxB,KAAK,EACL,QAAQ,EAAE,SAAS,EACnB,UAAU,GACX,EAAE,cAAc,GAAG,KAAK,CAAC,YAAY,CAyCrC;AAED,eAAe,SAAS,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ export function ScopeTabs({ scope, onToggle: _onToggle, toggleHint, }) {
4
+ const isProject = scope === 'project';
5
+ return (_jsxs(Box, { marginBottom: 1, flexDirection: "row", gap: 1, children: [_jsx(Box, { children: isProject ? (_jsxs(Text, { backgroundColor: "cyan", color: "black", bold: true, children: [' ', "\u25C6 Project", ' '] })) : (_jsxs(Text, { color: "gray", children: [' ', "\u25CB Project", ' '] })) }), _jsx(Box, { children: !isProject ? (_jsxs(Text, { backgroundColor: "magenta", color: "white", bold: true, children: [' ', "\u25C6 Global", ' '] })) : (_jsxs(Text, { color: "gray", children: [' ', "\u25CB Global", ' '] })) }), toggleHint && (_jsx(Box, { marginLeft: 2, children: _jsxs(Text, { color: "gray", dimColor: true, children: ["(", toggleHint, ")"] }) }))] }));
6
+ }
7
+ export default ScopeTabs;
8
+ //# sourceMappingURL=ScopeTabs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScopeTabs.js","sourceRoot":"","sources":["../../../../src/ui/components/layout/ScopeTabs.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAWhC,MAAM,UAAU,SAAS,CAAC,EACxB,KAAK,EACL,QAAQ,EAAE,SAAS,EACnB,UAAU,GACK;IACf,MAAM,SAAS,GAAG,KAAK,KAAK,SAAS,CAAC;IAEtC,OAAO,CACL,MAAC,GAAG,IAAC,YAAY,EAAE,CAAC,EAAE,aAAa,EAAC,KAAK,EAAC,GAAG,EAAE,CAAC,aAE9C,KAAC,GAAG,cACD,SAAS,CAAC,CAAC,CAAC,CACX,MAAC,IAAI,IAAC,eAAe,EAAC,MAAM,EAAC,KAAK,EAAC,OAAO,EAAC,IAAI,mBAC5C,GAAG,oBAAW,GAAG,IACb,CACR,CAAC,CAAC,CAAC,CACF,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,aACf,GAAG,oBAAW,GAAG,IACb,CACR,GACG,EAGN,KAAC,GAAG,cACD,CAAC,SAAS,CAAC,CAAC,CAAC,CACZ,MAAC,IAAI,IAAC,eAAe,EAAC,SAAS,EAAC,KAAK,EAAC,OAAO,EAAC,IAAI,mBAC/C,GAAG,mBAAU,GAAG,IACZ,CACR,CAAC,CAAC,CAAC,CACF,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,aACf,GAAG,mBAAU,GAAG,IACZ,CACR,GACG,EAGL,UAAU,IAAI,CACb,KAAC,GAAG,IAAC,UAAU,EAAE,CAAC,YAChB,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,QAAQ,wBACvB,UAAU,SACP,GACH,CACP,IACG,CACP,CAAC;AACJ,CAAC;AAED,eAAe,SAAS,CAAC"}
@@ -0,0 +1,30 @@
1
+ import React from 'react';
2
+ import type { Screen } from '../../state/types.js';
3
+ interface ScreenLayoutProps {
4
+ /** Screen title (e.g., "claudeup Plugins") */
5
+ title: string;
6
+ /** Optional subtitle shown to the right of title */
7
+ subtitle?: string;
8
+ /** Current screen for tab highlighting */
9
+ currentScreen: Screen;
10
+ /** Search bar configuration (for screens with search) */
11
+ search?: {
12
+ /** Is search currently active */
13
+ isActive: boolean;
14
+ /** Current search query */
15
+ query: string;
16
+ /** Placeholder when not searching (default: "/") */
17
+ placeholder?: string;
18
+ };
19
+ /** Status line content (for screens without search) - shown in second row */
20
+ statusLine?: React.ReactNode;
21
+ /** Footer hints (left side) */
22
+ footerHints: string;
23
+ /** Left panel content */
24
+ listPanel: React.ReactNode;
25
+ /** Right panel content (detail view) */
26
+ detailPanel: React.ReactNode;
27
+ }
28
+ export declare function ScreenLayout({ title, subtitle, currentScreen, search, statusLine, footerHints, listPanel, detailPanel, }: ScreenLayoutProps): React.ReactElement;
29
+ export default ScreenLayout;
30
+ //# sourceMappingURL=ScreenLayout.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScreenLayout.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/layout/ScreenLayout.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAEnD,UAAU,iBAAiB;IACzB,8CAA8C;IAC9C,KAAK,EAAE,MAAM,CAAC;IACd,oDAAoD;IACpD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,0CAA0C;IAC1C,aAAa,EAAE,MAAM,CAAC;IACtB,yDAAyD;IACzD,MAAM,CAAC,EAAE;QACP,iCAAiC;QACjC,QAAQ,EAAE,OAAO,CAAC;QAClB,2BAA2B;QAC3B,KAAK,EAAE,MAAM,CAAC;QACd,oDAAoD;QACpD,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,CAAC;IACF,6EAA6E;IAC7E,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC7B,+BAA+B;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,yBAAyB;IACzB,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,wCAAwC;IACxC,WAAW,EAAE,KAAK,CAAC,SAAS,CAAC;CAC9B;AAID,wBAAgB,YAAY,CAAC,EAC3B,KAAK,EACL,QAAQ,EACR,aAAa,EACb,MAAM,EACN,UAAU,EACV,WAAW,EACX,SAAS,EACT,WAAW,GACZ,EAAE,iBAAiB,GAAG,KAAK,CAAC,YAAY,CA2FxC;AAED,eAAe,YAAY,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { Box, Text } from 'ink';
3
+ import { useDimensions } from '../../state/DimensionsContext.js';
4
+ import { TabBar } from '../TabBar.js';
5
+ const HEADER_COLOR = '#7e57c2';
6
+ export function ScreenLayout({ title, subtitle, currentScreen, search, statusLine, footerHints, listPanel, detailPanel, }) {
7
+ const dimensions = useDimensions();
8
+ // Calculate panel heights
9
+ // Header: 4 lines (border + title + status/search + border)
10
+ // Footer: 2 lines (border-top + content)
11
+ const headerHeight = 4;
12
+ const footerHeight = 2;
13
+ const panelHeight = Math.max(5, dimensions.contentHeight - headerHeight - footerHeight);
14
+ return (_jsxs(Box, { flexDirection: "column", height: dimensions.contentHeight, children: [_jsxs(Box, { flexDirection: "column", borderStyle: "single", borderColor: HEADER_COLOR, paddingX: 1, marginBottom: 0, children: [_jsxs(Box, { flexDirection: "row", justifyContent: "space-between", children: [_jsx(Text, { color: HEADER_COLOR, bold: true, children: title }), subtitle && _jsx(Text, { color: "gray", children: subtitle })] }), _jsx(Box, { flexDirection: "row", marginTop: 0, children: search ? (
15
+ // Search mode
16
+ _jsxs(_Fragment, { children: [_jsx(Text, { color: "green", children: '> ' }), search.isActive ? (_jsxs(_Fragment, { children: [_jsx(Text, { color: "white", children: search.query }), _jsx(Text, { inverse: true, color: "gray", children: " " })] })) : (_jsx(Text, { color: "gray", children: search.query || search.placeholder || '/' }))] })) : statusLine ? (
17
+ // Custom status line
18
+ statusLine) : (
19
+ // Default empty status
20
+ _jsx(Text, { color: "gray", children: "\u2500" })) })] }), _jsxs(Box, { flexDirection: "row", height: panelHeight, children: [_jsx(Box, { flexDirection: "column", width: "50%", height: panelHeight, paddingRight: 1, borderStyle: "single", borderTop: false, borderBottom: false, borderColor: "gray", overflow: "hidden", children: listPanel }), _jsx(Box, { flexDirection: "column", width: "50%", height: panelHeight, paddingLeft: 1, overflow: "hidden", children: detailPanel })] }), _jsxs(Box, { height: 1, borderStyle: "single", borderTop: true, borderBottom: false, borderLeft: false, borderRight: false, borderColor: "gray", flexDirection: "row", justifyContent: "space-between", children: [_jsx(Text, { dimColor: true, children: footerHints }), _jsx(TabBar, { currentScreen: currentScreen })] })] }));
21
+ }
22
+ export default ScreenLayout;
23
+ //# sourceMappingURL=ScreenLayout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScreenLayout.js","sourceRoot":"","sources":["../../../../src/ui/components/layout/ScreenLayout.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AA6BtC,MAAM,YAAY,GAAG,SAAS,CAAC;AAE/B,MAAM,UAAU,YAAY,CAAC,EAC3B,KAAK,EACL,QAAQ,EACR,aAAa,EACb,MAAM,EACN,UAAU,EACV,WAAW,EACX,SAAS,EACT,WAAW,GACO;IAClB,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IAEnC,0BAA0B;IAC1B,4DAA4D;IAC5D,yCAAyC;IACzC,MAAM,YAAY,GAAG,CAAC,CAAC;IACvB,MAAM,YAAY,GAAG,CAAC,CAAC;IACvB,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,CAAC,aAAa,GAAG,YAAY,GAAG,YAAY,CAAC,CAAC;IAExF,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,MAAM,EAAE,UAAU,CAAC,aAAa,aAE1D,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAE,YAAY,EACzB,QAAQ,EAAE,CAAC,EACX,YAAY,EAAE,CAAC,aAGf,MAAC,GAAG,IAAC,aAAa,EAAC,KAAK,EAAC,cAAc,EAAC,eAAe,aACrD,KAAC,IAAI,IAAC,KAAK,EAAE,YAAY,EAAE,IAAI,kBAAE,KAAK,GAAQ,EAC7C,QAAQ,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,YAAE,QAAQ,GAAQ,IAC7C,EAGN,KAAC,GAAG,IAAC,aAAa,EAAC,KAAK,EAAC,SAAS,EAAE,CAAC,YAClC,MAAM,CAAC,CAAC,CAAC;wBACR,cAAc;wBACd,8BACE,KAAC,IAAI,IAAC,KAAK,EAAC,OAAO,YAAE,IAAI,GAAQ,EAChC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CACjB,8BACE,KAAC,IAAI,IAAC,KAAK,EAAC,OAAO,YAAE,MAAM,CAAC,KAAK,GAAQ,EACzC,KAAC,IAAI,IAAC,OAAO,QAAC,KAAK,EAAC,MAAM,kBAAS,IAClC,CACJ,CAAC,CAAC,CAAC,CACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,YAAE,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,WAAW,IAAI,GAAG,GAAQ,CACtE,IACA,CACJ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;wBACf,qBAAqB;wBACrB,UAAU,CACX,CAAC,CAAC,CAAC;wBACF,uBAAuB;wBACvB,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,uBAAS,CAC5B,GACG,IACF,EAGN,MAAC,GAAG,IAAC,aAAa,EAAC,KAAK,EAAC,MAAM,EAAE,WAAW,aAE1C,KAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,KAAK,EAAC,KAAK,EACX,MAAM,EAAE,WAAW,EACnB,YAAY,EAAE,CAAC,EACf,WAAW,EAAC,QAAQ,EACpB,SAAS,EAAE,KAAK,EAChB,YAAY,EAAE,KAAK,EACnB,WAAW,EAAC,MAAM,EAClB,QAAQ,EAAC,QAAQ,YAEhB,SAAS,GACN,EAGN,KAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,KAAK,EAAC,KAAK,EAAC,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EAAE,QAAQ,EAAC,QAAQ,YAC3F,WAAW,GACR,IACF,EAGN,MAAC,GAAG,IACF,MAAM,EAAE,CAAC,EACT,WAAW,EAAC,QAAQ,EACpB,SAAS,EAAE,IAAI,EACf,YAAY,EAAE,KAAK,EACnB,UAAU,EAAE,KAAK,EACjB,WAAW,EAAE,KAAK,EAClB,WAAW,EAAC,MAAM,EAClB,aAAa,EAAC,KAAK,EACnB,cAAc,EAAC,eAAe,aAE9B,KAAC,IAAI,IAAC,QAAQ,kBAAE,WAAW,GAAQ,EACnC,KAAC,MAAM,IAAC,aAAa,EAAE,aAAa,GAAI,IACpC,IACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,YAAY,CAAC"}
@@ -0,0 +1,7 @@
1
+ export { Header } from './Header.js';
2
+ export { Footer } from './Footer.js';
3
+ export { Panel } from './Panel.js';
4
+ export { ScopeTabs } from './ScopeTabs.js';
5
+ export { ProgressBar } from './ProgressBar.js';
6
+ export { ScreenLayout } from './ScreenLayout.js';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/layout/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,7 @@
1
+ export { Header } from './Header.js';
2
+ export { Footer } from './Footer.js';
3
+ export { Panel } from './Panel.js';
4
+ export { ScopeTabs } from './ScopeTabs.js';
5
+ export { ProgressBar } from './ProgressBar.js';
6
+ export { ScreenLayout } from './ScreenLayout.js';
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/ui/components/layout/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ interface ConfirmModalProps {
3
+ /** Modal title */
4
+ title: string;
5
+ /** Modal message */
6
+ message: string;
7
+ /** Callback when confirmed */
8
+ onConfirm: () => void;
9
+ /** Callback when cancelled */
10
+ onCancel: () => void;
11
+ }
12
+ export declare function ConfirmModal({ title, message, onConfirm, onCancel, }: ConfirmModalProps): React.ReactElement;
13
+ export default ConfirmModal;
14
+ //# sourceMappingURL=ConfirmModal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfirmModal.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/modals/ConfirmModal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,iBAAiB;IACzB,kBAAkB;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,oBAAoB;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,8BAA8B;IAC9B,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,8BAA8B;IAC9B,QAAQ,EAAE,MAAM,IAAI,CAAC;CACtB;AAED,wBAAgB,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,SAAS,EACT,QAAQ,GACT,EAAE,iBAAiB,GAAG,KAAK,CAAC,YAAY,CA8BxC;AAED,eAAe,YAAY,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Text, useInput } from 'ink';
3
+ export function ConfirmModal({ title, message, onConfirm, onCancel, }) {
4
+ useInput((input, key) => {
5
+ if (input === 'y' || input === 'Y') {
6
+ onConfirm();
7
+ }
8
+ else if (input === 'n' || input === 'N' || key.escape) {
9
+ onCancel();
10
+ }
11
+ });
12
+ return (_jsxs(Box, { flexDirection: "column", borderStyle: "round", borderColor: "yellow", paddingX: 2, paddingY: 1, width: 60, children: [_jsx(Text, { bold: true, children: title }), _jsx(Box, { marginY: 1, children: _jsx(Text, { children: message }) }), _jsxs(Box, { children: [_jsx(Text, { color: "green", children: "[Y]" }), _jsx(Text, { children: "es " }), _jsx(Text, { color: "red", children: "[N]" }), _jsx(Text, { children: "o" })] })] }));
13
+ }
14
+ export default ConfirmModal;
15
+ //# sourceMappingURL=ConfirmModal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfirmModal.js","sourceRoot":"","sources":["../../../../src/ui/components/modals/ConfirmModal.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAa1C,MAAM,UAAU,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,SAAS,EACT,QAAQ,GACU;IAClB,QAAQ,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACtB,IAAI,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,GAAG,EAAE,CAAC;YACnC,SAAS,EAAE,CAAC;QACd,CAAC;aAAM,IAAI,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,GAAG,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACxD,QAAQ,EAAE,CAAC;QACb,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,WAAW,EAAC,OAAO,EACnB,WAAW,EAAC,QAAQ,EACpB,QAAQ,EAAE,CAAC,EACX,QAAQ,EAAE,CAAC,EACX,KAAK,EAAE,EAAE,aAET,KAAC,IAAI,IAAC,IAAI,kBAAE,KAAK,GAAQ,EACzB,KAAC,GAAG,IAAC,OAAO,EAAE,CAAC,YACb,KAAC,IAAI,cAAE,OAAO,GAAQ,GAClB,EACN,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAC,OAAO,oBAAW,EAC9B,KAAC,IAAI,sBAAW,EAChB,KAAC,IAAI,IAAC,KAAK,EAAC,KAAK,oBAAW,EAC5B,KAAC,IAAI,oBAAS,IACV,IACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,YAAY,CAAC"}
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ interface InputModalProps {
3
+ /** Modal title */
4
+ title: string;
5
+ /** Input label */
6
+ label: string;
7
+ /** Default input value */
8
+ defaultValue?: string;
9
+ /** Callback when submitted */
10
+ onSubmit: (value: string) => void;
11
+ /** Callback when cancelled */
12
+ onCancel: () => void;
13
+ }
14
+ export declare function InputModal({ title, label, defaultValue, onSubmit, onCancel, }: InputModalProps): React.ReactElement;
15
+ export default InputModal;
16
+ //# sourceMappingURL=InputModal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputModal.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/modals/InputModal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAGxC,UAAU,eAAe;IACvB,kBAAkB;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,kBAAkB;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,0BAA0B;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,8BAA8B;IAC9B,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,8BAA8B;IAC9B,QAAQ,EAAE,MAAM,IAAI,CAAC;CACtB;AAED,wBAAgB,UAAU,CAAC,EACzB,KAAK,EACL,KAAK,EACL,YAAiB,EACjB,QAAQ,EACR,QAAQ,GACT,EAAE,eAAe,GAAG,KAAK,CAAC,YAAY,CA+CtC;AAED,eAAe,UAAU,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useState } from 'react';
3
+ import { Box, Text, useInput } from 'ink';
4
+ export function InputModal({ title, label, defaultValue = '', onSubmit, onCancel, }) {
5
+ const [value, setValue] = useState(defaultValue);
6
+ useInput((input, key) => {
7
+ if (key.return) {
8
+ onSubmit(value);
9
+ }
10
+ else if (key.escape) {
11
+ onCancel();
12
+ }
13
+ else if (key.backspace || key.delete) {
14
+ setValue((prev) => prev.slice(0, -1));
15
+ }
16
+ else if (input && !key.ctrl && !key.meta) {
17
+ setValue((prev) => prev + input);
18
+ }
19
+ });
20
+ return (_jsxs(Box, { flexDirection: "column", borderStyle: "round", borderColor: "cyan", paddingX: 2, paddingY: 1, width: 60, children: [_jsx(Text, { bold: true, children: title }), _jsx(Box, { marginY: 1, children: _jsx(Text, { children: label }) }), _jsx(Box, { borderStyle: "single", borderColor: "green", paddingX: 1, width: 56, children: _jsxs(Text, { children: [value, _jsx(Text, { inverse: true, children: " " })] }) }), _jsx(Box, { marginTop: 1, children: _jsx(Text, { color: "gray", children: "Enter to confirm \u2022 Escape to cancel" }) })] }));
21
+ }
22
+ export default InputModal;
23
+ //# sourceMappingURL=InputModal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputModal.js","sourceRoot":"","sources":["../../../../src/ui/components/modals/InputModal.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAe1C,MAAM,UAAU,UAAU,CAAC,EACzB,KAAK,EACL,KAAK,EACL,YAAY,GAAG,EAAE,EACjB,QAAQ,EACR,QAAQ,GACQ;IAChB,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,YAAY,CAAC,CAAC;IAEjD,QAAQ,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACtB,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACf,QAAQ,CAAC,KAAK,CAAC,CAAC;QAClB,CAAC;aAAM,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACtB,QAAQ,EAAE,CAAC;QACb,CAAC;aAAM,IAAI,GAAG,CAAC,SAAS,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;YACvC,QAAQ,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC;aAAM,IAAI,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YAC3C,QAAQ,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC;QACnC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,WAAW,EAAC,OAAO,EACnB,WAAW,EAAC,MAAM,EAClB,QAAQ,EAAE,CAAC,EACX,QAAQ,EAAE,CAAC,EACX,KAAK,EAAE,EAAE,aAET,KAAC,IAAI,IAAC,IAAI,kBAAE,KAAK,GAAQ,EAEzB,KAAC,GAAG,IAAC,OAAO,EAAE,CAAC,YACb,KAAC,IAAI,cAAE,KAAK,GAAQ,GAChB,EAEN,KAAC,GAAG,IACF,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAC,OAAO,EACnB,QAAQ,EAAE,CAAC,EACX,KAAK,EAAE,EAAE,YAET,MAAC,IAAI,eACF,KAAK,EACN,KAAC,IAAI,IAAC,OAAO,wBAAS,IACjB,GACH,EAEN,KAAC,GAAG,IAAC,SAAS,EAAE,CAAC,YACf,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,yDAA2C,GACzD,IACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,UAAU,CAAC"}