@gientech/modual 1.2.7 → 1.2.9-fix

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 (377) hide show
  1. package/.editorconfig +38 -0
  2. package/.prettierignore +16 -0
  3. package/.prettierrc +17 -0
  4. package/README.md +643 -129
  5. package/USAGE.md +247 -0
  6. package/bash.exe.stackdump +40 -0
  7. package/components.json +21 -0
  8. package/dist/README.md +643 -0
  9. package/dist/assets/GientechStreamReader-C21-q_Qv.js +449 -0
  10. package/dist/assets/chevron-down-DjLtKwcs.js +280 -0
  11. package/{assets → dist/assets}/database.svg +11 -11
  12. package/{assets → dist/assets}/database_add.svg +53 -53
  13. package/{assets → dist/assets}/database_connect.svg +66 -66
  14. package/{assets → dist/assets}/database_upload.svg +29 -29
  15. package/dist/assets/databse.svg +6 -0
  16. package/{assets → dist/assets}/defaultWeLogo.svg +14 -14
  17. package/dist/assets/graph.svg +4 -0
  18. package/dist/assets/homeBg.png +0 -0
  19. package/dist/assets/index-BMz4lcjQ.js +1 -0
  20. package/dist/assets/index-C3Viu8Oj.js +1 -0
  21. package/dist/assets/index-C9GlPyHu.js +13 -0
  22. package/dist/assets/index-CRbX3ZA1.js +1 -0
  23. package/dist/assets/index-CTwzi_v2.js +21 -0
  24. package/dist/assets/index-DQlLDleQ.js +11 -0
  25. package/dist/assets/index-DRU1P9R0.js +1150 -0
  26. package/dist/assets/index-Dqej68NT.js +585 -0
  27. package/dist/assets/index-ECprhahs.js +157 -0
  28. package/dist/assets/index-i7qcZOwY.js +1088 -0
  29. package/dist/assets/knowledge.svg +4 -0
  30. package/dist/assets/left.jpg +0 -0
  31. package/dist/assets/logoImg.png +0 -0
  32. package/{assets/MySQL.svg → dist/assets/mysql.svg} +14 -14
  33. package/{assets/plus-fNg4vmeA.js → dist/assets/plus-CvJRSbOe.js} +1 -1
  34. package/dist/assets/sensitive.svg +5 -0
  35. package/dist/assets/style.css +1 -0
  36. package/dist/assets/style3.css +1 -0
  37. package/dist/assets/worker-BbpylX7l.js +13 -0
  38. package/{assets/x-tMUaBf0a.js → dist/assets/x-DKPeLdlu.js} +1 -1
  39. package/dist/assistantConfig.d.ts +31 -0
  40. package/dist/assistantConfig.js +1 -0
  41. package/{chat.d.ts → dist/chat.d.ts} +25 -1
  42. package/dist/chat.js +842 -0
  43. package/dist/database.js +20 -0
  44. package/dist/databaseId.js +1 -0
  45. package/dist/databaseTable.js +6 -0
  46. package/dist/index.d.ts +85 -0
  47. package/dist/index.js +1 -0
  48. package/dist/modelManage.js +1 -0
  49. package/dist/package.json +68 -0
  50. package/dist/sensitive.js +1 -0
  51. package/{streamFilesReader.d.ts → dist/streamFilesReader.d.ts} +3 -0
  52. package/dist/streamFilesReader.js +1 -0
  53. package/{worker → dist/worker}/pdf.worker.min.js +21 -21
  54. package/doc_assets/2.png +0 -0
  55. package/doc_assets/demo.md +27 -0
  56. package/doc_assets/demos/dist-app/assets/index.Dh-ZAS9Z.css +2 -0
  57. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js +23699 -0
  58. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js.map +1 -0
  59. package/doc_assets/demos/dist-app/index.html +14 -0
  60. package/doc_assets/demos/dist-app/vite.svg +1 -0
  61. package/doc_assets/images/1.png +0 -0
  62. package/doc_assets/images/3.png +0 -0
  63. package/doc_assets/images/component-screenshot.png +1 -0
  64. package/doc_assets/install.md +5 -0
  65. package/doc_assets//346/226/271/346/241/210//344/274/230/345/214/226/346/226/271/346/241/210-/345/244/232/344/274/232/350/257/235SSE/350/277/236/346/216/245/347/256/241/347/220/206.md +504 -0
  66. package/eslint.config.js +92 -0
  67. package/index.html +13 -0
  68. package/package.json +109 -40
  69. package/package.json.demo-backup +109 -0
  70. package/postcss.config.cjs +19 -0
  71. package/public/vite.svg +1 -0
  72. package/public/worker/pdf.worker.min.js +22 -0
  73. package/scripts/README.md +133 -0
  74. package/scripts/build-demo.js +88 -0
  75. package/scripts/demo-selector.js +216 -0
  76. package/scripts/dev-demo.js +76 -0
  77. package/scripts/preview-demo.js +130 -0
  78. package/scripts/run-demo.bat +34 -0
  79. package/src/assets/img/close.png +0 -0
  80. package/src/assets/img/database.png +0 -0
  81. package/src/assets/img/downArrow.png +0 -0
  82. package/src/assets/img/downLoad.png +0 -0
  83. package/src/assets/img/excel.png +0 -0
  84. package/src/assets/img/graphIcon.png +0 -0
  85. package/src/assets/img/img.png +0 -0
  86. package/src/assets/img/pdf.png +0 -0
  87. package/src/assets/img/ppt.png +0 -0
  88. package/src/assets/img/singleQa.png +0 -0
  89. package/src/assets/img/txt.png +0 -0
  90. package/src/assets/img/webSearch.png +0 -0
  91. package/src/assets/img/word.png +0 -0
  92. package/src/assets/login/homeBg.png +0 -0
  93. package/src/assets/login/left.jpg +0 -0
  94. package/src/assets/login/logoImg.png +0 -0
  95. package/src/examples/ConversationAssistantPage/index.tsx +37 -0
  96. package/src/examples/Demo/index.tsx +12 -0
  97. package/src/examples/LoginPage/index.tsx +18 -0
  98. package/src/examples/chat/components/DrawerGraphPreview.tsx +78 -0
  99. package/src/examples/chat/index.tsx +153 -0
  100. package/src/examples/chat/logo03.png +0 -0
  101. package/src/examples/gientechStreamFilesReader/index.tsx +951 -0
  102. package/src/examples/ragDatabaseDataPage/index.tsx +36 -0
  103. package/src/examples/ragDatabaseIdPage/index.tsx +44 -0
  104. package/src/examples/ragDatabasePage/index.tsx +36 -0
  105. package/src/examples/ragModelManagePage/index.tsx +37 -0
  106. package/src/examples/ragSearchPage/index.tsx +0 -0
  107. package/src/examples/ragSensitiveWordsPage/index.tsx +32 -0
  108. package/src/examples/streamFiles/index.tsx +384 -0
  109. package/src/lib_enter.ts +43 -0
  110. package/src/main.tsx +5 -0
  111. package/src/main.tsx.backup +5 -0
  112. package/src/modules/assistantConfig/assets/databse.svg +6 -0
  113. package/src/modules/assistantConfig/assets/empty.png +0 -0
  114. package/src/modules/assistantConfig/assets/graph.svg +4 -0
  115. package/src/modules/assistantConfig/assets/knowledge.svg +4 -0
  116. package/src/modules/assistantConfig/assets/sensitive.svg +5 -0
  117. package/src/modules/assistantConfig/components/Database.tsx +144 -0
  118. package/src/modules/assistantConfig/components/Graph.tsx +156 -0
  119. package/src/modules/assistantConfig/components/Knowledge.tsx +266 -0
  120. package/src/modules/assistantConfig/components/NotFoundContent.tsx +21 -0
  121. package/src/modules/assistantConfig/components/Paragraph.tsx +51 -0
  122. package/src/modules/assistantConfig/components/ParamsItem.tsx +39 -0
  123. package/src/modules/assistantConfig/components/ResourceBinderItem.tsx +132 -0
  124. package/src/modules/assistantConfig/components/SearchableSelector.tsx +500 -0
  125. package/src/modules/assistantConfig/components/Sensitive.tsx +179 -0
  126. package/src/modules/assistantConfig/components/SliderInput.tsx +65 -0
  127. package/src/modules/assistantConfig/constants.tsx +74 -0
  128. package/src/modules/assistantConfig/index.tsx +700 -0
  129. package/src/modules/assistantConfig/server.ts +262 -0
  130. package/src/modules/chat/Conversations/Item.tsx +167 -0
  131. package/src/modules/chat/Conversations/List.tsx +210 -0
  132. package/src/modules/chat/Conversations/groupByTime.ts +39 -0
  133. package/src/modules/chat/Conversations/index.tsx +230 -0
  134. package/src/modules/chat/ReferenceBar.tsx +592 -0
  135. package/src/modules/chat/constants.tsx +56 -0
  136. package/src/modules/chat/data.txt +82 -0
  137. package/src/modules/chat/index.tsx +2081 -0
  138. package/src/modules/chat/referenceCom/DeleteModal.tsx +75 -0
  139. package/src/modules/chat/referenceCom/DrawerContent.tsx +136 -0
  140. package/src/modules/chat/referenceCom/DrawerDatabase.tsx +110 -0
  141. package/src/modules/chat/referenceCom/DrawerGraphPreview.tsx +86 -0
  142. package/src/modules/chat/referenceCom/DrawerPreview.tsx +73 -0
  143. package/src/modules/chat/referenceCom/DrawerTitle.tsx +26 -0
  144. package/src/modules/chat/referenceCom/RenameModal.tsx +86 -0
  145. package/src/modules/chat/referenceCom/TagCom.tsx +30 -0
  146. package/src/modules/chat/style.less +3 -0
  147. package/src/modules/chat/types.ts +17 -0
  148. package/src/modules/chat/utils/index.ts +326 -0
  149. package/src/modules/database/CreateModal.tsx +398 -0
  150. package/src/modules/database/assets/Doris.png +0 -0
  151. package/src/modules/database/assets/PostgreSQL.png +0 -0
  152. package/src/modules/database/assets/SQLServer.png +0 -0
  153. package/src/modules/database/assets/database.svg +11 -0
  154. package/src/modules/database/assets/database_add.svg +53 -0
  155. package/src/modules/database/assets/database_connect.svg +66 -0
  156. package/src/modules/database/assets/database_upload.svg +29 -0
  157. package/src/modules/database/assets/empty.png +0 -0
  158. package/src/modules/database/assets/mysql.svg +14 -0
  159. package/src/modules/database/index.tsx +466 -0
  160. package/src/modules/database/server.ts +196 -0
  161. package/src/modules/databaseId/CustomCom.tsx +156 -0
  162. package/src/modules/databaseId/EditConfig.tsx +268 -0
  163. package/src/modules/databaseId/UploadDrawer.tsx +520 -0
  164. package/src/modules/databaseId/assets/aiOptimize.svg +10 -0
  165. package/src/modules/databaseId/assets/empty.png +0 -0
  166. package/src/modules/databaseId/assets/template.svg +6 -0
  167. package/src/modules/databaseId/assets/upload.svg +9 -0
  168. package/src/modules/databaseId/assets/useTemp.svg +6 -0
  169. package/src/modules/databaseId/index.tsx +734 -0
  170. package/src/modules/databaseId/server.ts +286 -0
  171. package/src/modules/databaseId/style.css +5 -0
  172. package/src/modules/databaseTable/EditRowDrawer.tsx +119 -0
  173. package/src/modules/databaseTable/index.tsx +357 -0
  174. package/src/modules/databaseTable/server.ts +180 -0
  175. package/src/modules/headlessChat/constants.tsx +32 -0
  176. package/src/modules/headlessChat/index.tsx +1063 -0
  177. package/src/modules/headlessChat/types.ts +23 -0
  178. package/src/modules/login/components/Login/LoginBox/index.tsx +102 -0
  179. package/src/modules/login/components/Login/RegisterBox/index.tsx +180 -0
  180. package/src/modules/login/components/Login/index.tsx +100 -0
  181. package/src/modules/login/index.tsx +106 -0
  182. package/src/modules/login/style.css +3 -0
  183. package/src/modules/login/useServices.ts +53 -0
  184. package/src/modules/login/utils.ts +42 -0
  185. package/src/modules/modelManage/ConfigDrawer.tsx +249 -0
  186. package/src/modules/modelManage/assets/empty.png +0 -0
  187. package/src/modules/modelManage/const.ts +50 -0
  188. package/src/modules/modelManage/index.tsx +439 -0
  189. package/src/modules/modelManage/server.ts +185 -0
  190. package/src/modules/nodegraph/index.tsx +1 -0
  191. package/src/modules/search/assets/Icon-history.svg +8 -0
  192. package/src/modules/search/assets/answerAwartar.png +0 -0
  193. package/src/modules/search/assets/doc.png +0 -0
  194. package/src/modules/search/assets/genera.gif +0 -0
  195. package/src/modules/search/assets/icon-robot.svg +9 -0
  196. package/src/modules/search/assets/icon-search-bar.svg +14 -0
  197. package/src/modules/search/assets/icon-sub-title.svg +3 -0
  198. package/src/modules/search/assets/icon-title.svg +9 -0
  199. package/src/modules/search/assets/icon-zoomOut.svg +9 -0
  200. package/src/modules/search/assets/iconAi.svg +9 -0
  201. package/src/modules/search/assets/pdf.png +0 -0
  202. package/src/modules/search/assets/ppt.png +0 -0
  203. package/src/modules/search/assets/search.svg +3 -0
  204. package/src/modules/search/assets/selected.svg +4 -0
  205. package/src/modules/search/assets/txt.png +0 -0
  206. package/src/modules/search/assets/xls.png +0 -0
  207. package/src/modules/search/components/AssisSelect.tsx +137 -0
  208. package/src/modules/search/components/Editor/ChatViewEditor.tsx +261 -0
  209. package/src/modules/search/components/Editor/aichat.css +1 -0
  210. package/src/modules/search/components/Editor/constant.ts +13 -0
  211. package/src/modules/search/components/Editor/index.tsx +113 -0
  212. package/src/modules/search/components/Editor/plugins/autofomatRules.ts +332 -0
  213. package/src/modules/search/components/Editor/plugins/convertImgPlugins.tsx +20 -0
  214. package/src/modules/search/components/Editor/plugins/createIndexes.tsx +38 -0
  215. package/src/modules/search/components/Editor/plugins/displayer.ts +298 -0
  216. package/src/modules/search/components/Editor/plugins/imageClick.tsx +32 -0
  217. package/src/modules/search/components/Editor/plugins/myplugin.tsx +98 -0
  218. package/src/modules/search/components/Editor/ui/avatar.tsx +19 -0
  219. package/src/modules/search/components/Editor/ui/blockquote-element.tsx +21 -0
  220. package/src/modules/search/components/Editor/ui/button.tsx +58 -0
  221. package/src/modules/search/components/Editor/ui/calendar.tsx +68 -0
  222. package/src/modules/search/components/Editor/ui/caption.tsx +46 -0
  223. package/src/modules/search/components/Editor/ui/checkbox.tsx +27 -0
  224. package/src/modules/search/components/Editor/ui/code-block-combobox.tsx +188 -0
  225. package/src/modules/search/components/Editor/ui/code-block-element.css +434 -0
  226. package/src/modules/search/components/Editor/ui/code-block-element.tsx +39 -0
  227. package/src/modules/search/components/Editor/ui/code-leaf.tsx +24 -0
  228. package/src/modules/search/components/Editor/ui/code-line-element.tsx +10 -0
  229. package/src/modules/search/components/Editor/ui/code-syntax-leaf.tsx +21 -0
  230. package/src/modules/search/components/Editor/ui/column-element.tsx +30 -0
  231. package/src/modules/search/components/Editor/ui/column-group-element.tsx +94 -0
  232. package/src/modules/search/components/Editor/ui/command.tsx +75 -0
  233. package/src/modules/search/components/Editor/ui/comment-avatar.tsx +22 -0
  234. package/src/modules/search/components/Editor/ui/comment-create-form.tsx +37 -0
  235. package/src/modules/search/components/Editor/ui/comment-item.tsx +74 -0
  236. package/src/modules/search/components/Editor/ui/comment-leaf.tsx +49 -0
  237. package/src/modules/search/components/Editor/ui/comment-more-dropdown.tsx +42 -0
  238. package/src/modules/search/components/Editor/ui/comment-reply-items.tsx +22 -0
  239. package/src/modules/search/components/Editor/ui/comment-resolve-button.tsx +32 -0
  240. package/src/modules/search/components/Editor/ui/comment-value.tsx +34 -0
  241. package/src/modules/search/components/Editor/ui/comments-popover.tsx +63 -0
  242. package/src/modules/search/components/Editor/ui/date-element.tsx +83 -0
  243. package/src/modules/search/components/Editor/ui/dialog.tsx +63 -0
  244. package/src/modules/search/components/Editor/ui/draggable.tsx +177 -0
  245. package/src/modules/search/components/Editor/ui/dropdown-menu.tsx +180 -0
  246. package/src/modules/search/components/Editor/ui/emoji-input-element.tsx +85 -0
  247. package/src/modules/search/components/Editor/ui/excalidraw-element.tsx +28 -0
  248. package/src/modules/search/components/Editor/ui/fixed-toolbar-buttons.tsx +76 -0
  249. package/src/modules/search/components/Editor/ui/fixed-toolbar.tsx +8 -0
  250. package/src/modules/search/components/Editor/ui/floating-toolbar-buttons.tsx +51 -0
  251. package/src/modules/search/components/Editor/ui/floating-toolbar.tsx +77 -0
  252. package/src/modules/search/components/Editor/ui/heading-element.tsx +48 -0
  253. package/src/modules/search/components/Editor/ui/highlight-leaf.tsx +17 -0
  254. package/src/modules/search/components/Editor/ui/hr-element.tsx +30 -0
  255. package/src/modules/search/components/Editor/ui/icons.tsx +267 -0
  256. package/src/modules/search/components/Editor/ui/image-element.tsx +74 -0
  257. package/src/modules/search/components/Editor/ui/inline-combobox.tsx +368 -0
  258. package/src/modules/search/components/Editor/ui/input.tsx +25 -0
  259. package/src/modules/search/components/Editor/ui/insert-dropdown-menu.tsx +218 -0
  260. package/src/modules/search/components/Editor/ui/kbd-leaf.tsx +20 -0
  261. package/src/modules/search/components/Editor/ui/link-element.tsx +29 -0
  262. package/src/modules/search/components/Editor/ui/link-floating-toolbar.tsx +161 -0
  263. package/src/modules/search/components/Editor/ui/list-element.tsx +30 -0
  264. package/src/modules/search/components/Editor/ui/mark-toolbar-button.tsx +24 -0
  265. package/src/modules/search/components/Editor/ui/media-embed-element.tsx +133 -0
  266. package/src/modules/search/components/Editor/ui/media-popover.tsx +97 -0
  267. package/src/modules/search/components/Editor/ui/mention-element.tsx +43 -0
  268. package/src/modules/search/components/Editor/ui/mention-input-element.tsx +141 -0
  269. package/src/modules/search/components/Editor/ui/mode-dropdown-menu.tsx +93 -0
  270. package/src/modules/search/components/Editor/ui/more-dropdown-menu.tsx +67 -0
  271. package/src/modules/search/components/Editor/ui/paragraph-element.tsx +4 -0
  272. package/src/modules/search/components/Editor/ui/placeholder.tsx +52 -0
  273. package/src/modules/search/components/Editor/ui/popover.tsx +32 -0
  274. package/src/modules/search/components/Editor/ui/resizable.tsx +66 -0
  275. package/src/modules/search/components/Editor/ui/separator.tsx +25 -0
  276. package/src/modules/search/components/Editor/ui/style.less +12 -0
  277. package/src/modules/search/components/Editor/ui/table-cell-element.tsx +143 -0
  278. package/src/modules/search/components/Editor/ui/table-element.tsx +243 -0
  279. package/src/modules/search/components/Editor/ui/table-row-element.tsx +22 -0
  280. package/src/modules/search/components/Editor/ui/tableValue.tsx +135 -0
  281. package/src/modules/search/components/Editor/ui/todo-list-element.tsx +43 -0
  282. package/src/modules/search/components/Editor/ui/toggle-element.tsx +31 -0
  283. package/src/modules/search/components/Editor/ui/toolbar.tsx +157 -0
  284. package/src/modules/search/components/Editor/ui/tooltip.tsx +65 -0
  285. package/src/modules/search/components/Editor/ui/turn-into-dropdown-menu.tsx +160 -0
  286. package/src/modules/search/components/Editor/ui/with-draggables.tsx +175 -0
  287. package/src/modules/search/components/FileList.tsx +287 -0
  288. package/src/modules/search/components/ImageGroupView/index.tsx +85 -0
  289. package/src/modules/search/components/ResultContent.tsx +232 -0
  290. package/src/modules/search/components/SearchInput.tsx +232 -0
  291. package/src/modules/search/components/SearchLanding.tsx +74 -0
  292. package/src/modules/search/components/SearchView.tsx +563 -0
  293. package/src/modules/search/components/SimpleEditor.tsx +158 -0
  294. package/src/modules/search/components/SimpleFileList.tsx +215 -0
  295. package/src/modules/search/index.tsx +10 -0
  296. package/src/modules/search/reademe.md +1 -0
  297. package/src/modules/search/servers/apis.tsx +19 -0
  298. package/src/modules/search/servers/index.ts +184 -0
  299. package/src/modules/search/style.less +503 -0
  300. package/src/modules/search/type.ts +22 -0
  301. package/src/modules/search/utils.ts +34 -0
  302. package/src/modules/sensitive/index.tsx +313 -0
  303. package/src/modules/sensitive/server.ts +122 -0
  304. package/src/modules/streamFilesReader/GientechStreamReader.tsx +1624 -0
  305. package/src/modules/streamFilesReader/components/Header/Toolbar.tsx +0 -0
  306. package/src/modules/streamFilesReader/components/Header/index.tsx +297 -0
  307. package/src/modules/streamFilesReader/index.tsx +3 -0
  308. package/src/style.css +6 -0
  309. package/src/type.d.ts +0 -0
  310. package/src/utils/commonFn.tsx +111 -0
  311. package/src/utils/gientechCommon/components/AppError.tsx +32 -0
  312. package/src/utils/gientechCommon/components/AppLoading.tsx +75 -0
  313. package/src/utils/gientechCommon/components/DeleteModal.tsx +75 -0
  314. package/src/utils/gientechCommon/components/DisplayError.tsx +33 -0
  315. package/src/utils/gientechCommon/components/DisplayLoading.tsx +38 -0
  316. package/src/utils/gientechCommon/components/FeedBackModal.tsx +310 -0
  317. package/src/utils/gientechCommon/components/FileCardCommon.tsx +82 -0
  318. package/src/utils/gientechCommon/components/FileManager/index.tsx +390 -0
  319. package/src/utils/gientechCommon/components/FileManager/style.css +5 -0
  320. package/src/utils/gientechCommon/components/Messages/GientechNewChatWelcome.tsx +581 -0
  321. package/src/utils/gientechCommon/components/Messages/ReferenceCard.tsx +339 -0
  322. package/src/utils/gientechCommon/components/Messages/RetriveItem.tsx +245 -0
  323. package/src/utils/gientechCommon/components/Messages/WebRetriveItem.tsx +209 -0
  324. package/src/utils/gientechCommon/components/Messages/defaultBot.png +0 -0
  325. package/src/utils/gientechCommon/components/Messages/defaultStyleSet.tsx +148 -0
  326. package/src/utils/gientechCommon/components/Messages/defaultWeLogo.svg +14 -0
  327. package/src/utils/gientechCommon/components/RenameModal.tsx +86 -0
  328. package/src/utils/gientechCommon/components/style.less +11 -0
  329. package/src/utils/gientechCommon/configs/commonConfig.ts +2 -0
  330. package/src/utils/gientechCommon/configs/senderConfig.ts +0 -0
  331. package/src/utils/gientechCommon/configs/stylesConfig.ts +142 -0
  332. package/src/utils/gientechCommon/hooks/AichatUseController.tsx +417 -0
  333. package/src/utils/gientechCommon/slate/converters/deserializers.ts +763 -0
  334. package/src/utils/gientechCommon/slate/converters/mockData.ts +232 -0
  335. package/src/utils/gientechCommon/slate/converters/slateConverters.ts +258 -0
  336. package/src/utils/gientechCommon/slate/richElements/index.tsx +499 -0
  337. package/src/utils/gientechCommon/utils/request.ts +37 -0
  338. package/src/utils/gientechCommon/utils/serverFn.ts +172 -0
  339. package/src/utils/index.tsx +126 -0
  340. package/src/utils/testconfigs/demologin/index.tsx +32 -0
  341. package/src/utils/testconfigs/index.ts +59 -0
  342. package/src/vite-env.d.ts +11 -0
  343. package/stats.html +4949 -0
  344. package/tailwind.config.js +170 -0
  345. package/tsconfig.app.json +30 -0
  346. package/tsconfig.app.tsbuildinfo +11 -0
  347. package/tsconfig.json +13 -0
  348. package/tsconfig.node.json +22 -0
  349. package/tsconfig.node.tsbuildinfo +1 -0
  350. package/vite.config.ts +227 -0
  351. package/workflows/release.yml +60 -0
  352. package/assets/_commonjsHelpers-gnU0ypJ3.js +0 -1
  353. package/assets/index--DG-fVvc.js +0 -26
  354. package/assets/index-BfureYPx.js +0 -1505
  355. package/assets/index-CXwV5fAx.js +0 -1230
  356. package/assets/style.css +0 -1
  357. package/assets/style3.css +0 -1
  358. package/assets/styled-components.browser.esm-DPkS13KC.js +0 -2
  359. package/chat.js +0 -893
  360. package/database.js +0 -20
  361. package/databaseId.js +0 -21
  362. package/databaseTable.js +0 -6
  363. package/modelManage.js +0 -1
  364. package/sensitive.js +0 -1
  365. package/streamFilesReader.js +0 -442
  366. /package/{assets → dist/assets}/Doris.png +0 -0
  367. /package/{assets → dist/assets}/PostgreSQL.png +0 -0
  368. /package/{assets → dist/assets}/SQLServer.png +0 -0
  369. /package/{assets → dist/assets}/empty.png +0 -0
  370. /package/{assets → dist/assets}/index-CpW6Dhpp.js +0 -0
  371. /package/{assets → dist/assets}/style2.css +0 -0
  372. /package/{database.d.ts → dist/database.d.ts} +0 -0
  373. /package/{databaseId.d.ts → dist/databaseId.d.ts} +0 -0
  374. /package/{databaseTable.d.ts → dist/databaseTable.d.ts} +0 -0
  375. /package/{modelManage.d.ts → dist/modelManage.d.ts} +0 -0
  376. /package/{sensitive.d.ts → dist/sensitive.d.ts} +0 -0
  377. /package/{vite.svg → dist/vite.svg} +0 -0
@@ -0,0 +1,132 @@
1
+ import { useState } from 'react';
2
+ import { Tag, Button } from 'antd';
3
+ import { ChevronUp, ChevronDown, CircleX, X } from 'lucide-react';
4
+
5
+ interface Items {
6
+ key: string;
7
+ label: string;
8
+ tags?: string[];
9
+ }
10
+
11
+ const ResourceBinderItem = ({
12
+ countText,
13
+ eventsEmit,
14
+ data,
15
+ }: {
16
+ countText?: string;
17
+ eventsEmit: (name: string, data?: any) => void;
18
+ data: Items[];
19
+ }) => {
20
+ const [expanded, setExpanded] = useState(true);
21
+ return (
22
+ <div
23
+ style={{
24
+ marginTop: 8,
25
+ }}
26
+ >
27
+ {countText && (
28
+ <div className="flex items-center gap-2">
29
+ <span style={{ color: expanded ? '#4E6EF2' : '#4E5969' }}>{countText}</span>
30
+ {expanded ? (
31
+ <ChevronUp onClick={() => setExpanded(v => !v)} color="#4E6EF2" size={14} />
32
+ ) : (
33
+ <ChevronDown onClick={() => setExpanded(v => !v)} color="#4E5969" size={14} />
34
+ )}
35
+ </div>
36
+ )}
37
+
38
+ <div
39
+ style={{
40
+ display: expanded ? 'block' : 'none',
41
+ }}
42
+ >
43
+ {data.map(item => (
44
+ <BindTagItem key={item.key} item={item} eventsEmit={eventsEmit} />
45
+ ))}
46
+ </div>
47
+ </div>
48
+ );
49
+ };
50
+
51
+ const BindTagItem = ({ item, eventsEmit }: any) => {
52
+ const [expanded, setExpanded] = useState(true);
53
+
54
+ return (
55
+ <div
56
+ key={item.key}
57
+ className="flex items-center justify-between"
58
+ style={{ padding: '8px 12px', borderRadius: 6 }}
59
+ >
60
+ <div>
61
+ <div style={{ color: '#1D2129' }} className="flex items-center">
62
+ {item.label}
63
+ {item?.tags?.length > 0 && (
64
+ <>
65
+ <span
66
+ style={{
67
+ color: '#4E5969',
68
+ marginLeft: '6px',
69
+ marginRight: 6,
70
+ }}
71
+ >
72
+ ({item?.tags?.length}个标签)
73
+ </span>
74
+ {expanded ? (
75
+ <ChevronUp onClick={() => setExpanded(v => !v)} color="#4E6EF2" size={14} />
76
+ ) : (
77
+ <ChevronDown onClick={() => setExpanded(v => !v)} color="#4E5969" size={14} />
78
+ )}
79
+ </>
80
+ )}
81
+ </div>
82
+
83
+ {item?.tags?.length > 0 && (
84
+ <div
85
+ className="flex flex-wrap gap-4"
86
+ style={{
87
+ display: expanded ? 'block' : 'none',
88
+ marginTop: 8,
89
+ }}
90
+ >
91
+ {(item?.tags || []).map((tag: string) => (
92
+ <Button
93
+ key={tag}
94
+ iconPosition="end"
95
+ type="text"
96
+ style={{
97
+ backgroundColor: '#F0F0F0',
98
+ padding: '2px 6px',
99
+ height: 22,
100
+ borderRadius: 2,
101
+ color: '#1D2129',
102
+ }}
103
+ icon={
104
+ <X
105
+ size={14}
106
+ color="#86909C"
107
+ onClick={() => {
108
+ const newItem = {
109
+ ...item,
110
+ tags: item.tags.filter((t: any) => t !== tag),
111
+ };
112
+ eventsEmit(`removeTag`, newItem);
113
+ }}
114
+ />
115
+ }
116
+ >
117
+ {tag}
118
+ </Button>
119
+ ))}
120
+ </div>
121
+ )}
122
+ </div>
123
+ <Button
124
+ type="text"
125
+ icon={<CircleX size={14} />}
126
+ onClick={() => eventsEmit(`removeItem`, item)}
127
+ ></Button>
128
+ </div>
129
+ );
130
+ };
131
+
132
+ export default ResourceBinderItem;
@@ -0,0 +1,500 @@
1
+ import React, { useMemo, useState, useEffect, useImperativeHandle, forwardRef } from 'react';
2
+ import styled from 'styled-components';
3
+ import {
4
+ defaultTheme,
5
+ deepMergeTheme,
6
+ useTheme,
7
+ type AppTheme,
8
+ type Styles,
9
+ } from '@mxmweb/zui-theme';
10
+ import { Search, CircleX } from 'lucide-react';
11
+
12
+ export interface Item {
13
+ key: string | number;
14
+ label: string;
15
+ disabled?: boolean;
16
+ tags?: string[];
17
+ [key: string]: any; // 允许其他自定义属性
18
+ }
19
+
20
+ export interface SearchableSelectorProps {
21
+ /** 可选数据源 */
22
+ dataSource: Item[];
23
+ /** 外部已选择的值(这些项在左侧不可选) */
24
+ value?: Item[];
25
+ /** 确认回调,点击确定时调用 */
26
+ onConfirm?: (selectedItems: Item[]) => void;
27
+ /** 最大选择数量,0表示不限制 */
28
+ maxCount?: number;
29
+ /** 搜索框占位符 */
30
+ searchPlaceholder?: string;
31
+ /** 标题 */
32
+ title?: string;
33
+
34
+ /** 是否显示搜索框 */
35
+ showSearch?: boolean;
36
+ /** 自定义搜索过滤函数 */
37
+ filterOption?: (inputValue: string, item: Item) => boolean;
38
+ /** 自定义渲染项 */
39
+ renderItem?: (item: Item) => React.ReactNode;
40
+ /** 自定义渲染已选项 */
41
+
42
+ renderSelectedItem?: (
43
+ item: Item,
44
+ updateItemData: (data: Record<string, any>) => void
45
+ ) => React.ReactNode;
46
+ className?: string;
47
+ style?: React.CSSProperties;
48
+ styles?: Styles;
49
+ /** 高度 */
50
+ height?: string;
51
+ /** 宽度 */
52
+ width?: string;
53
+ }
54
+
55
+ export interface SearchableSelectorRef {
56
+ getSelectedItems: () => Item[];
57
+ confirm: () => void;
58
+ }
59
+
60
+ const Container = styled.div<{ $theme: AppTheme; $width?: string; $height?: string }>`
61
+ display: flex;
62
+ background-color: #ffffff;
63
+ border: 1px solid ${p => p.$theme?.colors?.border?.default || '#e5e7eb'};
64
+ border-radius: ${p => p.$theme?.space?.radius || '8px'};
65
+ overflow: hidden;
66
+ width: ${p => p.$width || '600px'};
67
+ height: ${p => p.$height || '400px'};
68
+ position: relative;
69
+ `;
70
+
71
+ const Pane = styled.div<{ $theme: AppTheme }>`
72
+ display: flex;
73
+ flex-direction: column;
74
+ border-right: 1px solid ${p => p.$theme?.colors?.border?.default || '#e5e7eb'};
75
+ overflow: hidden;
76
+
77
+ &:last-child {
78
+ border-right: none;
79
+ }
80
+ `;
81
+
82
+ const PaneHeader = styled.div<{ $theme: AppTheme }>`
83
+ padding: 12px 16px;
84
+ font-weight: 400;
85
+ font-size: 14px;
86
+ display: flex;
87
+ align-items: center;
88
+ justify-content: space-between;
89
+ color: ${p => p.$theme?.colors?.text?.primary || '#4E5969'};
90
+ `;
91
+
92
+ const PaneHeaderClear = styled.div<{ $theme: AppTheme }>`
93
+ font-weight: 400;
94
+ font-size: 14px;
95
+ color: ${p => p.$theme?.colors?.text?.primary || '#4E6EF2'};
96
+ `;
97
+
98
+ const SearchWrapper = styled.div<{ $theme: AppTheme }>`
99
+ padding: 12px;
100
+ background-color: ${p => p.$theme?.colors?.background?.default || '#ffffff'};
101
+ `;
102
+
103
+ const SearchInput = styled.input<{ $theme: AppTheme }>`
104
+ width: 100%;
105
+ padding: 8px 12px 8px 36px;
106
+ border: 1px solid ${p => p.$theme?.colors?.border?.default || '#e5e7eb'};
107
+ border-radius: ${p => p.$theme?.space?.radius || '6px'};
108
+ font-size: 14px;
109
+ outline: none;
110
+ transition: all 0.2s;
111
+
112
+ &:focus {
113
+ border-color: ${p => p.$theme?.colors?.primary?.default || '#3b82f6'};
114
+ box-shadow: 0 0 0 3px ${p => p.$theme?.colors?.primary?.default || '#3b82f6'}20;
115
+ }
116
+
117
+ &::placeholder {
118
+ color: ${p => p.$theme?.colors?.text?.tertiary || '#9ca3af'};
119
+ }
120
+ `;
121
+
122
+ const SearchIcon = styled.div`
123
+ position: absolute;
124
+ left: 20px;
125
+ top: 50%;
126
+ transform: translateY(-50%);
127
+ color: #9ca3af;
128
+ pointer-events: none;
129
+ `;
130
+
131
+ const ListContainer = styled.div`
132
+ flex: 1;
133
+ overflow-y: auto;
134
+ overflow-x: hidden;
135
+
136
+ &::-webkit-scrollbar {
137
+ width: 6px;
138
+ }
139
+
140
+ &::-webkit-scrollbar-track {
141
+ background: #f1f1f1;
142
+ }
143
+
144
+ &::-webkit-scrollbar-thumb {
145
+ background: #c1c1c1;
146
+ border-radius: 3px;
147
+
148
+ &:hover {
149
+ background: #a8a8a8;
150
+ }
151
+ }
152
+ `;
153
+
154
+ const ItemWrapper = styled.div<{ $theme: AppTheme; $disabled?: boolean; $selected?: boolean }>`
155
+ padding: 10px 16px;
156
+ cursor: ${p => (p.$disabled ? 'not-allowed' : 'pointer')};
157
+ transition: all 0.2s;
158
+ display: flex;
159
+ align-items: center;
160
+ justify-content: space-between;
161
+ opacity: ${p => (p.$disabled ? 0.5 : 1)};
162
+
163
+ &:hover {
164
+ background-color: ${p =>
165
+ p.$disabled ? 'transparent' : p.$theme?.colors?.background?.hover || '#f3f4f6'};
166
+ }
167
+
168
+ &:last-child {
169
+ border-bottom: none;
170
+ }
171
+ `;
172
+
173
+ const ItemLabel = styled.span<{ $theme: AppTheme }>`
174
+ flex: 1;
175
+ font-size: 14px;
176
+ color: ${p => p.$theme?.colors?.text?.primary || '#111827'};
177
+ overflow: hidden;
178
+ text-overflow: ellipsis;
179
+ white-space: nowrap;
180
+ `;
181
+
182
+ const ActionButton = styled.button<{ $theme: AppTheme }>`
183
+ display: flex;
184
+ align-items: center;
185
+ justify-content: center;
186
+ width: 68px;
187
+ border: none;
188
+ background-color: #ebecf3;
189
+ border-radius: 4px;
190
+ cursor: pointer;
191
+ font-size: 12px;
192
+ color: ${p => p.$theme?.colors?.text?.secondary || '#1D2129'};
193
+ transition: all 0.2s;
194
+
195
+ &:disabled {
196
+ cursor: not-allowed;
197
+ color: ${p => p.$theme?.colors?.text?.secondary || '#C9CDD4'};
198
+ }
199
+ `;
200
+
201
+ const EmptyState = styled.div<{ $theme: AppTheme }>`
202
+ padding: 40px 20px;
203
+ text-align: center;
204
+ color: ${p => p.$theme?.colors?.text?.tertiary || '#9ca3af'};
205
+ font-size: 14px;
206
+ `;
207
+
208
+ const CountBadge = styled.span<{ $theme: AppTheme }>`
209
+ display: inline-flex;
210
+ align-items: center;
211
+ justify-content: center;
212
+ min-width: 20px;
213
+ height: 20px;
214
+ padding: 0 6px;
215
+ background-color: ${p => p.$theme?.colors?.primary?.default || '#3b82f6'};
216
+ color: white;
217
+ border-radius: 10px;
218
+ font-size: 12px;
219
+ font-weight: 500;
220
+ margin-left: 8px;
221
+ `;
222
+
223
+ const SearchableSelector = forwardRef<SearchableSelectorRef, SearchableSelectorProps>(
224
+ (
225
+ {
226
+ dataSource,
227
+ value = [],
228
+ onConfirm,
229
+ maxCount = 0,
230
+ searchPlaceholder = '搜索...',
231
+ title = '',
232
+ showSearch = true,
233
+ filterOption,
234
+ renderItem,
235
+ renderSelectedItem,
236
+ className,
237
+ style,
238
+ styles,
239
+ height,
240
+ width,
241
+ },
242
+ ref
243
+ ) => {
244
+ // 1. 获取全局主题
245
+ const globalTheme = useTheme();
246
+
247
+ // 2. 优先级合并:用户styles > useTheme > 默认主题
248
+ const theme = deepMergeTheme(
249
+ deepMergeTheme({ theme: defaultTheme, mode: 'light' }, globalTheme),
250
+ styles
251
+ );
252
+
253
+ // 内部状态管理 - 使用 Item[] 数组,初始值为外部传入的 value
254
+ const [internalSelectedItems, setInternalSelectedItems] = useState<Item[]>(value);
255
+ const [searchValue, setSearchValue] = useState<string>('');
256
+
257
+ // 当外部 value 变化时,同步到内部状态(但只在初始化时,后续由内部管理)
258
+ useEffect(() => {
259
+ setInternalSelectedItems(value);
260
+ }, [value]);
261
+
262
+ // 获取外部已选择项的 key 集合(这些项在左侧不可选)
263
+ const externalSelectedKeys = useMemo(() => {
264
+ return new Set(value.map(item => item.key));
265
+ }, [value]);
266
+
267
+ // 获取已选择项的 key 集合,用于快速查找
268
+ const selectedKeys = useMemo(() => {
269
+ return new Set(internalSelectedItems.map(item => item.key));
270
+ }, [internalSelectedItems]);
271
+
272
+ // 暴露方法给外部调用
273
+ useImperativeHandle(
274
+ ref,
275
+ () => ({
276
+ getSelectedItems: () => internalSelectedItems,
277
+ confirm: () => {
278
+ onConfirm?.(internalSelectedItems);
279
+ },
280
+ }),
281
+ [internalSelectedItems, onConfirm]
282
+ );
283
+
284
+ // 默认搜索过滤函数
285
+ const defaultFilterOption = (inputValue: string, item: Item): boolean => {
286
+ if (!inputValue) return true;
287
+ const searchLower = inputValue.toLowerCase();
288
+ return (
289
+ item.label.toLowerCase().includes(searchLower) ||
290
+ item.tags?.some(tag => tag.toLowerCase().includes(searchLower)) ||
291
+ false
292
+ );
293
+ };
294
+
295
+ const filterFn = filterOption || defaultFilterOption;
296
+
297
+ // 过滤后的可选列表
298
+ const filteredDataSource = useMemo(() => {
299
+ return dataSource.filter(item => filterFn(searchValue, item));
300
+ }, [dataSource, searchValue, filterFn]);
301
+
302
+ // 处理选择
303
+ const handleSelect = (item: Item) => {
304
+ if (item.disabled) return;
305
+ // 如果该项是外部传入的(已在 value 中),则不可选
306
+ if (externalSelectedKeys.has(item.key)) {
307
+ return;
308
+ }
309
+
310
+ const isSelected = selectedKeys.has(item.key);
311
+ let newSelectedItems: Item[];
312
+
313
+ if (isSelected) {
314
+ // 已选中,取消选择(只从内部选中项中移除)
315
+ newSelectedItems = internalSelectedItems.filter(
316
+ selectedItem => selectedItem.key !== item.key
317
+ );
318
+ } else {
319
+ // 未选中,检查是否达到最大限制
320
+ if (maxCount > 0 && internalSelectedItems.length >= maxCount) {
321
+ return; // 达到最大限制,不添加
322
+ }
323
+ newSelectedItems = [...internalSelectedItems, item];
324
+ }
325
+
326
+ setInternalSelectedItems(newSelectedItems);
327
+ };
328
+
329
+ // 更新已选项数据的函数
330
+ const updateItemData = (key: string | number, data: Record<string, any>) => {
331
+ setInternalSelectedItems((pre: any) => {
332
+ const newSelectedItems = pre.map(selectedItem => {
333
+ if (selectedItem.key == key) {
334
+ return {
335
+ ...selectedItem,
336
+ tags: data,
337
+ };
338
+ } else {
339
+ return selectedItem;
340
+ }
341
+ });
342
+ return newSelectedItems;
343
+ });
344
+ };
345
+ // 处理移除
346
+ const handleRemove = (item: Item) => {
347
+ // 只从内部选中项中移除
348
+ const newSelectedItems = internalSelectedItems.filter(
349
+ selectedItem => selectedItem.key !== item.key
350
+ );
351
+
352
+ setInternalSelectedItems(newSelectedItems);
353
+ };
354
+
355
+ // 判断是否已选中
356
+ const isSelected = (key: string | number) => {
357
+ return selectedKeys.has(key);
358
+ };
359
+
360
+ // 判断是否达到最大限制
361
+ const isMaxReached = maxCount > 0 && internalSelectedItems.length >= maxCount;
362
+
363
+ return (
364
+ <Container
365
+ $theme={theme.theme || defaultTheme}
366
+ $width={width}
367
+ $height={height}
368
+ className={className}
369
+ style={style}
370
+ >
371
+ {/* 左侧:可选列表 */}
372
+ <Pane $theme={theme.theme || defaultTheme} style={{ flex: 1 }}>
373
+ {showSearch && (
374
+ <SearchWrapper $theme={theme.theme || defaultTheme}>
375
+ <div style={{ position: 'relative' }}>
376
+ <SearchIcon>
377
+ <Search size={16} />
378
+ </SearchIcon>
379
+ <SearchInput
380
+ $theme={theme.theme || defaultTheme}
381
+ type="text"
382
+ placeholder={searchPlaceholder}
383
+ value={searchValue}
384
+ onChange={e => setSearchValue(e.target.value)}
385
+ />
386
+ </div>
387
+ </SearchWrapper>
388
+ )}
389
+
390
+ <ListContainer>
391
+ {filteredDataSource.length === 0 ? (
392
+ <EmptyState $theme={theme.theme || defaultTheme}>
393
+ {searchValue ? '未找到匹配项' : '暂无数据'}
394
+ </EmptyState>
395
+ ) : (
396
+ filteredDataSource.map(item => {
397
+ const selected = isSelected(item.key);
398
+ // 外部传入的项不可选,或者达到最大限制且未选中
399
+ const isExternalSelected = externalSelectedKeys.has(item.key);
400
+ const disabled = item.disabled || isExternalSelected || (isMaxReached && !selected);
401
+
402
+ return (
403
+ <ItemWrapper
404
+ key={item.key}
405
+ $theme={theme.theme || defaultTheme}
406
+ $disabled={disabled}
407
+ $selected={selected}
408
+ onClick={() => handleSelect(item)}
409
+ >
410
+ <ItemLabel $theme={theme.theme || defaultTheme}>
411
+ {renderItem ? renderItem(item) : item.label}
412
+ </ItemLabel>
413
+ {selected && (
414
+ <ActionButton
415
+ $theme={theme.theme || defaultTheme}
416
+ onClick={e => {
417
+ e.stopPropagation();
418
+ handleRemove(item);
419
+ }}
420
+ disabled
421
+ >
422
+ 已添加
423
+ </ActionButton>
424
+ )}
425
+ {!selected && (
426
+ <ActionButton
427
+ $theme={theme.theme || defaultTheme}
428
+ disabled={disabled}
429
+ onClick={e => {
430
+ e.stopPropagation();
431
+ handleSelect(item);
432
+ }}
433
+ >
434
+ 添加
435
+ </ActionButton>
436
+ )}
437
+ </ItemWrapper>
438
+ );
439
+ })
440
+ )}
441
+ </ListContainer>
442
+ </Pane>
443
+
444
+ {/* 右侧:已选列表 */}
445
+ <Pane $theme={theme.theme || defaultTheme} style={{ flex: 1 }}>
446
+ <PaneHeader $theme={theme.theme || defaultTheme}>
447
+ {maxCount > 0
448
+ ? `已选:${internalSelectedItems.length}/${maxCount}个${title}`
449
+ : `已选:${internalSelectedItems.length}个${title}`}
450
+
451
+ <PaneHeaderClear
452
+ $theme={theme.theme || defaultTheme}
453
+ onClick={e => {
454
+ e.stopPropagation();
455
+ setInternalSelectedItems([]);
456
+ }}
457
+ >
458
+ 清空
459
+ </PaneHeaderClear>
460
+ </PaneHeader>
461
+
462
+ <ListContainer>
463
+ {internalSelectedItems.length === 0 ? (
464
+ <EmptyState $theme={theme.theme || defaultTheme}>暂无已选项</EmptyState>
465
+ ) : (
466
+ internalSelectedItems.map(item => {
467
+ const updateData = (data: Record<string, any>) => updateItemData(item.key, data);
468
+
469
+ return (
470
+ <ItemWrapper key={item.key} $theme={theme.theme || defaultTheme}>
471
+ <ItemLabel $theme={theme.theme || defaultTheme}>
472
+ {renderSelectedItem ? renderSelectedItem(item, updateData) : item.label}
473
+ </ItemLabel>
474
+
475
+ <CircleX
476
+ size={14}
477
+ color={theme.theme?.colors?.text?.secondary || '#86909C'}
478
+ style={{
479
+ cursor: 'pointer',
480
+ // marginLeft: '8px',
481
+ }}
482
+ onClick={e => {
483
+ e.stopPropagation();
484
+ handleRemove(item);
485
+ }}
486
+ />
487
+ </ItemWrapper>
488
+ );
489
+ })
490
+ )}
491
+ </ListContainer>
492
+ </Pane>
493
+ </Container>
494
+ );
495
+ }
496
+ );
497
+
498
+ SearchableSelector.displayName = 'SearchableSelector';
499
+
500
+ export default SearchableSelector;