claudeup 1.8.0 → 3.3.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.
- package/bin/claudeup.js +20 -2
- package/package.json +10 -19
- package/src/data/cli-tools.js +123 -0
- package/src/data/cli-tools.ts +140 -0
- package/{dist → src}/data/marketplaces.js +23 -24
- package/src/data/marketplaces.ts +95 -0
- package/src/data/mcp-servers.js +509 -0
- package/src/data/mcp-servers.ts +526 -0
- package/src/data/statuslines.js +159 -0
- package/src/data/statuslines.ts +188 -0
- package/src/index.js +4 -0
- package/src/index.ts +5 -0
- package/{dist → src}/main.js +46 -47
- package/src/main.tsx +145 -0
- package/src/opentui.d.ts +191 -0
- package/{dist → src}/prerunner/index.js +31 -41
- package/src/prerunner/index.ts +124 -0
- package/{dist → src}/services/claude-runner.js +9 -10
- package/src/services/claude-runner.ts +31 -0
- package/{dist → src}/services/claude-settings.js +72 -33
- package/src/services/claude-settings.ts +934 -0
- package/src/services/local-marketplace.js +339 -0
- package/src/services/local-marketplace.ts +489 -0
- package/{dist → src}/services/mcp-registry.js +13 -14
- package/src/services/mcp-registry.ts +105 -0
- package/{dist → src}/services/plugin-manager.js +61 -13
- package/src/services/plugin-manager.ts +693 -0
- package/{dist → src}/services/plugin-mcp-config.js +19 -18
- package/src/services/plugin-mcp-config.ts +242 -0
- package/{dist → src}/services/update-cache.js +0 -1
- package/src/services/update-cache.ts +78 -0
- package/{dist → src}/services/version-check.js +15 -14
- package/src/services/version-check.ts +122 -0
- package/src/types/index.js +1 -0
- package/src/types/index.ts +141 -0
- package/src/ui/App.js +213 -0
- package/src/ui/App.tsx +359 -0
- package/src/ui/components/CategoryHeader.js +9 -0
- package/src/ui/components/CategoryHeader.tsx +41 -0
- package/{dist → src}/ui/components/ScrollableList.js +19 -6
- package/src/ui/components/ScrollableList.tsx +98 -0
- package/src/ui/components/SearchInput.js +19 -0
- package/src/ui/components/SearchInput.tsx +56 -0
- package/src/ui/components/StyledText.js +39 -0
- package/src/ui/components/StyledText.tsx +70 -0
- package/src/ui/components/TabBar.js +38 -0
- package/src/ui/components/TabBar.tsx +88 -0
- package/src/ui/components/layout/Panel.js +6 -0
- package/src/ui/components/layout/Panel.tsx +62 -0
- package/src/ui/components/layout/ProgressBar.js +14 -0
- package/src/ui/components/layout/ProgressBar.tsx +47 -0
- package/src/ui/components/layout/ScopeTabs.js +6 -0
- package/src/ui/components/layout/ScopeTabs.tsx +53 -0
- package/src/ui/components/layout/ScreenLayout.js +21 -0
- package/src/ui/components/layout/ScreenLayout.tsx +147 -0
- package/src/ui/components/layout/index.js +4 -0
- package/src/ui/components/layout/index.ts +4 -0
- package/src/ui/components/modals/ConfirmModal.js +14 -0
- package/src/ui/components/modals/ConfirmModal.tsx +59 -0
- package/src/ui/components/modals/InputModal.js +16 -0
- package/src/ui/components/modals/InputModal.tsx +68 -0
- package/src/ui/components/modals/LoadingModal.js +14 -0
- package/src/ui/components/modals/LoadingModal.tsx +40 -0
- package/src/ui/components/modals/MessageModal.js +16 -0
- package/src/ui/components/modals/MessageModal.tsx +64 -0
- package/src/ui/components/modals/ModalContainer.js +56 -0
- package/src/ui/components/modals/ModalContainer.tsx +104 -0
- package/src/ui/components/modals/SelectModal.js +26 -0
- package/src/ui/components/modals/SelectModal.tsx +82 -0
- package/src/ui/components/modals/index.js +6 -0
- package/src/ui/components/modals/index.ts +6 -0
- package/src/ui/hooks/index.js +3 -0
- package/src/ui/hooks/index.ts +3 -0
- package/{dist → src}/ui/hooks/useAsyncData.js +21 -22
- package/src/ui/hooks/useAsyncData.ts +127 -0
- package/src/ui/hooks/useKeyboard.js +13 -0
- package/src/ui/hooks/useKeyboard.ts +26 -0
- package/src/ui/hooks/useKeyboardHandler.js +39 -0
- package/src/ui/hooks/useKeyboardHandler.ts +63 -0
- package/{dist → src}/ui/screens/CliToolsScreen.js +60 -54
- package/src/ui/screens/CliToolsScreen.tsx +468 -0
- package/src/ui/screens/EnvVarsScreen.js +154 -0
- package/src/ui/screens/EnvVarsScreen.tsx +269 -0
- package/{dist → src}/ui/screens/McpRegistryScreen.js +56 -55
- package/src/ui/screens/McpRegistryScreen.tsx +331 -0
- package/{dist → src}/ui/screens/McpScreen.js +46 -47
- package/src/ui/screens/McpScreen.tsx +392 -0
- package/src/ui/screens/ModelSelectorScreen.js +292 -0
- package/src/ui/screens/ModelSelectorScreen.tsx +441 -0
- package/{dist → src}/ui/screens/PluginsScreen.js +305 -293
- package/src/ui/screens/PluginsScreen.tsx +1231 -0
- package/src/ui/screens/StatusLineScreen.js +200 -0
- package/src/ui/screens/StatusLineScreen.tsx +411 -0
- package/src/ui/screens/index.js +7 -0
- package/src/ui/screens/index.ts +7 -0
- package/src/ui/state/AnimationContext.js +34 -0
- package/src/ui/state/AnimationContext.tsx +76 -0
- package/{dist → src}/ui/state/AppContext.js +31 -32
- package/src/ui/state/AppContext.tsx +235 -0
- package/{dist → src}/ui/state/DimensionsContext.js +16 -17
- package/src/ui/state/DimensionsContext.tsx +144 -0
- package/{dist → src}/ui/state/reducer.js +89 -90
- package/src/ui/state/reducer.ts +467 -0
- package/src/ui/state/types.js +1 -0
- package/src/ui/state/types.ts +273 -0
- package/{dist → src}/utils/command-utils.js +3 -4
- package/src/utils/command-utils.ts +20 -0
- package/{dist → src}/utils/fuzzy-search.js +2 -3
- package/src/utils/fuzzy-search.ts +138 -0
- package/{dist → src}/utils/string-utils.js +6 -6
- package/src/utils/string-utils.ts +88 -0
- package/dist/data/cli-tools.d.ts +0 -13
- package/dist/data/cli-tools.d.ts.map +0 -1
- package/dist/data/cli-tools.js +0 -124
- package/dist/data/cli-tools.js.map +0 -1
- package/dist/data/marketplaces.d.ts +0 -6
- package/dist/data/marketplaces.d.ts.map +0 -1
- package/dist/data/marketplaces.js.map +0 -1
- package/dist/data/mcp-servers.d.ts +0 -8
- package/dist/data/mcp-servers.d.ts.map +0 -1
- package/dist/data/mcp-servers.js +0 -503
- package/dist/data/mcp-servers.js.map +0 -1
- package/dist/data/statuslines.d.ts +0 -10
- package/dist/data/statuslines.d.ts.map +0 -1
- package/dist/data/statuslines.js +0 -160
- package/dist/data/statuslines.js.map +0 -1
- package/dist/index.d.ts +0 -3
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -90
- package/dist/index.js.map +0 -1
- package/dist/main.d.ts +0 -3
- package/dist/main.d.ts.map +0 -1
- package/dist/main.js.map +0 -1
- package/dist/prerunner/index.d.ts +0 -7
- package/dist/prerunner/index.d.ts.map +0 -1
- package/dist/prerunner/index.js.map +0 -1
- package/dist/services/claude-runner.d.ts +0 -7
- package/dist/services/claude-runner.d.ts.map +0 -1
- package/dist/services/claude-runner.js.map +0 -1
- package/dist/services/claude-settings.d.ts +0 -73
- package/dist/services/claude-settings.d.ts.map +0 -1
- package/dist/services/claude-settings.js.map +0 -1
- package/dist/services/local-marketplace.d.ts +0 -111
- package/dist/services/local-marketplace.d.ts.map +0 -1
- package/dist/services/local-marketplace.js +0 -599
- package/dist/services/local-marketplace.js.map +0 -1
- package/dist/services/mcp-registry.d.ts +0 -10
- package/dist/services/mcp-registry.d.ts.map +0 -1
- package/dist/services/mcp-registry.js.map +0 -1
- package/dist/services/plugin-manager.d.ts +0 -65
- package/dist/services/plugin-manager.d.ts.map +0 -1
- package/dist/services/plugin-manager.js.map +0 -1
- package/dist/services/plugin-mcp-config.d.ts +0 -52
- package/dist/services/plugin-mcp-config.d.ts.map +0 -1
- package/dist/services/plugin-mcp-config.js.map +0 -1
- package/dist/services/update-cache.d.ts +0 -21
- package/dist/services/update-cache.d.ts.map +0 -1
- package/dist/services/update-cache.js.map +0 -1
- package/dist/services/version-check.d.ts +0 -20
- package/dist/services/version-check.d.ts.map +0 -1
- package/dist/services/version-check.js.map +0 -1
- package/dist/types/index.d.ts +0 -105
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -2
- package/dist/types/index.js.map +0 -1
- package/dist/ui/InkApp.d.ts +0 -5
- package/dist/ui/InkApp.d.ts.map +0 -1
- package/dist/ui/InkApp.js +0 -188
- package/dist/ui/InkApp.js.map +0 -1
- package/dist/ui/components/CategoryHeader.d.ts +0 -16
- package/dist/ui/components/CategoryHeader.d.ts.map +0 -1
- package/dist/ui/components/CategoryHeader.js +0 -11
- package/dist/ui/components/CategoryHeader.js.map +0 -1
- package/dist/ui/components/ScrollableList.d.ts +0 -16
- package/dist/ui/components/ScrollableList.d.ts.map +0 -1
- package/dist/ui/components/ScrollableList.js.map +0 -1
- package/dist/ui/components/SearchInput.d.ts +0 -18
- package/dist/ui/components/SearchInput.d.ts.map +0 -1
- package/dist/ui/components/SearchInput.js +0 -30
- package/dist/ui/components/SearchInput.js.map +0 -1
- package/dist/ui/components/TabBar.d.ts +0 -8
- package/dist/ui/components/TabBar.d.ts.map +0 -1
- package/dist/ui/components/TabBar.js +0 -18
- package/dist/ui/components/TabBar.js.map +0 -1
- package/dist/ui/components/layout/Footer.d.ts +0 -14
- package/dist/ui/components/layout/Footer.d.ts.map +0 -1
- package/dist/ui/components/layout/Footer.js +0 -23
- package/dist/ui/components/layout/Footer.js.map +0 -1
- package/dist/ui/components/layout/Header.d.ts +0 -4
- package/dist/ui/components/layout/Header.d.ts.map +0 -1
- package/dist/ui/components/layout/Header.js +0 -25
- package/dist/ui/components/layout/Header.js.map +0 -1
- package/dist/ui/components/layout/Panel.d.ts +0 -22
- package/dist/ui/components/layout/Panel.d.ts.map +0 -1
- package/dist/ui/components/layout/Panel.js +0 -8
- package/dist/ui/components/layout/Panel.js.map +0 -1
- package/dist/ui/components/layout/ProgressBar.d.ts +0 -12
- package/dist/ui/components/layout/ProgressBar.d.ts.map +0 -1
- package/dist/ui/components/layout/ProgressBar.js +0 -16
- package/dist/ui/components/layout/ProgressBar.js.map +0 -1
- package/dist/ui/components/layout/ScopeTabs.d.ts +0 -12
- package/dist/ui/components/layout/ScopeTabs.d.ts.map +0 -1
- package/dist/ui/components/layout/ScopeTabs.js +0 -8
- package/dist/ui/components/layout/ScopeTabs.js.map +0 -1
- package/dist/ui/components/layout/ScreenLayout.d.ts +0 -30
- package/dist/ui/components/layout/ScreenLayout.d.ts.map +0 -1
- package/dist/ui/components/layout/ScreenLayout.js +0 -23
- package/dist/ui/components/layout/ScreenLayout.js.map +0 -1
- package/dist/ui/components/layout/index.d.ts +0 -7
- package/dist/ui/components/layout/index.d.ts.map +0 -1
- package/dist/ui/components/layout/index.js +0 -7
- package/dist/ui/components/layout/index.js.map +0 -1
- package/dist/ui/components/modals/ConfirmModal.d.ts +0 -14
- package/dist/ui/components/modals/ConfirmModal.d.ts.map +0 -1
- package/dist/ui/components/modals/ConfirmModal.js +0 -15
- package/dist/ui/components/modals/ConfirmModal.js.map +0 -1
- package/dist/ui/components/modals/InputModal.d.ts +0 -16
- package/dist/ui/components/modals/InputModal.d.ts.map +0 -1
- package/dist/ui/components/modals/InputModal.js +0 -23
- package/dist/ui/components/modals/InputModal.js.map +0 -1
- package/dist/ui/components/modals/LoadingModal.d.ts +0 -8
- package/dist/ui/components/modals/LoadingModal.d.ts.map +0 -1
- package/dist/ui/components/modals/LoadingModal.js +0 -8
- package/dist/ui/components/modals/LoadingModal.js.map +0 -1
- package/dist/ui/components/modals/MessageModal.d.ts +0 -14
- package/dist/ui/components/modals/MessageModal.d.ts.map +0 -1
- package/dist/ui/components/modals/MessageModal.js +0 -17
- package/dist/ui/components/modals/MessageModal.js.map +0 -1
- package/dist/ui/components/modals/ModalContainer.d.ts +0 -7
- package/dist/ui/components/modals/ModalContainer.d.ts.map +0 -1
- package/dist/ui/components/modals/ModalContainer.js +0 -38
- package/dist/ui/components/modals/ModalContainer.js.map +0 -1
- package/dist/ui/components/modals/SelectModal.d.ts +0 -17
- package/dist/ui/components/modals/SelectModal.d.ts.map +0 -1
- package/dist/ui/components/modals/SelectModal.js +0 -33
- package/dist/ui/components/modals/SelectModal.js.map +0 -1
- package/dist/ui/components/modals/index.d.ts +0 -7
- package/dist/ui/components/modals/index.d.ts.map +0 -1
- package/dist/ui/components/modals/index.js +0 -7
- package/dist/ui/components/modals/index.js.map +0 -1
- package/dist/ui/hooks/index.d.ts +0 -3
- package/dist/ui/hooks/index.d.ts.map +0 -1
- package/dist/ui/hooks/index.js +0 -3
- package/dist/ui/hooks/index.js.map +0 -1
- package/dist/ui/hooks/useAsyncData.d.ts +0 -40
- package/dist/ui/hooks/useAsyncData.d.ts.map +0 -1
- package/dist/ui/hooks/useAsyncData.js.map +0 -1
- package/dist/ui/hooks/useKeyboardNavigation.d.ts +0 -27
- package/dist/ui/hooks/useKeyboardNavigation.d.ts.map +0 -1
- package/dist/ui/hooks/useKeyboardNavigation.js +0 -82
- package/dist/ui/hooks/useKeyboardNavigation.js.map +0 -1
- package/dist/ui/screens/CliToolsScreen.d.ts +0 -4
- package/dist/ui/screens/CliToolsScreen.d.ts.map +0 -1
- package/dist/ui/screens/CliToolsScreen.js.map +0 -1
- package/dist/ui/screens/EnvVarsScreen.d.ts +0 -4
- package/dist/ui/screens/EnvVarsScreen.d.ts.map +0 -1
- package/dist/ui/screens/EnvVarsScreen.js +0 -145
- package/dist/ui/screens/EnvVarsScreen.js.map +0 -1
- package/dist/ui/screens/McpRegistryScreen.d.ts +0 -4
- package/dist/ui/screens/McpRegistryScreen.d.ts.map +0 -1
- package/dist/ui/screens/McpRegistryScreen.js.map +0 -1
- package/dist/ui/screens/McpScreen.d.ts +0 -4
- package/dist/ui/screens/McpScreen.d.ts.map +0 -1
- package/dist/ui/screens/McpScreen.js.map +0 -1
- package/dist/ui/screens/ModelSelectorScreen.d.ts +0 -4
- package/dist/ui/screens/ModelSelectorScreen.d.ts.map +0 -1
- package/dist/ui/screens/ModelSelectorScreen.js +0 -143
- package/dist/ui/screens/ModelSelectorScreen.js.map +0 -1
- package/dist/ui/screens/PluginsScreen.d.ts +0 -4
- package/dist/ui/screens/PluginsScreen.d.ts.map +0 -1
- package/dist/ui/screens/PluginsScreen.js.map +0 -1
- package/dist/ui/screens/StatusLineScreen.d.ts +0 -4
- package/dist/ui/screens/StatusLineScreen.d.ts.map +0 -1
- package/dist/ui/screens/StatusLineScreen.js +0 -197
- package/dist/ui/screens/StatusLineScreen.js.map +0 -1
- package/dist/ui/screens/index.d.ts +0 -8
- package/dist/ui/screens/index.d.ts.map +0 -1
- package/dist/ui/screens/index.js +0 -8
- package/dist/ui/screens/index.js.map +0 -1
- package/dist/ui/state/AppContext.d.ts +0 -40
- package/dist/ui/state/AppContext.d.ts.map +0 -1
- package/dist/ui/state/AppContext.js.map +0 -1
- package/dist/ui/state/DimensionsContext.d.ts +0 -27
- package/dist/ui/state/DimensionsContext.d.ts.map +0 -1
- package/dist/ui/state/DimensionsContext.js.map +0 -1
- package/dist/ui/state/reducer.d.ts +0 -4
- package/dist/ui/state/reducer.d.ts.map +0 -1
- package/dist/ui/state/reducer.js.map +0 -1
- package/dist/ui/state/types.d.ts +0 -266
- package/dist/ui/state/types.d.ts.map +0 -1
- package/dist/ui/state/types.js +0 -2
- package/dist/ui/state/types.js.map +0 -1
- package/dist/utils/command-utils.d.ts +0 -8
- package/dist/utils/command-utils.d.ts.map +0 -1
- package/dist/utils/command-utils.js.map +0 -1
- package/dist/utils/fuzzy-search.d.ts +0 -33
- package/dist/utils/fuzzy-search.d.ts.map +0 -1
- package/dist/utils/fuzzy-search.js.map +0 -1
- package/dist/utils/string-utils.d.ts +0 -24
- package/dist/utils/string-utils.d.ts.map +0 -1
- package/dist/utils/string-utils.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,30 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,8 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,23 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,25 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,22 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,8 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,12 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,16 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,12 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,8 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,30 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,23 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,7 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,7 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,15 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,16 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,23 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
interface LoadingModalProps {
|
|
3
|
-
/** Loading message */
|
|
4
|
-
message: string;
|
|
5
|
-
}
|
|
6
|
-
export declare function LoadingModal({ message }: LoadingModalProps): React.ReactElement;
|
|
7
|
-
export default LoadingModal;
|
|
8
|
-
//# sourceMappingURL=LoadingModal.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"LoadingModal.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/modals/LoadingModal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,iBAAiB;IACzB,sBAAsB;IACtB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,YAAY,CAAC,EAAE,OAAO,EAAE,EAAE,iBAAiB,GAAG,KAAK,CAAC,YAAY,CAe/E;AAED,eAAe,YAAY,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { Box, Text } from 'ink';
|
|
3
|
-
import Spinner from 'ink-spinner';
|
|
4
|
-
export function LoadingModal({ message }) {
|
|
5
|
-
return (_jsxs(Box, { flexDirection: "row", borderStyle: "round", borderColor: "cyan", paddingX: 2, paddingY: 1, children: [_jsx(Text, { color: "cyan", children: _jsx(Spinner, { type: "dots" }) }), _jsxs(Text, { children: [" ", message] })] }));
|
|
6
|
-
}
|
|
7
|
-
export default LoadingModal;
|
|
8
|
-
//# sourceMappingURL=LoadingModal.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"LoadingModal.js","sourceRoot":"","sources":["../../../../src/ui/components/modals/LoadingModal.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,OAAO,MAAM,aAAa,CAAC;AAOlC,MAAM,UAAU,YAAY,CAAC,EAAE,OAAO,EAAqB;IACzD,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,KAAK,EACnB,WAAW,EAAC,OAAO,EACnB,WAAW,EAAC,MAAM,EAClB,QAAQ,EAAE,CAAC,EACX,QAAQ,EAAE,CAAC,aAEX,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,YAChB,KAAC,OAAO,IAAC,IAAI,EAAC,MAAM,GAAG,GAClB,EACP,MAAC,IAAI,oBAAG,OAAO,IAAQ,IACnB,CACP,CAAC;AACJ,CAAC;AAED,eAAe,YAAY,CAAC"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
interface MessageModalProps {
|
|
3
|
-
/** Modal title */
|
|
4
|
-
title: string;
|
|
5
|
-
/** Modal message */
|
|
6
|
-
message: string;
|
|
7
|
-
/** Message variant */
|
|
8
|
-
variant: 'info' | 'success' | 'error';
|
|
9
|
-
/** Callback when dismissed */
|
|
10
|
-
onDismiss: () => void;
|
|
11
|
-
}
|
|
12
|
-
export declare function MessageModal({ title, message, variant, onDismiss, }: MessageModalProps): React.ReactElement;
|
|
13
|
-
export default MessageModal;
|
|
14
|
-
//# sourceMappingURL=MessageModal.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MessageModal.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/modals/MessageModal.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,sBAAsB;IACtB,OAAO,EAAE,MAAM,GAAG,SAAS,GAAG,OAAO,CAAC;IACtC,8BAA8B;IAC9B,SAAS,EAAE,MAAM,IAAI,CAAC;CACvB;AAQD,wBAAgB,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,OAAO,EACP,SAAS,GACV,EAAE,iBAAiB,GAAG,KAAK,CAAC,YAAY,CA+BxC;AAED,eAAe,YAAY,CAAC"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { Box, Text, useInput } from 'ink';
|
|
3
|
-
const variantConfig = {
|
|
4
|
-
info: { icon: 'ℹ', color: 'cyan' },
|
|
5
|
-
success: { icon: '✓', color: 'green' },
|
|
6
|
-
error: { icon: '✗', color: 'red' },
|
|
7
|
-
};
|
|
8
|
-
export function MessageModal({ title, message, variant, onDismiss, }) {
|
|
9
|
-
const config = variantConfig[variant];
|
|
10
|
-
useInput(() => {
|
|
11
|
-
// Any key dismisses
|
|
12
|
-
onDismiss();
|
|
13
|
-
});
|
|
14
|
-
return (_jsxs(Box, { flexDirection: "column", borderStyle: "round", borderColor: config.color, paddingX: 2, paddingY: 1, width: 60, children: [_jsxs(Box, { children: [_jsx(Text, { color: config.color, children: config.icon }), _jsxs(Text, { bold: true, children: [" ", title] })] }), _jsx(Box, { marginY: 1, children: _jsx(Text, { children: message }) }), _jsx(Box, { children: _jsx(Text, { color: "gray", children: "Press any key to continue" }) })] }));
|
|
15
|
-
}
|
|
16
|
-
export default MessageModal;
|
|
17
|
-
//# sourceMappingURL=MessageModal.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MessageModal.js","sourceRoot":"","sources":["../../../../src/ui/components/modals/MessageModal.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAa1C,MAAM,aAAa,GAAG;IACpB,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE;IAClC,OAAO,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE;IACtC,KAAK,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE;CAC1B,CAAC;AAEX,MAAM,UAAU,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,OAAO,EACP,SAAS,GACS;IAClB,MAAM,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;IAEtC,QAAQ,CAAC,GAAG,EAAE;QACZ,oBAAoB;QACpB,SAAS,EAAE,CAAC;IACd,CAAC,CAAC,CAAC;IAEH,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,WAAW,EAAC,OAAO,EACnB,WAAW,EAAE,MAAM,CAAC,KAAK,EACzB,QAAQ,EAAE,CAAC,EACX,QAAQ,EAAE,CAAC,EACX,KAAK,EAAE,EAAE,aAET,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,YAAG,MAAM,CAAC,IAAI,GAAQ,EAC/C,MAAC,IAAI,IAAC,IAAI,wBAAG,KAAK,IAAQ,IACtB,EAEN,KAAC,GAAG,IAAC,OAAO,EAAE,CAAC,YACb,KAAC,IAAI,cAAE,OAAO,GAAQ,GAClB,EAEN,KAAC,GAAG,cACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,0CAAiC,GAC/C,IACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,YAAY,CAAC"}
|