@baishuyun/chat-sdk 0.0.1-alpha.1

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 (469) hide show
  1. package/.storybook/main.ts +21 -0
  2. package/.storybook/preview-head.html +1 -0
  3. package/.storybook/preview.ts +16 -0
  4. package/.turbo/turbo-build.log +82 -0
  5. package/components.json +22 -0
  6. package/dist/chat-sdk.js +55613 -0
  7. package/dist/chat-sdk.js.map +1 -0
  8. package/dist/chat-sdk.umd.cjs +661 -0
  9. package/dist/chat-sdk.umd.cjs.map +1 -0
  10. package/dist/chat.d.ts +5 -0
  11. package/dist/chat.d.ts.map +1 -0
  12. package/dist/components/biz-comp/FakeBotMsg.d.ts +7 -0
  13. package/dist/components/biz-comp/FakeBotMsg.d.ts.map +1 -0
  14. package/dist/components/biz-comp/FieldChecker.d.ts +16 -0
  15. package/dist/components/biz-comp/FieldChecker.d.ts.map +1 -0
  16. package/dist/components/biz-comp/FieldCheckerListMsg.d.ts +12 -0
  17. package/dist/components/biz-comp/FieldCheckerListMsg.d.ts.map +1 -0
  18. package/dist/components/biz-comp/FieldValueChecker.d.ts +14 -0
  19. package/dist/components/biz-comp/FieldValueChecker.d.ts.map +1 -0
  20. package/dist/components/biz-comp/SubformFieldsValueChecker.d.ts +20 -0
  21. package/dist/components/biz-comp/SubformFieldsValueChecker.d.ts.map +1 -0
  22. package/dist/components/biz-comp/chat-client.d.ts +13 -0
  23. package/dist/components/biz-comp/chat-client.d.ts.map +1 -0
  24. package/dist/components/biz-comp/chat-frame.d.ts +6 -0
  25. package/dist/components/biz-comp/chat-frame.d.ts.map +1 -0
  26. package/dist/components/biz-comp/conversation.d.ts +10 -0
  27. package/dist/components/biz-comp/conversation.d.ts.map +1 -0
  28. package/dist/components/biz-comp/dock-btn.d.ts +2 -0
  29. package/dist/components/biz-comp/dock-btn.d.ts.map +1 -0
  30. package/dist/components/biz-comp/field-icon.d.ts +5 -0
  31. package/dist/components/biz-comp/field-icon.d.ts.map +1 -0
  32. package/dist/components/biz-comp/markdown-part.d.ts +5 -0
  33. package/dist/components/biz-comp/markdown-part.d.ts.map +1 -0
  34. package/dist/components/biz-comp/markdown.d.ts +5 -0
  35. package/dist/components/biz-comp/markdown.d.ts.map +1 -0
  36. package/dist/components/biz-comp/message-content.d.ts +6 -0
  37. package/dist/components/biz-comp/message-content.d.ts.map +1 -0
  38. package/dist/components/biz-comp/messages.d.ts +3 -0
  39. package/dist/components/biz-comp/messages.d.ts.map +1 -0
  40. package/dist/components/biz-comp/multi-modal-input/attachment-btn.d.ts +9 -0
  41. package/dist/components/biz-comp/multi-modal-input/attachment-btn.d.ts.map +1 -0
  42. package/dist/components/biz-comp/multi-modal-input/clear-btn.d.ts +7 -0
  43. package/dist/components/biz-comp/multi-modal-input/clear-btn.d.ts.map +1 -0
  44. package/dist/components/biz-comp/multi-modal-input/index.d.ts +21 -0
  45. package/dist/components/biz-comp/multi-modal-input/index.d.ts.map +1 -0
  46. package/dist/components/biz-comp/multi-modal-input/preview-attachment.d.ts +12 -0
  47. package/dist/components/biz-comp/multi-modal-input/preview-attachment.d.ts.map +1 -0
  48. package/dist/components/biz-comp/multi-modal-input/prompt-input.d.ts +35 -0
  49. package/dist/components/biz-comp/multi-modal-input/prompt-input.d.ts.map +1 -0
  50. package/dist/components/biz-comp/opening-lines.d.ts +3 -0
  51. package/dist/components/biz-comp/opening-lines.d.ts.map +1 -0
  52. package/dist/components/biz-comp/preview-message-wrapper.d.ts +9 -0
  53. package/dist/components/biz-comp/preview-message-wrapper.d.ts.map +1 -0
  54. package/dist/components/biz-comp/preview-message.d.ts +11 -0
  55. package/dist/components/biz-comp/preview-message.d.ts.map +1 -0
  56. package/dist/components/biz-comp/response.d.ts +6 -0
  57. package/dist/components/biz-comp/response.d.ts.map +1 -0
  58. package/dist/components/biz-comp/suggestions.d.ts +7 -0
  59. package/dist/components/biz-comp/suggestions.d.ts.map +1 -0
  60. package/dist/components/bs-ui/abs-fullscreen-gradient-bg.d.ts +9 -0
  61. package/dist/components/bs-ui/abs-fullscreen-gradient-bg.d.ts.map +1 -0
  62. package/dist/components/bs-ui/attachments-previewer.d.ts +15 -0
  63. package/dist/components/bs-ui/attachments-previewer.d.ts.map +1 -0
  64. package/dist/components/bs-ui/border-color-animation.d.ts +9 -0
  65. package/dist/components/bs-ui/border-color-animation.d.ts.map +1 -0
  66. package/dist/components/bs-ui/bot-avatar-name.d.ts +6 -0
  67. package/dist/components/bs-ui/bot-avatar-name.d.ts.map +1 -0
  68. package/dist/components/bs-ui/bot-icon.d.ts +5 -0
  69. package/dist/components/bs-ui/bot-icon.d.ts.map +1 -0
  70. package/dist/components/bs-ui/bs-icons.d.ts +39 -0
  71. package/dist/components/bs-ui/bs-icons.d.ts.map +1 -0
  72. package/dist/components/bs-ui/card.d.ts +10 -0
  73. package/dist/components/bs-ui/card.d.ts.map +1 -0
  74. package/dist/components/bs-ui/chat-area-header.d.ts +9 -0
  75. package/dist/components/bs-ui/chat-area-header.d.ts.map +1 -0
  76. package/dist/components/bs-ui/collapsible-txt-msg.d.ts +10 -0
  77. package/dist/components/bs-ui/collapsible-txt-msg.d.ts.map +1 -0
  78. package/dist/components/bs-ui/confirm-dialog.d.ts +26 -0
  79. package/dist/components/bs-ui/confirm-dialog.d.ts.map +1 -0
  80. package/dist/components/bs-ui/fields-generating-indicator.d.ts +2 -0
  81. package/dist/components/bs-ui/fields-generating-indicator.d.ts.map +1 -0
  82. package/dist/components/bs-ui/fields-portal.d.ts +8 -0
  83. package/dist/components/bs-ui/fields-portal.d.ts.map +1 -0
  84. package/dist/components/bs-ui/fields-previewer.d.ts +12 -0
  85. package/dist/components/bs-ui/fields-previewer.d.ts.map +1 -0
  86. package/dist/components/bs-ui/font-icon.d.ts +6 -0
  87. package/dist/components/bs-ui/font-icon.d.ts.map +1 -0
  88. package/dist/components/bs-ui/form-info-editor.d.ts +37 -0
  89. package/dist/components/bs-ui/form-info-editor.d.ts.map +1 -0
  90. package/dist/components/bs-ui/generate-animation.d.ts +4 -0
  91. package/dist/components/bs-ui/generate-animation.d.ts.map +1 -0
  92. package/dist/components/bs-ui/icon-btn.d.ts +7 -0
  93. package/dist/components/bs-ui/icon-btn.d.ts.map +1 -0
  94. package/dist/components/bs-ui/line-checker.d.ts +15 -0
  95. package/dist/components/bs-ui/line-checker.d.ts.map +1 -0
  96. package/dist/components/bs-ui/linear-gradient-border-btn.d.ts +10 -0
  97. package/dist/components/bs-ui/linear-gradient-border-btn.d.ts.map +1 -0
  98. package/dist/components/bs-ui/linear-gradient-color-bg-animation.d.ts +8 -0
  99. package/dist/components/bs-ui/linear-gradient-color-bg-animation.d.ts.map +1 -0
  100. package/dist/components/bs-ui/option-item.d.ts +9 -0
  101. package/dist/components/bs-ui/option-item.d.ts.map +1 -0
  102. package/dist/components/bs-ui/previewer-header.d.ts +13 -0
  103. package/dist/components/bs-ui/previewer-header.d.ts.map +1 -0
  104. package/dist/components/bs-ui/primary-confirm-btn.d.ts +7 -0
  105. package/dist/components/bs-ui/primary-confirm-btn.d.ts.map +1 -0
  106. package/dist/components/bs-ui/primary-entry-btn.d.ts +9 -0
  107. package/dist/components/bs-ui/primary-entry-btn.d.ts.map +1 -0
  108. package/dist/components/bs-ui/tab-radio-group.d.ts +16 -0
  109. package/dist/components/bs-ui/tab-radio-group.d.ts.map +1 -0
  110. package/dist/components/bs-ui/tooltip.d.ts +5 -0
  111. package/dist/components/bs-ui/tooltip.d.ts.map +1 -0
  112. package/dist/components/bs-ui/user-txt-msg-bubble.d.ts +6 -0
  113. package/dist/components/bs-ui/user-txt-msg-bubble.d.ts.map +1 -0
  114. package/dist/components/ui/badge.d.ts +10 -0
  115. package/dist/components/ui/badge.d.ts.map +1 -0
  116. package/dist/components/ui/button.d.ts +12 -0
  117. package/dist/components/ui/button.d.ts.map +1 -0
  118. package/dist/components/ui/card.d.ts +9 -0
  119. package/dist/components/ui/card.d.ts.map +1 -0
  120. package/dist/components/ui/checkbox.d.ts +5 -0
  121. package/dist/components/ui/checkbox.d.ts.map +1 -0
  122. package/dist/components/ui/collapsible.d.ts +6 -0
  123. package/dist/components/ui/collapsible.d.ts.map +1 -0
  124. package/dist/components/ui/dialog.d.ts +24 -0
  125. package/dist/components/ui/dialog.d.ts.map +1 -0
  126. package/dist/components/ui/dropdown-menu.d.ts +28 -0
  127. package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
  128. package/dist/components/ui/icons.d.ts +176 -0
  129. package/dist/components/ui/icons.d.ts.map +1 -0
  130. package/dist/components/ui/input-group.d.ts +17 -0
  131. package/dist/components/ui/input-group.d.ts.map +1 -0
  132. package/dist/components/ui/input.d.ts +4 -0
  133. package/dist/components/ui/input.d.ts.map +1 -0
  134. package/dist/components/ui/label.d.ts +6 -0
  135. package/dist/components/ui/label.d.ts.map +1 -0
  136. package/dist/components/ui/one-time-click-btn.d.ts +4 -0
  137. package/dist/components/ui/one-time-click-btn.d.ts.map +1 -0
  138. package/dist/components/ui/select.d.ts +14 -0
  139. package/dist/components/ui/select.d.ts.map +1 -0
  140. package/dist/components/ui/spinner.d.ts +3 -0
  141. package/dist/components/ui/spinner.d.ts.map +1 -0
  142. package/dist/components/ui/tabs.d.ts +8 -0
  143. package/dist/components/ui/tabs.d.ts.map +1 -0
  144. package/dist/components/ui/textarea.d.ts +4 -0
  145. package/dist/components/ui/textarea.d.ts.map +1 -0
  146. package/dist/components/ui/tooltip.d.ts +8 -0
  147. package/dist/components/ui/tooltip.d.ts.map +1 -0
  148. package/dist/components/web-comp/fields-previewer-web-component.d.ts +61 -0
  149. package/dist/components/web-comp/fields-previewer-web-component.d.ts.map +1 -0
  150. package/dist/const/index.d.ts +4 -0
  151. package/dist/const/index.d.ts.map +1 -0
  152. package/dist/const/ui.d.ts +4 -0
  153. package/dist/const/ui.d.ts.map +1 -0
  154. package/dist/hooks/use-evt-bus.d.ts +2 -0
  155. package/dist/hooks/use-evt-bus.d.ts.map +1 -0
  156. package/dist/hooks/use-evt.d.ts +3 -0
  157. package/dist/hooks/use-evt.d.ts.map +1 -0
  158. package/dist/hooks/use-frame-mode.d.ts +5 -0
  159. package/dist/hooks/use-frame-mode.d.ts.map +1 -0
  160. package/dist/hooks/use-plugin-component.d.ts +5 -0
  161. package/dist/hooks/use-plugin-component.d.ts.map +1 -0
  162. package/dist/hooks/use-plugin-ctx.d.ts +3 -0
  163. package/dist/hooks/use-plugin-ctx.d.ts.map +1 -0
  164. package/dist/hooks/use-plugin-custom-components.d.ts +4 -0
  165. package/dist/hooks/use-plugin-custom-components.d.ts.map +1 -0
  166. package/dist/hooks/use-plugin-life-cycle-chain-runner.d.ts +5 -0
  167. package/dist/hooks/use-plugin-life-cycle-chain-runner.d.ts.map +1 -0
  168. package/dist/hooks/use-plugin-list.d.ts +2 -0
  169. package/dist/hooks/use-plugin-list.d.ts.map +1 -0
  170. package/dist/hooks/use-plugin.d.ts +2 -0
  171. package/dist/hooks/use-plugin.d.ts.map +1 -0
  172. package/dist/hooks/use-shadow.d.ts +25 -0
  173. package/dist/hooks/use-shadow.d.ts.map +1 -0
  174. package/dist/index.css +1 -0
  175. package/dist/index.d.ts +6 -0
  176. package/dist/index.d.ts.map +1 -0
  177. package/dist/lib/event-emitter.d.ts +39 -0
  178. package/dist/lib/event-emitter.d.ts.map +1 -0
  179. package/dist/lib/utils.d.ts +30 -0
  180. package/dist/lib/utils.d.ts.map +1 -0
  181. package/dist/plugins/form-builder-base-plugin/const.d.ts +3 -0
  182. package/dist/plugins/form-builder-base-plugin/const.d.ts.map +1 -0
  183. package/dist/plugins/form-builder-base-plugin/index.d.ts +7 -0
  184. package/dist/plugins/form-builder-base-plugin/index.d.ts.map +1 -0
  185. package/dist/plugins/form-builder-base-plugin/types.d.ts +12 -0
  186. package/dist/plugins/form-builder-base-plugin/types.d.ts.map +1 -0
  187. package/dist/plugins/form-filling-plugin/components/FormFillingOpeningLines.d.ts +2 -0
  188. package/dist/plugins/form-filling-plugin/components/FormFillingOpeningLines.d.ts.map +1 -0
  189. package/dist/plugins/form-filling-plugin/components/avatar.d.ts +5 -0
  190. package/dist/plugins/form-filling-plugin/components/avatar.d.ts.map +1 -0
  191. package/dist/plugins/form-filling-plugin/components/entry-btn.d.ts +3 -0
  192. package/dist/plugins/form-filling-plugin/components/entry-btn.d.ts.map +1 -0
  193. package/dist/plugins/form-filling-plugin/components/msg-part.d.ts +3 -0
  194. package/dist/plugins/form-filling-plugin/components/msg-part.d.ts.map +1 -0
  195. package/dist/plugins/form-filling-plugin/const.d.ts +612 -0
  196. package/dist/plugins/form-filling-plugin/const.d.ts.map +1 -0
  197. package/dist/plugins/form-filling-plugin/index.d.ts +13 -0
  198. package/dist/plugins/form-filling-plugin/index.d.ts.map +1 -0
  199. package/dist/plugins/form-filling-plugin/types.d.ts +8 -0
  200. package/dist/plugins/form-filling-plugin/types.d.ts.map +1 -0
  201. package/dist/plugins/form-filling-plugin/utils.d.ts +4 -0
  202. package/dist/plugins/form-filling-plugin/utils.d.ts.map +1 -0
  203. package/dist/plugins/general-model-form-builder-plugin/components/confirmer.d.ts +9 -0
  204. package/dist/plugins/general-model-form-builder-plugin/components/confirmer.d.ts.map +1 -0
  205. package/dist/plugins/general-model-form-builder-plugin/components/ghost-evt-dispatcher.d.ts +10 -0
  206. package/dist/plugins/general-model-form-builder-plugin/components/ghost-evt-dispatcher.d.ts.map +1 -0
  207. package/dist/plugins/general-model-form-builder-plugin/components/msg-part.d.ts +3 -0
  208. package/dist/plugins/general-model-form-builder-plugin/components/msg-part.d.ts.map +1 -0
  209. package/dist/plugins/general-model-form-builder-plugin/components/new-confirmer.d.ts +10 -0
  210. package/dist/plugins/general-model-form-builder-plugin/components/new-confirmer.d.ts.map +1 -0
  211. package/dist/plugins/general-model-form-builder-plugin/const.d.ts +3 -0
  212. package/dist/plugins/general-model-form-builder-plugin/const.d.ts.map +1 -0
  213. package/dist/plugins/general-model-form-builder-plugin/index.d.ts +9 -0
  214. package/dist/plugins/general-model-form-builder-plugin/index.d.ts.map +1 -0
  215. package/dist/plugins/general-model-form-builder-plugin/types.d.ts +3 -0
  216. package/dist/plugins/general-model-form-builder-plugin/types.d.ts.map +1 -0
  217. package/dist/plugins/mcp-form-builder-plugin/components/create-form-confirm.d.ts +7 -0
  218. package/dist/plugins/mcp-form-builder-plugin/components/create-form-confirm.d.ts.map +1 -0
  219. package/dist/plugins/mcp-form-builder-plugin/components/entry-btn.d.ts +3 -0
  220. package/dist/plugins/mcp-form-builder-plugin/components/entry-btn.d.ts.map +1 -0
  221. package/dist/plugins/mcp-form-builder-plugin/components/follow-up.d.ts +3 -0
  222. package/dist/plugins/mcp-form-builder-plugin/components/follow-up.d.ts.map +1 -0
  223. package/dist/plugins/mcp-form-builder-plugin/components/msg-part.d.ts +3 -0
  224. package/dist/plugins/mcp-form-builder-plugin/components/msg-part.d.ts.map +1 -0
  225. package/dist/plugins/mcp-form-builder-plugin/const/index.d.ts +12 -0
  226. package/dist/plugins/mcp-form-builder-plugin/const/index.d.ts.map +1 -0
  227. package/dist/plugins/mcp-form-builder-plugin/hooks/index.d.ts +1 -0
  228. package/dist/plugins/mcp-form-builder-plugin/hooks/index.d.ts.map +1 -0
  229. package/dist/plugins/mcp-form-builder-plugin/hooks/use-fields-confirmed.d.ts +2 -0
  230. package/dist/plugins/mcp-form-builder-plugin/hooks/use-fields-confirmed.d.ts.map +1 -0
  231. package/dist/plugins/mcp-form-builder-plugin/index.d.ts +23 -0
  232. package/dist/plugins/mcp-form-builder-plugin/index.d.ts.map +1 -0
  233. package/dist/plugins/mcp-form-builder-plugin/types.d.ts +17 -0
  234. package/dist/plugins/mcp-form-builder-plugin/types.d.ts.map +1 -0
  235. package/dist/plugins/mcp-form-builder-plugin/utils/index.d.ts +51 -0
  236. package/dist/plugins/mcp-form-builder-plugin/utils/index.d.ts.map +1 -0
  237. package/dist/sdk.impl.d.ts +21 -0
  238. package/dist/sdk.impl.d.ts.map +1 -0
  239. package/dist/store/context.d.ts +12 -0
  240. package/dist/store/context.d.ts.map +1 -0
  241. package/dist/store/index.d.ts +13 -0
  242. package/dist/store/index.d.ts.map +1 -0
  243. package/dist/stories/AbsFullscreenGradientBg.stories.d.ts +17 -0
  244. package/dist/stories/AbsFullscreenGradientBg.stories.d.ts.map +1 -0
  245. package/dist/stories/AttachmentsPreviewer.stories.d.ts +16 -0
  246. package/dist/stories/AttachmentsPreviewer.stories.d.ts.map +1 -0
  247. package/dist/stories/BorderColorAnimation.stories.d.ts +24 -0
  248. package/dist/stories/BorderColorAnimation.stories.d.ts.map +1 -0
  249. package/dist/stories/BotAvatarAndName.stories.d.ts +18 -0
  250. package/dist/stories/BotAvatarAndName.stories.d.ts.map +1 -0
  251. package/dist/stories/BotIcon.stories.d.ts +17 -0
  252. package/dist/stories/BotIcon.stories.d.ts.map +1 -0
  253. package/dist/stories/BsTooltip.stories.d.ts +7 -0
  254. package/dist/stories/BsTooltip.stories.d.ts.map +1 -0
  255. package/dist/stories/Card.stories.d.ts +14 -0
  256. package/dist/stories/Card.stories.d.ts.map +1 -0
  257. package/dist/stories/ChatAreaHeader.stories.d.ts +14 -0
  258. package/dist/stories/ChatAreaHeader.stories.d.ts.map +1 -0
  259. package/dist/stories/CollapsibleTextMsg.stories.d.ts +16 -0
  260. package/dist/stories/CollapsibleTextMsg.stories.d.ts.map +1 -0
  261. package/dist/stories/ConfirmDialog.stories.d.ts +61 -0
  262. package/dist/stories/ConfirmDialog.stories.d.ts.map +1 -0
  263. package/dist/stories/FormInfoEditor.stories.d.ts +15 -0
  264. package/dist/stories/FormInfoEditor.stories.d.ts.map +1 -0
  265. package/dist/stories/GenerateAnimation.stories.d.ts +16 -0
  266. package/dist/stories/GenerateAnimation.stories.d.ts.map +1 -0
  267. package/dist/stories/IconBtn.stories.d.ts +14 -0
  268. package/dist/stories/IconBtn.stories.d.ts.map +1 -0
  269. package/dist/stories/IconLib.d.ts +12 -0
  270. package/dist/stories/IconLib.d.ts.map +1 -0
  271. package/dist/stories/Icons.stories.d.ts +24 -0
  272. package/dist/stories/Icons.stories.d.ts.map +1 -0
  273. package/dist/stories/LineChecker.stories.d.ts +23 -0
  274. package/dist/stories/LineChecker.stories.d.ts.map +1 -0
  275. package/dist/stories/LinearGradientBorderBtn.stories.d.ts +22 -0
  276. package/dist/stories/LinearGradientBorderBtn.stories.d.ts.map +1 -0
  277. package/dist/stories/LinearGradientColorBgAnimation.stories.d.ts +23 -0
  278. package/dist/stories/LinearGradientColorBgAnimation.stories.d.ts.map +1 -0
  279. package/dist/stories/OptionItem.stories.d.ts +20 -0
  280. package/dist/stories/OptionItem.stories.d.ts.map +1 -0
  281. package/dist/stories/PreviewerHeader.stories.d.ts +9 -0
  282. package/dist/stories/PreviewerHeader.stories.d.ts.map +1 -0
  283. package/dist/stories/PrimaryConfirmBtn.stories.d.ts +16 -0
  284. package/dist/stories/PrimaryConfirmBtn.stories.d.ts.map +1 -0
  285. package/dist/stories/PrimaryEntryBtn.stories.d.ts +26 -0
  286. package/dist/stories/PrimaryEntryBtn.stories.d.ts.map +1 -0
  287. package/dist/stories/TabRadioGroup.stories.d.ts +18 -0
  288. package/dist/stories/TabRadioGroup.stories.d.ts.map +1 -0
  289. package/dist/stories/UserTextMsgBubble.stories.d.ts +14 -0
  290. package/dist/stories/UserTextMsgBubble.stories.d.ts.map +1 -0
  291. package/dist/stories/fields-generating.stories.d.ts +14 -0
  292. package/dist/stories/fields-generating.stories.d.ts.map +1 -0
  293. package/dist/stories/fields-previewer.stories.d.ts +18 -0
  294. package/dist/stories/fields-previewer.stories.d.ts.map +1 -0
  295. package/package.json +76 -0
  296. package/scripts/inline-style-inject.ts +36 -0
  297. package/src/chat.tsx +56 -0
  298. package/src/components/biz-comp/FakeBotMsg.tsx +52 -0
  299. package/src/components/biz-comp/FieldChecker.tsx +114 -0
  300. package/src/components/biz-comp/FieldCheckerListMsg.tsx +34 -0
  301. package/src/components/biz-comp/FieldValueChecker.tsx +98 -0
  302. package/src/components/biz-comp/SubformFieldsValueChecker.tsx +166 -0
  303. package/src/components/biz-comp/chat-client.tsx +206 -0
  304. package/src/components/biz-comp/chat-frame.tsx +25 -0
  305. package/src/components/biz-comp/conversation.tsx +70 -0
  306. package/src/components/biz-comp/dock-btn.tsx +52 -0
  307. package/src/components/biz-comp/field-icon.tsx +8 -0
  308. package/src/components/biz-comp/markdown-part.tsx +48 -0
  309. package/src/components/biz-comp/markdown.tsx +36 -0
  310. package/src/components/biz-comp/message-content.tsx +21 -0
  311. package/src/components/biz-comp/messages.tsx +42 -0
  312. package/src/components/biz-comp/multi-modal-input/attachment-btn.tsx +30 -0
  313. package/src/components/biz-comp/multi-modal-input/clear-btn.tsx +42 -0
  314. package/src/components/biz-comp/multi-modal-input/index.tsx +422 -0
  315. package/src/components/biz-comp/multi-modal-input/preview-attachment.tsx +72 -0
  316. package/src/components/biz-comp/multi-modal-input/prompt-input.tsx +260 -0
  317. package/src/components/biz-comp/opening-lines.tsx +34 -0
  318. package/src/components/biz-comp/preview-message-wrapper.tsx +55 -0
  319. package/src/components/biz-comp/preview-message.tsx +91 -0
  320. package/src/components/biz-comp/response.tsx +23 -0
  321. package/src/components/biz-comp/suggestions.tsx +78 -0
  322. package/src/components/bs-ui/abs-fullscreen-gradient-bg.tsx +34 -0
  323. package/src/components/bs-ui/attachments-previewer.tsx +229 -0
  324. package/src/components/bs-ui/border-color-animation.tsx +58 -0
  325. package/src/components/bs-ui/bot-avatar-name.tsx +25 -0
  326. package/src/components/bs-ui/bot-icon.tsx +23 -0
  327. package/src/components/bs-ui/bs-icons.tsx +801 -0
  328. package/src/components/bs-ui/card.tsx +37 -0
  329. package/src/components/bs-ui/chat-area-header.tsx +41 -0
  330. package/src/components/bs-ui/collapsible-txt-msg.tsx +50 -0
  331. package/src/components/bs-ui/confirm-dialog.tsx +128 -0
  332. package/src/components/bs-ui/fields-generating-indicator.tsx +50 -0
  333. package/src/components/bs-ui/fields-portal.tsx +18 -0
  334. package/src/components/bs-ui/fields-previewer.tsx +109 -0
  335. package/src/components/bs-ui/font-icon.tsx +17 -0
  336. package/src/components/bs-ui/form-info-editor.tsx +286 -0
  337. package/src/components/bs-ui/generate-animation.tsx +54 -0
  338. package/src/components/bs-ui/icon-btn.tsx +31 -0
  339. package/src/components/bs-ui/line-checker.tsx +129 -0
  340. package/src/components/bs-ui/linear-gradient-border-btn.tsx +48 -0
  341. package/src/components/bs-ui/linear-gradient-color-bg-animation.tsx +103 -0
  342. package/src/components/bs-ui/option-item.tsx +28 -0
  343. package/src/components/bs-ui/previewer-header.tsx +134 -0
  344. package/src/components/bs-ui/primary-confirm-btn.tsx +46 -0
  345. package/src/components/bs-ui/primary-entry-btn.tsx +37 -0
  346. package/src/components/bs-ui/tab-radio-group.tsx +73 -0
  347. package/src/components/bs-ui/tooltip.tsx +18 -0
  348. package/src/components/bs-ui/user-txt-msg-bubble.tsx +19 -0
  349. package/src/components/ui/badge.tsx +36 -0
  350. package/src/components/ui/button.tsx +51 -0
  351. package/src/components/ui/card.tsx +76 -0
  352. package/src/components/ui/checkbox.tsx +29 -0
  353. package/src/components/ui/collapsible.tsx +9 -0
  354. package/src/components/ui/dialog.tsx +104 -0
  355. package/src/components/ui/dropdown-menu.tsx +199 -0
  356. package/src/components/ui/icons.tsx +1288 -0
  357. package/src/components/ui/input-group.tsx +172 -0
  358. package/src/components/ui/input.tsx +22 -0
  359. package/src/components/ui/label.tsx +24 -0
  360. package/src/components/ui/one-time-click-btn.tsx +32 -0
  361. package/src/components/ui/select.tsx +157 -0
  362. package/src/components/ui/spinner.tsx +17 -0
  363. package/src/components/ui/tabs.tsx +53 -0
  364. package/src/components/ui/textarea.tsx +22 -0
  365. package/src/components/ui/tooltip.tsx +34 -0
  366. package/src/components/web-comp/fields-previewer-web-component.ts +259 -0
  367. package/src/const/index.ts +61 -0
  368. package/src/const/ui.ts +7 -0
  369. package/src/global.d.ts +1 -0
  370. package/src/hooks/use-evt-bus.ts +11 -0
  371. package/src/hooks/use-evt.ts +17 -0
  372. package/src/hooks/use-frame-mode.ts +13 -0
  373. package/src/hooks/use-plugin-component.ts +12 -0
  374. package/src/hooks/use-plugin-ctx.ts +12 -0
  375. package/src/hooks/use-plugin-custom-components.ts +31 -0
  376. package/src/hooks/use-plugin-life-cycle-chain-runner.ts +26 -0
  377. package/src/hooks/use-plugin-list.ts +11 -0
  378. package/src/hooks/use-plugin.ts +11 -0
  379. package/src/hooks/use-shadow.ts +128 -0
  380. package/src/index.tsx +10 -0
  381. package/src/lib/event-emitter.ts +93 -0
  382. package/src/lib/utils.ts +222 -0
  383. package/src/plugins/form-builder-base-plugin/const.ts +27 -0
  384. package/src/plugins/form-builder-base-plugin/index.ts +45 -0
  385. package/src/plugins/form-builder-base-plugin/types.ts +13 -0
  386. package/src/plugins/form-filling-plugin/components/FormFillingOpeningLines.tsx +3 -0
  387. package/src/plugins/form-filling-plugin/components/avatar.tsx +14 -0
  388. package/src/plugins/form-filling-plugin/components/entry-btn.tsx +15 -0
  389. package/src/plugins/form-filling-plugin/components/msg-part.tsx +90 -0
  390. package/src/plugins/form-filling-plugin/const.ts +595 -0
  391. package/src/plugins/form-filling-plugin/index.ts +135 -0
  392. package/src/plugins/form-filling-plugin/types.ts +11 -0
  393. package/src/plugins/form-filling-plugin/utils.ts +63 -0
  394. package/src/plugins/general-model-form-builder-plugin/components/confirmer.tsx +90 -0
  395. package/src/plugins/general-model-form-builder-plugin/components/ghost-evt-dispatcher.tsx +69 -0
  396. package/src/plugins/general-model-form-builder-plugin/components/msg-part.tsx +147 -0
  397. package/src/plugins/general-model-form-builder-plugin/components/new-confirmer.tsx +191 -0
  398. package/src/plugins/general-model-form-builder-plugin/const.ts +3 -0
  399. package/src/plugins/general-model-form-builder-plugin/index.ts +20 -0
  400. package/src/plugins/general-model-form-builder-plugin/types.ts +1 -0
  401. package/src/plugins/mcp-form-builder-plugin/components/create-form-confirm.tsx +126 -0
  402. package/src/plugins/mcp-form-builder-plugin/components/entry-btn.tsx +9 -0
  403. package/src/plugins/mcp-form-builder-plugin/components/follow-up.tsx +15 -0
  404. package/src/plugins/mcp-form-builder-plugin/components/msg-part.tsx +135 -0
  405. package/src/plugins/mcp-form-builder-plugin/const/index.ts +13 -0
  406. package/src/plugins/mcp-form-builder-plugin/hooks/index.ts +0 -0
  407. package/src/plugins/mcp-form-builder-plugin/hooks/use-fields-confirmed.ts +12 -0
  408. package/src/plugins/mcp-form-builder-plugin/index.ts +225 -0
  409. package/src/plugins/mcp-form-builder-plugin/types.ts +21 -0
  410. package/src/plugins/mcp-form-builder-plugin/utils/index.ts +450 -0
  411. package/src/sdk.impl.tsx +108 -0
  412. package/src/store/context.tsx +22 -0
  413. package/src/store/index.ts +53 -0
  414. package/src/stories/AbsFullscreenGradientBg.stories.tsx +36 -0
  415. package/src/stories/AttachmentsPreviewer.stories.tsx +188 -0
  416. package/src/stories/BorderColorAnimation.stories.tsx +60 -0
  417. package/src/stories/BotAvatarAndName.stories.ts +24 -0
  418. package/src/stories/BotIcon.stories.ts +22 -0
  419. package/src/stories/BsTooltip.stories.tsx +32 -0
  420. package/src/stories/Card.stories.tsx +28 -0
  421. package/src/stories/ChatAreaHeader.stories.ts +26 -0
  422. package/src/stories/CollapsibleTextMsg.stories.ts +44 -0
  423. package/src/stories/ConfirmDialog.stories.tsx +123 -0
  424. package/src/stories/FormInfoEditor.stories.tsx +183 -0
  425. package/src/stories/GenerateAnimation.stories.ts +20 -0
  426. package/src/stories/IconBtn.stories.tsx +26 -0
  427. package/src/stories/IconLib.tsx +47 -0
  428. package/src/stories/Icons.stories.ts +22 -0
  429. package/src/stories/LineChecker.stories.tsx +134 -0
  430. package/src/stories/LinearGradientBorderBtn.stories.tsx +86 -0
  431. package/src/stories/LinearGradientColorBgAnimation.stories.tsx +60 -0
  432. package/src/stories/OptionItem.stories.tsx +77 -0
  433. package/src/stories/PreviewerHeader.stories.tsx +45 -0
  434. package/src/stories/PrimaryConfirmBtn.stories.ts +37 -0
  435. package/src/stories/PrimaryEntryBtn.stories.tsx +74 -0
  436. package/src/stories/TabRadioGroup.stories.tsx +84 -0
  437. package/src/stories/UserTextMsgBubble.stories.ts +24 -0
  438. package/src/stories/assets/accessibility.png +0 -0
  439. package/src/stories/assets/accessibility.svg +1 -0
  440. package/src/stories/assets/addon-library.png +0 -0
  441. package/src/stories/assets/assets.png +0 -0
  442. package/src/stories/assets/avif-test-image.avif +0 -0
  443. package/src/stories/assets/context.png +0 -0
  444. package/src/stories/assets/demo.css +539 -0
  445. package/src/stories/assets/demo_index.html +7988 -0
  446. package/src/stories/assets/discord.svg +1 -0
  447. package/src/stories/assets/docs.png +0 -0
  448. package/src/stories/assets/figma-plugin.png +0 -0
  449. package/src/stories/assets/github.svg +1 -0
  450. package/src/stories/assets/iconfont.css +1377 -0
  451. package/src/stories/assets/iconfont.eot +0 -0
  452. package/src/stories/assets/iconfont.json +2382 -0
  453. package/src/stories/assets/iconfont.svg +697 -0
  454. package/src/stories/assets/iconfont.ttf +0 -0
  455. package/src/stories/assets/iconfont.woff +0 -0
  456. package/src/stories/assets/iconfont.woff2 +0 -0
  457. package/src/stories/assets/share.png +0 -0
  458. package/src/stories/assets/styling.png +0 -0
  459. package/src/stories/assets/testing.png +0 -0
  460. package/src/stories/assets/theming.png +0 -0
  461. package/src/stories/assets/tutorials.svg +1 -0
  462. package/src/stories/assets/youtube.svg +1 -0
  463. package/src/stories/fields-generating.stories.tsx +22 -0
  464. package/src/stories/fields-previewer.stories.tsx +67 -0
  465. package/src/style.css +172 -0
  466. package/stats.html +4949 -0
  467. package/tailwind.config.js +49 -0
  468. package/tsconfig.json +13 -0
  469. package/vite.config.ts +38 -0
@@ -0,0 +1,12 @@
1
+ export declare const IconLibrary: {
2
+ (): import("react/jsx-runtime").JSX.Element;
3
+ storyName: string;
4
+ parameters: {
5
+ docs: {
6
+ description: {
7
+ story: string;
8
+ };
9
+ };
10
+ };
11
+ };
12
+ //# sourceMappingURL=IconLib.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconLib.d.ts","sourceRoot":"","sources":["../../src/stories/IconLib.tsx"],"names":[],"mappings":"AAMA,eAAO,MAAM,WAAW;;;;;;;;;;CAgCvB,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: {
5
+ (): import("react/jsx-runtime").JSX.Element;
6
+ storyName: string;
7
+ parameters: {
8
+ docs: {
9
+ description: {
10
+ story: string;
11
+ };
12
+ };
13
+ };
14
+ };
15
+ tags: string[];
16
+ parameters: {
17
+ layout: string;
18
+ };
19
+ args: {};
20
+ };
21
+ export default meta;
22
+ type Story = StoryObj<typeof meta>;
23
+ export declare const Base: Story;
24
+ //# sourceMappingURL=Icons.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Icons.stories.d.ts","sourceRoot":"","sources":["../../src/stories/Icons.stories.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAI5D,QAAA,MAAM,IAAI;;;;;;;;;;;;;;;;;;CAU0B,CAAC;AAErC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,IAAI,EAAE,KAElB,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: import('react').FC<import('../components/bs-ui/line-checker').LineCheckerProps>;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Default: Story;
14
+ export declare const WithIcon: Story;
15
+ export declare const LongTitle: Story;
16
+ export declare const Checked: Story;
17
+ export declare const Disabled: Story;
18
+ export declare const DisabledChecked: Story;
19
+ export declare const NoShortDesc: Story;
20
+ export declare const NoIcon: Story;
21
+ export declare const MinimalVariant: Story;
22
+ export declare const WithExtraNodes: Story;
23
+ //# sourceMappingURL=LineChecker.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LineChecker.stories.d.ts","sourceRoot":"","sources":["../../src/stories/LineChecker.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAK5D,QAAA,MAAM,IAAI;;;;;;;;CAU0B,CAAC;AAErC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAQrB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAStB,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,KASvB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,KAOrB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAUtB,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,KAW7B,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAQzB,CAAC;AAEF,eAAO,MAAM,MAAM,EAAE,KAQpB,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,KAI5B,CAAC;AAGF,eAAO,MAAM,cAAc,EAAE,KAoB5B,CAAC"}
@@ -0,0 +1,22 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: import('react').FC<import('../components/bs-ui/linear-gradient-border-btn').LinearGradientBorderBtnProps>;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Default: Story;
14
+ export declare const ShortText: Story;
15
+ export declare const LongText: Story;
16
+ export declare const Disabled: Story;
17
+ export declare const WithClickHandler: Story;
18
+ export declare const CustomClassName: Story;
19
+ export declare const MultipleButtons: Story;
20
+ export declare const WithIcon: Story;
21
+ export declare const FixedWidth: Story;
22
+ //# sourceMappingURL=LinearGradientBorderBtn.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LinearGradientBorderBtn.stories.d.ts","sourceRoot":"","sources":["../../src/stories/LinearGradientBorderBtn.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAK5D,QAAA,MAAM,IAAI;;;;;;;;CAUsC,CAAC;AAEjD,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAIrB,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,KAIvB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAItB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAKtB,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,KAK9B,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,KAK7B,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,KAQ7B,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAStB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KAKxB,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: ({ children, width, height, style, childrenContainerStyle, }: {
5
+ children?: React.ReactNode;
6
+ width?: string | number;
7
+ height?: string | number;
8
+ style?: React.CSSProperties;
9
+ childrenContainerStyle?: React.CSSProperties;
10
+ }) => import("react/jsx-runtime").JSX.Element;
11
+ tags: string[];
12
+ parameters: {
13
+ layout: string;
14
+ };
15
+ args: {};
16
+ };
17
+ export default meta;
18
+ type Story = StoryObj<typeof meta>;
19
+ export declare const Default: Story;
20
+ export declare const WithContent: Story;
21
+ export declare const FixedSize: Story;
22
+ export declare const TallSize: Story;
23
+ //# sourceMappingURL=LinearGradientColorBgAnimation.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LinearGradientColorBgAnimation.stories.d.ts","sourceRoot":"","sources":["../../src/stories/LinearGradientColorBgAnimation.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAI5D,QAAA,MAAM,IAAI;;;gBAFiE,CAAC;aAE5E,CAFwG;cAG/F,CAAC;aAA2B,CAAC;8BACd,CAAC;;;;;;;CAM8B,CAAC;AAExD,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAKrB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAqBzB,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,KAKvB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAKtB,CAAC"}
@@ -0,0 +1,20 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: ({ bgColor, color, label, children, }: import('../components/bs-ui/option-item').OptionItemProps) => import("react/jsx-runtime").JSX.Element;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Default: Story;
14
+ export declare const WithBgColor: Story;
15
+ export declare const RedVariant: Story;
16
+ export declare const GreenVariant: Story;
17
+ export declare const WithChildren: Story;
18
+ export declare const WithIcon: Story;
19
+ export declare const CustomColor: Story;
20
+ //# sourceMappingURL=OptionItem.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OptionItem.stories.d.ts","sourceRoot":"","sources":["../../src/stories/OptionItem.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAI5D,QAAA,MAAM,IAAI;;;;;;;;CAUyB,CAAC;AAEpC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAIrB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAMzB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KAMxB,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KAM1B,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KAM1B,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAWtB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAMzB,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { Meta, StoryObj } from '@storybook/react-vite';
2
+ import { PreviewerHeader } from '../components/bs-ui/previewer-header';
3
+ declare const meta: Meta<typeof PreviewerHeader>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof meta>;
6
+ export declare const Default: Story;
7
+ export declare const ActiveMode: Story;
8
+ export declare const WithTips: Story;
9
+ //# sourceMappingURL=PreviewerHeader.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PreviewerHeader.stories.d.ts","sourceRoot":"","sources":["../../src/stories/PreviewerHeader.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAEtE,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,eAAe,CAOtC,CAAC;AACF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAOrB,CAAC;AAGF,eAAO,MAAM,UAAU,EAAE,KAQxB,CAAC;AAGF,eAAO,MAAM,QAAQ,EAAE,KAStB,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: ({ text, prefixDesc, className, disabled, ...rest }: import('../components/bs-ui/primary-confirm-btn').PrimaryConfirmBtnProps) => import("react/jsx-runtime").JSX.Element;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Default: Story;
14
+ export declare const Disabled: Story;
15
+ export declare const CustomText: Story;
16
+ //# sourceMappingURL=PrimaryConfirmBtn.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PrimaryConfirmBtn.stories.d.ts","sourceRoot":"","sources":["../../src/stories/PrimaryConfirmBtn.stories.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAI5D,QAAA,MAAM,IAAI;;;;;;;;CAUgC,CAAC;AAE3C,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAIrB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAKtB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KAIxB,CAAC"}
@@ -0,0 +1,26 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: ({ children, className, minimal, entryVariant, icon, ...rest }: import('../components/bs-ui/primary-entry-btn').PrimaryEntryBtnProps) => import("react/jsx-runtime").JSX.Element;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ argTypes: {
11
+ entryVariant: {
12
+ control: "select";
13
+ options: string[];
14
+ };
15
+ };
16
+ };
17
+ export default meta;
18
+ type Story = StoryObj<typeof meta>;
19
+ export declare const Base: Story;
20
+ export declare const Minimal: Story;
21
+ export declare const Ghost: Story;
22
+ export declare const Selected: Story;
23
+ export declare const CustomIcon: Story;
24
+ export declare const GhostMinimal: Story;
25
+ export declare const SelectedMinimal: Story;
26
+ //# sourceMappingURL=PrimaryEntryBtn.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PrimaryEntryBtn.stories.d.ts","sourceRoot":"","sources":["../../src/stories/PrimaryEntryBtn.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAM5D,QAAA,MAAM,IAAI;;;;;;;;;;;;;;CAgB8B,CAAC;AAEzC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,IAAI,EAAE,KAIlB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,KAIrB,CAAC;AAEF,eAAO,MAAM,KAAK,EAAE,KAKnB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,KAKtB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KAMxB,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KAK1B,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,KAK7B,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: import('react').ForwardRefExoticComponent<import('../components/bs-ui/tab-radio-group').TabRadioGroupProps & import('react').RefAttributes<HTMLDivElement>>;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Default: Story;
14
+ export declare const NormalSelected: Story;
15
+ export declare const ThreeOptions: Story;
16
+ export declare const WithCustomWidth: Story;
17
+ export declare const Controlled: Story;
18
+ //# sourceMappingURL=TabRadioGroup.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabRadioGroup.stories.d.ts","sourceRoot":"","sources":["../../src/stories/TabRadioGroup.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAK5D,QAAA,MAAM,IAAI;;;;;;;;CAQ4B,CAAC;AAEvC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAQrB,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,KAQ5B,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KAS1B,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,KAS7B,CAAC;AAoBF,eAAO,MAAM,UAAU,EAAE,KAKxB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: ({ text, children }: import('../components/bs-ui/user-txt-msg-bubble').UserTextMsgBubbleProps) => import("react/jsx-runtime").JSX.Element;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Base: Story;
14
+ //# sourceMappingURL=UserTextMsgBubble.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserTextMsgBubble.stories.d.ts","sourceRoot":"","sources":["../../src/stories/UserTextMsgBubble.stories.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAI5D,QAAA,MAAM,IAAI;;;;;;;;CAUgC,CAAC;AAE3C,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,IAAI,EAAE,KAIlB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: () => import("react/jsx-runtime").JSX.Element;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Base: Story;
14
+ //# sourceMappingURL=fields-generating.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-generating.stories.d.ts","sourceRoot":"","sources":["../../src/stories/fields-generating.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAI5D,QAAA,MAAM,IAAI;;;;;;;;CAUwC,CAAC;AAEnD,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,IAAI,EAAE,KAElB,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { StoryObj } from '@storybook/react-vite';
2
+ declare const meta: {
3
+ title: string;
4
+ component: ({ zIndex, children, title, tips, active, fullscreen, padding, className, empty, rightSpaceWidth, streaming, onBackClick, onSave, onCancel, style, }: import('../components/bs-ui/fields-previewer').FieldsPreviewerProps) => import("react/jsx-runtime").JSX.Element;
5
+ tags: string[];
6
+ parameters: {
7
+ layout: string;
8
+ };
9
+ args: {};
10
+ };
11
+ export default meta;
12
+ type Story = StoryObj<typeof meta>;
13
+ export declare const Base: Story;
14
+ export declare const WithSideSpace: Story;
15
+ export declare const streaming: Story;
16
+ export declare const Empty: Story;
17
+ export declare const Fullscreen: Story;
18
+ //# sourceMappingURL=fields-previewer.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-previewer.stories.d.ts","sourceRoot":"","sources":["../../src/stories/fields-previewer.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAI5D,QAAA,MAAM,IAAI;;;;;;;;CAU8B,CAAC;AAEzC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,IAAI,EAAE,KAMlB,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAO3B,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,KASvB,CAAC;AAEF,eAAO,MAAM,KAAK,EAAE,KAQnB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KASxB,CAAC"}
package/package.json ADDED
@@ -0,0 +1,76 @@
1
+ {
2
+ "name": "@baishuyun/chat-sdk",
3
+ "version": "0.0.1-alpha.1",
4
+ "description": "",
5
+ "main": "src/index.jsx",
6
+ "module": "dist/chat-sdk.js",
7
+ "style": "dist/style.css",
8
+ "type": "module",
9
+ "scripts": {
10
+ "test": "echo \"Error: no test specified\" && exit 1",
11
+ "build": "vite build",
12
+ "dev": "vite build --watch",
13
+ "storybook": "storybook dev -p 6006",
14
+ "build-storybook": "storybook build"
15
+ },
16
+ "dependencies": {
17
+ "@ai-sdk/react": "^2.0.101",
18
+ "@radix-ui/react-checkbox": "^1.3.3",
19
+ "@radix-ui/react-collapsible": "^1.1.12",
20
+ "@radix-ui/react-dialog": "^1.1.15",
21
+ "@radix-ui/react-dropdown-menu": "^2.1.16",
22
+ "@radix-ui/react-label": "^2.1.8",
23
+ "@radix-ui/react-radio-group": "^1.3.8",
24
+ "@radix-ui/react-select": "^2.2.6",
25
+ "@radix-ui/react-slot": "^1.2.4",
26
+ "@radix-ui/react-tabs": "^1.1.13",
27
+ "@radix-ui/react-tooltip": "^1.2.8",
28
+ "@baishuyun/agents": "workspace:*",
29
+ "ai": "^5.0.101",
30
+ "class-variance-authority": "^0.7.1",
31
+ "classnames": "^2.5.1",
32
+ "clsx": "^2.1.1",
33
+ "fast-deep-equal": "^3.1.3",
34
+ "lucide-react": "^0.554.0",
35
+ "marked": "^17.0.1",
36
+ "nanoid": "^5.1.6",
37
+ "radix-ui": "^1.4.3",
38
+ "react": "^18.2.0",
39
+ "react-dom": "^18.2.0",
40
+ "react-markdown": "^10.1.0",
41
+ "tailwind-merge": "^3.4.0",
42
+ "tailwindcss-animate": "^1.0.7",
43
+ "tw-animate-css": "^1.4.0",
44
+ "use-stick-to-bottom": "^1.1.1",
45
+ "zustand": "^5.0.8"
46
+ },
47
+ "devDependencies": {
48
+ "@baishuyun/types": "workspace:*",
49
+ "@baishuyun/typescript-config": "workspace:*",
50
+ "@storybook/react-vite": "^10.1.11",
51
+ "@tailwindcss/typography": "^0.5.19",
52
+ "@tailwindcss/vite": "^4.1.17",
53
+ "@types/react": "18.2.37",
54
+ "@types/react-dom": "18.2.15",
55
+ "@vitejs/plugin-react": "^5.1.1",
56
+ "eslint-plugin-storybook": "^10.1.11",
57
+ "less": "^4.4.2",
58
+ "rollup-plugin-visualizer": "^6.0.5",
59
+ "storybook": "^10.1.11",
60
+ "tailwindcss": "^4.1.17",
61
+ "vite": "^5.1.4",
62
+ "vite-plugin-dts": "^4.5.4"
63
+ },
64
+ "exports": {
65
+ ".": {
66
+ "import": "./dist/chat-sdk.js",
67
+ "require": "./dist/chat-sdk.umd.cjs",
68
+ "styles": "./dist/style.css",
69
+ "types": "./dist/index.d.ts"
70
+ },
71
+ "./css": "./dist/style.css"
72
+ },
73
+ "keywords": [],
74
+ "author": "",
75
+ "license": "ISC"
76
+ }
@@ -0,0 +1,36 @@
1
+ import { type Plugin } from "vite";
2
+
3
+ export function inlineCssPlugin(): Plugin {
4
+ return {
5
+ name: "inline-css-plugin",
6
+ apply: "build",
7
+ generateBundle(_, bundle) {
8
+ // 找到生成的 CSS 文件
9
+ const allCssFiles = Object.keys(bundle).filter((key) =>
10
+ key.endsWith(".css"),
11
+ );
12
+ let cssContent = "";
13
+
14
+ for (const cssFile of allCssFiles) {
15
+ // @ts-ignore
16
+ cssContent += bundle[cssFile].source + "\n";
17
+ }
18
+
19
+ // 创建包含 CSS 字符串的 JS 文件}
20
+ if (cssContent) {
21
+ // 直接注入到主 bundle
22
+ const mainFile = Object.keys(bundle).find(
23
+ (key) => key.endsWith(".js") && !key.includes("styles"),
24
+ );
25
+ // @ts-ignore
26
+ if (mainFile && bundle[mainFile].code) {
27
+ // @ts-ignore
28
+ bundle[mainFile].code =
29
+ `const __SDK_STYLES__ = ${JSON.stringify(cssContent)};\n` +
30
+ // @ts-ignore
31
+ bundle[mainFile].code;
32
+ }
33
+ }
34
+ },
35
+ };
36
+ }
package/src/chat.tsx ADDED
@@ -0,0 +1,56 @@
1
+ import { useChat } from '@ai-sdk/react';
2
+ import { DefaultChatTransport } from 'ai';
3
+ import { useEffect, useState } from 'react';
4
+ import { ChatFrame } from '@/components/biz-comp/chat-frame';
5
+ import { Messages } from '@/components/biz-comp/messages';
6
+ import { Attachment, ChatMessage } from '@baishuyun/types';
7
+ import { ChatSDK } from '@/.';
8
+ import { MultimodalInput } from './components/biz-comp/multi-modal-input';
9
+
10
+ export const Chat = ({ client }: { client: ChatSDK }) => {
11
+ const { messages, sendMessage, status, id, setMessages, stop, addToolOutput } =
12
+ useChat<ChatMessage>({
13
+ transport: new DefaultChatTransport({
14
+ api: client?.options?.chatApiEndpoint,
15
+ }),
16
+ });
17
+
18
+ const [input, setInput] = useState('');
19
+
20
+ const [attachments, setAttachments] = useState<Attachment[]>([]);
21
+
22
+ useEffect(() => {
23
+ return () => {
24
+ stop();
25
+ };
26
+ }, []);
27
+
28
+ return (
29
+ <ChatFrame
30
+ messagesArea={
31
+ <Messages
32
+ status={status}
33
+ messages={messages}
34
+ setMessages={setMessages}
35
+ sendMessage={sendMessage}
36
+ addToolOutput={addToolOutput}
37
+ />
38
+ }
39
+ inputArea={
40
+ <MultimodalInput
41
+ fileUploadEndpoint={client.options!.fileUploadEndPoint!}
42
+ attachments={attachments}
43
+ chatId={id}
44
+ input={input}
45
+ messages={messages}
46
+ sendMessage={sendMessage}
47
+ setAttachments={setAttachments}
48
+ setInput={setInput}
49
+ setMessages={setMessages}
50
+ status={status}
51
+ stop={stop}
52
+ />
53
+ }
54
+ />
55
+ );
56
+ };
@@ -0,0 +1,52 @@
1
+ import { ComponentType, ReactNode } from 'react';
2
+ import { MessageContent } from './message-content';
3
+ import { cn } from '@/lib/utils';
4
+ import { BotAvatarAndName } from '../bs-ui/bot-avatar-name';
5
+ import { useDefaultPluginCustomComponent } from '@/hooks/use-plugin-custom-components';
6
+
7
+ export const FakeBotMessage = ({
8
+ children,
9
+ headless,
10
+ }: {
11
+ children: ReactNode;
12
+ headless?: boolean;
13
+ offset?: boolean;
14
+ }) => {
15
+ const avatarComInfo = useDefaultPluginCustomComponent('AvatarAndName');
16
+
17
+ if (headless) {
18
+ return (
19
+ <div>
20
+ <MessageContent
21
+ className="w-fit wrap-break-words rounded-2 bg-transparent px-0 py-0 text-left"
22
+ data-testid="message-content"
23
+ >
24
+ {children}
25
+ </MessageContent>
26
+ </div>
27
+ );
28
+ }
29
+
30
+ const Avatar: ComponentType | undefined = avatarComInfo?.Component;
31
+ const avatarJsx = Avatar ? <Avatar /> : <BotAvatarAndName name={'AI表单搭建'} />;
32
+
33
+ return (
34
+ <div
35
+ className={cn('group/message w-full')}
36
+ data-role="assistant"
37
+ data-testid={`message-assistant`}
38
+ >
39
+ <div className="flex w-full flex-col items-start justify-start gap-2.5">
40
+ {avatarJsx}
41
+ <div className="flex flex-col min-w-0 grow gap-2.5 w-full">
42
+ <MessageContent
43
+ className="w-full wrap-break-words rounded-2 bg-transparent px-0 py-0 text-left"
44
+ data-testid="message-content"
45
+ >
46
+ {children}
47
+ </MessageContent>
48
+ </div>
49
+ </div>
50
+ </div>
51
+ );
52
+ };
@@ -0,0 +1,114 @@
1
+ import { Checkbox } from '@/components/ui/checkbox';
2
+ import { memo, useEffect } from 'react';
3
+ import { Label } from '@/components/ui/label';
4
+ import { FieldType, ValueOf } from '@baishuyun/types';
5
+ import { FieldTypeNameMap } from '@/const';
6
+ import { ToolUIPart } from 'ai';
7
+ import { FieldsTools, Option } from '@baishuyun/agents';
8
+ import { cn } from '@/lib/utils';
9
+ import LineChecker from '../bs-ui/line-checker';
10
+ import { OptionItem } from '../bs-ui/option-item';
11
+ import { FieldIcon } from '@/components/biz-comp/field-icon';
12
+
13
+ type Field = ValueOf<Pick<ToolUIPart<FieldsTools>, 'output'>>;
14
+
15
+ export interface FieldCheckerProps {
16
+ field: ValueOf<Pick<ToolUIPart<FieldsTools>, 'output'>>;
17
+ isSubField?: boolean;
18
+ disabled?: boolean;
19
+ icon?: React.ReactNode;
20
+ onChange?: (checked: boolean, field: Field, parentFieldName?: string, index?: number) => void;
21
+ value?: unknown;
22
+ onLoaded?: (field: Field) => void;
23
+ }
24
+
25
+ export const FieldChecker = memo(
26
+ ({ field, disabled, isSubField, onChange, onLoaded, icon, value }: FieldCheckerProps) => {
27
+ const { widget, label } = field;
28
+ if (!widget) {
29
+ return null;
30
+ }
31
+
32
+ const { type } = widget;
33
+
34
+ const t = type as FieldType;
35
+
36
+ if (!FieldTypeNameMap.hasOwnProperty(type)) {
37
+ return null;
38
+ }
39
+
40
+ const typeDesc = FieldTypeNameMap[t] || FieldTypeNameMap.unknown;
41
+
42
+ const isSubForm = type === 'subform';
43
+
44
+ const items = isSubForm ? [] : (widget.items as Option[]) || [];
45
+
46
+ useEffect(() => {
47
+ onLoaded?.(field);
48
+ }, []);
49
+
50
+ const handleCheck = (checked: boolean) => {
51
+ onChange?.(checked, field);
52
+ };
53
+
54
+ const extraPadding = isSubField ? 'pl-[38px]' : '';
55
+
56
+ // 表单填充
57
+ if (value) {
58
+ return (
59
+ <LineChecker
60
+ title={label}
61
+ disabled={disabled}
62
+ defaultChecked={true}
63
+ onCheckedChange={handleCheck}
64
+ icon={icon}
65
+ className={extraPadding}
66
+ shortDesc={value as string}
67
+ />
68
+ );
69
+ }
70
+
71
+ return (
72
+ <>
73
+ <LineChecker
74
+ title={label}
75
+ disabled={disabled}
76
+ defaultChecked={true}
77
+ onCheckedChange={handleCheck}
78
+ icon={icon}
79
+ shortDesc={typeDesc}
80
+ className={extraPadding}
81
+ extra={
82
+ items.length ? (
83
+ <>
84
+ {items.map(({ value, text, color }) => (
85
+ <OptionItem key={value} color={color ? 'white' : undefined} bgColor={color}>
86
+ {text}
87
+ </OptionItem>
88
+ ))}
89
+ </>
90
+ ) : null
91
+ }
92
+ />
93
+ {isSubForm
94
+ ? widget.items.map((subField: Field, index: number) => (
95
+ <FieldChecker
96
+ key={subField.label}
97
+ isSubField={true}
98
+ disabled={disabled}
99
+ field={subField}
100
+ icon={<FieldIcon type={subField.widget?.type} />}
101
+ onChange={(checked) => {
102
+ // 处理子表单字段变化
103
+ onChange?.(checked, subField, field.widget.widgetName, index);
104
+ }}
105
+ />
106
+ ))
107
+ : null}
108
+ </>
109
+ );
110
+ },
111
+ (p1, p2) => {
112
+ return p1.field?.label === p2.field?.label && p1.disabled === p2.disabled;
113
+ }
114
+ );