@gientech/modual 2.0.4 → 2.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (419) hide show
  1. package/.editorconfig +38 -0
  2. package/.prettierignore +16 -0
  3. package/.prettierrc +17 -0
  4. package/README.md +643 -643
  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/{assets/GientechStreamReader-CzB5AuYo.js → dist/assets/GientechStreamReader-DUCq-O5X.js} +1 -1
  10. package/{assets → dist/assets}/database.svg +11 -11
  11. package/{assets → dist/assets}/database_add.svg +53 -53
  12. package/{assets → dist/assets}/database_connect.svg +66 -66
  13. package/{assets → dist/assets}/database_upload.svg +29 -29
  14. package/{assets → dist/assets}/databse.svg +6 -6
  15. package/{assets → dist/assets}/defaultWeLogo.svg +14 -14
  16. package/{assets → dist/assets}/graph.svg +4 -4
  17. package/{assets/index-CN2AYX8Q.js → dist/assets/index-B2yNvzjy.js} +1 -1
  18. package/{assets/index-D9lYd8TZ.js → dist/assets/index-BKe5FgcC.js} +1 -1
  19. package/{assets/index-CBTA5S-5.js → dist/assets/index-D72cKELw.js} +1 -1
  20. package/{assets/index-s0cmC4Ks.js → dist/assets/index-DdVFXD_y.js} +1 -1
  21. package/{assets/index-B1ZDDbC1.js → dist/assets/index-DrkSoKz6.js} +1 -1
  22. package/{assets/index-B2rFliXg.js → dist/assets/index-KCfkkJKb.js} +1 -1
  23. package/{assets/index-DnBY0UXI.js → dist/assets/index-QI9biQrR.js} +2 -2
  24. package/{assets/index-DYhXjvk4.js → dist/assets/index-ZopkeZtI.js} +1 -1
  25. package/{assets/index-LDFwTu47.js → dist/assets/index-g-SUxfJH.js} +1 -1
  26. package/{assets/index-NFQIKNFn.js → dist/assets/index-j0kQJd0a.js} +1 -1
  27. package/{assets → dist/assets}/knowledge.svg +4 -4
  28. package/{assets/MySQL.svg → dist/assets/mysql.svg} +14 -14
  29. package/{assets/plus-G7zGXf6S.js → dist/assets/plus-V9zUoSq6.js} +1 -1
  30. package/{assets → dist/assets}/sensitive.svg +5 -5
  31. package/{assets/style-Bn7b5XHU.js → dist/assets/style-CGmZ5osp.js} +2 -2
  32. package/{assets/x-vfKYzKkK.js → dist/assets/x-CnaaLGJF.js} +1 -1
  33. package/dist/assistantConfig.js +1 -0
  34. package/dist/chat.js +824 -0
  35. package/dist/database.js +20 -0
  36. package/dist/databaseId.js +1 -0
  37. package/{databaseTable.js → dist/databaseTable.js} +1 -1
  38. package/dist/index.js +1 -0
  39. package/{modelManage.js → dist/modelManage.js} +1 -1
  40. package/dist/package.json +68 -0
  41. package/{sensitive.js → dist/sensitive.js} +1 -1
  42. package/dist/streamFilesReader.js +1 -0
  43. package/{worker → dist/worker}/pdf.worker.min.js +21 -21
  44. package/doc_assets/2.png +0 -0
  45. package/doc_assets/demo.md +27 -0
  46. package/doc_assets/demos/dist-app/assets/index.Dh-ZAS9Z.css +2 -0
  47. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js +23699 -0
  48. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js.map +1 -0
  49. package/doc_assets/demos/dist-app/index.html +14 -0
  50. package/doc_assets/demos/dist-app/vite.svg +1 -0
  51. package/doc_assets/images/1.png +0 -0
  52. package/doc_assets/images/3.png +0 -0
  53. package/doc_assets/images/component-screenshot.png +1 -0
  54. package/doc_assets/install.md +5 -0
  55. 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
  56. package/eslint.config.js +92 -0
  57. package/index.html +13 -0
  58. package/package.json +106 -44
  59. package/package.json.demo-backup +109 -0
  60. package/postcss.config.cjs +19 -0
  61. package/public/icons/answerAwartar.png +0 -0
  62. package/public/icons/docx-file.png +0 -0
  63. package/public/icons/folder.png +0 -0
  64. package/public/icons/html.png +0 -0
  65. package/public/icons/image.png +0 -0
  66. package/public/icons/jpg-file.png +0 -0
  67. package/public/icons/json.png +0 -0
  68. package/public/icons/md.png +0 -0
  69. package/public/icons/pdf.png +0 -0
  70. package/public/icons/pptx.png +0 -0
  71. package/public/icons/questionAwartar.png +0 -0
  72. package/public/icons/sheets.png +0 -0
  73. package/public/icons/txt.png +0 -0
  74. package/public/icons/xlsx.png +0 -0
  75. package/public/vite.svg +1 -0
  76. package/public/worker/pdf.worker.min.js +22 -0
  77. package/scripts/README.md +133 -0
  78. package/scripts/build-demo.js +88 -0
  79. package/scripts/decrypt-api-key.js +95 -0
  80. package/scripts/demo-selector.js +216 -0
  81. package/scripts/dev-demo.js +76 -0
  82. package/scripts/preview-demo.js +130 -0
  83. package/scripts/run-demo.bat +34 -0
  84. package/src/assets/img/close.png +0 -0
  85. package/src/assets/img/database.png +0 -0
  86. package/src/assets/img/downArrow.png +0 -0
  87. package/src/assets/img/downLoad.png +0 -0
  88. package/src/assets/img/excel.png +0 -0
  89. package/src/assets/img/graphIcon.png +0 -0
  90. package/src/assets/img/img.png +0 -0
  91. package/src/assets/img/pdf.png +0 -0
  92. package/src/assets/img/ppt.png +0 -0
  93. package/src/assets/img/singleQa.png +0 -0
  94. package/src/assets/img/txt.png +0 -0
  95. package/src/assets/img/webSearch.png +0 -0
  96. package/src/assets/img/word.png +0 -0
  97. package/src/assets/login/homeBg.png +0 -0
  98. package/src/assets/login/left.jpg +0 -0
  99. package/src/assets/login/logoImg.png +0 -0
  100. package/src/examples/ConversationAssistantPage/index.tsx +41 -0
  101. package/src/examples/Demo/index.tsx +12 -0
  102. package/src/examples/LoginPage/index.tsx +18 -0
  103. package/src/examples/chat/components/DrawerGraphPreview.tsx +78 -0
  104. package/src/examples/chat/index.tsx +154 -0
  105. package/src/examples/chat/logo03.png +0 -0
  106. package/src/examples/gientechStreamFilesReader/index.tsx +951 -0
  107. package/src/examples/headlessChat/index.tsx +234 -0
  108. package/src/examples/ragDatabaseDataPage/index.tsx +40 -0
  109. package/src/examples/ragDatabaseIdPage/index.tsx +47 -0
  110. package/src/examples/ragDatabasePage/index.tsx +36 -0
  111. package/src/examples/ragModelManagePage/index.tsx +38 -0
  112. package/src/examples/ragSearchPage/index.tsx +0 -0
  113. package/src/examples/ragSensitiveWordsPage/index.tsx +32 -0
  114. package/src/examples/streamFiles/index.tsx +417 -0
  115. package/src/lib_enter.ts +43 -0
  116. package/src/main.tsx +5 -0
  117. package/src/main.tsx.backup +5 -0
  118. package/src/modules/CHAT_UNIFICATION_PLAN.md +324 -0
  119. package/src/modules/assistantConfig/assets/databse.svg +6 -0
  120. package/src/modules/assistantConfig/assets/empty.png +0 -0
  121. package/src/modules/assistantConfig/assets/graph.svg +4 -0
  122. package/src/modules/assistantConfig/assets/knowledge.svg +4 -0
  123. package/src/modules/assistantConfig/assets/sensitive.svg +5 -0
  124. package/src/modules/assistantConfig/components/Database.tsx +171 -0
  125. package/src/modules/assistantConfig/components/Graph.tsx +177 -0
  126. package/src/modules/assistantConfig/components/Knowledge.tsx +276 -0
  127. package/src/modules/assistantConfig/components/NotFoundContent.tsx +21 -0
  128. package/src/modules/assistantConfig/components/Paragraph.tsx +51 -0
  129. package/src/modules/assistantConfig/components/ParamsItem.tsx +39 -0
  130. package/src/modules/assistantConfig/components/ResourceBinderItem.tsx +133 -0
  131. package/src/modules/assistantConfig/components/SearchableSelector.tsx +500 -0
  132. package/src/modules/assistantConfig/components/Sensitive.tsx +221 -0
  133. package/src/modules/assistantConfig/components/SliderInput.tsx +65 -0
  134. package/src/modules/assistantConfig/constants.tsx +75 -0
  135. package/src/modules/assistantConfig/index.tsx +710 -0
  136. package/src/modules/assistantConfig/server.ts +262 -0
  137. package/src/modules/chat/Conversations/Item.tsx +167 -0
  138. package/src/modules/chat/Conversations/List.tsx +210 -0
  139. package/src/modules/chat/Conversations/groupByTime.ts +39 -0
  140. package/src/modules/chat/Conversations/index.tsx +252 -0
  141. package/src/modules/chat/ReferenceBar.tsx +622 -0
  142. package/src/modules/chat/constants.tsx +52 -0
  143. package/src/modules/chat/data.txt +82 -0
  144. package/src/modules/chat/index.tsx +2054 -0
  145. package/src/modules/chat/referenceCom/DeleteModal.tsx +75 -0
  146. package/src/modules/chat/referenceCom/DrawerContent.tsx +136 -0
  147. package/src/modules/chat/referenceCom/DrawerDatabase.tsx +102 -0
  148. package/src/modules/chat/referenceCom/DrawerGraphPreview.tsx +86 -0
  149. package/src/modules/chat/referenceCom/DrawerPreview.tsx +73 -0
  150. package/src/modules/chat/referenceCom/DrawerTitle.tsx +26 -0
  151. package/src/modules/chat/referenceCom/RenameModal.tsx +86 -0
  152. package/src/modules/chat/referenceCom/TagCom.tsx +30 -0
  153. package/src/modules/chat/style.less +3 -0
  154. package/src/modules/chat/types.ts +17 -0
  155. package/src/modules/chat/utils/index.ts +348 -0
  156. package/src/modules/database/CreateModal.tsx +403 -0
  157. package/src/modules/database/assets/Doris.png +0 -0
  158. package/src/modules/database/assets/PostgreSQL.png +0 -0
  159. package/src/modules/database/assets/SQLServer.png +0 -0
  160. package/src/modules/database/assets/database.svg +11 -0
  161. package/src/modules/database/assets/database_add.svg +53 -0
  162. package/src/modules/database/assets/database_connect.svg +66 -0
  163. package/src/modules/database/assets/database_upload.svg +29 -0
  164. package/src/modules/database/assets/empty.png +0 -0
  165. package/src/modules/database/assets/mysql.svg +14 -0
  166. package/src/modules/database/index.tsx +477 -0
  167. package/src/modules/database/server.ts +196 -0
  168. package/src/modules/databaseId/CustomCom.tsx +156 -0
  169. package/src/modules/databaseId/EditConfig.tsx +280 -0
  170. package/src/modules/databaseId/UploadDrawer.tsx +535 -0
  171. package/src/modules/databaseId/assets/aiOptimize.svg +10 -0
  172. package/src/modules/databaseId/assets/empty.png +0 -0
  173. package/src/modules/databaseId/assets/template.svg +6 -0
  174. package/src/modules/databaseId/assets/upload.svg +9 -0
  175. package/src/modules/databaseId/assets/useTemp.svg +6 -0
  176. package/src/modules/databaseId/index.tsx +769 -0
  177. package/src/modules/databaseId/server.ts +286 -0
  178. package/src/modules/databaseId/style.css +5 -0
  179. package/src/modules/databaseTable/EditRowDrawer.tsx +124 -0
  180. package/src/modules/databaseTable/index.tsx +359 -0
  181. package/src/modules/databaseTable/server.ts +180 -0
  182. package/src/modules/headlessChat/ReferenceBar.tsx +783 -0
  183. package/src/modules/headlessChat/constants.tsx +54 -0
  184. package/src/modules/headlessChat/index.tsx +1706 -0
  185. package/src/modules/headlessChat/referenceCom/DeleteModal.tsx +75 -0
  186. package/src/modules/headlessChat/referenceCom/DrawerContent.tsx +136 -0
  187. package/src/modules/headlessChat/referenceCom/DrawerDatabase.tsx +102 -0
  188. package/src/modules/headlessChat/referenceCom/DrawerGraphPreview.tsx +86 -0
  189. package/src/modules/headlessChat/referenceCom/DrawerPreview.tsx +73 -0
  190. package/src/modules/headlessChat/referenceCom/DrawerTitle.tsx +26 -0
  191. package/src/modules/headlessChat/referenceCom/RenameModal.tsx +86 -0
  192. package/src/modules/headlessChat/referenceCom/TagCom.tsx +30 -0
  193. package/src/modules/headlessChat/style.less +3 -0
  194. package/src/modules/headlessChat/types.ts +23 -0
  195. package/src/modules/headlessChat/utils/index.ts +348 -0
  196. package/src/modules/login/components/Login/LoginBox/index.tsx +102 -0
  197. package/src/modules/login/components/Login/RegisterBox/index.tsx +180 -0
  198. package/src/modules/login/components/Login/index.tsx +100 -0
  199. package/src/modules/login/index.tsx +106 -0
  200. package/src/modules/login/style.css +3 -0
  201. package/src/modules/login/useServices.ts +53 -0
  202. package/src/modules/login/utils.ts +42 -0
  203. package/src/modules/modelManage/ConfigDrawer.tsx +249 -0
  204. package/src/modules/modelManage/ReplaceModal.tsx +124 -0
  205. package/src/modules/modelManage/assets/empty.png +0 -0
  206. package/src/modules/modelManage/const.ts +51 -0
  207. package/src/modules/modelManage/index.tsx +606 -0
  208. package/src/modules/modelManage/server.ts +223 -0
  209. package/src/modules/nodegraph/index.tsx +1 -0
  210. package/src/modules/search/assets/Icon-history.svg +8 -0
  211. package/src/modules/search/assets/answerAwartar.png +0 -0
  212. package/src/modules/search/assets/doc.png +0 -0
  213. package/src/modules/search/assets/genera.gif +0 -0
  214. package/src/modules/search/assets/icon-robot.svg +9 -0
  215. package/src/modules/search/assets/icon-search-bar.svg +14 -0
  216. package/src/modules/search/assets/icon-sub-title.svg +3 -0
  217. package/src/modules/search/assets/icon-title.svg +9 -0
  218. package/src/modules/search/assets/icon-zoomOut.svg +9 -0
  219. package/src/modules/search/assets/iconAi.svg +9 -0
  220. package/src/modules/search/assets/pdf.png +0 -0
  221. package/src/modules/search/assets/ppt.png +0 -0
  222. package/src/modules/search/assets/search.svg +3 -0
  223. package/src/modules/search/assets/selected.svg +4 -0
  224. package/src/modules/search/assets/txt.png +0 -0
  225. package/src/modules/search/assets/xls.png +0 -0
  226. package/src/modules/search/components/AssisSelect.tsx +137 -0
  227. package/src/modules/search/components/Editor/ChatViewEditor.tsx +261 -0
  228. package/src/modules/search/components/Editor/aichat.css +1 -0
  229. package/src/modules/search/components/Editor/constant.ts +13 -0
  230. package/src/modules/search/components/Editor/index.tsx +113 -0
  231. package/src/modules/search/components/Editor/plugins/autofomatRules.ts +332 -0
  232. package/src/modules/search/components/Editor/plugins/convertImgPlugins.tsx +20 -0
  233. package/src/modules/search/components/Editor/plugins/createIndexes.tsx +38 -0
  234. package/src/modules/search/components/Editor/plugins/displayer.ts +298 -0
  235. package/src/modules/search/components/Editor/plugins/imageClick.tsx +32 -0
  236. package/src/modules/search/components/Editor/plugins/myplugin.tsx +98 -0
  237. package/src/modules/search/components/Editor/ui/avatar.tsx +19 -0
  238. package/src/modules/search/components/Editor/ui/blockquote-element.tsx +21 -0
  239. package/src/modules/search/components/Editor/ui/button.tsx +58 -0
  240. package/src/modules/search/components/Editor/ui/calendar.tsx +68 -0
  241. package/src/modules/search/components/Editor/ui/caption.tsx +46 -0
  242. package/src/modules/search/components/Editor/ui/checkbox.tsx +27 -0
  243. package/src/modules/search/components/Editor/ui/code-block-combobox.tsx +188 -0
  244. package/src/modules/search/components/Editor/ui/code-block-element.css +434 -0
  245. package/src/modules/search/components/Editor/ui/code-block-element.tsx +39 -0
  246. package/src/modules/search/components/Editor/ui/code-leaf.tsx +24 -0
  247. package/src/modules/search/components/Editor/ui/code-line-element.tsx +10 -0
  248. package/src/modules/search/components/Editor/ui/code-syntax-leaf.tsx +21 -0
  249. package/src/modules/search/components/Editor/ui/column-element.tsx +30 -0
  250. package/src/modules/search/components/Editor/ui/column-group-element.tsx +94 -0
  251. package/src/modules/search/components/Editor/ui/command.tsx +75 -0
  252. package/src/modules/search/components/Editor/ui/comment-avatar.tsx +22 -0
  253. package/src/modules/search/components/Editor/ui/comment-create-form.tsx +37 -0
  254. package/src/modules/search/components/Editor/ui/comment-item.tsx +74 -0
  255. package/src/modules/search/components/Editor/ui/comment-leaf.tsx +49 -0
  256. package/src/modules/search/components/Editor/ui/comment-more-dropdown.tsx +42 -0
  257. package/src/modules/search/components/Editor/ui/comment-reply-items.tsx +22 -0
  258. package/src/modules/search/components/Editor/ui/comment-resolve-button.tsx +32 -0
  259. package/src/modules/search/components/Editor/ui/comment-value.tsx +34 -0
  260. package/src/modules/search/components/Editor/ui/comments-popover.tsx +63 -0
  261. package/src/modules/search/components/Editor/ui/date-element.tsx +83 -0
  262. package/src/modules/search/components/Editor/ui/dialog.tsx +63 -0
  263. package/src/modules/search/components/Editor/ui/draggable.tsx +177 -0
  264. package/src/modules/search/components/Editor/ui/dropdown-menu.tsx +180 -0
  265. package/src/modules/search/components/Editor/ui/emoji-input-element.tsx +85 -0
  266. package/src/modules/search/components/Editor/ui/excalidraw-element.tsx +28 -0
  267. package/src/modules/search/components/Editor/ui/fixed-toolbar-buttons.tsx +76 -0
  268. package/src/modules/search/components/Editor/ui/fixed-toolbar.tsx +8 -0
  269. package/src/modules/search/components/Editor/ui/floating-toolbar-buttons.tsx +51 -0
  270. package/src/modules/search/components/Editor/ui/floating-toolbar.tsx +77 -0
  271. package/src/modules/search/components/Editor/ui/heading-element.tsx +48 -0
  272. package/src/modules/search/components/Editor/ui/highlight-leaf.tsx +17 -0
  273. package/src/modules/search/components/Editor/ui/hr-element.tsx +30 -0
  274. package/src/modules/search/components/Editor/ui/icons.tsx +267 -0
  275. package/src/modules/search/components/Editor/ui/image-element.tsx +74 -0
  276. package/src/modules/search/components/Editor/ui/inline-combobox.tsx +368 -0
  277. package/src/modules/search/components/Editor/ui/input.tsx +25 -0
  278. package/src/modules/search/components/Editor/ui/insert-dropdown-menu.tsx +218 -0
  279. package/src/modules/search/components/Editor/ui/kbd-leaf.tsx +20 -0
  280. package/src/modules/search/components/Editor/ui/link-element.tsx +29 -0
  281. package/src/modules/search/components/Editor/ui/link-floating-toolbar.tsx +161 -0
  282. package/src/modules/search/components/Editor/ui/list-element.tsx +30 -0
  283. package/src/modules/search/components/Editor/ui/mark-toolbar-button.tsx +24 -0
  284. package/src/modules/search/components/Editor/ui/media-embed-element.tsx +133 -0
  285. package/src/modules/search/components/Editor/ui/media-popover.tsx +97 -0
  286. package/src/modules/search/components/Editor/ui/mention-element.tsx +43 -0
  287. package/src/modules/search/components/Editor/ui/mention-input-element.tsx +141 -0
  288. package/src/modules/search/components/Editor/ui/mode-dropdown-menu.tsx +93 -0
  289. package/src/modules/search/components/Editor/ui/more-dropdown-menu.tsx +67 -0
  290. package/src/modules/search/components/Editor/ui/paragraph-element.tsx +4 -0
  291. package/src/modules/search/components/Editor/ui/placeholder.tsx +52 -0
  292. package/src/modules/search/components/Editor/ui/popover.tsx +32 -0
  293. package/src/modules/search/components/Editor/ui/resizable.tsx +66 -0
  294. package/src/modules/search/components/Editor/ui/separator.tsx +25 -0
  295. package/src/modules/search/components/Editor/ui/style.less +12 -0
  296. package/src/modules/search/components/Editor/ui/table-cell-element.tsx +143 -0
  297. package/src/modules/search/components/Editor/ui/table-element.tsx +243 -0
  298. package/src/modules/search/components/Editor/ui/table-row-element.tsx +22 -0
  299. package/src/modules/search/components/Editor/ui/tableValue.tsx +135 -0
  300. package/src/modules/search/components/Editor/ui/todo-list-element.tsx +43 -0
  301. package/src/modules/search/components/Editor/ui/toggle-element.tsx +31 -0
  302. package/src/modules/search/components/Editor/ui/toolbar.tsx +157 -0
  303. package/src/modules/search/components/Editor/ui/tooltip.tsx +65 -0
  304. package/src/modules/search/components/Editor/ui/turn-into-dropdown-menu.tsx +160 -0
  305. package/src/modules/search/components/Editor/ui/with-draggables.tsx +175 -0
  306. package/src/modules/search/components/FileList.tsx +287 -0
  307. package/src/modules/search/components/ImageGroupView/index.tsx +85 -0
  308. package/src/modules/search/components/ResultContent.tsx +232 -0
  309. package/src/modules/search/components/SearchInput.tsx +232 -0
  310. package/src/modules/search/components/SearchLanding.tsx +74 -0
  311. package/src/modules/search/components/SearchView.tsx +563 -0
  312. package/src/modules/search/components/SimpleEditor.tsx +158 -0
  313. package/src/modules/search/components/SimpleFileList.tsx +215 -0
  314. package/src/modules/search/index.tsx +10 -0
  315. package/src/modules/search/reademe.md +1 -0
  316. package/src/modules/search/servers/apis.tsx +19 -0
  317. package/src/modules/search/servers/index.ts +184 -0
  318. package/src/modules/search/style.less +503 -0
  319. package/src/modules/search/type.ts +22 -0
  320. package/src/modules/search/utils.ts +34 -0
  321. package/src/modules/sensitive/index.tsx +313 -0
  322. package/src/modules/sensitive/server.ts +122 -0
  323. package/src/modules/streamFilesReader/GientechStreamReader.tsx +1625 -0
  324. package/src/modules/streamFilesReader/components/Header/Toolbar.tsx +0 -0
  325. package/src/modules/streamFilesReader/components/Header/index.tsx +297 -0
  326. package/src/modules/streamFilesReader/index.tsx +3 -0
  327. package/src/style.css +6 -0
  328. package/src/type.d.ts +0 -0
  329. package/src/utils/commonFn.tsx +111 -0
  330. package/src/utils/decryptApiKey.ts +40 -0
  331. package/src/utils/gientechCommon/components/AppError.tsx +32 -0
  332. package/src/utils/gientechCommon/components/AppLoading.tsx +75 -0
  333. package/src/utils/gientechCommon/components/DeleteModal.tsx +75 -0
  334. package/src/utils/gientechCommon/components/DisplayError.tsx +33 -0
  335. package/src/utils/gientechCommon/components/DisplayLoading.tsx +38 -0
  336. package/src/utils/gientechCommon/components/FeedBackModal.tsx +319 -0
  337. package/src/utils/gientechCommon/components/FileCardCommon.tsx +82 -0
  338. package/src/utils/gientechCommon/components/FileManager/index.tsx +400 -0
  339. package/src/utils/gientechCommon/components/FileManager/style.css +5 -0
  340. package/src/utils/gientechCommon/components/Messages/GientechNewChatWelcome.tsx +581 -0
  341. package/src/utils/gientechCommon/components/Messages/ReferenceCard.tsx +359 -0
  342. package/src/utils/gientechCommon/components/Messages/RetriveItem.tsx +245 -0
  343. package/src/utils/gientechCommon/components/Messages/WebRetriveItem.tsx +209 -0
  344. package/src/utils/gientechCommon/components/Messages/defaultBot.png +0 -0
  345. package/src/utils/gientechCommon/components/Messages/defaultStyleSet.tsx +148 -0
  346. package/src/utils/gientechCommon/components/Messages/defaultWeLogo.svg +14 -0
  347. package/src/utils/gientechCommon/components/RenameModal.tsx +86 -0
  348. package/src/utils/gientechCommon/components/style.less +11 -0
  349. package/src/utils/gientechCommon/configs/commonConfig.ts +2 -0
  350. package/src/utils/gientechCommon/configs/senderConfig.ts +0 -0
  351. package/src/utils/gientechCommon/configs/stylesConfig.ts +142 -0
  352. package/src/utils/gientechCommon/hooks/AichatUseController.tsx +417 -0
  353. package/src/utils/gientechCommon/hooks/useFileDisplayTools.tsx +204 -0
  354. package/src/utils/gientechCommon/hooks/useFileManager.ts +193 -0
  355. package/src/utils/gientechCommon/slate/converters/deserializers.ts +763 -0
  356. package/src/utils/gientechCommon/slate/converters/mockData.ts +232 -0
  357. package/src/utils/gientechCommon/slate/converters/slateConverters.ts +258 -0
  358. package/src/utils/gientechCommon/slate/richElements/index.tsx +499 -0
  359. package/src/utils/gientechCommon/utils/fileUtils.ts +86 -0
  360. package/src/utils/gientechCommon/utils/request.ts +37 -0
  361. package/src/utils/gientechCommon/utils/serverFn.ts +172 -0
  362. package/src/utils/index.tsx +142 -0
  363. package/src/utils/testconfigs/demologin/index.tsx +32 -0
  364. package/src/utils/testconfigs/index.ts +59 -0
  365. package/src/vite-env.d.ts +42 -0
  366. package/stats.html +4949 -0
  367. package/tailwind.config.js +170 -0
  368. package/tsconfig.app.json +30 -0
  369. package/tsconfig.app.tsbuildinfo +11 -0
  370. package/tsconfig.json +13 -0
  371. package/tsconfig.node.json +22 -0
  372. package/tsconfig.node.tsbuildinfo +1 -0
  373. package/vite.config.app.ts +93 -0
  374. package/vite.config.ts +232 -0
  375. package/workflows/release.yml +60 -0
  376. 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
  377. package/assistantConfig.js +0 -1
  378. package/chat.js +0 -786
  379. package/database.js +0 -20
  380. package/databaseId.js +0 -1
  381. package/index.js +0 -1
  382. package/streamFilesReader.js +0 -1
  383. /package/{assets → dist/assets}/Doris.png +0 -0
  384. /package/{assets → dist/assets}/PostgreSQL.png +0 -0
  385. /package/{assets → dist/assets}/SQLServer.png +0 -0
  386. /package/{assets → dist/assets}/empty.png +0 -0
  387. /package/{assets → dist/assets}/homeBg.png +0 -0
  388. /package/{assets → dist/assets}/index-CpW6Dhpp.js +0 -0
  389. /package/{assets → dist/assets}/left.jpg +0 -0
  390. /package/{assets → dist/assets}/logoImg.png +0 -0
  391. /package/{assets → dist/assets}/style.css +0 -0
  392. /package/{assets → dist/assets}/style2.css +0 -0
  393. /package/{assets → dist/assets}/style3.css +0 -0
  394. /package/{assets → dist/assets}/style4.css +0 -0
  395. /package/{assets → dist/assets}/worker-BbpylX7l.js +0 -0
  396. /package/{assistantConfig.d.ts → dist/assistantConfig.d.ts} +0 -0
  397. /package/{chat.d.ts → dist/chat.d.ts} +0 -0
  398. /package/{database.d.ts → dist/database.d.ts} +0 -0
  399. /package/{databaseId.d.ts → dist/databaseId.d.ts} +0 -0
  400. /package/{databaseTable.d.ts → dist/databaseTable.d.ts} +0 -0
  401. /package/{icons → dist/icons}/answerAwartar.png +0 -0
  402. /package/{icons → dist/icons}/docx-file.png +0 -0
  403. /package/{icons → dist/icons}/folder.png +0 -0
  404. /package/{icons → dist/icons}/html.png +0 -0
  405. /package/{icons → dist/icons}/image.png +0 -0
  406. /package/{icons → dist/icons}/jpg-file.png +0 -0
  407. /package/{icons → dist/icons}/json.png +0 -0
  408. /package/{icons → dist/icons}/md.png +0 -0
  409. /package/{icons → dist/icons}/pdf.png +0 -0
  410. /package/{icons → dist/icons}/pptx.png +0 -0
  411. /package/{icons → dist/icons}/questionAwartar.png +0 -0
  412. /package/{icons → dist/icons}/sheets.png +0 -0
  413. /package/{icons → dist/icons}/txt.png +0 -0
  414. /package/{icons → dist/icons}/xlsx.png +0 -0
  415. /package/{index.d.ts → dist/index.d.ts} +0 -0
  416. /package/{modelManage.d.ts → dist/modelManage.d.ts} +0 -0
  417. /package/{sensitive.d.ts → dist/sensitive.d.ts} +0 -0
  418. /package/{streamFilesReader.d.ts → dist/streamFilesReader.d.ts} +0 -0
  419. /package/{vite.svg → dist/vite.svg} +0 -0
@@ -0,0 +1,160 @@
1
+ import React from "react";
2
+
3
+ import type { DropdownMenuProps } from "@radix-ui/react-dropdown-menu";
4
+
5
+ import { BlockquotePlugin } from "@udecode/plate-block-quote/react";
6
+ import {
7
+ collapseSelection,
8
+ getNodeEntries,
9
+ isBlock
10
+ } from "@udecode/plate-common";
11
+ import {
12
+ focusEditor,
13
+ useEditorRef,
14
+ useEditorSelector,
15
+ ParagraphPlugin
16
+ } from "@udecode/plate-common/react";
17
+ import { HEADING_KEYS } from "@udecode/plate-heading";
18
+
19
+ import { Icons } from "./icons";
20
+
21
+ import {
22
+ DropdownMenu,
23
+ DropdownMenuContent,
24
+ DropdownMenuLabel,
25
+ DropdownMenuRadioGroup,
26
+ DropdownMenuRadioItem,
27
+ DropdownMenuTrigger,
28
+ useOpenState
29
+ } from "./dropdown-menu";
30
+ import { ToolbarButton } from "./toolbar";
31
+
32
+ const items = [
33
+ {
34
+ description: "Paragraph",
35
+ icon: Icons.paragraph,
36
+ label: "Paragraph",
37
+ value: ParagraphPlugin.key
38
+ },
39
+ {
40
+ description: "Heading 1",
41
+ icon: Icons.h1,
42
+ label: "Heading 1",
43
+ value: HEADING_KEYS.h1
44
+ },
45
+ {
46
+ description: "Heading 2",
47
+ icon: Icons.h2,
48
+ label: "Heading 2",
49
+ value: HEADING_KEYS.h2
50
+ },
51
+ {
52
+ description: "Heading 3",
53
+ icon: Icons.h3,
54
+ label: "Heading 3",
55
+ value: HEADING_KEYS.h3
56
+ },
57
+ {
58
+ description: "Quote (⌘+⇧+.)",
59
+ icon: Icons.blockquote,
60
+ label: "Quote",
61
+ value: BlockquotePlugin.key
62
+ }
63
+ // {
64
+ // value: 'ul',
65
+ // label: 'Bulleted list',
66
+ // description: 'Bulleted list',
67
+ // icon: Icons.ul,
68
+ // },
69
+ // {
70
+ // value: 'ol',
71
+ // label: 'Numbered list',
72
+ // description: 'Numbered list',
73
+ // icon: Icons.ol,
74
+ // },
75
+ ];
76
+
77
+ const defaultItem = items.find((item) => item.value === ParagraphPlugin.key)!;
78
+
79
+ export function TurnIntoDropdownMenu(props: DropdownMenuProps) {
80
+ const value: string = useEditorSelector((editor) => {
81
+ let initialNodeType: string = ParagraphPlugin.key;
82
+ let allNodesMatchInitialNodeType = false;
83
+ const codeBlockEntries = getNodeEntries(editor, {
84
+ match: (n) => isBlock(editor, n),
85
+ mode: "highest"
86
+ });
87
+ const nodes = Array.from(codeBlockEntries);
88
+
89
+ if (nodes.length > 0) {
90
+ initialNodeType = nodes[0][0].type as string;
91
+ allNodesMatchInitialNodeType = nodes.every(([node]) => {
92
+ const type: string = (node?.type as string) || ParagraphPlugin.key;
93
+
94
+ return type === initialNodeType;
95
+ });
96
+ }
97
+
98
+ return allNodesMatchInitialNodeType ? initialNodeType : ParagraphPlugin.key;
99
+ }, []);
100
+
101
+ const editor = useEditorRef();
102
+ const openState = useOpenState();
103
+
104
+ const selectedItem =
105
+ items.find((item) => item.value === value) ?? defaultItem;
106
+ const { icon: SelectedItemIcon, label: selectedItemLabel } = selectedItem;
107
+
108
+ return (
109
+ <DropdownMenu modal={false} {...openState} {...props}>
110
+ <DropdownMenuTrigger asChild>
111
+ <ToolbarButton
112
+ className="lg:min-w-[130px]"
113
+ isDropdown
114
+ pressed={openState.open}
115
+ tooltip="Turn into"
116
+ >
117
+ <SelectedItemIcon className="size-5 lg:hidden" />
118
+ <span className="max-lg:hidden">{selectedItemLabel}</span>
119
+ </ToolbarButton>
120
+ </DropdownMenuTrigger>
121
+
122
+ <DropdownMenuContent align="start" className="min-w-0">
123
+ <DropdownMenuLabel>Turn into</DropdownMenuLabel>
124
+
125
+ <DropdownMenuRadioGroup
126
+ className="flex flex-col gap-0.5"
127
+ onValueChange={(type) => {
128
+ // if (type === 'ul' || type === 'ol') {
129
+ // if (settingsStore.get.checkedId(IndentListPlugin.key)) {
130
+ // toggleIndentList(editor, {
131
+ // listStyleType: type === 'ul' ? 'disc' : 'decimal',
132
+ // });
133
+ // } else if (settingsStore.get.checkedId('list')) {
134
+ // toggleList(editor, { type });
135
+ // }
136
+ // } else {
137
+ // unwrapList(editor);
138
+ editor.tf.toggle.block({ type });
139
+ // }
140
+
141
+ collapseSelection(editor);
142
+ focusEditor(editor);
143
+ }}
144
+ value={value}
145
+ >
146
+ {items.map(({ icon: Icon, label, value: itemValue }) => (
147
+ <DropdownMenuRadioItem
148
+ className="min-w-[180px]"
149
+ key={itemValue}
150
+ value={itemValue}
151
+ >
152
+ <Icon className="mr-2 size-5" />
153
+ {label}
154
+ </DropdownMenuRadioItem>
155
+ ))}
156
+ </DropdownMenuRadioGroup>
157
+ </DropdownMenuContent>
158
+ </DropdownMenu>
159
+ );
160
+ }
@@ -0,0 +1,175 @@
1
+ import type { FC } from 'react';
2
+
3
+ import { BlockquotePlugin } from '@udecode/plate-block-quote/react';
4
+ import { CodeBlockPlugin } from '@udecode/plate-code-block/react';
5
+ import {
6
+ ParagraphPlugin,
7
+ createNodesWithHOC,
8
+ } from '@udecode/plate-common/react';
9
+ import {
10
+ type WithDraggableOptions,
11
+ withDraggable as withDraggablePrimitive,
12
+ } from '@udecode/plate-dnd';
13
+ import { ExcalidrawPlugin } from '@udecode/plate-excalidraw';
14
+ import { HEADING_KEYS } from '@udecode/plate-heading';
15
+ import { ColumnPlugin } from '@udecode/plate-layout';
16
+ import {
17
+ BulletedListPlugin,
18
+ NumberedListPlugin,
19
+ } from '@udecode/plate-list/react';
20
+ import {
21
+ ImagePlugin,
22
+ MediaEmbedPlugin,
23
+ PlaceholderPlugin,
24
+ } from '@udecode/plate-media';
25
+ import { TablePlugin } from '@udecode/plate-table';
26
+ import { TogglePlugin } from '@udecode/plate-toggle';
27
+
28
+ import { Draggable, type DraggableProps } from './draggable';
29
+
30
+ export const withDraggable = (
31
+ Component: FC,
32
+ options?: WithDraggableOptions<
33
+ Partial<Omit<DraggableProps, 'children' | 'editor' | 'element'>>
34
+ >
35
+ ) =>
36
+ withDraggablePrimitive<DraggableProps>(Draggable, Component, options as any);
37
+
38
+ export const withDraggablesPrimitive = createNodesWithHOC(withDraggable);
39
+
40
+ export const withDraggables = (components: any) => {
41
+ return withDraggablesPrimitive(components, [
42
+ {
43
+ keys: [
44
+ ParagraphPlugin.key,
45
+ BulletedListPlugin.key,
46
+ NumberedListPlugin.key,
47
+ ],
48
+ level: 0,
49
+ },
50
+ {
51
+ draggableProps: {
52
+ classNames: {
53
+ blockToolbarWrapper: 'h-[1.3em]',
54
+ gutterLeft: 'px-0 pb-1 text-[1.875em]',
55
+ },
56
+ },
57
+ key: HEADING_KEYS.h1,
58
+ },
59
+ {
60
+ draggableProps: {
61
+ classNames: {
62
+ blockToolbarWrapper: 'h-[1.3em]',
63
+ gutterLeft: 'px-0 pb-1 text-[1.5em]',
64
+ },
65
+ },
66
+ key: HEADING_KEYS.h2,
67
+ },
68
+ {
69
+ draggableProps: {
70
+ classNames: {
71
+ blockToolbarWrapper: 'h-[1.3em]',
72
+ gutterLeft: 'pt-[2px] px-0 pb-1 text-[1.25em]',
73
+ },
74
+ },
75
+ key: HEADING_KEYS.h3,
76
+ },
77
+ {
78
+ draggableProps: {
79
+ classNames: {
80
+ blockToolbarWrapper: 'h-[1.3em]',
81
+ gutterLeft: 'pt-[3px] px-0 pb-0 text-[1.1em]',
82
+ },
83
+ },
84
+ keys: [HEADING_KEYS.h4, HEADING_KEYS.h5],
85
+ },
86
+ {
87
+ draggableProps: {
88
+ classNames: {
89
+ gutterLeft: 'pt-[3px] px-0 pb-0',
90
+ },
91
+ },
92
+ keys: [ParagraphPlugin.key],
93
+ },
94
+ {
95
+ draggableProps: {
96
+ classNames: {
97
+ gutterLeft: 'px-0 pb-0',
98
+ },
99
+ },
100
+ keys: [HEADING_KEYS.h6, BulletedListPlugin.key, NumberedListPlugin.key],
101
+ },
102
+ {
103
+ draggableProps: {
104
+ classNames: {
105
+ gutterLeft: 'px-0 pb-0',
106
+ },
107
+ },
108
+ key: BlockquotePlugin.key,
109
+ },
110
+ {
111
+ draggableProps: {
112
+ classNames: {
113
+ gutterLeft: 'pt-6 px-0 pb-0',
114
+ },
115
+ },
116
+ key: CodeBlockPlugin.key,
117
+ },
118
+ {
119
+ draggableProps: {
120
+ classNames: {
121
+ gutterLeft: 'pt-0 px-0 pb-0',
122
+ },
123
+ },
124
+ key: ImagePlugin.key,
125
+ },
126
+ {
127
+ draggableProps: {
128
+ classNames: {
129
+ gutterLeft: 'pt-0 px-0 pb-0',
130
+ },
131
+ },
132
+ key: MediaEmbedPlugin.key,
133
+ },
134
+ {
135
+ draggableProps: {
136
+ classNames: {
137
+ gutterLeft: 'pt-0 px-0 pb-0',
138
+ },
139
+ },
140
+ key: ExcalidrawPlugin.key,
141
+ },
142
+ {
143
+ draggableProps: {
144
+ classNames: {
145
+ gutterLeft: 'pt-0 px-0 pb-0',
146
+ },
147
+ },
148
+ key: TogglePlugin.key,
149
+ },
150
+ {
151
+ draggableProps: {
152
+ classNames: {
153
+ gutterLeft: 'pt-0 px-0 pb-0',
154
+ },
155
+ },
156
+ key: ColumnPlugin.key,
157
+ },
158
+ {
159
+ draggableProps: {
160
+ classNames: {
161
+ gutterLeft: 'pt-3 px-0 pb-0',
162
+ },
163
+ },
164
+ key: PlaceholderPlugin.key,
165
+ },
166
+ {
167
+ draggableProps: {
168
+ classNames: {
169
+ gutterLeft: 'pt-3 px-0 pb-0',
170
+ },
171
+ },
172
+ key: TablePlugin.key,
173
+ },
174
+ ]);
175
+ };
@@ -0,0 +1,287 @@
1
+ import React, { useState, useMemo, useEffect } from "react";
2
+ import { uid } from "uid";
3
+ import { Image, Checkbox, Pagination } from "antd";
4
+
5
+ import { CaretRightOutlined, CaretDownOutlined } from "@ant-design/icons";
6
+ import { createPlateEditor, Plate } from "@udecode/plate-common/react";
7
+ import { deserializeMd } from "@udecode/plate-markdown";
8
+
9
+ import { displayerEditor } from "./Editor/plugins/displayer.ts";
10
+ import { validateAndFixNodes } from "./Editor/ChatViewEditor";
11
+ import { isMarkdownTableData, tableValue } from "./Editor/ui/tableValue";
12
+ import { Editor } from "./Editor";
13
+
14
+ import ImageGroupView from "./ImageGroupView";
15
+
16
+ import xls from "../assets/xls.png";
17
+ import txt from "../assets/txt.png";
18
+ import doc from "../assets/doc.png";
19
+ import pdf from "../assets/pdf.png";
20
+ import ppt from "../assets/ppt.png";
21
+ import "../style.less";
22
+
23
+ export const FILEIMG: any = {
24
+ docx: doc,
25
+ doc: doc,
26
+ pdf: pdf,
27
+ xls: xls,
28
+ xlsx: xls,
29
+ ppt: ppt,
30
+ pptx: ppt,
31
+ pub: ppt,
32
+ txt: txt
33
+ };
34
+ interface FileListProps {
35
+ selectFile: string;
36
+ selectBlock: string;
37
+ fileList: Array<any>;
38
+ selectFileHandler: (fileId: string) => void;
39
+ selectBlockHandler: (blockId: string) => void;
40
+ }
41
+ const pageSize = 10;
42
+ const FileListNew: React.FC<FileListProps> = ({
43
+ fileList,
44
+ selectFile,
45
+ selectBlock,
46
+ selectFileHandler,
47
+ selectBlockHandler
48
+ }) => {
49
+ const [isOpenList, setIsOpenList] = useState<boolean>(false);
50
+ const [checkedFileList, setCheckedFileList] = useState<Array<string>>([]);
51
+ const [pageNo, setPageNo] = useState<number>(1);
52
+ const [total, setTotal] = useState<number>(0);
53
+
54
+ const totalChunkList = useMemo(() => {
55
+ if (fileList && fileList.length) {
56
+ setCheckedFileList(fileList.map((i: any) => i.url));
57
+
58
+ const list = fileList.map((i: any) => {
59
+ const { fileExtension, fileName, list, url } = i;
60
+ return (list || []).map((l: any) =>
61
+ Object.assign({}, l, {
62
+ fileExtension,
63
+ fileName,
64
+ url
65
+ })
66
+ );
67
+ });
68
+ console.log("list:", list);
69
+ return [...list.flat(Infinity)];
70
+ }
71
+ return [];
72
+ }, [fileList]);
73
+
74
+ const chundList = useMemo(() => {
75
+ const list = totalChunkList.filter((i: any) =>
76
+ checkedFileList.includes(i.url)
77
+ );
78
+ if (list.length) {
79
+ setTotal(list.length);
80
+ let _pageNo = pageNo;
81
+ if (_pageNo > 1 && (_pageNo - 1) * pageSize > list.length) {
82
+ _pageNo = 1;
83
+ }
84
+ const curList = list.slice(pageSize * (_pageNo - 1), _pageNo * pageSize);
85
+ return curList.length ? [...curList] : [];
86
+ }
87
+ return [];
88
+ }, [totalChunkList, pageNo, checkedFileList]);
89
+
90
+ const selectThisFile = (fileId: string) => () => {
91
+ if (selectFile !== fileId) {
92
+ selectFileHandler(fileId);
93
+ }
94
+ };
95
+
96
+ const selectThisBlock = (fileId: string, blockId: string) => () => {
97
+ if (selectBlock !== blockId) {
98
+ fileId !== selectFile && selectFileHandler(fileId);
99
+ selectBlockHandler(blockId);
100
+ }
101
+ };
102
+ const changeOpenSta = () => {
103
+ setIsOpenList(!isOpenList);
104
+ };
105
+
106
+ const checkedFileListOnChange = (url: string) => (e: any) => {
107
+ const _checkedFileList = [...checkedFileList];
108
+ if (e.target.checked) {
109
+ setCheckedFileList(Array.from(new Set([..._checkedFileList, url])));
110
+ } else {
111
+ setCheckedFileList(_checkedFileList.filter((i) => i !== url));
112
+ }
113
+ };
114
+
115
+ const pageNoOnChangeHandler = (pageNo: number) => {
116
+ setPageNo(pageNo);
117
+ };
118
+
119
+ const traverseTree = (tree: any[]) => {
120
+ function traverseTreeNode(node: any) {
121
+ if (node.children && node.children.length > 0) {
122
+ node.children.forEach((child: any, index: any) => {
123
+ if (child.text) {
124
+ if (isMarkdownTableData(child.text)) {
125
+ node.children[index] = tableValue(node.children[0].text)[0];
126
+ }
127
+ }
128
+ traverseTreeNode(child); // 递归遍历子节点
129
+ });
130
+ }
131
+ }
132
+
133
+ // 从根节点开始遍历整个树
134
+ tree.forEach((node, index) => {
135
+ traverseTreeNode(node);
136
+ });
137
+ };
138
+
139
+ const WithPlate = ({ id, data, className = "", type }: any) => {
140
+ const tempEditor = createPlateEditor({
141
+ plugins: [...displayerEditor({}).plugins]
142
+ });
143
+
144
+ let deserializedData = deserializeMd(tempEditor, data || "");
145
+ if (type === "table") {
146
+ deserializedData = validateAndFixNodes(deserializedData);
147
+ traverseTree(deserializedData);
148
+ }
149
+
150
+ const editor = createPlateEditor({
151
+ ...displayerEditor({}),
152
+ id: id,
153
+ shouldNormalizeEditor: true,
154
+ value: deserializedData
155
+ });
156
+
157
+ return (
158
+ <Plate editor={editor}>
159
+ <Editor readOnly className={className} />
160
+ </Plate>
161
+ );
162
+ };
163
+
164
+ return (
165
+ <div className="refrence-list-wrap text-[#2a2a2a] text-sm">
166
+ <div className="bg-white rounded-lg mb-3 overflow-hidden select-none">
167
+ <div
168
+ className={`px-5 py-3 min-h-8 flex list-title-wrap justify-between ${isOpenList ? "open-list" : ""}`}
169
+ >
170
+ <div className="text-[#2a2a2a]">
171
+ 已筛选:<span className="mx-1">{checkedFileList.length}</span>个文件
172
+ </div>
173
+ <div
174
+ className={`${isOpenList ? "open-btn" : "close-btn"} opener-btn`}
175
+ >
176
+ <span onClick={changeOpenSta}>
177
+ {isOpenList ? "收起" : "展开"}
178
+ {isOpenList ? <CaretDownOutlined /> : <CaretRightOutlined />}
179
+ </span>
180
+ </div>
181
+ </div>
182
+ {isOpenList ? (
183
+ <div className="list-wrap px-5 py-4">
184
+ {fileList.length === 0 ? (
185
+ <div className="text-center text-[#555] text-xs">暂无文件</div>
186
+ ) : (
187
+ (fileList || []).map((i: any, idx: number) => {
188
+ const { fileExtension, fileName, list, url } = i;
189
+ return (
190
+ <div key={`file-name-row-${idx}`}>
191
+ <Checkbox
192
+ onChange={checkedFileListOnChange(url)}
193
+ checked={checkedFileList.includes(url)}
194
+ >
195
+ <div className="text-ellipsis break-words line-clamp-1 overflow-hidden">
196
+ {fileName}.{fileExtension}
197
+ </div>
198
+ </Checkbox>
199
+ </div>
200
+ );
201
+ })
202
+ )}
203
+ </div>
204
+ ) : null}
205
+ </div>
206
+ {(chundList || []).map((i: any) => {
207
+ const {
208
+ fileExtension,
209
+ fileName,
210
+ url,
211
+ page_content,
212
+ id,
213
+ pic_url_list,
214
+ metadata
215
+ } = i;
216
+ const { chunk_type, image_path } = metadata;
217
+ return (
218
+ <div
219
+ key={`chunk-row-${id}`}
220
+ className={`rounded-lg bg-white mb-3 overflow-hidden text-sm chunk-wrap ${selectBlock === id ? "select-chunk" : ""}`}
221
+ >
222
+ <div
223
+ className="px-5 py-4 chatView"
224
+ style={{ borderBottom: "1px solid #EFF5FF" }}
225
+ onClick={selectThisBlock(url, id)}
226
+ >
227
+ {chunk_type === "text" ? (
228
+ <span>{page_content}</span>
229
+ ) : (
230
+ <div className={`${image_path ? "flex" : ""}`}>
231
+ {image_path ? (
232
+ <Image
233
+ src={image_path}
234
+ className="object-contain max-w-[126px] max-h-[126px]"
235
+ />
236
+ ) : null}
237
+
238
+ <div
239
+ className={`text-sm ${image_path ? "w-[calc(100%-150px)] ml-[10px]" : ""}`}
240
+ >
241
+ <WithPlate
242
+ id={uid(32)}
243
+ className="px-0 py-0 text-[14px] text-[#2a2a2a] overflow-x-hidden bg-transparent"
244
+ data={page_content}
245
+ type={chunk_type}
246
+ />
247
+ </div>
248
+ {pic_url_list && pic_url_list.length ? (
249
+ <div className="flex flex-wrap mt-[10px]">
250
+ <ImageGroupView imageList={pic_url_list} />
251
+ </div>
252
+ ) : null}
253
+ </div>
254
+ )}
255
+ </div>
256
+ <div className="relative pl-11 pt-3 pr-5 pb-4 text-xs text-[#555] bg-[#fafcff]">
257
+ <img
258
+ src={FILEIMG[fileExtension] || FILEIMG["doc"]}
259
+ width={16}
260
+ height={16}
261
+ className="absolute left-5 top-[10px]"
262
+ />
263
+ <div
264
+ className={`text-ellipsis break-words line-clamp-1 overflow-hidden file-name-link ${selectFile === url ? "select-file" : ""}`}
265
+ onClick={selectThisFile(url)}
266
+ >
267
+ {fileName}.{fileExtension}
268
+ </div>
269
+ </div>
270
+ </div>
271
+ );
272
+ })}
273
+ {chundList.length ? (
274
+ <div className="bg-white px-5 py-4 mb-1 rounded-lg overflow-hidden">
275
+ <Pagination
276
+ defaultCurrent={pageNo}
277
+ total={total}
278
+ pageSize={pageSize}
279
+ align="end"
280
+ onChange={pageNoOnChangeHandler}
281
+ />
282
+ </div>
283
+ ) : null}
284
+ </div>
285
+ );
286
+ };
287
+ export default FileListNew;
@@ -0,0 +1,85 @@
1
+ import { Space, Image } from "antd";
2
+ import { useState } from "react";
3
+ import {
4
+ DownloadOutlined,
5
+ LeftOutlined,
6
+ RightOutlined,
7
+ RotateLeftOutlined,
8
+ RotateRightOutlined,
9
+ SwapOutlined,
10
+ UndoOutlined,
11
+ ZoomInOutlined,
12
+ ZoomOutOutlined
13
+ } from "@ant-design/icons";
14
+ import { dealMinioUrl } from "../../utils.ts";
15
+
16
+ const ImageGroupView = ({ imageList, h }: any) => {
17
+ const [current, setCurrent] = useState(0);
18
+
19
+ const onDownload = () => {
20
+ const url = imageList[current];
21
+ const suffix = url.slice(url.lastIndexOf("."));
22
+ const filename = Date.now() + suffix;
23
+ fetch(url)
24
+ .then((response) => response.blob())
25
+ .then((blob) => {
26
+ const blobUrl = URL.createObjectURL(new Blob([blob]));
27
+ const link = document.createElement("a");
28
+ link.href = blobUrl;
29
+ link.download = filename;
30
+ document.body.appendChild(link);
31
+ link.click();
32
+ URL.revokeObjectURL(blobUrl);
33
+ link.remove();
34
+ });
35
+ };
36
+ return (
37
+ <Image.PreviewGroup
38
+ preview={{
39
+ toolbarRender: (
40
+ _,
41
+ {
42
+ transform: { scale },
43
+ actions: {
44
+ onActive,
45
+ onFlipY,
46
+ onFlipX,
47
+ onRotateLeft,
48
+ onRotateRight,
49
+ onZoomOut,
50
+ onZoomIn,
51
+ onReset
52
+ }
53
+ }
54
+ ) => (
55
+ <Space size={12} className="toolbar-wrapper">
56
+ <LeftOutlined onClick={() => onActive?.(-1)} />
57
+ <RightOutlined onClick={() => onActive?.(1)} />
58
+ <DownloadOutlined onClick={onDownload} />
59
+ <SwapOutlined rotate={90} onClick={onFlipY} />
60
+ <SwapOutlined onClick={onFlipX} />
61
+ <RotateLeftOutlined onClick={onRotateLeft} />
62
+ <RotateRightOutlined onClick={onRotateRight} />
63
+ <ZoomOutOutlined disabled={scale === 1} onClick={onZoomOut} />
64
+ <ZoomInOutlined disabled={scale === 50} onClick={onZoomIn} />
65
+ <UndoOutlined onClick={onReset} />
66
+ </Space>
67
+ ),
68
+ onChange: (index) => {
69
+ setCurrent(index);
70
+ }
71
+ }}
72
+ >
73
+ {(imageList || []).map((item: any, index: number) => (
74
+ <Image
75
+ key={index}
76
+ src={dealMinioUrl(item)}
77
+ height={h || 60}
78
+ className="object-contain mr-[10px]"
79
+ />
80
+ ))}
81
+ </Image.PreviewGroup>
82
+ );
83
+ };
84
+
85
+ export default ImageGroupView;