centaurus-cli 2.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.
- package/AUTH_FLOW.md +138 -0
- package/CONFIG_GUIDE.md +255 -0
- package/LICENSE +21 -0
- package/README.md +346 -0
- package/dist/ai/provider-factory.d.ts +6 -0
- package/dist/ai/provider-factory.d.ts.map +1 -0
- package/dist/ai/provider-factory.js +27 -0
- package/dist/ai/provider-factory.js.map +1 -0
- package/dist/ai/providers/base.d.ts +25 -0
- package/dist/ai/providers/base.d.ts.map +1 -0
- package/dist/ai/providers/base.js +9 -0
- package/dist/ai/providers/base.js.map +1 -0
- package/dist/ai/providers/gemini.d.ts +34 -0
- package/dist/ai/providers/gemini.d.ts.map +1 -0
- package/dist/ai/providers/gemini.js +146 -0
- package/dist/ai/providers/gemini.js.map +1 -0
- package/dist/ai/types.d.ts +20 -0
- package/dist/ai/types.d.ts.map +1 -0
- package/dist/ai/types.js +2 -0
- package/dist/ai/types.js.map +1 -0
- package/dist/cli-adapter.d.ts +78 -0
- package/dist/cli-adapter.d.ts.map +1 -0
- package/dist/cli-adapter.js +605 -0
- package/dist/cli-adapter.js.map +1 -0
- package/dist/commands/CommandParser.d.ts +27 -0
- package/dist/commands/CommandParser.d.ts.map +1 -0
- package/dist/commands/CommandParser.js +238 -0
- package/dist/commands/CommandParser.js.map +1 -0
- package/dist/config/ConfigManager.d.ts +59 -0
- package/dist/config/ConfigManager.d.ts.map +1 -0
- package/dist/config/ConfigManager.js +332 -0
- package/dist/config/ConfigManager.js.map +1 -0
- package/dist/config/defaultConfig.d.ts +82 -0
- package/dist/config/defaultConfig.d.ts.map +1 -0
- package/dist/config/defaultConfig.js +88 -0
- package/dist/config/defaultConfig.js.map +1 -0
- package/dist/config/manager.d.ts +60 -0
- package/dist/config/manager.d.ts.map +1 -0
- package/dist/config/manager.js +162 -0
- package/dist/config/manager.js.map +1 -0
- package/dist/config/types.d.ts +9 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +6 -0
- package/dist/config/types.js.map +1 -0
- package/dist/index-custom.d.ts +3 -0
- package/dist/index-custom.d.ts.map +1 -0
- package/dist/index-custom.js +65 -0
- package/dist/index-custom.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +102 -0
- package/dist/index.js.map +1 -0
- package/dist/prompts/system-prompt.d.ts +47 -0
- package/dist/prompts/system-prompt.d.ts.map +1 -0
- package/dist/prompts/system-prompt.js +378 -0
- package/dist/prompts/system-prompt.js.map +1 -0
- package/dist/providers/GoogleProvider.d.ts +26 -0
- package/dist/providers/GoogleProvider.d.ts.map +1 -0
- package/dist/providers/GoogleProvider.js +313 -0
- package/dist/providers/GoogleProvider.js.map +1 -0
- package/dist/providers/Provider.d.ts +114 -0
- package/dist/providers/Provider.d.ts.map +1 -0
- package/dist/providers/Provider.js +44 -0
- package/dist/providers/Provider.js.map +1 -0
- package/dist/services/api-client.d.ts +282 -0
- package/dist/services/api-client.d.ts.map +1 -0
- package/dist/services/api-client.js +339 -0
- package/dist/services/api-client.js.map +1 -0
- package/dist/services/auth-handler.d.ts +30 -0
- package/dist/services/auth-handler.d.ts.map +1 -0
- package/dist/services/auth-handler.js +210 -0
- package/dist/services/auth-handler.js.map +1 -0
- package/dist/services/conversation-manager.d.ts +73 -0
- package/dist/services/conversation-manager.d.ts.map +1 -0
- package/dist/services/conversation-manager.js +128 -0
- package/dist/services/conversation-manager.js.map +1 -0
- package/dist/tests/automated-verification.d.ts +27 -0
- package/dist/tests/automated-verification.d.ts.map +1 -0
- package/dist/tests/automated-verification.js +359 -0
- package/dist/tests/automated-verification.js.map +1 -0
- package/dist/tests/integration-tests.d.ts +50 -0
- package/dist/tests/integration-tests.d.ts.map +1 -0
- package/dist/tests/integration-tests.js +648 -0
- package/dist/tests/integration-tests.js.map +1 -0
- package/dist/tools/ToolRegistry.d.ts +44 -0
- package/dist/tools/ToolRegistry.d.ts.map +1 -0
- package/dist/tools/ToolRegistry.js +494 -0
- package/dist/tools/ToolRegistry.js.map +1 -0
- package/dist/tools/command.d.ts +4 -0
- package/dist/tools/command.d.ts.map +1 -0
- package/dist/tools/command.js +117 -0
- package/dist/tools/command.js.map +1 -0
- package/dist/tools/file-ops-test.d.ts +6 -0
- package/dist/tools/file-ops-test.d.ts.map +1 -0
- package/dist/tools/file-ops-test.js +197 -0
- package/dist/tools/file-ops-test.js.map +1 -0
- package/dist/tools/file-ops.d.ts +6 -0
- package/dist/tools/file-ops.d.ts.map +1 -0
- package/dist/tools/file-ops.js +189 -0
- package/dist/tools/file-ops.js.map +1 -0
- package/dist/tools/plan-mode.d.ts +53 -0
- package/dist/tools/plan-mode.d.ts.map +1 -0
- package/dist/tools/plan-mode.js +202 -0
- package/dist/tools/plan-mode.js.map +1 -0
- package/dist/tools/registry.d.ts +30 -0
- package/dist/tools/registry.d.ts.map +1 -0
- package/dist/tools/registry.js +67 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/tools/types.d.ts +34 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +2 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/tools/web-search.d.ts +24 -0
- package/dist/tools/web-search.d.ts.map +1 -0
- package/dist/tools/web-search.js +194 -0
- package/dist/tools/web-search.js.map +1 -0
- package/dist/types/index.d.ts +32 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/ui/DisplayHistory.d.ts +53 -0
- package/dist/ui/DisplayHistory.d.ts.map +1 -0
- package/dist/ui/DisplayHistory.js +82 -0
- package/dist/ui/DisplayHistory.js.map +1 -0
- package/dist/ui/clack-ui.d.ts +83 -0
- package/dist/ui/clack-ui.d.ts.map +1 -0
- package/dist/ui/clack-ui.js +304 -0
- package/dist/ui/clack-ui.js.map +1 -0
- package/dist/ui/components/App.d.ts +47 -0
- package/dist/ui/components/App.d.ts.map +1 -0
- package/dist/ui/components/App.js +389 -0
- package/dist/ui/components/App.js.map +1 -0
- package/dist/ui/components/AuthScreen.d.ts +8 -0
- package/dist/ui/components/AuthScreen.d.ts.map +1 -0
- package/dist/ui/components/AuthScreen.js +37 -0
- package/dist/ui/components/AuthScreen.js.map +1 -0
- package/dist/ui/components/AuthWelcomeScreen.d.ts +8 -0
- package/dist/ui/components/AuthWelcomeScreen.d.ts.map +1 -0
- package/dist/ui/components/AuthWelcomeScreen.js +34 -0
- package/dist/ui/components/AuthWelcomeScreen.js.map +1 -0
- package/dist/ui/components/CodeBlock.d.ts +9 -0
- package/dist/ui/components/CodeBlock.d.ts.map +1 -0
- package/dist/ui/components/CodeBlock.js +22 -0
- package/dist/ui/components/CodeBlock.js.map +1 -0
- package/dist/ui/components/ConfigViewer.d.ts +11 -0
- package/dist/ui/components/ConfigViewer.d.ts.map +1 -0
- package/dist/ui/components/ConfigViewer.js +27 -0
- package/dist/ui/components/ConfigViewer.js.map +1 -0
- package/dist/ui/components/ConfirmPrompt.d.ts +11 -0
- package/dist/ui/components/ConfirmPrompt.d.ts.map +1 -0
- package/dist/ui/components/ConfirmPrompt.js +55 -0
- package/dist/ui/components/ConfirmPrompt.js.map +1 -0
- package/dist/ui/components/DiffViewer.d.ts +8 -0
- package/dist/ui/components/DiffViewer.d.ts.map +1 -0
- package/dist/ui/components/DiffViewer.js +63 -0
- package/dist/ui/components/DiffViewer.js.map +1 -0
- package/dist/ui/components/DisplayItemRenderer.d.ts +18 -0
- package/dist/ui/components/DisplayItemRenderer.d.ts.map +1 -0
- package/dist/ui/components/DisplayItemRenderer.js +53 -0
- package/dist/ui/components/DisplayItemRenderer.js.map +1 -0
- package/dist/ui/components/DynamicMessage.d.ts +13 -0
- package/dist/ui/components/DynamicMessage.d.ts.map +1 -0
- package/dist/ui/components/DynamicMessage.js +27 -0
- package/dist/ui/components/DynamicMessage.js.map +1 -0
- package/dist/ui/components/ErrorBoundary.d.ts +16 -0
- package/dist/ui/components/ErrorBoundary.d.ts.map +1 -0
- package/dist/ui/components/ErrorBoundary.js +25 -0
- package/dist/ui/components/ErrorBoundary.js.map +1 -0
- package/dist/ui/components/FileOperation.d.ts +10 -0
- package/dist/ui/components/FileOperation.d.ts.map +1 -0
- package/dist/ui/components/FileOperation.js +31 -0
- package/dist/ui/components/FileOperation.js.map +1 -0
- package/dist/ui/components/InputBox.d.ts +12 -0
- package/dist/ui/components/InputBox.d.ts.map +1 -0
- package/dist/ui/components/InputBox.js +50 -0
- package/dist/ui/components/InputBox.js.map +1 -0
- package/dist/ui/components/KeyboardHelp.d.ts +7 -0
- package/dist/ui/components/KeyboardHelp.d.ts.map +1 -0
- package/dist/ui/components/KeyboardHelp.js +25 -0
- package/dist/ui/components/KeyboardHelp.js.map +1 -0
- package/dist/ui/components/LoadingIndicator.d.ts +3 -0
- package/dist/ui/components/LoadingIndicator.d.ts.map +1 -0
- package/dist/ui/components/LoadingIndicator.js +25 -0
- package/dist/ui/components/LoadingIndicator.js.map +1 -0
- package/dist/ui/components/MarkdownRenderer.d.ts +8 -0
- package/dist/ui/components/MarkdownRenderer.d.ts.map +1 -0
- package/dist/ui/components/MarkdownRenderer.js +96 -0
- package/dist/ui/components/MarkdownRenderer.js.map +1 -0
- package/dist/ui/components/MessageBox.d.ts +10 -0
- package/dist/ui/components/MessageBox.d.ts.map +1 -0
- package/dist/ui/components/MessageBox.js +50 -0
- package/dist/ui/components/MessageBox.js.map +1 -0
- package/dist/ui/components/MessageDisplay.d.ts +8 -0
- package/dist/ui/components/MessageDisplay.d.ts.map +1 -0
- package/dist/ui/components/MessageDisplay.js +43 -0
- package/dist/ui/components/MessageDisplay.js.map +1 -0
- package/dist/ui/components/ScrollableContent.d.ts +7 -0
- package/dist/ui/components/ScrollableContent.d.ts.map +1 -0
- package/dist/ui/components/ScrollableContent.js +6 -0
- package/dist/ui/components/ScrollableContent.js.map +1 -0
- package/dist/ui/components/ScrollableMessageList.d.ts +10 -0
- package/dist/ui/components/ScrollableMessageList.d.ts.map +1 -0
- package/dist/ui/components/ScrollableMessageList.js +133 -0
- package/dist/ui/components/ScrollableMessageList.js.map +1 -0
- package/dist/ui/components/ScrollableScreen.d.ts +9 -0
- package/dist/ui/components/ScrollableScreen.d.ts.map +1 -0
- package/dist/ui/components/ScrollableScreen.js +22 -0
- package/dist/ui/components/ScrollableScreen.js.map +1 -0
- package/dist/ui/components/SelectPrompt.d.ts +12 -0
- package/dist/ui/components/SelectPrompt.d.ts.map +1 -0
- package/dist/ui/components/SelectPrompt.js +10 -0
- package/dist/ui/components/SelectPrompt.js.map +1 -0
- package/dist/ui/components/StaticMessageHistory.d.ts +14 -0
- package/dist/ui/components/StaticMessageHistory.d.ts.map +1 -0
- package/dist/ui/components/StaticMessageHistory.js +19 -0
- package/dist/ui/components/StaticMessageHistory.js.map +1 -0
- package/dist/ui/components/StatusBar.d.ts +10 -0
- package/dist/ui/components/StatusBar.d.ts.map +1 -0
- package/dist/ui/components/StatusBar.js +20 -0
- package/dist/ui/components/StatusBar.js.map +1 -0
- package/dist/ui/components/StreamingMessageDisplay.d.ts +13 -0
- package/dist/ui/components/StreamingMessageDisplay.d.ts.map +1 -0
- package/dist/ui/components/StreamingMessageDisplay.js +26 -0
- package/dist/ui/components/StreamingMessageDisplay.js.map +1 -0
- package/dist/ui/components/ToolExecutionMessage.d.ts +8 -0
- package/dist/ui/components/ToolExecutionMessage.d.ts.map +1 -0
- package/dist/ui/components/ToolExecutionMessage.js +189 -0
- package/dist/ui/components/ToolExecutionMessage.js.map +1 -0
- package/dist/ui/components/ToolExecutionStatus.d.ts +10 -0
- package/dist/ui/components/ToolExecutionStatus.d.ts.map +1 -0
- package/dist/ui/components/ToolExecutionStatus.js +65 -0
- package/dist/ui/components/ToolExecutionStatus.js.map +1 -0
- package/dist/ui/components/ToolResult.d.ts +10 -0
- package/dist/ui/components/ToolResult.d.ts.map +1 -0
- package/dist/ui/components/ToolResult.js +17 -0
- package/dist/ui/components/ToolResult.js.map +1 -0
- package/dist/ui/components/WelcomeBanner.d.ts +3 -0
- package/dist/ui/components/WelcomeBanner.d.ts.map +1 -0
- package/dist/ui/components/WelcomeBanner.js +28 -0
- package/dist/ui/components/WelcomeBanner.js.map +1 -0
- package/dist/ui/components/code-block.d.ts +10 -0
- package/dist/ui/components/code-block.d.ts.map +1 -0
- package/dist/ui/components/code-block.js +74 -0
- package/dist/ui/components/code-block.js.map +1 -0
- package/dist/ui/components/confirm-prompt.d.ts +12 -0
- package/dist/ui/components/confirm-prompt.d.ts.map +1 -0
- package/dist/ui/components/confirm-prompt.js +104 -0
- package/dist/ui/components/confirm-prompt.js.map +1 -0
- package/dist/ui/components/diff-viewer.d.ts +9 -0
- package/dist/ui/components/diff-viewer.d.ts.map +1 -0
- package/dist/ui/components/diff-viewer.js +57 -0
- package/dist/ui/components/diff-viewer.js.map +1 -0
- package/dist/ui/components/input-box.d.ts +18 -0
- package/dist/ui/components/input-box.d.ts.map +1 -0
- package/dist/ui/components/input-box.js +157 -0
- package/dist/ui/components/input-box.js.map +1 -0
- package/dist/ui/components/keyboard-help.d.ts +7 -0
- package/dist/ui/components/keyboard-help.d.ts.map +1 -0
- package/dist/ui/components/keyboard-help.js +43 -0
- package/dist/ui/components/keyboard-help.js.map +1 -0
- package/dist/ui/components/loading-indicator.d.ts +3 -0
- package/dist/ui/components/loading-indicator.d.ts.map +1 -0
- package/dist/ui/components/loading-indicator.js +42 -0
- package/dist/ui/components/loading-indicator.js.map +1 -0
- package/dist/ui/components/message-display.d.ts +7 -0
- package/dist/ui/components/message-display.d.ts.map +1 -0
- package/dist/ui/components/message-display.js +104 -0
- package/dist/ui/components/message-display.js.map +1 -0
- package/dist/ui/components/misc.d.ts +28 -0
- package/dist/ui/components/misc.d.ts.map +1 -0
- package/dist/ui/components/misc.js +128 -0
- package/dist/ui/components/misc.js.map +1 -0
- package/dist/ui/components/select-prompt.d.ts +13 -0
- package/dist/ui/components/select-prompt.d.ts.map +1 -0
- package/dist/ui/components/select-prompt.js +42 -0
- package/dist/ui/components/select-prompt.js.map +1 -0
- package/dist/ui/components/status-bar.d.ts +11 -0
- package/dist/ui/components/status-bar.d.ts.map +1 -0
- package/dist/ui/components/status-bar.js +47 -0
- package/dist/ui/components/status-bar.js.map +1 -0
- package/dist/ui/components/tool-execution.d.ts +3 -0
- package/dist/ui/components/tool-execution.d.ts.map +1 -0
- package/dist/ui/components/tool-execution.js +374 -0
- package/dist/ui/components/tool-execution.js.map +1 -0
- package/dist/ui/components/tool-result.d.ts +11 -0
- package/dist/ui/components/tool-result.d.ts.map +1 -0
- package/dist/ui/components/tool-result.js +58 -0
- package/dist/ui/components/tool-result.js.map +1 -0
- package/dist/ui/components/welcome-banner.d.ts +3 -0
- package/dist/ui/components/welcome-banner.d.ts.map +1 -0
- package/dist/ui/components/welcome-banner.js +46 -0
- package/dist/ui/components/welcome-banner.js.map +1 -0
- package/dist/ui/hooks/useDisplayHistory.d.ts +13 -0
- package/dist/ui/hooks/useDisplayHistory.d.ts.map +1 -0
- package/dist/ui/hooks/useDisplayHistory.js +45 -0
- package/dist/ui/hooks/useDisplayHistory.js.map +1 -0
- package/dist/ui/render-engine.d.ts +69 -0
- package/dist/ui/render-engine.d.ts.map +1 -0
- package/dist/ui/render-engine.js +197 -0
- package/dist/ui/render-engine.js.map +1 -0
- package/dist/ui/terminal/TerminalRenderer.d.ts +84 -0
- package/dist/ui/terminal/TerminalRenderer.d.ts.map +1 -0
- package/dist/ui/terminal/TerminalRenderer.js +154 -0
- package/dist/ui/terminal/TerminalRenderer.js.map +1 -0
- package/dist/ui/terminal/TerminalUI.d.ts +139 -0
- package/dist/ui/terminal/TerminalUI.d.ts.map +1 -0
- package/dist/ui/terminal/TerminalUI.js +430 -0
- package/dist/ui/terminal/TerminalUI.js.map +1 -0
- package/dist/ui/terminal/VirtualChatBuffer.d.ts +32 -0
- package/dist/ui/terminal/VirtualChatBuffer.d.ts.map +1 -0
- package/dist/ui/terminal/VirtualChatBuffer.js +37 -0
- package/dist/ui/terminal/VirtualChatBuffer.js.map +1 -0
- package/dist/ui/terminal-kit-base.d.ts +117 -0
- package/dist/ui/terminal-kit-base.d.ts.map +1 -0
- package/dist/ui/terminal-kit-base.js +188 -0
- package/dist/ui/terminal-kit-base.js.map +1 -0
- package/dist/utils/file.d.ts +21 -0
- package/dist/utils/file.d.ts.map +1 -0
- package/dist/utils/file.js +68 -0
- package/dist/utils/file.js.map +1 -0
- package/dist/utils/logger.d.ts +17 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +57 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/markdown-parser.d.ts +56 -0
- package/dist/utils/markdown-parser.d.ts.map +1 -0
- package/dist/utils/markdown-parser.js +307 -0
- package/dist/utils/markdown-parser.js.map +1 -0
- package/dist/utils/shell.d.ts +7 -0
- package/dist/utils/shell.d.ts.map +1 -0
- package/dist/utils/shell.js +62 -0
- package/dist/utils/shell.js.map +1 -0
- package/dist/utils/state.d.ts +13 -0
- package/dist/utils/state.d.ts.map +1 -0
- package/dist/utils/state.js +25 -0
- package/dist/utils/state.js.map +1 -0
- package/package.json +81 -0
- package/postinstall.js +46 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import React, { useMemo } from 'react';
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import { MarkdownParser, wrapText } from '../../utils/markdown-parser.js';
|
|
4
|
+
export const MarkdownRenderer = ({ content, maxWidth = 100 }) => {
|
|
5
|
+
const parser = useMemo(() => new MarkdownParser(), []);
|
|
6
|
+
const elements = useMemo(() => parser.parse(content), [content, parser]);
|
|
7
|
+
const renderInlineElements = (children) => {
|
|
8
|
+
if (!children || children.length === 0)
|
|
9
|
+
return null;
|
|
10
|
+
return children.map((child, idx) => {
|
|
11
|
+
switch (child.type) {
|
|
12
|
+
case 'bold':
|
|
13
|
+
return (React.createElement(Text, { key: idx, bold: true, color: "#ffffff" }, child.content));
|
|
14
|
+
case 'italic':
|
|
15
|
+
return (React.createElement(Text, { key: idx, italic: true, color: "#cccccc" }, child.content));
|
|
16
|
+
case 'code-inline':
|
|
17
|
+
return (React.createElement(Text, { key: idx, backgroundColor: "#2d2d2d", color: "#ff79c6" }, ` ${child.content} `));
|
|
18
|
+
case 'link':
|
|
19
|
+
return (React.createElement(Text, { key: idx, color: "#00ccff", underline: true }, child.content));
|
|
20
|
+
case 'text':
|
|
21
|
+
default:
|
|
22
|
+
return (React.createElement(Text, { key: idx, color: "#ffffff" }, child.content));
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
const renderElement = (element, index) => {
|
|
27
|
+
switch (element.type) {
|
|
28
|
+
case 'heading': {
|
|
29
|
+
const level = element.level || 1;
|
|
30
|
+
const colors = ['#00ffff', '#00dddd', '#00bbbb', '#009999', '#007777', '#005555'];
|
|
31
|
+
const color = colors[level - 1] || '#ffffff';
|
|
32
|
+
const prefix = level === 1 ? '\n' : '';
|
|
33
|
+
const suffix = '\n';
|
|
34
|
+
return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1 },
|
|
35
|
+
React.createElement(Text, { bold: true, color: color },
|
|
36
|
+
prefix,
|
|
37
|
+
'#'.repeat(level),
|
|
38
|
+
" ",
|
|
39
|
+
element.content,
|
|
40
|
+
suffix)));
|
|
41
|
+
}
|
|
42
|
+
case 'code-block': {
|
|
43
|
+
const lines = element.content.split('\n');
|
|
44
|
+
return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1, marginTop: 1 },
|
|
45
|
+
React.createElement(Box, { borderStyle: "round", borderColor: "#666666", paddingX: 1, paddingY: 0 },
|
|
46
|
+
React.createElement(Box, { flexDirection: "column" },
|
|
47
|
+
element.language && element.language !== 'text' && (React.createElement(Text, { color: "#888888", dimColor: true }, element.language)),
|
|
48
|
+
lines.map((line, lineIdx) => (React.createElement(Text, { key: lineIdx, color: "#f8f8f2" }, line || ' ')))))));
|
|
49
|
+
}
|
|
50
|
+
case 'list-item': {
|
|
51
|
+
const indent = (element.level || 0) * 2;
|
|
52
|
+
const bullet = element.ordered ? `${element.index}.` : '•';
|
|
53
|
+
const bulletColor = '#00cc66';
|
|
54
|
+
return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 0 },
|
|
55
|
+
React.createElement(Box, null,
|
|
56
|
+
React.createElement(Text, { color: "#666666" }, ' '.repeat(indent)),
|
|
57
|
+
React.createElement(Text, { color: bulletColor, bold: true },
|
|
58
|
+
bullet,
|
|
59
|
+
' '),
|
|
60
|
+
element.children && element.children.length > 0 ? (React.createElement(Text, null, renderInlineElements(element.children))) : (React.createElement(Text, { color: "#ffffff" }, element.content)))));
|
|
61
|
+
}
|
|
62
|
+
case 'blockquote': {
|
|
63
|
+
return (React.createElement(Box, { key: index, flexDirection: "row", marginBottom: 1 },
|
|
64
|
+
React.createElement(Text, { color: "#666666", bold: true },
|
|
65
|
+
"\u2502",
|
|
66
|
+
' '),
|
|
67
|
+
React.createElement(Text, { color: "#cccccc", italic: true }, element.children && element.children.length > 0
|
|
68
|
+
? renderInlineElements(element.children)
|
|
69
|
+
: element.content)));
|
|
70
|
+
}
|
|
71
|
+
case 'horizontal-rule': {
|
|
72
|
+
return (React.createElement(Box, { key: index, marginY: 1 },
|
|
73
|
+
React.createElement(Text, { color: "#444444" }, '─'.repeat(Math.min(maxWidth, 80)))));
|
|
74
|
+
}
|
|
75
|
+
case 'line-break': {
|
|
76
|
+
return React.createElement(Box, { key: index, height: 1 });
|
|
77
|
+
}
|
|
78
|
+
case 'text': {
|
|
79
|
+
// If we have inline children (formatted text), render them directly
|
|
80
|
+
if (element.children && element.children.length > 0) {
|
|
81
|
+
return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1 },
|
|
82
|
+
React.createElement(Box, { paddingLeft: 2 },
|
|
83
|
+
React.createElement(Text, null, renderInlineElements(element.children)))));
|
|
84
|
+
}
|
|
85
|
+
// Otherwise, wrap plain text if needed
|
|
86
|
+
const wrappedLines = wrapText(element.content, maxWidth, 2);
|
|
87
|
+
return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1 }, wrappedLines.map((line, lineIdx) => (React.createElement(Box, { key: lineIdx, paddingLeft: 2 },
|
|
88
|
+
React.createElement(Text, { color: "#ffffff" }, line))))));
|
|
89
|
+
}
|
|
90
|
+
default:
|
|
91
|
+
return null;
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
return (React.createElement(Box, { flexDirection: "column" }, elements.map((element, index) => renderElement(element, index))));
|
|
95
|
+
};
|
|
96
|
+
//# sourceMappingURL=MarkdownRenderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarkdownRenderer.js","sourceRoot":"","sources":["../../../src/ui/components/MarkdownRenderer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface MessageBoxProps {
|
|
3
|
+
role: 'user' | 'assistant' | 'system';
|
|
4
|
+
content: string;
|
|
5
|
+
timestamp?: Date;
|
|
6
|
+
isStreaming?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare const MessageBox: React.FC<MessageBoxProps>;
|
|
9
|
+
export default MessageBox;
|
|
10
|
+
//# sourceMappingURL=MessageBox.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageBox.d.ts","sourceRoot":"","sources":["../../../src/ui/components/MessageBox.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,eAAe;IACvB,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA+EhD,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import chalk from 'chalk';
|
|
4
|
+
export const MessageBox = ({ role, content, timestamp, isStreaming }) => {
|
|
5
|
+
const renderContent = () => {
|
|
6
|
+
// Parse markdown-style formatting
|
|
7
|
+
let formattedContent = content;
|
|
8
|
+
// Bold text
|
|
9
|
+
formattedContent = formattedContent.replace(/\*\*(.*?)\*\*/g, (_, text) => chalk.bold(text));
|
|
10
|
+
// Code blocks
|
|
11
|
+
formattedContent = formattedContent.replace(/`([^`]+)`/g, (_, code) => chalk.gray.bgBlackBright(` ${code} `));
|
|
12
|
+
// Links
|
|
13
|
+
formattedContent = formattedContent.replace(/\[([^\]]+)\]\(([^)]+)\)/g, (_, text, url) => chalk.blue.underline(text));
|
|
14
|
+
return formattedContent;
|
|
15
|
+
};
|
|
16
|
+
const getPrefix = () => {
|
|
17
|
+
switch (role) {
|
|
18
|
+
case 'user':
|
|
19
|
+
return chalk.cyan('Your Message:');
|
|
20
|
+
case 'assistant':
|
|
21
|
+
return chalk.green('Centaurus:');
|
|
22
|
+
case 'system':
|
|
23
|
+
return chalk.yellow('System:');
|
|
24
|
+
default:
|
|
25
|
+
return '';
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
const getBorderColor = () => {
|
|
29
|
+
switch (role) {
|
|
30
|
+
case 'user':
|
|
31
|
+
return 'cyan';
|
|
32
|
+
case 'assistant':
|
|
33
|
+
return 'green';
|
|
34
|
+
case 'system':
|
|
35
|
+
return 'yellow';
|
|
36
|
+
default:
|
|
37
|
+
return 'white';
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
return (React.createElement(Box, { flexDirection: "column", marginY: 1, paddingX: 1, borderStyle: "round", borderColor: getBorderColor() },
|
|
41
|
+
React.createElement(Box, { justifyContent: "space-between", marginBottom: 1 },
|
|
42
|
+
React.createElement(Text, null, getPrefix()),
|
|
43
|
+
timestamp && (React.createElement(Text, { dimColor: true }, timestamp.toLocaleTimeString()))),
|
|
44
|
+
React.createElement(Box, { paddingLeft: 2 },
|
|
45
|
+
React.createElement(Text, { wrap: "wrap" },
|
|
46
|
+
renderContent(),
|
|
47
|
+
isStreaming && React.createElement(Text, { color: "cyan" }, "\u258C")))));
|
|
48
|
+
};
|
|
49
|
+
export default MessageBox;
|
|
50
|
+
//# sourceMappingURL=MessageBox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageBox.js","sourceRoot":"","sources":["../../../src/ui/components/MessageBox.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,KAAK,MAAM,OAAO,CAAC;AAS1B,MAAM,CAAC,MAAM,UAAU,GAA8B,CAAC,EACpD,IAAI,EACJ,OAAO,EACP,SAAS,EACT,WAAW,EACZ,EAAE,EAAE;IACH,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,kCAAkC;QAClC,IAAI,gBAAgB,GAAG,OAAO,CAAC;QAE/B,YAAY;QACZ,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,CACxE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CACjB,CAAC;QAEF,cAAc;QACd,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,CACpE,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,GAAG,CAAC,CACtC,CAAC;QAEF,QAAQ;QACR,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,0BAA0B,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,CACvF,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAC3B,CAAC;QAEF,OAAO,gBAAgB,CAAC;IAC1B,CAAC,CAAC;IAEF,MAAM,SAAS,GAAG,GAAG,EAAE;QACrB,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM;gBACT,OAAO,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACrC,KAAK,WAAW;gBACd,OAAO,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YACnC,KAAK,QAAQ;gBACX,OAAO,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACjC;gBACE,OAAO,EAAE,CAAC;QACd,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM;gBACT,OAAO,MAAM,CAAC;YAChB,KAAK,WAAW;gBACd,OAAO,OAAO,CAAC;YACjB,KAAK,QAAQ;gBACX,OAAO,QAAQ,CAAC;YAClB;gBACE,OAAO,OAAO,CAAC;QACnB,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CACL,oBAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,OAAO,EAAE,CAAC,EACV,QAAQ,EAAE,CAAC,EACX,WAAW,EAAC,OAAO,EACnB,WAAW,EAAE,cAAc,EAAE;QAE7B,oBAAC,GAAG,IAAC,cAAc,EAAC,eAAe,EAAC,YAAY,EAAE,CAAC;YACjD,oBAAC,IAAI,QAAE,SAAS,EAAE,CAAQ;YACzB,SAAS,IAAI,CACZ,oBAAC,IAAI,IAAC,QAAQ,UACX,SAAS,CAAC,kBAAkB,EAAE,CAC1B,CACR,CACG;QAEN,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;YACjB,oBAAC,IAAI,IAAC,IAAI,EAAC,MAAM;gBACd,aAAa,EAAE;gBACf,WAAW,IAAI,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM,aAAS,CACtC,CACH,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageDisplay.d.ts","sourceRoot":"","sources":["../../../src/ui/components/MessageDisplay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAI/C,UAAU,mBAAmB;IAC3B,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CAoDvD,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import { ToolExecutionMessage } from './ToolExecutionMessage.js';
|
|
4
|
+
import { MarkdownRenderer } from './MarkdownRenderer.js';
|
|
5
|
+
export const MessageDisplay = React.memo(({ message }) => {
|
|
6
|
+
const getRoleColor = (role) => {
|
|
7
|
+
switch (role) {
|
|
8
|
+
case 'user': return '#00ccff';
|
|
9
|
+
case 'assistant': return '#00cc66';
|
|
10
|
+
case 'system': return '#ffaa00';
|
|
11
|
+
case 'tool': return '#00ccff';
|
|
12
|
+
default: return '#ffffff';
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
const getRoleLabel = (role) => {
|
|
16
|
+
switch (role) {
|
|
17
|
+
case 'user': return 'You';
|
|
18
|
+
case 'assistant': return 'Centaurus';
|
|
19
|
+
case 'system': return 'System';
|
|
20
|
+
case 'tool': return 'Tool';
|
|
21
|
+
default: return role;
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
const timestamp = message.timestamp
|
|
25
|
+
? new Date(message.timestamp).toLocaleTimeString()
|
|
26
|
+
: '';
|
|
27
|
+
// Render tool execution message using specialized component
|
|
28
|
+
if (message.toolExecution) {
|
|
29
|
+
return React.createElement(ToolExecutionMessage, { message: message });
|
|
30
|
+
}
|
|
31
|
+
// Regular message rendering
|
|
32
|
+
return (React.createElement(Box, { flexDirection: "column", marginBottom: 1 },
|
|
33
|
+
React.createElement(Box, { marginBottom: 1 },
|
|
34
|
+
React.createElement(Text, { color: getRoleColor(message.role), bold: true },
|
|
35
|
+
getRoleLabel(message.role),
|
|
36
|
+
":"),
|
|
37
|
+
timestamp && (React.createElement(Text, { color: "#666666", dimColor: true },
|
|
38
|
+
" ",
|
|
39
|
+
timestamp))),
|
|
40
|
+
message.role === 'assistant' ? (React.createElement(MarkdownRenderer, { content: message.content, maxWidth: 100 })) : (React.createElement(Box, { paddingLeft: 2 },
|
|
41
|
+
React.createElement(Text, { color: "#ffffff" }, message.content)))));
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=MessageDisplay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageDisplay.js","sourceRoot":"","sources":["../../../src/ui/components/MessageDisplay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAEhC,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAMzD,MAAM,CAAC,MAAM,cAAc,GAAkC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;IACtF,MAAM,YAAY,GAAG,CAAC,IAAY,EAAE,EAAE;QACpC,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM,CAAC,CAAC,OAAO,SAAS,CAAC;YAC9B,KAAK,WAAW,CAAC,CAAC,OAAO,SAAS,CAAC;YACnC,KAAK,QAAQ,CAAC,CAAC,OAAO,SAAS,CAAC;YAChC,KAAK,MAAM,CAAC,CAAC,OAAO,SAAS,CAAC;YAC9B,OAAO,CAAC,CAAC,OAAO,SAAS,CAAC;QAC5B,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,CAAC,IAAY,EAAE,EAAE;QACpC,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM,CAAC,CAAC,OAAO,KAAK,CAAC;YAC1B,KAAK,WAAW,CAAC,CAAC,OAAO,WAAW,CAAC;YACrC,KAAK,QAAQ,CAAC,CAAC,OAAO,QAAQ,CAAC;YAC/B,KAAK,MAAM,CAAC,CAAC,OAAO,MAAM,CAAC;YAC3B,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC;QACvB,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS;QACjC,CAAC,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,kBAAkB,EAAE;QAClD,CAAC,CAAC,EAAE,CAAC;IAEP,4DAA4D;IAC5D,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;QAC1B,OAAO,oBAAC,oBAAoB,IAAC,OAAO,EAAE,OAAO,GAAI,CAAC;IACpD,CAAC;IAED,4BAA4B;IAC5B,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,YAAY,EAAE,CAAC;QACzC,oBAAC,GAAG,IAAC,YAAY,EAAE,CAAC;YAClB,oBAAC,IAAI,IAAC,KAAK,EAAE,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI;gBAC1C,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC;oBACtB;YACN,SAAS,IAAI,CACZ,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,QAAQ;;gBAAG,SAAS,CAAQ,CACnD,CACG;QAGL,OAAO,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC,CAC9B,oBAAC,gBAAgB,IAAC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,GAAG,GAAI,CAC9D,CAAC,CAAC,CAAC,CACF,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;YACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,IAAE,OAAO,CAAC,OAAO,CAAQ,CAC1C,CACP,CACG,CACP,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollableContent.d.ts","sourceRoot":"","sources":["../../../src/ui/components/ScrollableContent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,sBAAsB;IAC9B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CAM9D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollableContent.js","sourceRoot":"","sources":["../../../src/ui/components/ScrollableContent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAM1B,MAAM,CAAC,MAAM,iBAAiB,GAAqC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IAClF,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,IACpC,QAAQ,CACL,CACP,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Message } from '../../types/index.js';
|
|
3
|
+
interface ScrollableMessageListProps {
|
|
4
|
+
messages: Message[];
|
|
5
|
+
maxScrollback?: number;
|
|
6
|
+
viewportHeight?: number;
|
|
7
|
+
}
|
|
8
|
+
export declare const ScrollableMessageList: React.FC<ScrollableMessageListProps>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=ScrollableMessageList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollableMessageList.d.ts","sourceRoot":"","sources":["../../../src/ui/components/ScrollableMessageList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA+C,MAAM,OAAO,CAAC;AAGpE,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAE/C,UAAU,0BAA0B;IAClC,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,0BAA0B,CAoKtE,CAAC"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import React, { useState, useEffect, useRef, useMemo } from 'react';
|
|
2
|
+
import { Box, useInput, useStdin, Text } from 'ink';
|
|
3
|
+
import { MessageDisplay } from './MessageDisplay.js';
|
|
4
|
+
export const ScrollableMessageList = ({ messages, maxScrollback = 500, viewportHeight = 20 }) => {
|
|
5
|
+
const [scrollOffset, setScrollOffset] = useState(0);
|
|
6
|
+
const [isScrolledToBottom, setIsScrolledToBottom] = useState(true);
|
|
7
|
+
const { stdin, setRawMode } = useStdin();
|
|
8
|
+
const prevMessagesLengthRef = useRef(messages.length);
|
|
9
|
+
// Limit messages to max scrollback
|
|
10
|
+
const limitedMessages = useMemo(() => {
|
|
11
|
+
return messages.slice(-maxScrollback);
|
|
12
|
+
}, [messages, maxScrollback]);
|
|
13
|
+
const totalMessages = limitedMessages.length;
|
|
14
|
+
const maxScrollOffset = Math.max(0, totalMessages - viewportHeight);
|
|
15
|
+
// Auto-scroll to bottom when new messages arrive (only if already at bottom)
|
|
16
|
+
useEffect(() => {
|
|
17
|
+
if (messages.length > prevMessagesLengthRef.current) {
|
|
18
|
+
if (isScrolledToBottom) {
|
|
19
|
+
setScrollOffset(Math.max(0, messages.slice(-maxScrollback).length - viewportHeight));
|
|
20
|
+
}
|
|
21
|
+
prevMessagesLengthRef.current = messages.length;
|
|
22
|
+
}
|
|
23
|
+
}, [messages, isScrolledToBottom, viewportHeight, maxScrollback]);
|
|
24
|
+
// Check if we're at the bottom
|
|
25
|
+
useEffect(() => {
|
|
26
|
+
const atBottom = scrollOffset >= maxScrollOffset;
|
|
27
|
+
setIsScrolledToBottom(atBottom);
|
|
28
|
+
}, [scrollOffset, maxScrollOffset]);
|
|
29
|
+
// Keyboard input handling
|
|
30
|
+
useInput((input, key) => {
|
|
31
|
+
// Don't handle input if there are too few messages to scroll
|
|
32
|
+
if (totalMessages <= viewportHeight)
|
|
33
|
+
return;
|
|
34
|
+
if (key.upArrow) {
|
|
35
|
+
setScrollOffset(prev => Math.max(0, prev - 1));
|
|
36
|
+
}
|
|
37
|
+
else if (key.downArrow) {
|
|
38
|
+
setScrollOffset(prev => Math.min(maxScrollOffset, prev + 1));
|
|
39
|
+
}
|
|
40
|
+
else if (key.pageUp) {
|
|
41
|
+
setScrollOffset(prev => Math.max(0, prev - viewportHeight));
|
|
42
|
+
}
|
|
43
|
+
else if (key.pageDown) {
|
|
44
|
+
setScrollOffset(prev => Math.min(maxScrollOffset, prev + viewportHeight));
|
|
45
|
+
}
|
|
46
|
+
else if (input === 'g' || input === 'G') {
|
|
47
|
+
// Home - go to top
|
|
48
|
+
if (input === 'g') {
|
|
49
|
+
setScrollOffset(0);
|
|
50
|
+
}
|
|
51
|
+
// End - go to bottom
|
|
52
|
+
if (input === 'G') {
|
|
53
|
+
setScrollOffset(maxScrollOffset);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
// Mouse wheel support
|
|
58
|
+
useEffect(() => {
|
|
59
|
+
if (!stdin || typeof setRawMode !== 'function')
|
|
60
|
+
return;
|
|
61
|
+
// Enable mouse tracking (X11 mouse protocol)
|
|
62
|
+
process.stdout.write('\x1b[?1000h'); // Enable mouse button events
|
|
63
|
+
process.stdout.write('\x1b[?1003h'); // Enable all mouse events
|
|
64
|
+
process.stdout.write('\x1b[?1015h'); // Enable urxvt mouse mode
|
|
65
|
+
process.stdout.write('\x1b[?1006h'); // Enable SGR mouse mode
|
|
66
|
+
const handleData = (data) => {
|
|
67
|
+
const str = data.toString('utf8');
|
|
68
|
+
// Parse SGR mouse format: \x1b[<b;x;y;M or m
|
|
69
|
+
// Wheel up: button 64, Wheel down: button 65
|
|
70
|
+
const sgrMatch = str.match(/\x1b\[<(\d+);(\d+);(\d+)([Mm])/);
|
|
71
|
+
if (sgrMatch) {
|
|
72
|
+
const button = parseInt(sgrMatch[1], 10);
|
|
73
|
+
const action = sgrMatch[4];
|
|
74
|
+
if (action === 'M') { // Mouse button press
|
|
75
|
+
if (button === 64) {
|
|
76
|
+
// Scroll up (wheel up)
|
|
77
|
+
setScrollOffset(prev => Math.max(0, prev - 3));
|
|
78
|
+
}
|
|
79
|
+
else if (button === 65) {
|
|
80
|
+
// Scroll down (wheel down)
|
|
81
|
+
setScrollOffset(prev => Math.min(maxScrollOffset, prev + 3));
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
// Fallback: Parse X10 mouse format: \x1b[Mbxy
|
|
86
|
+
if (str.startsWith('\x1b[M') && str.length >= 6) {
|
|
87
|
+
const cb = str.charCodeAt(3) - 32;
|
|
88
|
+
// Wheel up: 64, Wheel down: 65
|
|
89
|
+
if (cb === 64) {
|
|
90
|
+
setScrollOffset(prev => Math.max(0, prev - 3));
|
|
91
|
+
}
|
|
92
|
+
else if (cb === 65) {
|
|
93
|
+
setScrollOffset(prev => Math.min(maxScrollOffset, prev + 3));
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
stdin.on('data', handleData);
|
|
98
|
+
return () => {
|
|
99
|
+
// Disable mouse tracking on cleanup
|
|
100
|
+
process.stdout.write('\x1b[?1000l');
|
|
101
|
+
process.stdout.write('\x1b[?1003l');
|
|
102
|
+
process.stdout.write('\x1b[?1015l');
|
|
103
|
+
process.stdout.write('\x1b[?1006l');
|
|
104
|
+
stdin.off('data', handleData);
|
|
105
|
+
};
|
|
106
|
+
}, [stdin, setRawMode, maxScrollOffset]);
|
|
107
|
+
// Calculate visible messages
|
|
108
|
+
const visibleMessages = useMemo(() => {
|
|
109
|
+
const start = scrollOffset;
|
|
110
|
+
const end = Math.min(totalMessages, scrollOffset + viewportHeight);
|
|
111
|
+
return limitedMessages.slice(start, end);
|
|
112
|
+
}, [limitedMessages, scrollOffset, viewportHeight, totalMessages]);
|
|
113
|
+
// Scrollbar indicator
|
|
114
|
+
const showScrollbar = totalMessages > viewportHeight;
|
|
115
|
+
const scrollbarPosition = maxScrollOffset > 0
|
|
116
|
+
? Math.round((scrollOffset / maxScrollOffset) * (viewportHeight - 1))
|
|
117
|
+
: 0;
|
|
118
|
+
return (React.createElement(Box, { flexDirection: "row", width: "100%" },
|
|
119
|
+
React.createElement(Box, { flexDirection: "column", flexGrow: 1, marginY: 1 },
|
|
120
|
+
visibleMessages.map((msg) => (React.createElement(MessageDisplay, { key: msg.id, message: msg }))),
|
|
121
|
+
totalMessages > viewportHeight && !isScrolledToBottom && (React.createElement(Box, { marginTop: 1 },
|
|
122
|
+
React.createElement(Text, { dimColor: true },
|
|
123
|
+
"\u2193 ",
|
|
124
|
+
totalMessages - (scrollOffset + viewportHeight),
|
|
125
|
+
" more messages below (\u2193/PgDn/G)"))),
|
|
126
|
+
totalMessages > viewportHeight && scrollOffset > 0 && (React.createElement(Box, null,
|
|
127
|
+
React.createElement(Text, { dimColor: true },
|
|
128
|
+
"\u2191 ",
|
|
129
|
+
scrollOffset,
|
|
130
|
+
" messages above (\u2191/PgUp/g)")))),
|
|
131
|
+
showScrollbar && (React.createElement(Box, { flexDirection: "column", marginLeft: 1, width: 1 }, Array.from({ length: viewportHeight }).map((_, i) => (React.createElement(Text, { key: i, dimColor: true }, i === scrollbarPosition ? '█' : '│')))))));
|
|
132
|
+
};
|
|
133
|
+
//# sourceMappingURL=ScrollableMessageList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollableMessageList.js","sourceRoot":"","sources":["../../../src/ui/components/ScrollableMessageList.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* ScrollableScreen component that uses alternate screen buffer with scrolling enabled
|
|
4
|
+
* This prevents seeing duplicate renders while allowing scrollback within the current session
|
|
5
|
+
*/
|
|
6
|
+
export declare const ScrollableScreen: React.FC<{
|
|
7
|
+
children: React.ReactNode;
|
|
8
|
+
}>;
|
|
9
|
+
//# sourceMappingURL=ScrollableScreen.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollableScreen.d.ts","sourceRoot":"","sources":["../../../src/ui/components/ScrollableScreen.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B;;;GAGG;AACH,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAkBpE,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box } from 'ink';
|
|
3
|
+
/**
|
|
4
|
+
* ScrollableScreen component that uses alternate screen buffer with scrolling enabled
|
|
5
|
+
* This prevents seeing duplicate renders while allowing scrollback within the current session
|
|
6
|
+
*/
|
|
7
|
+
export const ScrollableScreen = ({ children }) => {
|
|
8
|
+
React.useEffect(() => {
|
|
9
|
+
// Enter alternate screen buffer
|
|
10
|
+
process.stdout.write('\x1B[?1049h');
|
|
11
|
+
// Enable scrolling in the alternate buffer
|
|
12
|
+
process.stdout.write('\x1B[?7h'); // Enable line wrap
|
|
13
|
+
// Clear screen and home cursor
|
|
14
|
+
process.stdout.write('\x1B[2J\x1B[H');
|
|
15
|
+
return () => {
|
|
16
|
+
// Exit alternate screen buffer on unmount
|
|
17
|
+
process.stdout.write('\x1B[?1049l');
|
|
18
|
+
};
|
|
19
|
+
}, []);
|
|
20
|
+
return React.createElement(Box, { flexDirection: "column" }, children);
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=ScrollableScreen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollableScreen.js","sourceRoot":"","sources":["../../../src/ui/components/ScrollableScreen.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B;;;GAGG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAA4C,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IACxF,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,gCAAgC;QAChC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAEpC,2CAA2C;QAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,mBAAmB;QAErD,+BAA+B;QAC/B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAEtC,OAAO,GAAG,EAAE;YACV,0CAA0C;YAC1C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACtC,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,IAAE,QAAQ,CAAO,CAAC;AACtD,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface SelectPromptProps {
|
|
3
|
+
message: string;
|
|
4
|
+
choices: Array<{
|
|
5
|
+
label: string;
|
|
6
|
+
value: string;
|
|
7
|
+
}>;
|
|
8
|
+
onSelect: (value: string) => void;
|
|
9
|
+
}
|
|
10
|
+
export declare const SelectPrompt: React.FC<SelectPromptProps>;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=SelectPrompt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SelectPrompt.d.ts","sourceRoot":"","sources":["../../../src/ui/components/SelectPrompt.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,iBAAiB;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACjD,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACnC;AAED,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import SelectInput from 'ink-select-input';
|
|
4
|
+
export const SelectPrompt = ({ message, choices, onSelect }) => {
|
|
5
|
+
return (React.createElement(Box, { flexDirection: "column", borderStyle: "round", borderColor: "#00ccff", paddingX: 1 },
|
|
6
|
+
React.createElement(Text, { color: "#00ccff", bold: true }, message),
|
|
7
|
+
React.createElement(Box, { marginTop: 1 },
|
|
8
|
+
React.createElement(SelectInput, { items: choices, onSelect: (item) => onSelect(item.value) }))));
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=SelectPrompt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SelectPrompt.js","sourceRoot":"","sources":["../../../src/ui/components/SelectPrompt.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,WAAW,MAAM,kBAAkB,CAAC;AAQ3C,MAAM,CAAC,MAAM,YAAY,GAAgC,CAAC,EACxD,OAAO,EACP,OAAO,EACP,QAAQ,EACT,EAAE,EAAE;IACH,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAC,OAAO,EAAC,WAAW,EAAC,SAAS,EAAC,QAAQ,EAAE,CAAC;QAC/E,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,IAAI,UAAE,OAAO,CAAQ;QAC3C,oBAAC,GAAG,IAAC,SAAS,EAAE,CAAC;YACf,oBAAC,WAAW,IACV,KAAK,EAAE,OAAO,EACd,QAAQ,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GACxC,CACE,CACF,CACP,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Message } from '../../types/index.js';
|
|
3
|
+
interface StaticMessageHistoryProps {
|
|
4
|
+
messages: Message[];
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Renders completed messages using Ink's Static component.
|
|
8
|
+
* These messages are "frozen" and never re-render.
|
|
9
|
+
* This is the key to preventing UI duplication - once a message is rendered
|
|
10
|
+
* in Static, it's written to stdout and frozen forever.
|
|
11
|
+
*/
|
|
12
|
+
export declare const StaticMessageHistory: React.FC<StaticMessageHistoryProps>;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=StaticMessageHistory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StaticMessageHistory.d.ts","sourceRoot":"","sources":["../../../src/ui/components/StaticMessageHistory.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG/C,UAAU,yBAAyB;IACjC,QAAQ,EAAE,OAAO,EAAE,CAAC;CACrB;AAED;;;;;GAKG;AACH,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAAE,CAAC,yBAAyB,CAcnE,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Static } from 'ink';
|
|
3
|
+
import { MessageDisplay } from './MessageDisplay.js';
|
|
4
|
+
/**
|
|
5
|
+
* Renders completed messages using Ink's Static component.
|
|
6
|
+
* These messages are "frozen" and never re-render.
|
|
7
|
+
* This is the key to preventing UI duplication - once a message is rendered
|
|
8
|
+
* in Static, it's written to stdout and frozen forever.
|
|
9
|
+
*/
|
|
10
|
+
export const StaticMessageHistory = React.memo(({ messages }) => {
|
|
11
|
+
// Static component ensures these items never re-render
|
|
12
|
+
// They are written to stdout once and frozen
|
|
13
|
+
return (React.createElement(Static, { items: messages }, (message) => (React.createElement(MessageDisplay, { key: message.id, message: message }))));
|
|
14
|
+
}, (prevProps, nextProps) => {
|
|
15
|
+
// Return true to SKIP re-render, false to re-render
|
|
16
|
+
// Only re-render when messages array actually changes (new messages added)
|
|
17
|
+
return prevProps.messages === nextProps.messages;
|
|
18
|
+
});
|
|
19
|
+
//# sourceMappingURL=StaticMessageHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StaticMessageHistory.js","sourceRoot":"","sources":["../../../src/ui/components/StaticMessageHistory.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAE7B,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAMrD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAwC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IACnG,uDAAuD;IACvD,6CAA6C;IAC7C,OAAO,CACL,oBAAC,MAAM,IAAC,KAAK,EAAE,QAAQ,IACpB,CAAC,OAAO,EAAE,EAAE,CAAC,CACZ,oBAAC,cAAc,IAAC,GAAG,EAAE,OAAO,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,GAAI,CACtD,CACM,CACV,CAAC;AACJ,CAAC,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE;IAC1B,oDAAoD;IACpD,2EAA2E;IAC3E,OAAO,SAAS,CAAC,QAAQ,KAAK,SAAS,CAAC,QAAQ,CAAC;AACnD,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface StatusBarProps {
|
|
3
|
+
autoAcceptMode: boolean;
|
|
4
|
+
isLoading: boolean;
|
|
5
|
+
loadingMessage?: string;
|
|
6
|
+
model?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare const StatusBar: React.FC<StatusBarProps>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=StatusBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusBar.d.ts","sourceRoot":"","sources":["../../../src/ui/components/StatusBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,cAAc;IACtB,cAAc,EAAE,OAAO,CAAC;IACxB,SAAS,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAoC9C,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box, Text } from 'ink';
|
|
3
|
+
import Spinner from 'ink-spinner';
|
|
4
|
+
export const StatusBar = ({ autoAcceptMode, isLoading, loadingMessage = 'Processing...', model }) => {
|
|
5
|
+
return (React.createElement(Box, { borderStyle: "single", borderColor: "#003b59", paddingX: 1 },
|
|
6
|
+
React.createElement(Box, { flexGrow: 1 },
|
|
7
|
+
isLoading && (React.createElement(Box, { marginRight: 1 },
|
|
8
|
+
React.createElement(Text, { color: "#00ccff" },
|
|
9
|
+
React.createElement(Spinner, { type: "dots" })),
|
|
10
|
+
React.createElement(Text, { color: "#00ccff" },
|
|
11
|
+
" ",
|
|
12
|
+
loadingMessage))),
|
|
13
|
+
!isLoading && model && (React.createElement(Box, { marginRight: 1 },
|
|
14
|
+
React.createElement(Text, { color: "#666666" }, "Model: "),
|
|
15
|
+
React.createElement(Text, { color: "#00ccff" }, model)))),
|
|
16
|
+
React.createElement(Box, null,
|
|
17
|
+
autoAcceptMode && (React.createElement(Text, { color: "#00cc66", bold: true }, "[AUTO-ACCEPT: ON]")),
|
|
18
|
+
!autoAcceptMode && (React.createElement(Text, { color: "#666666", dimColor: true }, "[AUTO-ACCEPT: OFF]")))));
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=StatusBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusBar.js","sourceRoot":"","sources":["../../../src/ui/components/StatusBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,OAAO,MAAM,aAAa,CAAC;AASlC,MAAM,CAAC,MAAM,SAAS,GAA6B,CAAC,EAClD,cAAc,EACd,SAAS,EACT,cAAc,GAAG,eAAe,EAChC,KAAK,EACN,EAAE,EAAE;IACH,OAAO,CACL,oBAAC,GAAG,IAAC,WAAW,EAAC,QAAQ,EAAC,WAAW,EAAC,SAAS,EAAC,QAAQ,EAAE,CAAC;QACzD,oBAAC,GAAG,IAAC,QAAQ,EAAE,CAAC;YACb,SAAS,IAAI,CACZ,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;gBACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS;oBACnB,oBAAC,OAAO,IAAC,IAAI,EAAC,MAAM,GAAG,CAClB;gBACP,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS;;oBAAG,cAAc,CAAQ,CAC1C,CACP;YAEA,CAAC,SAAS,IAAI,KAAK,IAAI,CACtB,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;gBACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,cAAe;gBACpC,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,IAAE,KAAK,CAAQ,CAChC,CACP,CACG;QAEN,oBAAC,GAAG;YACD,cAAc,IAAI,CACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,IAAI,8BAAyB,CACpD;YACA,CAAC,cAAc,IAAI,CAClB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,QAAQ,+BAA0B,CACzD,CACG,CACF,CACP,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface StreamingMessage {
|
|
3
|
+
id: string;
|
|
4
|
+
role: 'assistant';
|
|
5
|
+
content: string;
|
|
6
|
+
timestamp: Date;
|
|
7
|
+
}
|
|
8
|
+
interface StreamingMessageDisplayProps {
|
|
9
|
+
message: StreamingMessage;
|
|
10
|
+
}
|
|
11
|
+
export declare const StreamingMessageDisplay: React.FC<StreamingMessageDisplayProps>;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=StreamingMessageDisplay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StreamingMessageDisplay.d.ts","sourceRoot":"","sources":["../../../src/ui/components/StreamingMessageDisplay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,gBAAgB;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;CACjB;AAED,UAAU,4BAA4B;IACpC,OAAO,EAAE,gBAAgB,CAAC;CAC3B;AAED,eAAO,MAAM,uBAAuB,EAAE,KAAK,CAAC,EAAE,CAAC,4BAA4B,CAkCzE,CAAC"}
|