@opensumi/ide-ai-native 3.9.1-next-1749022986.0 → 3.9.1-next-1749115679.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 (83) hide show
  1. package/lib/browser/components/ChatMentionInput.d.ts.map +1 -1
  2. package/lib/browser/components/ChatMentionInput.js +3 -18
  3. package/lib/browser/components/ChatMentionInput.js.map +1 -1
  4. package/lib/browser/components/ChatReply.js +2 -2
  5. package/lib/browser/components/ChatReply.js.map +1 -1
  6. package/lib/browser/components/components.module.less +8 -30
  7. package/lib/browser/components/mention-input/mention-input.d.ts.map +1 -1
  8. package/lib/browser/components/mention-input/mention-input.js +36 -30
  9. package/lib/browser/components/mention-input/mention-input.js.map +1 -1
  10. package/lib/browser/components/mention-input/mention-input.module.less +1 -0
  11. package/lib/browser/components/mention-input/types.d.ts +0 -13
  12. package/lib/browser/components/mention-input/types.d.ts.map +1 -1
  13. package/lib/browser/components/mention-input/types.js.map +1 -1
  14. package/lib/browser/mcp/mcp-server.feature.registry.d.ts.map +1 -1
  15. package/lib/browser/mcp/mcp-server.feature.registry.js +7 -1
  16. package/lib/browser/mcp/mcp-server.feature.registry.js.map +1 -1
  17. package/lib/browser/mcp/tools/createNewFileWithText.d.ts +1 -3
  18. package/lib/browser/mcp/tools/createNewFileWithText.d.ts.map +1 -1
  19. package/lib/browser/mcp/tools/createNewFileWithText.js +14 -40
  20. package/lib/browser/mcp/tools/createNewFileWithText.js.map +1 -1
  21. package/lib/browser/mcp/tools/fileSearch.d.ts.map +1 -1
  22. package/lib/browser/mcp/tools/fileSearch.js +9 -5
  23. package/lib/browser/mcp/tools/fileSearch.js.map +1 -1
  24. package/lib/browser/mcp/tools/grepSearch.d.ts.map +1 -1
  25. package/lib/browser/mcp/tools/grepSearch.js +22 -10
  26. package/lib/browser/mcp/tools/grepSearch.js.map +1 -1
  27. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.d.ts +15 -0
  28. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.d.ts.map +1 -0
  29. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.js +53 -0
  30. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.js.map +1 -0
  31. package/lib/browser/mcp/tools/handlers/ListDir.js +1 -1
  32. package/lib/browser/mcp/tools/handlers/ListDir.js.map +1 -1
  33. package/lib/browser/mcp/tools/handlers/ReadFile.js +1 -1
  34. package/lib/browser/mcp/tools/handlers/ReadFile.js.map +1 -1
  35. package/lib/browser/mcp/tools/handlers/RunCommand.d.ts +11 -1
  36. package/lib/browser/mcp/tools/handlers/RunCommand.d.ts.map +1 -1
  37. package/lib/browser/mcp/tools/handlers/RunCommand.js +11 -4
  38. package/lib/browser/mcp/tools/handlers/RunCommand.js.map +1 -1
  39. package/lib/browser/mcp/tools/listDir.d.ts.map +1 -1
  40. package/lib/browser/mcp/tools/listDir.js +19 -15
  41. package/lib/browser/mcp/tools/listDir.js.map +1 -1
  42. package/lib/browser/rules/rules.module.less +0 -1
  43. package/lib/browser/rules/rules.view.js +1 -1
  44. package/lib/browser/rules/rules.view.js.map +1 -1
  45. package/lib/common/model.d.ts +0 -1
  46. package/lib/common/model.d.ts.map +1 -1
  47. package/lib/common/model.js.map +1 -1
  48. package/lib/node/base-language-model.js +1 -2
  49. package/lib/node/base-language-model.js.map +1 -1
  50. package/lib/node/mcp-server.sse.d.ts +187 -1
  51. package/lib/node/mcp-server.sse.d.ts.map +1 -1
  52. package/lib/node/mcp-server.sse.js +2 -2
  53. package/lib/node/mcp-server.sse.js.map +1 -1
  54. package/lib/node/mcp-server.stdio.d.ts +187 -1
  55. package/lib/node/mcp-server.stdio.d.ts.map +1 -1
  56. package/package.json +26 -26
  57. package/src/browser/components/ChatMentionInput.tsx +4 -26
  58. package/src/browser/components/ChatReply.tsx +4 -4
  59. package/src/browser/components/components.module.less +8 -30
  60. package/src/browser/components/mention-input/mention-input.module.less +1 -0
  61. package/src/browser/components/mention-input/mention-input.tsx +52 -38
  62. package/src/browser/components/mention-input/types.ts +0 -14
  63. package/src/browser/mcp/mcp-server.feature.registry.ts +6 -1
  64. package/src/browser/mcp/tools/createNewFileWithText.ts +17 -46
  65. package/src/browser/mcp/tools/fileSearch.ts +8 -5
  66. package/src/browser/mcp/tools/grepSearch.ts +32 -21
  67. package/src/browser/mcp/tools/handlers/CreateNewFileWithText.ts +49 -0
  68. package/src/browser/mcp/tools/handlers/ListDir.ts +2 -2
  69. package/src/browser/mcp/tools/handlers/ReadFile.ts +2 -2
  70. package/src/browser/mcp/tools/handlers/RunCommand.ts +21 -14
  71. package/src/browser/mcp/tools/listDir.ts +15 -12
  72. package/src/browser/rules/rules.module.less +0 -1
  73. package/src/browser/rules/rules.view.tsx +1 -1
  74. package/src/common/model.ts +0 -1
  75. package/src/node/base-language-model.ts +1 -1
  76. package/src/node/mcp-server.sse.ts +1 -2
  77. package/lib/browser/components/mention-input/mention-select.d.ts +0 -28
  78. package/lib/browser/components/mention-input/mention-select.d.ts.map +0 -1
  79. package/lib/browser/components/mention-input/mention-select.js +0 -136
  80. package/lib/browser/components/mention-input/mention-select.js.map +0 -1
  81. package/lib/browser/components/mention-input/mention-select.module.less +0 -297
  82. package/src/browser/components/mention-input/mention-select.module.less +0 -297
  83. package/src/browser/components/mention-input/mention-select.tsx +0 -256
@@ -1,297 +0,0 @@
1
- .mention_select {
2
- position: relative;
3
- display: inline-block;
4
-
5
- &.size_small {
6
- .select_trigger {
7
- height: 20px;
8
- padding: 0 6px;
9
- font-size: 12px;
10
- }
11
- }
12
-
13
- &.size_medium {
14
- .select_trigger {
15
- height: 32px;
16
- padding: 0 12px;
17
- font-size: 14px;
18
- }
19
- }
20
-
21
- &.size_large {
22
- .select_trigger {
23
- height: 40px;
24
- padding: 0 16px;
25
- font-size: 16px;
26
- }
27
- }
28
-
29
- &.disabled {
30
- opacity: 0.6;
31
- cursor: not-allowed;
32
-
33
- .select_trigger {
34
- cursor: not-allowed;
35
- background-color: var(--input-background-disabled);
36
- }
37
- }
38
-
39
- .select_trigger {
40
- display: flex;
41
- align-items: center;
42
- justify-content: space-between;
43
- background-color: var(--input-background);
44
- border: 1px solid var(--input-border);
45
- border-radius: 4px;
46
- cursor: pointer;
47
- transition: all 0.2s;
48
- opacity: 0.7;
49
-
50
- &:hover:not(.disabled) {
51
- opacity: 1;
52
- }
53
- }
54
-
55
- .select_content {
56
- flex: 1;
57
- overflow: hidden;
58
- }
59
-
60
- .selected_option {
61
- display: flex;
62
- align-items: center;
63
- gap: 6px;
64
- }
65
-
66
- .option_icon {
67
- flex-shrink: 0;
68
- font-size: 14px;
69
- }
70
-
71
- .option_label {
72
- flex: 1;
73
- white-space: nowrap;
74
- overflow: hidden;
75
- text-overflow: ellipsis;
76
- }
77
-
78
- .option_badge {
79
- display: inline-block;
80
- padding: 2px 6px;
81
- border-radius: 10px;
82
- font-size: 10px;
83
- color: white;
84
- background-color: var(--badge-background);
85
- white-space: nowrap;
86
- }
87
-
88
- .placeholder {
89
- color: var(--input-placeholder-foreground);
90
- }
91
-
92
- .dropdown_arrow {
93
- margin-left: 8px;
94
- transition: transform 0.2s;
95
- color: var(--icon-foreground);
96
-
97
- &.open {
98
- transform: rotate(180deg);
99
- }
100
- }
101
-
102
- .dropdown {
103
- position: absolute;
104
- left: 0;
105
- right: 0;
106
- z-index: 1000;
107
- background-color: var(--editor-background);
108
- border: 1px solid var(--dropdown-border);
109
- border-radius: 6px;
110
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 2px 4px rgba(0, 0, 0, 0.05);
111
- max-height: 400px;
112
- min-width: 300px;
113
- overflow-y: auto;
114
- padding: 4px;
115
- animation: dropdownFadeIn 0.15s ease-out;
116
-
117
- // 滚动条样式
118
- &::-webkit-scrollbar {
119
- width: 6px;
120
- }
121
-
122
- &::-webkit-scrollbar-track {
123
- background: transparent;
124
- }
125
-
126
- &::-webkit-scrollbar-thumb {
127
- background: var(--scrollbar-thumb);
128
- border-radius: 3px;
129
- transition: background-color 0.2s;
130
- }
131
-
132
- &::-webkit-scrollbar-thumb:hover {
133
- background: var(--scrollbar-thumb-hover);
134
- }
135
- }
136
-
137
- @keyframes dropdownFadeIn {
138
- from {
139
- opacity: 0;
140
- transform: translateY(-4px);
141
- }
142
-
143
- to {
144
- opacity: 1;
145
- transform: translateY(0);
146
- }
147
- }
148
-
149
- .thinking_section {
150
- padding: 8px 12px 4px;
151
- }
152
-
153
- .thinking_toggle {
154
- display: flex;
155
- align-items: center;
156
- gap: 8px;
157
- padding: 6px 0;
158
- cursor: pointer;
159
- border-radius: 4px;
160
-
161
- &:hover {
162
- background-color: var(--list-hover-background);
163
- }
164
- }
165
-
166
- .thinking_icon {
167
- flex-shrink: 0;
168
- color: var(--icon-foreground);
169
-
170
- &.enabled {
171
- color: var(--list-active-selection-foreground);
172
- }
173
- }
174
-
175
- .thinking_label {
176
- font-size: 13px;
177
- color: var(--foreground);
178
- font-weight: 500;
179
- }
180
-
181
- .divider {
182
- height: 1px;
183
- background-color: var(--separator-border);
184
- margin: 8px 0 4px;
185
- }
186
-
187
- // 向上展开(默认)
188
- &.dropdown_up .dropdown {
189
- bottom: 100%;
190
- margin-bottom: 4px;
191
- }
192
-
193
- // 向下展开
194
- &.dropdown_down .dropdown {
195
- top: 100%;
196
- margin-top: 4px;
197
- }
198
-
199
- .option {
200
- padding: 8px 12px;
201
- border-radius: 4px;
202
- cursor: pointer;
203
- transition: all 0.2s;
204
- position: relative;
205
- border: 1px solid transparent;
206
- box-sizing: content-box;
207
- margin-bottom: 4px;
208
- &:last-child {
209
- margin-bottom: 0;
210
- }
211
- &:hover:not(.disabled) {
212
- border-color: var(--dropdown-border);
213
- }
214
-
215
- &.active {
216
- border-color: var(--dropdown-border);
217
- }
218
-
219
- &.selected {
220
- background-color: var(--dropdown-background);
221
-
222
- &::after {
223
- content: '✓';
224
- position: absolute;
225
- top: 50%;
226
- right: 12px;
227
- transform: translateY(-50%);
228
- color: var(--list-active-selection-foreground);
229
- font-weight: bold;
230
- font-size: 14px;
231
- z-index: 1;
232
- }
233
- }
234
-
235
- &.disabled {
236
- opacity: 0.5;
237
- cursor: not-allowed;
238
-
239
- &:hover {
240
- transform: none;
241
- box-shadow: none;
242
- border-color: transparent;
243
- }
244
- }
245
- }
246
-
247
- .option_main {
248
- display: flex;
249
- flex-direction: column;
250
- gap: 6px;
251
- padding-right: 24px;
252
- }
253
-
254
- .option_header {
255
- display: flex;
256
- align-items: center;
257
- justify-content: space-between;
258
- }
259
-
260
- .option_title {
261
- display: flex;
262
- align-items: center;
263
- gap: 8px;
264
- flex: 1;
265
- }
266
-
267
- .option_description {
268
- font-size: 12px;
269
- color: var(--descriptionForeground);
270
- line-height: 1.4;
271
- margin-top: 4px;
272
- }
273
-
274
- .option_tags {
275
- display: flex;
276
- flex-wrap: wrap;
277
- gap: 4px;
278
- margin-top: 6px;
279
- }
280
-
281
- .tag {
282
- display: inline-block;
283
- padding: 2px 6px;
284
- border-radius: 10px;
285
- font-size: 10px;
286
- background-color: var(--badge-background);
287
- color: var(--badge-foreground);
288
- white-space: nowrap;
289
- }
290
-
291
- .status_indicator {
292
- width: 8px;
293
- height: 8px;
294
- border-radius: 50%;
295
- flex-shrink: 0;
296
- }
297
- }
@@ -1,297 +0,0 @@
1
- .mention_select {
2
- position: relative;
3
- display: inline-block;
4
-
5
- &.size_small {
6
- .select_trigger {
7
- height: 20px;
8
- padding: 0 6px;
9
- font-size: 12px;
10
- }
11
- }
12
-
13
- &.size_medium {
14
- .select_trigger {
15
- height: 32px;
16
- padding: 0 12px;
17
- font-size: 14px;
18
- }
19
- }
20
-
21
- &.size_large {
22
- .select_trigger {
23
- height: 40px;
24
- padding: 0 16px;
25
- font-size: 16px;
26
- }
27
- }
28
-
29
- &.disabled {
30
- opacity: 0.6;
31
- cursor: not-allowed;
32
-
33
- .select_trigger {
34
- cursor: not-allowed;
35
- background-color: var(--input-background-disabled);
36
- }
37
- }
38
-
39
- .select_trigger {
40
- display: flex;
41
- align-items: center;
42
- justify-content: space-between;
43
- background-color: var(--input-background);
44
- border: 1px solid var(--input-border);
45
- border-radius: 4px;
46
- cursor: pointer;
47
- transition: all 0.2s;
48
- opacity: 0.7;
49
-
50
- &:hover:not(.disabled) {
51
- opacity: 1;
52
- }
53
- }
54
-
55
- .select_content {
56
- flex: 1;
57
- overflow: hidden;
58
- }
59
-
60
- .selected_option {
61
- display: flex;
62
- align-items: center;
63
- gap: 6px;
64
- }
65
-
66
- .option_icon {
67
- flex-shrink: 0;
68
- font-size: 14px;
69
- }
70
-
71
- .option_label {
72
- flex: 1;
73
- white-space: nowrap;
74
- overflow: hidden;
75
- text-overflow: ellipsis;
76
- }
77
-
78
- .option_badge {
79
- display: inline-block;
80
- padding: 2px 6px;
81
- border-radius: 10px;
82
- font-size: 10px;
83
- color: white;
84
- background-color: var(--badge-background);
85
- white-space: nowrap;
86
- }
87
-
88
- .placeholder {
89
- color: var(--input-placeholder-foreground);
90
- }
91
-
92
- .dropdown_arrow {
93
- margin-left: 8px;
94
- transition: transform 0.2s;
95
- color: var(--icon-foreground);
96
-
97
- &.open {
98
- transform: rotate(180deg);
99
- }
100
- }
101
-
102
- .dropdown {
103
- position: absolute;
104
- left: 0;
105
- right: 0;
106
- z-index: 1000;
107
- background-color: var(--editor-background);
108
- border: 1px solid var(--dropdown-border);
109
- border-radius: 6px;
110
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 2px 4px rgba(0, 0, 0, 0.05);
111
- max-height: 400px;
112
- min-width: 300px;
113
- overflow-y: auto;
114
- padding: 4px;
115
- animation: dropdownFadeIn 0.15s ease-out;
116
-
117
- // 滚动条样式
118
- &::-webkit-scrollbar {
119
- width: 6px;
120
- }
121
-
122
- &::-webkit-scrollbar-track {
123
- background: transparent;
124
- }
125
-
126
- &::-webkit-scrollbar-thumb {
127
- background: var(--scrollbar-thumb);
128
- border-radius: 3px;
129
- transition: background-color 0.2s;
130
- }
131
-
132
- &::-webkit-scrollbar-thumb:hover {
133
- background: var(--scrollbar-thumb-hover);
134
- }
135
- }
136
-
137
- @keyframes dropdownFadeIn {
138
- from {
139
- opacity: 0;
140
- transform: translateY(-4px);
141
- }
142
-
143
- to {
144
- opacity: 1;
145
- transform: translateY(0);
146
- }
147
- }
148
-
149
- .thinking_section {
150
- padding: 8px 12px 4px;
151
- }
152
-
153
- .thinking_toggle {
154
- display: flex;
155
- align-items: center;
156
- gap: 8px;
157
- padding: 6px 0;
158
- cursor: pointer;
159
- border-radius: 4px;
160
-
161
- &:hover {
162
- background-color: var(--list-hover-background);
163
- }
164
- }
165
-
166
- .thinking_icon {
167
- flex-shrink: 0;
168
- color: var(--icon-foreground);
169
-
170
- &.enabled {
171
- color: var(--list-active-selection-foreground);
172
- }
173
- }
174
-
175
- .thinking_label {
176
- font-size: 13px;
177
- color: var(--foreground);
178
- font-weight: 500;
179
- }
180
-
181
- .divider {
182
- height: 1px;
183
- background-color: var(--separator-border);
184
- margin: 8px 0 4px;
185
- }
186
-
187
- // 向上展开(默认)
188
- &.dropdown_up .dropdown {
189
- bottom: 100%;
190
- margin-bottom: 4px;
191
- }
192
-
193
- // 向下展开
194
- &.dropdown_down .dropdown {
195
- top: 100%;
196
- margin-top: 4px;
197
- }
198
-
199
- .option {
200
- padding: 8px 12px;
201
- border-radius: 4px;
202
- cursor: pointer;
203
- transition: all 0.2s;
204
- position: relative;
205
- border: 1px solid transparent;
206
- box-sizing: content-box;
207
- margin-bottom: 4px;
208
- &:last-child {
209
- margin-bottom: 0;
210
- }
211
- &:hover:not(.disabled) {
212
- border-color: var(--dropdown-border);
213
- }
214
-
215
- &.active {
216
- border-color: var(--dropdown-border);
217
- }
218
-
219
- &.selected {
220
- background-color: var(--dropdown-background);
221
-
222
- &::after {
223
- content: '✓';
224
- position: absolute;
225
- top: 50%;
226
- right: 12px;
227
- transform: translateY(-50%);
228
- color: var(--list-active-selection-foreground);
229
- font-weight: bold;
230
- font-size: 14px;
231
- z-index: 1;
232
- }
233
- }
234
-
235
- &.disabled {
236
- opacity: 0.5;
237
- cursor: not-allowed;
238
-
239
- &:hover {
240
- transform: none;
241
- box-shadow: none;
242
- border-color: transparent;
243
- }
244
- }
245
- }
246
-
247
- .option_main {
248
- display: flex;
249
- flex-direction: column;
250
- gap: 6px;
251
- padding-right: 24px;
252
- }
253
-
254
- .option_header {
255
- display: flex;
256
- align-items: center;
257
- justify-content: space-between;
258
- }
259
-
260
- .option_title {
261
- display: flex;
262
- align-items: center;
263
- gap: 8px;
264
- flex: 1;
265
- }
266
-
267
- .option_description {
268
- font-size: 12px;
269
- color: var(--descriptionForeground);
270
- line-height: 1.4;
271
- margin-top: 4px;
272
- }
273
-
274
- .option_tags {
275
- display: flex;
276
- flex-wrap: wrap;
277
- gap: 4px;
278
- margin-top: 6px;
279
- }
280
-
281
- .tag {
282
- display: inline-block;
283
- padding: 2px 6px;
284
- border-radius: 10px;
285
- font-size: 10px;
286
- background-color: var(--badge-background);
287
- color: var(--badge-foreground);
288
- white-space: nowrap;
289
- }
290
-
291
- .status_indicator {
292
- width: 8px;
293
- height: 8px;
294
- border-radius: 50%;
295
- flex-shrink: 0;
296
- }
297
- }