@opensumi/ide-ai-native 3.9.1-next-1749538805.0 → 3.9.1-next-1749540423.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 (253) hide show
  1. package/lib/browser/ai-core.contribution.d.ts.map +1 -1
  2. package/lib/browser/ai-core.contribution.js +4 -9
  3. package/lib/browser/ai-core.contribution.js.map +1 -1
  4. package/lib/browser/chat/apply.service.d.ts +0 -3
  5. package/lib/browser/chat/apply.service.d.ts.map +1 -1
  6. package/lib/browser/chat/apply.service.js +0 -47
  7. package/lib/browser/chat/apply.service.js.map +1 -1
  8. package/lib/browser/chat/chat-manager.service.d.ts +0 -1
  9. package/lib/browser/chat/chat-manager.service.d.ts.map +1 -1
  10. package/lib/browser/chat/chat-manager.service.js +3 -9
  11. package/lib/browser/chat/chat-manager.service.js.map +1 -1
  12. package/lib/browser/chat/chat-model.d.ts +1 -8
  13. package/lib/browser/chat/chat-model.d.ts.map +1 -1
  14. package/lib/browser/chat/chat-model.js +76 -113
  15. package/lib/browser/chat/chat-model.js.map +1 -1
  16. package/lib/browser/chat/chat-proxy.service.d.ts +2 -0
  17. package/lib/browser/chat/chat-proxy.service.d.ts.map +1 -1
  18. package/lib/browser/chat/chat-proxy.service.js +57 -50
  19. package/lib/browser/chat/chat-proxy.service.js.map +1 -1
  20. package/lib/browser/chat/chat.feature.registry.d.ts +1 -4
  21. package/lib/browser/chat/chat.feature.registry.d.ts.map +1 -1
  22. package/lib/browser/chat/chat.feature.registry.js +0 -6
  23. package/lib/browser/chat/chat.feature.registry.js.map +1 -1
  24. package/lib/browser/chat/chat.view.d.ts.map +1 -1
  25. package/lib/browser/chat/chat.view.js +10 -50
  26. package/lib/browser/chat/chat.view.js.map +1 -1
  27. package/lib/browser/components/ChatEditor.js +2 -2
  28. package/lib/browser/components/ChatEditor.js.map +1 -1
  29. package/lib/browser/components/ChatHistory.d.ts.map +1 -1
  30. package/lib/browser/components/ChatHistory.js +1 -2
  31. package/lib/browser/components/ChatHistory.js.map +1 -1
  32. package/lib/browser/components/ChatMentionInput.d.ts.map +1 -1
  33. package/lib/browser/components/ChatMentionInput.js +30 -148
  34. package/lib/browser/components/ChatMentionInput.js.map +1 -1
  35. package/lib/browser/components/ChatReply.js +2 -2
  36. package/lib/browser/components/ChatReply.js.map +1 -1
  37. package/lib/browser/components/ChatToolRender.d.ts.map +1 -1
  38. package/lib/browser/components/ChatToolRender.js +2 -7
  39. package/lib/browser/components/ChatToolRender.js.map +1 -1
  40. package/lib/browser/components/ChatToolRender.module.less +0 -25
  41. package/lib/browser/components/components.module.less +8 -37
  42. package/lib/browser/components/mention-input/mention-input.d.ts.map +1 -1
  43. package/lib/browser/components/mention-input/mention-input.js +14 -150
  44. package/lib/browser/components/mention-input/mention-input.js.map +1 -1
  45. package/lib/browser/components/mention-input/mention-input.module.less +1 -165
  46. package/lib/browser/components/mention-input/types.d.ts +1 -28
  47. package/lib/browser/components/mention-input/types.d.ts.map +1 -1
  48. package/lib/browser/components/mention-input/types.js +0 -1
  49. package/lib/browser/components/mention-input/types.js.map +1 -1
  50. package/lib/browser/components/utils.d.ts +2 -2
  51. package/lib/browser/context/llm-context.service.d.ts +2 -21
  52. package/lib/browser/context/llm-context.service.d.ts.map +1 -1
  53. package/lib/browser/context/llm-context.service.js +20 -162
  54. package/lib/browser/context/llm-context.service.js.map +1 -1
  55. package/lib/browser/contrib/intelligent-completions/decoration/additions-deletions.decoration.d.ts.map +1 -1
  56. package/lib/browser/contrib/intelligent-completions/decoration/additions-deletions.decoration.js.map +1 -1
  57. package/lib/browser/contrib/intelligent-completions/diff-computer.js +1 -1
  58. package/lib/browser/contrib/intelligent-completions/diff-computer.js.map +1 -1
  59. package/lib/browser/contrib/terminal/terminal.feature.registry.js.map +1 -1
  60. package/lib/browser/index.d.ts.map +1 -1
  61. package/lib/browser/index.js +0 -7
  62. package/lib/browser/index.js.map +1 -1
  63. package/lib/browser/layout/ai-layout.d.ts.map +1 -1
  64. package/lib/browser/layout/ai-layout.js +4 -6
  65. package/lib/browser/layout/ai-layout.js.map +1 -1
  66. package/lib/browser/layout/tabbar.view.d.ts +1 -1
  67. package/lib/browser/layout/tabbar.view.d.ts.map +1 -1
  68. package/lib/browser/layout/tabbar.view.js +12 -5
  69. package/lib/browser/layout/tabbar.view.js.map +1 -1
  70. package/lib/browser/mcp/base-apply.service.d.ts +4 -5
  71. package/lib/browser/mcp/base-apply.service.d.ts.map +1 -1
  72. package/lib/browser/mcp/base-apply.service.js +5 -23
  73. package/lib/browser/mcp/base-apply.service.js.map +1 -1
  74. package/lib/browser/mcp/mcp-server-proxy.service.d.ts +1 -3
  75. package/lib/browser/mcp/mcp-server-proxy.service.d.ts.map +1 -1
  76. package/lib/browser/mcp/mcp-server-proxy.service.js +0 -4
  77. package/lib/browser/mcp/mcp-server-proxy.service.js.map +1 -1
  78. package/lib/browser/mcp/mcp-server.feature.registry.d.ts.map +1 -1
  79. package/lib/browser/mcp/mcp-server.feature.registry.js +1 -7
  80. package/lib/browser/mcp/mcp-server.feature.registry.js.map +1 -1
  81. package/lib/browser/mcp/tools/createNewFileWithText.d.ts +3 -1
  82. package/lib/browser/mcp/tools/createNewFileWithText.d.ts.map +1 -1
  83. package/lib/browser/mcp/tools/createNewFileWithText.js +40 -14
  84. package/lib/browser/mcp/tools/createNewFileWithText.js.map +1 -1
  85. package/lib/browser/mcp/tools/fileSearch.d.ts.map +1 -1
  86. package/lib/browser/mcp/tools/fileSearch.js +5 -9
  87. package/lib/browser/mcp/tools/fileSearch.js.map +1 -1
  88. package/lib/browser/mcp/tools/getDiagnosticsByPath.js.map +1 -1
  89. package/lib/browser/mcp/tools/getOpenEditorFileDiagnostics.js.map +1 -1
  90. package/lib/browser/mcp/tools/grepSearch.d.ts.map +1 -1
  91. package/lib/browser/mcp/tools/grepSearch.js +10 -22
  92. package/lib/browser/mcp/tools/grepSearch.js.map +1 -1
  93. package/lib/browser/mcp/tools/handlers/ListDir.js +1 -1
  94. package/lib/browser/mcp/tools/handlers/ListDir.js.map +1 -1
  95. package/lib/browser/mcp/tools/handlers/ReadFile.js +1 -1
  96. package/lib/browser/mcp/tools/handlers/ReadFile.js.map +1 -1
  97. package/lib/browser/mcp/tools/handlers/RunCommand.d.ts +1 -11
  98. package/lib/browser/mcp/tools/handlers/RunCommand.d.ts.map +1 -1
  99. package/lib/browser/mcp/tools/handlers/RunCommand.js +4 -11
  100. package/lib/browser/mcp/tools/handlers/RunCommand.js.map +1 -1
  101. package/lib/browser/mcp/tools/listDir.d.ts.map +1 -1
  102. package/lib/browser/mcp/tools/listDir.js +15 -19
  103. package/lib/browser/mcp/tools/listDir.js.map +1 -1
  104. package/lib/browser/mcp/tools/runTerminalCmd.js.map +1 -1
  105. package/lib/browser/model/msg-history-manager.d.ts +1 -47
  106. package/lib/browser/model/msg-history-manager.d.ts.map +1 -1
  107. package/lib/browser/model/msg-history-manager.js +2 -127
  108. package/lib/browser/model/msg-history-manager.js.map +1 -1
  109. package/lib/browser/preferences/schema.d.ts.map +1 -1
  110. package/lib/browser/preferences/schema.js +0 -5
  111. package/lib/browser/preferences/schema.js.map +1 -1
  112. package/lib/browser/types.d.ts +1 -12
  113. package/lib/browser/types.d.ts.map +1 -1
  114. package/lib/browser/types.js.map +1 -1
  115. package/lib/browser/widget/inline-stream-diff/live-preview.component.d.ts.map +1 -1
  116. package/lib/browser/widget/inline-stream-diff/live-preview.component.js.map +1 -1
  117. package/lib/common/index.d.ts +1 -5
  118. package/lib/common/index.d.ts.map +1 -1
  119. package/lib/common/index.js +0 -2
  120. package/lib/common/index.js.map +1 -1
  121. package/lib/common/llm-context.d.ts +0 -19
  122. package/lib/common/llm-context.d.ts.map +1 -1
  123. package/lib/common/llm-context.js.map +1 -1
  124. package/lib/common/model.d.ts +0 -1
  125. package/lib/common/model.d.ts.map +1 -1
  126. package/lib/common/model.js.map +1 -1
  127. package/lib/common/prompts/context-prompt-provider.d.ts +2 -0
  128. package/lib/common/prompts/context-prompt-provider.d.ts.map +1 -1
  129. package/lib/common/prompts/context-prompt-provider.js +29 -35
  130. package/lib/common/prompts/context-prompt-provider.js.map +1 -1
  131. package/lib/common/types.d.ts +0 -21
  132. package/lib/common/types.d.ts.map +1 -1
  133. package/lib/common/types.js.map +1 -1
  134. package/lib/common/utils.d.ts +0 -1
  135. package/lib/common/utils.d.ts.map +1 -1
  136. package/lib/common/utils.js +2 -5
  137. package/lib/common/utils.js.map +1 -1
  138. package/lib/node/anthropic/anthropic-language-model.d.ts +1 -1
  139. package/lib/node/base-language-model.d.ts +1 -2
  140. package/lib/node/base-language-model.d.ts.map +1 -1
  141. package/lib/node/base-language-model.js +2 -12
  142. package/lib/node/base-language-model.js.map +1 -1
  143. package/lib/node/deepseek/deepseek-language-model.d.ts +1 -1
  144. package/lib/node/mcp/sumi-mcp-server.d.ts +1 -3
  145. package/lib/node/mcp/sumi-mcp-server.d.ts.map +1 -1
  146. package/lib/node/mcp/sumi-mcp-server.js +1 -7
  147. package/lib/node/mcp/sumi-mcp-server.js.map +1 -1
  148. package/lib/node/mcp-server-manager-impl.d.ts +1 -3
  149. package/lib/node/mcp-server-manager-impl.d.ts.map +1 -1
  150. package/lib/node/mcp-server-manager-impl.js +2 -14
  151. package/lib/node/mcp-server-manager-impl.js.map +1 -1
  152. package/lib/node/mcp-server.sse.d.ts +1 -187
  153. package/lib/node/mcp-server.sse.d.ts.map +1 -1
  154. package/lib/node/mcp-server.sse.js +2 -2
  155. package/lib/node/mcp-server.sse.js.map +1 -1
  156. package/lib/node/mcp-server.stdio.d.ts +1 -187
  157. package/lib/node/mcp-server.stdio.d.ts.map +1 -1
  158. package/package.json +26 -27
  159. package/src/browser/ai-core.contribution.ts +4 -14
  160. package/src/browser/chat/apply.service.ts +1 -62
  161. package/src/browser/chat/chat-manager.service.ts +7 -16
  162. package/src/browser/chat/chat-model.ts +73 -130
  163. package/src/browser/chat/chat-proxy.service.ts +81 -68
  164. package/src/browser/chat/chat.feature.registry.ts +1 -17
  165. package/src/browser/chat/chat.view.tsx +12 -73
  166. package/src/browser/components/ChatEditor.tsx +1 -1
  167. package/src/browser/components/ChatHistory.tsx +1 -2
  168. package/src/browser/components/ChatMentionInput.tsx +35 -180
  169. package/src/browser/components/ChatReply.tsx +4 -4
  170. package/src/browser/components/ChatToolRender.module.less +0 -25
  171. package/src/browser/components/ChatToolRender.tsx +2 -10
  172. package/src/browser/components/components.module.less +8 -37
  173. package/src/browser/components/mention-input/mention-input.module.less +1 -165
  174. package/src/browser/components/mention-input/mention-input.tsx +31 -232
  175. package/src/browser/components/mention-input/types.ts +0 -29
  176. package/src/browser/context/llm-context.service.ts +21 -182
  177. package/src/browser/contrib/intelligent-completions/decoration/additions-deletions.decoration.ts +1 -1
  178. package/src/browser/contrib/intelligent-completions/diff-computer.ts +1 -1
  179. package/src/browser/contrib/terminal/terminal.feature.registry.ts +1 -1
  180. package/src/browser/index.ts +0 -8
  181. package/src/browser/layout/ai-layout.tsx +8 -12
  182. package/src/browser/layout/tabbar.view.tsx +23 -10
  183. package/src/browser/mcp/base-apply.service.ts +10 -30
  184. package/src/browser/mcp/mcp-server-proxy.service.ts +1 -6
  185. package/src/browser/mcp/mcp-server.feature.registry.ts +1 -6
  186. package/src/browser/mcp/tools/createNewFileWithText.ts +46 -17
  187. package/src/browser/mcp/tools/fileSearch.ts +5 -8
  188. package/src/browser/mcp/tools/getDiagnosticsByPath.ts +1 -1
  189. package/src/browser/mcp/tools/getOpenEditorFileDiagnostics.ts +1 -1
  190. package/src/browser/mcp/tools/grepSearch.ts +21 -32
  191. package/src/browser/mcp/tools/handlers/ListDir.ts +2 -2
  192. package/src/browser/mcp/tools/handlers/ReadFile.ts +2 -2
  193. package/src/browser/mcp/tools/handlers/RunCommand.ts +14 -21
  194. package/src/browser/mcp/tools/listDir.ts +12 -15
  195. package/src/browser/mcp/tools/runTerminalCmd.ts +1 -1
  196. package/src/browser/model/msg-history-manager.ts +2 -181
  197. package/src/browser/preferences/schema.ts +0 -5
  198. package/src/browser/types.ts +0 -18
  199. package/src/browser/widget/inline-stream-diff/live-preview.component.tsx +1 -0
  200. package/src/common/index.ts +1 -6
  201. package/src/common/llm-context.ts +0 -23
  202. package/src/common/model.ts +0 -1
  203. package/src/common/prompts/context-prompt-provider.ts +40 -55
  204. package/src/common/types.ts +0 -18
  205. package/src/common/utils.ts +1 -4
  206. package/src/node/base-language-model.ts +14 -11
  207. package/src/node/mcp/sumi-mcp-server.ts +2 -10
  208. package/src/node/mcp-server-manager-impl.ts +2 -17
  209. package/src/node/mcp-server.sse.ts +2 -1
  210. package/lib/browser/components/mention-input/mention-select.d.ts +0 -28
  211. package/lib/browser/components/mention-input/mention-select.d.ts.map +0 -1
  212. package/lib/browser/components/mention-input/mention-select.js +0 -136
  213. package/lib/browser/components/mention-input/mention-select.js.map +0 -1
  214. package/lib/browser/components/mention-input/mention-select.module.less +0 -297
  215. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.d.ts +0 -15
  216. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.d.ts.map +0 -1
  217. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.js +0 -53
  218. package/lib/browser/mcp/tools/handlers/CreateNewFileWithText.js.map +0 -1
  219. package/lib/browser/rules/rules.contribution.d.ts +0 -29
  220. package/lib/browser/rules/rules.contribution.d.ts.map +0 -1
  221. package/lib/browser/rules/rules.contribution.js +0 -94
  222. package/lib/browser/rules/rules.contribution.js.map +0 -1
  223. package/lib/browser/rules/rules.module.less +0 -175
  224. package/lib/browser/rules/rules.service.d.ts +0 -25
  225. package/lib/browser/rules/rules.service.d.ts.map +0 -1
  226. package/lib/browser/rules/rules.service.js +0 -180
  227. package/lib/browser/rules/rules.service.js.map +0 -1
  228. package/lib/browser/rules/rules.view.d.ts +0 -3
  229. package/lib/browser/rules/rules.view.d.ts.map +0 -1
  230. package/lib/browser/rules/rules.view.js +0 -76
  231. package/lib/browser/rules/rules.view.js.map +0 -1
  232. package/lib/common/image-compression.d.ts +0 -25
  233. package/lib/common/image-compression.d.ts.map +0 -1
  234. package/lib/common/image-compression.js +0 -153
  235. package/lib/common/image-compression.js.map +0 -1
  236. package/lib/common/mdc-parser.d.ts +0 -60
  237. package/lib/common/mdc-parser.d.ts.map +0 -1
  238. package/lib/common/mdc-parser.js +0 -246
  239. package/lib/common/mdc-parser.js.map +0 -1
  240. package/lib/common/prompts/system-prompt.d.ts +0 -2
  241. package/lib/common/prompts/system-prompt.d.ts.map +0 -1
  242. package/lib/common/prompts/system-prompt.js +0 -5
  243. package/lib/common/prompts/system-prompt.js.map +0 -1
  244. package/src/browser/components/mention-input/mention-select.module.less +0 -297
  245. package/src/browser/components/mention-input/mention-select.tsx +0 -256
  246. package/src/browser/mcp/tools/handlers/CreateNewFileWithText.ts +0 -49
  247. package/src/browser/rules/rules.contribution.ts +0 -105
  248. package/src/browser/rules/rules.module.less +0 -175
  249. package/src/browser/rules/rules.service.ts +0 -189
  250. package/src/browser/rules/rules.view.tsx +0 -127
  251. package/src/common/image-compression.ts +0 -174
  252. package/src/common/mdc-parser.ts +0 -295
  253. package/src/common/prompts/system-prompt.ts +0 -2
@@ -1,256 +0,0 @@
1
- import cls from 'classnames';
2
- import React, { useEffect, useRef, useState } from 'react';
3
-
4
- import { ClickOutside } from '@opensumi/ide-components/lib/click-outside';
5
- import { Icon, getIcon } from '@opensumi/ide-core-browser/lib/components';
6
-
7
- import styles from './mention-select.module.less';
8
-
9
- export interface ExtendedModelOption {
10
- label: string;
11
- value: string;
12
- icon?: string;
13
- iconClass?: string;
14
- tags?: string[];
15
- features?: string[];
16
- description?: string;
17
- disabled?: boolean;
18
- badge?: string;
19
- badgeColor?: string;
20
- selected?: boolean;
21
- }
22
-
23
- export interface MentionSelectProps {
24
- options: ExtendedModelOption[];
25
- value?: string;
26
- onChange?: (value: string) => void;
27
- placeholder?: string;
28
- disabled?: boolean;
29
- className?: string;
30
- size?: 'small' | 'medium' | 'large';
31
- showThinking?: boolean;
32
- thinkingEnabled?: boolean;
33
- onThinkingChange?: (enabled: boolean) => void;
34
- }
35
-
36
- const ThinkingToggle: React.FC<{
37
- enabled: boolean;
38
- onChange: (enabled: boolean) => void;
39
- }> = ({ enabled, onChange }) => (
40
- <div className={styles.thinking_toggle} onClick={() => onChange(!enabled)}>
41
- <Icon
42
- iconClass={getIcon(enabled ? 'check' : 'circle-outline')}
43
- className={cls(styles.thinking_icon, {
44
- [styles.enabled]: enabled,
45
- })}
46
- />
47
- <span className={styles.thinking_label}>Thinking</span>
48
- </div>
49
- );
50
-
51
- export const MentionSelect: React.FC<MentionSelectProps> = ({
52
- options,
53
- value,
54
- onChange,
55
- placeholder,
56
- disabled = false,
57
- className,
58
- size = 'small',
59
- showThinking = false,
60
- thinkingEnabled = false,
61
- onThinkingChange,
62
- }) => {
63
- const [isOpen, setIsOpen] = useState(false);
64
- const [activeIndex, setActiveIndex] = useState(-1);
65
- const [dropdownDirection, setDropdownDirection] = useState<'up' | 'down'>('up');
66
- const selectRef = useRef<HTMLDivElement>(null);
67
- const dropdownRef = useRef<HTMLDivElement>(null);
68
-
69
- const selectedOption = options.find((option) => option.selected) || options.find((option) => option.value === value);
70
-
71
- const handleToggle = () => {
72
- if (!disabled) {
73
- setIsOpen(!isOpen);
74
- setActiveIndex(-1);
75
- }
76
- };
77
-
78
- const handleSelect = (option: ExtendedModelOption) => {
79
- if (!option.disabled) {
80
- onChange?.(option.value);
81
- setIsOpen(false);
82
- setActiveIndex(-1);
83
- }
84
- };
85
-
86
- const handleKeyDown = (e: React.KeyboardEvent) => {
87
- if (disabled) {
88
- return;
89
- }
90
-
91
- switch (e.key) {
92
- case 'Enter':
93
- case ' ':
94
- e.preventDefault();
95
- if (!isOpen) {
96
- setIsOpen(true);
97
- } else if (activeIndex >= 0) {
98
- handleSelect(options[activeIndex]);
99
- }
100
- break;
101
- case 'Escape':
102
- e.preventDefault();
103
- setIsOpen(false);
104
- setActiveIndex(-1);
105
- break;
106
- case 'ArrowDown':
107
- e.preventDefault();
108
- if (!isOpen) {
109
- setIsOpen(true);
110
- } else {
111
- setActiveIndex((prev) => (prev < options.length - 1 ? prev + 1 : 0));
112
- }
113
- break;
114
- case 'ArrowUp':
115
- e.preventDefault();
116
- if (isOpen) {
117
- setActiveIndex((prev) => (prev > 0 ? prev - 1 : options.length - 1));
118
- }
119
- break;
120
- }
121
- };
122
-
123
- const handleClickOutside = () => {
124
- setIsOpen(false);
125
- setActiveIndex(-1);
126
- };
127
-
128
- useEffect(() => {
129
- if (isOpen && selectRef.current) {
130
- const selectRect = selectRef.current.getBoundingClientRect();
131
- const viewportHeight = window.innerHeight;
132
- const dropdownHeight = Math.min(400, options.length * 60);
133
-
134
- const spaceAbove = selectRect.top;
135
- const spaceBelow = viewportHeight - selectRect.bottom;
136
-
137
- if (spaceAbove < dropdownHeight && spaceBelow > spaceAbove) {
138
- setDropdownDirection('down');
139
- } else {
140
- setDropdownDirection('up');
141
- }
142
- }
143
- }, [isOpen, options.length]);
144
-
145
- useEffect(() => {
146
- if (isOpen && activeIndex >= 0 && dropdownRef.current) {
147
- const activeElement = dropdownRef.current.children[activeIndex] as HTMLElement;
148
- if (activeElement) {
149
- activeElement.scrollIntoView({
150
- behavior: 'smooth',
151
- block: 'nearest',
152
- });
153
- }
154
- }
155
- }, [isOpen, activeIndex]);
156
-
157
- return (
158
- <ClickOutside onOutsideClick={handleClickOutside}>
159
- <div
160
- ref={selectRef}
161
- className={cls(
162
- styles.mention_select,
163
- styles[`size_${size}`],
164
- {
165
- [styles.disabled]: disabled,
166
- [styles.open]: isOpen,
167
- [styles.dropdown_up]: dropdownDirection === 'up',
168
- [styles.dropdown_down]: dropdownDirection === 'down',
169
- },
170
- className,
171
- )}
172
- onClick={handleToggle}
173
- onKeyDown={handleKeyDown}
174
- tabIndex={disabled ? -1 : 0}
175
- role='combobox'
176
- aria-expanded={isOpen}
177
- aria-haspopup='listbox'
178
- >
179
- <div className={styles.select_trigger}>
180
- <div className={styles.select_content}>
181
- {selectedOption ? (
182
- <div className={styles.selected_option}>
183
- <span className={styles.option_label}>{selectedOption.label}</span>
184
- {selectedOption.badge && (
185
- <span className={styles.option_badge} style={{ backgroundColor: selectedOption.badgeColor }}>
186
- {selectedOption.badge}
187
- </span>
188
- )}
189
- </div>
190
- ) : (
191
- <span className={styles.placeholder}>{placeholder}</span>
192
- )}
193
- </div>
194
- <Icon
195
- iconClass={getIcon('down-arrow')}
196
- className={cls(styles.dropdown_arrow, {
197
- [styles.open]: isOpen,
198
- })}
199
- />
200
- </div>
201
-
202
- {isOpen && (
203
- <div ref={dropdownRef} className={styles.dropdown} role='listbox'>
204
- {showThinking && onThinkingChange && (
205
- <div className={styles.thinking_section}>
206
- <ThinkingToggle enabled={thinkingEnabled} onChange={onThinkingChange} />
207
- <div className={styles.divider} />
208
- </div>
209
- )}
210
-
211
- {options.map((option, index) => (
212
- <div
213
- key={option.value}
214
- className={cls(styles.option, {
215
- [styles.active]: index === activeIndex,
216
- [styles.selected]: option.selected || option.value === value,
217
- [styles.disabled]: option.disabled,
218
- })}
219
- onClick={() => handleSelect(option)}
220
- role='option'
221
- aria-selected={option.selected || option.value === value}
222
- >
223
- <div className={styles.option_main}>
224
- <div className={styles.option_header}>
225
- <div className={styles.option_title}>
226
- {option.icon && <Icon icon={option.icon} className={styles.option_icon} />}
227
- {option.iconClass && <Icon iconClass={option.iconClass} className={styles.option_icon} />}
228
- <span className={styles.option_label}>{option.label}</span>
229
- {option.badge && (
230
- <span className={styles.option_badge} style={{ backgroundColor: option.badgeColor }}>
231
- {option.badge}
232
- </span>
233
- )}
234
- </div>
235
- </div>
236
-
237
- {option.description && <div className={styles.option_description}>{option.description}</div>}
238
-
239
- {option.tags && option.tags.length > 0 && (
240
- <div className={styles.option_tags}>
241
- {option.tags.map((tag, idx) => (
242
- <span key={idx} className={styles.tag}>
243
- {tag}
244
- </span>
245
- ))}
246
- </div>
247
- )}
248
- </div>
249
- </div>
250
- ))}
251
- </div>
252
- )}
253
- </div>
254
- </ClickOutside>
255
- );
256
- };
@@ -1,49 +0,0 @@
1
- import { Autowired, Injectable } from '@opensumi/di';
2
- import { URI, path } from '@opensumi/ide-core-common';
3
- import { IFileServiceClient } from '@opensumi/ide-file-service';
4
- import { IWorkspaceService } from '@opensumi/ide-workspace';
5
-
6
- import { CodeBlockData } from '../../../../common/types';
7
- import { BaseApplyService } from '../../base-apply.service';
8
-
9
- /**
10
- * 创建新文件处理器
11
- * 用于处理创建新文件并写入内容的操作
12
- */
13
- @Injectable()
14
- export class CreateNewFileWithTextHandler {
15
- @Autowired(IWorkspaceService)
16
- private readonly workspaceService: IWorkspaceService;
17
-
18
- @Autowired(IFileServiceClient)
19
- private readonly fileService: IFileServiceClient;
20
-
21
- @Autowired(BaseApplyService)
22
- private applyService: BaseApplyService;
23
-
24
- async handler(params: { targetFile: string; codeEdit: string }, toolCallId: string): Promise<CodeBlockData> {
25
- // 获取工作区根目录
26
- const workspaceRoots = this.workspaceService.tryGetRoots();
27
- if (!workspaceRoots || workspaceRoots.length === 0) {
28
- throw new Error("can't find project dir");
29
- }
30
-
31
- // 构建完整的文件路径
32
- const rootUri = URI.parse(workspaceRoots[0].uri);
33
- const fullPath = path.join(rootUri.codeUri.fsPath, params.targetFile);
34
- const fileUri = URI.file(fullPath);
35
-
36
- // 创建父目录
37
- const parentDir = path.dirname(fullPath);
38
- const parentUri = URI.file(parentDir);
39
- await this.fileService.createFolder(parentUri.toString());
40
-
41
- // 创建文件
42
- await this.fileService.createFile(fileUri.toString());
43
-
44
- // 使用 applyService 写入文件内容
45
- const codeBlock = await this.applyService.registerCodeBlock(params.targetFile, params.codeEdit, toolCallId);
46
- await this.applyService.apply(codeBlock);
47
- return codeBlock;
48
- }
49
- }
@@ -1,105 +0,0 @@
1
- import { Autowired } from '@opensumi/di';
2
- import { getIcon } from '@opensumi/ide-components';
3
- import { ClientAppContribution } from '@opensumi/ide-core-browser';
4
- import { LabelService } from '@opensumi/ide-core-browser/lib/services';
5
- import {
6
- CommandContribution,
7
- CommandRegistry,
8
- Domain,
9
- RulesServiceToken,
10
- URI,
11
- localize,
12
- } from '@opensumi/ide-core-common';
13
- import {
14
- BrowserEditorContribution,
15
- EditorComponentRegistry,
16
- EditorComponentRenderMode,
17
- IResource,
18
- ResourceService,
19
- WorkbenchEditorService,
20
- } from '@opensumi/ide-editor/lib/browser/types';
21
- import { IconService } from '@opensumi/ide-theme/lib/browser';
22
- import { IWorkspaceService } from '@opensumi/ide-workspace/lib/common';
23
-
24
- import { RulesService } from './rules.service';
25
- import { RulesView } from './rules.view';
26
-
27
- export namespace RulesCommands {
28
- export const OPEN_RULES_FILE = {
29
- id: 'rules.openRulesConfig',
30
- label: 'Open Rules Configuration',
31
- };
32
- }
33
-
34
- const COMPONENTS_ID = 'opensumi-rules-viewer';
35
- export const RULES_COMPONENTS_SCHEME_ID = 'rules';
36
-
37
- export type IRulesResource = IResource<{ configType: string }>;
38
-
39
- @Domain(BrowserEditorContribution, CommandContribution, ClientAppContribution)
40
- export class RulesContribution implements BrowserEditorContribution, CommandContribution, ClientAppContribution {
41
- @Autowired(IWorkspaceService)
42
- protected readonly workspaceService: IWorkspaceService;
43
-
44
- @Autowired(IconService)
45
- protected readonly iconService: IconService;
46
-
47
- @Autowired(WorkbenchEditorService)
48
- protected readonly editorService: WorkbenchEditorService;
49
-
50
- @Autowired()
51
- labelService: LabelService;
52
-
53
- @Autowired(RulesServiceToken)
54
- protected readonly rulesService: RulesService;
55
-
56
- onStart() {
57
- this.rulesService.initProjectRules();
58
- }
59
-
60
- registerEditorComponent(registry: EditorComponentRegistry) {
61
- registry.registerEditorComponent({
62
- uid: COMPONENTS_ID,
63
- scheme: RULES_COMPONENTS_SCHEME_ID,
64
- component: RulesView,
65
- renderMode: EditorComponentRenderMode.ONE_PER_WORKBENCH,
66
- });
67
-
68
- registry.registerEditorComponentResolver(RULES_COMPONENTS_SCHEME_ID, (resource, results) => {
69
- results.push({
70
- type: 'component',
71
- componentId: COMPONENTS_ID,
72
- });
73
- });
74
- }
75
-
76
- registerResource(service: ResourceService) {
77
- service.registerResourceProvider({
78
- scheme: RULES_COMPONENTS_SCHEME_ID,
79
- provideResource: async (uri: URI): Promise<IRulesResource> => {
80
- const { configType } = uri.getParsedQuery();
81
-
82
- return {
83
- uri,
84
- name: localize('ai.native.rules.title'),
85
- icon: getIcon('rules'),
86
- metadata: {
87
- configType,
88
- },
89
- };
90
- },
91
- });
92
- }
93
-
94
- registerCommands(registry: CommandRegistry) {
95
- registry.registerCommand(RulesCommands.OPEN_RULES_FILE, {
96
- execute: () => {
97
- const uri = new URI().withScheme(RULES_COMPONENTS_SCHEME_ID);
98
- this.editorService.open(uri, {
99
- preview: false,
100
- focus: true,
101
- });
102
- },
103
- });
104
- }
105
- }
@@ -1,175 +0,0 @@
1
- .container {
2
- padding: 20px;
3
- color: var(--foreground);
4
- textarea {
5
- resize: vertical;
6
- min-height: 60px;
7
- }
8
- input,
9
- textarea {
10
- width: 100%;
11
- padding: 8px;
12
- border: 1px solid var(--input-border);
13
- border-radius: 4px;
14
- background-color: var(--input-background);
15
- color: var(--input-foreground);
16
- font-size: 13px;
17
- font-family: var(--monaco-monospace-font);
18
-
19
- &:focus {
20
- border-color: var(--focusBorder);
21
- outline: none;
22
- }
23
-
24
- &::placeholder {
25
- color: var(--descriptionForeground);
26
- opacity: 0.6;
27
- }
28
- }
29
- }
30
-
31
- .header {
32
- display: flex;
33
- justify-content: space-between;
34
- align-items: flex-start;
35
- margin-bottom: 24px;
36
- }
37
-
38
- .title {
39
- margin: 0 0 8px 0;
40
- font-size: 24px;
41
- font-weight: 600;
42
- }
43
-
44
- .description {
45
- margin: 0;
46
- color: var(--descriptionForeground);
47
- font-size: 14px;
48
- line-height: 1.5;
49
- }
50
-
51
- .user_rules {
52
- display: flex;
53
- flex-direction: column;
54
- gap: 16px;
55
- .user_rules_header {
56
- display: flex;
57
- flex-direction: column;
58
- }
59
- }
60
-
61
- .project_rules {
62
- margin-top: 20px;
63
- display: flex;
64
- flex-direction: column;
65
- gap: 16px;
66
- h3 {
67
- position: relative;
68
- }
69
- .actionButton {
70
- position: absolute;
71
- right: 0;
72
- top: 0;
73
- }
74
- }
75
-
76
- .project_rules_header {
77
- display: flex;
78
- justify-content: space-between;
79
- align-items: flex-start;
80
- }
81
-
82
- .project_rules_header_left {
83
- width: 100%;
84
- display: flex;
85
- flex-direction: column;
86
- }
87
-
88
- .actionButton {
89
- padding: 8px 16px;
90
- border-radius: 4px;
91
- background-color: var(--button-primary-background);
92
- color: var(--button-primary-foreground);
93
- border: none;
94
- cursor: pointer;
95
- font-size: 13px;
96
- .actionButtonIcon {
97
- margin-right: 5px;
98
- }
99
-
100
- &:hover {
101
- background-color: var(--button-primary-hover-background);
102
- }
103
- }
104
-
105
- .project_rules_list {
106
- display: flex;
107
- flex-direction: column;
108
- gap: 8px;
109
- }
110
-
111
- .rule_item {
112
- display: flex;
113
- justify-content: space-between;
114
- align-items: center;
115
- padding: 12px;
116
- border: 1px solid var(--input-border);
117
- border-radius: 4px;
118
- background-color: var(--input-background);
119
- opacity: 0.6;
120
-
121
- &:hover {
122
- opacity: 1;
123
- }
124
- }
125
-
126
- .rule_item_left {
127
- display: flex;
128
- flex-direction: column;
129
- gap: 4px;
130
- flex: 1;
131
- }
132
-
133
- .rule_item_right {
134
- display: flex;
135
- align-items: center;
136
- flex-shrink: 0;
137
- margin-left: 16px;
138
- }
139
-
140
- .rule_filename {
141
- font-size: 13px;
142
- font-weight: 500;
143
- color: var(--foreground);
144
- }
145
-
146
- .rule_description {
147
- font-size: 12px;
148
- color: var(--descriptionForeground);
149
- }
150
-
151
- .rule_warning {
152
- font-size: 12px;
153
- color: var(--editorWarning-foreground);
154
- display: flex;
155
- align-items: center;
156
- gap: 4px;
157
-
158
- &::before {
159
- content: '⚠';
160
- color: var(--editorWarning-foreground);
161
- }
162
- }
163
-
164
- .rule_applies_to {
165
- font-size: 12px;
166
- color: var(--descriptionForeground);
167
- font-family: var(--monaco-monospace-font);
168
- }
169
-
170
- .empty_state {
171
- text-align: center;
172
- padding: 32px;
173
- color: var(--descriptionForeground);
174
- font-style: italic;
175
- }