@gientech/modual 2.0.7 → 2.0.9

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 (415) hide show
  1. package/.editorconfig +38 -0
  2. package/.prettierignore +16 -0
  3. package/.prettierrc +17 -0
  4. package/INSTALL_TROUBLESHOOTING.md +316 -0
  5. package/USAGE.md +247 -0
  6. package/bash.exe.stackdump +40 -0
  7. package/components.json +21 -0
  8. package/dist/README.md +761 -0
  9. package/{assets/GientechStreamReader-Dx72IaEx.js → dist/assets/GientechStreamReader-CNj6Rcm7.js} +1 -1
  10. package/{assets/index-D4pXe94o.js → dist/assets/index-BJv0t0eJ.js} +36 -36
  11. package/{assets/index-BbNz3Zrz.js → dist/assets/index-CU45mVZ4.js} +1 -1
  12. package/{chat.js → dist/chat.js} +1 -1
  13. package/{databaseId.js → dist/databaseId.js} +1 -1
  14. package/{index.js → dist/index.js} +1 -1
  15. package/dist/package.json +68 -0
  16. package/{streamFilesReader.js → dist/streamFilesReader.js} +1 -1
  17. package/doc_assets/2.png +0 -0
  18. package/doc_assets/demo.md +27 -0
  19. package/doc_assets/demos/dist-app/assets/index.Dh-ZAS9Z.css +2 -0
  20. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js +23699 -0
  21. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js.map +1 -0
  22. package/doc_assets/demos/dist-app/index.html +14 -0
  23. package/doc_assets/demos/dist-app/vite.svg +1 -0
  24. package/doc_assets/images/1.png +0 -0
  25. package/doc_assets/images/3.png +0 -0
  26. package/doc_assets/images/component-screenshot.png +1 -0
  27. package/doc_assets/install.md +5 -0
  28. package/doc_assets/v2.0.7/345/217/230/346/233/264/346/200/273/347/273/223.md +115 -0
  29. 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
  30. package/eslint.config.js +92 -0
  31. package/index.html +13 -0
  32. package/package.json +103 -41
  33. package/package.json.demo-backup +109 -0
  34. package/postcss.config.cjs +19 -0
  35. package/public/icons/answerAwartar.png +0 -0
  36. package/public/icons/docx-file.png +0 -0
  37. package/public/icons/folder.png +0 -0
  38. package/public/icons/html.png +0 -0
  39. package/public/icons/image.png +0 -0
  40. package/public/icons/jpg-file.png +0 -0
  41. package/public/icons/json.png +0 -0
  42. package/public/icons/md.png +0 -0
  43. package/public/icons/pdf.png +0 -0
  44. package/public/icons/pptx.png +0 -0
  45. package/public/icons/questionAwartar.png +0 -0
  46. package/public/icons/sheets.png +0 -0
  47. package/public/icons/txt.png +0 -0
  48. package/public/icons/xlsx.png +0 -0
  49. package/public/vite.svg +1 -0
  50. package/public/worker/pdf.worker.min.js +22 -0
  51. package/scripts/README.md +133 -0
  52. package/scripts/build-demo.js +88 -0
  53. package/scripts/decrypt-api-key.js +95 -0
  54. package/scripts/demo-selector.js +216 -0
  55. package/scripts/dev-demo.js +76 -0
  56. package/scripts/preview-demo.js +130 -0
  57. package/scripts/run-demo.bat +34 -0
  58. package/src/assets/img/close.png +0 -0
  59. package/src/assets/img/database.png +0 -0
  60. package/src/assets/img/downArrow.png +0 -0
  61. package/src/assets/img/downLoad.png +0 -0
  62. package/src/assets/img/excel.png +0 -0
  63. package/src/assets/img/graphIcon.png +0 -0
  64. package/src/assets/img/img.png +0 -0
  65. package/src/assets/img/pdf.png +0 -0
  66. package/src/assets/img/ppt.png +0 -0
  67. package/src/assets/img/singleQa.png +0 -0
  68. package/src/assets/img/txt.png +0 -0
  69. package/src/assets/img/webSearch.png +0 -0
  70. package/src/assets/img/word.png +0 -0
  71. package/src/assets/login/homeBg.png +0 -0
  72. package/src/assets/login/left.jpg +0 -0
  73. package/src/assets/login/logoImg.png +0 -0
  74. package/src/examples/ConversationAssistantPage/index.tsx +41 -0
  75. package/src/examples/Demo/index.tsx +12 -0
  76. package/src/examples/LoginPage/index.tsx +18 -0
  77. package/src/examples/chat/components/DrawerGraphPreview.tsx +78 -0
  78. package/src/examples/chat/index.tsx +166 -0
  79. package/src/examples/chat/logo03.png +0 -0
  80. package/src/examples/gientechStreamFilesReader/index.tsx +951 -0
  81. package/src/examples/headlessChat/assets/mind.svg +6 -0
  82. package/src/examples/headlessChat/assets/net.svg +7 -0
  83. package/src/examples/headlessChat/index.tsx +285 -0
  84. package/src/examples/ragDatabaseDataPage/index.tsx +40 -0
  85. package/src/examples/ragDatabaseIdPage/index.tsx +47 -0
  86. package/src/examples/ragDatabasePage/index.tsx +36 -0
  87. package/src/examples/ragModelManagePage/index.tsx +38 -0
  88. package/src/examples/ragSearchPage/index.tsx +0 -0
  89. package/src/examples/ragSensitiveWordsPage/index.tsx +32 -0
  90. package/src/examples/streamFiles/index.tsx +417 -0
  91. package/src/lib_enter.ts +43 -0
  92. package/src/main.tsx +5 -0
  93. package/src/main.tsx.backup +5 -0
  94. package/src/modules/CHAT_UNIFICATION_PLAN.md +324 -0
  95. package/src/modules/assistantConfig/assets/databse.svg +6 -0
  96. package/src/modules/assistantConfig/assets/empty.png +0 -0
  97. package/src/modules/assistantConfig/assets/graph.svg +4 -0
  98. package/src/modules/assistantConfig/assets/knowledge.svg +4 -0
  99. package/src/modules/assistantConfig/assets/sensitive.svg +5 -0
  100. package/src/modules/assistantConfig/components/Database.tsx +171 -0
  101. package/src/modules/assistantConfig/components/Graph.tsx +177 -0
  102. package/src/modules/assistantConfig/components/Knowledge.tsx +276 -0
  103. package/src/modules/assistantConfig/components/NotFoundContent.tsx +21 -0
  104. package/src/modules/assistantConfig/components/Paragraph.tsx +51 -0
  105. package/src/modules/assistantConfig/components/ParamsItem.tsx +39 -0
  106. package/src/modules/assistantConfig/components/ResourceBinderItem.tsx +133 -0
  107. package/src/modules/assistantConfig/components/SearchableSelector.tsx +500 -0
  108. package/src/modules/assistantConfig/components/Sensitive.tsx +221 -0
  109. package/src/modules/assistantConfig/components/SliderInput.tsx +65 -0
  110. package/src/modules/assistantConfig/constants.tsx +75 -0
  111. package/src/modules/assistantConfig/index.tsx +710 -0
  112. package/src/modules/assistantConfig/server.ts +262 -0
  113. package/src/modules/chat/Conversations/Item.tsx +167 -0
  114. package/src/modules/chat/Conversations/List.tsx +210 -0
  115. package/src/modules/chat/Conversations/groupByTime.ts +39 -0
  116. package/src/modules/chat/Conversations/index.tsx +252 -0
  117. package/src/modules/chat/ReferenceBar.tsx +622 -0
  118. package/src/modules/chat/constants.tsx +57 -0
  119. package/src/modules/chat/index.tsx +2449 -0
  120. package/src/modules/chat/referenceCom/DeleteModal.tsx +75 -0
  121. package/src/modules/chat/referenceCom/DrawerContent.tsx +136 -0
  122. package/src/modules/chat/referenceCom/DrawerDatabase.tsx +102 -0
  123. package/src/modules/chat/referenceCom/DrawerGraphPreview.tsx +86 -0
  124. package/src/modules/chat/referenceCom/DrawerPreview.tsx +73 -0
  125. package/src/modules/chat/referenceCom/DrawerTitle.tsx +26 -0
  126. package/src/modules/chat/referenceCom/RenameModal.tsx +86 -0
  127. package/src/modules/chat/referenceCom/TagCom.tsx +30 -0
  128. package/src/modules/chat/style.less +3 -0
  129. package/src/modules/chat/types.ts +17 -0
  130. package/src/modules/chat/utils/index.ts +348 -0
  131. package/src/modules/database/CreateModal.tsx +403 -0
  132. package/src/modules/database/assets/Doris.png +0 -0
  133. package/src/modules/database/assets/PostgreSQL.png +0 -0
  134. package/src/modules/database/assets/SQLServer.png +0 -0
  135. package/src/modules/database/assets/database.svg +11 -0
  136. package/src/modules/database/assets/database_add.svg +53 -0
  137. package/src/modules/database/assets/database_connect.svg +66 -0
  138. package/src/modules/database/assets/database_upload.svg +29 -0
  139. package/src/modules/database/assets/empty.png +0 -0
  140. package/src/modules/database/assets/mysql.svg +14 -0
  141. package/src/modules/database/index.tsx +477 -0
  142. package/src/modules/database/server.ts +196 -0
  143. package/src/modules/databaseId/CustomCom.tsx +156 -0
  144. package/src/modules/databaseId/EditConfig.tsx +280 -0
  145. package/src/modules/databaseId/UploadDrawer.tsx +535 -0
  146. package/src/modules/databaseId/assets/aiOptimize.svg +10 -0
  147. package/src/modules/databaseId/assets/empty.png +0 -0
  148. package/src/modules/databaseId/assets/template.svg +6 -0
  149. package/src/modules/databaseId/assets/upload.svg +9 -0
  150. package/src/modules/databaseId/assets/useTemp.svg +6 -0
  151. package/src/modules/databaseId/index.tsx +769 -0
  152. package/src/modules/databaseId/server.ts +286 -0
  153. package/src/modules/databaseId/style.css +5 -0
  154. package/src/modules/databaseTable/EditRowDrawer.tsx +124 -0
  155. package/src/modules/databaseTable/index.tsx +359 -0
  156. package/src/modules/databaseTable/server.ts +180 -0
  157. package/src/modules/headlessChat/ReferenceBar.tsx +783 -0
  158. package/src/modules/headlessChat/constants.tsx +54 -0
  159. package/src/modules/headlessChat/index.tsx +1782 -0
  160. package/src/modules/headlessChat/referenceCom/DeleteModal.tsx +75 -0
  161. package/src/modules/headlessChat/referenceCom/DrawerContent.tsx +136 -0
  162. package/src/modules/headlessChat/referenceCom/DrawerDatabase.tsx +102 -0
  163. package/src/modules/headlessChat/referenceCom/DrawerGraphPreview.tsx +86 -0
  164. package/src/modules/headlessChat/referenceCom/DrawerPreview.tsx +73 -0
  165. package/src/modules/headlessChat/referenceCom/DrawerTitle.tsx +26 -0
  166. package/src/modules/headlessChat/referenceCom/RenameModal.tsx +86 -0
  167. package/src/modules/headlessChat/referenceCom/TagCom.tsx +30 -0
  168. package/src/modules/headlessChat/style.less +3 -0
  169. package/src/modules/headlessChat/types.ts +23 -0
  170. package/src/modules/headlessChat/utils/index.ts +348 -0
  171. package/src/modules/login/components/Login/LoginBox/index.tsx +102 -0
  172. package/src/modules/login/components/Login/RegisterBox/index.tsx +180 -0
  173. package/src/modules/login/components/Login/index.tsx +100 -0
  174. package/src/modules/login/index.tsx +106 -0
  175. package/src/modules/login/style.css +3 -0
  176. package/src/modules/login/useServices.ts +53 -0
  177. package/src/modules/login/utils.ts +42 -0
  178. package/src/modules/modelManage/ConfigDrawer.tsx +249 -0
  179. package/src/modules/modelManage/ReplaceModal.tsx +124 -0
  180. package/src/modules/modelManage/assets/empty.png +0 -0
  181. package/src/modules/modelManage/const.ts +51 -0
  182. package/src/modules/modelManage/index.tsx +606 -0
  183. package/src/modules/modelManage/server.ts +223 -0
  184. package/src/modules/nodegraph/index.tsx +1 -0
  185. package/src/modules/search/assets/Icon-history.svg +8 -0
  186. package/src/modules/search/assets/answerAwartar.png +0 -0
  187. package/src/modules/search/assets/doc.png +0 -0
  188. package/src/modules/search/assets/genera.gif +0 -0
  189. package/src/modules/search/assets/icon-robot.svg +9 -0
  190. package/src/modules/search/assets/icon-search-bar.svg +14 -0
  191. package/src/modules/search/assets/icon-sub-title.svg +3 -0
  192. package/src/modules/search/assets/icon-title.svg +9 -0
  193. package/src/modules/search/assets/icon-zoomOut.svg +9 -0
  194. package/src/modules/search/assets/iconAi.svg +9 -0
  195. package/src/modules/search/assets/pdf.png +0 -0
  196. package/src/modules/search/assets/ppt.png +0 -0
  197. package/src/modules/search/assets/search.svg +3 -0
  198. package/src/modules/search/assets/selected.svg +4 -0
  199. package/src/modules/search/assets/txt.png +0 -0
  200. package/src/modules/search/assets/xls.png +0 -0
  201. package/src/modules/search/components/AssisSelect.tsx +137 -0
  202. package/src/modules/search/components/Editor/ChatViewEditor.tsx +261 -0
  203. package/src/modules/search/components/Editor/aichat.css +1 -0
  204. package/src/modules/search/components/Editor/constant.ts +13 -0
  205. package/src/modules/search/components/Editor/index.tsx +113 -0
  206. package/src/modules/search/components/Editor/plugins/autofomatRules.ts +332 -0
  207. package/src/modules/search/components/Editor/plugins/convertImgPlugins.tsx +20 -0
  208. package/src/modules/search/components/Editor/plugins/createIndexes.tsx +38 -0
  209. package/src/modules/search/components/Editor/plugins/displayer.ts +298 -0
  210. package/src/modules/search/components/Editor/plugins/imageClick.tsx +32 -0
  211. package/src/modules/search/components/Editor/plugins/myplugin.tsx +98 -0
  212. package/src/modules/search/components/Editor/ui/avatar.tsx +19 -0
  213. package/src/modules/search/components/Editor/ui/blockquote-element.tsx +21 -0
  214. package/src/modules/search/components/Editor/ui/button.tsx +58 -0
  215. package/src/modules/search/components/Editor/ui/calendar.tsx +68 -0
  216. package/src/modules/search/components/Editor/ui/caption.tsx +46 -0
  217. package/src/modules/search/components/Editor/ui/checkbox.tsx +27 -0
  218. package/src/modules/search/components/Editor/ui/code-block-combobox.tsx +188 -0
  219. package/src/modules/search/components/Editor/ui/code-block-element.css +434 -0
  220. package/src/modules/search/components/Editor/ui/code-block-element.tsx +39 -0
  221. package/src/modules/search/components/Editor/ui/code-leaf.tsx +24 -0
  222. package/src/modules/search/components/Editor/ui/code-line-element.tsx +10 -0
  223. package/src/modules/search/components/Editor/ui/code-syntax-leaf.tsx +21 -0
  224. package/src/modules/search/components/Editor/ui/column-element.tsx +30 -0
  225. package/src/modules/search/components/Editor/ui/column-group-element.tsx +94 -0
  226. package/src/modules/search/components/Editor/ui/command.tsx +75 -0
  227. package/src/modules/search/components/Editor/ui/comment-avatar.tsx +22 -0
  228. package/src/modules/search/components/Editor/ui/comment-create-form.tsx +37 -0
  229. package/src/modules/search/components/Editor/ui/comment-item.tsx +74 -0
  230. package/src/modules/search/components/Editor/ui/comment-leaf.tsx +49 -0
  231. package/src/modules/search/components/Editor/ui/comment-more-dropdown.tsx +42 -0
  232. package/src/modules/search/components/Editor/ui/comment-reply-items.tsx +22 -0
  233. package/src/modules/search/components/Editor/ui/comment-resolve-button.tsx +32 -0
  234. package/src/modules/search/components/Editor/ui/comment-value.tsx +34 -0
  235. package/src/modules/search/components/Editor/ui/comments-popover.tsx +63 -0
  236. package/src/modules/search/components/Editor/ui/date-element.tsx +83 -0
  237. package/src/modules/search/components/Editor/ui/dialog.tsx +63 -0
  238. package/src/modules/search/components/Editor/ui/draggable.tsx +177 -0
  239. package/src/modules/search/components/Editor/ui/dropdown-menu.tsx +180 -0
  240. package/src/modules/search/components/Editor/ui/emoji-input-element.tsx +85 -0
  241. package/src/modules/search/components/Editor/ui/excalidraw-element.tsx +28 -0
  242. package/src/modules/search/components/Editor/ui/fixed-toolbar-buttons.tsx +76 -0
  243. package/src/modules/search/components/Editor/ui/fixed-toolbar.tsx +8 -0
  244. package/src/modules/search/components/Editor/ui/floating-toolbar-buttons.tsx +51 -0
  245. package/src/modules/search/components/Editor/ui/floating-toolbar.tsx +77 -0
  246. package/src/modules/search/components/Editor/ui/heading-element.tsx +48 -0
  247. package/src/modules/search/components/Editor/ui/highlight-leaf.tsx +17 -0
  248. package/src/modules/search/components/Editor/ui/hr-element.tsx +30 -0
  249. package/src/modules/search/components/Editor/ui/icons.tsx +267 -0
  250. package/src/modules/search/components/Editor/ui/image-element.tsx +74 -0
  251. package/src/modules/search/components/Editor/ui/inline-combobox.tsx +368 -0
  252. package/src/modules/search/components/Editor/ui/input.tsx +25 -0
  253. package/src/modules/search/components/Editor/ui/insert-dropdown-menu.tsx +218 -0
  254. package/src/modules/search/components/Editor/ui/kbd-leaf.tsx +20 -0
  255. package/src/modules/search/components/Editor/ui/link-element.tsx +29 -0
  256. package/src/modules/search/components/Editor/ui/link-floating-toolbar.tsx +161 -0
  257. package/src/modules/search/components/Editor/ui/list-element.tsx +30 -0
  258. package/src/modules/search/components/Editor/ui/mark-toolbar-button.tsx +24 -0
  259. package/src/modules/search/components/Editor/ui/media-embed-element.tsx +133 -0
  260. package/src/modules/search/components/Editor/ui/media-popover.tsx +97 -0
  261. package/src/modules/search/components/Editor/ui/mention-element.tsx +43 -0
  262. package/src/modules/search/components/Editor/ui/mention-input-element.tsx +141 -0
  263. package/src/modules/search/components/Editor/ui/mode-dropdown-menu.tsx +93 -0
  264. package/src/modules/search/components/Editor/ui/more-dropdown-menu.tsx +67 -0
  265. package/src/modules/search/components/Editor/ui/paragraph-element.tsx +4 -0
  266. package/src/modules/search/components/Editor/ui/placeholder.tsx +52 -0
  267. package/src/modules/search/components/Editor/ui/popover.tsx +32 -0
  268. package/src/modules/search/components/Editor/ui/resizable.tsx +66 -0
  269. package/src/modules/search/components/Editor/ui/separator.tsx +25 -0
  270. package/src/modules/search/components/Editor/ui/style.less +12 -0
  271. package/src/modules/search/components/Editor/ui/table-cell-element.tsx +143 -0
  272. package/src/modules/search/components/Editor/ui/table-element.tsx +243 -0
  273. package/src/modules/search/components/Editor/ui/table-row-element.tsx +22 -0
  274. package/src/modules/search/components/Editor/ui/tableValue.tsx +135 -0
  275. package/src/modules/search/components/Editor/ui/todo-list-element.tsx +43 -0
  276. package/src/modules/search/components/Editor/ui/toggle-element.tsx +31 -0
  277. package/src/modules/search/components/Editor/ui/toolbar.tsx +157 -0
  278. package/src/modules/search/components/Editor/ui/tooltip.tsx +65 -0
  279. package/src/modules/search/components/Editor/ui/turn-into-dropdown-menu.tsx +160 -0
  280. package/src/modules/search/components/Editor/ui/with-draggables.tsx +175 -0
  281. package/src/modules/search/components/FileList.tsx +287 -0
  282. package/src/modules/search/components/ImageGroupView/index.tsx +85 -0
  283. package/src/modules/search/components/ResultContent.tsx +232 -0
  284. package/src/modules/search/components/SearchInput.tsx +232 -0
  285. package/src/modules/search/components/SearchLanding.tsx +74 -0
  286. package/src/modules/search/components/SearchView.tsx +563 -0
  287. package/src/modules/search/components/SimpleEditor.tsx +158 -0
  288. package/src/modules/search/components/SimpleFileList.tsx +215 -0
  289. package/src/modules/search/index.tsx +10 -0
  290. package/src/modules/search/reademe.md +1 -0
  291. package/src/modules/search/servers/apis.tsx +19 -0
  292. package/src/modules/search/servers/index.ts +184 -0
  293. package/src/modules/search/style.less +503 -0
  294. package/src/modules/search/type.ts +22 -0
  295. package/src/modules/search/utils.ts +34 -0
  296. package/src/modules/sensitive/index.tsx +313 -0
  297. package/src/modules/sensitive/server.ts +122 -0
  298. package/src/modules/streamFilesReader/GientechStreamReader.tsx +1625 -0
  299. package/src/modules/streamFilesReader/components/Header/Toolbar.tsx +0 -0
  300. package/src/modules/streamFilesReader/components/Header/index.tsx +297 -0
  301. package/src/modules/streamFilesReader/index.tsx +3 -0
  302. package/src/style.css +6 -0
  303. package/src/type.d.ts +0 -0
  304. package/src/utils/commonFn.tsx +111 -0
  305. package/src/utils/decryptApiKey.ts +40 -0
  306. package/src/utils/gientechCommon/components/AppError.tsx +32 -0
  307. package/src/utils/gientechCommon/components/AppLoading.tsx +75 -0
  308. package/src/utils/gientechCommon/components/DeleteModal.tsx +75 -0
  309. package/src/utils/gientechCommon/components/DisplayError.tsx +33 -0
  310. package/src/utils/gientechCommon/components/DisplayLoading.tsx +38 -0
  311. package/src/utils/gientechCommon/components/FeedBackModal.tsx +319 -0
  312. package/src/utils/gientechCommon/components/FileCardCommon.tsx +82 -0
  313. package/src/utils/gientechCommon/components/FileManager/index.tsx +418 -0
  314. package/src/utils/gientechCommon/components/FileManager/style.css +5 -0
  315. package/src/utils/gientechCommon/components/Messages/GientechNewChatWelcome.tsx +581 -0
  316. package/src/utils/gientechCommon/components/Messages/ReferenceCard.tsx +359 -0
  317. package/src/utils/gientechCommon/components/Messages/RetriveItem.tsx +245 -0
  318. package/src/utils/gientechCommon/components/Messages/WebRetriveItem.tsx +209 -0
  319. package/src/utils/gientechCommon/components/Messages/defaultBot.png +0 -0
  320. package/src/utils/gientechCommon/components/Messages/defaultStyleSet.tsx +148 -0
  321. package/src/utils/gientechCommon/components/Messages/defaultWeLogo.svg +14 -0
  322. package/src/utils/gientechCommon/components/RenameModal.tsx +86 -0
  323. package/src/utils/gientechCommon/components/style.less +11 -0
  324. package/src/utils/gientechCommon/configs/commonConfig.ts +2 -0
  325. package/src/utils/gientechCommon/configs/senderConfig.ts +0 -0
  326. package/src/utils/gientechCommon/configs/stylesConfig.ts +142 -0
  327. package/src/utils/gientechCommon/hooks/AichatUseController.tsx +417 -0
  328. package/src/utils/gientechCommon/hooks/useFileDisplayTools.tsx +251 -0
  329. package/src/utils/gientechCommon/hooks/useFileManager.ts +208 -0
  330. package/src/utils/gientechCommon/slate/converters/deserializers.ts +763 -0
  331. package/src/utils/gientechCommon/slate/converters/mockData.ts +232 -0
  332. package/src/utils/gientechCommon/slate/converters/slateConverters.ts +258 -0
  333. package/src/utils/gientechCommon/slate/richElements/index.tsx +499 -0
  334. package/src/utils/gientechCommon/utils/fileUtils.ts +86 -0
  335. package/src/utils/gientechCommon/utils/request.ts +37 -0
  336. package/src/utils/gientechCommon/utils/serverFn.ts +172 -0
  337. package/src/utils/index.tsx +142 -0
  338. package/src/utils/testconfigs/demologin/index.tsx +32 -0
  339. package/src/utils/testconfigs/index.ts +59 -0
  340. package/src/vite-env.d.ts +42 -0
  341. package/stats.html +4949 -0
  342. package/tailwind.config.js +170 -0
  343. package/tsconfig.app.json +30 -0
  344. package/tsconfig.app.tsbuildinfo +11 -0
  345. package/tsconfig.json +13 -0
  346. package/tsconfig.node.json +22 -0
  347. package/tsconfig.node.tsbuildinfo +1 -0
  348. package/vite.config.app.ts +93 -0
  349. package/vite.config.ts +232 -0
  350. package/workflows/release.yml +60 -0
  351. package//346/215/242/350/241/214/346/240/274/345/274/217/344/277/235/346/214/201/344/274/230/345/214/226/346/226/271/346/241/210.md +359 -0
  352. /package/{assets → dist/assets}/Doris.png +0 -0
  353. /package/{assets → dist/assets}/PostgreSQL.png +0 -0
  354. /package/{assets → dist/assets}/SQLServer.png +0 -0
  355. /package/{assets → dist/assets}/database.svg +0 -0
  356. /package/{assets → dist/assets}/database_add.svg +0 -0
  357. /package/{assets → dist/assets}/database_connect.svg +0 -0
  358. /package/{assets → dist/assets}/database_upload.svg +0 -0
  359. /package/{assets → dist/assets}/databse.svg +0 -0
  360. /package/{assets → dist/assets}/defaultWeLogo.svg +0 -0
  361. /package/{assets → dist/assets}/empty.png +0 -0
  362. /package/{assets → dist/assets}/graph.svg +0 -0
  363. /package/{assets → dist/assets}/homeBg.png +0 -0
  364. /package/{assets → dist/assets}/index-B2yNvzjy.js +0 -0
  365. /package/{assets → dist/assets}/index-BKe5FgcC.js +0 -0
  366. /package/{assets → dist/assets}/index-CpW6Dhpp.js +0 -0
  367. /package/{assets → dist/assets}/index-D72cKELw.js +0 -0
  368. /package/{assets → dist/assets}/index-DdVFXD_y.js +0 -0
  369. /package/{assets → dist/assets}/index-DrkSoKz6.js +0 -0
  370. /package/{assets → dist/assets}/index-ZopkeZtI.js +0 -0
  371. /package/{assets → dist/assets}/index-g-SUxfJH.js +0 -0
  372. /package/{assets → dist/assets}/index-j0kQJd0a.js +0 -0
  373. /package/{assets → dist/assets}/knowledge.svg +0 -0
  374. /package/{assets → dist/assets}/left.jpg +0 -0
  375. /package/{assets → dist/assets}/logoImg.png +0 -0
  376. /package/{assets → dist/assets}/mysql.svg +0 -0
  377. /package/{assets → dist/assets}/plus-V9zUoSq6.js +0 -0
  378. /package/{assets → dist/assets}/sensitive.svg +0 -0
  379. /package/{assets → dist/assets}/style-CGmZ5osp.js +0 -0
  380. /package/{assets → dist/assets}/style.css +0 -0
  381. /package/{assets → dist/assets}/style2.css +0 -0
  382. /package/{assets → dist/assets}/style3.css +0 -0
  383. /package/{assets → dist/assets}/style4.css +0 -0
  384. /package/{assets → dist/assets}/worker-BbpylX7l.js +0 -0
  385. /package/{assets → dist/assets}/x-CnaaLGJF.js +0 -0
  386. /package/{assistantConfig.d.ts → dist/assistantConfig.d.ts} +0 -0
  387. /package/{assistantConfig.js → dist/assistantConfig.js} +0 -0
  388. /package/{chat.d.ts → dist/chat.d.ts} +0 -0
  389. /package/{database.d.ts → dist/database.d.ts} +0 -0
  390. /package/{database.js → dist/database.js} +0 -0
  391. /package/{databaseId.d.ts → dist/databaseId.d.ts} +0 -0
  392. /package/{databaseTable.d.ts → dist/databaseTable.d.ts} +0 -0
  393. /package/{databaseTable.js → dist/databaseTable.js} +0 -0
  394. /package/{icons → dist/icons}/answerAwartar.png +0 -0
  395. /package/{icons → dist/icons}/docx-file.png +0 -0
  396. /package/{icons → dist/icons}/folder.png +0 -0
  397. /package/{icons → dist/icons}/html.png +0 -0
  398. /package/{icons → dist/icons}/image.png +0 -0
  399. /package/{icons → dist/icons}/jpg-file.png +0 -0
  400. /package/{icons → dist/icons}/json.png +0 -0
  401. /package/{icons → dist/icons}/md.png +0 -0
  402. /package/{icons → dist/icons}/pdf.png +0 -0
  403. /package/{icons → dist/icons}/pptx.png +0 -0
  404. /package/{icons → dist/icons}/questionAwartar.png +0 -0
  405. /package/{icons → dist/icons}/sheets.png +0 -0
  406. /package/{icons → dist/icons}/txt.png +0 -0
  407. /package/{icons → dist/icons}/xlsx.png +0 -0
  408. /package/{index.d.ts → dist/index.d.ts} +0 -0
  409. /package/{modelManage.d.ts → dist/modelManage.d.ts} +0 -0
  410. /package/{modelManage.js → dist/modelManage.js} +0 -0
  411. /package/{sensitive.d.ts → dist/sensitive.d.ts} +0 -0
  412. /package/{sensitive.js → dist/sensitive.js} +0 -0
  413. /package/{streamFilesReader.d.ts → dist/streamFilesReader.d.ts} +0 -0
  414. /package/{vite.svg → dist/vite.svg} +0 -0
  415. /package/{worker → dist/worker}/pdf.worker.min.js +0 -0
@@ -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 12px;
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
+ right: 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;
@@ -0,0 +1,221 @@
1
+ import { useState, useEffect, useRef } from 'react';
2
+ import ResourceBinderItem from './ResourceBinderItem';
3
+ import SearchableSelector, { type SearchableSelectorRef } from './SearchableSelector';
4
+ import { Button, Modal, Form, Checkbox, Input } from 'antd';
5
+ import { Plus } from 'lucide-react';
6
+ import Icon from '../assets/sensitive.svg';
7
+ import AxiosInstance from '../server';
8
+ import { DEFAULT_ANSWER } from '../constants';
9
+ const { Item } = Form;
10
+ const SensitiveSection = ({
11
+ url,
12
+ token,
13
+ role,
14
+ eventsEmit,
15
+ sectionData,
16
+ defaultAnswer,
17
+ form,
18
+ }: any) => {
19
+ const [options, setOptions]: any = useState([]);
20
+ const [data, setData]: any = useState([]);
21
+ const [isModalShow, setIsModalShow] = useState(false);
22
+ const [showDefaultAnswer, setShowDefaultAnswer] = useState(false);
23
+ const selectorRef = useRef<SearchableSelectorRef>(null);
24
+
25
+ const { fetchSensitiveLibrary } = AxiosInstance({
26
+ url,
27
+ token,
28
+ role,
29
+ eventsEmit,
30
+ });
31
+
32
+ useEffect(() => {
33
+ getList();
34
+ }, []);
35
+
36
+ useEffect(() => {
37
+ if (sectionData && options?.length > 0) {
38
+ let _sensitiveWordIds = sectionData
39
+ ? Array.isArray(sectionData)
40
+ ? sectionData
41
+ : sectionData.split(',')
42
+ : [];
43
+ let _data: any[] = [];
44
+ _sensitiveWordIds.forEach((s: string) => {
45
+ const _targetSensitive = (options || []).find((i: any) => i.key === s);
46
+ if (_targetSensitive) {
47
+ _data.push({
48
+ key: _targetSensitive.key,
49
+ label: _targetSensitive.label,
50
+ });
51
+ }
52
+ });
53
+ setData(_data);
54
+ }
55
+ }, [sectionData, options]);
56
+
57
+ useEffect(() => {
58
+ if (defaultAnswer) {
59
+ setShowDefaultAnswer(true);
60
+ }
61
+ }, [defaultAnswer]);
62
+
63
+ const getList = async () => {
64
+ try {
65
+ const res = await fetchSensitiveLibrary({
66
+ pageNo: 1,
67
+ pageSize: 9999,
68
+ });
69
+ if (res?.records) {
70
+ const options = (res?.records || []).map((item: any) => {
71
+ return {
72
+ key: item.id + '',
73
+ label: item.name,
74
+ };
75
+ });
76
+ setOptions(options);
77
+ }
78
+ } catch (e) {
79
+ console.error(e);
80
+ }
81
+ };
82
+
83
+ const handleEventsEmit = (name: string, eventsData?: any) => {
84
+ switch (name) {
85
+ case 'removeItem':
86
+ const _data = data.filter((p: any) => p.key !== eventsData.key);
87
+ setData([..._data]);
88
+ handleDatatoSubmit(_data);
89
+ break;
90
+ }
91
+ };
92
+
93
+ const handleDatatoSubmit = (selectedItems: any) => {
94
+ const item = selectedItems
95
+ .map((s: any) => s?.key || '')
96
+ .filter(key => key)
97
+ .join(',');
98
+ eventsEmit && eventsEmit('sensitive_selected', item);
99
+ };
100
+
101
+ const handleOk = () => {
102
+ // 通过 ref 获取选中的项
103
+ const selectedItems = selectorRef.current?.getSelectedItems() || [];
104
+ setData(selectedItems);
105
+ setIsModalShow(false);
106
+ handleDatatoSubmit(selectedItems);
107
+ };
108
+
109
+ return (
110
+ <div style={{ borderBottom: '1px solid #E5E6EB', padding: '12px 0 ' }}>
111
+ <div className="flex items-center justify-between">
112
+ <div className="flex items-center">
113
+ <img src={Icon} />
114
+ <span
115
+ className="font-medium "
116
+ style={{
117
+ marginLeft: '10px',
118
+ }}
119
+ >
120
+ 敏感词
121
+ </span>
122
+ </div>
123
+ <Button
124
+ color="primary"
125
+ variant="outlined"
126
+ size="small"
127
+ icon={<Plus size={14} />}
128
+ onClick={() => setIsModalShow(true)}
129
+ >
130
+ 添加
131
+ </Button>
132
+ </div>
133
+ <Checkbox
134
+ checked={showDefaultAnswer}
135
+ onChange={(e: any) => {
136
+ setShowDefaultAnswer(e.target.checked);
137
+ if (e.target.checked) {
138
+ form.setFieldsValue({
139
+ defaultAnswer: DEFAULT_ANSWER,
140
+ });
141
+ } else {
142
+ form.setFieldsValue({
143
+ defaultAnswer: '',
144
+ });
145
+ }
146
+ }}
147
+ style={{
148
+ marginBottom: 8,
149
+ marginTop: 8,
150
+ }}
151
+ >
152
+ 自定义回复
153
+ </Checkbox>
154
+ {showDefaultAnswer && (
155
+ <Item label="自定义回复内容" name="defaultAnswer" layout="vertical">
156
+ <Input.TextArea style={{ height: '55px', resize: 'none' }} />
157
+ </Item>
158
+ )}
159
+ {data?.length > 0 && (
160
+ <ResourceBinderItem
161
+ countText={data?.length > 0 ? `已选:${data?.length}个敏感词库` : undefined}
162
+ eventsEmit={handleEventsEmit}
163
+ data={data}
164
+ />
165
+ )}
166
+
167
+ <Modal
168
+ width={740}
169
+ title="选择敏感词"
170
+ okText="确定"
171
+ cancelText="取消"
172
+ open={isModalShow}
173
+ onOk={handleOk}
174
+ onCancel={() => setIsModalShow(false)}
175
+ destroyOnHidden
176
+ className="assistant-config-resource-bind-modal"
177
+ >
178
+ <SearchableSelector
179
+ ref={selectorRef}
180
+ dataSource={options}
181
+ value={data}
182
+ searchPlaceholder="搜索名称..."
183
+ width="700px"
184
+ height="500px"
185
+ title="敏感词库"
186
+ renderItem={item => {
187
+ return (
188
+ <div className="flex ">
189
+ <img src={Icon} alt="add" />
190
+ <span
191
+ style={{
192
+ marginLeft: 8,
193
+ marginRight: 8,
194
+ overflow: 'hidden',
195
+ textOverflow: 'ellipsis',
196
+ whiteSpace: 'nowrap',
197
+ }}
198
+ title={item.label}
199
+ >
200
+ {item.label}
201
+ </span>
202
+ </div>
203
+ );
204
+ }}
205
+ renderSelectedItem={(item, updateItemData) => {
206
+ return (
207
+ <div className="flex items-center">
208
+ <img src={Icon} alt="add" />
209
+ <div style={{ marginLeft: '12px' }}>
210
+ <div style={{ fontWeight: 500 }}>{item.label}</div>
211
+ </div>
212
+ </div>
213
+ );
214
+ }}
215
+ />
216
+ </Modal>
217
+ </div>
218
+ );
219
+ };
220
+
221
+ export default SensitiveSection;