@opensumi/ide-ai-native 3.8.3-next-1741763546.0 → 3.8.3-next-1741767755.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 (74) 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 +52 -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 +221 -0
  15. package/lib/browser/components/ChatMentionInput.js.map +1 -0
  16. package/lib/browser/components/{ChatContext/ContextSelector.d.ts → chat-context/context-selector.d.ts} +1 -1
  17. package/lib/browser/components/chat-context/context-selector.d.ts.map +1 -0
  18. package/lib/browser/components/{ChatContext/ContextSelector.js → chat-context/context-selector.js} +1 -1
  19. package/lib/browser/components/chat-context/context-selector.js.map +1 -0
  20. package/lib/browser/components/chat-context/index.d.ts.map +1 -0
  21. package/lib/browser/components/{ChatContext → chat-context}/index.js +2 -2
  22. package/lib/browser/components/chat-context/index.js.map +1 -0
  23. package/lib/browser/components/components.module.less +25 -0
  24. package/lib/browser/components/mention-input/mention-input.d.ts +5 -0
  25. package/lib/browser/components/mention-input/mention-input.d.ts.map +1 -0
  26. package/lib/browser/components/mention-input/mention-input.js +753 -0
  27. package/lib/browser/components/mention-input/mention-input.js.map +1 -0
  28. package/lib/browser/components/mention-input/mention-input.module.less +328 -0
  29. package/lib/browser/components/mention-input/mention-item.d.ts +10 -0
  30. package/lib/browser/components/mention-input/mention-item.d.ts.map +1 -0
  31. package/lib/browser/components/mention-input/mention-item.js +16 -0
  32. package/lib/browser/components/mention-input/mention-item.js.map +1 -0
  33. package/lib/browser/components/mention-input/mention-panel.d.ts +15 -0
  34. package/lib/browser/components/mention-input/mention-panel.d.ts.map +1 -0
  35. package/lib/browser/components/mention-input/mention-panel.js +49 -0
  36. package/lib/browser/components/mention-input/mention-panel.js.map +1 -0
  37. package/lib/browser/components/mention-input/types.d.ts +76 -0
  38. package/lib/browser/components/mention-input/types.d.ts.map +1 -0
  39. package/lib/browser/components/mention-input/types.js +16 -0
  40. package/lib/browser/components/mention-input/types.js.map +1 -0
  41. package/lib/browser/context/llm-context.service.d.ts +10 -2
  42. package/lib/browser/context/llm-context.service.d.ts.map +1 -1
  43. package/lib/browser/context/llm-context.service.js +71 -2
  44. package/lib/browser/context/llm-context.service.js.map +1 -1
  45. package/lib/common/llm-context.d.ts +15 -1
  46. package/lib/common/llm-context.d.ts.map +1 -1
  47. package/lib/common/llm-context.js.map +1 -1
  48. package/lib/common/prompts/context-prompt-provider.d.ts +12 -2
  49. package/lib/common/prompts/context-prompt-provider.d.ts.map +1 -1
  50. package/lib/common/prompts/context-prompt-provider.js +94 -30
  51. package/lib/common/prompts/context-prompt-provider.js.map +1 -1
  52. package/package.json +23 -23
  53. package/src/browser/chat/chat-agent.service.ts +7 -7
  54. package/src/browser/chat/chat.view.tsx +72 -21
  55. package/src/browser/components/ChatEditor.tsx +126 -9
  56. package/src/browser/components/ChatMentionInput.tsx +268 -0
  57. package/src/browser/components/{ChatContext → chat-context}/index.tsx +1 -1
  58. package/src/browser/components/components.module.less +25 -0
  59. package/src/browser/components/mention-input/mention-input.module.less +328 -0
  60. package/src/browser/components/mention-input/mention-input.tsx +943 -0
  61. package/src/browser/components/mention-input/mention-item.tsx +24 -0
  62. package/src/browser/components/mention-input/mention-panel.tsx +89 -0
  63. package/src/browser/components/mention-input/types.ts +82 -0
  64. package/src/browser/context/llm-context.service.ts +81 -3
  65. package/src/common/llm-context.ts +16 -1
  66. package/src/common/prompts/context-prompt-provider.ts +126 -36
  67. package/lib/browser/components/ChatContext/ContextSelector.d.ts.map +0 -1
  68. package/lib/browser/components/ChatContext/ContextSelector.js.map +0 -1
  69. package/lib/browser/components/ChatContext/index.d.ts.map +0 -1
  70. package/lib/browser/components/ChatContext/index.js.map +0 -1
  71. /package/lib/browser/components/{ChatContext → chat-context}/index.d.ts +0 -0
  72. /package/lib/browser/components/{ChatContext → chat-context}/style.module.less +0 -0
  73. /package/src/browser/components/{ChatContext/ContextSelector.tsx → chat-context/context-selector.tsx} +0 -0
  74. /package/src/browser/components/{ChatContext → chat-context}/style.module.less +0 -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 {
@@ -565,3 +566,27 @@
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
+ margin-right: 3px;
584
+ }
585
+ }
586
+ }
587
+
588
+ .attachment_text {
589
+ line-height: 20px;
590
+ vertical-align: middle;
591
+ font-size: 12px;
592
+ }
@@ -0,0 +1,328 @@
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
+ }
267
+
268
+ .empty_state {
269
+ padding: 5px 10px;
270
+ text-align: center;
271
+ color: var(--descriptionForeground);
272
+ font-size: 14px;
273
+ }
274
+
275
+ .model_selector {
276
+ margin-right: 5px;
277
+ }
278
+
279
+ .mcp_logo {
280
+ margin-right: 5px;
281
+ }
282
+
283
+ .send_logo {
284
+ color: var(--icon-foreground);
285
+ cursor: pointer;
286
+ margin-left: auto;
287
+
288
+ &:hover {
289
+ color: var(--notification-success-foreground);
290
+ }
291
+ }
292
+
293
+ .popover_icon {
294
+ // 移除 margin-left: auto
295
+ }
296
+
297
+ .loading_container {
298
+ display: none;
299
+ }
300
+
301
+ .loading_bar {
302
+ position: absolute;
303
+ top: 0;
304
+ left: 0;
305
+ height: 2px;
306
+ width: 100%;
307
+ background: linear-gradient(90deg, transparent, var(--kt-primaryButton-background), transparent);
308
+ background-size: 200% 100%;
309
+ animation: loading-bar 1.5s infinite;
310
+ z-index: 10;
311
+ }
312
+
313
+ @keyframes loading-bar {
314
+ 0% {
315
+ background-position: 100% 0;
316
+ }
317
+
318
+ 100% {
319
+ background-position: -100% 0;
320
+ }
321
+ }
322
+
323
+ .no_results {
324
+ padding: 12px;
325
+ text-align: center;
326
+ color: #666;
327
+ font-style: italic;
328
+ }