@mybricks/plugin-ai 0.0.2 → 0.0.3

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 (249) hide show
  1. package/dist/_virtual/_rollupPluginBabelHelpers.js +164 -0
  2. package/dist/_virtual/_rollupPluginBabelHelpers.js.map +1 -0
  3. package/dist/agents/app.js +335 -0
  4. package/dist/agents/app.js.map +1 -0
  5. package/dist/agents/common.js +483 -0
  6. package/dist/agents/common.js.map +1 -0
  7. package/dist/agents/custom.js +16 -0
  8. package/dist/agents/custom.js.map +1 -0
  9. package/dist/agents/index.js +38 -0
  10. package/dist/agents/index.js.map +1 -0
  11. package/dist/agents/knowledges/knowledge-base.js +579 -0
  12. package/dist/agents/knowledges/knowledge-base.js.map +1 -0
  13. package/dist/agents/knowledges/knowledge-node.js +228 -0
  14. package/dist/agents/knowledges/knowledge-node.js.map +1 -0
  15. package/dist/agents/knowledges/types.js +105 -0
  16. package/dist/agents/knowledges/types.js.map +1 -0
  17. package/dist/agents/utils/config.js +229 -0
  18. package/dist/agents/utils/config.js.map +1 -0
  19. package/dist/agents/workspace/coding-manager.js +20 -0
  20. package/dist/agents/workspace/coding-manager.js.map +1 -0
  21. package/dist/agents/workspace/components-manager.js +113 -0
  22. package/dist/agents/workspace/components-manager.js.map +1 -0
  23. package/dist/agents/workspace/outline-focus.js +167 -0
  24. package/dist/agents/workspace/outline-focus.js.map +1 -0
  25. package/dist/agents/workspace/outline-info.js +430 -0
  26. package/dist/agents/workspace/outline-info.js.map +1 -0
  27. package/dist/agents/workspace/page-tree-generator.js +70 -0
  28. package/dist/agents/workspace/page-tree-generator.js.map +1 -0
  29. package/dist/agents/workspace/workspace.js +251 -0
  30. package/dist/agents/workspace/workspace.js.map +1 -0
  31. package/dist/agents/workspace-by-knowledges/providers/component-docs-provider.js +100 -0
  32. package/dist/agents/workspace-by-knowledges/providers/component-docs-provider.js.map +1 -0
  33. package/dist/agents/workspace-by-knowledges/providers/focus-info-provider.js +120 -0
  34. package/dist/agents/workspace-by-knowledges/providers/focus-info-provider.js.map +1 -0
  35. package/dist/agents/workspace-by-knowledges/providers/project-info-provider.js +146 -0
  36. package/dist/agents/workspace-by-knowledges/providers/project-info-provider.js.map +1 -0
  37. package/dist/agents/workspace-by-knowledges/test.js +242 -0
  38. package/dist/agents/workspace-by-knowledges/test.js.map +1 -0
  39. package/dist/agents/workspace-by-knowledges/utils/components-manager.js +132 -0
  40. package/dist/agents/workspace-by-knowledges/utils/components-manager.js.map +1 -0
  41. package/dist/agents/workspace-by-knowledges/utils/outline-focus.js +167 -0
  42. package/dist/agents/workspace-by-knowledges/utils/outline-focus.js.map +1 -0
  43. package/dist/agents/workspace-by-knowledges/utils/outline-info.js +430 -0
  44. package/dist/agents/workspace-by-knowledges/utils/outline-info.js.map +1 -0
  45. package/dist/agents/workspace-by-knowledges/workspace.js +169 -0
  46. package/dist/agents/workspace-by-knowledges/workspace.js.map +1 -0
  47. package/dist/api/cloud-components.js +85 -0
  48. package/dist/api/cloud-components.js.map +1 -0
  49. package/dist/api-record-replay/manager.js +168 -0
  50. package/dist/api-record-replay/manager.js.map +1 -0
  51. package/{src/api-record-replay/recorder.ts → dist/api-record-replay/recorder.js} +22 -32
  52. package/dist/api-record-replay/recorder.js.map +1 -0
  53. package/dist/api-record-replay/replayer.js +136 -0
  54. package/dist/api-record-replay/replayer.js.map +1 -0
  55. package/dist/components/attachments/index.js +124 -0
  56. package/dist/components/attachments/index.js.map +1 -0
  57. package/dist/components/attachments/index.less.js +8 -0
  58. package/dist/components/attachments/index.less.js.map +1 -0
  59. package/dist/components/icons/index.js +112 -0
  60. package/dist/components/icons/index.js.map +1 -0
  61. package/dist/components/icons/index.less.js +8 -0
  62. package/dist/components/icons/index.less.js.map +1 -0
  63. package/dist/components/mention/index.js +19 -0
  64. package/dist/components/mention/index.js.map +1 -0
  65. package/dist/components/mention/index.less.js +8 -0
  66. package/dist/components/mention/index.less.js.map +1 -0
  67. package/dist/components/messages/index.js +429 -0
  68. package/dist/components/messages/index.js.map +1 -0
  69. package/dist/components/messages/index.less.js +8 -0
  70. package/dist/components/messages/index.less.js.map +1 -0
  71. package/dist/components/sender/index.js +244 -0
  72. package/dist/components/sender/index.js.map +1 -0
  73. package/dist/components/sender/index.less.js +8 -0
  74. package/dist/components/sender/index.less.js.map +1 -0
  75. package/dist/context/RequestStatusTracker.js +44 -0
  76. package/dist/context/RequestStatusTracker.js.map +1 -0
  77. package/dist/context/index.js +45 -0
  78. package/dist/context/index.js.map +1 -0
  79. package/dist/data.js +4 -0
  80. package/dist/data.js.map +1 -0
  81. package/dist/index.js +306 -0
  82. package/dist/index.js.map +1 -0
  83. package/dist/plugin-ai/node_modules/style-inject/dist/style-inject.es.js +27 -0
  84. package/dist/plugin-ai/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
  85. package/dist/plugin-ai/package.json.js +8 -0
  86. package/dist/plugin-ai/package.json.js.map +1 -0
  87. package/dist/plugin-ai/test/index.js +206 -0
  88. package/dist/plugin-ai/test/index.js.map +1 -0
  89. package/dist/preset/createTemplates.js +29 -0
  90. package/dist/preset/createTemplates.js.map +1 -0
  91. package/dist/preset/index.js +13 -0
  92. package/dist/preset/index.js.map +1 -0
  93. package/dist/preset/prompts.js +34 -0
  94. package/dist/preset/prompts.js.map +1 -0
  95. package/{src/preset/user.ts → dist/preset/user.js} +4 -3
  96. package/dist/preset/user.js.map +1 -0
  97. package/dist/requestAsStream.js +269 -0
  98. package/dist/requestAsStream.js.map +1 -0
  99. package/dist/rxai/node_modules/idb/build/index.js +277 -0
  100. package/dist/rxai/node_modules/idb/build/index.js.map +1 -0
  101. package/dist/rxai/src/agent/base.js +16 -0
  102. package/dist/rxai/src/agent/base.js.map +1 -0
  103. package/dist/rxai/src/agent/planning.js +1076 -0
  104. package/dist/rxai/src/agent/planning.js.map +1 -0
  105. package/dist/rxai/src/agent/rxai.js +254 -0
  106. package/dist/rxai/src/agent/rxai.js.map +1 -0
  107. package/dist/rxai/src/error/base.js +39 -0
  108. package/dist/rxai/src/error/base.js.map +1 -0
  109. package/dist/rxai/src/prompt/base.js +11 -0
  110. package/dist/rxai/src/prompt/base.js.map +1 -0
  111. package/dist/rxai/src/prompt/planning.js +23 -0
  112. package/dist/rxai/src/prompt/planning.js.map +1 -0
  113. package/dist/rxai/src/prompt/tool.js +14 -0
  114. package/dist/rxai/src/prompt/tool.js.map +1 -0
  115. package/dist/rxai/src/request/request.js +123 -0
  116. package/dist/rxai/src/request/request.js.map +1 -0
  117. package/dist/rxai/src/tool/getHistoryRecords.js +65 -0
  118. package/dist/rxai/src/tool/getHistoryRecords.js.map +1 -0
  119. package/dist/rxai/src/tool/util.js +424 -0
  120. package/dist/rxai/src/tool/util.js.map +1 -0
  121. package/dist/rxai/src/utils/events.js +43 -0
  122. package/dist/rxai/src/utils/events.js.map +1 -0
  123. package/dist/rxai/src/utils/idb.js +240 -0
  124. package/dist/rxai/src/utils/idb.js.map +1 -0
  125. package/dist/rxai/src/utils/retry.js +32 -0
  126. package/dist/rxai/src/utils/retry.js.map +1 -0
  127. package/dist/rxai/src/utils/uuid.js +7 -0
  128. package/dist/rxai/src/utils/uuid.js.map +1 -0
  129. package/dist/startView/components/header/header.js +12 -0
  130. package/dist/startView/components/header/header.js.map +1 -0
  131. package/dist/startView/components/header/header.less.js +8 -0
  132. package/dist/startView/components/header/header.less.js.map +1 -0
  133. package/dist/startView/index.js +62 -0
  134. package/dist/startView/index.js.map +1 -0
  135. package/dist/startView/index.less.js +8 -0
  136. package/dist/startView/index.less.js.map +1 -0
  137. package/dist/tools/analyze-and-expand-prd.js +116 -0
  138. package/dist/tools/analyze-and-expand-prd.js.map +1 -0
  139. package/dist/tools/analyze-requirement-and-components.js +208 -0
  140. package/dist/tools/analyze-requirement-and-components.js.map +1 -0
  141. package/dist/tools/answer.js +33 -0
  142. package/dist/tools/answer.js.map +1 -0
  143. package/dist/tools/build-process.js +550 -0
  144. package/dist/tools/build-process.js.map +1 -0
  145. package/dist/tools/coding-subagent-as-tool.js +101 -0
  146. package/dist/tools/coding-subagent-as-tool.js.map +1 -0
  147. package/dist/tools/generate-ui-content.js +528 -0
  148. package/dist/tools/generate-ui-content.js.map +1 -0
  149. package/dist/tools/index.js +31 -0
  150. package/dist/tools/index.js.map +1 -0
  151. package/dist/tools/open-dsl.js +49 -0
  152. package/dist/tools/open-dsl.js.map +1 -0
  153. package/dist/tools/refactor-ui-content.js +292 -0
  154. package/dist/tools/refactor-ui-content.js.map +1 -0
  155. package/dist/tools/utils.js +832 -0
  156. package/dist/tools/utils.js.map +1 -0
  157. package/dist/types/index.js +8 -0
  158. package/dist/types/index.js.map +1 -0
  159. package/dist/view/components/header/header.js +59 -0
  160. package/dist/view/components/header/header.js.map +1 -0
  161. package/dist/view/components/header/header.less.js +8 -0
  162. package/dist/view/components/header/header.less.js.map +1 -0
  163. package/dist/view/index.js +184 -0
  164. package/dist/view/index.js.map +1 -0
  165. package/dist/view/index.less.js +8 -0
  166. package/dist/view/index.less.js.map +1 -0
  167. package/package.json +28 -6
  168. package/src/agents/app.ts +0 -301
  169. package/src/agents/common.ts +0 -471
  170. package/src/agents/custom.ts +0 -14
  171. package/src/agents/index.ts +0 -37
  172. package/src/agents/knowledges/README.md +0 -614
  173. package/src/agents/knowledges/SUMMARY.md +0 -527
  174. package/src/agents/knowledges/index.ts +0 -8
  175. package/src/agents/knowledges/knowledge-base.ts +0 -565
  176. package/src/agents/knowledges/knowledge-node.ts +0 -266
  177. package/src/agents/knowledges/types.ts +0 -208
  178. package/src/agents/utils/config.ts +0 -427
  179. package/src/agents/workspace/coding-manager.ts +0 -31
  180. package/src/agents/workspace/components-manager.ts +0 -124
  181. package/src/agents/workspace/outline-focus.ts +0 -188
  182. package/src/agents/workspace/outline-info.ts +0 -520
  183. package/src/agents/workspace/page-tree-generator.ts +0 -83
  184. package/src/agents/workspace/workspace.ts +0 -319
  185. package/src/agents/workspace-by-knowledges/MIGRATION.md +0 -568
  186. package/src/agents/workspace-by-knowledges/README.md +0 -521
  187. package/src/agents/workspace-by-knowledges/index.ts +0 -11
  188. package/src/agents/workspace-by-knowledges/providers/component-docs-provider.ts +0 -92
  189. package/src/agents/workspace-by-knowledges/providers/focus-info-provider.ts +0 -131
  190. package/src/agents/workspace-by-knowledges/providers/index.ts +0 -8
  191. package/src/agents/workspace-by-knowledges/providers/project-info-provider.ts +0 -151
  192. package/src/agents/workspace-by-knowledges/test.ts +0 -240
  193. package/src/agents/workspace-by-knowledges/types.ts +0 -56
  194. package/src/agents/workspace-by-knowledges/utils/components-manager.ts +0 -145
  195. package/src/agents/workspace-by-knowledges/utils/index.ts +0 -8
  196. package/src/agents/workspace-by-knowledges/utils/outline-focus.ts +0 -178
  197. package/src/agents/workspace-by-knowledges/utils/outline-info.ts +0 -521
  198. package/src/agents/workspace-by-knowledges/workspace.ts +0 -166
  199. package/src/api/cloud-components.ts +0 -129
  200. package/src/api-record-replay/README.md +0 -187
  201. package/src/api-record-replay/index.ts +0 -11
  202. package/src/api-record-replay/manager.ts +0 -168
  203. package/src/api-record-replay/replayer.ts +0 -148
  204. package/src/components/attachments/index.less +0 -117
  205. package/src/components/attachments/index.tsx +0 -136
  206. package/src/components/icons/index.less +0 -8
  207. package/src/components/icons/index.tsx +0 -44
  208. package/src/components/index.less +0 -34
  209. package/src/components/mention/index.less +0 -23
  210. package/src/components/mention/index.tsx +0 -19
  211. package/src/components/messages/index.less +0 -1013
  212. package/src/components/messages/index.tsx +0 -519
  213. package/src/components/sender/index.less +0 -203
  214. package/src/components/sender/index.tsx +0 -298
  215. package/src/components/types.ts +0 -31
  216. package/src/constants/index.ts +0 -8
  217. package/src/context/RequestStatusTracker.ts +0 -50
  218. package/src/context/index.ts +0 -83
  219. package/src/data.ts +0 -5
  220. package/src/global.d.ts +0 -100
  221. package/src/index.tsx +0 -264
  222. package/src/mock.ts +0 -1267
  223. package/src/preset/agents.ts +0 -380
  224. package/src/preset/createTemplates.ts +0 -25
  225. package/src/preset/index.ts +0 -12
  226. package/src/preset/prompts.ts +0 -235
  227. package/src/preset/requestAsStream.ts +0 -246
  228. package/src/startView/components/header/header.less +0 -17
  229. package/src/startView/components/header/header.tsx +0 -15
  230. package/src/startView/components/index.ts +0 -1
  231. package/src/startView/index.less +0 -34
  232. package/src/startView/index.tsx +0 -61
  233. package/src/tools/analyze-and-expand-prd.ts +0 -272
  234. package/src/tools/analyze-requirement-and-components.ts +0 -589
  235. package/src/tools/answer.ts +0 -59
  236. package/src/tools/build-process.ts +0 -1174
  237. package/src/tools/coding-subagent-as-tool.ts +0 -119
  238. package/src/tools/generate-ui-content.ts +0 -1083
  239. package/src/tools/index.ts +0 -28
  240. package/src/tools/open-dsl.ts +0 -69
  241. package/src/tools/refactor-ui-content.ts +0 -801
  242. package/src/tools/type.d.ts +0 -12
  243. package/src/tools/utils.ts +0 -914
  244. package/src/types/index.ts +0 -4
  245. package/src/view/components/header/header.less +0 -51
  246. package/src/view/components/header/header.tsx +0 -60
  247. package/src/view/components/index.ts +0 -1
  248. package/src/view/index.less +0 -5
  249. package/src/view/index.tsx +0 -168
@@ -1,4 +0,0 @@
1
- export enum DeviceType {
2
- Desktop = 'desktop',
3
- Mobile = 'mobile'
4
- }
@@ -1,51 +0,0 @@
1
- .header {
2
- width: 100%;
3
- height: 40px;
4
- min-height: 40px;
5
- display: flex;
6
- align-items: center;
7
- padding: 0 60px 0 13px;
8
- // justify-content: space-between;
9
- border-bottom: 1px solid #f3f3f3;
10
- background: rgba(255, 255, 255, .8);
11
- gap: 6px;
12
-
13
- .title {
14
- font-weight: 700;
15
- font-size: 12px;
16
- color: rgb(25, 25, 25);
17
- line-height: 18px;
18
- cursor: default;
19
- }
20
-
21
- .actions {
22
- display: flex;
23
- align-items: center;
24
-
25
- .action {
26
- display: flex;
27
- align-items: center;
28
- cursor: pointer;
29
- color: #AAA;
30
- width: 20px;
31
- height: 20px;
32
- justify-content: center;
33
-
34
- &:hover {
35
- color: var(--mybricks-color-primary, #FA6400);
36
- }
37
-
38
- svg {
39
- width: 12px;
40
- height: 12px;
41
- }
42
-
43
- &.export {
44
- svg {
45
- width: 14px;
46
- height: 14px;
47
- }
48
- }
49
- }
50
- }
51
- }
@@ -1,60 +0,0 @@
1
- import React from "react"
2
- import classNames from "classnames"
3
- import { Rxai } from "@mybricks/rxai";
4
- import { Delete, Export } from "../../../components/icons"
5
- import { context } from "../../../context";
6
- import css from "./header.less"
7
-
8
- interface HeaderParams {
9
- rxai: Rxai;
10
- }
11
-
12
- const Header = (params: HeaderParams) => {
13
- const clear = () => {
14
- params.rxai.clear();
15
- }
16
-
17
- const exportRxai = async () => {
18
- try {
19
- const content = await params.rxai.export();
20
- downloadToFile({
21
- content: content,
22
- name: `rxai-${new Date().getTime()}.json`
23
- })
24
- } catch (e) {
25
- console.error("[@mybricks/plugin-ai - exportRxai - error]", e);
26
- }
27
- }
28
-
29
- return (
30
- <div className={classNames(css.header)}>
31
- <span className={classNames(css.title)}>
32
- {/* MyBricks.ai */}
33
- 智能助手
34
- </span>
35
- <div className={css['actions']}>
36
- <div className={css['action']} data-mybricks-tip={"清空对话记录"} onClick={clear}>
37
- <Delete />
38
- </div>
39
- <div className={classNames(css['action'], css['export'])} data-mybricks-tip={"导出对话记录"} onClick={exportRxai}>
40
- <Export />
41
- </div>
42
- </div>
43
- </div>
44
- )
45
- }
46
-
47
- export { Header }
48
-
49
- function downloadToFile ({ content, name }: { content: any, name: string }) {
50
- const eleLink = document.createElement('a')
51
- eleLink.download = name
52
- eleLink.style.display = 'none'
53
-
54
- const blob = new Blob([JSON.stringify(content)])
55
-
56
- eleLink.href = URL.createObjectURL(blob)
57
- document.body.appendChild(eleLink)
58
- eleLink.click()
59
- document.body.removeChild(eleLink)
60
- }
@@ -1 +0,0 @@
1
- export * from "./header/header";
@@ -1,5 +0,0 @@
1
- .view {
2
- display: flex;
3
- flex-direction: column;
4
- height: 100%;
5
- }
@@ -1,168 +0,0 @@
1
- import React, { useEffect, useRef, useState } from "react"
2
- import classNames from "classnames";
3
- import { Header } from "./components";
4
- import { Messages } from "../components/messages";
5
- import { Sender, SenderRef, SenderProps } from "../components/sender";
6
- import { context } from "../context";
7
- import { Agents } from '../agents'
8
- import { AbstractAgent } from "../agents/utils/config";
9
- import css from "./index.less";
10
-
11
- interface ViewProps {
12
- api: AiViewApi;
13
- user: any;
14
- copilot: any;
15
- }
16
-
17
- const View = ({ user, copilot, api }: ViewProps) => {
18
- const senderRef = useRef<SenderRef>(null);
19
- const [rxai, setRxai] = useState(context.rxai);
20
- const [vibeCoding, setVibeCoding] = useState(false);
21
-
22
- const PLACEHOLDER_MAP = {
23
- normal: `您好,我是${context.name},请详细描述您的需求`,
24
- disabled: `您好,我是${context.name},请先从画布中选择场景或组件,再开始对话`,
25
- loading: "处理中,请稍后..."
26
- }
27
-
28
- const [senderStateProps, setSenderStateProps] = useState(() => {
29
- return {
30
- loading: false,
31
- disabled: true,
32
- placeholder: PLACEHOLDER_MAP["disabled"]
33
- }
34
- })
35
- const focusID = useRef<string>(null);
36
-
37
- useEffect(() => {
38
- const statusChange = (state: "loading" | "normal" | "disabled") => {
39
- if (state === "disabled") {
40
- setSenderStateProps({
41
- disabled: true,
42
- loading: false,
43
- placeholder: PLACEHOLDER_MAP["disabled"]
44
- })
45
- } else {
46
- const bool = state === "loading";
47
- setSenderStateProps({
48
- disabled: bool,
49
- loading: bool,
50
- placeholder: PLACEHOLDER_MAP[state]
51
- })
52
- }
53
- }
54
-
55
- const disconnectAiViewDisplay = context.events.on("aiViewDisplay", () => {
56
- setTimeout(() => {
57
- senderRef.current!.focus();
58
- })
59
- }, true)
60
- const disconnectFocus = context.events.on("focus", (focus) => {
61
- if (!focus) {
62
- senderRef.current!.setMentions([]);
63
- focusID.current = null;
64
- statusChange("disabled");
65
- setRxai(context.rxai);
66
- } else {
67
- const type = focus.type;
68
- const id = ["page", "section"].includes(type) ? focus.pageId : focus.comId;
69
- const { onProgress, ...other } = focus;
70
- senderRef.current!.setMentions([other] as any);
71
- setVibeCoding(other.vibeCoding || false);
72
- focusID.current = id;
73
- const status = context.requestStatusTracker.getStatus(id);
74
- statusChange(status.state === "pending" ? "loading" : "normal");
75
- // setTimeout(() => {
76
- // senderRef.current!.focus();
77
- // })
78
- if (focus.vibeCoding) {
79
- setTimeout(() => {
80
- // TODO: ai组件库里注册agents的时机不对
81
- const agent = context.agents!.find((agent) => {
82
- return agent instanceof AbstractAgent && agent.type === "vibeCoding"
83
- });
84
- if (agent) {
85
- const rxai = (agent as AbstractAgent).getRxai({
86
- key: `${context.pluginParams.key}_${focus.pageId}_${focus.comId}`,
87
- })
88
- setRxai(rxai);
89
- } else {
90
- setRxai(context.rxai);
91
- }
92
- })
93
- } else {
94
- setRxai(context.rxai);
95
- }
96
- }
97
- }, true)
98
- const disconnectPromiseStatusTracker = context.requestStatusTracker.events.on("promise", (promise) => {
99
- if (promise.id === focusID.current) {
100
- statusChange(promise.status.state === "pending" ? "loading" : "normal");
101
- }
102
- })
103
- return () => {
104
- disconnectAiViewDisplay()
105
- disconnectFocus()
106
- disconnectPromiseStatusTracker()
107
- }
108
- }, [])
109
-
110
- const onSend = (sendMessage: Parameters<SenderProps["onSend"]>[0]) => {
111
- const { message, attachments, ...extension } = sendMessage;
112
-
113
- if (!focusID.current) {
114
- return;
115
- }
116
-
117
- context.requestStatusTracker.track(focusID.current, Agents.requestAgent({
118
- message,
119
- attachments,
120
- extension,
121
- onProgress: context.currentFocus?.onProgress
122
- }));
123
- }
124
-
125
- const onMentionClick: NonNullable<SenderProps["onMentionClick"]> = (mention) => {
126
- const { id, type, comId, pageId } = mention;
127
- api[type === "page" ? "focusPage" : "focusCom"]((type === "page" ? pageId : comId) || id as string);
128
- }
129
-
130
- const onMessagesSend = (sendMessage: Parameters<SenderProps["onSend"]>[0]) => {
131
- const { message, attachments, insertAfter, ...extension } = sendMessage;
132
- const { mentions } = extension
133
- const mention = sendMessage.mentions[0];
134
- context.requestStatusTracker.track(mention.type === "page" ? mention.pageId : mention.comId, Agents.requestAgent({
135
- message,
136
- attachments,
137
- insertAfter,
138
- extension,
139
- focus: mentions[0],
140
- onProgress: context.currentFocus?.onProgress
141
- }));
142
- }
143
-
144
- return (
145
- <div className={classNames(css.view)} style={vibeCoding ? ({ '--mybricks-color-primary': '#16A157' } as React.CSSProperties) : undefined}>
146
- <Header rxai={rxai}/>
147
- <Messages
148
- key={rxai.key}
149
- user={user}
150
- copilot={copilot}
151
- rxai={rxai}
152
- onSend={onMessagesSend}
153
- onMentionClick={onMentionClick}
154
- />
155
- <Sender
156
- ref={senderRef}
157
- loading={senderStateProps.loading}
158
- placeholder={senderStateProps.placeholder}
159
- disabled={senderStateProps.disabled}
160
- mode="mention"
161
- onSend={onSend}
162
- onMentionClick={onMentionClick}
163
- />
164
- </div>
165
- )
166
- }
167
-
168
- export { View }