@opensumi/ide-ai-native 2.26.9-next-1695201123.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 (194) hide show
  1. package/LICENSE +21 -0
  2. package/lib/browser/ai-chat.contribution.d.ts +26 -0
  3. package/lib/browser/ai-chat.contribution.d.ts.map +1 -0
  4. package/lib/browser/ai-chat.contribution.js +228 -0
  5. package/lib/browser/ai-chat.contribution.js.map +1 -0
  6. package/lib/browser/ai-chat.module.less +174 -0
  7. package/lib/browser/ai-chat.service.d.ts +30 -0
  8. package/lib/browser/ai-chat.service.d.ts.map +1 -0
  9. package/lib/browser/ai-chat.service.js +129 -0
  10. package/lib/browser/ai-chat.service.js.map +1 -0
  11. package/lib/browser/ai-chat.view.d.ts +4 -0
  12. package/lib/browser/ai-chat.view.d.ts.map +1 -0
  13. package/lib/browser/ai-chat.view.js +292 -0
  14. package/lib/browser/ai-chat.view.js.map +1 -0
  15. package/lib/browser/ai-editor.contribution.d.ts +26 -0
  16. package/lib/browser/ai-editor.contribution.d.ts.map +1 -0
  17. package/lib/browser/ai-editor.contribution.js +430 -0
  18. package/lib/browser/ai-editor.contribution.js.map +1 -0
  19. package/lib/browser/ai-project/generate.service.d.ts +34 -0
  20. package/lib/browser/ai-project/generate.service.d.ts.map +1 -0
  21. package/lib/browser/ai-project/generate.service.js +460 -0
  22. package/lib/browser/ai-project/generate.service.js.map +1 -0
  23. package/lib/browser/ai-sumi/sumi.service.d.ts +11 -0
  24. package/lib/browser/ai-sumi/sumi.service.d.ts.map +1 -0
  25. package/lib/browser/ai-sumi/sumi.service.js +64 -0
  26. package/lib/browser/ai-sumi/sumi.service.js.map +1 -0
  27. package/lib/browser/code-widget/ai-code-document.provider.d.ts +10 -0
  28. package/lib/browser/code-widget/ai-code-document.provider.d.ts.map +1 -0
  29. package/lib/browser/code-widget/ai-code-document.provider.js +26 -0
  30. package/lib/browser/code-widget/ai-code-document.provider.js.map +1 -0
  31. package/lib/browser/code-widget/ai-code-widget.d.ts +20 -0
  32. package/lib/browser/code-widget/ai-code-widget.d.ts.map +1 -0
  33. package/lib/browser/code-widget/ai-code-widget.js +164 -0
  34. package/lib/browser/code-widget/ai-code-widget.js.map +1 -0
  35. package/lib/browser/components/AIImprove.d.ts +9 -0
  36. package/lib/browser/components/AIImprove.d.ts.map +1 -0
  37. package/lib/browser/components/AIImprove.js +34 -0
  38. package/lib/browser/components/AIImprove.js.map +1 -0
  39. package/lib/browser/components/AIInput.d.ts +5 -0
  40. package/lib/browser/components/AIInput.d.ts.map +1 -0
  41. package/lib/browser/components/AIInput.js +22 -0
  42. package/lib/browser/components/AIInput.js.map +1 -0
  43. package/lib/browser/components/ChatEditor.d.ts +5 -0
  44. package/lib/browser/components/ChatEditor.d.ts.map +1 -0
  45. package/lib/browser/components/ChatEditor.js +85 -0
  46. package/lib/browser/components/ChatEditor.js.map +1 -0
  47. package/lib/browser/components/ChatInput.d.ts +6 -0
  48. package/lib/browser/components/ChatInput.d.ts.map +1 -0
  49. package/lib/browser/components/ChatInput.js +126 -0
  50. package/lib/browser/components/ChatInput.js.map +1 -0
  51. package/lib/browser/components/ChatMoreActions.d.ts +5 -0
  52. package/lib/browser/components/ChatMoreActions.d.ts.map +1 -0
  53. package/lib/browser/components/ChatMoreActions.js +26 -0
  54. package/lib/browser/components/ChatMoreActions.js.map +1 -0
  55. package/lib/browser/components/Thinking.d.ts +3 -0
  56. package/lib/browser/components/Thinking.d.ts.map +1 -0
  57. package/lib/browser/components/Thinking.js +19 -0
  58. package/lib/browser/components/Thinking.js.map +1 -0
  59. package/lib/browser/components/components.module.less +261 -0
  60. package/lib/browser/components/lineVertical.d.ts +4 -0
  61. package/lib/browser/components/lineVertical.d.ts.map +1 -0
  62. package/lib/browser/components/lineVertical.js +22 -0
  63. package/lib/browser/components/lineVertical.js.map +1 -0
  64. package/lib/browser/content-widget/ai-content-widget.d.ts +38 -0
  65. package/lib/browser/content-widget/ai-content-widget.d.ts.map +1 -0
  66. package/lib/browser/content-widget/ai-content-widget.js +97 -0
  67. package/lib/browser/content-widget/ai-content-widget.js.map +1 -0
  68. package/lib/browser/content-widget/ai-inline-chat-panel.d.ts +6 -0
  69. package/lib/browser/content-widget/ai-inline-chat-panel.d.ts.map +1 -0
  70. package/lib/browser/content-widget/ai-inline-chat-panel.js +108 -0
  71. package/lib/browser/content-widget/ai-inline-chat-panel.js.map +1 -0
  72. package/lib/browser/content-widget/ai-inline-chat.module.less +81 -0
  73. package/lib/browser/content-widget/ai-inline-chat.service.d.ts +23 -0
  74. package/lib/browser/content-widget/ai-inline-chat.service.d.ts.map +1 -0
  75. package/lib/browser/content-widget/ai-inline-chat.service.js +47 -0
  76. package/lib/browser/content-widget/ai-inline-chat.service.js.map +1 -0
  77. package/lib/browser/diff-widget/ai-diff-document.provider.d.ts +10 -0
  78. package/lib/browser/diff-widget/ai-diff-document.provider.d.ts.map +1 -0
  79. package/lib/browser/diff-widget/ai-diff-document.provider.js +26 -0
  80. package/lib/browser/diff-widget/ai-diff-document.provider.js.map +1 -0
  81. package/lib/browser/diff-widget/ai-diff-widget.d.ts +20 -0
  82. package/lib/browser/diff-widget/ai-diff-widget.d.ts.map +1 -0
  83. package/lib/browser/diff-widget/ai-diff-widget.js +158 -0
  84. package/lib/browser/diff-widget/ai-diff-widget.js.map +1 -0
  85. package/lib/browser/index.d.ts +11 -0
  86. package/lib/browser/index.d.ts.map +1 -0
  87. package/lib/browser/index.js +82 -0
  88. package/lib/browser/index.js.map +1 -0
  89. package/lib/browser/inline-completions/constants.d.ts +62 -0
  90. package/lib/browser/inline-completions/constants.d.ts.map +1 -0
  91. package/lib/browser/inline-completions/constants.js +69 -0
  92. package/lib/browser/inline-completions/constants.js.map +1 -0
  93. package/lib/browser/inline-completions/provider.d.ts +27 -0
  94. package/lib/browser/inline-completions/provider.d.ts.map +1 -0
  95. package/lib/browser/inline-completions/provider.js +63 -0
  96. package/lib/browser/inline-completions/provider.js.map +1 -0
  97. package/lib/browser/override/ai-editor-tab.service.d.ts +6 -0
  98. package/lib/browser/override/ai-editor-tab.service.d.ts.map +1 -0
  99. package/lib/browser/override/ai-editor-tab.service.js +22 -0
  100. package/lib/browser/override/ai-editor-tab.service.js.map +1 -0
  101. package/lib/browser/override/ai-marker.service.d.ts +11 -0
  102. package/lib/browser/override/ai-marker.service.d.ts.map +1 -0
  103. package/lib/browser/override/ai-marker.service.js +56 -0
  104. package/lib/browser/override/ai-marker.service.js.map +1 -0
  105. package/lib/browser/override/layout/layout-config.d.ts +11 -0
  106. package/lib/browser/override/layout/layout-config.d.ts.map +1 -0
  107. package/lib/browser/override/layout/layout-config.js +17 -0
  108. package/lib/browser/override/layout/layout-config.js.map +1 -0
  109. package/lib/browser/override/layout/layout.module.less +261 -0
  110. package/lib/browser/override/layout/main-slot-renderer.d.ts +4 -0
  111. package/lib/browser/override/layout/main-slot-renderer.d.ts.map +1 -0
  112. package/lib/browser/override/layout/main-slot-renderer.js +23 -0
  113. package/lib/browser/override/layout/main-slot-renderer.js.map +1 -0
  114. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.d.ts +8 -0
  115. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.d.ts.map +1 -0
  116. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.js +32 -0
  117. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.js.map +1 -0
  118. package/lib/browser/override/layout/menu-bar/menu-bar.module.less +41 -0
  119. package/lib/browser/override/layout/menu-bar/menu-bar.view.d.ts +3 -0
  120. package/lib/browser/override/layout/menu-bar/menu-bar.view.d.ts.map +1 -0
  121. package/lib/browser/override/layout/menu-bar/menu-bar.view.js +62 -0
  122. package/lib/browser/override/layout/menu-bar/menu-bar.view.js.map +1 -0
  123. package/lib/browser/override/layout/tabbar.view.d.ts +19 -0
  124. package/lib/browser/override/layout/tabbar.view.d.ts.map +1 -0
  125. package/lib/browser/override/layout/tabbar.view.js +38 -0
  126. package/lib/browser/override/layout/tabbar.view.js.map +1 -0
  127. package/lib/browser/override/override.module.less +32 -0
  128. package/lib/browser/override/theme/default-theme.d.ts +315 -0
  129. package/lib/browser/override/theme/default-theme.d.ts.map +1 -0
  130. package/lib/browser/override/theme/default-theme.js +821 -0
  131. package/lib/browser/override/theme/default-theme.js.map +1 -0
  132. package/lib/browser/run/run.service.d.ts +52 -0
  133. package/lib/browser/run/run.service.d.ts.map +1 -0
  134. package/lib/browser/run/run.service.js +176 -0
  135. package/lib/browser/run/run.service.js.map +1 -0
  136. package/lib/common/command.d.ts +17 -0
  137. package/lib/common/command.d.ts.map +1 -0
  138. package/lib/common/command.js +21 -0
  139. package/lib/common/command.js.map +1 -0
  140. package/lib/common/index.d.ts +47 -0
  141. package/lib/common/index.d.ts.map +1 -0
  142. package/lib/common/index.js +33 -0
  143. package/lib/common/index.js.map +1 -0
  144. package/lib/index.d.ts +2 -0
  145. package/lib/index.d.ts.map +1 -0
  146. package/lib/index.js +5 -0
  147. package/lib/index.js.map +1 -0
  148. package/lib/node/index.d.ts +10 -0
  149. package/lib/node/index.d.ts.map +1 -0
  150. package/lib/node/index.js +32 -0
  151. package/lib/node/index.js.map +1 -0
  152. package/package.json +38 -0
  153. package/src/browser/ai-chat.contribution.ts +300 -0
  154. package/src/browser/ai-chat.module.less +174 -0
  155. package/src/browser/ai-chat.service.ts +146 -0
  156. package/src/browser/ai-chat.view.tsx +410 -0
  157. package/src/browser/ai-editor.contribution.ts +564 -0
  158. package/src/browser/ai-project/generate.service.ts +515 -0
  159. package/src/browser/ai-sumi/sumi.service.ts +65 -0
  160. package/src/browser/code-widget/ai-code-document.provider.ts +22 -0
  161. package/src/browser/code-widget/ai-code-widget.tsx +202 -0
  162. package/src/browser/components/AIImprove.tsx +45 -0
  163. package/src/browser/components/AIInput.tsx +30 -0
  164. package/src/browser/components/ChatEditor.tsx +129 -0
  165. package/src/browser/components/ChatInput.tsx +199 -0
  166. package/src/browser/components/ChatMoreActions.tsx +33 -0
  167. package/src/browser/components/Thinking.tsx +23 -0
  168. package/src/browser/components/components.module.less +261 -0
  169. package/src/browser/components/lineVertical.tsx +19 -0
  170. package/src/browser/content-widget/ai-content-widget.tsx +132 -0
  171. package/src/browser/content-widget/ai-inline-chat-panel.tsx +163 -0
  172. package/src/browser/content-widget/ai-inline-chat.module.less +81 -0
  173. package/src/browser/content-widget/ai-inline-chat.service.ts +46 -0
  174. package/src/browser/diff-widget/ai-diff-document.provider.ts +22 -0
  175. package/src/browser/diff-widget/ai-diff-widget.tsx +196 -0
  176. package/src/browser/index.ts +89 -0
  177. package/src/browser/inline-completions/constants.ts +108 -0
  178. package/src/browser/inline-completions/provider.ts +55 -0
  179. package/src/browser/override/ai-editor-tab.service.tsx +22 -0
  180. package/src/browser/override/ai-marker.service.tsx +61 -0
  181. package/src/browser/override/layout/layout-config.ts +17 -0
  182. package/src/browser/override/layout/layout.module.less +261 -0
  183. package/src/browser/override/layout/main-slot-renderer.tsx +63 -0
  184. package/src/browser/override/layout/menu-bar/menu-bar.contribution.tsx +28 -0
  185. package/src/browser/override/layout/menu-bar/menu-bar.module.less +41 -0
  186. package/src/browser/override/layout/menu-bar/menu-bar.view.tsx +92 -0
  187. package/src/browser/override/layout/tabbar.view.tsx +91 -0
  188. package/src/browser/override/override.module.less +32 -0
  189. package/src/browser/override/theme/default-theme.ts +818 -0
  190. package/src/browser/run/run.service.ts +186 -0
  191. package/src/common/command.ts +21 -0
  192. package/src/common/index.ts +50 -0
  193. package/src/index.ts +1 -0
  194. package/src/node/index.ts +24 -0
@@ -0,0 +1,261 @@
1
+ :global {
2
+ div[class*='box-panel___'] {
3
+ background-image: url('https://mdn.alipayobjects.com/huamei_htww6h/afts/img/A*hLI-SqEx-YkAAAAAAAAAAAAADhl8AQ/original');
4
+ background-repeat: no-repeat;
5
+ background-size: cover;
6
+ }
7
+ }
8
+
9
+ .ai_native_panel_container {
10
+ margin-right: 16px;
11
+ width: initial;
12
+
13
+ .ai_native_slot_resize_horizontal {
14
+ height: 100%;
15
+ margin: 0 3px;
16
+ position: relative;
17
+
18
+ &::after {
19
+ content: '';
20
+ position: absolute;
21
+ height: 25px;
22
+ width: 2px;
23
+ background-color: #31363b;
24
+ border-radius: 1px;
25
+ top: 50%;
26
+ left: 50%;
27
+ }
28
+ }
29
+
30
+ .ai_native_slot_main {
31
+ height: 100%;
32
+ width: 100%;
33
+ background-color: #151b21;
34
+ border: 1px solid rgba(255, 255, 255, 0.12);
35
+ border-radius: 12px;
36
+ overflow: hidden;
37
+
38
+ /**
39
+ * ---------------- 覆盖 editor tab 样式 ---------------------
40
+ */
41
+ div[class*='kt_editor_group___'] div[class*='kt_editor_tabs_content___'] {
42
+ div[class*='kt_editor_tab___'] {
43
+ border-right: none;
44
+ border-top: none;
45
+ }
46
+
47
+ div[class*='kt_editor_tab_current___'] {
48
+ background-color: transparent !important;
49
+ }
50
+ }
51
+
52
+ /**
53
+ * ---------------- 覆盖 editor navigation 导航条样式 ---------------------
54
+ */
55
+ div[class*='navigation_container___'] {
56
+ height: 28px;
57
+ margin-bottom: 10px;
58
+ }
59
+ }
60
+ }
61
+
62
+ .ai_left_slot {
63
+ div[class*='tab_panel___'] {
64
+ border-right: none;
65
+ }
66
+
67
+ div[class*='file_tree_node___'] {
68
+ border-radius: 4px;
69
+ }
70
+
71
+ div[class*='icon_tab___'] {
72
+ height: 32px;
73
+ width: 32px;
74
+ border-radius: 8px;
75
+
76
+ :global {
77
+ .activity-icon {
78
+ font-size: 16px;
79
+ width: initial;
80
+ height: initial;
81
+ color: var(--activityBar-inactiveForeground);
82
+
83
+ &.mask-mode {
84
+ background-color: var(--activityBar-inactiveForeground);
85
+ -webkit-mask-size: 16px;
86
+ }
87
+ }
88
+ }
89
+ }
90
+
91
+ div[class*='tab_panel___'] {
92
+ &::before {
93
+ content: none;
94
+ }
95
+ }
96
+
97
+ div[class*='tab_panel_hidden___'] {
98
+ display: none;
99
+ }
100
+
101
+ li[class*='left_tab___'] {
102
+ width: 100%;
103
+ display: flex;
104
+ justify-content: center;
105
+ }
106
+
107
+ div[class*='left_tab_bar___'] {
108
+ border-right: none;
109
+ border-top: none;
110
+
111
+ div[class*='bar_content___'] {
112
+ width: 100%;
113
+ overflow-y: auto;
114
+
115
+ :global {
116
+ .active {
117
+ div[class*='icon_tab___'] {
118
+ background-color: var(--activityBar-activeBorder);
119
+
120
+ &::before {
121
+ content: none;
122
+ }
123
+ }
124
+ }
125
+ }
126
+
127
+ &::-webkit-scrollbar {
128
+ display: none !important;
129
+ }
130
+ }
131
+ }
132
+ }
133
+
134
+ .ai_bottom_slot {
135
+ /**
136
+ * ---------------- 覆盖编辑器面板底部 tabbar 样式 ---------------------
137
+ */
138
+ div[class*='tab_bar___'] {
139
+ height: 100%;
140
+ }
141
+
142
+ li[class*='bottom_tab___'] {
143
+ height: 100%;
144
+ line-height: 32px;
145
+ }
146
+
147
+ div[class*='bottom_bar_container___'] {
148
+ width: 100%;
149
+ height: 32px;
150
+ min-height: 32px;
151
+ }
152
+ }
153
+
154
+ /**
155
+ * -------------------------------------------- 右侧 chat 面板样式 --------------------------------------------
156
+ */
157
+ #ai_chat_panel {
158
+ height: 100%;
159
+
160
+ :global {
161
+ .rce-mbox-left-notch,
162
+ .rce-mbox-right-notch {
163
+ display: none;
164
+ }
165
+
166
+ .rce-mbox {
167
+ background-color: #ffffff0a;
168
+ border-radius: 2px 12px 12px 12px;
169
+ box-shadow: none;
170
+ padding: 8px 12px;
171
+ min-width: initial;
172
+ margin: 0;
173
+
174
+ ::after {
175
+ content: '';
176
+ }
177
+ }
178
+
179
+ .rce-mbox-text {
180
+ font-size: 12px;
181
+ line-height: 18px;
182
+ width: inherit;
183
+ }
184
+
185
+ .rce-smsg {
186
+ background-color: #ffffff0a;
187
+ box-shadow: none;
188
+ border-radius: 8px;
189
+ max-width: initial;
190
+ border-radius: 2px 12px 12px 12px;
191
+ width: 100%;
192
+ flex-direction: initial;
193
+ justify-content: left;
194
+ padding: 8px 12px 12px;
195
+ margin: 0;
196
+
197
+ .rce-smsg-text {
198
+ font-size: 12px;
199
+ width: 100%;
200
+ text-align: left;
201
+ }
202
+ }
203
+
204
+ .rce-container-smsg {
205
+ width: 100%;
206
+ }
207
+
208
+ .rce-mlist {
209
+ color: #ffffff;
210
+ font-size: 12px;
211
+ font-weight: 300;
212
+ }
213
+
214
+ .rce-ai-msg {
215
+ > .rce-mbox {
216
+ margin-bottom: 28px;
217
+ width: 100%;
218
+ }
219
+
220
+ .rce-mbox-body {
221
+ display: flex;
222
+ align-items: flex-start;
223
+ position: initial;
224
+ width: 100%;
225
+
226
+ .rce-mbox-title {
227
+ position: absolute;
228
+ left: -40px;
229
+ top: 0;
230
+ }
231
+
232
+ .rce-avatar-container {
233
+ &.default {
234
+ height: 32px;
235
+ width: 32px;
236
+ }
237
+ }
238
+ }
239
+ }
240
+
241
+ .rce-container-mbox {
242
+ overflow: hidden;
243
+ margin: 0 16px 16px 16px;
244
+ min-width: initial;
245
+ }
246
+
247
+ .rce-user-msg {
248
+ .rce-mbox-right {
249
+ border-radius: 12px 12px 2px 12px;
250
+ background-color: #3c8dff4d;
251
+ margin-right: 0;
252
+ margin-left: 0;
253
+ }
254
+ }
255
+
256
+ blockquote {
257
+ background: var(--vscode-textBlockQuote-background);
258
+ border-color: var(--vscode-textBlockQuote-border);
259
+ }
260
+ }
261
+ }
@@ -0,0 +1,63 @@
1
+ import React from 'react';
2
+
3
+ import { SlotRenderer } from '@opensumi/ide-core-browser';
4
+ import { IChildComponentProps, SplitPanel, getStorageValue } from '@opensumi/ide-core-browser/lib/components';
5
+
6
+ import { Ai_CHAT_CONTAINER_VIEW_ID } from '../../../common';
7
+
8
+ import * as styles from './layout.module.less';
9
+
10
+ export const AiMainSlotRenderer = (props?: IChildComponentProps) => {
11
+ const { colors, layout } = getStorageValue();
12
+
13
+ return (
14
+ <SplitPanel
15
+ id='ai-native-main-horizontal-0'
16
+ flex={1}
17
+ className={styles.ai_native_panel_container}
18
+ resizeHandleClassName={styles.ai_native_slot_resize_horizontal}
19
+ >
20
+ <SplitPanel
21
+ id='ai-native-main-horizontal-1'
22
+ flex={1}
23
+ flexGrow={1}
24
+ resizeHandleClassName={styles.ai_native_slot_resize_horizontal}
25
+ >
26
+ <SlotRenderer
27
+ backgroundColor={colors.sideBarBackground}
28
+ slot='left'
29
+ isTabbar={true}
30
+ defaultSize={layout.left?.currentId ? layout.left?.size || 310 : 49}
31
+ minResize={280}
32
+ maxResize={480}
33
+ />
34
+ <SplitPanel
35
+ id='main-vertical'
36
+ minResize={300}
37
+ flexGrow={1}
38
+ direction='top-to-bottom'
39
+ className={styles.ai_native_slot_main}
40
+ >
41
+ <SlotRenderer backgroundColor={colors.editorBackground} flex={2} flexGrow={1} minResize={200} slot='main' />
42
+ <SlotRenderer
43
+ backgroundColor={colors.panelBackground}
44
+ flex={1}
45
+ defaultSize={layout.bottom?.size}
46
+ minResize={160}
47
+ slot='bottom'
48
+ isTabbar={true}
49
+ />
50
+ </SplitPanel>
51
+ <SlotRenderer slot='right' isTabbar={true} defaultSize={0} maxResize={480} minResize={280} minSize={0} />
52
+ </SplitPanel>
53
+ <SlotRenderer
54
+ slot={Ai_CHAT_CONTAINER_VIEW_ID}
55
+ isTabbar={true}
56
+ defaultSize={420}
57
+ maxResize={480}
58
+ minResize={280}
59
+ minSize={0}
60
+ />
61
+ </SplitPanel>
62
+ );
63
+ };
@@ -0,0 +1,28 @@
1
+
2
+ import { Injectable } from '@opensumi/di';
3
+ import { ComponentContribution, ComponentRegistry, Domain, getExternalIcon } from '@opensumi/ide-core-browser';
4
+ import { IMenuRegistry, MenuContribution, MenuId } from '@opensumi/ide-core-browser/lib/menu/next';
5
+
6
+ import { AiMenuBarView } from './menu-bar.view';
7
+
8
+ @Injectable()
9
+ @Domain(ComponentContribution, MenuContribution)
10
+ export class AiMenuBarContribution implements ComponentContribution, MenuContribution {
11
+ static AiMenuBarContainer = 'ai-menubar';
12
+
13
+ registerComponent(registry: ComponentRegistry): void {
14
+ registry.register(AiMenuBarContribution.AiMenuBarContainer, {
15
+ component: AiMenuBarView,
16
+ id: AiMenuBarContribution.AiMenuBarContainer,
17
+ });
18
+ }
19
+
20
+ registerMenus(menus: IMenuRegistry): void {
21
+ menus.registerMenuItems(MenuId.IconMenubarContext, [
22
+ {
23
+ command: 'main-layout.left-panel.toggle',
24
+ iconClass: getExternalIcon('layout-sidebar-left-off'),
25
+ },
26
+ ]);
27
+ }
28
+ }
@@ -0,0 +1,41 @@
1
+ .menu_bar_view {
2
+ display: flex;
3
+ background-color: var(--kt-menubar-background);
4
+ align-items: center;
5
+ width: 100%;
6
+
7
+ .container {
8
+ display: flex;
9
+ justify-content: space-between;
10
+ width: inherit;
11
+ align-items: center;
12
+ padding: 0 16px;
13
+
14
+ .center {
15
+ .run {
16
+ .btn {
17
+ background-color: rgba(4, 74, 16, 0.6);
18
+ border-radius: 8px;
19
+ color: rgba(215, 219, 222, 1);
20
+ }
21
+ }
22
+ }
23
+
24
+ .right {
25
+ display: flex;
26
+ align-items: center;
27
+
28
+ .input {
29
+ margin-right: 16px;
30
+ width: 240px;
31
+
32
+ .input_wrapper {
33
+ height: 32px;
34
+ background-color: #ffffff1f;
35
+ border-radius: 8px;
36
+ border: 1px solid #ffffff1f;
37
+ }
38
+ }
39
+ }
40
+ }
41
+ }
@@ -0,0 +1,92 @@
1
+ import * as React from 'react';
2
+ import { Avatar } from 'react-chat-elements';
3
+
4
+ import { AppConfig, getIcon, useInjectable } from '@opensumi/ide-core-browser';
5
+ import { Button, Icon, Input } from '@opensumi/ide-core-browser/lib/components';
6
+ import { LAYOUT_VIEW_SIZE } from '@opensumi/ide-core-browser/lib/layout/constants';
7
+ import { VIEW_CONTAINERS } from '@opensumi/ide-core-browser/lib/layout/view-id';
8
+ import { CommandService } from '@opensumi/ide-core-common';
9
+ import { IconMenuBar } from '@opensumi/ide-menu-bar/lib/browser/menu-bar.view';
10
+
11
+ import { AI_RUN_DEBUG_COMMANDS } from '../../../../common/command';
12
+
13
+ import * as styles from './menu-bar.module.less';
14
+
15
+ export const AiMenuBarView = () => {
16
+ const commandService = useInjectable<CommandService>(CommandService);
17
+ const appConfig = useInjectable<AppConfig>(AppConfig);
18
+
19
+ const [latestWidth, setLatestWidth] = React.useState<number>(0);
20
+
21
+ const handleRun = () => {
22
+ commandService.executeCommand(AI_RUN_DEBUG_COMMANDS.id);
23
+ };
24
+
25
+ const handleRightPanel = () => {
26
+ /**
27
+ * 这里先这样处理,暂时没找到原因
28
+ */
29
+ const domID = 'div[id*=ai_chat_panel___]';
30
+ const chatPanel = document.querySelector(domID)?.parentElement?.parentElement;
31
+
32
+ if (chatPanel) {
33
+ let preWidth: number | string = chatPanel.style.width;
34
+ preWidth = parseInt(preWidth, 10);
35
+ setLatestWidth(preWidth);
36
+
37
+ if (preWidth !== 0) {
38
+ chatPanel.style.width = '0px';
39
+ } else {
40
+ chatPanel.style.width = latestWidth + 'px';
41
+ }
42
+ }
43
+ };
44
+
45
+ const MENUBAR_HEIGHT = React.useMemo(
46
+ () => appConfig.layoutViewSize?.MENUBAR_HEIGHT || LAYOUT_VIEW_SIZE.MENUBAR_HEIGHT,
47
+ [appConfig],
48
+ );
49
+
50
+ // quick-open-overlay
51
+ return (
52
+ <div id={VIEW_CONTAINERS.MENUBAR} className={styles.menu_bar_view} style={{ height: MENUBAR_HEIGHT }}>
53
+ {/* <span className={styles.menu_bar_logo} /> */}
54
+ <div className={styles.container}>
55
+ <div className={styles.left}>
56
+ <IconMenuBar />
57
+ </div>
58
+ <div className={styles.center}>
59
+ <div className={styles.run}>
60
+ <Button size={'large'} onClick={handleRun} className={styles.btn}>
61
+ <Icon className={getIcon('caret-right')} /> 运行
62
+ </Button>
63
+ </div>
64
+ </div>
65
+ <div className={styles.right}>
66
+ <div className={styles.input}>
67
+ <Input
68
+ className={styles.input_wrapper}
69
+ width={'100%'}
70
+ addonBefore={<Icon style={{ color: '#ffffff1f' }} className={getIcon('search')} />}
71
+ placeholder='请搜索并选择指令'
72
+ // onFocus={handleSelectFocus}
73
+ ></Input>
74
+ </div>
75
+ <div className={styles.ai_switch}>
76
+ {/* <Icon className={getIcon('search')} onClick={handleRightPanel}/> */}
77
+ <div
78
+ style={{
79
+ cursor: 'pointer',
80
+ }}
81
+ onClick={handleRightPanel}
82
+ >
83
+ <Avatar
84
+ src={'https://mdn.alipayobjects.com/huamei_htww6h/afts/img/A*6Y9PQp_rk7QAAAAAAAAAAAAADhl8AQ/original'}
85
+ />
86
+ </div>
87
+ </div>
88
+ </div>
89
+ </div>
90
+ </div>
91
+ );
92
+ };
@@ -0,0 +1,91 @@
1
+ import clsx from 'classnames';
2
+ import React, { useCallback } from 'react';
3
+
4
+ import { ComponentRegistryInfo, SlotLocation, useInjectable } from '@opensumi/ide-core-browser';
5
+ import { LeftTabbarRenderer } from '@opensumi/ide-main-layout/lib/browser/tabbar/bar.view';
6
+ import { BaseTabPanelView, ContainerView } from '@opensumi/ide-main-layout/lib/browser/tabbar/panel.view';
7
+ import {
8
+ BottomTabRenderer,
9
+ LeftTabRenderer,
10
+ RightTabRenderer,
11
+ TabRendererBase,
12
+ } from '@opensumi/ide-main-layout/lib/browser/tabbar/renderer.view';
13
+ import { TabbarService, TabbarServiceFactory } from '@opensumi/ide-main-layout/lib/browser/tabbar/tabbar.service';
14
+
15
+ import { Ai_CHAT_CONTAINER_VIEW_ID } from '../../../common';
16
+ import { HorizontalVertical } from '../../components/lineVertical';
17
+
18
+ import * as styles from './layout.module.less';
19
+
20
+ // 将注册在 right bar 的组件渲染到 left bar
21
+ const AiLeftTabbarRenderer: React.FC = () => {
22
+ const tabbarService: TabbarService = useInjectable(TabbarServiceFactory)(SlotLocation.right);
23
+
24
+ const renderOtherVisibleContainers = useCallback(
25
+ ({ props, renderContainers }) => {
26
+ const { currentContainerId, handleTabClick } = tabbarService;
27
+ const visibleContainers = tabbarService.visibleContainers.filter((container) => !container.options?.hideTab);
28
+
29
+ return (
30
+ <>
31
+ <HorizontalVertical />
32
+ {visibleContainers.map((component) => renderContainers(component, handleTabClick, currentContainerId))}
33
+ </>
34
+ );
35
+ },
36
+ [tabbarService],
37
+ );
38
+
39
+ return <LeftTabbarRenderer renderOtherVisibleContainers={renderOtherVisibleContainers} />;
40
+ };
41
+
42
+ export const AiLeftTabRenderer = ({
43
+ className,
44
+ components,
45
+ }: {
46
+ className: string;
47
+ components: ComponentRegistryInfo[];
48
+ }) => (
49
+ <LeftTabRenderer
50
+ className={clsx(className, styles.ai_left_slot)}
51
+ components={components}
52
+ tabbarView={AiLeftTabbarRenderer}
53
+ />
54
+ );
55
+
56
+ // right 面板只保留 panel
57
+ export const AiRightTabRenderer = ({
58
+ className,
59
+ components,
60
+ }: {
61
+ className: string;
62
+ components: ComponentRegistryInfo[];
63
+ }) => <RightTabRenderer className={className} components={components} tabbarView={() => null} />;
64
+
65
+ // 编辑器 bottom 面板
66
+ export const AiBottomTabRenderer = ({
67
+ className,
68
+ components,
69
+ }: {
70
+ className: string;
71
+ components: ComponentRegistryInfo[];
72
+ }) => <BottomTabRenderer className={clsx(className, styles.ai_bottom_slot)} components={components} />;
73
+
74
+ // ai_chat 面板
75
+ export const AiChatTabRenderer = ({
76
+ className,
77
+ components,
78
+ }: {
79
+ className: string;
80
+ components: ComponentRegistryInfo[];
81
+ }) => (
82
+ <TabRendererBase
83
+ side={Ai_CHAT_CONTAINER_VIEW_ID}
84
+ direction='right-to-left'
85
+ id={styles.ai_chat_panel}
86
+ className={clsx(className, `${Ai_CHAT_CONTAINER_VIEW_ID}-slot`)}
87
+ components={components}
88
+ TabbarView={() => null}
89
+ TabpanelView={() => <BaseTabPanelView PanelView={ContainerView} currentContainerId={Ai_CHAT_CONTAINER_VIEW_ID} />}
90
+ />
91
+ );
@@ -0,0 +1,32 @@
1
+ .ai_marker_node_icon_container {
2
+ display: flex;
3
+ align-items: center;
4
+
5
+ .ai_icon {
6
+ color: #ffcc00;
7
+ display: none !important;
8
+ margin-right: 4px;
9
+ }
10
+ }
11
+
12
+ .ai_editor_tab_block_container {
13
+ display: flex;
14
+ align-items: center;
15
+ height: 28px;
16
+ border-radius: 8px;
17
+ padding: 0 8px;
18
+
19
+ &.active {
20
+ background-color: var(--tab-activeBackground);
21
+ }
22
+
23
+ div:first-child {
24
+ margin-right: 5px;
25
+ flex-shrink: 0;
26
+ flex-grow: 0;
27
+ &::before {
28
+ background-size: 14px;
29
+ background-position: 2px;
30
+ }
31
+ }
32
+ }