@opensumi/ide-ai-native 2.26.9-rc-1695091570.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 (196) 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 +227 -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 +134 -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 +305 -0
  14. package/lib/browser/ai-chat.view.js.map +1 -0
  15. package/lib/browser/ai-editor.contribution.d.ts +24 -0
  16. package/lib/browser/ai-editor.contribution.d.ts.map +1 -0
  17. package/lib/browser/ai-editor.contribution.js +419 -0
  18. package/lib/browser/ai-editor.contribution.js.map +1 -0
  19. package/lib/browser/ai-project/generate.service.d.ts +31 -0
  20. package/lib/browser/ai-project/generate.service.d.ts.map +1 -0
  21. package/lib/browser/ai-project/generate.service.js +453 -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 +21 -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 +127 -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 +259 -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 +74 -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 +12 -0
  86. package/lib/browser/index.d.ts.map +1 -0
  87. package/lib/browser/index.js +84 -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 +55 -0
  104. package/lib/browser/override/ai-marker.service.js.map +1 -0
  105. package/lib/browser/override/global.styles.less +268 -0
  106. package/lib/browser/override/layout/layout-config.d.ts +6 -0
  107. package/lib/browser/override/layout/layout-config.d.ts.map +1 -0
  108. package/lib/browser/override/layout/layout-config.js +17 -0
  109. package/lib/browser/override/layout/layout-config.js.map +1 -0
  110. package/lib/browser/override/layout/layout.module.less +7 -0
  111. package/lib/browser/override/layout/main-slot-renderer.d.ts +4 -0
  112. package/lib/browser/override/layout/main-slot-renderer.d.ts.map +1 -0
  113. package/lib/browser/override/layout/main-slot-renderer.js +22 -0
  114. package/lib/browser/override/layout/main-slot-renderer.js.map +1 -0
  115. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.d.ts +8 -0
  116. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.d.ts.map +1 -0
  117. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.js +32 -0
  118. package/lib/browser/override/layout/menu-bar/menu-bar.contribution.js.map +1 -0
  119. package/lib/browser/override/layout/menu-bar/menu-bar.module.less +41 -0
  120. package/lib/browser/override/layout/menu-bar/menu-bar.view.d.ts +3 -0
  121. package/lib/browser/override/layout/menu-bar/menu-bar.view.d.ts.map +1 -0
  122. package/lib/browser/override/layout/menu-bar/menu-bar.view.js +62 -0
  123. package/lib/browser/override/layout/menu-bar/menu-bar.view.js.map +1 -0
  124. package/lib/browser/override/layout/tabbar.view.d.ts +17 -0
  125. package/lib/browser/override/layout/tabbar.view.d.ts.map +1 -0
  126. package/lib/browser/override/layout/tabbar.view.js +38 -0
  127. package/lib/browser/override/layout/tabbar.view.js.map +1 -0
  128. package/lib/browser/override/override.module.less +32 -0
  129. package/lib/browser/override/theme/default-theme.d.ts +315 -0
  130. package/lib/browser/override/theme/default-theme.d.ts.map +1 -0
  131. package/lib/browser/override/theme/default-theme.js +821 -0
  132. package/lib/browser/override/theme/default-theme.js.map +1 -0
  133. package/lib/browser/run/run.service.d.ts +52 -0
  134. package/lib/browser/run/run.service.d.ts.map +1 -0
  135. package/lib/browser/run/run.service.js +176 -0
  136. package/lib/browser/run/run.service.js.map +1 -0
  137. package/lib/common/command.d.ts +17 -0
  138. package/lib/common/command.d.ts.map +1 -0
  139. package/lib/common/command.js +21 -0
  140. package/lib/common/command.js.map +1 -0
  141. package/lib/common/index.d.ts +37 -0
  142. package/lib/common/index.d.ts.map +1 -0
  143. package/lib/common/index.js +22 -0
  144. package/lib/common/index.js.map +1 -0
  145. package/lib/index.d.ts +2 -0
  146. package/lib/index.d.ts.map +1 -0
  147. package/lib/index.js +5 -0
  148. package/lib/index.js.map +1 -0
  149. package/lib/node/index.d.ts +10 -0
  150. package/lib/node/index.d.ts.map +1 -0
  151. package/lib/node/index.js +32 -0
  152. package/lib/node/index.js.map +1 -0
  153. package/package.json +38 -0
  154. package/src/browser/ai-chat.contribution.ts +294 -0
  155. package/src/browser/ai-chat.module.less +174 -0
  156. package/src/browser/ai-chat.service.ts +152 -0
  157. package/src/browser/ai-chat.view.tsx +421 -0
  158. package/src/browser/ai-editor.contribution.ts +521 -0
  159. package/src/browser/ai-project/generate.service.ts +505 -0
  160. package/src/browser/ai-sumi/sumi.service.ts +65 -0
  161. package/src/browser/code-widget/ai-code-document.provider.ts +22 -0
  162. package/src/browser/code-widget/ai-code-widget.tsx +202 -0
  163. package/src/browser/components/AIImprove.tsx +45 -0
  164. package/src/browser/components/AIInput.tsx +30 -0
  165. package/src/browser/components/ChatEditor.tsx +129 -0
  166. package/src/browser/components/ChatInput.tsx +197 -0
  167. package/src/browser/components/ChatMoreActions.tsx +33 -0
  168. package/src/browser/components/Thinking.tsx +23 -0
  169. package/src/browser/components/components.module.less +259 -0
  170. package/src/browser/components/lineVertical.tsx +19 -0
  171. package/src/browser/content-widget/ai-content-widget.tsx +132 -0
  172. package/src/browser/content-widget/ai-inline-chat-panel.tsx +154 -0
  173. package/src/browser/content-widget/ai-inline-chat.module.less +74 -0
  174. package/src/browser/content-widget/ai-inline-chat.service.ts +46 -0
  175. package/src/browser/diff-widget/ai-diff-document.provider.ts +22 -0
  176. package/src/browser/diff-widget/ai-diff-widget.tsx +196 -0
  177. package/src/browser/index.ts +91 -0
  178. package/src/browser/inline-completions/constants.ts +108 -0
  179. package/src/browser/inline-completions/provider.ts +55 -0
  180. package/src/browser/override/ai-editor-tab.service.tsx +22 -0
  181. package/src/browser/override/ai-marker.service.tsx +55 -0
  182. package/src/browser/override/global.styles.less +268 -0
  183. package/src/browser/override/layout/layout-config.ts +21 -0
  184. package/src/browser/override/layout/layout.module.less +7 -0
  185. package/src/browser/override/layout/main-slot-renderer.tsx +62 -0
  186. package/src/browser/override/layout/menu-bar/menu-bar.contribution.tsx +28 -0
  187. package/src/browser/override/layout/menu-bar/menu-bar.module.less +41 -0
  188. package/src/browser/override/layout/menu-bar/menu-bar.view.tsx +92 -0
  189. package/src/browser/override/layout/tabbar.view.tsx +99 -0
  190. package/src/browser/override/override.module.less +32 -0
  191. package/src/browser/override/theme/default-theme.ts +818 -0
  192. package/src/browser/run/run.service.ts +183 -0
  193. package/src/common/command.ts +21 -0
  194. package/src/common/index.ts +39 -0
  195. package/src/index.ts +1 -0
  196. package/src/node/index.ts +24 -0
@@ -0,0 +1,6 @@
1
+ import { ReactNode } from 'react';
2
+ import { EditorTabService } from '@opensumi/ide-editor/lib/browser/editor.tab.service';
3
+ export declare class AiEditorTabService extends EditorTabService {
4
+ renderEditorTab(component: ReactNode, isCurrent: boolean): ReactNode;
5
+ }
6
+ //# sourceMappingURL=ai-editor-tab.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-editor-tab.service.d.ts","sourceRoot":"","sources":["../../../src/browser/override/ai-editor-tab.service.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qDAAqD,CAAC;AAKvF,qBACa,kBAAmB,SAAQ,gBAAgB;IAC7C,eAAe,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,GAAG,SAAS;CAY9E"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AiEditorTabService = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const react_1 = tslib_1.__importDefault(require("react"));
6
+ const di_1 = require("@opensumi/di");
7
+ const editor_tab_service_1 = require("@opensumi/ide-editor/lib/browser/editor.tab.service");
8
+ const classnames_1 = tslib_1.__importDefault(require("classnames"));
9
+ const styles = tslib_1.__importStar(require("./override.module.less"));
10
+ let AiEditorTabService = class AiEditorTabService extends editor_tab_service_1.EditorTabService {
11
+ renderEditorTab(component, isCurrent) {
12
+ return (react_1.default.createElement("div", { className: (0, classnames_1.default)({
13
+ [styles.ai_editor_tab_block_container]: true,
14
+ [styles.active]: isCurrent
15
+ }) }, component));
16
+ }
17
+ };
18
+ AiEditorTabService = tslib_1.__decorate([
19
+ (0, di_1.Injectable)()
20
+ ], AiEditorTabService);
21
+ exports.AiEditorTabService = AiEditorTabService;
22
+ //# sourceMappingURL=ai-editor-tab.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-editor-tab.service.js","sourceRoot":"","sources":["../../../src/browser/override/ai-editor-tab.service.tsx"],"names":[],"mappings":";;;;AAAA,0DAAyC;AACzC,qCAA0C;AAC1C,4FAAuF;AAEvF,oEAA6B;AAC7B,uEAAiD;AAG1C,IAAM,kBAAkB,GAAxB,MAAM,kBAAmB,SAAQ,qCAAgB;IAC7C,eAAe,CAAC,SAAoB,EAAE,SAAkB;QAC/D,OAAO,CACL,uCAAK,SAAS,EAAE,IAAA,oBAAG,EACjB;gBACE,CAAC,MAAM,CAAC,6BAA6B,CAAC,EAAE,IAAI;gBAC5C,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,SAAS;aAC3B,CACF,IACE,SAAS,CACN,CACP,CAAA;IACH,CAAC;CACF,CAAA;AAbY,kBAAkB;IAD9B,IAAA,eAAU,GAAE;GACA,kBAAkB,CAa9B;AAbY,gDAAkB"}
@@ -0,0 +1,11 @@
1
+ import { ReactNode } from 'react';
2
+ import { MarkerService } from '@opensumi/ide-markers/lib/browser/markers-service';
3
+ import { MarkerGroupNode, MarkerNode } from '@opensumi/ide-markers/lib/browser/tree/tree-node.defined';
4
+ export declare class AiMarkerService extends MarkerService {
5
+ private readonly editorService;
6
+ private aiChatService;
7
+ private readonly fileSystem;
8
+ private handleAiIcon;
9
+ renderMarkerNodeIcon(component: ReactNode, node: MarkerGroupNode | MarkerNode): ReactNode;
10
+ }
11
+ //# sourceMappingURL=ai-marker.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-marker.service.d.ts","sourceRoot":"","sources":["../../../src/browser/override/ai-marker.service.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEzC,OAAO,EAAE,aAAa,EAAE,MAAM,mDAAmD,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,0DAA0D,CAAC;AAYvG,qBACa,eAAgB,SAAQ,aAAa;IAGhD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAA6B;IAG3D,OAAO,CAAC,aAAa,CAAgB;IAGrC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAqB;YAElC,YAAY;IAiBjB,oBAAoB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,eAAe,GAAG,UAAU,GAAG,SAAS;CAUnG"}
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AiMarkerService = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const react_1 = tslib_1.__importDefault(require("react"));
6
+ const di_1 = require("@opensumi/di");
7
+ const markers_service_1 = require("@opensumi/ide-markers/lib/browser/markers-service");
8
+ const tree_node_defined_1 = require("@opensumi/ide-markers/lib/browser/tree/tree-node.defined");
9
+ const classnames_1 = tslib_1.__importDefault(require("classnames"));
10
+ const styles = tslib_1.__importStar(require("./override.module.less"));
11
+ const ide_components_1 = require("@opensumi/ide-components");
12
+ const ide_core_browser_1 = require("@opensumi/ide-core-browser");
13
+ const ai_chat_service_1 = require("../ai-chat.service");
14
+ const workbench_editor_service_1 = require("@opensumi/ide-editor/lib/browser/workbench-editor.service");
15
+ const ide_editor_1 = require("@opensumi/ide-editor");
16
+ const ide_file_service_1 = require("@opensumi/ide-file-service");
17
+ let AiMarkerService = class AiMarkerService extends markers_service_1.MarkerService {
18
+ async handleAiIcon(node) {
19
+ try {
20
+ const resource = node.marker.resource;
21
+ const message = node.marker.message;
22
+ const { content } = await this.fileSystem.readFile(resource.toString());
23
+ const messageWithPrompt = `代码内容是 \`\`\`\n${content.toString()}\n\`\`\`。此时有个异常问题是 "${message}", 你需要解释这个异常问题并给出修复建议`;
24
+ this.aiChatService.launchChatMessage({
25
+ message: `/explain ${node.marker.message}`,
26
+ prompt: messageWithPrompt,
27
+ });
28
+ }
29
+ catch (error) {
30
+ throw Error('read file error', error);
31
+ }
32
+ }
33
+ renderMarkerNodeIcon(component, node) {
34
+ return (react_1.default.createElement("div", { className: (0, classnames_1.default)(!(tree_node_defined_1.MarkerGroupNode.is(node)) && styles.ai_marker_node_icon_container) },
35
+ !tree_node_defined_1.MarkerGroupNode.is(node) && react_1.default.createElement(ide_components_1.Icon, { tooltip: 'AI \u667A\u80FD\u95EE\u9898\u8BCA\u65AD', onClick: () => this.handleAiIcon(node), className: (0, classnames_1.default)((0, ide_core_browser_1.getExternalIcon)('lightbulb'), styles.ai_icon) }),
36
+ component));
37
+ }
38
+ };
39
+ tslib_1.__decorate([
40
+ (0, di_1.Autowired)(ide_editor_1.WorkbenchEditorService),
41
+ tslib_1.__metadata("design:type", workbench_editor_service_1.WorkbenchEditorServiceImpl)
42
+ ], AiMarkerService.prototype, "editorService", void 0);
43
+ tslib_1.__decorate([
44
+ (0, di_1.Autowired)(),
45
+ tslib_1.__metadata("design:type", ai_chat_service_1.AiChatService)
46
+ ], AiMarkerService.prototype, "aiChatService", void 0);
47
+ tslib_1.__decorate([
48
+ (0, di_1.Autowired)(ide_file_service_1.IFileServiceClient),
49
+ tslib_1.__metadata("design:type", Object)
50
+ ], AiMarkerService.prototype, "fileSystem", void 0);
51
+ AiMarkerService = tslib_1.__decorate([
52
+ (0, di_1.Injectable)()
53
+ ], AiMarkerService);
54
+ exports.AiMarkerService = AiMarkerService;
55
+ //# sourceMappingURL=ai-marker.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-marker.service.js","sourceRoot":"","sources":["../../../src/browser/override/ai-marker.service.tsx"],"names":[],"mappings":";;;;AAAA,0DAAyC;AACzC,qCAAqD;AACrD,uFAAkF;AAClF,gGAAuG;AAEvG,oEAA6B;AAE7B,uEAAiD;AACjD,6DAAgD;AAChD,iEAA6D;AAC7D,wDAAmD;AACnD,wGAAuG;AACvG,qDAA8D;AAC9D,iEAAgE;AAGzD,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,+BAAa;IAWxC,KAAK,CAAC,YAAY,CAAC,IAAgB;QACzC,IAAI;YACF,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;YACtC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YACpC,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;YAExE,MAAM,iBAAiB,GAAG,iBAAiB,OAAO,CAAC,QAAQ,EAAE,uBAAuB,OAAO,uBAAuB,CAAC;YAEnH,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;gBACnC,OAAO,EAAE,YAAY,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;gBAC1C,MAAM,EAAE,iBAAiB;aAC1B,CAAC,CAAC;SACJ;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,KAAK,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAA;SACtC;IACH,CAAC;IAEQ,oBAAoB,CAAC,SAAoB,EAAE,IAAkC;QACpF,OAAO,CACL,uCAAK,SAAS,EAAE,IAAA,oBAAG,EAAC,CAAC,CAAC,mCAAe,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,MAAM,CAAC,6BAA6B,CAAC;YAEpF,CAAC,mCAAe,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,8BAAC,qBAAI,IAAC,OAAO,EAAC,yCAAW,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAA,oBAAG,EAAC,IAAA,kCAAe,EAAC,WAAW,CAAC,EAAE,MAAM,CAAC,OAAO,CAAC,GAAI;YAEhK,SAAS,CACN,CACP,CAAA;IACH,CAAC;CACF,CAAA;AApCC;IAAC,IAAA,cAAS,EAAC,mCAAsB,CAAC;sCACF,qDAA0B;sDAAC;AAE3D;IAAC,IAAA,cAAS,GAAE;sCACW,+BAAa;sDAAC;AAErC;IAAC,IAAA,cAAS,EAAC,qCAAkB,CAAC;;mDACkB;AATrC,eAAe;IAD3B,IAAA,eAAU,GAAE;GACA,eAAe,CAsC3B;AAtCY,0CAAe"}
@@ -0,0 +1,268 @@
1
+ @import '@opensumi/ide-core-browser/lib/style/variable.less';
2
+
3
+ #ai_chat_panel {
4
+ height: 100%;
5
+ }
6
+
7
+ /**
8
+ * ---------------- 覆盖 editor tab 样式 ---------------------
9
+ */
10
+ div[class*='kt_editor_group___'] div[class*='kt_editor_tabs_content___'] {
11
+ div[class*='kt_editor_tab___'] {
12
+ border-right: none;
13
+ border-top: none;
14
+ }
15
+
16
+ div[class*='kt_editor_tab_current___'] {
17
+ background-color: transparent !important;
18
+ }
19
+ }
20
+
21
+ /**
22
+ * ---------------- 覆盖 editor navigation 导航条样式 ---------------------
23
+ */
24
+ div[class*='navigation_container___'] {
25
+ height: 28px;
26
+ margin-bottom: 10px;
27
+ }
28
+
29
+ div[class*='file_tree_node___'] {
30
+ border-radius: 4px;
31
+ }
32
+
33
+ /**
34
+ * ---------------- 覆盖 左、右、底 tabbar 样式 ---------------------
35
+ */
36
+ @bottomBarHeight: 32px;
37
+
38
+ div[class*='icon_tab___'] {
39
+ height: 32px;
40
+ width: 32px;
41
+ border-radius: 8px;
42
+
43
+ div.activity-icon {
44
+ font-size: 16px;
45
+ width: initial;
46
+ height: initial;
47
+ color: var(--activityBar-inactiveForeground);
48
+
49
+ &.mask-mode {
50
+ background-color: var(--activityBar-inactiveForeground);
51
+ -webkit-mask-size: 16px;
52
+ }
53
+ }
54
+ }
55
+
56
+ div[class*='tab_panel___'] {
57
+ &::before {
58
+ content: none;
59
+ }
60
+ }
61
+
62
+ div[class*='tab_panel_hidden___'] {
63
+ display: none;
64
+ }
65
+
66
+ .left-slot div[class*='tab_panel___'] {
67
+ border-right: none;
68
+ }
69
+
70
+ li[class*='left_tab___'] {
71
+ width: 100%;
72
+ display: flex;
73
+ justify-content: center;
74
+
75
+ &.active {
76
+ div[class*='icon_tab___'] {
77
+ background-color: var(--activityBar-activeBorder);
78
+ &::before {
79
+ content: none;
80
+ }
81
+ }
82
+ }
83
+ }
84
+
85
+ div[class*='left_tab_bar___'] {
86
+ border-right: none;
87
+ border-top: none;
88
+ }
89
+
90
+ div[class*='bar_content___'] {
91
+ width: 100%;
92
+ }
93
+
94
+ .bottom-slot div[class*='tab_bar___'] {
95
+ height: 100%;
96
+ }
97
+
98
+ li[class*='bottom_tab___'] {
99
+ height: 100%;
100
+ line-height: @bottomBarHeight;
101
+ }
102
+
103
+ div[class*='bottom_bar_container___'] {
104
+ width: 100%;
105
+ height: @bottomBarHeight;
106
+ min-height: @bottomBarHeight;
107
+ }
108
+
109
+ /* --------------------------------------*/
110
+
111
+ div[class*='box-panel___'] {
112
+ background-image: url('https://mdn.alipayobjects.com/huamei_htww6h/afts/img/A*hLI-SqEx-YkAAAAAAAAAAAAADhl8AQ/original');
113
+ background-repeat: no-repeat;
114
+ background-size: cover;
115
+ }
116
+
117
+ .rce-mbox-left-notch,
118
+ .rce-mbox-right-notch {
119
+ display: none;
120
+ }
121
+
122
+ .rce-mbox {
123
+ background-color: #ffffff0a;
124
+ border-radius: 2px 12px 12px 12px;
125
+ box-shadow: none;
126
+ padding: 8px 12px;
127
+ min-width: initial;
128
+ margin: 0;
129
+
130
+ ::after {
131
+ content: '';
132
+ }
133
+ }
134
+
135
+ .rce-mbox-text {
136
+ font-size: 12px;
137
+ line-height: 18px;
138
+ width: inherit;
139
+ }
140
+
141
+ .rce-smsg {
142
+ background-color: #ffffff0a;
143
+ box-shadow: none;
144
+ border-radius: 8px;
145
+ max-width: initial;
146
+ border-radius: 2px 12px 12px 12px;
147
+ width: 100%;
148
+ flex-direction: initial;
149
+ justify-content: left;
150
+ padding: 8px 12px 12px;
151
+ margin: 0;
152
+
153
+ .rce-smsg-text {
154
+ font-size: 12px;
155
+ width: 100%;
156
+ text-align: left;
157
+ }
158
+ }
159
+
160
+ .rce-container-smsg {
161
+ width: 100%;
162
+ }
163
+
164
+ .rce-mlist {
165
+ color: #ffffff;
166
+ font-size: 12px;
167
+ font-weight: 300;
168
+ }
169
+
170
+ .rce-ai-msg {
171
+ > .rce-mbox {
172
+ margin-bottom: 28px;
173
+ width: 100%;
174
+ }
175
+
176
+ .rce-mbox-body {
177
+ display: flex;
178
+ align-items: flex-start;
179
+ position: initial;
180
+ width: 100%;
181
+
182
+ .rce-mbox-title {
183
+ position: absolute;
184
+ left: -40px;
185
+ top: 0;
186
+ }
187
+
188
+ .rce-avatar-container {
189
+ &.default {
190
+ height: 32px;
191
+ width: 32px;
192
+ }
193
+ }
194
+ }
195
+ }
196
+
197
+ .rce-container-mbox {
198
+ overflow: hidden;
199
+ margin: 0 16px 16px 16px;
200
+ min-width: initial;
201
+ }
202
+
203
+ .rce-user-msg {
204
+ .rce-mbox-right {
205
+ border-radius: 12px 12px 2px 12px;
206
+ background-color: #3c8dff4d;
207
+ margin-right: 0;
208
+ margin-left: 0;
209
+ }
210
+ }
211
+
212
+ blockquote {
213
+ background: var(--vscode-textBlockQuote-background);
214
+ border-color: var(--vscode-textBlockQuote-border);
215
+ }
216
+
217
+ .AI-Content-Widget {
218
+ box-shadow: 0 9px 28px 8px rgba(0, 0, 0, 0.15);
219
+ border-radius: 10px;
220
+ padding: 12px 16px;
221
+ background-color: rgba(23, 28, 37, 1);
222
+ border: 1px solid rgba(54, 57, 64, 1);
223
+
224
+ // 编辑区域的 content widget
225
+ .ant-select-selector {
226
+ background-color: #c0c7d008 !important;
227
+ }
228
+
229
+ .ai-shortcuts {
230
+ margin-bottom: 12px;
231
+ }
232
+ }
233
+
234
+ // ai native main
235
+ .ai_native_panel_container {
236
+ margin-right: 16px;
237
+ width: initial;
238
+ }
239
+
240
+ .ai_native_slot_main {
241
+ height: 100%;
242
+ width: 100%;
243
+ background-color: #151b21;
244
+ border: 1px solid rgba(255, 255, 255, 0.12);
245
+ border-radius: 12px;
246
+ overflow: hidden;
247
+ }
248
+
249
+ .ai_native_slot_resize_horizontal {
250
+ height: 100%;
251
+ margin: 0 3px;
252
+ position: relative;
253
+ &::after {
254
+ content: '';
255
+ position: absolute;
256
+ height: 25px;
257
+ width: 2px;
258
+ background-color: #31363b;
259
+ border-radius: 1px;
260
+ top: 50%;
261
+ left: 50%;
262
+ }
263
+ }
264
+
265
+ // ai native input
266
+ .ai_native_input_container {
267
+ height: 32px;
268
+ }
@@ -0,0 +1,6 @@
1
+ export declare const AiLayoutConfig: {
2
+ ai_chat: {
3
+ modules: string[];
4
+ };
5
+ };
6
+ //# sourceMappingURL=layout-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"layout-config.d.ts","sourceRoot":"","sources":["../../../../src/browser/override/layout/layout-config.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,cAAc;;;;CAY1B,CAAC"}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AiLayoutConfig = void 0;
4
+ const ide_core_browser_1 = require("@opensumi/ide-core-browser");
5
+ const default_config_1 = require("@opensumi/ide-main-layout/lib/browser/default-config");
6
+ const common_1 = require("../../../common");
7
+ const menu_bar_contribution_1 = require("./menu-bar/menu-bar.contribution");
8
+ exports.AiLayoutConfig = Object.assign(Object.assign(Object.assign({}, default_config_1.defaultConfig), {
9
+ [ide_core_browser_1.SlotLocation.top]: {
10
+ modules: [menu_bar_contribution_1.AiMenuBarContribution.AiMenuBarContainer],
11
+ },
12
+ }), {
13
+ [common_1.Ai_CHAT_CONTAINER_VIEW_ID]: {
14
+ modules: [common_1.Ai_CHAT_CONTAINER_VIEW_ID],
15
+ },
16
+ });
17
+ //# sourceMappingURL=layout-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"layout-config.js","sourceRoot":"","sources":["../../../../src/browser/override/layout/layout-config.ts"],"names":[],"mappings":";;;AAAA,iEAA0D;AAC1D,yFAAqF;AAErF,4CAA4D;AAG5D,4EAAyE;AAE5D,QAAA,cAAc,iDACtB,8BAAa,GACb;IACD,CAAC,+BAAY,CAAC,GAAG,CAAC,EAAE;QAClB,OAAO,EAAE,CAAC,6CAAqB,CAAC,kBAAkB,CAAC;KACpD;CACF,GACE;IACD,CAAC,kCAAyB,CAAC,EAAE;QAC3B,OAAO,EAAE,CAAC,kCAAyB,CAAC;KACrC;CACF,EACD"}
@@ -0,0 +1,7 @@
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
+ }
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { IChildComponentProps } from '@opensumi/ide-core-browser/lib/components';
3
+ export declare const AiMainSlotRenderer: (props?: IChildComponentProps) => React.JSX.Element;
4
+ //# sourceMappingURL=main-slot-renderer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main-slot-renderer.d.ts","sourceRoot":"","sources":["../../../../src/browser/override/layout/main-slot-renderer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAE,oBAAoB,EAA+B,MAAM,2CAA2C,CAAC;AAI9G,eAAO,MAAM,kBAAkB,WAAY,oBAAoB,sBAsD9D,CAAC"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AiMainSlotRenderer = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const react_1 = tslib_1.__importDefault(require("react"));
6
+ const ide_core_browser_1 = require("@opensumi/ide-core-browser");
7
+ const components_1 = require("@opensumi/ide-core-browser/lib/components");
8
+ const common_1 = require("../../../common");
9
+ const AiMainSlotRenderer = (props) => {
10
+ var _a, _b, _c;
11
+ const { colors, layout } = (0, components_1.getStorageValue)();
12
+ return (react_1.default.createElement(components_1.SplitPanel, { id: 'ai-native-main-horizontal-0', flex: 1, className: 'ai_native_panel_container', resizeHandleClassName: 'ai_native_slot_resize_horizontal' },
13
+ react_1.default.createElement(components_1.SplitPanel, { id: 'ai-native-main-horizontal-1', flex: 1, flexGrow: 1, resizeHandleClassName: 'ai_native_slot_resize_horizontal' },
14
+ react_1.default.createElement(ide_core_browser_1.SlotRenderer, { backgroundColor: colors.sideBarBackground, slot: 'left', isTabbar: true, defaultSize: ((_a = layout.left) === null || _a === void 0 ? void 0 : _a.currentId) ? ((_b = layout.left) === null || _b === void 0 ? void 0 : _b.size) || 310 : 49, minResize: 280, maxResize: 480 }),
15
+ react_1.default.createElement(components_1.SplitPanel, { id: 'main-vertical', minResize: 300, flexGrow: 1, direction: 'top-to-bottom', className: 'ai_native_slot_main', resizeHandleClassName: 'ai_native_slot_resize_horizontal' },
16
+ react_1.default.createElement(ide_core_browser_1.SlotRenderer, { backgroundColor: colors.editorBackground, flex: 2, flexGrow: 1, minResize: 200, slot: 'main' }),
17
+ react_1.default.createElement(ide_core_browser_1.SlotRenderer, { backgroundColor: colors.panelBackground, flex: 1, defaultSize: (_c = layout.bottom) === null || _c === void 0 ? void 0 : _c.size, minResize: 160, slot: 'bottom', isTabbar: true })),
18
+ react_1.default.createElement(ide_core_browser_1.SlotRenderer, { slot: 'right', isTabbar: true, defaultSize: 0, maxResize: 480, minResize: 280, minSize: 0 })),
19
+ react_1.default.createElement(ide_core_browser_1.SlotRenderer, { slot: common_1.Ai_CHAT_CONTAINER_VIEW_ID, isTabbar: true, defaultSize: 420, maxResize: 480, minResize: 280, minSize: 0 })));
20
+ };
21
+ exports.AiMainSlotRenderer = AiMainSlotRenderer;
22
+ //# sourceMappingURL=main-slot-renderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"main-slot-renderer.js","sourceRoot":"","sources":["../../../../src/browser/override/layout/main-slot-renderer.tsx"],"names":[],"mappings":";;;;AAAA,0DAA0B;AAE1B,iEAA0D;AAC1D,0EAA8G;AAE9G,4CAA4D;AAErD,MAAM,kBAAkB,GAAG,CAAC,KAA4B,EAAE,EAAE;;IACjE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAA,4BAAe,GAAE,CAAC;IAE7C,OAAO,CACL,8BAAC,uBAAU,IACT,EAAE,EAAC,6BAA6B,EAChC,IAAI,EAAE,CAAC,EACP,SAAS,EAAC,2BAA2B,EACrC,qBAAqB,EAAC,kCAAkC;QAExD,8BAAC,uBAAU,IACT,EAAE,EAAC,6BAA6B,EAChC,IAAI,EAAE,CAAC,EACP,QAAQ,EAAE,CAAC,EACX,qBAAqB,EAAC,kCAAkC;YAExD,8BAAC,+BAAY,IACX,eAAe,EAAE,MAAM,CAAC,iBAAiB,EACzC,IAAI,EAAC,MAAM,EACX,QAAQ,EAAE,IAAI,EACd,WAAW,EAAE,CAAA,MAAA,MAAM,CAAC,IAAI,0CAAE,SAAS,EAAC,CAAC,CAAC,CAAA,MAAA,MAAM,CAAC,IAAI,0CAAE,IAAI,KAAI,GAAG,CAAC,CAAC,CAAC,EAAE,EACnE,SAAS,EAAE,GAAG,EACd,SAAS,EAAE,GAAG,GACd;YACF,8BAAC,uBAAU,IACT,EAAE,EAAC,eAAe,EAClB,SAAS,EAAE,GAAG,EACd,QAAQ,EAAE,CAAC,EACX,SAAS,EAAC,eAAe,EACzB,SAAS,EAAC,qBAAqB,EAC/B,qBAAqB,EAAC,kCAAkC;gBAExD,8BAAC,+BAAY,IAAC,eAAe,EAAE,MAAM,CAAC,gBAAgB,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,IAAI,EAAC,MAAM,GAAG;gBAC5G,8BAAC,+BAAY,IACX,eAAe,EAAE,MAAM,CAAC,eAAe,EACvC,IAAI,EAAE,CAAC,EACP,WAAW,EAAE,MAAA,MAAM,CAAC,MAAM,0CAAE,IAAI,EAChC,SAAS,EAAE,GAAG,EACd,IAAI,EAAC,QAAQ,EACb,QAAQ,EAAE,IAAI,GACd,CACS;YACb,8BAAC,+BAAY,IAAC,IAAI,EAAC,OAAO,EAAC,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,GAAI,CAC9F;QACb,8BAAC,+BAAY,IACX,IAAI,EAAE,kCAAyB,EAC/B,QAAQ,EAAE,IAAI,EACd,WAAW,EAAE,GAAG,EAChB,SAAS,EAAE,GAAG,EACd,SAAS,EAAE,GAAG,EACd,OAAO,EAAE,CAAC,GACV,CACS,CACd,CAAC;AACJ,CAAC,CAAC;AAtDW,QAAA,kBAAkB,sBAsD7B"}
@@ -0,0 +1,8 @@
1
+ import { ComponentContribution, ComponentRegistry } from '@opensumi/ide-core-browser';
2
+ import { IMenuRegistry, MenuContribution } from '@opensumi/ide-core-browser/lib/menu/next';
3
+ export declare class AiMenuBarContribution implements ComponentContribution, MenuContribution {
4
+ static AiMenuBarContainer: string;
5
+ registerComponent(registry: ComponentRegistry): void;
6
+ registerMenus(menus: IMenuRegistry): void;
7
+ }
8
+ //# sourceMappingURL=menu-bar.contribution.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-bar.contribution.d.ts","sourceRoot":"","sources":["../../../../../src/browser/override/layout/menu-bar/menu-bar.contribution.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAA2B,MAAM,4BAA4B,CAAC;AAC/G,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAU,MAAM,0CAA0C,CAAC;AAInG,qBAEa,qBAAsB,YAAW,qBAAqB,EAAE,gBAAgB;IACnF,MAAM,CAAC,kBAAkB,SAAgB;IAEzC,iBAAiB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,IAAI;IAOpD,aAAa,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;CAQ1C"}
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ var AiMenuBarContribution_1;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.AiMenuBarContribution = void 0;
5
+ const tslib_1 = require("tslib");
6
+ const di_1 = require("@opensumi/di");
7
+ const ide_core_browser_1 = require("@opensumi/ide-core-browser");
8
+ const next_1 = require("@opensumi/ide-core-browser/lib/menu/next");
9
+ const menu_bar_view_1 = require("./menu-bar.view");
10
+ let AiMenuBarContribution = AiMenuBarContribution_1 = class AiMenuBarContribution {
11
+ registerComponent(registry) {
12
+ registry.register(AiMenuBarContribution_1.AiMenuBarContainer, {
13
+ component: menu_bar_view_1.AiMenuBarView,
14
+ id: AiMenuBarContribution_1.AiMenuBarContainer,
15
+ });
16
+ }
17
+ registerMenus(menus) {
18
+ menus.registerMenuItems(next_1.MenuId.IconMenubarContext, [
19
+ {
20
+ command: 'main-layout.left-panel.toggle',
21
+ iconClass: (0, ide_core_browser_1.getExternalIcon)('layout-sidebar-left-off'),
22
+ },
23
+ ]);
24
+ }
25
+ };
26
+ AiMenuBarContribution.AiMenuBarContainer = 'ai-menubar';
27
+ AiMenuBarContribution = AiMenuBarContribution_1 = tslib_1.__decorate([
28
+ (0, di_1.Injectable)(),
29
+ (0, ide_core_browser_1.Domain)(ide_core_browser_1.ComponentContribution, next_1.MenuContribution)
30
+ ], AiMenuBarContribution);
31
+ exports.AiMenuBarContribution = AiMenuBarContribution;
32
+ //# sourceMappingURL=menu-bar.contribution.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-bar.contribution.js","sourceRoot":"","sources":["../../../../../src/browser/override/layout/menu-bar/menu-bar.contribution.tsx"],"names":[],"mappings":";;;;;AACA,qCAA0C;AAC1C,iEAA+G;AAC/G,mEAAmG;AAEnG,mDAAgD;AAIzC,IAAM,qBAAqB,6BAA3B,MAAM,qBAAqB;IAGhC,iBAAiB,CAAC,QAA2B;QAC3C,QAAQ,CAAC,QAAQ,CAAC,uBAAqB,CAAC,kBAAkB,EAAE;YAC1D,SAAS,EAAE,6BAAa;YACxB,EAAE,EAAE,uBAAqB,CAAC,kBAAkB;SAC7C,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,KAAoB;QAChC,KAAK,CAAC,iBAAiB,CAAC,aAAM,CAAC,kBAAkB,EAAE;YACjD;gBACE,OAAO,EAAE,+BAA+B;gBACxC,SAAS,EAAE,IAAA,kCAAe,EAAC,yBAAyB,CAAC;aACtD;SACF,CAAC,CAAC;IACL,CAAC;;AAhBM,wCAAkB,GAAG,YAAY,CAAC;AAD9B,qBAAqB;IAFjC,IAAA,eAAU,GAAE;IACZ,IAAA,yBAAM,EAAC,wCAAqB,EAAE,uBAAgB,CAAC;GACnC,qBAAqB,CAkBjC;AAlBY,sDAAqB"}
@@ -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,3 @@
1
+ import * as React from 'react';
2
+ export declare const AiMenuBarView: () => React.JSX.Element;
3
+ //# sourceMappingURL=menu-bar.view.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-bar.view.d.ts","sourceRoot":"","sources":["../../../../../src/browser/override/layout/menu-bar/menu-bar.view.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAc/B,eAAO,MAAM,aAAa,yBA6EzB,CAAC"}
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AiMenuBarView = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const React = tslib_1.__importStar(require("react"));
6
+ const react_chat_elements_1 = require("react-chat-elements");
7
+ const ide_core_browser_1 = require("@opensumi/ide-core-browser");
8
+ const components_1 = require("@opensumi/ide-core-browser/lib/components");
9
+ const constants_1 = require("@opensumi/ide-core-browser/lib/layout/constants");
10
+ const view_id_1 = require("@opensumi/ide-core-browser/lib/layout/view-id");
11
+ const ide_core_common_1 = require("@opensumi/ide-core-common");
12
+ const menu_bar_view_1 = require("@opensumi/ide-menu-bar/lib/browser/menu-bar.view");
13
+ const command_1 = require("../../../../common/command");
14
+ const styles = tslib_1.__importStar(require("./menu-bar.module.less"));
15
+ const AiMenuBarView = () => {
16
+ const commandService = (0, ide_core_browser_1.useInjectable)(ide_core_common_1.CommandService);
17
+ const appConfig = (0, ide_core_browser_1.useInjectable)(ide_core_browser_1.AppConfig);
18
+ const [latestWidth, setLatestWidth] = React.useState(0);
19
+ const handleRun = () => {
20
+ commandService.executeCommand(command_1.AI_RUN_DEBUG_COMMANDS.id);
21
+ };
22
+ const handleRightPanel = () => {
23
+ var _a, _b;
24
+ /**
25
+ * 这里先这样处理,暂时没找到原因
26
+ */
27
+ const domID = 'ai_chat_panel';
28
+ const chatPanel = (_b = (_a = document.querySelector(`#${domID}`)) === null || _a === void 0 ? void 0 : _a.parentElement) === null || _b === void 0 ? void 0 : _b.parentElement;
29
+ if (chatPanel) {
30
+ let preWidth = chatPanel.style.width;
31
+ preWidth = parseInt(preWidth, 10);
32
+ setLatestWidth(preWidth);
33
+ if (preWidth !== 0) {
34
+ chatPanel.style.width = '0px';
35
+ }
36
+ else {
37
+ chatPanel.style.width = latestWidth + 'px';
38
+ }
39
+ }
40
+ };
41
+ const MENUBAR_HEIGHT = React.useMemo(() => { var _a; return ((_a = appConfig.layoutViewSize) === null || _a === void 0 ? void 0 : _a.MENUBAR_HEIGHT) || constants_1.LAYOUT_VIEW_SIZE.MENUBAR_HEIGHT; }, [appConfig]);
42
+ // quick-open-overlay
43
+ return (React.createElement("div", { id: view_id_1.VIEW_CONTAINERS.MENUBAR, className: styles.menu_bar_view, style: { height: MENUBAR_HEIGHT } },
44
+ React.createElement("div", { className: styles.container },
45
+ React.createElement("div", { className: styles.left },
46
+ React.createElement(menu_bar_view_1.IconMenuBar, null)),
47
+ React.createElement("div", { className: styles.center },
48
+ React.createElement("div", { className: styles.run },
49
+ React.createElement(components_1.Button, { size: 'large', onClick: handleRun, className: styles.btn },
50
+ React.createElement(components_1.Icon, { className: (0, ide_core_browser_1.getIcon)('caret-right') }),
51
+ " \u8FD0\u884C"))),
52
+ React.createElement("div", { className: styles.right },
53
+ React.createElement("div", { className: styles.input },
54
+ React.createElement(components_1.Input, { className: styles.input_wrapper, width: '100%', addonBefore: React.createElement(components_1.Icon, { style: { color: '#ffffff1f' }, className: (0, ide_core_browser_1.getIcon)('search') }), placeholder: '\u8BF7\u641C\u7D22\u5E76\u9009\u62E9\u6307\u4EE4' })),
55
+ React.createElement("div", { className: styles.ai_switch },
56
+ React.createElement("div", { style: {
57
+ cursor: 'pointer',
58
+ }, onClick: handleRightPanel },
59
+ React.createElement(react_chat_elements_1.Avatar, { src: 'https://mdn.alipayobjects.com/huamei_htww6h/afts/img/A*6Y9PQp_rk7QAAAAAAAAAAAAADhl8AQ/original' })))))));
60
+ };
61
+ exports.AiMenuBarView = AiMenuBarView;
62
+ //# sourceMappingURL=menu-bar.view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-bar.view.js","sourceRoot":"","sources":["../../../../../src/browser/override/layout/menu-bar/menu-bar.view.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import { ComponentRegistryInfo } from '@opensumi/ide-core-browser';
3
+ export declare const AiLeftTabbarRenderer: React.FC;
4
+ export declare const AiLeftTabRenderer: ({ className, components, }: {
5
+ className: string;
6
+ components: ComponentRegistryInfo[];
7
+ }) => React.JSX.Element;
8
+ export declare const AiRightTabRenderer: ({ className, components, }: {
9
+ className: string;
10
+ components: ComponentRegistryInfo[];
11
+ }) => React.JSX.Element;
12
+ export declare const ChatTabPanelRenderer: React.FC;
13
+ export declare const AiChatTabRenderer: ({ className, components, }: {
14
+ className: string;
15
+ components: ComponentRegistryInfo[];
16
+ }) => React.JSX.Element;
17
+ //# sourceMappingURL=tabbar.view.d.ts.map