@opensumi/ide-ai-native 3.9.1-next-1749022016.0 → 3.9.1-next-1749023860.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 (39) 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 +34 -39
  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 +6 -7
  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/rules/rules.module.less +0 -1
  15. package/lib/browser/rules/rules.view.js +1 -1
  16. package/lib/browser/rules/rules.view.js.map +1 -1
  17. package/lib/common/model.d.ts +0 -1
  18. package/lib/common/model.d.ts.map +1 -1
  19. package/lib/common/model.js.map +1 -1
  20. package/lib/node/base-language-model.js +1 -2
  21. package/lib/node/base-language-model.js.map +1 -1
  22. package/package.json +25 -25
  23. package/src/browser/components/ChatMentionInput.tsx +4 -26
  24. package/src/browser/components/ChatReply.tsx +4 -4
  25. package/src/browser/components/components.module.less +8 -30
  26. package/src/browser/components/mention-input/mention-input.module.less +1 -0
  27. package/src/browser/components/mention-input/mention-input.tsx +26 -36
  28. package/src/browser/components/mention-input/types.ts +7 -8
  29. package/src/browser/rules/rules.module.less +0 -1
  30. package/src/browser/rules/rules.view.tsx +1 -1
  31. package/src/common/model.ts +0 -1
  32. package/src/node/base-language-model.ts +1 -1
  33. package/lib/browser/components/mention-input/mention-select.d.ts +0 -28
  34. package/lib/browser/components/mention-input/mention-select.d.ts.map +0 -1
  35. package/lib/browser/components/mention-input/mention-select.js +0 -136
  36. package/lib/browser/components/mention-input/mention-select.js.map +0 -1
  37. package/lib/browser/components/mention-input/mention-select.module.less +0 -297
  38. package/src/browser/components/mention-input/mention-select.module.less +0 -297
  39. package/src/browser/components/mention-input/mention-select.tsx +0 -256
@@ -1 +0,0 @@
1
- {"version":3,"file":"mention-select.d.ts","sourceRoot":"","sources":["../../../../src/browser/components/mention-input/mention-select.tsx"],"names":[],"mappings":"AACA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAO3D,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,mBAAmB,EAAE,CAAC;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC;IACpC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,gBAAgB,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAC/C;AAiBD,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CA6MtD,CAAC"}
@@ -1,136 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MentionSelect = void 0;
4
- const tslib_1 = require("tslib");
5
- const classnames_1 = tslib_1.__importDefault(require("classnames"));
6
- const react_1 = tslib_1.__importStar(require("react"));
7
- const click_outside_1 = require("@opensumi/ide-components/lib/click-outside");
8
- const components_1 = require("@opensumi/ide-core-browser/lib/components");
9
- const mention_select_module_less_1 = tslib_1.__importDefault(require("./mention-select.module.less"));
10
- const ThinkingToggle = ({ enabled, onChange }) => (react_1.default.createElement("div", { className: mention_select_module_less_1.default.thinking_toggle, onClick: () => onChange(!enabled) },
11
- react_1.default.createElement(components_1.Icon, { iconClass: (0, components_1.getIcon)(enabled ? 'check' : 'circle-outline'), className: (0, classnames_1.default)(mention_select_module_less_1.default.thinking_icon, {
12
- [mention_select_module_less_1.default.enabled]: enabled,
13
- }) }),
14
- react_1.default.createElement("span", { className: mention_select_module_less_1.default.thinking_label }, "Thinking")));
15
- const MentionSelect = ({ options, value, onChange, placeholder, disabled = false, className, size = 'small', showThinking = false, thinkingEnabled = false, onThinkingChange, }) => {
16
- const [isOpen, setIsOpen] = (0, react_1.useState)(false);
17
- const [activeIndex, setActiveIndex] = (0, react_1.useState)(-1);
18
- const [dropdownDirection, setDropdownDirection] = (0, react_1.useState)('up');
19
- const selectRef = (0, react_1.useRef)(null);
20
- const dropdownRef = (0, react_1.useRef)(null);
21
- const selectedOption = options.find((option) => option.selected) || options.find((option) => option.value === value);
22
- const handleToggle = () => {
23
- if (!disabled) {
24
- setIsOpen(!isOpen);
25
- setActiveIndex(-1);
26
- }
27
- };
28
- const handleSelect = (option) => {
29
- if (!option.disabled) {
30
- onChange === null || onChange === void 0 ? void 0 : onChange(option.value);
31
- setIsOpen(false);
32
- setActiveIndex(-1);
33
- }
34
- };
35
- const handleKeyDown = (e) => {
36
- if (disabled) {
37
- return;
38
- }
39
- switch (e.key) {
40
- case 'Enter':
41
- case ' ':
42
- e.preventDefault();
43
- if (!isOpen) {
44
- setIsOpen(true);
45
- }
46
- else if (activeIndex >= 0) {
47
- handleSelect(options[activeIndex]);
48
- }
49
- break;
50
- case 'Escape':
51
- e.preventDefault();
52
- setIsOpen(false);
53
- setActiveIndex(-1);
54
- break;
55
- case 'ArrowDown':
56
- e.preventDefault();
57
- if (!isOpen) {
58
- setIsOpen(true);
59
- }
60
- else {
61
- setActiveIndex((prev) => (prev < options.length - 1 ? prev + 1 : 0));
62
- }
63
- break;
64
- case 'ArrowUp':
65
- e.preventDefault();
66
- if (isOpen) {
67
- setActiveIndex((prev) => (prev > 0 ? prev - 1 : options.length - 1));
68
- }
69
- break;
70
- }
71
- };
72
- const handleClickOutside = () => {
73
- setIsOpen(false);
74
- setActiveIndex(-1);
75
- };
76
- (0, react_1.useEffect)(() => {
77
- if (isOpen && selectRef.current) {
78
- const selectRect = selectRef.current.getBoundingClientRect();
79
- const viewportHeight = window.innerHeight;
80
- const dropdownHeight = Math.min(400, options.length * 60);
81
- const spaceAbove = selectRect.top;
82
- const spaceBelow = viewportHeight - selectRect.bottom;
83
- if (spaceAbove < dropdownHeight && spaceBelow > spaceAbove) {
84
- setDropdownDirection('down');
85
- }
86
- else {
87
- setDropdownDirection('up');
88
- }
89
- }
90
- }, [isOpen, options.length]);
91
- (0, react_1.useEffect)(() => {
92
- if (isOpen && activeIndex >= 0 && dropdownRef.current) {
93
- const activeElement = dropdownRef.current.children[activeIndex];
94
- if (activeElement) {
95
- activeElement.scrollIntoView({
96
- behavior: 'smooth',
97
- block: 'nearest',
98
- });
99
- }
100
- }
101
- }, [isOpen, activeIndex]);
102
- return (react_1.default.createElement(click_outside_1.ClickOutside, { onOutsideClick: handleClickOutside },
103
- react_1.default.createElement("div", { ref: selectRef, className: (0, classnames_1.default)(mention_select_module_less_1.default.mention_select, mention_select_module_less_1.default[`size_${size}`], {
104
- [mention_select_module_less_1.default.disabled]: disabled,
105
- [mention_select_module_less_1.default.open]: isOpen,
106
- [mention_select_module_less_1.default.dropdown_up]: dropdownDirection === 'up',
107
- [mention_select_module_less_1.default.dropdown_down]: dropdownDirection === 'down',
108
- }, className), onClick: handleToggle, onKeyDown: handleKeyDown, tabIndex: disabled ? -1 : 0, role: 'combobox', "aria-expanded": isOpen, "aria-haspopup": 'listbox' },
109
- react_1.default.createElement("div", { className: mention_select_module_less_1.default.select_trigger },
110
- react_1.default.createElement("div", { className: mention_select_module_less_1.default.select_content }, selectedOption ? (react_1.default.createElement("div", { className: mention_select_module_less_1.default.selected_option },
111
- react_1.default.createElement("span", { className: mention_select_module_less_1.default.option_label }, selectedOption.label),
112
- selectedOption.badge && (react_1.default.createElement("span", { className: mention_select_module_less_1.default.option_badge, style: { backgroundColor: selectedOption.badgeColor } }, selectedOption.badge)))) : (react_1.default.createElement("span", { className: mention_select_module_less_1.default.placeholder }, placeholder))),
113
- react_1.default.createElement(components_1.Icon, { iconClass: (0, components_1.getIcon)('down-arrow'), className: (0, classnames_1.default)(mention_select_module_less_1.default.dropdown_arrow, {
114
- [mention_select_module_less_1.default.open]: isOpen,
115
- }) })),
116
- isOpen && (react_1.default.createElement("div", { ref: dropdownRef, className: mention_select_module_less_1.default.dropdown, role: 'listbox' },
117
- showThinking && onThinkingChange && (react_1.default.createElement("div", { className: mention_select_module_less_1.default.thinking_section },
118
- react_1.default.createElement(ThinkingToggle, { enabled: thinkingEnabled, onChange: onThinkingChange }),
119
- react_1.default.createElement("div", { className: mention_select_module_less_1.default.divider }))),
120
- options.map((option, index) => (react_1.default.createElement("div", { key: option.value, className: (0, classnames_1.default)(mention_select_module_less_1.default.option, {
121
- [mention_select_module_less_1.default.active]: index === activeIndex,
122
- [mention_select_module_less_1.default.selected]: option.selected || option.value === value,
123
- [mention_select_module_less_1.default.disabled]: option.disabled,
124
- }), onClick: () => handleSelect(option), role: 'option', "aria-selected": option.selected || option.value === value },
125
- react_1.default.createElement("div", { className: mention_select_module_less_1.default.option_main },
126
- react_1.default.createElement("div", { className: mention_select_module_less_1.default.option_header },
127
- react_1.default.createElement("div", { className: mention_select_module_less_1.default.option_title },
128
- option.icon && react_1.default.createElement(components_1.Icon, { icon: option.icon, className: mention_select_module_less_1.default.option_icon }),
129
- option.iconClass && react_1.default.createElement(components_1.Icon, { iconClass: option.iconClass, className: mention_select_module_less_1.default.option_icon }),
130
- react_1.default.createElement("span", { className: mention_select_module_less_1.default.option_label }, option.label),
131
- option.badge && (react_1.default.createElement("span", { className: mention_select_module_less_1.default.option_badge, style: { backgroundColor: option.badgeColor } }, option.badge)))),
132
- option.description && react_1.default.createElement("div", { className: mention_select_module_less_1.default.option_description }, option.description),
133
- option.tags && option.tags.length > 0 && (react_1.default.createElement("div", { className: mention_select_module_less_1.default.option_tags }, option.tags.map((tag, idx) => (react_1.default.createElement("span", { key: idx, className: mention_select_module_less_1.default.tag }, tag))))))))))))));
134
- };
135
- exports.MentionSelect = MentionSelect;
136
- //# sourceMappingURL=mention-select.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"mention-select.js","sourceRoot":"","sources":["../../../../src/browser/components/mention-input/mention-select.tsx"],"names":[],"mappings":"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"}
@@ -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
- }