@opentiny/tiny-robot 0.4.2-alpha.4 → 0.4.2-alpha.5

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 (246) hide show
  1. package/dist/action-group/ActionGroup.vue.d.ts +26 -0
  2. package/dist/action-group/ActionGroupItem.vue.d.ts +18 -0
  3. package/dist/action-group/index.d.ts +12 -0
  4. package/dist/action-group/index.type.d.ts +17 -0
  5. package/dist/anchor/components/AnchorItem.vue.d.ts +24 -0
  6. package/dist/anchor/components/AnchorList.vue.d.ts +20 -0
  7. package/dist/anchor/components/AnchorOverlay.vue.d.ts +33 -0
  8. package/dist/anchor/components/AnchorSearch.vue.d.ts +7 -0
  9. package/dist/anchor/composables/index.d.ts +5 -0
  10. package/dist/anchor/composables/useActiveSync.d.ts +10 -0
  11. package/dist/anchor/composables/useFloatingOffset.d.ts +6 -0
  12. package/dist/anchor/composables/useNavController.d.ts +12 -0
  13. package/dist/anchor/composables/useOverlayInteractions.d.ts +6 -0
  14. package/dist/anchor/composables/useTargetFeedback.d.ts +5 -0
  15. package/dist/anchor/defaults.d.ts +16 -0
  16. package/dist/anchor/index.d.ts +7 -0
  17. package/dist/anchor/index.type.d.ts +60 -0
  18. package/dist/anchor/index.vue.d.ts +159 -0
  19. package/dist/anchor/internal.type.d.ts +103 -0
  20. package/dist/anchor/utils/scroll.d.ts +7 -0
  21. package/dist/anchor/utils/target.d.ts +6 -0
  22. package/dist/attachments/components/FileCard.vue.d.ts +18 -0
  23. package/dist/attachments/components/ImagePreview.vue.d.ts +17 -0
  24. package/dist/attachments/components/index.d.ts +2 -0
  25. package/dist/attachments/composables/index.d.ts +5 -0
  26. package/dist/attachments/composables/useFileCard.d.ts +15 -0
  27. package/dist/attachments/composables/useFileType.d.ts +20 -0
  28. package/dist/attachments/composables/useImagePreview.d.ts +18 -0
  29. package/dist/attachments/composables/useListType.d.ts +11 -0
  30. package/dist/attachments/index.d.ts +7 -0
  31. package/dist/attachments/index.js +2 -2
  32. package/dist/attachments/index.type.d.ts +70 -0
  33. package/dist/attachments/index.vue.d.ts +27 -0
  34. package/dist/attachments/utils.d.ts +3 -0
  35. package/dist/base-popper/components/Popper.vue.d.ts +28 -0
  36. package/dist/base-popper/index.d.ts +2 -0
  37. package/dist/base-popper/index.vue.d.ts +41 -0
  38. package/dist/bubble/Bubble.vue.d.ts +39 -0
  39. package/dist/bubble/BubbleBoxWrapper.vue.d.ts +22 -0
  40. package/dist/bubble/BubbleContentWrapper.vue.d.ts +16 -0
  41. package/dist/bubble/BubbleItem.vue.d.ts +36 -0
  42. package/dist/bubble/BubbleList.vue.d.ts +41 -0
  43. package/dist/bubble/BubbleProvider.vue.d.ts +18 -0
  44. package/dist/bubble/composables/index.d.ts +10 -0
  45. package/dist/bubble/composables/useBubbleBoxRenderer.d.ts +18 -0
  46. package/dist/bubble/composables/useBubbleContentRenderer.d.ts +18 -0
  47. package/dist/bubble/composables/useBubbleStateChange.d.ts +2 -0
  48. package/dist/bubble/composables/useBubbleStore.d.ts +16 -0
  49. package/dist/bubble/composables/useContentResolver.d.ts +5 -0
  50. package/dist/bubble/composables/useCopyCleanup.d.ts +6 -0
  51. package/dist/bubble/composables/useMessageContent.d.ts +5 -0
  52. package/dist/bubble/composables/useMessageGroup.d.ts +4 -0
  53. package/dist/bubble/composables/useOmitMessageFields.d.ts +12 -0
  54. package/dist/bubble/composables/useToolCall.d.ts +25 -0
  55. package/dist/bubble/constants.d.ts +42 -0
  56. package/dist/bubble/index.d.ts +19 -0
  57. package/dist/bubble/index.type.d.ts +171 -0
  58. package/dist/bubble/renderers/Box.vue.d.ts +18 -0
  59. package/dist/bubble/renderers/Image.vue.d.ts +4 -0
  60. package/dist/bubble/renderers/Loading.vue.d.ts +4 -0
  61. package/dist/bubble/renderers/Markdown.vue.d.ts +4 -0
  62. package/dist/bubble/renderers/Reasoning.vue.d.ts +9 -0
  63. package/dist/bubble/renderers/Text.vue.d.ts +4 -0
  64. package/dist/bubble/renderers/Tool.vue.d.ts +14 -0
  65. package/dist/bubble/renderers/ToolRole.vue.d.ts +4 -0
  66. package/dist/bubble/renderers/Tools.vue.d.ts +4 -0
  67. package/dist/bubble/renderers/allRenderers.d.ts +93 -0
  68. package/dist/bubble/renderers/defaultRenderers.d.ts +27 -0
  69. package/dist/bubble/utils.d.ts +7 -0
  70. package/dist/chat/components/ChatConversation.vue.d.ts +70 -0
  71. package/dist/chat/components/ChatLauncherButton.vue.d.ts +12 -0
  72. package/dist/chat/components/ChatMcpTrigger.vue.d.ts +30 -0
  73. package/dist/chat/components/ChatThemeToggleButton.vue.d.ts +2 -0
  74. package/dist/chat/components/ChatWelcome.vue.d.ts +13 -0
  75. package/dist/chat/composables/useChatConversation.d.ts +37 -0
  76. package/dist/chat/composables/useChatMcp.d.ts +29 -0
  77. package/dist/chat/composables/useChatModel.d.ts +27 -0
  78. package/dist/chat/index.d.ts +9 -0
  79. package/dist/chat/index.js +13701 -0
  80. package/dist/chat/index.type.d.ts +88 -0
  81. package/dist/chat/index.vue.d.ts +58 -0
  82. package/dist/container/index.d.ts +7 -0
  83. package/dist/container/index.type.d.ts +20 -0
  84. package/dist/container/index.vue.d.ts +32 -0
  85. package/dist/conversations/index.d.ts +7 -0
  86. package/dist/conversations/index.vue.d.ts +2 -0
  87. package/dist/drag-overlay/constants.d.ts +17 -0
  88. package/dist/drag-overlay/directives/vDropzone.d.ts +14 -0
  89. package/dist/drag-overlay/index.d.ts +7 -0
  90. package/dist/drag-overlay/index.type.d.ts +105 -0
  91. package/dist/drag-overlay/index.vue.d.ts +20 -0
  92. package/dist/dropdown-menu/composables/usePopperHover.d.ts +6 -0
  93. package/dist/dropdown-menu/index.d.ts +7 -0
  94. package/dist/dropdown-menu/index.js +17 -17
  95. package/dist/dropdown-menu/index.type.d.ts +42 -0
  96. package/dist/dropdown-menu/index.vue.d.ts +217 -0
  97. package/dist/feedback/components/SourceList.vue.d.ts +11 -0
  98. package/dist/feedback/components/index.d.ts +1 -0
  99. package/dist/feedback/index.d.ts +7 -0
  100. package/dist/feedback/index.type.d.ts +25 -0
  101. package/dist/feedback/index.vue.d.ts +13 -0
  102. package/dist/flow-layout-buttons/index.d.ts +7 -0
  103. package/dist/flow-layout-buttons/index.js +1 -1
  104. package/dist/flow-layout-buttons/index.type.d.ts +35 -0
  105. package/dist/flow-layout-buttons/index.vue.d.ts +22 -0
  106. package/dist/history/components/Empty.vue.d.ts +7 -0
  107. package/dist/history/components/MenuList.vue.d.ts +24 -0
  108. package/dist/history/composables/useRenameEditor.d.ts +22 -0
  109. package/dist/history/constants.d.ts +1 -0
  110. package/dist/history/index.d.ts +7 -0
  111. package/dist/history/index.type.d.ts +33 -0
  112. package/dist/history/index.vue.d.ts +18 -0
  113. package/dist/icon-button/index.d.ts +7 -0
  114. package/dist/icon-button/index.type.d.ts +7 -0
  115. package/dist/icon-button/index.vue.d.ts +6 -0
  116. package/dist/index.d.ts +49 -5018
  117. package/dist/index.js +1 -1
  118. package/dist/mcp-add-form/components/CodeEditor.vue.d.ts +9 -0
  119. package/dist/mcp-add-form/components/FormEditor.vue.d.ts +10 -0
  120. package/dist/mcp-add-form/components/index.d.ts +2 -0
  121. package/dist/mcp-add-form/index.d.ts +7 -0
  122. package/dist/mcp-add-form/index.type.d.ts +19 -0
  123. package/dist/mcp-add-form/index.vue.d.ts +13 -0
  124. package/dist/mcp-server-picker/components/NoData.vue.d.ts +7 -0
  125. package/dist/mcp-server-picker/components/PluginCard.vue.d.ts +40 -0
  126. package/dist/mcp-server-picker/components/PluginModal.vue.d.ts +15 -0
  127. package/dist/mcp-server-picker/components/index.d.ts +3 -0
  128. package/dist/mcp-server-picker/index.d.ts +7 -0
  129. package/dist/mcp-server-picker/index.js +83 -80
  130. package/dist/mcp-server-picker/index.type.d.ts +99 -0
  131. package/dist/mcp-server-picker/index.vue.d.ts +71 -0
  132. package/dist/prompts/index.d.ts +12 -0
  133. package/dist/prompts/index.type.d.ts +59 -0
  134. package/dist/prompts/prompt.vue.d.ts +5 -0
  135. package/dist/prompts/prompts.vue.d.ts +20 -0
  136. package/dist/sender/components/editor-content/index.vue.d.ts +4 -0
  137. package/dist/sender/components/footer/index.vue.d.ts +38 -0
  138. package/dist/sender/components/layouts/MultiLineLayout.vue.d.ts +43 -0
  139. package/dist/sender/components/layouts/SingleLineLayout.vue.d.ts +32 -0
  140. package/dist/sender/composables/index.d.ts +7 -0
  141. package/dist/sender/composables/useAutoSize.d.ts +5 -0
  142. package/dist/sender/composables/useEditor.d.ts +13 -0
  143. package/dist/sender/composables/useKeyboardShortcuts.d.ts +7 -0
  144. package/dist/sender/composables/useModeSwitch.d.ts +4 -0
  145. package/dist/sender/composables/useSenderCore.d.ts +31 -0
  146. package/dist/sender/composables/useSlotScope.d.ts +10 -0
  147. package/dist/sender/context/index.d.ts +6 -0
  148. package/dist/sender/context/types.d.ts +7 -0
  149. package/dist/sender/extensions/constants.d.ts +94 -0
  150. package/dist/sender/extensions/index.d.ts +12 -0
  151. package/dist/sender/extensions/mention/commands.d.ts +20 -0
  152. package/dist/sender/extensions/mention/components/mention-list.vue.d.ts +18 -0
  153. package/dist/sender/extensions/mention/components/mention-view.vue.d.ts +19 -0
  154. package/dist/sender/extensions/mention/extension.d.ts +6 -0
  155. package/dist/sender/extensions/mention/index.d.ts +22 -0
  156. package/dist/sender/extensions/mention/plugin.d.ts +16 -0
  157. package/dist/sender/extensions/mention/types.d.ts +126 -0
  158. package/dist/sender/extensions/mention/utils.d.ts +34 -0
  159. package/dist/sender/extensions/suggestion/extension.d.ts +8 -0
  160. package/dist/sender/extensions/suggestion/index.d.ts +20 -0
  161. package/dist/sender/extensions/suggestion/plugin.d.ts +21 -0
  162. package/dist/sender/extensions/suggestion/suggestion-list.vue.d.ts +46 -0
  163. package/dist/sender/extensions/suggestion/types.d.ts +254 -0
  164. package/dist/sender/extensions/suggestion/utils/filter.d.ts +29 -0
  165. package/dist/sender/extensions/suggestion/utils/highlight.d.ts +73 -0
  166. package/dist/sender/extensions/template/block/extension.d.ts +6 -0
  167. package/dist/sender/extensions/template/block/plugins.d.ts +13 -0
  168. package/dist/sender/extensions/template/block/template-block-view.vue.d.ts +14 -0
  169. package/dist/sender/extensions/template/commands.d.ts +31 -0
  170. package/dist/sender/extensions/template/extension.d.ts +6 -0
  171. package/dist/sender/extensions/template/index.d.ts +21 -0
  172. package/dist/sender/extensions/template/select/dropdown-manager.d.ts +23 -0
  173. package/dist/sender/extensions/template/select/extension.d.ts +5 -0
  174. package/dist/sender/extensions/template/select/plugins.d.ts +34 -0
  175. package/dist/sender/extensions/template/select/template-select-view.vue.d.ts +20 -0
  176. package/dist/sender/extensions/template/types.d.ts +100 -0
  177. package/dist/sender/extensions/template/utils.d.ts +20 -0
  178. package/dist/sender/extensions/utils/id-generator.d.ts +16 -0
  179. package/dist/sender/extensions/utils/index.d.ts +7 -0
  180. package/dist/sender/extensions/utils/keyboard.d.ts +49 -0
  181. package/dist/sender/extensions/utils/position.d.ts +25 -0
  182. package/dist/sender/index.d.ts +136 -0
  183. package/dist/sender/index.type.d.ts +302 -0
  184. package/dist/sender/index.vue.d.ts +90 -0
  185. package/dist/sender/types/base.d.ts +239 -0
  186. package/dist/sender/types/components.d.ts +68 -0
  187. package/dist/sender/types/composables.d.ts +122 -0
  188. package/dist/sender/types/context.d.ts +132 -0
  189. package/dist/sender/types/slots.d.ts +67 -0
  190. package/dist/sender/utils/countGraphemes.d.ts +1 -0
  191. package/dist/sender-actions/action-button/index.vue.d.ts +23 -0
  192. package/dist/sender-actions/clear-button/index.vue.d.ts +2 -0
  193. package/dist/sender-actions/clear-button/useClearButtonState.d.ts +6 -0
  194. package/dist/sender-actions/default-actions/index.vue.d.ts +17 -0
  195. package/dist/sender-actions/index.d.ts +21 -0
  196. package/dist/sender-actions/index.type.d.ts +7 -0
  197. package/dist/sender-actions/submit-button/index.vue.d.ts +2 -0
  198. package/dist/sender-actions/types/common.d.ts +40 -0
  199. package/dist/sender-actions/types/index.d.ts +5 -0
  200. package/dist/sender-actions/types/tooltip.d.ts +7 -0
  201. package/dist/sender-actions/upload-button/index.type.d.ts +57 -0
  202. package/dist/sender-actions/upload-button/index.vue.d.ts +16 -0
  203. package/dist/sender-actions/utils/tooltip.d.ts +8 -0
  204. package/dist/sender-actions/voice-button/index.type.d.ts +78 -0
  205. package/dist/sender-actions/voice-button/index.vue.d.ts +43 -0
  206. package/dist/sender-actions/voice-button/speech.types.d.ts +40 -0
  207. package/dist/sender-actions/voice-button/useSpeechHandler.d.ts +10 -0
  208. package/dist/sender-actions/voice-button/webSpeechHandler.d.ts +40 -0
  209. package/dist/sender-actions/word-counter/index.vue.d.ts +2 -0
  210. package/dist/sender-compat/index.d.ts +7 -0
  211. package/dist/sender-compat/index.type.d.ts +91 -0
  212. package/dist/sender-compat/index.vue.d.ts +532 -0
  213. package/dist/shared/composables/createTeleport.d.ts +2 -0
  214. package/dist/shared/composables/index.d.ts +5 -0
  215. package/dist/shared/composables/useAutoScroll.d.ts +25 -0
  216. package/dist/shared/composables/useSlotRefs.d.ts +12 -0
  217. package/dist/shared/composables/useTeleportTarget.d.ts +11 -0
  218. package/dist/shared/composables/useTouchDevice.d.ts +3 -0
  219. package/dist/shared/utils.d.ts +7 -0
  220. package/dist/style.css +1 -1
  221. package/dist/suggestion-pills/components/PillButton.vue.d.ts +16 -0
  222. package/dist/suggestion-pills/components/index.d.ts +1 -0
  223. package/dist/suggestion-pills/index.d.ts +13 -0
  224. package/dist/suggestion-pills/index.js +12 -12
  225. package/dist/suggestion-pills/index.type.d.ts +45 -0
  226. package/dist/suggestion-pills/index.vue.d.ts +44 -0
  227. package/dist/suggestion-popover/components/Backdrop.vue.d.ts +5 -0
  228. package/dist/suggestion-popover/components/Header.vue.d.ts +4 -0
  229. package/dist/suggestion-popover/components/Loading.vue.d.ts +17 -0
  230. package/dist/suggestion-popover/components/NoData.vue.d.ts +17 -0
  231. package/dist/suggestion-popover/components/Tooltip.vue.d.ts +19 -0
  232. package/dist/suggestion-popover/index.d.ts +7 -0
  233. package/dist/suggestion-popover/index.js +35 -35
  234. package/dist/suggestion-popover/index.type.d.ts +80 -0
  235. package/dist/suggestion-popover/index.vue.d.ts +262 -0
  236. package/dist/theme-provider/constants.d.ts +6 -0
  237. package/dist/theme-provider/index.d.ts +9 -0
  238. package/dist/theme-provider/index.js +32 -41
  239. package/dist/theme-provider/index.type.d.ts +18 -0
  240. package/dist/theme-provider/index.vue.d.ts +32 -0
  241. package/dist/theme-provider/useTheme.d.ts +11 -0
  242. package/dist/useTheme.js +22 -0
  243. package/dist/welcome/index.d.ts +7 -0
  244. package/dist/welcome/index.type.d.ts +10 -0
  245. package/dist/welcome/index.vue.d.ts +18 -0
  246. package/package.json +22 -3
@@ -0,0 +1,19 @@
1
+ import { App } from 'vue';
2
+ import { default as BubbleComp } from './Bubble.vue';
3
+ import { default as BubbleListComp } from './BubbleList.vue';
4
+ import { default as BubbleProviderComp } from './BubbleProvider.vue';
5
+ declare const bubbleInstall: (app: App) => void;
6
+ export declare const Bubble: typeof BubbleComp & {
7
+ install: typeof bubbleInstall;
8
+ };
9
+ declare const bubbleListInstall: (app: App) => void;
10
+ export declare const BubbleList: typeof BubbleListComp & {
11
+ install: typeof bubbleListInstall;
12
+ };
13
+ declare const bubbleProviderInstall: (app: App) => void;
14
+ export declare const BubbleProvider: typeof BubbleProviderComp & {
15
+ install: typeof bubbleProviderInstall;
16
+ };
17
+ export { useBubbleBoxRenderer, useBubbleContentRenderer, useBubbleStateChangeFn, useMessageContent, useOmitMessageFields, useToolCall, } from './composables';
18
+ export { BubbleRendererMatchPriority } from './constants';
19
+ export { BubbleRenderers } from './renderers/allRenderers';
@@ -0,0 +1,171 @@
1
+ import { Component, VNode } from 'vue';
2
+ /**
3
+ * 工具调用接口(支持 OpenAI 格式)
4
+ */
5
+ export interface ToolCall {
6
+ id: string;
7
+ type: 'function' | string;
8
+ function: {
9
+ name: string;
10
+ arguments: string;
11
+ };
12
+ [x: string]: any;
13
+ }
14
+ export type ChatMessageContentItem = {
15
+ type: string;
16
+ [key: string]: any;
17
+ };
18
+ export type ChatMessageContent = string | ChatMessageContentItem[];
19
+ /**
20
+ * 聊天消息接口(支持 OpenAI 格式)
21
+ */
22
+ interface ChatMessage<T extends ChatMessageContent = ChatMessageContent> {
23
+ role: string;
24
+ content?: T;
25
+ reasoning_content?: string;
26
+ tool_calls?: ToolCall[];
27
+ tool_call_id?: string;
28
+ name?: string;
29
+ }
30
+ type ChatMessageWithOptionalRole<T extends ChatMessageContent = ChatMessageContent> = Omit<ChatMessage<T>, 'role'> & {
31
+ role?: string;
32
+ };
33
+ export type BubbleMessage<T extends ChatMessageContent = ChatMessageContent, S extends Record<string, unknown> = Record<string, unknown>> = ChatMessageWithOptionalRole<T> & {
34
+ id?: string;
35
+ loading?: boolean;
36
+ state?: S;
37
+ };
38
+ export type BubbleProps = BubbleMessage & {
39
+ hidden?: boolean;
40
+ avatar?: VNode | Component;
41
+ placement?: 'start' | 'end';
42
+ shape?: 'corner' | 'rounded' | 'none';
43
+ contentRenderMode?: 'single' | 'split';
44
+ contentResolver?: (message: BubbleMessage) => ChatMessageContent | undefined;
45
+ fallbackBoxRenderer?: Component<BubbleBoxRendererProps>;
46
+ fallbackContentRenderer?: Component<BubbleContentRendererProps>;
47
+ };
48
+ export type BubbleMessageGroup = {
49
+ role: string;
50
+ messages: BubbleMessage[];
51
+ messageIndexes: number[];
52
+ startIndex: number;
53
+ };
54
+ export type BubbleAttributes = Record<string, unknown>;
55
+ export type BubbleBoxRendererAttributeMap = BubbleAttributes;
56
+ export type BubbleBoxRendererAttributesResolver = (messages: BubbleMessage[], content: ChatMessageContentItem | undefined, contentIndex: number | undefined) => BubbleBoxRendererAttributeMap | undefined;
57
+ export type BubbleBoxAttributesResolver = (messages: BubbleMessage[], content: ChatMessageContentItem | undefined, contentIndex: number | undefined) => BubbleAttributes | undefined;
58
+ export type BubbleContentAttributesResolver = (message: BubbleMessage, content: ChatMessageContentItem, contentIndex: number) => BubbleAttributes | undefined;
59
+ export type BubbleBoxAttributesConfig = BubbleAttributes | BubbleBoxAttributesResolver;
60
+ export type BubbleContentAttributesConfig = BubbleAttributes | BubbleContentAttributesResolver;
61
+ export type BubbleBoxRendererMatch = {
62
+ /**
63
+ * 匹配函数,用于判断是否应该使用此渲染器
64
+ * @param messages - 消息数组
65
+ * @param content - 要渲染的内容项。仅在 `split` 模式下(contentIndex 为数字)才会传入;为当前消息(messages[0])经过 `contentResolver` 解析后的内容;`messages[0].content` 一定是一个数组,`content` 则为对应索引的内容项,即 `messages[0].content[contentIndex]`;当 contentIndex 为 undefined 时,content 也为 undefined
66
+ * @param contentIndex - 内容索引,用于指定要渲染的内容项。仅在 split 模式下才会传入(为数字),此时 messages 数组长度为 1
67
+ * @returns 如果匹配则返回 true,否则返回 false
68
+ */
69
+ find: (messages: BubbleMessage[], content: ChatMessageContentItem | undefined, contentIndex: number | undefined) => boolean;
70
+ renderer: Component<BubbleBoxRendererProps>;
71
+ priority?: number;
72
+ attributes?: BubbleBoxRendererAttributeMap | BubbleBoxRendererAttributesResolver;
73
+ };
74
+ export type BubbleContentRendererMatch = {
75
+ /**
76
+ * 匹配函数,用于判断是否应该使用此渲染器
77
+ * @param message - 消息对象
78
+ * @param content - 要渲染的内容项。为当前消息经过 contentResolver 解析并统一化后的内容项:若解析结果为数组,则取对应索引的内容项(由 contentIndex 指定);若为字符串,则转为 { type: 'text', text: string }。统一化为 ChatMessageContentItem 对象格式
79
+ * @param contentIndex - 内容索引。由 contentResolver 的解析结果为数组时使用。若 contentResolver 解析结果为字符串,content 会转换为对象,此时 contentIndex 为 0
80
+ * @returns 如果匹配则返回 true,否则返回 false
81
+ */
82
+ find: (message: BubbleMessage, content: ChatMessageContentItem, contentIndex: number) => boolean;
83
+ renderer: Component<BubbleContentRendererProps>;
84
+ priority?: number;
85
+ attributes?: BubbleAttributes;
86
+ };
87
+ export type BubbleBoxRendererProps = Pick<BubbleProps, 'placement' | 'shape'>;
88
+ export type BubbleContentRendererProps<T extends ChatMessageContent = ChatMessageContent, S extends Record<string, unknown> = Record<string, unknown>> = {
89
+ message: BubbleMessage<T, S>;
90
+ contentIndex: number;
91
+ };
92
+ type BubbleSlotProps = {
93
+ messages: BubbleMessage[];
94
+ role?: string;
95
+ };
96
+ export interface BubbleSlots {
97
+ prefix?: (slotProps: BubbleSlotProps) => VNode | VNode[];
98
+ suffix?: (slotProps: BubbleSlotProps) => VNode | VNode[];
99
+ after?: (slotProps: BubbleSlotProps) => VNode | VNode[];
100
+ 'content-footer'?: (slotProps: BubbleSlotProps & {
101
+ contentIndex?: number;
102
+ }) => VNode | VNode[];
103
+ }
104
+ /**
105
+ * 角色配置
106
+ * 用于配置不同角色的气泡样式
107
+ */
108
+ export type BubbleRoleConfig = Pick<BubbleProps, 'avatar' | 'placement' | 'shape' | 'hidden' | 'fallbackBoxRenderer' | 'fallbackContentRenderer'>;
109
+ /**
110
+ * 自定义分组函数类型
111
+ */
112
+ type BubbleGroupFunction = (messages: BubbleMessage[], dividerRole?: string) => BubbleMessageGroup[];
113
+ export interface BubbleListProps {
114
+ messages: BubbleMessage[];
115
+ /**
116
+ * 分组策略:
117
+ * - 'consecutive': 连续相同角色的消息合并为一组
118
+ * - 'divider': 按分割角色分组(每条分割角色消息单独成组,其他消息在两个分割角色之间合并为一组)
119
+ * - 自定义函数: (messages, dividerRole) => BubbleMessageGroup[]
120
+ *
121
+ * 特殊情况:
122
+ * - hidden 的消息需要单独分组,连续的 hidden 可以同一组
123
+ */
124
+ groupStrategy?: 'consecutive' | 'divider' | BubbleGroupFunction;
125
+ /**
126
+ * 'divider' 策略的分割角色
127
+ * 具有此角色的消息将作为分割线
128
+ * @default 'user'
129
+ */
130
+ dividerRole?: string;
131
+ /**
132
+ * 当消息没有角色或角色为空时,使用此角色
133
+ * @default 'assistant'
134
+ */
135
+ fallbackRole?: string;
136
+ /**
137
+ * 角色配置(头像、位置、形状)
138
+ */
139
+ roleConfigs?: Record<string, BubbleRoleConfig>;
140
+ contentRenderMode?: BubbleProps['contentRenderMode'];
141
+ contentResolver?: BubbleProps['contentResolver'];
142
+ /**
143
+ * 是否自动滚动到底部。需要满足以下条件:
144
+ * - BubbleList 是可滚动容器(需要 scrollHeight > clientHeight)
145
+ * - 滚动容器接近底部
146
+ *
147
+ * @default false
148
+ */
149
+ autoScroll?: boolean;
150
+ }
151
+ export interface BubbleProviderProps {
152
+ boxRendererMatches?: BubbleBoxRendererMatch[];
153
+ contentRendererMatches?: BubbleContentRendererMatch[];
154
+ boxAttributes?: BubbleBoxAttributesConfig;
155
+ contentAttributes?: BubbleContentAttributesConfig;
156
+ fallbackBoxRenderer?: Component<BubbleBoxRendererProps>;
157
+ fallbackContentRenderer?: Component<BubbleContentRendererProps>;
158
+ store?: Record<string, unknown>;
159
+ }
160
+ type BubbleListSlotProps = BubbleSlotProps & {
161
+ messageIndexes: number[];
162
+ };
163
+ export interface BubbleListSlots {
164
+ prefix?: (slotProps: BubbleListSlotProps) => VNode | VNode[];
165
+ suffix?: (slotProps: BubbleListSlotProps) => VNode | VNode[];
166
+ after?: (slotProps: BubbleListSlotProps) => VNode | VNode[];
167
+ 'content-footer'?: (slotProps: BubbleListSlotProps & {
168
+ contentIndex?: number;
169
+ }) => VNode | VNode[];
170
+ }
171
+ export {};
@@ -0,0 +1,18 @@
1
+ import { BubbleBoxRendererProps } from '../index.type';
2
+ declare function __VLS_template(): {
3
+ attrs: Partial<{}>;
4
+ slots: {
5
+ default?(_: {}): any;
6
+ };
7
+ refs: {};
8
+ rootEl: HTMLDivElement;
9
+ };
10
+ type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
11
+ declare const __VLS_component: import('vue').DefineComponent<BubbleBoxRendererProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<BubbleBoxRendererProps> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
12
+ declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
13
+ export default _default;
14
+ type __VLS_WithTemplateSlots<T, S> = T & {
15
+ new (): {
16
+ $slots: S;
17
+ };
18
+ };
@@ -0,0 +1,4 @@
1
+ import { BubbleContentRendererProps, ChatMessageContentItem } from '../index.type';
2
+ type __VLS_Props = BubbleContentRendererProps<ChatMessageContentItem[]>;
3
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLImageElement>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ import { BubbleContentRendererProps } from '../index.type';
2
+ type __VLS_Props = BubbleContentRendererProps;
3
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ import { BubbleContentRendererProps } from '../index.type';
2
+ type __VLS_Props = BubbleContentRendererProps;
3
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
4
+ export default _default;
@@ -0,0 +1,9 @@
1
+ import { BubbleContentRendererProps, ChatMessageContent } from '../index.type';
2
+ type __VLS_Props = BubbleContentRendererProps<ChatMessageContent, {
3
+ thinking?: boolean;
4
+ open?: boolean;
5
+ }>;
6
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
7
+ detailRef: HTMLParagraphElement;
8
+ }, any>;
9
+ export default _default;
@@ -0,0 +1,4 @@
1
+ import { BubbleContentRendererProps } from '../index.type';
2
+ type __VLS_Props = BubbleContentRendererProps;
3
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
4
+ export default _default;
@@ -0,0 +1,14 @@
1
+ import { ToolCallStatus } from '../composables';
2
+ import { BubbleContentRendererProps, ChatMessageContent } from '../index.type';
3
+ type __VLS_Props = BubbleContentRendererProps<ChatMessageContent, {
4
+ toolCall?: Record<string, {
5
+ status?: ToolCallStatus;
6
+ open?: boolean;
7
+ }>;
8
+ }> & {
9
+ toolCallIndex: number;
10
+ };
11
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
12
+ detailRef: HTMLDivElement;
13
+ }, HTMLDivElement>;
14
+ export default _default;
@@ -0,0 +1,4 @@
1
+ import { BubbleContentRendererProps } from '../index.type';
2
+ type __VLS_Props = BubbleContentRendererProps<string>;
3
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ import { BubbleContentRendererProps } from '../index.type';
2
+ type __VLS_Props = BubbleContentRendererProps;
3
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
4
+ export default _default;
@@ -0,0 +1,93 @@
1
+ export declare const BubbleRenderers: {
2
+ Box: {
3
+ new (...args: any[]): import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('../index.type').BubbleBoxRendererProps> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, false, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {}, HTMLDivElement, import('vue').ComponentProvideOptions, {
4
+ P: {};
5
+ B: {};
6
+ D: {};
7
+ C: {};
8
+ M: {};
9
+ Defaults: {};
10
+ }, Readonly<import('../index.type').BubbleBoxRendererProps> & Readonly<{}>, {}, {}, {}, {}, {}>;
11
+ __isFragment?: never;
12
+ __isTeleport?: never;
13
+ __isSuspense?: never;
14
+ } & import('vue').ComponentOptionsBase<Readonly<import('../index.type').BubbleBoxRendererProps> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, {}, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & (new () => {
15
+ $slots: {
16
+ default?(_: {}): any;
17
+ };
18
+ });
19
+ Image: import('vue').DefineComponent<{
20
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContentItem[], Record<string, unknown>>;
21
+ contentIndex: number;
22
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
23
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContentItem[], Record<string, unknown>>;
24
+ contentIndex: number;
25
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLImageElement>;
26
+ Loading: import('vue').DefineComponent<{
27
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
28
+ contentIndex: number;
29
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
30
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
31
+ contentIndex: number;
32
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
33
+ Markdown: import('vue').DefineComponent<{
34
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
35
+ contentIndex: number;
36
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
37
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
38
+ contentIndex: number;
39
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
40
+ Reasoning: import('vue').DefineComponent<{
41
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, {
42
+ thinking?: boolean;
43
+ open?: boolean;
44
+ }>;
45
+ contentIndex: number;
46
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
47
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, {
48
+ thinking?: boolean;
49
+ open?: boolean;
50
+ }>;
51
+ contentIndex: number;
52
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
53
+ detailRef: HTMLParagraphElement;
54
+ }, any>;
55
+ Text: import('vue').DefineComponent<{
56
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
57
+ contentIndex: number;
58
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
59
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
60
+ contentIndex: number;
61
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
62
+ Tool: import('vue').DefineComponent<import('../index.type').BubbleContentRendererProps<import('../index.type').ChatMessageContent, {
63
+ toolCall?: Record<string, {
64
+ status?: import('../composables').ToolCallStatus;
65
+ open?: boolean;
66
+ }>;
67
+ }> & {
68
+ toolCallIndex: number;
69
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('../index.type').BubbleContentRendererProps<import('../index.type').ChatMessageContent, {
70
+ toolCall?: Record<string, {
71
+ status?: import('../composables').ToolCallStatus;
72
+ open?: boolean;
73
+ }>;
74
+ }> & {
75
+ toolCallIndex: number;
76
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
77
+ detailRef: HTMLDivElement;
78
+ }, HTMLDivElement>;
79
+ ToolRole: import('vue').DefineComponent<{
80
+ message: import('../index.type').BubbleMessage<string, Record<string, unknown>>;
81
+ contentIndex: number;
82
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
83
+ message: import('../index.type').BubbleMessage<string, Record<string, unknown>>;
84
+ contentIndex: number;
85
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
86
+ Tools: import('vue').DefineComponent<{
87
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
88
+ contentIndex: number;
89
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
90
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
91
+ contentIndex: number;
92
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
93
+ };
@@ -0,0 +1,27 @@
1
+ import { BubbleBoxRendererMatch, BubbleContentRendererMatch } from '../index.type';
2
+ export declare const defaultBoxRendererMatches: Array<BubbleBoxRendererMatch>;
3
+ export declare const defaultContentRendererMatches: Array<BubbleContentRendererMatch>;
4
+ export declare const defaultFallbackBoxRenderer: import('vue').Raw<{
5
+ new (...args: any[]): import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('../index.type').BubbleBoxRendererProps> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, false, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {}, HTMLDivElement, import('vue').ComponentProvideOptions, {
6
+ P: {};
7
+ B: {};
8
+ D: {};
9
+ C: {};
10
+ M: {};
11
+ Defaults: {};
12
+ }, Readonly<import('../index.type').BubbleBoxRendererProps> & Readonly<{}>, {}, {}, {}, {}, {}>;
13
+ __isFragment?: never;
14
+ __isTeleport?: never;
15
+ __isSuspense?: never;
16
+ } & import('vue').ComponentOptionsBase<Readonly<import('../index.type').BubbleBoxRendererProps> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, {}, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & (new () => {
17
+ $slots: {
18
+ default?(_: {}): any;
19
+ };
20
+ })>;
21
+ export declare const defaultFallbackContentRenderer: import('vue').Raw<import('vue').DefineComponent<{
22
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
23
+ contentIndex: number;
24
+ }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
25
+ message: import('../index.type').BubbleMessage<import('../index.type').ChatMessageContent, Record<string, unknown>>;
26
+ contentIndex: number;
27
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>>;
@@ -0,0 +1,7 @@
1
+ import { default as DOMPurify } from 'dompurify';
2
+ import { default as MarkdownIt } from 'markdown-it';
3
+ export declare const getJsonrepair: () => Promise<typeof import("jsonrepair")>;
4
+ export declare const getMarkdownItAndDompurify: () => Promise<{
5
+ markdown: typeof MarkdownIt;
6
+ dompurify: typeof DOMPurify;
7
+ } | null>;
@@ -0,0 +1,70 @@
1
+ import { PluginInfo } from '../../mcp-server-picker/index.type';
2
+ import { ChatModelOption, ChatPromptItem, ChatWelcomeIcon } from '../index.type';
3
+ type __VLS_Props = {
4
+ fullscreen?: boolean;
5
+ inputMessage: string;
6
+ messages: Record<string, unknown>[];
7
+ visibleMessages: Record<string, unknown>[];
8
+ isProcessing: boolean;
9
+ hasApiConfig: boolean;
10
+ availableModelCount: number;
11
+ modelOptions: ChatModelOption[];
12
+ selectedModel?: ChatModelOption;
13
+ title: string;
14
+ description: string;
15
+ welcomeIcon?: ChatWelcomeIcon;
16
+ promptItems?: ChatPromptItem[];
17
+ modelPlaceholder: string;
18
+ mcpTitle: string;
19
+ installedTabTitle: string;
20
+ marketTabTitle: string;
21
+ searchPluginsPlaceholder: string;
22
+ marketCategoryPlaceholder: string;
23
+ unavailableModelConfig: string;
24
+ missingProviderConfig: string;
25
+ unavailableModelPrompt: string;
26
+ missingProviderPrompt: string;
27
+ thinkingPrompt: string;
28
+ defaultPrompt: string;
29
+ activePluginCount: number;
30
+ pickerVisible: boolean;
31
+ installedPlugins: PluginInfo[];
32
+ marketPlugins: PluginInfo[];
33
+ };
34
+ declare function __VLS_template(): {
35
+ attrs: Partial<{}>;
36
+ slots: {
37
+ welcome?(_: {}): any;
38
+ };
39
+ refs: {};
40
+ rootEl: HTMLElement;
41
+ };
42
+ type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
43
+ declare const __VLS_component: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
44
+ cancel: () => any;
45
+ submit: (value: string) => any;
46
+ "plugin-toggle": (plugin: PluginInfo, enabled: boolean) => any;
47
+ "plugin-delete": (plugin: PluginInfo) => any;
48
+ "plugin-add": (plugin: PluginInfo) => any;
49
+ "tool-toggle": (plugin: PluginInfo, toolId: string, enabled: boolean) => any;
50
+ "update:selectedModelId": (value: string) => any;
51
+ "update:pickerVisible": (value: boolean) => any;
52
+ "update:inputMessage": (value: string) => any;
53
+ }, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{
54
+ onCancel?: (() => any) | undefined;
55
+ onSubmit?: ((value: string) => any) | undefined;
56
+ "onPlugin-toggle"?: ((plugin: PluginInfo, enabled: boolean) => any) | undefined;
57
+ "onPlugin-delete"?: ((plugin: PluginInfo) => any) | undefined;
58
+ "onPlugin-add"?: ((plugin: PluginInfo) => any) | undefined;
59
+ "onTool-toggle"?: ((plugin: PluginInfo, toolId: string, enabled: boolean) => any) | undefined;
60
+ "onUpdate:selectedModelId"?: ((value: string) => any) | undefined;
61
+ "onUpdate:pickerVisible"?: ((value: boolean) => any) | undefined;
62
+ "onUpdate:inputMessage"?: ((value: string) => any) | undefined;
63
+ }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLElement>;
64
+ declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
65
+ export default _default;
66
+ type __VLS_WithTemplateSlots<T, S> = T & {
67
+ new (): {
68
+ $slots: S;
69
+ };
70
+ };
@@ -0,0 +1,12 @@
1
+ import { Component } from 'vue';
2
+ type __VLS_Props = {
3
+ show: boolean;
4
+ icon?: Component;
5
+ ariaLabel: string;
6
+ };
7
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
8
+ open: () => any;
9
+ }, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{
10
+ onOpen?: (() => any) | undefined;
11
+ }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
12
+ export default _default;
@@ -0,0 +1,30 @@
1
+ import { PluginInfo } from '../../mcp-server-picker/index.type';
2
+ type __VLS_Props = {
3
+ compact?: boolean;
4
+ activePluginCount: number;
5
+ installedPlugins: PluginInfo[];
6
+ marketPlugins: PluginInfo[];
7
+ title: string;
8
+ installedTabTitle: string;
9
+ marketTabTitle: string;
10
+ searchPlaceholder: string;
11
+ marketCategoryPlaceholder: string;
12
+ };
13
+ type __VLS_PublicProps = {
14
+ 'pickerVisible': boolean;
15
+ } & __VLS_Props;
16
+ declare const _default: import('vue').DefineComponent<__VLS_PublicProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
17
+ "update:pickerVisible": (value: boolean) => any;
18
+ } & {
19
+ "plugin-toggle": (plugin: PluginInfo, enabled: boolean) => any;
20
+ "plugin-delete": (plugin: PluginInfo) => any;
21
+ "plugin-add": (plugin: PluginInfo) => any;
22
+ "tool-toggle": (plugin: PluginInfo, toolId: string, enabled: boolean) => any;
23
+ }, string, import('vue').PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
24
+ "onPlugin-toggle"?: ((plugin: PluginInfo, enabled: boolean) => any) | undefined;
25
+ "onPlugin-delete"?: ((plugin: PluginInfo) => any) | undefined;
26
+ "onPlugin-add"?: ((plugin: PluginInfo) => any) | undefined;
27
+ "onTool-toggle"?: ((plugin: PluginInfo, toolId: string, enabled: boolean) => any) | undefined;
28
+ "onUpdate:pickerVisible"?: ((value: boolean) => any) | undefined;
29
+ }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
30
+ export default _default;
@@ -0,0 +1,2 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, HTMLButtonElement>;
2
+ export default _default;
@@ -0,0 +1,13 @@
1
+ import { ChatPromptItem, ChatWelcomeIcon } from '../index.type';
2
+ type __VLS_Props = {
3
+ title: string;
4
+ description: string;
5
+ icon?: ChatWelcomeIcon;
6
+ promptItems?: ChatPromptItem[];
7
+ };
8
+ declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
9
+ submit: (value: string) => any;
10
+ }, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{
11
+ onSubmit?: ((value: string) => any) | undefined;
12
+ }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLElement>;
13
+ export default _default;
@@ -0,0 +1,37 @@
1
+ import { ChatModelOption } from '../index.type';
2
+ import { EnabledChatMcpTool } from './useChatMcp';
3
+ interface UseChatConversationOptions {
4
+ storageKey: string;
5
+ activeConversationStorageKey: string;
6
+ systemPrompt: string;
7
+ selectedModel: () => ChatModelOption | undefined;
8
+ hasApiConfig: () => boolean;
9
+ getEnabledTools: () => Promise<EnabledChatMcpTool[]>;
10
+ callTool: (toolName: string, args: Record<string, unknown>) => Promise<string>;
11
+ }
12
+ export declare function useChatConversation(options: UseChatConversationOptions): {
13
+ inputMessage: import('vue').Ref<string, string>;
14
+ messages: import('vue').ComputedRef<import('@opentiny/tiny-robot-kit').ChatMessage[]>;
15
+ visibleMessages: import('vue').ComputedRef<import('@opentiny/tiny-robot-kit').ChatMessage[]>;
16
+ isProcessing: import('vue').ComputedRef<boolean>;
17
+ currentConversationTitle: import('vue').ComputedRef<string>;
18
+ sendMessage: (content: string) => Promise<void>;
19
+ abortRequest: () => Promise<void>;
20
+ startNewConversation: () => Promise<void>;
21
+ conversations: import('vue').Ref<import('@opentiny/tiny-robot-kit').ConversationInfo[]>;
22
+ activeConversationId: import('vue').Ref<string | null>;
23
+ activeConversation: import('vue').ComputedRef<import('@opentiny/tiny-robot-kit').Conversation | null>;
24
+ createConversation: (params?: {
25
+ id?: string;
26
+ title?: string;
27
+ metadata?: Record<string, unknown>;
28
+ useMessageOptions?: Partial<import('@opentiny/tiny-robot-kit').UseMessageOptions>;
29
+ }) => import('@opentiny/tiny-robot-kit').Conversation;
30
+ switchConversation: (id: string) => Promise<import('@opentiny/tiny-robot-kit').Conversation | null>;
31
+ deleteConversation: (id: string) => Promise<void>;
32
+ clear: () => void;
33
+ updateConversationTitle: (id: string, title?: string) => void;
34
+ saveMessages: (id?: string) => void;
35
+ abortActiveRequest: () => Promise<void>;
36
+ };
37
+ export {};
@@ -0,0 +1,29 @@
1
+ import { PluginInfo } from '../../mcp-server-picker/index.type';
2
+ import { ChatMcpServerConfig } from '../index.type';
3
+ export interface EnabledChatMcpTool {
4
+ serverId: string;
5
+ name: string;
6
+ fullName: string;
7
+ description: string;
8
+ inputSchema: Record<string, unknown>;
9
+ }
10
+ interface UseChatMcpOptions {
11
+ storageKey: string;
12
+ mcpServers: Record<string, ChatMcpServerConfig>;
13
+ defaultInstalledServerIds: string[];
14
+ marketServerIds: string[];
15
+ }
16
+ export declare function useChatMcp(options: UseChatMcpOptions): {
17
+ pickerVisible: import('vue').Ref<boolean, boolean>;
18
+ installedPlugins: import('vue').ComputedRef<PluginInfo[]>;
19
+ marketPlugins: import('vue').ComputedRef<PluginInfo[]>;
20
+ activePluginCount: import('vue').ComputedRef<number>;
21
+ handlePluginAdd: (plugin: PluginInfo) => Promise<void>;
22
+ handlePluginToggle: (plugin: PluginInfo, enabled: boolean) => Promise<void>;
23
+ handlePluginDelete: (plugin: PluginInfo) => void;
24
+ handleToolToggle: (plugin: PluginInfo, toolId: string, enabled: boolean) => void;
25
+ getEnabledTools: () => Promise<EnabledChatMcpTool[]>;
26
+ callTool: (fullToolName: string, args?: Record<string, unknown>) => Promise<string>;
27
+ closePicker: () => void;
28
+ };
29
+ export {};
@@ -0,0 +1,27 @@
1
+ import { Ref } from 'vue';
2
+ import { ChatModelOption } from '../index.type';
3
+ export declare function useChatModel(getModelOptions: () => ChatModelOption[], selectedModelId: Ref<string>): {
4
+ modelOptions: import('vue').ComputedRef<{
5
+ apiKey: string | undefined;
6
+ id: string;
7
+ provider: string;
8
+ name: string;
9
+ model: string;
10
+ apiUrl: string;
11
+ icon?: import('vue').Component;
12
+ capabilities?: import('..').ChatModelCapabilities;
13
+ }[]>;
14
+ selectedModelId: Ref<string, string>;
15
+ selectedModel: import('vue').ComputedRef<{
16
+ apiKey: string | undefined;
17
+ id: string;
18
+ provider: string;
19
+ name: string;
20
+ model: string;
21
+ apiUrl: string;
22
+ icon?: import('vue').Component;
23
+ capabilities?: import('..').ChatModelCapabilities;
24
+ } | undefined>;
25
+ hasApiConfig: import('vue').ComputedRef<boolean>;
26
+ availableModelCount: import('vue').ComputedRef<number>;
27
+ };