@gientech/modual 1.2.7 → 1.2.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 (312) hide show
  1. package/.editorconfig +38 -0
  2. package/.prettierignore +16 -0
  3. package/.prettierrc +17 -0
  4. package/README.md +129 -129
  5. package/USAGE.md +191 -0
  6. package/bash.exe.stackdump +40 -0
  7. package/components.json +21 -0
  8. package/dist/README.md +129 -0
  9. package/dist/assets/circle-alert-g2Y6zAjt.js +6 -0
  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}/defaultWeLogo.svg +14 -14
  15. package/dist/assets/index-97TKgPKE.js +1284 -0
  16. package/dist/assets/index-CEK88UzR.js +26 -0
  17. package/dist/assets/index-DIm7RgkM.js +1709 -0
  18. package/{assets/MySQL.svg → dist/assets/mysql.svg} +14 -14
  19. package/{assets/plus-fNg4vmeA.js → dist/assets/plus-omCUN0e3.js} +1 -1
  20. package/dist/assets/style.css +1 -0
  21. package/dist/assets/style3.css +1 -0
  22. package/{assets/x-tMUaBf0a.js → dist/assets/x-vPcWt3fC.js} +1 -1
  23. package/dist/chat.js +648 -0
  24. package/dist/database.js +20 -0
  25. package/dist/databaseId.js +11 -0
  26. package/{databaseTable.js → dist/databaseTable.js} +2 -2
  27. package/dist/modelManage.js +1 -0
  28. package/dist/package.json +56 -0
  29. package/dist/sensitive.js +1 -0
  30. package/{streamFilesReader.js → dist/streamFilesReader.js} +16 -16
  31. package/{worker → dist/worker}/pdf.worker.min.js +21 -21
  32. package/doc_assets/2.png +0 -0
  33. package/doc_assets/demo.md +27 -0
  34. package/doc_assets/demos/dist-app/assets/index.Dh-ZAS9Z.css +2 -0
  35. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js +23699 -0
  36. package/doc_assets/demos/dist-app/assets/index.Dv8KVW18.js.map +1 -0
  37. package/doc_assets/demos/dist-app/index.html +14 -0
  38. package/doc_assets/demos/dist-app/vite.svg +1 -0
  39. package/doc_assets/images/1.png +0 -0
  40. package/doc_assets/images/3.png +0 -0
  41. package/doc_assets/images/component-screenshot.png +1 -0
  42. package/doc_assets/install.md +5 -0
  43. package/eslint.config.js +92 -0
  44. package/index.html +13 -0
  45. package/package.json +99 -56
  46. package/postcss.config.cjs +19 -0
  47. package/public/vite.svg +1 -0
  48. package/public/worker/pdf.worker.min.js +22 -0
  49. package/scripts/README.md +133 -0
  50. package/scripts/build-demo.js +88 -0
  51. package/scripts/demo-selector.js +216 -0
  52. package/scripts/dev-demo.js +76 -0
  53. package/scripts/preview-demo.js +130 -0
  54. package/scripts/run-demo.bat +34 -0
  55. package/src/assets/img/downArrow.png +0 -0
  56. package/src/assets/img/excel.png +0 -0
  57. package/src/assets/img/img.png +0 -0
  58. package/src/assets/img/pdf.png +0 -0
  59. package/src/assets/img/ppt.png +0 -0
  60. package/src/assets/img/txt.png +0 -0
  61. package/src/assets/img/word.png +0 -0
  62. package/src/assets/login/homeBg.png +0 -0
  63. package/src/assets/login/left.jpg +0 -0
  64. package/src/assets/login/logoImg.png +0 -0
  65. package/src/examples/LoginPage/index.tsx +18 -0
  66. package/src/examples/chat/index.tsx +140 -0
  67. package/src/examples/gientechStreamFilesReader/index.tsx +1016 -0
  68. package/src/examples/ragDatabaseDataPage/index.tsx +36 -0
  69. package/src/examples/ragDatabaseIdPage/index.tsx +44 -0
  70. package/src/examples/ragDatabasePage/index.tsx +36 -0
  71. package/src/examples/ragModelManagePage/index.tsx +37 -0
  72. package/src/examples/ragSearchPage/index.tsx +0 -0
  73. package/src/examples/ragSensitiveWordsPage/index.tsx +32 -0
  74. package/src/examples/streamFiles/index.tsx +384 -0
  75. package/src/lib_enter.ts +38 -0
  76. package/src/main.tsx +5 -0
  77. package/src/main.tsx.backup +5 -0
  78. package/src/modules/chat/Conversations/Item.tsx +167 -0
  79. package/src/modules/chat/Conversations/List.tsx +143 -0
  80. package/src/modules/chat/Conversations/groupByTime.ts +39 -0
  81. package/src/modules/chat/Conversations/index.tsx +212 -0
  82. package/src/modules/chat/constants.tsx +33 -0
  83. package/src/modules/chat/index.tsx +1837 -0
  84. package/src/modules/chat/types.ts +17 -0
  85. package/src/modules/database/CreateModal.tsx +398 -0
  86. package/src/modules/database/assets/Doris.png +0 -0
  87. package/src/modules/database/assets/PostgreSQL.png +0 -0
  88. package/src/modules/database/assets/SQLServer.png +0 -0
  89. package/src/modules/database/assets/database.svg +11 -0
  90. package/src/modules/database/assets/database_add.svg +53 -0
  91. package/src/modules/database/assets/database_connect.svg +66 -0
  92. package/src/modules/database/assets/database_upload.svg +29 -0
  93. package/src/modules/database/assets/empty.png +0 -0
  94. package/src/modules/database/assets/mysql.svg +14 -0
  95. package/src/modules/database/index.tsx +466 -0
  96. package/src/modules/database/server.ts +196 -0
  97. package/src/modules/databaseId/CustomCom.tsx +156 -0
  98. package/src/modules/databaseId/EditConfig.tsx +268 -0
  99. package/src/modules/databaseId/UploadDrawer.tsx +520 -0
  100. package/src/modules/databaseId/assets/aiOptimize.svg +10 -0
  101. package/src/modules/databaseId/assets/empty.png +0 -0
  102. package/src/modules/databaseId/assets/template.svg +6 -0
  103. package/src/modules/databaseId/assets/upload.svg +9 -0
  104. package/src/modules/databaseId/assets/useTemp.svg +6 -0
  105. package/src/modules/databaseId/index.tsx +734 -0
  106. package/src/modules/databaseId/server.ts +286 -0
  107. package/src/modules/databaseId/style.css +5 -0
  108. package/src/modules/databaseTable/EditRowDrawer.tsx +119 -0
  109. package/src/modules/databaseTable/index.tsx +357 -0
  110. package/src/modules/databaseTable/server.ts +180 -0
  111. package/src/modules/headlessChat/constants.tsx +32 -0
  112. package/src/modules/headlessChat/index.tsx +1065 -0
  113. package/src/modules/headlessChat/types.ts +23 -0
  114. package/src/modules/login/components/Login/LoginBox/index.tsx +102 -0
  115. package/src/modules/login/components/Login/RegisterBox/index.tsx +180 -0
  116. package/src/modules/login/components/Login/index.tsx +100 -0
  117. package/src/modules/login/index.tsx +106 -0
  118. package/src/modules/login/style.css +3 -0
  119. package/src/modules/login/useServices.ts +53 -0
  120. package/src/modules/login/utils.ts +42 -0
  121. package/src/modules/modelManage/ConfigDrawer.tsx +249 -0
  122. package/src/modules/modelManage/assets/empty.png +0 -0
  123. package/src/modules/modelManage/const.ts +50 -0
  124. package/src/modules/modelManage/index.tsx +439 -0
  125. package/src/modules/modelManage/server.ts +185 -0
  126. package/src/modules/search/assets/Icon-history.svg +8 -0
  127. package/src/modules/search/assets/answerAwartar.png +0 -0
  128. package/src/modules/search/assets/doc.png +0 -0
  129. package/src/modules/search/assets/genera.gif +0 -0
  130. package/src/modules/search/assets/icon-robot.svg +9 -0
  131. package/src/modules/search/assets/icon-search-bar.svg +14 -0
  132. package/src/modules/search/assets/icon-sub-title.svg +3 -0
  133. package/src/modules/search/assets/icon-title.svg +9 -0
  134. package/src/modules/search/assets/icon-zoomOut.svg +9 -0
  135. package/src/modules/search/assets/iconAi.svg +9 -0
  136. package/src/modules/search/assets/pdf.png +0 -0
  137. package/src/modules/search/assets/ppt.png +0 -0
  138. package/src/modules/search/assets/search.svg +3 -0
  139. package/src/modules/search/assets/selected.svg +4 -0
  140. package/src/modules/search/assets/txt.png +0 -0
  141. package/src/modules/search/assets/xls.png +0 -0
  142. package/src/modules/search/components/AssisSelect.tsx +137 -0
  143. package/src/modules/search/components/Editor/ChatViewEditor.tsx +261 -0
  144. package/src/modules/search/components/Editor/aichat.css +1 -0
  145. package/src/modules/search/components/Editor/constant.ts +13 -0
  146. package/src/modules/search/components/Editor/index.tsx +113 -0
  147. package/src/modules/search/components/Editor/plugins/autofomatRules.ts +332 -0
  148. package/src/modules/search/components/Editor/plugins/convertImgPlugins.tsx +20 -0
  149. package/src/modules/search/components/Editor/plugins/createIndexes.tsx +38 -0
  150. package/src/modules/search/components/Editor/plugins/displayer.ts +298 -0
  151. package/src/modules/search/components/Editor/plugins/imageClick.tsx +32 -0
  152. package/src/modules/search/components/Editor/plugins/myplugin.tsx +98 -0
  153. package/src/modules/search/components/Editor/ui/avatar.tsx +19 -0
  154. package/src/modules/search/components/Editor/ui/blockquote-element.tsx +21 -0
  155. package/src/modules/search/components/Editor/ui/button.tsx +58 -0
  156. package/src/modules/search/components/Editor/ui/calendar.tsx +68 -0
  157. package/src/modules/search/components/Editor/ui/caption.tsx +46 -0
  158. package/src/modules/search/components/Editor/ui/checkbox.tsx +27 -0
  159. package/src/modules/search/components/Editor/ui/code-block-combobox.tsx +188 -0
  160. package/src/modules/search/components/Editor/ui/code-block-element.css +434 -0
  161. package/src/modules/search/components/Editor/ui/code-block-element.tsx +39 -0
  162. package/src/modules/search/components/Editor/ui/code-leaf.tsx +24 -0
  163. package/src/modules/search/components/Editor/ui/code-line-element.tsx +10 -0
  164. package/src/modules/search/components/Editor/ui/code-syntax-leaf.tsx +21 -0
  165. package/src/modules/search/components/Editor/ui/column-element.tsx +30 -0
  166. package/src/modules/search/components/Editor/ui/column-group-element.tsx +94 -0
  167. package/src/modules/search/components/Editor/ui/command.tsx +75 -0
  168. package/src/modules/search/components/Editor/ui/comment-avatar.tsx +22 -0
  169. package/src/modules/search/components/Editor/ui/comment-create-form.tsx +37 -0
  170. package/src/modules/search/components/Editor/ui/comment-item.tsx +74 -0
  171. package/src/modules/search/components/Editor/ui/comment-leaf.tsx +49 -0
  172. package/src/modules/search/components/Editor/ui/comment-more-dropdown.tsx +42 -0
  173. package/src/modules/search/components/Editor/ui/comment-reply-items.tsx +22 -0
  174. package/src/modules/search/components/Editor/ui/comment-resolve-button.tsx +32 -0
  175. package/src/modules/search/components/Editor/ui/comment-value.tsx +34 -0
  176. package/src/modules/search/components/Editor/ui/comments-popover.tsx +63 -0
  177. package/src/modules/search/components/Editor/ui/date-element.tsx +83 -0
  178. package/src/modules/search/components/Editor/ui/dialog.tsx +63 -0
  179. package/src/modules/search/components/Editor/ui/draggable.tsx +177 -0
  180. package/src/modules/search/components/Editor/ui/dropdown-menu.tsx +180 -0
  181. package/src/modules/search/components/Editor/ui/emoji-input-element.tsx +85 -0
  182. package/src/modules/search/components/Editor/ui/excalidraw-element.tsx +28 -0
  183. package/src/modules/search/components/Editor/ui/fixed-toolbar-buttons.tsx +76 -0
  184. package/src/modules/search/components/Editor/ui/fixed-toolbar.tsx +8 -0
  185. package/src/modules/search/components/Editor/ui/floating-toolbar-buttons.tsx +51 -0
  186. package/src/modules/search/components/Editor/ui/floating-toolbar.tsx +77 -0
  187. package/src/modules/search/components/Editor/ui/heading-element.tsx +48 -0
  188. package/src/modules/search/components/Editor/ui/highlight-leaf.tsx +17 -0
  189. package/src/modules/search/components/Editor/ui/hr-element.tsx +30 -0
  190. package/src/modules/search/components/Editor/ui/icons.tsx +267 -0
  191. package/src/modules/search/components/Editor/ui/image-element.tsx +74 -0
  192. package/src/modules/search/components/Editor/ui/inline-combobox.tsx +368 -0
  193. package/src/modules/search/components/Editor/ui/input.tsx +25 -0
  194. package/src/modules/search/components/Editor/ui/insert-dropdown-menu.tsx +218 -0
  195. package/src/modules/search/components/Editor/ui/kbd-leaf.tsx +20 -0
  196. package/src/modules/search/components/Editor/ui/link-element.tsx +29 -0
  197. package/src/modules/search/components/Editor/ui/link-floating-toolbar.tsx +161 -0
  198. package/src/modules/search/components/Editor/ui/list-element.tsx +30 -0
  199. package/src/modules/search/components/Editor/ui/mark-toolbar-button.tsx +24 -0
  200. package/src/modules/search/components/Editor/ui/media-embed-element.tsx +133 -0
  201. package/src/modules/search/components/Editor/ui/media-popover.tsx +97 -0
  202. package/src/modules/search/components/Editor/ui/mention-element.tsx +43 -0
  203. package/src/modules/search/components/Editor/ui/mention-input-element.tsx +141 -0
  204. package/src/modules/search/components/Editor/ui/mode-dropdown-menu.tsx +93 -0
  205. package/src/modules/search/components/Editor/ui/more-dropdown-menu.tsx +67 -0
  206. package/src/modules/search/components/Editor/ui/paragraph-element.tsx +4 -0
  207. package/src/modules/search/components/Editor/ui/placeholder.tsx +52 -0
  208. package/src/modules/search/components/Editor/ui/popover.tsx +32 -0
  209. package/src/modules/search/components/Editor/ui/resizable.tsx +66 -0
  210. package/src/modules/search/components/Editor/ui/separator.tsx +25 -0
  211. package/src/modules/search/components/Editor/ui/style.less +12 -0
  212. package/src/modules/search/components/Editor/ui/table-cell-element.tsx +143 -0
  213. package/src/modules/search/components/Editor/ui/table-element.tsx +243 -0
  214. package/src/modules/search/components/Editor/ui/table-row-element.tsx +22 -0
  215. package/src/modules/search/components/Editor/ui/tableValue.tsx +135 -0
  216. package/src/modules/search/components/Editor/ui/todo-list-element.tsx +43 -0
  217. package/src/modules/search/components/Editor/ui/toggle-element.tsx +31 -0
  218. package/src/modules/search/components/Editor/ui/toolbar.tsx +157 -0
  219. package/src/modules/search/components/Editor/ui/tooltip.tsx +65 -0
  220. package/src/modules/search/components/Editor/ui/turn-into-dropdown-menu.tsx +160 -0
  221. package/src/modules/search/components/Editor/ui/with-draggables.tsx +175 -0
  222. package/src/modules/search/components/FileList.tsx +287 -0
  223. package/src/modules/search/components/ImageGroupView/index.tsx +85 -0
  224. package/src/modules/search/components/ResultContent.tsx +232 -0
  225. package/src/modules/search/components/SearchInput.tsx +232 -0
  226. package/src/modules/search/components/SearchLanding.tsx +74 -0
  227. package/src/modules/search/components/SearchView.tsx +563 -0
  228. package/src/modules/search/components/SimpleEditor.tsx +158 -0
  229. package/src/modules/search/components/SimpleFileList.tsx +215 -0
  230. package/src/modules/search/index.tsx +10 -0
  231. package/src/modules/search/reademe.md +1 -0
  232. package/src/modules/search/servers/apis.tsx +19 -0
  233. package/src/modules/search/servers/index.ts +184 -0
  234. package/src/modules/search/style.less +503 -0
  235. package/src/modules/search/type.ts +22 -0
  236. package/src/modules/search/utils.ts +34 -0
  237. package/src/modules/sensitive/index.tsx +313 -0
  238. package/src/modules/sensitive/server.ts +122 -0
  239. package/src/modules/streamFilesReader/GientechStreamReader.tsx +1555 -0
  240. package/src/modules/streamFilesReader/components/Header/Toolbar.tsx +0 -0
  241. package/src/modules/streamFilesReader/components/Header/index.tsx +297 -0
  242. package/src/modules/streamFilesReader/index.tsx +3 -0
  243. package/src/style.css +6 -0
  244. package/src/type.d.ts +0 -0
  245. package/src/utils/commonFn.tsx +111 -0
  246. package/src/utils/gientechCommon/components/AppError.tsx +32 -0
  247. package/src/utils/gientechCommon/components/AppLoading.tsx +75 -0
  248. package/src/utils/gientechCommon/components/DeleteModal.tsx +75 -0
  249. package/src/utils/gientechCommon/components/DisplayError.tsx +33 -0
  250. package/src/utils/gientechCommon/components/DisplayLoading.tsx +38 -0
  251. package/src/utils/gientechCommon/components/FeedBackModal.tsx +310 -0
  252. package/src/utils/gientechCommon/components/FileCardCommon.tsx +82 -0
  253. package/src/utils/gientechCommon/components/FileManager/index.tsx +390 -0
  254. package/src/utils/gientechCommon/components/FileManager/style.css +5 -0
  255. package/src/utils/gientechCommon/components/Messages/GientechNewChatWelcome.tsx +296 -0
  256. package/src/utils/gientechCommon/components/Messages/ReferenceCard.tsx +339 -0
  257. package/src/utils/gientechCommon/components/Messages/RetriveItem.tsx +245 -0
  258. package/src/utils/gientechCommon/components/Messages/WebRetriveItem.tsx +209 -0
  259. package/src/utils/gientechCommon/components/Messages/defaultBot.png +0 -0
  260. package/src/utils/gientechCommon/components/Messages/defaultStyleSet.tsx +148 -0
  261. package/src/utils/gientechCommon/components/Messages/defaultWeLogo.svg +14 -0
  262. package/src/utils/gientechCommon/components/RenameModal.tsx +86 -0
  263. package/src/utils/gientechCommon/components/style.less +11 -0
  264. package/src/utils/gientechCommon/configs/commonConfig.ts +2 -0
  265. package/src/utils/gientechCommon/configs/senderConfig.ts +0 -0
  266. package/src/utils/gientechCommon/configs/stylesConfig.ts +142 -0
  267. package/src/utils/gientechCommon/hooks/AichatUseController.tsx +339 -0
  268. package/src/utils/gientechCommon/slate/converters/deserializers.ts +763 -0
  269. package/src/utils/gientechCommon/slate/converters/mockData.ts +232 -0
  270. package/src/utils/gientechCommon/slate/converters/slateConverters.ts +258 -0
  271. package/src/utils/gientechCommon/slate/richElements/index.tsx +499 -0
  272. package/src/utils/gientechCommon/utils/request.ts +37 -0
  273. package/src/utils/gientechCommon/utils/serverFn.ts +172 -0
  274. package/src/utils/index.tsx +126 -0
  275. package/src/utils/testconfigs/demologin/index.tsx +32 -0
  276. package/src/utils/testconfigs/index.ts +53 -0
  277. package/src/vite-env.d.ts +11 -0
  278. package/stats.html +4949 -0
  279. package/tailwind.config.js +170 -0
  280. package/tsconfig.app.json +30 -0
  281. package/tsconfig.app.tsbuildinfo +11 -0
  282. package/tsconfig.json +13 -0
  283. package/tsconfig.node.json +22 -0
  284. package/tsconfig.node.tsbuildinfo +1 -0
  285. package/vite.config.ts +178 -0
  286. package/workflows/release.yml +60 -0
  287. package/assets/index--DG-fVvc.js +0 -26
  288. package/assets/index-BfureYPx.js +0 -1505
  289. package/assets/index-CXwV5fAx.js +0 -1230
  290. package/assets/style.css +0 -1
  291. package/assets/style3.css +0 -1
  292. package/chat.js +0 -893
  293. package/database.js +0 -20
  294. package/databaseId.js +0 -21
  295. package/modelManage.js +0 -1
  296. package/sensitive.js +0 -1
  297. /package/{assets → dist/assets}/Doris.png +0 -0
  298. /package/{assets → dist/assets}/PostgreSQL.png +0 -0
  299. /package/{assets → dist/assets}/SQLServer.png +0 -0
  300. /package/{assets → dist/assets}/_commonjsHelpers-gnU0ypJ3.js +0 -0
  301. /package/{assets → dist/assets}/empty.png +0 -0
  302. /package/{assets → dist/assets}/index-CpW6Dhpp.js +0 -0
  303. /package/{assets → dist/assets}/style2.css +0 -0
  304. /package/{assets → dist/assets}/styled-components.browser.esm-DPkS13KC.js +0 -0
  305. /package/{chat.d.ts → dist/chat.d.ts} +0 -0
  306. /package/{database.d.ts → dist/database.d.ts} +0 -0
  307. /package/{databaseId.d.ts → dist/databaseId.d.ts} +0 -0
  308. /package/{databaseTable.d.ts → dist/databaseTable.d.ts} +0 -0
  309. /package/{modelManage.d.ts → dist/modelManage.d.ts} +0 -0
  310. /package/{sensitive.d.ts → dist/sensitive.d.ts} +0 -0
  311. /package/{streamFilesReader.d.ts → dist/streamFilesReader.d.ts} +0 -0
  312. /package/{vite.svg → dist/vite.svg} +0 -0
@@ -0,0 +1,196 @@
1
+ import axios from 'axios';
2
+
3
+ type IDataSourceType = 'DataTable' | 'DirectDB';
4
+
5
+ interface DatabaseApiProps {
6
+ url?: string;
7
+ token?: string;
8
+ role?: string;
9
+ eventsEmit?: (name: string, data: any) => void;
10
+ }
11
+
12
+ const AxiosInstance = ({ url, token, role, eventsEmit }: DatabaseApiProps) => {
13
+ const axios$ = axios.create({
14
+ baseURL: url,
15
+ // 配置请求超时时间
16
+ timeout: 1000000,
17
+ });
18
+ // 请求拦截
19
+ axios$.interceptors.request.use((config: any) => {
20
+ let target_cookie = token;
21
+
22
+ const noA = ['user/login', 'user/kaptcha', 'user/regist'];
23
+ // dangerous behaviour
24
+ if (!target_cookie && !noA.some((item: string) => config.url.includes(item))) {
25
+ // 通过eventsEmit抛出认证错误事件,让调用层处理
26
+ if (eventsEmit) {
27
+ eventsEmit('request:error_auth', {
28
+ errorMsg: '未登录或token已过期',
29
+ redirect: '/login',
30
+ });
31
+ }
32
+ return Promise.reject(new Error('未登录或token已过期'));
33
+ }
34
+
35
+ config.headers.Authorization = target_cookie || '';
36
+ // 这里传中文会报错
37
+ config.headers.userName = role === '未登录用户' ? '' : role;
38
+ // config.headers.userId = roleId;
39
+ return config;
40
+ });
41
+
42
+ // 返回拦截
43
+ axios$.interceptors.response.use(
44
+ response => {
45
+ // 获取接口返回结果
46
+ const noA = ['user/kaptcha'];
47
+ const res = response.data;
48
+ if (noA.some((item: string) => response.config.url && response.config.url.includes(item))) {
49
+ return res;
50
+ }
51
+ if (res.size && res.type) {
52
+ return res;
53
+ }
54
+ const { success, errorMsg, errorCode } = res;
55
+
56
+ if (success) {
57
+ return res;
58
+ } else {
59
+ // 通过eventsEmit抛出业务错误事件,让调用层处理
60
+ if (eventsEmit) {
61
+ eventsEmit('request:error_business', {
62
+ errorCode,
63
+ errorMsg: errorMsg || '请求出错,请稍后再试',
64
+ response: res,
65
+ });
66
+ }
67
+ }
68
+ return false;
69
+ },
70
+ async error => {
71
+ // 主动取消请求,不给报错信息
72
+ if (error.message === 'canceled') {
73
+ return Promise.reject(error);
74
+ }
75
+
76
+ // 通过eventsEmit抛出网络错误事件,让调用层处理
77
+ if (eventsEmit) {
78
+ let errorType = 'request:error_network';
79
+ let errorData: any = {
80
+ errorMsg: '网络请求失败',
81
+ error: error,
82
+ };
83
+
84
+ if (error?.response?.status === 401) {
85
+ errorType = 'request:error_auth';
86
+ errorData = {
87
+ errorMsg: '没有足够权限',
88
+ error: error,
89
+ redirect: '/login',
90
+ };
91
+ } else if (
92
+ error?.response?.data?.errorCode === '30013' ||
93
+ error?.response?.data?.errorCode === '30023'
94
+ ) {
95
+ errorType = 'request:error_business';
96
+ errorData = {
97
+ errorCode: error?.response?.data?.errorCode,
98
+ errorMsg: error?.response?.data?.errorMsg || '请求出错,请稍后再试',
99
+ error: error,
100
+ };
101
+ }
102
+
103
+ eventsEmit(errorType, errorData);
104
+ }
105
+
106
+ console.log('Error occurs', error);
107
+ return Promise.reject(error);
108
+ }
109
+ );
110
+
111
+ //数据库列表
112
+ const getDatabaseList = async (params: any) => {
113
+ try {
114
+ const res: any = await axios$.get(
115
+ `/queryPageDBList?${new URLSearchParams(params).toString()}`
116
+ );
117
+ const { success, data } = res;
118
+ if (success) return data;
119
+ } catch (e) {
120
+ console.log('getDatabaseList error:', e);
121
+ }
122
+ };
123
+ //共享数据库列表
124
+ // /database/queryShareDBList
125
+ const getShareDatabaseList = async (params: any) => {
126
+ try {
127
+ const res: any = await axios$.get(
128
+ `/queryShareDBList?${new URLSearchParams(params).toString()}`
129
+ );
130
+ const { success, data } = res;
131
+ if (success) return data;
132
+ } catch (e) {
133
+ console.log('getShareDatabaseList error:', e);
134
+ }
135
+ };
136
+ //删除数据库
137
+ const delDatabaseById = async (id: string | number, type: IDataSourceType) => {
138
+ const typeToUrl = getTypeToUrl(type);
139
+ try {
140
+ const res: any = await axios$.delete(`/${typeToUrl}/deleteDB/${id}`);
141
+
142
+ const { success, data } = res;
143
+ if (success) return data;
144
+ } catch (e) {
145
+ console.log('delDatabaseById error:', e);
146
+ }
147
+ };
148
+
149
+ // 保存数据库
150
+ const saveDatabase = async (params: any, type: IDataSourceType) => {
151
+ const typeToUrl = getTypeToUrl(type);
152
+ try {
153
+ const res: any = await axios$.post(`/${typeToUrl}/saveDBInfo`, params);
154
+
155
+ const { success, data } = res;
156
+ if (success) return data;
157
+ } catch (e) {
158
+ console.log('saveDatabase error:', e);
159
+ }
160
+ };
161
+
162
+ const testConnection = async (params: any) => {
163
+ try {
164
+ const res: any = await axios$.post(`/directDB/testConnect`, params);
165
+
166
+ const { success, data } = res;
167
+ if (success) return data;
168
+ } catch (e) {
169
+ console.log('testConnection error:', e);
170
+ }
171
+ };
172
+
173
+ const syncSchema = async (id: any) => {
174
+ try {
175
+ const res: any = await axios$.get(`/directDB/syncSchema/${id}`);
176
+ const { success, data } = res;
177
+ if (success) return data;
178
+ } catch (e) {
179
+ console.log('syncSchema error:', e);
180
+ }
181
+ };
182
+ return {
183
+ getDatabaseList,
184
+ getShareDatabaseList,
185
+ delDatabaseById,
186
+ saveDatabase,
187
+ testConnection,
188
+ syncSchema,
189
+ };
190
+ };
191
+
192
+ const getTypeToUrl = (type: IDataSourceType) => {
193
+ return type == 'DataTable' ? 'dataTable' : 'directDB';
194
+ };
195
+
196
+ export default AxiosInstance;
@@ -0,0 +1,156 @@
1
+ import { TriangleAlert, LoaderCircle } from 'lucide-react';
2
+ import { Tooltip, Tag, Badge } from 'antd';
3
+ import { Button } from '@mxmweb/zui';
4
+ import EmptyImg from './assets/empty.png';
5
+
6
+ enum OPT_BTN {
7
+ DATE = 0,
8
+ VIEW,
9
+ ERROR,
10
+ AUTHORIZE,
11
+ DELETE,
12
+ ANALYSIS_OR_EXTRACT,
13
+ DOWNLOAD,
14
+ EDIT,
15
+ ADD,
16
+ ANALYSIS_CONFIG,
17
+ AUTHORIZE_CONFIG,
18
+ }
19
+
20
+ enum DescStatus {
21
+ GENERATING = 'generating',
22
+ SUCCESS = 'success',
23
+ FAIL = 'fail',
24
+ }
25
+
26
+ const statusColorMap = {
27
+ success: 'green',
28
+ error: 'red',
29
+ warning: 'orange',
30
+ processing: 'blue',
31
+ info: 'cyan',
32
+ default: 'default',
33
+ };
34
+
35
+ type StatusColorKey = keyof typeof statusColorMap;
36
+ const getStatusColor = (statusType: unknown): string => {
37
+ if (typeof statusType === 'string' && (statusType as string) in statusColorMap) {
38
+ return statusColorMap[statusType as StatusColorKey];
39
+ }
40
+ return statusColorMap.default;
41
+ };
42
+
43
+ const StatusComponent = (props: any) => {
44
+ const { value, cell } = props;
45
+
46
+ switch (cell.columnId) {
47
+ case 'importstatus':
48
+ if (value) {
49
+ return (
50
+ <Tooltip title="有追加失败的文件,请及时处理">
51
+ <Tag color="red" bordered={false}>
52
+ 追加失败
53
+ </Tag>
54
+ </Tooltip>
55
+ );
56
+ }
57
+ return <></>;
58
+ case 'status':
59
+ const color = getStatusColor(props.cell.statusType);
60
+ if (value == '导入失败') {
61
+ return (
62
+ <Tooltip title={cell.errorMsg}>
63
+ <div className="flex items-center gap-2">
64
+ <Badge color={color} text={value} />
65
+ <TriangleAlert size={14} color="red" />
66
+ </div>
67
+ </Tooltip>
68
+ );
69
+ } else {
70
+ return <Badge color={color} text={value} />;
71
+ }
72
+ default:
73
+ return <></>;
74
+ }
75
+ };
76
+ const statusArr = [
77
+ { statusType: 'success', value: '导入成功', status: '30' },
78
+ { statusType: 'error', value: '导入失败', status: '00' },
79
+ { statusType: 'default', value: '待导入', status: '10' },
80
+ { statusType: 'processing', value: '导入中', status: '20' },
81
+ { statusType: 'processing', value: '导入中', status: '11' }, //11是导入中但未建表, 需要在前端展示导入中
82
+ ];
83
+
84
+ const TableMetaDescriptionCom = (info: any) => {
85
+ const { cell, value } = info;
86
+ if (typeof value == 'string') {
87
+ return (
88
+ <div
89
+ title={value}
90
+ style={{
91
+ maxWidth: 240,
92
+ whiteSpace: 'nowrap',
93
+ overflow: 'hidden',
94
+ textOverflow: 'ellipsis',
95
+ }}
96
+ >
97
+ {value}
98
+ </div>
99
+ );
100
+ } else {
101
+ if (cell.tableMeta?.isGenDescription) {
102
+ //如果用户选择了自动生成描述
103
+ if (cell.tableMeta?.generateDescriptionStatus == 'generating') {
104
+ return (
105
+ <div
106
+ className="flex items-center gap-1 text-[#84ADFF]"
107
+ style={{
108
+ color: '#84ADFF',
109
+ }}
110
+ >
111
+ <span>生成中</span>
112
+ <LoaderCircle size={14} />
113
+ </div>
114
+ );
115
+ }
116
+
117
+ return '-';
118
+ }
119
+
120
+ return '-';
121
+ }
122
+ };
123
+
124
+ const EmptyData = ({
125
+ dbInfo,
126
+ setDrawerTitle,
127
+ setDrawerVisible,
128
+ getBtnDisabled,
129
+ }: {
130
+ dbInfo: any;
131
+ setDrawerTitle: (title: string) => void;
132
+ setDrawerVisible: (open: boolean) => void;
133
+ getBtnDisabled?: (type: OPT_BTN, permission: number) => boolean;
134
+ }) => (
135
+ <div className="flex flex-col items-center justify-center h-full">
136
+ <div className="text-xl font-semibold mb-3">
137
+ <img src={EmptyImg} width={120} />
138
+ </div>
139
+ <div className="text-base mb-2" style={{ color: '#888888' }}>
140
+ 暂无数据文件
141
+ </div>
142
+ <div className="flex gap-3">
143
+ <Button
144
+ mode="primary"
145
+ label="上传数据文件"
146
+ disabled={getBtnDisabled && getBtnDisabled(OPT_BTN.ADD, dbInfo?.permission)}
147
+ onClick={() => {
148
+ setDrawerTitle('上传数据文件');
149
+ setDrawerVisible(true);
150
+ }}
151
+ />
152
+ </div>
153
+ </div>
154
+ );
155
+
156
+ export { StatusComponent, TableMetaDescriptionCom, statusArr, EmptyData, OPT_BTN, DescStatus };
@@ -0,0 +1,268 @@
1
+ import { useState, useCallback, useMemo, useEffect } from 'react';
2
+ import { message, Drawer, Popover, Modal } from 'antd';
3
+ import { Button } from '@mxmweb/zui';
4
+ import { X } from 'lucide-react';
5
+ import TemIcon from './assets/template.svg';
6
+ import AIIcon from './assets/aiOptimize.svg';
7
+ import { PromptTempDesigner } from '@mxmweb/rtext';
8
+ const { confirm } = Modal;
9
+
10
+ const initTemplate =
11
+ '<template key="type" placeholder="输入表格类型"></template>表格主要展示了<template key="scene" placeholder="输入场景名称"></template>场景的数据,包含<template key="primary_key" placeholder="主要字段(可写多个,用顿号分隔)"></template>等主要字段,支持用户查询<template key="search_direction" placeholder="大概介绍需要查询的方向"></template>问题,如果设计多表关联查询,最好说明此表格通过<template key="key_name" placeholder="字段名称"></template>字段可以关联另一个<template key="table_name" placeholder="表格名称"></template>表格。';
12
+ interface UploadDrawerProps {
13
+ drawerTitle: string;
14
+ drawerVisible: boolean;
15
+ handleDrawerClose: () => void;
16
+ optimizeDesc: (tableId: string | number) => Promise<any>;
17
+ tableInfo?: any;
18
+ eventsEmit: (name: string, data: any, appFn?: any) => void;
19
+ }
20
+ const EditConfig = ({
21
+ drawerTitle,
22
+ drawerVisible,
23
+ tableInfo,
24
+ handleDrawerClose,
25
+ optimizeDesc,
26
+ eventsEmit,
27
+ }: UploadDrawerProps) => {
28
+ const tbTitle = useMemo(() => {
29
+ return tableInfo?.data.find((d: any) => d.columnId == 'name').value || '-';
30
+ }, [tableInfo]);
31
+
32
+ const [templateContent, setTemplateContent] = useState('');
33
+ const [getDataFunction, setGetDataFunction] = useState<
34
+ ((format: 'pure_string' | 'string' | 'markdown' | 'html') => string) | null
35
+ >(null);
36
+ const [data, setData] = useState<string>('');
37
+ const [version, setVersion] = useState<number>(0);
38
+
39
+ // AI优化loading
40
+ const [optimizeLoading, setOptimizeLoading] = useState(false);
41
+
42
+ //使用模版popover
43
+ const [showModel, setShowModel] = useState(false);
44
+
45
+ useEffect(() => {
46
+ const tbDesc = tableInfo?.data.find((d: any) => d.columnId == 'description').value || '-';
47
+ setData(tbDesc);
48
+ }, [tableInfo]);
49
+
50
+ const showConfirm = () => {
51
+ confirm({
52
+ title: '你确定要使用模板吗?',
53
+ content: '这将替换你当前已填写的内容,且无法撤销。',
54
+ okText: '确认替换',
55
+ cancelText: '取消',
56
+ onOk() {
57
+ setData(initTemplate);
58
+ setVersion(v => v + 1);
59
+ },
60
+ onCancel() {
61
+ console.log('Cancel');
62
+ },
63
+ });
64
+ };
65
+
66
+ // 处理模版内容变化
67
+ const handleTemplateChange = useCallback((template: string) => {
68
+ setTemplateContent(template);
69
+ console.log('模版内容变化:', template);
70
+ }, []);
71
+
72
+ // 处理getData回调
73
+ const handleGetData = useCallback(
74
+ (getData: (format: 'pure_string' | 'string' | 'markdown' | 'html') => string) => {
75
+ setGetDataFunction(() => getData);
76
+ console.log('getData函数已设置');
77
+ },
78
+ []
79
+ );
80
+
81
+ const handleOptimize = async () => {
82
+ try {
83
+ setOptimizeLoading(true);
84
+ const res = await optimizeDesc(tableInfo.tableId);
85
+ if (res) {
86
+ setData(res);
87
+ setVersion(v => v + 1);
88
+ setOptimizeLoading(false);
89
+ }
90
+ } catch (e) {
91
+ message.error('AI 优化失败');
92
+ }
93
+ };
94
+
95
+ const handleDesData = useCallback(() => {
96
+ if (!getDataFunction) {
97
+ console.error('getData函数尚未准备好,请稍后再试');
98
+ return;
99
+ }
100
+
101
+ const result = getDataFunction('pure_string');
102
+ eventsEmit('table_info:update', result);
103
+ }, [getDataFunction, eventsEmit]);
104
+ return (
105
+ <Drawer
106
+ title={drawerTitle}
107
+ placement="right"
108
+ width={720}
109
+ onClose={handleDrawerClose}
110
+ closeIcon={false}
111
+ extra={<X size={20} color="#888888" onClick={handleDrawerClose} className="cursor-pointer" />}
112
+ open={drawerVisible}
113
+ destroyOnHidden
114
+ footer={
115
+ <div className={`flex justify-end items-center`}>
116
+ {/* 右侧:操作按钮组 */}
117
+ <div className="flex self-end gap-3">
118
+ <Button mode="default" label="取消" onClick={handleDrawerClose} />
119
+ <Button
120
+ mode="primary"
121
+ label="确认"
122
+ onClick={() => handleDesData()}
123
+ disabled={optimizeLoading}
124
+ />
125
+ </div>
126
+ </div>
127
+ }
128
+ >
129
+ <div className="mb-[10px] font-bold">{tbTitle}</div>
130
+ <div className="mb-[10px]">
131
+ <span
132
+ style={{
133
+ color: '#FF3B30',
134
+ marginRight: '4px',
135
+ }}
136
+ >
137
+ *
138
+ </span>
139
+ <span>数据表描述</span>
140
+ <span className="text-[#888888] ml-[4px]">
141
+ (请准确填写表格的应用场景描述,大模型将依赖此信息识别并正确调用该数据表。)
142
+ </span>
143
+ </div>
144
+ <PromptTempDesigner
145
+ key={version}
146
+ data={data}
147
+ onChange={handleTemplateChange}
148
+ onGetData={handleGetData}
149
+ styles={{
150
+ theme: {
151
+ colors: {
152
+ primary: '#0969da',
153
+ secondary: '#6b7280',
154
+ success: '#10b981',
155
+ warning: '#f59e0b',
156
+ error: '#ef4444',
157
+ info: '#3b82f6',
158
+ background: '#ffffff',
159
+ text: '#1f2937',
160
+ border: '#e5e7eb',
161
+ disabled: '#9ca3af',
162
+ disabledBackground: '#f3f4f6',
163
+ disabledText: '#6b7280',
164
+ shadow: '0 1px 3px rgba(0, 0, 0, 0.1)',
165
+ appBackground: 'transparent',
166
+ listBackground: '#f9fafb',
167
+ dashboardBackground: '#ffffff',
168
+ textSecondary: '#6b7280',
169
+ },
170
+ space: {
171
+ sidebar: '260px',
172
+ size: '12px',
173
+ radius: '8px',
174
+ padding: '1rem',
175
+ margin: '1rem',
176
+ shadow: '0 2px 8px rgba(0,0,0,0.1)',
177
+ lineHeight: '1.8',
178
+ },
179
+ icons: {},
180
+ fonts: {
181
+ body: {
182
+ size: '14px',
183
+ weight: 'normal',
184
+ family: 'PingFang SC, Microsoft YaHei, Arial, sans-serif',
185
+ },
186
+ heading: {
187
+ size: '14px',
188
+ weight: '600',
189
+ family: 'PingFang SC, Microsoft YaHei, Arial, sans-serif',
190
+ },
191
+ },
192
+ others: {
193
+ baseFontWeight: 'normal',
194
+ },
195
+ },
196
+ templateField: {
197
+ backgroundColor: '#E5EEFF', // 输入框背景色
198
+ borderColor: '#84ADFF', // 输入框边框颜色
199
+ borderRadius: '6px',
200
+ padding: '6px 12px', // 调整为1px间距,让蓝色块之间有精确的1px间距
201
+ margin: '2px',
202
+ fontSize: '14px',
203
+ fontWeight: '500',
204
+ minWidth: '80px',
205
+ textColor: '#84ADFF', // 未激活前文字颜色
206
+ },
207
+ }}
208
+ />
209
+ <div>
210
+ <Popover
211
+ open={showModel}
212
+ onOpenChange={v => setShowModel(!!v)}
213
+ content={
214
+ <div
215
+ style={{
216
+ width: '600px',
217
+ margin: '10px',
218
+ padding: '10px',
219
+ }}
220
+ onClick={showConfirm}
221
+ className="hover:bg-gray-100 h-[80px] cursor-pointer rounded"
222
+ >
223
+ {
224
+ '______表格主要展示了______场景的数据,包含______、______、______等主要字段,支持用户查询______问题(大概介绍)如果涉及多表关联查询,最好说明此表格通过______字段可以关联另一个______表格。'
225
+ }
226
+ </div>
227
+ }
228
+ title={
229
+ <div
230
+ className="flex justify-between items-center"
231
+ style={{
232
+ margin: '10px',
233
+ }}
234
+ >
235
+ <div className="text-[16px]">模版</div>
236
+ <X
237
+ size={20}
238
+ color="#888888"
239
+ onClick={() => setShowModel(false)}
240
+ className="cursor-pointer"
241
+ />
242
+ </div>
243
+ }
244
+ trigger="click"
245
+ destroyOnHidden
246
+ placement="bottomRight"
247
+ getPopupContainer={(triggerNode: HTMLElement) => triggerNode}
248
+ >
249
+ <span>
250
+ <Button mode="text" icon={<img src={TemIcon} />}>
251
+ 使用模版
252
+ </Button>
253
+ </span>
254
+ </Popover>
255
+ <Button
256
+ onClick={handleOptimize}
257
+ mode="text"
258
+ icon={<img src={AIIcon} />}
259
+ loading={optimizeLoading}
260
+ >
261
+ AI优化
262
+ </Button>
263
+ </div>
264
+ </Drawer>
265
+ );
266
+ };
267
+
268
+ export default EditConfig;