@opensumi/ide-ai-native 3.8.3-next-1741772268.0 → 3.8.3-next-1741774345.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 (85) 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.view.d.ts.map +1 -1
  6. package/lib/browser/chat/chat.view.js +55 -18
  7. package/lib/browser/chat/chat.view.js.map +1 -1
  8. package/lib/browser/components/ChatEditor.d.ts +11 -2
  9. package/lib/browser/components/ChatEditor.d.ts.map +1 -1
  10. package/lib/browser/components/ChatEditor.js +66 -6
  11. package/lib/browser/components/ChatEditor.js.map +1 -1
  12. package/lib/browser/components/ChatMentionInput.d.ts +25 -0
  13. package/lib/browser/components/ChatMentionInput.d.ts.map +1 -0
  14. package/lib/browser/components/ChatMentionInput.js +224 -0
  15. package/lib/browser/components/ChatMentionInput.js.map +1 -0
  16. package/lib/browser/components/ChatThinking.d.ts +1 -1
  17. package/lib/browser/components/ChatThinking.d.ts.map +1 -1
  18. package/lib/browser/components/ChatThinking.js +8 -2
  19. package/lib/browser/components/ChatThinking.js.map +1 -1
  20. package/lib/browser/components/change-list.module.less +2 -0
  21. package/lib/browser/components/{ChatContext/ContextSelector.d.ts → chat-context/context-selector.d.ts} +1 -1
  22. package/lib/browser/components/chat-context/context-selector.d.ts.map +1 -0
  23. package/lib/browser/components/{ChatContext/ContextSelector.js → chat-context/context-selector.js} +1 -1
  24. package/lib/browser/components/chat-context/context-selector.js.map +1 -0
  25. package/lib/browser/components/chat-context/index.d.ts.map +1 -0
  26. package/lib/browser/components/{ChatContext → chat-context}/index.js +2 -2
  27. package/lib/browser/components/chat-context/index.js.map +1 -0
  28. package/lib/browser/components/components.module.less +32 -2
  29. package/lib/browser/components/mention-input/mention-input.d.ts +5 -0
  30. package/lib/browser/components/mention-input/mention-input.d.ts.map +1 -0
  31. package/lib/browser/components/mention-input/mention-input.js +763 -0
  32. package/lib/browser/components/mention-input/mention-input.js.map +1 -0
  33. package/lib/browser/components/mention-input/mention-input.module.less +329 -0
  34. package/lib/browser/components/mention-input/mention-item.d.ts +10 -0
  35. package/lib/browser/components/mention-input/mention-item.d.ts.map +1 -0
  36. package/lib/browser/components/mention-input/mention-item.js +16 -0
  37. package/lib/browser/components/mention-input/mention-item.js.map +1 -0
  38. package/lib/browser/components/mention-input/mention-panel.d.ts +15 -0
  39. package/lib/browser/components/mention-input/mention-panel.d.ts.map +1 -0
  40. package/lib/browser/components/mention-input/mention-panel.js +49 -0
  41. package/lib/browser/components/mention-input/mention-panel.js.map +1 -0
  42. package/lib/browser/components/mention-input/types.d.ts +78 -0
  43. package/lib/browser/components/mention-input/types.d.ts.map +1 -0
  44. package/lib/browser/components/mention-input/types.js +16 -0
  45. package/lib/browser/components/mention-input/types.js.map +1 -0
  46. package/lib/browser/context/llm-context.service.d.ts +10 -2
  47. package/lib/browser/context/llm-context.service.d.ts.map +1 -1
  48. package/lib/browser/context/llm-context.service.js +71 -2
  49. package/lib/browser/context/llm-context.service.js.map +1 -1
  50. package/lib/common/llm-context.d.ts +15 -1
  51. package/lib/common/llm-context.d.ts.map +1 -1
  52. package/lib/common/llm-context.js.map +1 -1
  53. package/lib/common/prompts/context-prompt-provider.d.ts +12 -2
  54. package/lib/common/prompts/context-prompt-provider.d.ts.map +1 -1
  55. package/lib/common/prompts/context-prompt-provider.js +94 -30
  56. package/lib/common/prompts/context-prompt-provider.js.map +1 -1
  57. package/lib/node/mcp-server.sse.d.ts.map +1 -1
  58. package/lib/node/mcp-server.sse.js +2 -2
  59. package/lib/node/mcp-server.sse.js.map +1 -1
  60. package/package.json +23 -23
  61. package/src/browser/chat/chat-agent.service.ts +7 -7
  62. package/src/browser/chat/chat.view.tsx +74 -21
  63. package/src/browser/components/ChatEditor.tsx +126 -9
  64. package/src/browser/components/ChatMentionInput.tsx +271 -0
  65. package/src/browser/components/ChatThinking.tsx +10 -4
  66. package/src/browser/components/change-list.module.less +2 -0
  67. package/src/browser/components/{ChatContext → chat-context}/index.tsx +1 -1
  68. package/src/browser/components/components.module.less +32 -2
  69. package/src/browser/components/mention-input/mention-input.module.less +329 -0
  70. package/src/browser/components/mention-input/mention-input.tsx +952 -0
  71. package/src/browser/components/mention-input/mention-item.tsx +24 -0
  72. package/src/browser/components/mention-input/mention-panel.tsx +89 -0
  73. package/src/browser/components/mention-input/types.ts +84 -0
  74. package/src/browser/context/llm-context.service.ts +81 -3
  75. package/src/common/llm-context.ts +16 -1
  76. package/src/common/prompts/context-prompt-provider.ts +126 -36
  77. package/src/node/mcp-server.sse.ts +1 -2
  78. package/lib/browser/components/ChatContext/ContextSelector.d.ts.map +0 -1
  79. package/lib/browser/components/ChatContext/ContextSelector.js.map +0 -1
  80. package/lib/browser/components/ChatContext/index.d.ts.map +0 -1
  81. package/lib/browser/components/ChatContext/index.js.map +0 -1
  82. /package/lib/browser/components/{ChatContext → chat-context}/index.d.ts +0 -0
  83. /package/lib/browser/components/{ChatContext → chat-context}/style.module.less +0 -0
  84. /package/src/browser/components/{ChatContext/ContextSelector.tsx → chat-context/context-selector.tsx} +0 -0
  85. /package/src/browser/components/{ChatContext → chat-context}/style.module.less +0 -0
@@ -1,7 +1,6 @@
1
1
  import React, { useCallback, useEffect, useMemo, useState } from 'react';
2
2
 
3
3
  import { useInjectable } from '@opensumi/ide-core-browser';
4
- import { Icon, getIcon } from '@opensumi/ide-core-browser/lib/components';
5
4
  import { EnhanceIcon, Thumbs } from '@opensumi/ide-core-browser/lib/components/ai-native';
6
5
  import { Progress } from '@opensumi/ide-core-browser/lib/progress/progress-bar';
7
6
  import { ChatRenderRegistryToken, isUndefined, localize } from '@opensumi/ide-core-common';
@@ -13,7 +12,7 @@ import { ChatRenderRegistry } from '../chat/chat.render.registry';
13
12
  import styles from './components.module.less';
14
13
 
15
14
  interface ITinkingProps {
16
- children?: React.ReactNode;
15
+ children?: React.ReactNode | string | React.ReactNode[];
17
16
  hasMessage?: boolean;
18
17
  message?: string;
19
18
  onRegenerate?: () => void;
@@ -32,8 +31,15 @@ export const ChatThinking = (props: ITinkingProps) => {
32
31
  [chatRenderRegistry, chatRenderRegistry.chatThinkingRender],
33
32
  );
34
33
 
34
+ const isEmptyChildren = useMemo(() => {
35
+ if (Array.isArray(children)) {
36
+ return children.length === 0;
37
+ }
38
+ return !children;
39
+ }, [children]);
40
+
35
41
  const renderContent = useCallback(() => {
36
- if (!children) {
42
+ if (isEmptyChildren) {
37
43
  if (CustomThinkingRender) {
38
44
  return <CustomThinkingRender thinkingText={thinkingText} />;
39
45
  }
@@ -52,7 +58,7 @@ export const ChatThinking = (props: ITinkingProps) => {
52
58
  {!CustomThinkingRender && (
53
59
  <span className={styles.progress_bar}>
54
60
  {/* 保持动画效果一致 */}
55
- {!children && <Progress loading={true} wrapperClassName={styles.ai_native_progress_wrapper} />}
61
+ {isEmptyChildren && <Progress loading={true} wrapperClassName={styles.ai_native_progress_wrapper} />}
56
62
  </span>
57
63
  )}
58
64
  {/* {showStop && (
@@ -103,6 +103,8 @@
103
103
  .fileStats {
104
104
  font-size: 12px;
105
105
  display: flex;
106
+ flex: 1;
107
+ justify-content: flex-end;
106
108
  align-items: center;
107
109
  gap: 4px;
108
110
  }
@@ -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 });
@@ -4,9 +4,9 @@
4
4
  height: 100%;
5
5
  .stop {
6
6
  position: absolute;
7
- bottom: -38px;
7
+ bottom: -15px;
8
8
  padding-top: 12px;
9
- left: -8px;
9
+ left: -9px;
10
10
  width: 105%;
11
11
  }
12
12
 
@@ -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 {
@@ -565,3 +566,32 @@
565
566
  color: var(--descriptionForeground);
566
567
  }
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
+ cursor: pointer;
581
+ :global {
582
+ .kt-icon {
583
+ font-size: 12px;
584
+ margin-right: 3px;
585
+ }
586
+ }
587
+ &:hover {
588
+ background-color: var(--chat-slashCommandBackground);
589
+ color: var(--chat-slashCommandForeground);
590
+ }
591
+ }
592
+
593
+ .attachment_text {
594
+ line-height: 20px;
595
+ vertical-align: middle;
596
+ font-size: 12px;
597
+ }
@@ -0,0 +1,329 @@
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
+ margin-right: 3px;
266
+ font-size: 12px;
267
+ }
268
+
269
+ .empty_state {
270
+ padding: 5px 10px;
271
+ text-align: center;
272
+ color: var(--descriptionForeground);
273
+ font-size: 14px;
274
+ }
275
+
276
+ .model_selector {
277
+ margin-right: 5px;
278
+ }
279
+
280
+ .mcp_logo {
281
+ margin-right: 5px;
282
+ }
283
+
284
+ .send_logo {
285
+ color: var(--icon-foreground);
286
+ cursor: pointer;
287
+ margin-left: auto;
288
+
289
+ &:hover {
290
+ color: var(--notification-success-foreground);
291
+ }
292
+ }
293
+
294
+ .popover_icon {
295
+ // 移除 margin-left: auto
296
+ }
297
+
298
+ .loading_container {
299
+ display: none;
300
+ }
301
+
302
+ .loading_bar {
303
+ position: absolute;
304
+ top: 0;
305
+ left: 0;
306
+ height: 2px;
307
+ width: 100%;
308
+ background: linear-gradient(90deg, transparent, var(--kt-primaryButton-background), transparent);
309
+ background-size: 200% 100%;
310
+ animation: loading-bar 1.5s infinite;
311
+ z-index: 10;
312
+ }
313
+
314
+ @keyframes loading-bar {
315
+ 0% {
316
+ background-position: 100% 0;
317
+ }
318
+
319
+ 100% {
320
+ background-position: -100% 0;
321
+ }
322
+ }
323
+
324
+ .no_results {
325
+ padding: 12px;
326
+ text-align: center;
327
+ color: #666;
328
+ font-style: italic;
329
+ }