@agi-cli/web-sdk 0.1.80 → 0.1.82
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/dist/components/chat/ChatInput.d.ts +1 -0
- package/dist/components/chat/ChatInput.d.ts.map +1 -1
- package/dist/components/chat/ChatInput.js +147 -9
- package/dist/components/chat/ChatInput.js.map +1 -1
- package/dist/components/chat/ChatInputContainer.d.ts +1 -0
- package/dist/components/chat/ChatInputContainer.d.ts.map +1 -1
- package/dist/components/chat/ChatInputContainer.js +17 -2
- package/dist/components/chat/ChatInputContainer.js.map +1 -1
- package/dist/components/chat/CommandSuggestionsPopup.d.ts +10 -0
- package/dist/components/chat/CommandSuggestionsPopup.d.ts.map +1 -0
- package/dist/components/chat/CommandSuggestionsPopup.js +85 -0
- package/dist/components/chat/CommandSuggestionsPopup.js.map +1 -0
- package/dist/components/chat/ConfigModal.d.ts +2 -1
- package/dist/components/chat/ConfigModal.d.ts.map +1 -1
- package/dist/components/chat/ConfigModal.js +20 -17
- package/dist/components/chat/ConfigModal.js.map +1 -1
- package/dist/components/chat/FileMentionPopup.d.ts +15 -0
- package/dist/components/chat/FileMentionPopup.d.ts.map +1 -0
- package/dist/components/chat/FileMentionPopup.js +123 -0
- package/dist/components/chat/FileMentionPopup.js.map +1 -0
- package/dist/components/chat/ShortcutsModal.d.ts +7 -0
- package/dist/components/chat/ShortcutsModal.d.ts.map +1 -0
- package/dist/components/chat/ShortcutsModal.js +177 -0
- package/dist/components/chat/ShortcutsModal.js.map +1 -0
- package/dist/components/chat/UnifiedAgentSelector.d.ts +4 -1
- package/dist/components/chat/UnifiedAgentSelector.d.ts.map +1 -1
- package/dist/components/chat/UnifiedAgentSelector.js +12 -6
- package/dist/components/chat/UnifiedAgentSelector.js.map +1 -1
- package/dist/components/chat/UnifiedModelSelector.d.ts +4 -1
- package/dist/components/chat/UnifiedModelSelector.d.ts.map +1 -1
- package/dist/components/chat/UnifiedModelSelector.js +12 -6
- package/dist/components/chat/UnifiedModelSelector.js.map +1 -1
- package/dist/components/git/GitCommitModal.d.ts.map +1 -1
- package/dist/components/git/GitCommitModal.js +25 -6
- package/dist/components/git/GitCommitModal.js.map +1 -1
- package/dist/components/git/GitFileItem.d.ts.map +1 -1
- package/dist/components/git/GitFileItem.js +43 -3
- package/dist/components/git/GitFileItem.js.map +1 -1
- package/dist/components/git/GitFileList.d.ts.map +1 -1
- package/dist/components/git/GitFileList.js +68 -4
- package/dist/components/git/GitFileList.js.map +1 -1
- package/dist/components/index.d.ts +1 -0
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +1 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/sessions/LeanHeader.js +1 -1
- package/dist/components/sessions/SessionListContainer.d.ts.map +1 -1
- package/dist/components/sessions/SessionListContainer.js +18 -3
- package/dist/components/sessions/SessionListContainer.js.map +1 -1
- package/dist/components/ui/ConfirmationDialog.d.ts +2 -0
- package/dist/components/ui/ConfirmationDialog.d.ts.map +1 -0
- package/dist/components/ui/ConfirmationDialog.js +57 -0
- package/dist/components/ui/ConfirmationDialog.js.map +1 -0
- package/dist/components/ui/Modal.d.ts +14 -0
- package/dist/components/ui/Modal.d.ts.map +1 -0
- package/dist/components/ui/Modal.js +43 -0
- package/dist/components/ui/Modal.js.map +1 -0
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +2 -0
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/useConfig.d.ts.map +1 -1
- package/dist/hooks/useFiles.d.ts +9 -0
- package/dist/hooks/useFiles.d.ts.map +1 -0
- package/dist/hooks/useFiles.js +14 -0
- package/dist/hooks/useFiles.js.map +1 -0
- package/dist/hooks/useGit.d.ts +6 -0
- package/dist/hooks/useGit.d.ts.map +1 -1
- package/dist/hooks/useGit.js +18 -0
- package/dist/hooks/useGit.js.map +1 -1
- package/dist/hooks/useKeyboardShortcuts.d.ts +27 -0
- package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -0
- package/dist/hooks/useKeyboardShortcuts.js +231 -0
- package/dist/hooks/useKeyboardShortcuts.js.map +1 -0
- package/dist/lib/api-client.d.ts +14 -0
- package/dist/lib/api-client.d.ts.map +1 -1
- package/dist/lib/api-client.js +30 -1
- package/dist/lib/api-client.js.map +1 -1
- package/dist/stores/confirmationStore.d.ts +23 -0
- package/dist/stores/confirmationStore.d.ts.map +1 -0
- package/dist/stores/confirmationStore.js +27 -0
- package/dist/stores/confirmationStore.js.map +1 -0
- package/dist/stores/focusStore.d.ts +14 -0
- package/dist/stores/focusStore.d.ts.map +1 -0
- package/dist/stores/focusStore.js +12 -0
- package/dist/stores/focusStore.js.map +1 -0
- package/dist/stores/index.d.ts +2 -0
- package/dist/stores/index.d.ts.map +1 -1
- package/dist/stores/index.js +2 -0
- package/dist/stores/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChatInput.d.ts","sourceRoot":"","sources":["../../../src/components/chat/ChatInput.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ChatInput.d.ts","sourceRoot":"","sources":["../../../src/components/chat/ChatInput.tsx"],"names":[],"mappings":"AAiBA,UAAU,cAAc;IACvB,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,SAAS,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3B,gBAAgB,CAAC,EAAE,CAAC,UAAU,EAAE,OAAO,KAAK,IAAI,CAAC;IACjD,UAAU,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,SAAS;WACD,MAAM,IAAI;GA6S9B,CAAC"}
|
|
@@ -2,10 +2,26 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
2
2
|
import { useState, useRef, useEffect, useCallback, memo, forwardRef, useImperativeHandle, } from 'react';
|
|
3
3
|
import { ArrowUp, MoreVertical } from 'lucide-react';
|
|
4
4
|
import { Textarea } from '../ui/Textarea';
|
|
5
|
-
|
|
5
|
+
import { FileMentionPopup } from './FileMentionPopup';
|
|
6
|
+
import { CommandSuggestionsPopup } from './CommandSuggestionsPopup';
|
|
7
|
+
import { ShortcutsModal } from './ShortcutsModal';
|
|
8
|
+
import { useFiles } from '../../hooks/useFiles';
|
|
9
|
+
export const ChatInput = memo(forwardRef(function ChatInput({ onSend, onCommand, disabled, onConfigClick, onPlanModeToggle, isPlanMode: externalIsPlanMode, }, ref) {
|
|
6
10
|
const [message, setMessage] = useState('');
|
|
7
11
|
const [isPlanMode, setIsPlanMode] = useState(externalIsPlanMode || false);
|
|
12
|
+
const [showFileMention, setShowFileMention] = useState(false);
|
|
13
|
+
const [mentionQuery, setMentionQuery] = useState('');
|
|
14
|
+
const [mentionSelectedIndex, setMentionSelectedIndex] = useState(0);
|
|
15
|
+
const [showCommandSuggestions, setShowCommandSuggestions] = useState(false);
|
|
16
|
+
const [commandQuery, setCommandQuery] = useState('');
|
|
17
|
+
const [commandSelectedIndex, setCommandSelectedIndex] = useState(0);
|
|
18
|
+
const [showShortcutsModal, setShowShortcutsModal] = useState(false);
|
|
19
|
+
const [currentFileToSelect, setCurrentFileToSelect] = useState();
|
|
20
|
+
const [currentCommandToSelect, setCurrentCommandToSelect] = useState();
|
|
8
21
|
const textareaRef = useRef(null);
|
|
22
|
+
const { data: filesData, isLoading: filesLoading } = useFiles();
|
|
23
|
+
const files = filesData?.files || [];
|
|
24
|
+
const changedFiles = filesData?.changedFiles || [];
|
|
9
25
|
useEffect(() => {
|
|
10
26
|
textareaRef.current?.focus();
|
|
11
27
|
}, []);
|
|
@@ -40,10 +56,122 @@ export const ChatInput = memo(forwardRef(function ChatInput({ onSend, disabled,
|
|
|
40
56
|
textareaRef.current?.focus();
|
|
41
57
|
}
|
|
42
58
|
}, [message, disabled, onSend]);
|
|
59
|
+
const handleFileSelect = useCallback((filePath) => {
|
|
60
|
+
const textarea = textareaRef.current;
|
|
61
|
+
if (!textarea)
|
|
62
|
+
return;
|
|
63
|
+
const value = textarea.value;
|
|
64
|
+
const cursorPos = textarea.selectionStart;
|
|
65
|
+
const textBeforeCursor = value.slice(0, cursorPos);
|
|
66
|
+
const match = textBeforeCursor.match(/@(\S*)$/);
|
|
67
|
+
if (!match)
|
|
68
|
+
return;
|
|
69
|
+
const atPos = cursorPos - match[0].length;
|
|
70
|
+
const newValue = `${value.slice(0, atPos)}@${filePath} ${value.slice(cursorPos)}`;
|
|
71
|
+
setMessage(newValue);
|
|
72
|
+
setShowFileMention(false);
|
|
73
|
+
setTimeout(() => {
|
|
74
|
+
const newCursorPos = atPos + filePath.length + 2;
|
|
75
|
+
textarea.setSelectionRange(newCursorPos, newCursorPos);
|
|
76
|
+
textarea.focus();
|
|
77
|
+
}, 0);
|
|
78
|
+
}, []);
|
|
79
|
+
const handleEnterSelect = useCallback((file) => {
|
|
80
|
+
setCurrentFileToSelect(file);
|
|
81
|
+
}, []);
|
|
82
|
+
const handleCommandEnterSelect = useCallback((commandId) => {
|
|
83
|
+
setCurrentCommandToSelect(commandId);
|
|
84
|
+
}, []);
|
|
85
|
+
const handleCommandSelect = useCallback((commandId) => {
|
|
86
|
+
if (commandId === 'help') {
|
|
87
|
+
setShowShortcutsModal(true);
|
|
88
|
+
setMessage('');
|
|
89
|
+
setShowCommandSuggestions(false);
|
|
90
|
+
if (textareaRef.current) {
|
|
91
|
+
textareaRef.current.style.height = 'auto';
|
|
92
|
+
}
|
|
93
|
+
textareaRef.current?.focus();
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
if (onCommand) {
|
|
97
|
+
onCommand(commandId);
|
|
98
|
+
}
|
|
99
|
+
setMessage('');
|
|
100
|
+
setShowCommandSuggestions(false);
|
|
101
|
+
if (textareaRef.current) {
|
|
102
|
+
textareaRef.current.style.height = 'auto';
|
|
103
|
+
}
|
|
104
|
+
textareaRef.current?.focus();
|
|
105
|
+
}, [onCommand]);
|
|
43
106
|
const handleChange = useCallback((e) => {
|
|
44
107
|
setMessage(e.target.value);
|
|
108
|
+
const value = e.target.value;
|
|
109
|
+
// Check for slash command (only when input starts with /)
|
|
110
|
+
if (value.startsWith('/') && !value.includes(' ')) {
|
|
111
|
+
setShowCommandSuggestions(true);
|
|
112
|
+
setCommandQuery(value.slice(1));
|
|
113
|
+
setCommandSelectedIndex(0);
|
|
114
|
+
setShowFileMention(false);
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
setShowCommandSuggestions(false);
|
|
118
|
+
// Check for file mention
|
|
119
|
+
const cursorPos = e.target.selectionStart;
|
|
120
|
+
const textBeforeCursor = value.slice(0, cursorPos);
|
|
121
|
+
const match = textBeforeCursor.match(/@(\S*)$/);
|
|
122
|
+
if (match) {
|
|
123
|
+
setShowFileMention(true);
|
|
124
|
+
setMentionQuery(match[1]);
|
|
125
|
+
setMentionSelectedIndex(0);
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
setShowFileMention(false);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
45
131
|
}, []);
|
|
46
132
|
const handleKeyDown = useCallback((e) => {
|
|
133
|
+
if (showCommandSuggestions) {
|
|
134
|
+
if (e.key === 'ArrowDown' || (e.ctrlKey && e.key === 'j')) {
|
|
135
|
+
e.preventDefault();
|
|
136
|
+
setCommandSelectedIndex((prev) => (prev + 1) % 5);
|
|
137
|
+
}
|
|
138
|
+
else if (e.key === 'ArrowUp' || (e.ctrlKey && e.key === 'k')) {
|
|
139
|
+
e.preventDefault();
|
|
140
|
+
setCommandSelectedIndex((prev) => (prev - 1 + 5) % 5);
|
|
141
|
+
}
|
|
142
|
+
else if (e.key === 'Enter') {
|
|
143
|
+
e.preventDefault();
|
|
144
|
+
if (currentCommandToSelect) {
|
|
145
|
+
handleCommandSelect(currentCommandToSelect);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
else if (e.key === 'Escape') {
|
|
149
|
+
e.preventDefault();
|
|
150
|
+
setShowCommandSuggestions(false);
|
|
151
|
+
}
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
if (showFileMention) {
|
|
155
|
+
if (e.key === 'ArrowDown' || (e.ctrlKey && e.key === 'j')) {
|
|
156
|
+
e.preventDefault();
|
|
157
|
+
setMentionSelectedIndex((prev) => (prev + 1) % 20);
|
|
158
|
+
}
|
|
159
|
+
else if (e.key === 'ArrowUp' || (e.ctrlKey && e.key === 'k')) {
|
|
160
|
+
e.preventDefault();
|
|
161
|
+
setMentionSelectedIndex((prev) => (prev - 1 + 20) % 20);
|
|
162
|
+
}
|
|
163
|
+
else if (e.key === 'Enter') {
|
|
164
|
+
e.preventDefault();
|
|
165
|
+
if (currentFileToSelect) {
|
|
166
|
+
handleFileSelect(currentFileToSelect);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
else if (e.key === 'Escape') {
|
|
170
|
+
e.preventDefault();
|
|
171
|
+
setShowFileMention(false);
|
|
172
|
+
}
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
47
175
|
if (e.key === 'Tab') {
|
|
48
176
|
e.preventDefault();
|
|
49
177
|
const newPlanMode = !isPlanMode;
|
|
@@ -54,13 +182,23 @@ export const ChatInput = memo(forwardRef(function ChatInput({ onSend, disabled,
|
|
|
54
182
|
e.preventDefault();
|
|
55
183
|
handleSend();
|
|
56
184
|
}
|
|
57
|
-
}, [
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
185
|
+
}, [
|
|
186
|
+
showFileMention,
|
|
187
|
+
showCommandSuggestions,
|
|
188
|
+
handleSend,
|
|
189
|
+
isPlanMode,
|
|
190
|
+
onPlanModeToggle,
|
|
191
|
+
currentFileToSelect,
|
|
192
|
+
handleFileSelect,
|
|
193
|
+
currentCommandToSelect,
|
|
194
|
+
handleCommandSelect,
|
|
195
|
+
]);
|
|
196
|
+
return (_jsx("div", { className: "absolute bottom-0 left-0 right-0 pt-16 pb-6 md:pb-8 px-2 md:px-4 bg-gradient-to-t from-background via-background to-transparent pointer-events-none z-20 safe-area-inset-bottom", children: _jsxs("div", { className: "max-w-3xl mx-auto pointer-events-auto mb-2 md:mb-0 relative", children: [_jsxs("div", { className: `flex items-end gap-1 rounded-3xl p-1 transition-all touch-manipulation ${isPlanMode
|
|
197
|
+
? 'bg-slate-100 dark:bg-slate-900/40 border border-slate-300 dark:border-slate-700 focus-within:border-slate-400 dark:focus-within:border-slate-600 focus-within:ring-1 focus-within:ring-slate-300 dark:focus-within:ring-slate-700'
|
|
198
|
+
: 'bg-card border border-border focus-within:border-primary/60 focus-within:ring-1 focus-within:ring-primary/40'}`, children: [onConfigClick && (_jsx("button", { type: "button", onClick: onConfigClick, className: "flex items-center justify-center w-10 h-10 rounded-full hover:bg-background/50 active:bg-background/70 transition-colors text-muted-foreground hover:text-foreground flex-shrink-0 touch-manipulation", children: _jsx(MoreVertical, { className: "w-4 h-4" }) })), _jsx(Textarea, { ref: textareaRef, value: message, onChange: handleChange, onKeyDown: handleKeyDown, placeholder: isPlanMode
|
|
199
|
+
? 'Plan mode - Type a message...'
|
|
200
|
+
: 'Type a message...', disabled: disabled, rows: 1, className: "border-0 bg-transparent pl-1 pr-2 py-2 max-h-[200px] overflow-y-auto leading-normal resize-none scrollbar-hide text-base", style: { height: '2.5rem' } }), _jsx("button", { type: "button", onClick: handleSend, disabled: disabled || !message.trim(), className: `flex items-center justify-center w-10 h-10 rounded-full transition-colors flex-shrink-0 touch-manipulation ${message.trim()
|
|
201
|
+
? 'bg-primary hover:bg-primary/90 active:bg-primary/80 text-primary-foreground'
|
|
202
|
+
: 'bg-transparent text-muted-foreground'}`, children: _jsx(ArrowUp, { className: "w-4 h-4" }) })] }), showFileMention && !filesLoading && (_jsx(FileMentionPopup, { files: files, changedFiles: changedFiles, query: mentionQuery, selectedIndex: mentionSelectedIndex, onSelect: handleFileSelect, onEnterSelect: handleEnterSelect, onClose: () => setShowFileMention(false) })), showCommandSuggestions && (_jsx(CommandSuggestionsPopup, { query: commandQuery, selectedIndex: commandSelectedIndex, onSelect: handleCommandSelect, onEnterSelect: handleCommandEnterSelect, onClose: () => setShowCommandSuggestions(false) })), _jsx(ShortcutsModal, { isOpen: showShortcutsModal, onClose: () => setShowShortcutsModal(false) })] }) }));
|
|
65
203
|
}));
|
|
66
204
|
//# sourceMappingURL=ChatInput.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChatInput.js","sourceRoot":"","sources":["../../../src/components/chat/ChatInput.tsx"],"names":[],"mappings":";AAAA,OAAO,EACN,QAAQ,EACR,MAAM,EACN,SAAS,EACT,WAAW,EACX,IAAI,EACJ,UAAU,EACV,mBAAmB,GACnB,MAAM,OAAO,CAAC;AAEf,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"ChatInput.js","sourceRoot":"","sources":["../../../src/components/chat/ChatInput.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChatInputContainer.d.ts","sourceRoot":"","sources":["../../../src/components/chat/ChatInputContainer.tsx"],"names":[],"mappings":"AAcA,UAAU,uBAAuB;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"ChatInputContainer.d.ts","sourceRoot":"","sources":["../../../src/components/chat/ChatInputContainer.tsx"],"names":[],"mappings":"AAcA,UAAU,uBAAuB;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;CAC1B;AAED,MAAM,WAAW,qBAAqB;IACrC,KAAK,EAAE,MAAM,IAAI,CAAC;CAClB;AAED,eAAO,MAAM,kBAAkB,sHA+K9B,CAAC"}
|
|
@@ -4,12 +4,13 @@ import { useSendMessage } from '../../hooks/useMessages';
|
|
|
4
4
|
import { useSession, useUpdateSession } from '../../hooks/useSessions';
|
|
5
5
|
import { ChatInput } from './ChatInput';
|
|
6
6
|
import { ConfigModal } from './ConfigModal';
|
|
7
|
-
export const ChatInputContainer = memo(forwardRef(function ChatInputContainer({ sessionId, userContext }, ref) {
|
|
7
|
+
export const ChatInputContainer = memo(forwardRef(function ChatInputContainer({ sessionId, userContext, onNewSession }, ref) {
|
|
8
8
|
const session = useSession(sessionId);
|
|
9
9
|
const [agent, setAgent] = useState('');
|
|
10
10
|
const [provider, setProvider] = useState('');
|
|
11
11
|
const [model, setModel] = useState('');
|
|
12
12
|
const [isConfigOpen, setIsConfigOpen] = useState(false);
|
|
13
|
+
const [configFocusTarget, setConfigFocusTarget] = useState(null);
|
|
13
14
|
const [inputKey, setInputKey] = useState(0);
|
|
14
15
|
const chatInputRef = useRef(null);
|
|
15
16
|
const sendMessage = useSendMessage(sessionId);
|
|
@@ -48,7 +49,21 @@ export const ChatInputContainer = memo(forwardRef(function ChatInputContainer({
|
|
|
48
49
|
}, []);
|
|
49
50
|
const handleCloseConfig = useCallback(() => {
|
|
50
51
|
setIsConfigOpen(false);
|
|
52
|
+
setConfigFocusTarget(null);
|
|
51
53
|
}, []);
|
|
54
|
+
const handleCommand = useCallback((commandId) => {
|
|
55
|
+
if (commandId === 'models') {
|
|
56
|
+
setConfigFocusTarget('model');
|
|
57
|
+
setIsConfigOpen(true);
|
|
58
|
+
}
|
|
59
|
+
else if (commandId === 'agents') {
|
|
60
|
+
setConfigFocusTarget('agent');
|
|
61
|
+
setIsConfigOpen(true);
|
|
62
|
+
}
|
|
63
|
+
else if (commandId === 'new') {
|
|
64
|
+
onNewSession?.();
|
|
65
|
+
}
|
|
66
|
+
}, [onNewSession]);
|
|
52
67
|
const handleAgentChange = useCallback(async (value) => {
|
|
53
68
|
setAgent(value);
|
|
54
69
|
try {
|
|
@@ -104,6 +119,6 @@ export const ChatInputContainer = memo(forwardRef(function ChatInputContainer({
|
|
|
104
119
|
console.error('Failed to switch agent:', error);
|
|
105
120
|
}
|
|
106
121
|
}, [updateSession]);
|
|
107
|
-
return (_jsxs(_Fragment, { children: [_jsx(ConfigModal, { isOpen: isConfigOpen, onClose: handleCloseConfig, agent: agent, provider: provider, model: model, onAgentChange: handleAgentChange, onProviderChange: handleProviderChange, onModelChange: handleModelChange, onModelSelectorChange: handleModelSelectorChange }), _jsx(ChatInput, { ref: chatInputRef, onSend: handleSendMessage, disabled: sendMessage.isPending, onConfigClick: handleToggleConfig, onPlanModeToggle: handlePlanModeToggle, isPlanMode: agent === 'plan' }, inputKey)] }));
|
|
122
|
+
return (_jsxs(_Fragment, { children: [_jsx(ConfigModal, { isOpen: isConfigOpen, onClose: handleCloseConfig, initialFocus: configFocusTarget, agent: agent, provider: provider, model: model, onAgentChange: handleAgentChange, onProviderChange: handleProviderChange, onModelChange: handleModelChange, onModelSelectorChange: handleModelSelectorChange }), _jsx(ChatInput, { ref: chatInputRef, onSend: handleSendMessage, onCommand: handleCommand, disabled: sendMessage.isPending, onConfigClick: handleToggleConfig, onPlanModeToggle: handlePlanModeToggle, isPlanMode: agent === 'plan' }, inputKey)] }));
|
|
108
123
|
}));
|
|
109
124
|
//# sourceMappingURL=ChatInputContainer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChatInputContainer.js","sourceRoot":"","sources":["../../../src/components/chat/ChatInputContainer.tsx"],"names":[],"mappings":";AAAA,OAAO,EACN,IAAI,EACJ,QAAQ,EACR,WAAW,EACX,SAAS,EACT,MAAM,EACN,UAAU,EACV,mBAAmB,GACnB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"ChatInputContainer.js","sourceRoot":"","sources":["../../../src/components/chat/ChatInputContainer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
interface CommandSuggestionsPopupProps {
|
|
2
|
+
query: string;
|
|
3
|
+
selectedIndex: number;
|
|
4
|
+
onSelect: (commandId: string) => void;
|
|
5
|
+
onEnterSelect: (commandId: string | undefined) => void;
|
|
6
|
+
onClose: () => void;
|
|
7
|
+
}
|
|
8
|
+
export declare function CommandSuggestionsPopup({ query, selectedIndex, onSelect, onEnterSelect, onClose, }: CommandSuggestionsPopupProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=CommandSuggestionsPopup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CommandSuggestionsPopup.d.ts","sourceRoot":"","sources":["../../../src/components/chat/CommandSuggestionsPopup.tsx"],"names":[],"mappings":"AAWA,UAAU,4BAA4B;IACrC,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,aAAa,EAAE,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC;IACvD,OAAO,EAAE,MAAM,IAAI,CAAC;CACpB;AAwDD,wBAAgB,uBAAuB,CAAC,EACvC,KAAK,EACL,aAAa,EACb,QAAQ,EACR,aAAa,EACb,OAAO,GACP,EAAE,4BAA4B,2CAwE9B"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useMemo } from 'react';
|
|
3
|
+
import { Terminal, Sparkles, Plus, Keyboard } from 'lucide-react';
|
|
4
|
+
const COMMANDS = [
|
|
5
|
+
{
|
|
6
|
+
id: 'models',
|
|
7
|
+
label: '/models',
|
|
8
|
+
description: 'Open model selector',
|
|
9
|
+
icon: Sparkles,
|
|
10
|
+
},
|
|
11
|
+
{
|
|
12
|
+
id: 'agents',
|
|
13
|
+
label: '/agents',
|
|
14
|
+
description: 'Open agent selector',
|
|
15
|
+
icon: Terminal,
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
id: 'new',
|
|
19
|
+
label: '/new',
|
|
20
|
+
description: 'Create new session',
|
|
21
|
+
icon: Plus,
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
id: 'help',
|
|
25
|
+
label: '/help',
|
|
26
|
+
description: 'Show keyboard shortcuts and help',
|
|
27
|
+
icon: Keyboard,
|
|
28
|
+
},
|
|
29
|
+
];
|
|
30
|
+
function fuzzySearchCommands(query) {
|
|
31
|
+
if (!query) {
|
|
32
|
+
return COMMANDS;
|
|
33
|
+
}
|
|
34
|
+
const lowerQuery = query.toLowerCase();
|
|
35
|
+
const matches = [];
|
|
36
|
+
for (const cmd of COMMANDS) {
|
|
37
|
+
const labelMatch = cmd.label.toLowerCase().includes(lowerQuery);
|
|
38
|
+
const descriptionMatch = cmd.description.toLowerCase().includes(lowerQuery);
|
|
39
|
+
if (labelMatch || descriptionMatch) {
|
|
40
|
+
// Prioritize label matches over description matches
|
|
41
|
+
const matchScore = labelMatch ? 10 : 5;
|
|
42
|
+
matches.push({ ...cmd, matchScore });
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
// Sort by match score (higher first), then alphabetically
|
|
46
|
+
return matches.sort((a, b) => {
|
|
47
|
+
const scoreDiff = (b.matchScore || 0) - (a.matchScore || 0);
|
|
48
|
+
if (scoreDiff !== 0)
|
|
49
|
+
return scoreDiff;
|
|
50
|
+
return a.label.localeCompare(b.label);
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
export function CommandSuggestionsPopup({ query, selectedIndex, onSelect, onEnterSelect, onClose, }) {
|
|
54
|
+
const results = useMemo(() => {
|
|
55
|
+
return fuzzySearchCommands(query);
|
|
56
|
+
}, [query]);
|
|
57
|
+
useEffect(() => {
|
|
58
|
+
const element = document.getElementById(`command-item-${selectedIndex}`);
|
|
59
|
+
element?.scrollIntoView({ block: 'nearest' });
|
|
60
|
+
}, [selectedIndex]);
|
|
61
|
+
useEffect(() => {
|
|
62
|
+
onEnterSelect(results[selectedIndex]?.id);
|
|
63
|
+
}, [results, selectedIndex, onEnterSelect]);
|
|
64
|
+
useEffect(() => {
|
|
65
|
+
const handleClickOutside = (e) => {
|
|
66
|
+
const target = e.target;
|
|
67
|
+
if (!target.closest('[data-command-popup]')) {
|
|
68
|
+
onClose();
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
document.addEventListener('mousedown', handleClickOutside);
|
|
72
|
+
return () => document.removeEventListener('mousedown', handleClickOutside);
|
|
73
|
+
}, [onClose]);
|
|
74
|
+
if (results.length === 0) {
|
|
75
|
+
return (_jsx("div", { "data-command-popup": true, className: "absolute bottom-full left-0 right-0 mb-2 bg-card border border-border rounded-lg shadow-lg z-50 p-3", children: _jsx("span", { className: "text-muted-foreground text-sm", children: "No commands found" }) }));
|
|
76
|
+
}
|
|
77
|
+
return (_jsx("div", { "data-command-popup": true, className: "absolute bottom-full left-0 right-0 mb-2 bg-card border border-border rounded-lg shadow-lg max-h-[300px] overflow-y-auto z-50", children: results.map((command, index) => {
|
|
78
|
+
const Icon = command.icon;
|
|
79
|
+
return (_jsx("button", { type: "button", id: `command-item-${index}`, onMouseDown: (e) => {
|
|
80
|
+
e.preventDefault();
|
|
81
|
+
onSelect(command.id);
|
|
82
|
+
}, className: `w-full text-left px-3 py-2 hover:bg-accent ${index === selectedIndex ? 'bg-accent' : ''}`, children: _jsxs("div", { className: "flex items-center gap-3 w-full", children: [_jsx(Icon, { className: "w-4 h-4 flex-shrink-0 text-primary" }), _jsxs("div", { className: "flex-1 min-w-0", children: [_jsx("div", { className: "font-mono text-sm font-medium text-foreground", children: command.label }), _jsx("div", { className: "text-xs text-muted-foreground truncate", children: command.description })] })] }) }, command.id));
|
|
83
|
+
}) }));
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=CommandSuggestionsPopup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CommandSuggestionsPopup.js","sourceRoot":"","sources":["../../../src/components/chat/CommandSuggestionsPopup.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
interface ConfigModalProps {
|
|
2
2
|
isOpen: boolean;
|
|
3
3
|
onClose: () => void;
|
|
4
|
+
initialFocus?: 'agent' | 'model' | null;
|
|
4
5
|
agent: string;
|
|
5
6
|
provider: string;
|
|
6
7
|
model: string;
|
|
@@ -9,6 +10,6 @@ interface ConfigModalProps {
|
|
|
9
10
|
onModelChange: (model: string) => void;
|
|
10
11
|
onModelSelectorChange?: (provider: string, model: string) => void;
|
|
11
12
|
}
|
|
12
|
-
export declare function ConfigModal({ isOpen, onClose, agent, provider, model, onAgentChange, onProviderChange, onModelChange, onModelSelectorChange, }: ConfigModalProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export declare function ConfigModal({ isOpen, onClose, initialFocus, agent, provider, model, onAgentChange, onProviderChange, onModelChange, onModelSelectorChange, }: ConfigModalProps): import("react/jsx-runtime").JSX.Element;
|
|
13
14
|
export {};
|
|
14
15
|
//# sourceMappingURL=ConfigModal.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigModal.d.ts","sourceRoot":"","sources":["../../../src/components/chat/ConfigModal.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ConfigModal.d.ts","sourceRoot":"","sources":["../../../src/components/chat/ConfigModal.tsx"],"names":[],"mappings":"AAYA,UAAU,gBAAgB;IACzB,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,YAAY,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,IAAI,CAAC;IACxC,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,gBAAgB,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7C,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,qBAAqB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CAClE;AAED,wBAAgB,WAAW,CAAC,EAC3B,MAAM,EACN,OAAO,EACP,YAAY,EACZ,KAAK,EACL,QAAQ,EACR,KAAK,EACL,aAAa,EACb,gBAAgB,EAChB,aAAa,EACb,qBAAqB,GACrB,EAAE,gBAAgB,2CAsElB"}
|
|
@@ -1,22 +1,25 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs
|
|
2
|
-
import {
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useRef } from 'react';
|
|
3
3
|
import { useConfig } from '../../hooks/useConfig';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
|
|
4
|
+
import { Modal } from '../ui/Modal';
|
|
5
|
+
import { UnifiedModelSelector, } from './UnifiedModelSelector';
|
|
6
|
+
import { UnifiedAgentSelector, } from './UnifiedAgentSelector';
|
|
7
|
+
export function ConfigModal({ isOpen, onClose, initialFocus, agent, provider, model, onAgentChange, onProviderChange, onModelChange, onModelSelectorChange, }) {
|
|
7
8
|
const { data: config, isLoading: configLoading } = useConfig();
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
if (
|
|
12
|
-
|
|
9
|
+
const agentSelectorRef = useRef(null);
|
|
10
|
+
const modelSelectorRef = useRef(null);
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (isOpen && initialFocus) {
|
|
13
|
+
setTimeout(() => {
|
|
14
|
+
if (initialFocus === 'agent') {
|
|
15
|
+
agentSelectorRef.current?.openAndFocus();
|
|
16
|
+
}
|
|
17
|
+
else if (initialFocus === 'model') {
|
|
18
|
+
modelSelectorRef.current?.openAndFocus();
|
|
19
|
+
}
|
|
20
|
+
}, 100);
|
|
13
21
|
}
|
|
14
|
-
};
|
|
15
|
-
const handleBackdropKeyDown = (e) => {
|
|
16
|
-
if (e.key === 'Escape') {
|
|
17
|
-
onClose();
|
|
18
|
-
}
|
|
19
|
-
};
|
|
22
|
+
}, [isOpen, initialFocus]);
|
|
20
23
|
const handleModelChange = (selectedProvider, selectedModel) => {
|
|
21
24
|
if (onModelSelectorChange) {
|
|
22
25
|
onModelSelectorChange(selectedProvider, selectedModel);
|
|
@@ -26,6 +29,6 @@ export function ConfigModal({ isOpen, onClose, agent, provider, model, onAgentCh
|
|
|
26
29
|
onModelChange(selectedModel);
|
|
27
30
|
}
|
|
28
31
|
};
|
|
29
|
-
return (
|
|
32
|
+
return (_jsx(Modal, { isOpen: isOpen, onClose: onClose, title: "Configuration", closeOnEscape: true, closeOnBackdropClick: true, children: configLoading ? (_jsx("div", { className: "text-center text-muted-foreground py-8", children: "Loading configuration..." })) : config ? (_jsxs("div", { className: "space-y-4", children: [_jsxs("div", { children: [_jsx("div", { className: "block text-sm font-medium text-foreground mb-2", children: "Agent" }), _jsx(UnifiedAgentSelector, { ref: agentSelectorRef, agent: agent, agents: config.agents, onChange: onAgentChange })] }), _jsxs("div", { children: [_jsx("div", { className: "block text-sm font-medium text-foreground mb-2", children: "Provider / Model" }), _jsx(UnifiedModelSelector, { ref: modelSelectorRef, provider: provider, model: model, onChange: handleModelChange })] })] })) : null }));
|
|
30
33
|
}
|
|
31
34
|
//# sourceMappingURL=ConfigModal.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigModal.js","sourceRoot":"","sources":["../../../src/components/chat/ConfigModal.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"ConfigModal.js","sourceRoot":"","sources":["../../../src/components/chat/ConfigModal.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EACN,oBAAoB,GAEpB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EACN,oBAAoB,GAEpB,MAAM,wBAAwB,CAAC;AAehC,MAAM,UAAU,WAAW,CAAC,EAC3B,MAAM,EACN,OAAO,EACP,YAAY,EACZ,KAAK,EACL,QAAQ,EACR,KAAK,EACL,aAAa,EACb,gBAAgB,EAChB,aAAa,EACb,qBAAqB,GACH;IAClB,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,SAAS,EAAE,CAAC;IAC/D,MAAM,gBAAgB,GAAG,MAAM,CAA0B,IAAI,CAAC,CAAC;IAC/D,MAAM,gBAAgB,GAAG,MAAM,CAA0B,IAAI,CAAC,CAAC;IAE/D,SAAS,CAAC,GAAG,EAAE;QACd,IAAI,MAAM,IAAI,YAAY,EAAE,CAAC;YAC5B,UAAU,CAAC,GAAG,EAAE;gBACf,IAAI,YAAY,KAAK,OAAO,EAAE,CAAC;oBAC9B,gBAAgB,CAAC,OAAO,EAAE,YAAY,EAAE,CAAC;gBAC1C,CAAC;qBAAM,IAAI,YAAY,KAAK,OAAO,EAAE,CAAC;oBACrC,gBAAgB,CAAC,OAAO,EAAE,YAAY,EAAE,CAAC;gBAC1C,CAAC;YACF,CAAC,EAAE,GAAG,CAAC,CAAC;QACT,CAAC;IACF,CAAC,EAAE,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC;IAE3B,MAAM,iBAAiB,GAAG,CACzB,gBAAwB,EACxB,aAAqB,EACpB,EAAE;QACH,IAAI,qBAAqB,EAAE,CAAC;YAC3B,qBAAqB,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;QACxD,CAAC;aAAM,CAAC;YACP,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;YACnC,aAAa,CAAC,aAAa,CAAC,CAAC;QAC9B,CAAC;IACF,CAAC,CAAC;IAEF,OAAO,CACN,KAAC,KAAK,IACL,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,EAChB,KAAK,EAAC,eAAe,EACrB,aAAa,EAAE,IAAI,EACnB,oBAAoB,EAAE,IAAI,YAEzB,aAAa,CAAC,CAAC,CAAC,CAChB,cAAK,SAAS,EAAC,wCAAwC,yCAEjD,CACN,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CACZ,eAAK,SAAS,EAAC,WAAW,aACzB,0BACC,cAAK,SAAS,EAAC,gDAAgD,sBAEzD,EACN,KAAC,oBAAoB,IACpB,GAAG,EAAE,gBAAgB,EACrB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,CAAC,MAAM,EACrB,QAAQ,EAAE,aAAa,GACtB,IACG,EAEN,0BACC,cAAK,SAAS,EAAC,gDAAgD,iCAEzD,EACN,KAAC,oBAAoB,IACpB,GAAG,EAAE,gBAAgB,EACrB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,iBAAiB,GAC1B,IACG,IACD,CACN,CAAC,CAAC,CAAC,IAAI,GACD,CACR,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
interface FileMentionPopupProps {
|
|
2
|
+
files: string[];
|
|
3
|
+
changedFiles?: Array<{
|
|
4
|
+
path: string;
|
|
5
|
+
status: string;
|
|
6
|
+
}>;
|
|
7
|
+
query: string;
|
|
8
|
+
selectedIndex: number;
|
|
9
|
+
onSelect: (file: string) => void;
|
|
10
|
+
onEnterSelect: (file: string | undefined) => void;
|
|
11
|
+
onClose: () => void;
|
|
12
|
+
}
|
|
13
|
+
export declare function FileMentionPopup({ files, changedFiles, query, selectedIndex, onSelect, onEnterSelect, onClose, }: FileMentionPopupProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=FileMentionPopup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileMentionPopup.d.ts","sourceRoot":"","sources":["../../../src/components/chat/FileMentionPopup.tsx"],"names":[],"mappings":"AAeA,UAAU,qBAAqB;IAC9B,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,YAAY,CAAC,EAAE,KAAK,CAAC;QACpB,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;KACf,CAAC,CAAC;IACH,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACjC,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC;IAClD,OAAO,EAAE,MAAM,IAAI,CAAC;CACpB;AA8ED,wBAAgB,gBAAgB,CAAC,EAChC,KAAK,EACL,YAAiB,EACjB,KAAK,EACL,aAAa,EACb,QAAQ,EACR,aAAa,EACb,OAAO,GACP,EAAE,qBAAqB,2CA6GvB"}
|