@opensumi/ide-ai-native 3.8.3-next-1741752385.0 → 3.8.3-next-1741763229.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (178) hide show
  1. package/lib/browser/chat/chat-agent.service.d.ts +1 -1
  2. package/lib/browser/chat/chat-agent.service.d.ts.map +1 -1
  3. package/lib/browser/chat/chat-agent.service.js +7 -7
  4. package/lib/browser/chat/chat-agent.service.js.map +1 -1
  5. package/lib/browser/chat/chat-model.d.ts +2 -2
  6. package/lib/browser/chat/chat-model.d.ts.map +1 -1
  7. package/lib/browser/chat/chat-model.js +18 -1
  8. package/lib/browser/chat/chat-model.js.map +1 -1
  9. package/lib/browser/chat/chat.view.d.ts.map +1 -1
  10. package/lib/browser/chat/chat.view.js +49 -18
  11. package/lib/browser/chat/chat.view.js.map +1 -1
  12. package/lib/browser/components/ChatEditor.d.ts +5 -2
  13. package/lib/browser/components/ChatEditor.d.ts.map +1 -1
  14. package/lib/browser/components/ChatEditor.js +45 -6
  15. package/lib/browser/components/ChatEditor.js.map +1 -1
  16. package/lib/browser/components/ChatMentionInput.d.ts +25 -0
  17. package/lib/browser/components/ChatMentionInput.d.ts.map +1 -0
  18. package/lib/browser/components/ChatMentionInput.js +221 -0
  19. package/lib/browser/components/ChatMentionInput.js.map +1 -0
  20. package/lib/browser/components/ChatReply.d.ts.map +1 -1
  21. package/lib/browser/components/ChatReply.js +35 -17
  22. package/lib/browser/components/ChatReply.js.map +1 -1
  23. package/lib/browser/components/ChatThinking.js +1 -1
  24. package/lib/browser/components/ChatThinking.js.map +1 -1
  25. package/lib/browser/components/WelcomeMsg.js +1 -1
  26. package/lib/browser/components/WelcomeMsg.js.map +1 -1
  27. package/lib/browser/components/{ChatContext/ContextSelector.d.ts → chat-context/context-selector.d.ts} +1 -1
  28. package/lib/browser/components/chat-context/context-selector.d.ts.map +1 -0
  29. package/lib/browser/components/{ChatContext/ContextSelector.js → chat-context/context-selector.js} +1 -1
  30. package/lib/browser/components/chat-context/context-selector.js.map +1 -0
  31. package/lib/browser/components/chat-context/index.d.ts.map +1 -0
  32. package/lib/browser/components/{ChatContext → chat-context}/index.js +2 -2
  33. package/lib/browser/components/chat-context/index.js.map +1 -0
  34. package/lib/browser/components/components.module.less +43 -0
  35. package/lib/browser/components/mention-input/mention-input.d.ts +5 -0
  36. package/lib/browser/components/mention-input/mention-input.d.ts.map +1 -0
  37. package/lib/browser/components/mention-input/mention-input.js +753 -0
  38. package/lib/browser/components/mention-input/mention-input.js.map +1 -0
  39. package/lib/browser/components/mention-input/mention-input.module.less +327 -0
  40. package/lib/browser/components/mention-input/mention-item.d.ts +10 -0
  41. package/lib/browser/components/mention-input/mention-item.d.ts.map +1 -0
  42. package/lib/browser/components/mention-input/mention-item.js +16 -0
  43. package/lib/browser/components/mention-input/mention-item.js.map +1 -0
  44. package/lib/browser/components/mention-input/mention-panel.d.ts +15 -0
  45. package/lib/browser/components/mention-input/mention-panel.d.ts.map +1 -0
  46. package/lib/browser/components/mention-input/mention-panel.js +49 -0
  47. package/lib/browser/components/mention-input/mention-panel.js.map +1 -0
  48. package/lib/browser/components/mention-input/types.d.ts +76 -0
  49. package/lib/browser/components/mention-input/types.d.ts.map +1 -0
  50. package/lib/browser/components/mention-input/types.js +16 -0
  51. package/lib/browser/components/mention-input/types.js.map +1 -0
  52. package/lib/browser/context/llm-context.service.d.ts +10 -2
  53. package/lib/browser/context/llm-context.service.d.ts.map +1 -1
  54. package/lib/browser/context/llm-context.service.js +71 -2
  55. package/lib/browser/context/llm-context.service.js.map +1 -1
  56. package/lib/browser/contrib/inline-completions/prompt/matcher.js +2 -2
  57. package/lib/browser/contrib/inline-completions/prompt/similarSnippets.d.ts +1 -1
  58. package/lib/browser/contrib/inline-completions/prompt/similarSnippets.js +2 -2
  59. package/lib/browser/contrib/intelligent-completions/view/default.d.ts.map +1 -1
  60. package/lib/browser/contrib/intelligent-completions/view/default.js.map +1 -1
  61. package/lib/browser/mcp/config/components/mcp-config.view.d.ts.map +1 -1
  62. package/lib/browser/mcp/config/components/mcp-config.view.js +28 -18
  63. package/lib/browser/mcp/config/components/mcp-config.view.js.map +1 -1
  64. package/lib/browser/mcp/config/components/mcp-server-form.d.ts.map +1 -1
  65. package/lib/browser/mcp/config/components/mcp-server-form.js +33 -25
  66. package/lib/browser/mcp/config/components/mcp-server-form.js.map +1 -1
  67. package/lib/browser/mcp/mcp-server.feature.registry.js +1 -1
  68. package/lib/browser/mcp/mcp-server.feature.registry.js.map +1 -1
  69. package/lib/browser/mcp/tools/components/ExpandableFileList.d.ts.map +1 -1
  70. package/lib/browser/mcp/tools/components/ExpandableFileList.js +3 -1
  71. package/lib/browser/mcp/tools/components/ExpandableFileList.js.map +1 -1
  72. package/lib/browser/mcp/tools/components/Terminal.d.ts.map +1 -1
  73. package/lib/browser/mcp/tools/components/Terminal.js +6 -5
  74. package/lib/browser/mcp/tools/components/Terminal.js.map +1 -1
  75. package/lib/browser/mcp/tools/components/computeAnsiLogString.d.ts +4 -0
  76. package/lib/browser/mcp/tools/components/computeAnsiLogString.d.ts.map +1 -0
  77. package/lib/browser/mcp/tools/components/computeAnsiLogString.js +22 -0
  78. package/lib/browser/mcp/tools/components/computeAnsiLogString.js.map +1 -0
  79. package/lib/browser/mcp/tools/components/filterEraseMultipleLine.d.ts +18 -0
  80. package/lib/browser/mcp/tools/components/filterEraseMultipleLine.d.ts.map +1 -0
  81. package/lib/browser/mcp/tools/components/filterEraseMultipleLine.js +69 -0
  82. package/lib/browser/mcp/tools/components/filterEraseMultipleLine.js.map +1 -0
  83. package/lib/browser/mcp/tools/components/index.module.less +8 -5
  84. package/lib/browser/mcp/tools/createNewFileWithText.d.ts.map +1 -1
  85. package/lib/browser/mcp/tools/createNewFileWithText.js +1 -0
  86. package/lib/browser/mcp/tools/createNewFileWithText.js.map +1 -1
  87. package/lib/browser/mcp/tools/editFile.d.ts.map +1 -1
  88. package/lib/browser/mcp/tools/editFile.js +1 -0
  89. package/lib/browser/mcp/tools/editFile.js.map +1 -1
  90. package/lib/browser/mcp/tools/fileSearch.d.ts.map +1 -1
  91. package/lib/browser/mcp/tools/fileSearch.js +1 -0
  92. package/lib/browser/mcp/tools/fileSearch.js.map +1 -1
  93. package/lib/browser/mcp/tools/getDiagnosticsByPath.d.ts.map +1 -1
  94. package/lib/browser/mcp/tools/getDiagnosticsByPath.js +2 -1
  95. package/lib/browser/mcp/tools/getDiagnosticsByPath.js.map +1 -1
  96. package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.d.ts.map +1 -1
  97. package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.js +2 -0
  98. package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.js.map +1 -1
  99. package/lib/browser/mcp/tools/grepSearch.d.ts.map +1 -1
  100. package/lib/browser/mcp/tools/grepSearch.js +1 -0
  101. package/lib/browser/mcp/tools/grepSearch.js.map +1 -1
  102. package/lib/browser/mcp/tools/listDir.d.ts.map +1 -1
  103. package/lib/browser/mcp/tools/listDir.js +1 -0
  104. package/lib/browser/mcp/tools/listDir.js.map +1 -1
  105. package/lib/browser/mcp/tools/readFile.d.ts.map +1 -1
  106. package/lib/browser/mcp/tools/readFile.js +1 -0
  107. package/lib/browser/mcp/tools/readFile.js.map +1 -1
  108. package/lib/browser/mcp/tools/runTerminalCmd.d.ts.map +1 -1
  109. package/lib/browser/mcp/tools/runTerminalCmd.js +1 -0
  110. package/lib/browser/mcp/tools/runTerminalCmd.js.map +1 -1
  111. package/lib/browser/types.d.ts +1 -0
  112. package/lib/browser/types.d.ts.map +1 -1
  113. package/lib/browser/widget/inline-diff/inline-diff-manager.d.ts.map +1 -1
  114. package/lib/browser/widget/inline-diff/inline-diff-manager.js.map +1 -1
  115. package/lib/browser/widget/inline-stream-diff/live-preview.decoration.d.ts.map +1 -1
  116. package/lib/browser/widget/inline-stream-diff/live-preview.decoration.js +10 -5
  117. package/lib/browser/widget/inline-stream-diff/live-preview.decoration.js.map +1 -1
  118. package/lib/common/llm-context.d.ts +15 -1
  119. package/lib/common/llm-context.d.ts.map +1 -1
  120. package/lib/common/llm-context.js.map +1 -1
  121. package/lib/common/prompts/context-prompt-provider.d.ts +12 -2
  122. package/lib/common/prompts/context-prompt-provider.d.ts.map +1 -1
  123. package/lib/common/prompts/context-prompt-provider.js +94 -28
  124. package/lib/common/prompts/context-prompt-provider.js.map +1 -1
  125. package/lib/node/base-language-model.d.ts.map +1 -1
  126. package/lib/node/base-language-model.js +6 -0
  127. package/lib/node/base-language-model.js.map +1 -1
  128. package/package.json +24 -23
  129. package/src/browser/chat/chat-agent.service.ts +7 -7
  130. package/src/browser/chat/chat-model.ts +19 -2
  131. package/src/browser/chat/chat.view.tsx +63 -20
  132. package/src/browser/components/ChatEditor.tsx +72 -9
  133. package/src/browser/components/ChatMentionInput.tsx +268 -0
  134. package/src/browser/components/ChatReply.tsx +61 -18
  135. package/src/browser/components/ChatThinking.tsx +1 -1
  136. package/src/browser/components/WelcomeMsg.tsx +1 -1
  137. package/src/browser/components/{ChatContext → chat-context}/index.tsx +1 -1
  138. package/src/browser/components/components.module.less +43 -0
  139. package/src/browser/components/mention-input/mention-input.module.less +327 -0
  140. package/src/browser/components/mention-input/mention-input.tsx +943 -0
  141. package/src/browser/components/mention-input/mention-item.tsx +24 -0
  142. package/src/browser/components/mention-input/mention-panel.tsx +89 -0
  143. package/src/browser/components/mention-input/types.ts +82 -0
  144. package/src/browser/context/llm-context.service.ts +81 -3
  145. package/src/browser/contrib/inline-completions/prompt/matcher.ts +2 -2
  146. package/src/browser/contrib/inline-completions/prompt/similarSnippets.ts +2 -2
  147. package/src/browser/contrib/intelligent-completions/view/default.ts +0 -1
  148. package/src/browser/mcp/config/components/mcp-config.view.tsx +23 -12
  149. package/src/browser/mcp/config/components/mcp-server-form.tsx +68 -54
  150. package/src/browser/mcp/mcp-server.feature.registry.ts +1 -1
  151. package/src/browser/mcp/tools/components/ExpandableFileList.tsx +4 -1
  152. package/src/browser/mcp/tools/components/Terminal.tsx +4 -6
  153. package/src/browser/mcp/tools/components/computeAnsiLogString.ts +24 -0
  154. package/src/browser/mcp/tools/components/filterEraseMultipleLine.ts +71 -0
  155. package/src/browser/mcp/tools/components/index.module.less +8 -5
  156. package/src/browser/mcp/tools/createNewFileWithText.ts +1 -0
  157. package/src/browser/mcp/tools/editFile.ts +1 -0
  158. package/src/browser/mcp/tools/fileSearch.ts +1 -0
  159. package/src/browser/mcp/tools/getDiagnosticsByPath.ts +2 -1
  160. package/src/browser/mcp/tools/getOpenEditorFileDiagnostics.ts +2 -0
  161. package/src/browser/mcp/tools/grepSearch.ts +1 -0
  162. package/src/browser/mcp/tools/listDir.ts +1 -0
  163. package/src/browser/mcp/tools/readFile.ts +1 -0
  164. package/src/browser/mcp/tools/runTerminalCmd.ts +1 -0
  165. package/src/browser/types.ts +1 -0
  166. package/src/browser/widget/inline-diff/inline-diff-manager.tsx +0 -1
  167. package/src/browser/widget/inline-stream-diff/live-preview.decoration.tsx +9 -5
  168. package/src/common/llm-context.ts +16 -1
  169. package/src/common/prompts/context-prompt-provider.ts +126 -32
  170. package/src/node/base-language-model.ts +5 -0
  171. package/lib/browser/components/ChatContext/ContextSelector.d.ts.map +0 -1
  172. package/lib/browser/components/ChatContext/ContextSelector.js.map +0 -1
  173. package/lib/browser/components/ChatContext/index.d.ts.map +0 -1
  174. package/lib/browser/components/ChatContext/index.js.map +0 -1
  175. /package/lib/browser/components/{ChatContext → chat-context}/index.d.ts +0 -0
  176. /package/lib/browser/components/{ChatContext → chat-context}/style.module.less +0 -0
  177. /package/src/browser/components/{ChatContext/ContextSelector.tsx → chat-context/context-selector.tsx} +0 -0
  178. /package/src/browser/components/{ChatContext → chat-context}/style.module.less +0 -0
@@ -1,3 +1,4 @@
1
+ import cls from 'classnames';
1
2
  import React, {
2
3
  Fragment,
3
4
  ReactNode,
@@ -40,6 +41,7 @@ import {
40
41
  IChatResponseProgressFileTreeData,
41
42
  IChatToolContent,
42
43
  URI,
44
+ localize,
43
45
  } from '@opensumi/ide-core-common';
44
46
  import { IIconService } from '@opensumi/ide-theme';
45
47
  import { IMarkdownString, MarkdownString } from '@opensumi/monaco-editor-core/esm/vs/base/common/htmlContent';
@@ -224,6 +226,28 @@ export const ChatReply = (props: IChatReplyProps) => {
224
226
  const chatApiService = useInjectable<ChatService>(ChatServiceToken);
225
227
  const chatAgentService = useInjectable<IChatAgentService>(IChatAgentService);
226
228
  const chatRenderRegistry = useInjectable<ChatRenderRegistry>(ChatRenderRegistryToken);
229
+ const [collapseThinkingIndexSet, setCollapseThinkingIndexSet] = useState<Set<number>>(
230
+ !request.response.isComplete
231
+ ? new Set()
232
+ : new Set(
233
+ request.response.responseContents
234
+ .map((item, index) => (item.kind === 'reasoning' ? index : -1))
235
+ .filter((item) => item !== -1),
236
+ ),
237
+ );
238
+
239
+ useEffect(() => {
240
+ if (request.response.isComplete) {
241
+ setCollapseThinkingIndexSet(
242
+ new Set(
243
+ request.response.responseContents
244
+ .map((item, index) => (item.kind === 'reasoning' ? index : -1))
245
+ .filter((item) => item !== -1),
246
+ ),
247
+ );
248
+ }
249
+ }, [request.response.isComplete]);
250
+
227
251
  useEffect(() => {
228
252
  const disposableCollection = new DisposableCollection();
229
253
 
@@ -263,23 +287,6 @@ export const ChatReply = (props: IChatReplyProps) => {
263
287
  onRegenerate?.();
264
288
  }, [onRegenerate]);
265
289
 
266
- const onStop = () => {
267
- if (onDone) {
268
- onDone();
269
- }
270
- aiReporter.end(relationId, {
271
- assistantMessage: request.response.responseText,
272
- replytime: Date.now() - startTime,
273
- success: false,
274
- isStop: true,
275
- command,
276
- agentId,
277
- messageId: msgId,
278
- sessionId: aiChatService.sessionModel.sessionId,
279
- });
280
- aiChatService.cancelRequest();
281
- };
282
-
283
290
  const renderMarkdown = useCallback(
284
291
  (markdown: IMarkdownString) => {
285
292
  if (chatRenderRegistry.chatAIRoleRender) {
@@ -313,12 +320,48 @@ export const ChatReply = (props: IChatReplyProps) => {
313
320
  node = <ComponentRender component={item.component} value={item.value} messageId={msgId} />;
314
321
  } else if (item.kind === 'toolCall') {
315
322
  node = <ToolCallRender toolCall={item.content} messageId={msgId} />;
323
+ } else if (item.kind === 'reasoning') {
324
+ // 思考中必然为最后一条
325
+ const isThinking = index === request.response.responseContents.length - 1 && !request.response.isComplete;
326
+ node = (
327
+ <div className={cls(styles.reasoning, { [styles.thinking]: isThinking })}>
328
+ <Button
329
+ size='small'
330
+ type='secondary'
331
+ className={styles.thinking}
332
+ onClick={() => {
333
+ if (isThinking) {
334
+ return;
335
+ }
336
+ if (collapseThinkingIndexSet.has(index)) {
337
+ collapseThinkingIndexSet.delete(index);
338
+ } else {
339
+ collapseThinkingIndexSet.add(index);
340
+ }
341
+ setCollapseThinkingIndexSet(new Set(collapseThinkingIndexSet));
342
+ }}
343
+ >
344
+ <Icon iconClass='codicon codicon-sparkle' />
345
+ {localize('aiNative.chat.thinking')}
346
+ {isThinking ? (
347
+ <Loading />
348
+ ) : collapseThinkingIndexSet.has(index) ? (
349
+ <Icon iconClass='codicon codicon-chevron-right' />
350
+ ) : (
351
+ <Icon iconClass='codicon codicon-chevron-down' />
352
+ )}
353
+ </Button>
354
+ {!collapseThinkingIndexSet.has(index) ? (
355
+ <div className={styles.reasoning_content}>{renderMarkdown(new MarkdownString(item.content))}</div>
356
+ ) : null}
357
+ </div>
358
+ );
316
359
  } else {
317
360
  node = renderMarkdown(item.content);
318
361
  }
319
362
  return <Fragment key={`${item.kind}-${index}`}>{node}</Fragment>;
320
363
  }),
321
- [request.response.responseContents],
364
+ [request.response.responseContents, collapseThinkingIndexSet],
322
365
  );
323
366
 
324
367
  const followupNode = React.useMemo(() => {
@@ -33,7 +33,7 @@ export const ChatThinking = (props: ITinkingProps) => {
33
33
  );
34
34
 
35
35
  const renderContent = useCallback(() => {
36
- if (!children || !message?.trim()) {
36
+ if (!children) {
37
37
  if (CustomThinkingRender) {
38
38
  return <CustomThinkingRender thinkingText={thinkingText} />;
39
39
  }
@@ -79,7 +79,7 @@ export const WelcomeMessage = () => {
79
79
  return (
80
80
  <div className={styles.chat_welcome_head}>
81
81
  <div className={styles.chat_container_des}>
82
- {isMarkdownString(welcomeMessage) ? <ChatMarkdown markdown={welcomeMessage} /> : welcomeMessage}
82
+ {isMarkdownString(welcomeMessage) ? <ChatMarkdown key='welcome' markdown={welcomeMessage} /> : welcomeMessage}
83
83
  </div>
84
84
  <div className={styles.chat_container_content}>
85
85
  {allSampleQuestions.map((data: any, index) => {
@@ -15,7 +15,7 @@ import { WorkbenchEditorService } from '@opensumi/ide-editor/lib/browser/types';
15
15
 
16
16
  import { FileContext, LLMContextService, LLMContextServiceToken } from '../../../common/llm-context';
17
17
 
18
- import { ContextSelector } from './ContextSelector';
18
+ import { ContextSelector } from './context-selector';
19
19
  import styles from './style.module.less';
20
20
 
21
21
  const getCollapsedHeight = () => ({ height: 0, opacity: 0 });
@@ -519,6 +519,7 @@
519
519
  display: flex;
520
520
  font-size: 11px;
521
521
  align-items: center;
522
+ min-width: 150px;
522
523
  }
523
524
 
524
525
  .mcp_desc {
@@ -541,3 +542,45 @@
541
542
  }
542
543
  }
543
544
  }
545
+
546
+ .reasoning {
547
+ .thinking {
548
+ display: flex;
549
+ align-items: center;
550
+ gap: 4px;
551
+ margin-bottom: 4px;
552
+ transition: color 0.2s ease-in-out;
553
+ :global {
554
+ .codicon {
555
+ color: inherit;
556
+ }
557
+ .codicon-sparkle {
558
+ margin-right: -1px;
559
+ font-size: 14px;
560
+ }
561
+ }
562
+ }
563
+ .reasoning_content {
564
+ padding-left: 12px;
565
+ border-left: 2px solid var(--descriptionForeground);
566
+ color: var(--descriptionForeground);
567
+ }
568
+ }
569
+
570
+ .attachment {
571
+ display: inline-flex;
572
+ align-items: center;
573
+ padding: 0 4px;
574
+ margin: 0 2px;
575
+ background: var(--badge-background);
576
+ color: var(--badge-foreground);
577
+ border-radius: 3px;
578
+ vertical-align: middle;
579
+ font-size: 12px;
580
+ }
581
+
582
+ .attachment_text {
583
+ line-height: 20px;
584
+ vertical-align: middle;
585
+ font-size: 12px;
586
+ }
@@ -0,0 +1,327 @@
1
+ .input_container {
2
+ position: relative;
3
+ width: 100%;
4
+ margin: 0 auto;
5
+ border-radius: 4px;
6
+
7
+ .model_selector {
8
+ margin-right: 5px;
9
+ }
10
+
11
+ .editor_area {
12
+ position: relative;
13
+ padding: 0 15px;
14
+ min-height: 42px;
15
+ max-height: 105px;
16
+ }
17
+
18
+ .editor {
19
+ width: 100%;
20
+ background-color: transparent;
21
+ border: none;
22
+ font-size: 14px;
23
+ line-height: 1.5;
24
+ outline: none;
25
+ resize: none;
26
+ min-height: 24px;
27
+ max-height: 120px;
28
+ overflow-y: auto;
29
+ border-radius: 4px;
30
+ word-break: break-word;
31
+
32
+ .mention_tag {
33
+ margin: 0 2px;
34
+ vertical-align: middle;
35
+ }
36
+ }
37
+
38
+ .editor:empty:before,
39
+ .editor[data-content=''] + .editor:before {
40
+ content: attr(data-placeholder);
41
+ color: var(--descriptionForeground);
42
+ pointer-events: none;
43
+ display: block;
44
+ }
45
+
46
+ .ai_enhance_icon {
47
+ border-radius: 6px;
48
+ padding: 2px 3px;
49
+ display: flex;
50
+ align-items: center;
51
+ cursor: pointer;
52
+ text-wrap: nowrap;
53
+ white-space: nowrap;
54
+ box-sizing: border-box;
55
+
56
+ span {
57
+ color: var(--design-text-foreground);
58
+ }
59
+
60
+ &:hover {
61
+ background-color: var(--badge-background);
62
+
63
+ span {
64
+ color: var(--badge-foreground);
65
+ }
66
+ }
67
+
68
+ > span {
69
+ &::before {
70
+ font-size: 14px;
71
+ }
72
+ }
73
+ }
74
+
75
+ .footer {
76
+ padding: 12px 15px;
77
+ display: flex;
78
+ justify-content: flex-start;
79
+ align-items: center;
80
+ flex-direction: row;
81
+
82
+ .left_control {
83
+ display: flex;
84
+ align-items: center;
85
+ justify-content: flex-start;
86
+ flex-direction: row;
87
+ flex: 1;
88
+ }
89
+
90
+ .right_control {
91
+ display: flex;
92
+ align-items: center;
93
+ justify-content: flex-end;
94
+ flex-direction: row;
95
+
96
+ .send_logo,
97
+ .stop_logo {
98
+ background-color: var(--badge-background);
99
+ color: var(--badge-foreground);
100
+
101
+ &:hover {
102
+ background-color: var(--kt-primaryButton-background);
103
+
104
+ .send_logo_icon,
105
+ .stop_logo_icon {
106
+ color: var(--kt-primaryButton-foreground);
107
+ }
108
+ }
109
+ }
110
+ }
111
+ }
112
+
113
+ .send_button {
114
+ color: var(--icon-foreground);
115
+ border: none;
116
+ border-radius: 4px;
117
+ padding: 6px 12px;
118
+ cursor: pointer;
119
+ display: flex;
120
+ align-items: center;
121
+ justify-content: center;
122
+ transition: background-color 0.2s;
123
+ }
124
+
125
+ .send_button:hover {
126
+ background-color: var(--notification-success-background);
127
+ }
128
+ }
129
+
130
+ .mention_panel_container {
131
+ position: absolute;
132
+ top: -20px;
133
+ left: 0;
134
+ right: 0;
135
+ width: 100%;
136
+ z-index: 1000;
137
+ transform: translateY(-100%);
138
+ display: flex;
139
+ justify-content: center;
140
+ }
141
+
142
+ .mention_panel {
143
+ background-color: var(--editor-background);
144
+ color: var(--editor-foreground);
145
+ border-radius: 6px;
146
+ max-height: 300px;
147
+ overflow-y: auto;
148
+ z-index: 1000;
149
+ padding: 8px 4px;
150
+ width: 100%;
151
+ }
152
+
153
+ .mention_item {
154
+ padding: 0 8px;
155
+ border-radius: 8px;
156
+ cursor: pointer;
157
+ line-height: 22px;
158
+ height: 22px;
159
+ display: flex;
160
+ align-items: center;
161
+ transition: all 0.2s ease;
162
+ justify-content: space-between;
163
+ color: var(--foreground);
164
+ border-radius: 4px;
165
+ margin-bottom: 5px;
166
+
167
+ &:last-child {
168
+ margin-bottom: 0;
169
+ }
170
+ }
171
+
172
+ .mention_list {
173
+ margin: 0;
174
+ padding: 0;
175
+ list-style: none;
176
+ }
177
+
178
+ .mention_item.active {
179
+ color: var(--kt-tree-inactiveSelectionForeground);
180
+ background: var(--kt-tree-inactiveSelectionBackground);
181
+ }
182
+
183
+ .mention_item:hover:not(.active) {
184
+ color: var(--kt-tree-inactiveSelectionForeground);
185
+ background: var(--kt-tree-inactiveSelectionBackground);
186
+ }
187
+
188
+ .mention_item_left {
189
+ display: flex;
190
+ align-items: center;
191
+ flex: 1;
192
+ }
193
+
194
+ .mention_item_icon {
195
+ margin-right: 8px;
196
+ width: 18px;
197
+ height: 18px;
198
+ display: flex;
199
+ align-items: center;
200
+ justify-content: center;
201
+ }
202
+
203
+ .mention_item_text {
204
+ font-size: 13px;
205
+ margin-right: 6px;
206
+ display: inline;
207
+ white-space: pre;
208
+ }
209
+
210
+ .mention_item_description {
211
+ color: var(--descriptionForeground);
212
+ font-size: 13px;
213
+ display: inline;
214
+ flex: 1;
215
+ text-overflow: ellipsis;
216
+ overflow: hidden;
217
+ white-space: nowrap;
218
+ margin-left: 5px;
219
+ text-align: right;
220
+ }
221
+
222
+ .mention_item_right {
223
+ color: #8b949e;
224
+ font-size: 12px;
225
+ }
226
+
227
+ .mention_panel_title {
228
+ padding: 8px 12px;
229
+ font-size: 12px;
230
+ display: flex;
231
+ justify-content: space-between;
232
+ align-items: center;
233
+ }
234
+
235
+ .back_button {
236
+ background: none;
237
+ border: none;
238
+ cursor: pointer;
239
+ font-size: 12px;
240
+ display: flex;
241
+ align-items: center;
242
+ }
243
+
244
+ .back_button:hover {
245
+ text-decoration: underline;
246
+ }
247
+
248
+ .mention_tag {
249
+ background-color: var(--chat-slashCommandBackground);
250
+ color: var(--chat-slashCommandForeground);
251
+ border-radius: 4px;
252
+ padding: 0 4px;
253
+ margin: 0 3px;
254
+ user-select: all;
255
+ cursor: default;
256
+ display: inline-flex;
257
+ align-items: center;
258
+ justify-content: center;
259
+ }
260
+
261
+ .mention_icon {
262
+ display: inline-flex;
263
+ align-items: center;
264
+ justify-content: center;
265
+ }
266
+
267
+ .empty_state {
268
+ padding: 5px 10px;
269
+ text-align: center;
270
+ color: var(--descriptionForeground);
271
+ font-size: 14px;
272
+ }
273
+
274
+ .model_selector {
275
+ margin-right: 5px;
276
+ }
277
+
278
+ .mcp_logo {
279
+ margin-right: 5px;
280
+ }
281
+
282
+ .send_logo {
283
+ color: var(--icon-foreground);
284
+ cursor: pointer;
285
+ margin-left: auto;
286
+
287
+ &:hover {
288
+ color: var(--notification-success-foreground);
289
+ }
290
+ }
291
+
292
+ .popover_icon {
293
+ // 移除 margin-left: auto
294
+ }
295
+
296
+ .loading_container {
297
+ display: none;
298
+ }
299
+
300
+ .loading_bar {
301
+ position: absolute;
302
+ top: 0;
303
+ left: 0;
304
+ height: 2px;
305
+ width: 100%;
306
+ background: linear-gradient(90deg, transparent, var(--kt-primaryButton-background), transparent);
307
+ background-size: 200% 100%;
308
+ animation: loading-bar 1.5s infinite;
309
+ z-index: 10;
310
+ }
311
+
312
+ @keyframes loading-bar {
313
+ 0% {
314
+ background-position: 100% 0;
315
+ }
316
+
317
+ 100% {
318
+ background-position: -100% 0;
319
+ }
320
+ }
321
+
322
+ .no_results {
323
+ padding: 12px;
324
+ text-align: center;
325
+ color: #666;
326
+ font-style: italic;
327
+ }