@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,177 @@
1
+ import { useState, useEffect, useRef } from 'react';
2
+ import ResourceBinderItem from './ResourceBinderItem';
3
+ import SearchableSelector, { type SearchableSelectorRef } from './SearchableSelector';
4
+ import { Button, Modal } from 'antd';
5
+ import { Plus } from 'lucide-react';
6
+ import Icon from '../assets/graph.svg';
7
+ import AxiosInstance from '../server';
8
+
9
+ const GraphSection = ({ url, token, role, eventsEmit, sectionData }: any) => {
10
+ const [options, setOptions]: any = useState([]);
11
+ const [data, setData]: any = useState([]);
12
+ const [isModalShow, setIsModalShow] = useState(false);
13
+ const selectorRef = useRef<SearchableSelectorRef>(null);
14
+
15
+ const { fetchGraphs } = AxiosInstance({
16
+ url,
17
+ token,
18
+ role,
19
+ eventsEmit,
20
+ });
21
+
22
+ useEffect(() => {
23
+ getList();
24
+ }, []);
25
+
26
+ useEffect(() => {
27
+ if (sectionData) {
28
+ let _data = [] as any;
29
+ (sectionData || []).map((g: any) => {
30
+ const _targetGraph = (options || []).find((i: any) => i.key === g.index_name);
31
+ if (_targetGraph) {
32
+ const { key, label } = _targetGraph;
33
+ _data.push({
34
+ key,
35
+ label,
36
+ });
37
+ }
38
+ });
39
+ setData(_data);
40
+ }
41
+ }, [sectionData, options]);
42
+
43
+ const getList = async () => {
44
+ try {
45
+ const res = await fetchGraphs();
46
+ if (res?.dataList) {
47
+ const options = (res?.dataList || []).map((item: any) => {
48
+ return {
49
+ key: item.schemaId,
50
+ label: item.name,
51
+ };
52
+ });
53
+ setOptions(options);
54
+ }
55
+ } catch (e) {
56
+ console.error(e);
57
+ }
58
+ };
59
+
60
+ const handleEventsEmit = (name: string, eventsData?: any) => {
61
+ switch (name) {
62
+ case 'removeItem':
63
+ const _data = data.filter((p: any) => p.key !== eventsData.key);
64
+ setData([..._data]);
65
+ handleDatatoSubmit(_data);
66
+ break;
67
+ }
68
+ };
69
+
70
+ const handleDatatoSubmit = (selectedItems: any) => {
71
+ const graph_nb_name = (selectedItems || []).map((s: any) => {
72
+ return {
73
+ graph_name: s.label,
74
+ index_name: s.key,
75
+ };
76
+ });
77
+ eventsEmit && eventsEmit('graph_selected', graph_nb_name);
78
+ };
79
+
80
+ const handleOk = () => {
81
+ // 通过 ref 获取选中的项
82
+ const selectedItems = selectorRef.current?.getSelectedItems() || [];
83
+ setData(selectedItems);
84
+ setIsModalShow(false);
85
+ handleDatatoSubmit(selectedItems);
86
+ };
87
+
88
+ return (
89
+ <div style={{ borderBottom: '1px solid #E5E6EB', padding: '12px 0 ' }}>
90
+ <div className="flex items-center justify-between">
91
+ <div className="flex items-center">
92
+ <img src={Icon} />
93
+ <span
94
+ className="font-medium "
95
+ style={{
96
+ marginLeft: '10px',
97
+ }}
98
+ >
99
+ 图谱库
100
+ </span>
101
+ </div>
102
+
103
+ <div className="flex items-center gap-2">
104
+ <Button
105
+ color="primary"
106
+ variant="outlined"
107
+ size="small"
108
+ icon={<Plus size={14} />}
109
+ onClick={() => setIsModalShow(true)}
110
+ >
111
+ 添加
112
+ </Button>
113
+ </div>
114
+ </div>
115
+ {data?.length > 0 && (
116
+ <ResourceBinderItem
117
+ countText={data?.length > 0 ? `已选:${data?.length}个图谱` : undefined}
118
+ eventsEmit={handleEventsEmit}
119
+ data={data}
120
+ />
121
+ )}
122
+
123
+ <Modal
124
+ width={740}
125
+ title="选择图谱"
126
+ okText="确定"
127
+ cancelText="取消"
128
+ className="assistant-config-resource-bind-modal"
129
+ open={isModalShow}
130
+ onOk={handleOk}
131
+ destroyOnHidden
132
+ onCancel={() => setIsModalShow(false)}
133
+ >
134
+ <SearchableSelector
135
+ ref={selectorRef}
136
+ dataSource={options}
137
+ value={data}
138
+ searchPlaceholder="搜索名称..."
139
+ width="700px"
140
+ height="500px"
141
+ title="图谱"
142
+ renderItem={item => {
143
+ return (
144
+ <div className="flex ">
145
+ <img src={Icon} alt="add" />
146
+ <span
147
+ style={{
148
+ marginLeft: 8,
149
+ marginRight: 8,
150
+ overflow: 'hidden',
151
+ textOverflow: 'ellipsis',
152
+ whiteSpace: 'nowrap',
153
+ }}
154
+ title={item.label}
155
+ >
156
+ {item.label}
157
+ </span>
158
+ </div>
159
+ );
160
+ }}
161
+ renderSelectedItem={item => {
162
+ return (
163
+ <div className="flex items-center">
164
+ <img src={Icon} alt="add" />
165
+ <div style={{ marginLeft: '12px' }}>
166
+ <div style={{ fontWeight: 500 }}>{item.label}</div>
167
+ </div>
168
+ </div>
169
+ );
170
+ }}
171
+ />
172
+ </Modal>
173
+ </div>
174
+ );
175
+ };
176
+
177
+ export default GraphSection;
@@ -0,0 +1,276 @@
1
+ import React, { useState, useEffect, useRef, useMemo } from 'react';
2
+ import ResourceBinderItem from './ResourceBinderItem';
3
+ import SearchableSelector, { type SearchableSelectorRef } from './SearchableSelector';
4
+ import { Button, Modal, Select } from 'antd';
5
+ import { Plus } from 'lucide-react';
6
+ import Icon from '../assets/knowledge.svg';
7
+ import AxiosInstance from '../server';
8
+
9
+ const KnowledgeSection = ({ url, token, role, sectionData, createBy, eventsEmit }: any) => {
10
+ const [options, setOptions]: any = useState();
11
+ const [data, setData]: any = useState([]);
12
+ const [isModalShow, setIsModalShow] = useState(false);
13
+ const selectorRef = useRef<SearchableSelectorRef>(null);
14
+ const [loading, setLoading] = useState(false);
15
+ const [tagOptions, setTagOptions] = useState([]);
16
+ const tagIdMap = useRef(new Map()).current;
17
+ const { fetchKnowledgeBase, getBizLabelLabels } = AxiosInstance({
18
+ url,
19
+ token,
20
+ role,
21
+ eventsEmit,
22
+ });
23
+
24
+ const hasInitialized = useRef(false);
25
+
26
+ useEffect(() => {
27
+ // 如果已经初始化过,不再执行
28
+ if (hasInitialized.current) return;
29
+
30
+ if (createBy) {
31
+ getList(createBy);
32
+ hasInitialized.current = true;
33
+ } else {
34
+ getList();
35
+ hasInitialized.current = true;
36
+ }
37
+ }, [createBy]);
38
+
39
+ useEffect(() => {
40
+ if (sectionData && options?.length > 0) {
41
+ const kbNames = sectionData?.knowledge_base_name_source;
42
+ const kbNamesArr = kbNames && (Array.isArray(kbNames) ? kbNames : kbNames.split(';'));
43
+ let _list = [] as any;
44
+ (kbNamesArr || []).forEach((kb: string) => {
45
+ const selKb = (sectionData?.selectedKnowledgeBase || []).find((k: any) => k.name == kb);
46
+ const _targetKb = (options || []).find((i: any) => i.knowledge_base_name_source === kb);
47
+ if (_targetKb) {
48
+ const { key, label, knowledge_base_name, knowledge_base_name_source } = _targetKb;
49
+ _list.push({
50
+ key,
51
+ label,
52
+ knowledge_base_name, //初始名
53
+ knowledge_base_name_source, //展示名
54
+ tags: selKb?.labels,
55
+ });
56
+ }
57
+ });
58
+ setData(_list);
59
+ }
60
+ }, [sectionData, options]);
61
+
62
+ const getList = async (params?: any) => {
63
+ try {
64
+ const res = await fetchKnowledgeBase(params);
65
+ if (res) {
66
+ const options = (res || []).map((kb: any) => {
67
+ // 没错: knowledge_base_name_source是展示名, knowledge_base_name是初始名
68
+ return {
69
+ key: kb.id,
70
+ label: kb.kbName, //展示名
71
+ knowledge_base_name: kb.primitiveName, //初始名
72
+ knowledge_base_name_source: kb.kbName, //展示名
73
+ };
74
+ });
75
+ setOptions(options);
76
+ }
77
+ } catch (e) {
78
+ console.error(e);
79
+ }
80
+ };
81
+
82
+ const handleEventsEmit = (name: string, eventsData?: any) => {
83
+ switch (name) {
84
+ case 'removeItem':
85
+ const _data = data.filter((p: any) => p.key !== eventsData.key);
86
+ setData([..._data]);
87
+ handleDatatoSubmit(_data);
88
+ break;
89
+ case 'removeTag':
90
+ const index = data.findIndex((d: any) => d.key == eventsData.key);
91
+ if (index !== -1) {
92
+ // 替换元素
93
+ data[index] = eventsData;
94
+ }
95
+
96
+ setData([...data]);
97
+ handleDatatoSubmit(data);
98
+ break;
99
+ }
100
+ };
101
+
102
+ const handleDatatoSubmit = (selectedItems: any) => {
103
+ const knowledge_base_name = (selectedItems || [])
104
+ .map((s: any) => s?.knowledge_base_name || '')
105
+ .filter((key: string) => key)
106
+ .join(';');
107
+ const knowledge_base_name_source = (selectedItems || [])
108
+ .map((s: any) => s?.knowledge_base_name_source || '')
109
+ .filter((key: string) => key)
110
+ .join(';');
111
+ const selectedKnowledgeBase = (selectedItems || [])
112
+ .filter((s: any) => Array.isArray(s?.tags) && s.tags?.length > 0)
113
+ .map((s: any) => {
114
+ return {
115
+ id: s.key,
116
+ name: s.label,
117
+ knowledge_base_name_source: s.knowledge_base_name_source,
118
+ labels: s.tags,
119
+ };
120
+ });
121
+
122
+ eventsEmit &&
123
+ eventsEmit('knowledge_selected', {
124
+ knowledge_base_name,
125
+ knowledge_base_name_source,
126
+ selectedKnowledgeBase,
127
+ });
128
+ };
129
+
130
+ const handleOk = () => {
131
+ // 通过 ref 获取选中的项
132
+ const selectedItems = selectorRef.current?.getSelectedItems() || [];
133
+ setData(selectedItems);
134
+ setIsModalShow(false);
135
+ handleDatatoSubmit(selectedItems);
136
+ };
137
+
138
+ // 监听下拉框展开事件
139
+ const handleDropdownVisibleChange = async (open: boolean, targetId: number) => {
140
+ if (open) {
141
+ const o = tagIdMap.get(targetId);
142
+ if (o) {
143
+ setTagOptions(o);
144
+ return;
145
+ }
146
+ // 如果尚未加载过数据,则发起请求
147
+ if (!loading) {
148
+ try {
149
+ setLoading(true);
150
+ const res: any = await getBizLabelLabels({ kbNames: [targetId] });
151
+
152
+ if (Array.isArray(res)) {
153
+ const label = res.length ? res[0].label : '';
154
+ const labels = label
155
+ ? (label || '').split(',').map((item: any) => {
156
+ return { label: item, value: item };
157
+ })
158
+ : [];
159
+
160
+ tagIdMap.set(targetId, labels);
161
+ setTagOptions(labels);
162
+ }
163
+ setLoading(false);
164
+ } catch (error) {
165
+ console.error('Error fetching data:', error);
166
+ setLoading(false);
167
+ }
168
+ }
169
+ }
170
+ };
171
+
172
+ return (
173
+ <div style={{ borderBottom: '1px solid #E5E6EB', padding: '12px 0 ' }}>
174
+ <div className="flex items-center justify-between">
175
+ <div className="flex items-center">
176
+ <img src={Icon} />
177
+ <span
178
+ className="font-medium "
179
+ style={{
180
+ marginLeft: '10px',
181
+ }}
182
+ >
183
+ 知识库
184
+ </span>
185
+ </div>
186
+
187
+ <div className="flex items-center gap-2">
188
+ <Button
189
+ color="primary"
190
+ variant="outlined"
191
+ size="small"
192
+ icon={<Plus size={14} />}
193
+ onClick={() => setIsModalShow(true)}
194
+ >
195
+ 添加
196
+ </Button>
197
+ </div>
198
+ </div>
199
+ {data?.length > 0 && (
200
+ <ResourceBinderItem
201
+ countText={data?.length > 0 ? `已选:${data?.length}个知识库` : undefined}
202
+ eventsEmit={handleEventsEmit}
203
+ data={data}
204
+ />
205
+ )}
206
+
207
+ <Modal
208
+ width={740}
209
+ className="assistant-config-resource-bind-modal"
210
+ title="选择知识库"
211
+ okText="确定"
212
+ cancelText="取消"
213
+ open={isModalShow}
214
+ onOk={handleOk}
215
+ onCancel={() => setIsModalShow(false)}
216
+ destroyOnHidden
217
+ >
218
+ <SearchableSelector
219
+ ref={selectorRef}
220
+ dataSource={options}
221
+ value={data}
222
+ searchPlaceholder="搜索名称..."
223
+ width="700px"
224
+ height="500px"
225
+ title="知识库"
226
+ renderItem={item => {
227
+ return (
228
+ <div className="flex ">
229
+ <img src={Icon} alt="add" />
230
+ <span
231
+ style={{
232
+ marginLeft: 8,
233
+ marginRight: 8,
234
+ overflow: 'hidden',
235
+ textOverflow: 'ellipsis',
236
+ whiteSpace: 'nowrap',
237
+ }}
238
+ title={item.label}
239
+ >
240
+ {item.label}
241
+ </span>
242
+ </div>
243
+ );
244
+ }}
245
+ renderSelectedItem={(item, updateItemData) => {
246
+ return (
247
+ <div className="flex ">
248
+ <img src={Icon} alt="add" />
249
+ <div style={{ marginLeft: '12px' }}>
250
+ <div style={{ marginBottom: '8px', fontWeight: 500 }}>{item.label}</div>
251
+ <Select
252
+ mode="tags"
253
+ placeholder="选择标签..."
254
+ maxTagCount={1}
255
+ value={item.tags || []}
256
+ onChange={tags => {
257
+ updateItemData(tags);
258
+ }}
259
+ style={{ width: 250 }}
260
+ options={tagOptions}
261
+ loading={loading}
262
+ onOpenChange={(open: boolean) => {
263
+ handleDropdownVisibleChange(open, item.knowledge_base_name);
264
+ }}
265
+ />
266
+ </div>
267
+ </div>
268
+ );
269
+ }}
270
+ />
271
+ </Modal>
272
+ </div>
273
+ );
274
+ };
275
+
276
+ export default React.memo(KnowledgeSection);
@@ -0,0 +1,21 @@
1
+ const NotFoundContent = () => {
2
+ return (
3
+ <div className="w-full h-[80px] rounded-md flex flex-col justify-center items-center">
4
+ <svg width="64" height="41" viewBox="0 0 64 41" xmlns="http://www.w3.org/2000/svg">
5
+ <g transform="translate(0 1)" fill="none" fill-rule="evenodd">
6
+ <ellipse fill="#f5f5f5" cx="32" cy="33" rx="32" ry="7"></ellipse>
7
+ <g fill-rule="nonzero" stroke="#d9d9d9">
8
+ <path d="M55 12.76L44.854 1.258C44.367.474 43.656 0 42.907 0H21.093c-.749 0-1.46.474-1.947 1.257L9 12.761V22h46v-9.24z"></path>
9
+ <path
10
+ d="M41.613 15.931c0-1.605.994-2.93 2.227-2.931H55v18.137C55 33.26 53.68 35 52.05 35h-40.1C10.32 35 9 33.259 9 31.137V13h11.16c1.233 0 2.227 1.323 2.227 2.928v.022c0 1.605 1.005 2.901 2.237 2.901h14.752c1.232 0 2.237-1.308 2.237-2.913v-.007z"
11
+ fill="#fafafa"
12
+ ></path>
13
+ </g>
14
+ </g>
15
+ </svg>
16
+ <div>暂无可用模型</div>
17
+ </div>
18
+ );
19
+ };
20
+
21
+ export default NotFoundContent;
@@ -0,0 +1,51 @@
1
+ import { useState, type PropsWithChildren } from 'react';
2
+ import { ChevronUp, ChevronDown } from 'lucide-react';
3
+ type ParagraphTitleProps = {
4
+ title: string;
5
+ defaultExpanded?: boolean;
6
+ className?: string;
7
+ };
8
+
9
+ const ParagraphTitle = ({
10
+ title,
11
+ defaultExpanded = true,
12
+ className,
13
+ children,
14
+ }: PropsWithChildren<ParagraphTitleProps>) => {
15
+ const [expanded, setExpanded] = useState<boolean>(defaultExpanded);
16
+
17
+ return (
18
+ <div className={className}>
19
+ <div className="flex items-center justify-between" style={{ marginBottom: '10px' }}>
20
+ <div className="flex items-center">
21
+ <div
22
+ style={{
23
+ width: '3px',
24
+ height: '12px',
25
+ backgroundColor: '#4E6EF2',
26
+ borderRadius: '6px',
27
+ marginRight: '6px',
28
+ }}
29
+ ></div>
30
+ <div className="font-bold">{title}</div>
31
+ </div>
32
+ {expanded ? (
33
+ <ChevronUp onClick={() => setExpanded(v => !v)} color="#4E6EF2" size={18} />
34
+ ) : (
35
+ <ChevronDown onClick={() => setExpanded(v => !v)} color="#4E5969" size={18} />
36
+ )}
37
+ </div>
38
+ {children ? (
39
+ <div
40
+ style={{
41
+ display: expanded ? 'block' : 'none',
42
+ }}
43
+ >
44
+ {children}
45
+ </div>
46
+ ) : null}
47
+ </div>
48
+ );
49
+ };
50
+
51
+ export default ParagraphTitle;
@@ -0,0 +1,39 @@
1
+ import { Form, Col } from 'antd';
2
+ import { useMemo } from 'react';
3
+ import SliderInput from './SliderInput';
4
+ const { Item } = Form;
5
+
6
+ const ParamsItem = ({ label, name, configScale }: any) => {
7
+ const config = useMemo(() => {
8
+ return configScale[name];
9
+ }, [configScale]);
10
+
11
+ const validateNumber = (min: number, max: number) => ({
12
+ validator(_: any, value: any) {
13
+ // 自定义验证逻辑
14
+ if (value === null || value === undefined) {
15
+ return Promise.reject('请输入有效数字');
16
+ }
17
+ if (typeof +value !== 'number' || isNaN(+value)) {
18
+ return Promise.reject('只能输入数字');
19
+ }
20
+ if (value < min || value > max) {
21
+ return Promise.reject(`请输入${min}到${max}之间的数字`);
22
+ }
23
+ return Promise.resolve();
24
+ },
25
+ });
26
+ return (
27
+ <Col span={12}>
28
+ <Item
29
+ label={label}
30
+ name={name}
31
+ tooltip={config.tooltip}
32
+ rules={[{ required: true, message: '' }, validateNumber(config.min, config.max)]}
33
+ >
34
+ <SliderInput min={config.min} max={config.max} step={config.step} />
35
+ </Item>
36
+ </Col>
37
+ );
38
+ };
39
+ export default ParamsItem;
@@ -0,0 +1,133 @@
1
+ import { useState } from 'react';
2
+ import { Tag, Button } from 'antd';
3
+ import { ChevronUp, ChevronDown, CircleX, X } from 'lucide-react';
4
+
5
+ interface Items {
6
+ key: string;
7
+ label: string;
8
+ tags?: string[];
9
+ }
10
+
11
+ const ResourceBinderItem = ({
12
+ countText,
13
+ eventsEmit,
14
+ data,
15
+ }: {
16
+ countText?: string;
17
+ eventsEmit: (name: string, data?: any) => void;
18
+ data: Items[];
19
+ }) => {
20
+ const [expanded, setExpanded] = useState(true);
21
+ return (
22
+ <div
23
+ style={{
24
+ marginTop: 8,
25
+ }}
26
+ >
27
+ {countText && (
28
+ <div className="flex items-center gap-2">
29
+ <span style={{ color: expanded ? '#4E6EF2' : '#4E5969' }}>{countText}</span>
30
+ {expanded ? (
31
+ <ChevronUp onClick={() => setExpanded(v => !v)} color="#4E6EF2" size={14} />
32
+ ) : (
33
+ <ChevronDown onClick={() => setExpanded(v => !v)} color="#4E5969" size={14} />
34
+ )}
35
+ </div>
36
+ )}
37
+
38
+ <div
39
+ style={{
40
+ display: expanded ? 'block' : 'none',
41
+ }}
42
+ >
43
+ {data.map(item => (
44
+ <BindTagItem key={item.key} item={item} eventsEmit={eventsEmit} />
45
+ ))}
46
+ </div>
47
+ </div>
48
+ );
49
+ };
50
+
51
+ const BindTagItem = ({ item, eventsEmit }: any) => {
52
+ const [expanded, setExpanded] = useState(true);
53
+
54
+ return (
55
+ <div
56
+ key={item.key}
57
+ className="flex items-center justify-between"
58
+ style={{ padding: '8px 12px', borderRadius: 6 }}
59
+ >
60
+ <div>
61
+ <div style={{ color: '#1D2129' }} className="flex items-center">
62
+ {item.label}
63
+ {item?.tags?.length > 0 && (
64
+ <>
65
+ <span
66
+ style={{
67
+ color: '#4E5969',
68
+ marginLeft: '6px',
69
+ marginRight: 6,
70
+ }}
71
+ >
72
+ ({item?.tags?.length}个标签)
73
+ </span>
74
+ {expanded ? (
75
+ <ChevronUp onClick={() => setExpanded(v => !v)} color="#4E6EF2" size={14} />
76
+ ) : (
77
+ <ChevronDown onClick={() => setExpanded(v => !v)} color="#4E5969" size={14} />
78
+ )}
79
+ </>
80
+ )}
81
+ </div>
82
+
83
+ {item?.tags?.length > 0 && (
84
+ <div
85
+ className="flex flex-wrap gap-4"
86
+ style={{
87
+ display: expanded ? 'block' : 'none',
88
+ marginTop: 8,
89
+ }}
90
+ >
91
+ {(item?.tags || []).map((tag: string) => (
92
+ <Button
93
+ key={tag}
94
+ iconPosition="end"
95
+ type="text"
96
+ style={{
97
+ backgroundColor: '#F0F0F0',
98
+ padding: '2px 6px',
99
+ height: 22,
100
+ borderRadius: 2,
101
+ color: '#1D2129',
102
+ margin: 5,
103
+ }}
104
+ icon={
105
+ <X
106
+ size={14}
107
+ color="#86909C"
108
+ onClick={() => {
109
+ const newItem = {
110
+ ...item,
111
+ tags: item.tags.filter((t: any) => t !== tag),
112
+ };
113
+ eventsEmit(`removeTag`, newItem);
114
+ }}
115
+ />
116
+ }
117
+ >
118
+ {tag}
119
+ </Button>
120
+ ))}
121
+ </div>
122
+ )}
123
+ </div>
124
+ <Button
125
+ type="text"
126
+ icon={<CircleX size={14} />}
127
+ onClick={() => eventsEmit(`removeItem`, item)}
128
+ ></Button>
129
+ </div>
130
+ );
131
+ };
132
+
133
+ export default ResourceBinderItem;