cx-chat 0.0.1 → 0.0.3

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 (406) hide show
  1. package/dist/cx-chat.css +1 -0
  2. package/dist/cx-chat.es.js +97326 -0
  3. package/dist/cx-chat.umd.js +734 -0
  4. package/package.json +21 -1
  5. package/.cursor/rules/i18n-cn-gloss-comments.mdc +0 -31
  6. package/.cursor/rules/list-page-view-pageconfig.mdc +0 -32
  7. package/.cursor/rules/no-over-defensive-programming.mdc +0 -90
  8. package/.cursor/rules/requirement-description-for-agent.mdc +0 -33
  9. package/.cursor/rules/use-showToast-not-antd-message.mdc +0 -28
  10. package/.docker/Dockerfile +0 -7
  11. package/.env +0 -9
  12. package/.env.development +0 -7
  13. package/.env.production +0 -7
  14. package/.gitlab-ci/docker-build.yaml +0 -28
  15. package/.gitlab-ci/k8s-deploy-dev-master.yaml +0 -42
  16. package/.gitlab-ci/npm-build.yaml +0 -17
  17. package/.gitlab-ci.yml +0 -8
  18. package/.k8s/0-namespace.yaml +0 -6
  19. package/.k8s/1-configmap-web.yaml +0 -7
  20. package/.k8s/1-nginx-conf-dev.yaml +0 -110
  21. package/.k8s/2-deployment.yaml +0 -27
  22. package/.k8s/3-service.yaml +0 -16
  23. package/.k8s/4-ingress-dev.yaml +0 -30
  24. package/.lingma/rules/use-showToast-not-antd-message.md +0 -34
  25. package/.nginx/nginx.conf +0 -52
  26. package/.prettierrc +0 -9
  27. package/eslint.config.js +0 -32
  28. package/index.html +0 -13
  29. package/postcss.config.js +0 -6
  30. package/src/App.tsx +0 -96
  31. package/src/_doc/0.docs-overview.md +0 -28
  32. package/src/_doc/cx-ui/0.docs-overview.md +0 -30
  33. package/src/_doc/cx-ui/comp.1.cx-ui-overview.md +0 -82
  34. package/src/_doc/cx-ui/comp.2.cx-modal.md +0 -82
  35. package/src/_doc/cx-ui/comp.3.cx-button.md +0 -89
  36. package/src/_doc/cx-ui/comp.4.cx-form.md +0 -72
  37. package/src/_doc/cx-ui/comp.5.cx-fields.md +0 -76
  38. package/src/_doc/cx-ui/comp.6.cx-tag.md +0 -57
  39. package/src/_doc/cx-ui/comp.7.cx-empty-state.md +0 -29
  40. package/src/_doc/meta/0.docs-overview.md +0 -24
  41. package/src/_doc/meta/comp.1.enum-runtime.md +0 -33
  42. package/src/_doc/meta/comp.2.dict-runtime.md +0 -39
  43. package/src/_doc/router/0.docs-overview.md +0 -14
  44. package/src/_doc/router/guide.1.menu-component-config.md +0 -181
  45. package/src/_doc/router/guide.2.router-auto-registration.md +0 -114
  46. package/src/_doc/table-view/0.docs-overview.md +0 -30
  47. package/src/_doc/table-view/comp.1.table-view.md +0 -542
  48. package/src/_doc/table-view/props.1.create-table-view-config.md +0 -193
  49. package/src/_doc/table-view/props.2.table-view-search-fields.md +0 -106
  50. package/src/api/_mock/README.md +0 -340
  51. package/src/api/_mock/api.ts +0 -1642
  52. package/src/api/_mock/bundle-shim.ts +0 -16
  53. package/src/api/_mock/handler-shim.ts +0 -6
  54. package/src/api/_mock/handler.ts +0 -458
  55. package/src/api/_mock/index.ts +0 -711
  56. package/src/api/_mock/interceptor.ts +0 -15
  57. package/src/api/_mock/mod.ts +0 -12
  58. package/src/api/_mock/utils.ts +0 -65
  59. package/src/api/base/memory.js +0 -24
  60. package/src/api/chat.js +0 -210
  61. package/src/api/common/auth.js +0 -70
  62. package/src/api/menus/business-rules.js +0 -76
  63. package/src/api/menus/feedback.js +0 -102
  64. package/src/api/menus/knowledge.js +0 -159
  65. package/src/api/menus/model-metadata/manage.js +0 -70
  66. package/src/api/menus/model-metadata/role.js +0 -50
  67. package/src/api/menus/model-metadata/training-detail-mock-data.js +0 -569
  68. package/src/api/menus/model-metadata/training.js +0 -28
  69. package/src/api/menus/skill.js +0 -40
  70. package/src/api/system/agent-config.js +0 -16
  71. package/src/api/system/department.js +0 -94
  72. package/src/api/system/dict.js +0 -86
  73. package/src/api/system/menu.js +0 -37
  74. package/src/api/system/permission.js +0 -26
  75. package/src/api/system/role.js +0 -34
  76. package/src/api/system/sys-config.js +0 -16
  77. package/src/api/system/sys-log.js +0 -17
  78. package/src/api/system/user.js +0 -75
  79. package/src/api/upload.js +0 -39
  80. package/src/assets/react.svg +0 -1
  81. package/src/components/auth/current-user-avatar.tsx +0 -77
  82. package/src/components/common/code-view.tsx +0 -149
  83. package/src/components/common/detail-link.tsx +0 -67
  84. package/src/components/common/error-boundary.tsx +0 -98
  85. package/src/components/common/language-switcher.tsx +0 -91
  86. package/src/components/common/lite-table/index.tsx +0 -135
  87. package/src/components/common/md-editor.tsx +0 -126
  88. package/src/components/common/modal/confirm-dialog.tsx +0 -113
  89. package/src/components/common/modal/dep-user-select-multi.tsx +0 -324
  90. package/src/components/common/modal/dep-user-select.tsx +0 -249
  91. package/src/components/common/modal/user-select-multi.tsx +0 -266
  92. package/src/components/common/pagination.tsx +0 -472
  93. package/src/components/common/path.tsx +0 -175
  94. package/src/components/common/system-logo-mark.tsx +0 -48
  95. package/src/components/cx-ui/button/index.less +0 -208
  96. package/src/components/cx-ui/button/index.tsx +0 -611
  97. package/src/components/cx-ui/checkbox/index.tsx +0 -78
  98. package/src/components/cx-ui/date-picker/index.less +0 -17
  99. package/src/components/cx-ui/date-picker/index.tsx +0 -193
  100. package/src/components/cx-ui/drawer/index.tsx +0 -47
  101. package/src/components/cx-ui/empty-state/index.tsx +0 -20
  102. package/src/components/cx-ui/floating-shell/CxFloatingShell.tsx +0 -89
  103. package/src/components/cx-ui/floating-shell/cx-floating-shell.less +0 -283
  104. package/src/components/cx-ui/floating-shell/has-floating-value.ts +0 -41
  105. package/src/components/cx-ui/form/CxForm.tsx +0 -15
  106. package/src/components/cx-ui/form/index.tsx +0 -20
  107. package/src/components/cx-ui/form-item/index.less +0 -26
  108. package/src/components/cx-ui/form-item/index.tsx +0 -36
  109. package/src/components/cx-ui/index.ts +0 -70
  110. package/src/components/cx-ui/input/auto-complete.tsx +0 -134
  111. package/src/components/cx-ui/input/index.tsx +0 -259
  112. package/src/components/cx-ui/input-number/index.jsx +0 -66
  113. package/src/components/cx-ui/modal/index.jsx +0 -212
  114. package/src/components/cx-ui/modal/index.less +0 -144
  115. package/src/components/cx-ui/modal/useCxModal.ts +0 -125
  116. package/src/components/cx-ui/multi-select/index.jsx +0 -74
  117. package/src/components/cx-ui/multi-select/index.less +0 -40
  118. package/src/components/cx-ui/multi-select/index2.tsx +0 -361
  119. package/src/components/cx-ui/radio/index.tsx +0 -33
  120. package/src/components/cx-ui/range-picker/index.less +0 -65
  121. package/src/components/cx-ui/range-picker/index.tsx +0 -219
  122. package/src/components/cx-ui/select/index.less +0 -34
  123. package/src/components/cx-ui/select/index.tsx +0 -196
  124. package/src/components/cx-ui/skeleton/index.tsx +0 -12
  125. package/src/components/cx-ui/steps/index.tsx +0 -14
  126. package/src/components/cx-ui/styles/_tokens.less +0 -79
  127. package/src/components/cx-ui/styles/index.less +0 -246
  128. package/src/components/cx-ui/switch/index.less +0 -106
  129. package/src/components/cx-ui/switch/index.tsx +0 -120
  130. package/src/components/cx-ui/table/index.less +0 -160
  131. package/src/components/cx-ui/table/index.tsx +0 -152
  132. package/src/components/cx-ui/tabs/index.less +0 -15
  133. package/src/components/cx-ui/tabs/index.tsx +0 -34
  134. package/src/components/cx-ui/tag/index.less +0 -51
  135. package/src/components/cx-ui/tag/index.tsx +0 -140
  136. package/src/components/cx-ui/timeline/index.tsx +0 -14
  137. package/src/components/cx-ui/tooltip/index.tsx +0 -67
  138. package/src/components/cx-ui/tree/index.tsx +0 -193
  139. package/src/components/cx-ui/tree-select/index.jsx +0 -91
  140. package/src/components/cx-ui/tree-select/index.less +0 -27
  141. package/src/components/cx-ui/upload-file/index.less +0 -223
  142. package/src/components/cx-ui/upload-file/index.tsx +0 -640
  143. package/src/components/cx-ui/upload-img/index.tsx +0 -291
  144. package/src/components/layout/components/Header.tsx +0 -216
  145. package/src/components/layout/components/Sidebar.tsx +0 -717
  146. package/src/components/layout/index.tsx +0 -95
  147. package/src/components/table-view/components/search-area.tsx +0 -411
  148. package/src/components/table-view/components/table-view-config.tsx +0 -528
  149. package/src/components/table-view/components/table-view.types.ts +0 -478
  150. package/src/components/table-view/components/tree-api-normalize.ts +0 -38
  151. package/src/components/table-view/components/tree-data-annotate.ts +0 -31
  152. package/src/components/table-view/components/tree-sidebar.tsx +0 -74
  153. package/src/components/table-view/index.tsx +0 -61
  154. package/src/components/table-view/list-page-view.tsx +0 -1049
  155. package/src/components/table-view/select-table-view.tsx +0 -1094
  156. package/src/components/table-view/styles/select-table-view.less +0 -51
  157. package/src/config/default-system-name.ts +0 -9
  158. package/src/config/system.ts +0 -165
  159. package/src/constants/countryCodes.ts +0 -3
  160. package/src/contexts/AuthContext.tsx +0 -256
  161. package/src/contexts/ChatContext.tsx +0 -839
  162. package/src/contexts/MenuContext.tsx +0 -62
  163. package/src/contexts/ToastContext.tsx +0 -181
  164. package/src/hooks/useCopyToClipboard.ts +0 -47
  165. package/src/hooks/useModalSubmit.ts +0 -104
  166. package/src/hooks/useRouter.ts +0 -240
  167. package/src/hooks/useStepForm.ts +0 -46
  168. package/src/hooks/useStickyHeader.ts +0 -42
  169. package/src/hooks/useThreadActions.ts +0 -105
  170. package/src/hooks/useUserPreferences.ts +0 -101
  171. package/src/http/axios.js +0 -372
  172. package/src/http/mock.interceptor.ts +0 -9
  173. package/src/http/obfuscationKey.ts +0 -41
  174. package/src/i18n.ts +0 -60
  175. package/src/index.js +0 -1
  176. package/src/index.less +0 -169
  177. package/src/locales/en/auth.ts +0 -70
  178. package/src/locales/en/base/memory.ts +0 -28
  179. package/src/locales/en/base/settings.ts +0 -41
  180. package/src/locales/en/chat.ts +0 -40
  181. package/src/locales/en/common.ts +0 -173
  182. package/src/locales/en/enum.ts +0 -27
  183. package/src/locales/en/menus/business-rules.ts +0 -48
  184. package/src/locales/en/menus/feedback.ts +0 -62
  185. package/src/locales/en/menus/knowledge.ts +0 -120
  186. package/src/locales/en/menus/model-metadata/index.ts +0 -10
  187. package/src/locales/en/menus/model-metadata/manage.ts +0 -151
  188. package/src/locales/en/menus/model-metadata/role.ts +0 -48
  189. package/src/locales/en/menus/model-metadata/training.ts +0 -65
  190. package/src/locales/en/menus/skill.ts +0 -34
  191. package/src/locales/en/system/agent-config.ts +0 -34
  192. package/src/locales/en/system/department.ts +0 -68
  193. package/src/locales/en/system/dict.ts +0 -44
  194. package/src/locales/en/system/menu.ts +0 -45
  195. package/src/locales/en/system/permission.ts +0 -89
  196. package/src/locales/en/system/role.ts +0 -25
  197. package/src/locales/en/system/sys-config.ts +0 -33
  198. package/src/locales/en/system/sys-log.ts +0 -38
  199. package/src/locales/en/system/user.ts +0 -113
  200. package/src/locales/en.ts +0 -68
  201. package/src/locales/zh/auth.ts +0 -70
  202. package/src/locales/zh/base/memory.ts +0 -29
  203. package/src/locales/zh/base/settings.ts +0 -41
  204. package/src/locales/zh/chat.ts +0 -47
  205. package/src/locales/zh/common.ts +0 -178
  206. package/src/locales/zh/enum.ts +0 -28
  207. package/src/locales/zh/menus/business-rules.ts +0 -47
  208. package/src/locales/zh/menus/feedback.ts +0 -62
  209. package/src/locales/zh/menus/knowledge.ts +0 -117
  210. package/src/locales/zh/menus/model-metadata/index.ts +0 -10
  211. package/src/locales/zh/menus/model-metadata/manage.ts +0 -151
  212. package/src/locales/zh/menus/model-metadata/role.ts +0 -47
  213. package/src/locales/zh/menus/model-metadata/training.ts +0 -64
  214. package/src/locales/zh/menus/skill.ts +0 -34
  215. package/src/locales/zh/system/agent-config.ts +0 -33
  216. package/src/locales/zh/system/department.ts +0 -69
  217. package/src/locales/zh/system/dict.ts +0 -44
  218. package/src/locales/zh/system/menu.ts +0 -47
  219. package/src/locales/zh/system/permission.ts +0 -94
  220. package/src/locales/zh/system/role.ts +0 -25
  221. package/src/locales/zh/system/sys-config.ts +0 -32
  222. package/src/locales/zh/system/sys-log.ts +0 -38
  223. package/src/locales/zh/system/user.ts +0 -114
  224. package/src/locales/zh.ts +0 -67
  225. package/src/main.tsx +0 -50
  226. package/src/meta/const/index.ts +0 -40
  227. package/src/meta/index-dict.ts +0 -56
  228. package/src/meta/index-enum.ts +0 -95
  229. package/src/meta/index.ts +0 -14
  230. package/src/meta/module/dict-data/runtime.ts +0 -199
  231. package/src/meta/module/dict-data/types.ts +0 -17
  232. package/src/meta/module/enum-data/runtime.ts +0 -75
  233. package/src/meta/module/enum-data/types.ts +0 -18
  234. package/src/router/index.tsx +0 -312
  235. package/src/styles/AntdThemeProvider.tsx +0 -40
  236. package/src/styles/antd-theme.ts +0 -20
  237. package/src/styles/global.less +0 -107
  238. package/src/styles/variable.less +0 -103
  239. package/src/types/feedback.ts +0 -43
  240. package/src/types/index.ts +0 -85
  241. package/src/types/menu.ts +0 -43
  242. package/src/utils/aesUtil.ts +0 -123
  243. package/src/utils/chatUtils.ts +0 -524
  244. package/src/utils/cn.ts +0 -6
  245. package/src/utils/crypto.ts +0 -164
  246. package/src/utils/date.ts +0 -72
  247. package/src/utils/file-icons.tsx +0 -79
  248. package/src/utils/index.ts +0 -168
  249. package/src/utils/markdown-math-plugins.ts +0 -21
  250. package/src/utils/menuI18n.ts +0 -305
  251. package/src/utils/menuRouteRegistry.ts +0 -78
  252. package/src/utils/permission-crud.ts +0 -147
  253. package/src/utils/routeConfig.ts +0 -350
  254. package/src/utils/storage.ts +0 -135
  255. package/src/utils/toastBridge.ts +0 -26
  256. package/src/utils/url.ts +0 -38
  257. package/src/utils/validation.ts +0 -16
  258. package/src/views/auth/auth-code/index.less +0 -169
  259. package/src/views/auth/auth-code/index.module.less +0 -174
  260. package/src/views/auth/auth-code/index.tsx +0 -233
  261. package/src/views/auth/login.tsx +0 -498
  262. package/src/views/auth/register.tsx +0 -388
  263. package/src/views/base/memory/index.tsx +0 -136
  264. package/src/views/base/memory/modal/detail-modal.tsx +0 -89
  265. package/src/views/base/memory/modal/submit-modal.tsx +0 -134
  266. package/src/views/base/settings/index.tsx +0 -657
  267. package/src/views/chat/chat.less +0 -323
  268. package/src/views/chat/components/chat-input.tsx +0 -298
  269. package/src/views/chat/components/header-thread-title.tsx +0 -210
  270. package/src/views/chat/components/message-list/content-answer.tsx +0 -100
  271. package/src/views/chat/components/message-list/content-question.tsx +0 -18
  272. package/src/views/chat/components/message-list/index.tsx +0 -520
  273. package/src/views/chat/components/message-list/message-item.tsx +0 -199
  274. package/src/views/chat/components/message-list/preparation-demo-items.ts +0 -147
  275. package/src/views/chat/components/message-list/preparation-steps.tsx +0 -506
  276. package/src/views/chat/components/message-list/suggestion-list.tsx +0 -36
  277. package/src/views/chat/components/message-list/thinking-process.tsx +0 -49
  278. package/src/views/chat/components/message-list/toolbar.tsx +0 -224
  279. package/src/views/chat/components/message-list/use-message-list-scroll.ts +0 -214
  280. package/src/views/chat/components/references-knowledge/context.tsx +0 -57
  281. package/src/views/chat/components/references-knowledge/index.ts +0 -9
  282. package/src/views/chat/components/references-knowledge/modal/knowledge-detail-drawer.tsx +0 -556
  283. package/src/views/chat/components/references-knowledge/modal/knowledge-doc-detail-drawer.tsx +0 -529
  284. package/src/views/chat/components/references-knowledge/panel.tsx +0 -115
  285. package/src/views/chat/hooks/use-chat-common.ts +0 -19
  286. package/src/views/chat/index-session.tsx +0 -647
  287. package/src/views/chat/index.tsx +0 -127
  288. package/src/views/page-error/401.tsx +0 -56
  289. package/src/views/page-error/404.tsx +0 -56
  290. package/src/views/page-menus/business-rules/index.tsx +0 -376
  291. package/src/views/page-menus/business-rules/modal/detail-modal.tsx +0 -186
  292. package/src/views/page-menus/business-rules/modal/scope-modal.tsx +0 -272
  293. package/src/views/page-menus/business-rules/modal/submit-modal.tsx +0 -142
  294. package/src/views/page-menus/feedback/components/feedback-dataset-list.tsx +0 -471
  295. package/src/views/page-menus/feedback/index.tsx +0 -166
  296. package/src/views/page-menus/feedback/modal/export-feedback-modal.tsx +0 -367
  297. package/src/views/page-menus/knowledge/components/doc-editor-by-type.tsx +0 -32
  298. package/src/views/page-menus/knowledge/components/doc-editor-type-file.tsx +0 -330
  299. package/src/views/page-menus/knowledge/detail.tsx +0 -600
  300. package/src/views/page-menus/knowledge/index.tsx +0 -337
  301. package/src/views/page-menus/knowledge/modal/detail-modal.tsx +0 -618
  302. package/src/views/page-menus/knowledge/modal/doc-detail-modal.tsx +0 -550
  303. package/src/views/page-menus/knowledge/modal/doc-parse.ts +0 -99
  304. package/src/views/page-menus/knowledge/modal/doc-submit-modal.tsx +0 -349
  305. package/src/views/page-menus/knowledge/modal/doc-type-picker-modal.tsx +0 -88
  306. package/src/views/page-menus/knowledge/modal/knowledge-user-select-modal.tsx +0 -283
  307. package/src/views/page-menus/knowledge/modal/submit-modal.tsx +0 -179
  308. package/src/views/page-menus/model-metadata/manage/components/metadata-detail-schema-tab.tsx +0 -114
  309. package/src/views/page-menus/model-metadata/manage/components/step1-basic-info.tsx +0 -232
  310. package/src/views/page-menus/model-metadata/manage/components/step2-schema.tsx +0 -316
  311. package/src/views/page-menus/model-metadata/manage/components/step3-permissions.tsx +0 -134
  312. package/src/views/page-menus/model-metadata/manage/components/step4-documents.tsx +0 -134
  313. package/src/views/page-menus/model-metadata/manage/components/step5-example-sql.tsx +0 -101
  314. package/src/views/page-menus/model-metadata/manage/components/submit-add.tsx +0 -338
  315. package/src/views/page-menus/model-metadata/manage/components/submit-edit.tsx +0 -276
  316. package/src/views/page-menus/model-metadata/manage/detail.tsx +0 -298
  317. package/src/views/page-menus/model-metadata/manage/hooks/model-metadata-submit-shared.ts +0 -113
  318. package/src/views/page-menus/model-metadata/manage/hooks/use-model-metadata-item-state.ts +0 -20
  319. package/src/views/page-menus/model-metadata/manage/index.tsx +0 -304
  320. package/src/views/page-menus/model-metadata/manage/modal/components/table-schema.ts +0 -374
  321. package/src/views/page-menus/model-metadata/manage/modal/components/use-table-detail-tabs.tsx +0 -151
  322. package/src/views/page-menus/model-metadata/manage/modal/components/use-table-submit-tabs.tsx +0 -423
  323. package/src/views/page-menus/model-metadata/manage/modal/detail-modal.tsx +0 -218
  324. package/src/views/page-menus/model-metadata/manage/modal/submit-modal.tsx +0 -261
  325. package/src/views/page-menus/model-metadata/manage/modal/table-detail-modal.tsx +0 -196
  326. package/src/views/page-menus/model-metadata/manage/modal/table-submit-modal.tsx +0 -229
  327. package/src/views/page-menus/model-metadata/manage/submit.tsx +0 -31
  328. package/src/views/page-menus/model-metadata/role/index.tsx +0 -207
  329. package/src/views/page-menus/model-metadata/role/modal/detail-modal.tsx +0 -97
  330. package/src/views/page-menus/model-metadata/role/modal/role-assign-users-modal.tsx +0 -254
  331. package/src/views/page-menus/model-metadata/role/modal/role-assign-users-panel.tsx +0 -393
  332. package/src/views/page-menus/model-metadata/role/modal/role-assign-users-utils.ts +0 -120
  333. package/src/views/page-menus/model-metadata/role/modal/role-permission-assign-panel.tsx +0 -698
  334. package/src/views/page-menus/model-metadata/role/modal/role-permission-modal.tsx +0 -237
  335. package/src/views/page-menus/model-metadata/role/modal/submit-modal.tsx +0 -135
  336. package/src/views/page-menus/model-metadata/training/components/detail-records/index.ts +0 -4
  337. package/src/views/page-menus/model-metadata/training/components/detail-records/node-card.tsx +0 -72
  338. package/src/views/page-menus/model-metadata/training/components/detail-records/summary-lines.ts +0 -196
  339. package/src/views/page-menus/model-metadata/training/components/detail-records/summary-list.tsx +0 -153
  340. package/src/views/page-menus/model-metadata/training/components/detail-records/timeline.tsx +0 -103
  341. package/src/views/page-menus/model-metadata/training/components/detail-records/types.ts +0 -82
  342. package/src/views/page-menus/model-metadata/training/detail.tsx +0 -159
  343. package/src/views/page-menus/model-metadata/training/index.tsx +0 -236
  344. package/src/views/page-menus/model-metadata/training/modal/update-detail-modal.tsx +0 -154
  345. package/src/views/page-menus/skill/index.tsx +0 -201
  346. package/src/views/page-menus/skill/modal/detail-modal.tsx +0 -156
  347. package/src/views/page-menus/skill/modal/submit-modal.tsx +0 -214
  348. package/src/views/page-system/agent-config/index.tsx +0 -370
  349. package/src/views/page-system/department/departmentFormShared.ts +0 -36
  350. package/src/views/page-system/department/index.tsx +0 -541
  351. package/src/views/page-system/department/modal/detail-modal.tsx +0 -94
  352. package/src/views/page-system/department/modal/member-role-modal.tsx +0 -128
  353. package/src/views/page-system/department/modal/submit-modal.tsx +0 -265
  354. package/src/views/page-system/dict/index.tsx +0 -440
  355. package/src/views/page-system/dict/modal/cate-submit-modal.tsx +0 -315
  356. package/src/views/page-system/dict/modal/submit-modal.tsx +0 -184
  357. package/src/views/page-system/logs/components/index.ts +0 -3
  358. package/src/views/page-system/logs/components/log-message-demo.tsx +0 -30
  359. package/src/views/page-system/logs/components/log-message-stream.ts +0 -184
  360. package/src/views/page-system/logs/components/message-list/content-answer.tsx +0 -100
  361. package/src/views/page-system/logs/components/message-list/content-question.tsx +0 -18
  362. package/src/views/page-system/logs/components/message-list/index.tsx +0 -515
  363. package/src/views/page-system/logs/components/message-list/message-item.tsx +0 -193
  364. package/src/views/page-system/logs/components/message-list/preparation-demo-items.ts +0 -147
  365. package/src/views/page-system/logs/components/message-list/preparation-steps.tsx +0 -506
  366. package/src/views/page-system/logs/components/message-list/suggestion-list.tsx +0 -36
  367. package/src/views/page-system/logs/components/message-list/thinking-process.tsx +0 -49
  368. package/src/views/page-system/logs/components/message-list/toolbar.tsx +0 -134
  369. package/src/views/page-system/logs/components/message-list/use-message-list-scroll.ts +0 -214
  370. package/src/views/page-system/logs/components/message-modal.tsx +0 -239
  371. package/src/views/page-system/logs/index.tsx +0 -132
  372. package/src/views/page-system/logs/modal/detail-modal.tsx +0 -157
  373. package/src/views/page-system/menu/components/menuFormShared.ts +0 -283
  374. package/src/views/page-system/menu/index.less +0 -12
  375. package/src/views/page-system/menu/index.tsx +0 -410
  376. package/src/views/page-system/menu/modal/icon-modal.less +0 -51
  377. package/src/views/page-system/menu/modal/icon-modal.tsx +0 -87
  378. package/src/views/page-system/menu/modal/submit-modal.tsx +0 -263
  379. package/src/views/page-system/permission/index.tsx +0 -562
  380. package/src/views/page-system/permission/modal/detail-modal.tsx +0 -179
  381. package/src/views/page-system/permission/modal/submit-modal.less +0 -146
  382. package/src/views/page-system/permission/modal/submit-modal.tsx +0 -650
  383. package/src/views/page-system/role/index.tsx +0 -163
  384. package/src/views/page-system/role/modal/detail-modal.tsx +0 -127
  385. package/src/views/page-system/role/modal/permission-assign-group-rules.ts +0 -86
  386. package/src/views/page-system/role/modal/permission-modal.tsx +0 -111
  387. package/src/views/page-system/role/modal/role-modal-shell-styles.ts +0 -21
  388. package/src/views/page-system/role/modal/role-permission-assign-panel.tsx +0 -916
  389. package/src/views/page-system/role/modal/role-permission-assign-shared.ts +0 -1047
  390. package/src/views/page-system/role/modal/submit-modal.tsx +0 -193
  391. package/src/views/page-system/sys-config/index.tsx +0 -294
  392. package/src/views/page-system/user/components/user-role-column.tsx +0 -87
  393. package/src/views/page-system/user/index.tsx +0 -439
  394. package/src/views/page-system/user/modal/assign-roles-modal.tsx +0 -389
  395. package/src/views/page-system/user/modal/detail-modal.tsx +0 -72
  396. package/src/views/page-system/user/modal/modal-style/submit-modal.less +0 -40
  397. package/src/views/page-system/user/modal/submit-modal.less +0 -40
  398. package/src/views/page-system/user/modal/submit-modal.tsx +0 -287
  399. package/src/views/page-system/user/userFormShared.ts +0 -51
  400. package/tailwind.config.js +0 -17
  401. package/tsconfig.app.json +0 -48
  402. package/tsconfig.json +0 -11
  403. package/tsconfig.node.json +0 -26
  404. package/vite.config.ts +0 -264
  405. /package/{public → dist}/favicon.ico +0 -0
  406. /package/{public → dist}/vite.svg +0 -0
@@ -1,254 +0,0 @@
1
- import DepUserSelectMultiModal, {
2
- pickUserId,
3
- type DepUserSelectUser,
4
- } from '@/components/common/modal/dep-user-select-multi'
5
- import { useToast } from '@/contexts/ToastContext'
6
- import { roleModalShellStyles } from '@/views/page-system/role/modal/role-modal-shell-styles'
7
- import {
8
- getModelMetadataRoleAssignUsersAPI,
9
- getModelMetadataRoleAssignUsersContextAPI,
10
- saveModelMetadataRoleAssignUsersAPI,
11
- } from '@api/menus/model-metadata/role'
12
- import { CxModal, useCxModal } from '@cx-ui'
13
- import { forwardRef, useCallback, useImperativeHandle, useRef, useState } from 'react'
14
- import { useTranslation } from 'react-i18next'
15
-
16
- import RoleAssignUsersPanel from './role-assign-users-panel'
17
- import {
18
- buildEmptyPermissionsFromContext,
19
- mergeUserPermissionsWithContext,
20
- parseLibrariesFromContext,
21
- parseUsersFromAssignResponse,
22
- type AssignContextLibrary,
23
- type AssignUserEntry,
24
- } from './role-assign-users-utils'
25
-
26
- export type RoleAssignUsersModalOpenPayload = {
27
- record: { id: string | number; name?: string }
28
- }
29
-
30
- const RoleAssignUsersModal = forwardRef<
31
- { open: (p: RoleAssignUsersModalOpenPayload) => void; close: () => void },
32
- { onSaved?: () => void | Promise<void> }
33
- >(function RoleAssignUsersModal({ onSaved }, ref) {
34
- const { t } = useTranslation()
35
- const { showToast } = useToast()
36
-
37
- const [loading, setLoading] = useState(false)
38
- const [saving, setSaving] = useState(false)
39
- const [roleId, setRoleId] = useState<string | number | null>(null)
40
- const [titleHintFromList, setTitleHintFromList] = useState<string | undefined>(undefined)
41
- const [libraries, setLibraries] = useState<AssignContextLibrary[]>([])
42
- const [users, setUsers] = useState<AssignUserEntry[]>([])
43
- const [activeUserId, setActiveUserId] = useState<string | null>(null)
44
- const [panelBootstrapKey, setPanelBootstrapKey] = useState(0)
45
-
46
- const librariesRef = useRef<AssignContextLibrary[]>([])
47
- librariesRef.current = libraries
48
-
49
- const userSelectRef = useRef<{ open: (p?: any) => void; close: () => void } | null>(null)
50
-
51
- const modal = useCxModal({
52
- onOpen: async (payload) => {
53
- const id = payload?.data?.record?.id ?? payload?.opeId
54
- setRoleId(id ?? null)
55
- setLibraries([])
56
- setUsers([])
57
- setActiveUserId(null)
58
- setPanelBootstrapKey((k) => k + 1)
59
-
60
- if (id == null || `${id}`.trim() === '') {
61
- setTitleHintFromList(undefined)
62
- return
63
- }
64
-
65
- const hint = payload?.data?.record?.name
66
- setTitleHintFromList(typeof hint === 'string' && hint.trim() ? hint.trim() : undefined)
67
-
68
- setLoading(true)
69
- try {
70
- const [contextRes, assignRes] = await Promise.all([
71
- getModelMetadataRoleAssignUsersContextAPI(id),
72
- getModelMetadataRoleAssignUsersAPI(id),
73
- ])
74
- const libs = parseLibrariesFromContext(contextRes)
75
- setLibraries(libs)
76
- librariesRef.current = libs
77
-
78
- const parsedUsers = parseUsersFromAssignResponse(assignRes).map((u) => ({
79
- ...u,
80
- permissions: mergeUserPermissionsWithContext(u.permissions, libs),
81
- }))
82
- setUsers(parsedUsers)
83
- setActiveUserId(parsedUsers[0]?.userId ?? null)
84
- } finally {
85
- setLoading(false)
86
- }
87
- },
88
- onClose: () => {
89
- setRoleId(null)
90
- setLibraries([])
91
- setUsers([])
92
- setActiveUserId(null)
93
- setTitleHintFromList(undefined)
94
- },
95
- })
96
-
97
- const { isOpen, close } = modal
98
-
99
- const handleAddUsersClick = useCallback(() => {
100
- userSelectRef.current?.open({
101
- title: t('menus.model_metadata.role.assign_users_pick_users_title'), // 选择用户
102
- deptSelectable: false,
103
- })
104
- }, [t])
105
-
106
- const handleUserSelectOk = useCallback(
107
- async ({ users: picked }: { users: DepUserSelectUser[] }) => {
108
- const libs = librariesRef.current
109
- let dupCount = 0
110
- const newEntries: AssignUserEntry[] = []
111
-
112
- setUsers((prev) => {
113
- const existingIds = new Set(prev.map((u) => String(u.userId)))
114
- for (const u of picked) {
115
- const id = pickUserId(u)
116
- if (id == null) continue
117
- const sid = String(id)
118
- if (existingIds.has(sid)) {
119
- dupCount++
120
- continue
121
- }
122
- existingIds.add(sid)
123
- newEntries.push({
124
- userId: sid,
125
- userName:
126
- u.display_name ?? u.userName ?? u.name ?? u.email ?? u.userEmail ?? sid,
127
- userPhone: (u as any).userPhone ?? (u as any).phone ?? '',
128
- permissions: buildEmptyPermissionsFromContext(libs),
129
- })
130
- }
131
- if (!newEntries.length) return prev
132
- return [...prev, ...newEntries]
133
- })
134
-
135
- if (newEntries.length > 0) {
136
- setActiveUserId((cur) => cur ?? newEntries[0]?.userId ?? null)
137
- }
138
- if (dupCount > 0) {
139
- showToast(t('menus.model_metadata.role.assign_users_duplicate'), 'info') // 已跳过重复用户
140
- }
141
- },
142
- [showToast, t],
143
- )
144
-
145
- const handleRemoveUser = useCallback((userId: string) => {
146
- setUsers((prev) => {
147
- const next = prev.filter((u) => u.userId !== userId)
148
- setActiveUserId((cur) => {
149
- if (cur !== userId) return cur
150
- return next[0]?.userId ?? null
151
- })
152
- return next
153
- })
154
- }, [])
155
-
156
- const handlePermissionValueChange = useCallback(
157
- (userId: string, metadataId: string, permissionId: string, value: string) => {
158
- setUsers((prev) =>
159
- prev.map((u) => {
160
- if (u.userId !== userId) return u
161
- return {
162
- ...u,
163
- permissions: u.permissions.map((p) =>
164
- p.metadataId === metadataId && p.permissionId === permissionId
165
- ? { ...p, permissionValue: value }
166
- : p,
167
- ),
168
- }
169
- }),
170
- )
171
- },
172
- [],
173
- )
174
-
175
- const handleSave = useCallback(async () => {
176
- if (!roleId) return
177
- setSaving(true)
178
- try {
179
- await saveModelMetadataRoleAssignUsersAPI(roleId, {
180
- users: users.map((u) => ({
181
- userId: u.userId,
182
- permissions: u.permissions.map((p) => ({
183
- permissionValue: p.permissionValue ?? '',
184
- metadataId: p.metadataId,
185
- permissionId: p.permissionId,
186
- })),
187
- })),
188
- })
189
- showToast(t('common.operation_success'), 'success') // 操作成功
190
- await onSaved?.()
191
- close()
192
- } catch {
193
- // 失败由 axios 拦截器等统一提示
194
- } finally {
195
- setSaving(false)
196
- }
197
- }, [roleId, users, showToast, t, onSaved, close])
198
-
199
- useImperativeHandle(
200
- ref,
201
- () => ({
202
- open: (payload: RoleAssignUsersModalOpenPayload) => {
203
- modal.open({
204
- opeType: 'edit',
205
- opeId: payload.record.id,
206
- data: { record: payload.record },
207
- })
208
- },
209
- close,
210
- }),
211
- [modal.open, close],
212
- )
213
-
214
- const titleBase = t('menus.model_metadata.role.assign_users_title') // 添加用户
215
- const modalTitle = titleHintFromList ? `${titleBase} — ${titleHintFromList}` : titleBase
216
-
217
- return (
218
- <>
219
- <CxModal
220
- isOpen={isOpen}
221
- title={modalTitle}
222
- onClose={close}
223
- opeType="edit"
224
- onSubmit={() => void handleSave()}
225
- submitting={saving}
226
- modalConfig={{
227
- width: 1380,
228
- styles: roleModalShellStyles,
229
- rootClassName: 'cx-modal-role-assign',
230
- }}
231
- >
232
- <div className="flex h-full min-h-0 w-full flex-1 flex-col overflow-hidden">
233
- <RoleAssignUsersPanel
234
- key={`${String(roleId)}-${panelBootstrapKey}`}
235
- active={isOpen}
236
- loading={loading}
237
- libraries={libraries}
238
- users={users}
239
- activeUserId={activeUserId}
240
- onActiveUserIdChange={setActiveUserId}
241
- onAddUsersClick={handleAddUsersClick}
242
- onRemoveUser={handleRemoveUser}
243
- onPermissionValueChange={handlePermissionValueChange}
244
- maxHeightClass="h-full min-h-0 w-full flex-1 overflow-hidden"
245
- />
246
- </div>
247
- </CxModal>
248
- <DepUserSelectMultiModal ref={userSelectRef} onOk={handleUserSelectOk} />
249
- </>
250
- )
251
- })
252
-
253
- RoleAssignUsersModal.displayName = 'RoleAssignUsersModal'
254
- export default RoleAssignUsersModal
@@ -1,393 +0,0 @@
1
- // i18n 中文:locales/zh/menus/model-metadata/role.ts、manage.ts(permissionName / permissionColumns)
2
-
3
- import { CxButton, CxInput, CxSkeleton, CxTable } from '@cx-ui'
4
- import clsx from 'clsx'
5
- import { Plus, Trash2 } from 'lucide-react'
6
- import { useCallback, useEffect, useMemo, useRef, useState } from 'react'
7
- import { useTranslation } from 'react-i18next'
8
-
9
- import {
10
- formatPermissionColumns,
11
- type AssignContextLibrary,
12
- type AssignUserEntry,
13
- type UserPermissionRow,
14
- } from './role-assign-users-utils'
15
-
16
- type RoleAssignUsersPanelProps = {
17
- active: boolean
18
- loading: boolean
19
- libraries: AssignContextLibrary[]
20
- users: AssignUserEntry[]
21
- activeUserId: string | null
22
- onActiveUserIdChange: (userId: string) => void
23
- onAddUsersClick: () => void
24
- onRemoveUser: (userId: string) => void
25
- onPermissionValueChange: (
26
- userId: string,
27
- metadataId: string,
28
- permissionId: string,
29
- value: string,
30
- ) => void
31
- maxHeightClass?: string
32
- }
33
-
34
- export default function RoleAssignUsersPanel(props: RoleAssignUsersPanelProps) {
35
- const {
36
- active,
37
- loading,
38
- libraries,
39
- users,
40
- activeUserId,
41
- onActiveUserIdChange,
42
- onAddUsersClick,
43
- onRemoveUser,
44
- onPermissionValueChange,
45
- maxHeightClass,
46
- } = props
47
- const { t } = useTranslation()
48
-
49
- const contentScrollRef = useRef<HTMLDivElement>(null)
50
- const sectionRefs = useRef<Record<string, HTMLElement | null>>({})
51
- const [activeMetadataId, setActiveMetadataId] = useState<string | null>(null)
52
-
53
- const activeUser = useMemo(
54
- () => users.find((u) => u.userId === activeUserId) ?? null,
55
- [users, activeUserId],
56
- )
57
-
58
- const permRowsByMeta = useMemo(() => {
59
- const map = new Map<string, UserPermissionRow[]>()
60
- for (const row of activeUser?.permissions ?? []) {
61
- const mid = row.metadataId
62
- if (!map.has(mid)) map.set(mid, [])
63
- map.get(mid)!.push(row)
64
- }
65
- return map
66
- }, [activeUser?.permissions])
67
-
68
- useEffect(() => {
69
- if (!libraries.length) {
70
- setActiveMetadataId(null)
71
- return
72
- }
73
- setActiveMetadataId((cur) => {
74
- if (cur && libraries.some((l) => l.metadataId === cur)) return cur
75
- return libraries[0]?.metadataId ?? null
76
- })
77
- }, [libraries, activeUserId])
78
-
79
- useEffect(() => {
80
- if (loading || !activeUser || !libraries.length) return
81
- const container = contentScrollRef.current
82
- if (!container) return
83
-
84
- const observer = new IntersectionObserver(
85
- (entries) => {
86
- const visible = entries
87
- .filter((e) => e.isIntersecting)
88
- .sort((a, b) => b.intersectionRatio - a.intersectionRatio)
89
- const top = visible[0]
90
- if (!top?.target) return
91
- const id = top.target.getAttribute('data-metadata-id')
92
- if (id) setActiveMetadataId(id)
93
- },
94
- { root: container, threshold: [0, 0.2, 0.45, 0.7], rootMargin: '-12% 0px -55% 0px' },
95
- )
96
-
97
- for (const lib of libraries) {
98
- const el = sectionRefs.current[lib.metadataId]
99
- if (el) {
100
- el.setAttribute('data-metadata-id', lib.metadataId)
101
- observer.observe(el)
102
- }
103
- }
104
- return () => observer.disconnect()
105
- }, [libraries, activeUser, loading])
106
-
107
- const scrollToMeta = useCallback((metadataId: string) => {
108
- setActiveMetadataId(metadataId)
109
- const el = sectionRefs.current[metadataId]
110
- const container = contentScrollRef.current
111
- if (!el || !container) return
112
- const top = el.offsetTop - container.offsetTop
113
- container.scrollTo({ top: Math.max(0, top - 8), behavior: 'smooth' })
114
- }, [])
115
-
116
- const hasLayoutLock = Boolean(maxHeightClass && String(maxHeightClass).trim())
117
- const rootLayoutClass = clsx(
118
- 'flex min-h-0 gap-4 overflow-hidden',
119
- hasLayoutLock ? clsx(maxHeightClass, 'min-h-0 flex-1') : 'min-h-[320px]',
120
- )
121
- const scrollColClass = 'min-h-0 flex-1 basis-0 overflow-y-auto overflow-x-hidden'
122
- /** 与 role-permission-assign-panel 侧栏标题一致:固定 44px 高 */
123
- const sidePanelHeaderClass =
124
- 'flex h-[44px] min-h-[44px] shrink-0 items-center border-b border-gray-200 bg-gray-50 px-3 py-2.5 dark:border-gray-700 dark:bg-gray-700/50'
125
- const sidePanelHeaderTitleClass =
126
- 'line-clamp-1 min-w-0 flex-1 py-0.5 text-xs font-semibold uppercase tracking-wider text-gray-700 dark:text-gray-300'
127
-
128
- if (!active) return null
129
-
130
- const renderLibrarySection = (lib: AssignContextLibrary) => {
131
- const mid = lib.metadataId
132
- const templateMap = new Map(
133
- (lib.permissions || []).map((p) => [p.permissionId, p] as const),
134
- )
135
- const rows = (permRowsByMeta.get(mid) ?? []).filter((r) => templateMap.has(r.permissionId))
136
-
137
- const columns = [
138
- {
139
- title: t('menus.model_metadata.manage.fields.permissionName'), // 权限组名称
140
- key: 'permissionName',
141
- width: 160,
142
- render: (_: unknown, row: UserPermissionRow) => {
143
- const tpl = templateMap.get(row.permissionId)
144
- return (
145
- <span className="text-sm text-gray-900 dark:text-gray-100">
146
- {tpl?.permissionName || '—'}
147
- </span>
148
- )
149
- },
150
- },
151
- {
152
- title: t('menus.model_metadata.manage.fields.permissionColumns'), // 模板允许的列名
153
- key: 'permissionColumns',
154
- minWidth: 200,
155
- render: (_: unknown, row: UserPermissionRow) => {
156
- const tpl = templateMap.get(row.permissionId)
157
- return (
158
- <span className="text-sm text-gray-600 dark:text-gray-300">
159
- {formatPermissionColumns(tpl?.permissionColumns ?? [])}
160
- </span>
161
- )
162
- },
163
- },
164
- {
165
- title: t('menus.model_metadata.role.assign_users_permission_value'), // 权限值
166
- key: 'permissionValue',
167
- width: 240,
168
- render: (_: unknown, row: UserPermissionRow) => {
169
- if (!activeUser) return null
170
- return (
171
- <CxInput
172
- className="w-[240px] max-w-full"
173
- value={row.permissionValue}
174
- onChange={(e) =>
175
- onPermissionValueChange(
176
- activeUser.userId,
177
- row.metadataId,
178
- row.permissionId,
179
- e.target.value,
180
- )
181
- }
182
- placeholder={t('menus.model_metadata.role.assign_users_permission_value')}
183
- />
184
- )
185
- },
186
- },
187
- ]
188
-
189
- return (
190
- <section
191
- key={mid}
192
- ref={(el) => {
193
- sectionRefs.current[mid] = el
194
- }}
195
- data-metadata-id={mid}
196
- className={clsx(
197
- 'scroll-mt-2 rounded-xl border bg-white p-4 shadow-sm dark:bg-gray-800',
198
- activeMetadataId === mid
199
- ? 'border-blue-300 ring-1 ring-blue-200/80 dark:border-blue-600 dark:ring-blue-900/50'
200
- : 'border-gray-200 dark:border-gray-600',
201
- )}
202
- >
203
- <h3 className="mb-3 text-sm font-semibold text-gray-900 dark:text-gray-100">
204
- {t('menus.model_metadata.role.assign_users_library_title', {
205
- subject: lib.subject || mid,
206
- databaseName: lib.databaseName || '—',
207
- })}
208
- </h3>
209
- {rows.length === 0 ? (
210
- <p className="py-4 text-center text-sm text-gray-500">{t('common.no_data')}</p>
211
- ) : (
212
- <CxTable
213
- className="min-w-0 w-full"
214
- columns={columns}
215
- dataSource={rows.map((r) => ({
216
- ...r,
217
- key: `${r.metadataId}::${r.permissionId}`,
218
- }))}
219
- pagination={false}
220
- scroll={{ x: true }}
221
- />
222
- )}
223
- </section>
224
- )
225
- }
226
-
227
- const renderMetaNav = () => {
228
- if (loading || !libraries.length || !activeUser) return null
229
- return (
230
- <div
231
- className={clsx(
232
- 'flex w-52 shrink-0 flex-col overflow-hidden border-r border-gray-200 bg-white dark:border-gray-700 dark:bg-gray-800',
233
- hasLayoutLock && 'h-full min-h-0',
234
- )}
235
- >
236
- <div className={sidePanelHeaderClass}>
237
- <h2 className={sidePanelHeaderTitleClass}>
238
- {t('menus.model_metadata.role.assign_users_nav_title')}
239
- </h2>
240
- </div>
241
- <nav className={clsx(scrollColClass, 'p-2')}>
242
- <ul className="space-y-1">
243
- {libraries.map((lib) => {
244
- const isNavActive = lib.metadataId === activeMetadataId
245
- return (
246
- <li key={lib.metadataId}>
247
- <button
248
- type="button"
249
- onClick={() => scrollToMeta(lib.metadataId)}
250
- className={clsx(
251
- 'w-full rounded-l-lg border-r-[3px] px-2 py-2 text-left text-sm transition-colors',
252
- isNavActive
253
- ? 'border-r-blue-500 bg-blue-50 font-medium text-blue-900 dark:border-r-blue-400 dark:bg-blue-950/40 dark:text-blue-100'
254
- : 'border-r-transparent text-gray-800 hover:bg-gray-100 dark:text-gray-100 dark:hover:bg-gray-700/50',
255
- )}
256
- >
257
- <div className="line-clamp-2">{lib.subject || lib.metadataId}</div>
258
- <div
259
- className={clsx(
260
- 'mt-0.5 line-clamp-1 text-xs',
261
- isNavActive
262
- ? 'text-blue-700/80 dark:text-blue-300/80'
263
- : 'text-gray-500 dark:text-gray-400',
264
- )}
265
- >
266
- {lib.databaseName ?? '—'}
267
- </div>
268
- </button>
269
- </li>
270
- )
271
- })}
272
- </ul>
273
- </nav>
274
- </div>
275
- )
276
- }
277
-
278
- return (
279
- <div className={rootLayoutClass}>
280
- <div
281
- className={clsx(
282
- 'flex min-w-0 w-72 shrink-0 flex-col overflow-hidden rounded-xl border border-gray-200 bg-white shadow-sm dark:border-gray-700 dark:bg-gray-800',
283
- hasLayoutLock && 'h-full min-h-0',
284
- )}
285
- >
286
- <div className="flex min-h-[44px] shrink-0 items-center justify-between gap-2 border-b border-gray-200 bg-gray-50 px-3 py-2.5 dark:border-gray-700 dark:bg-gray-700/50">
287
- <h2 className="min-w-0 flex-1 text-xs font-semibold uppercase tracking-wider text-gray-700 dark:text-gray-300">
288
- {t('menus.model_metadata.role.assign_users_user_list')}
289
- </h2>
290
- <CxButton
291
- type="primary"
292
- size="small"
293
- icon={<Plus size={14} />}
294
- onClick={onAddUsersClick}
295
- >
296
- {t('menus.model_metadata.role.assign_users_add_user')}
297
- </CxButton>
298
- </div>
299
- <div className={clsx(scrollColClass, 'p-2')}>
300
- {loading ? (
301
- <ul className="space-y-2 px-1 py-1">
302
- {Array.from({ length: 5 }).map((_, i) => (
303
- <li key={i}>
304
- <CxSkeleton active paragraph={{ rows: 2, width: ['80%', '50%'] }} title={false} />
305
- </li>
306
- ))}
307
- </ul>
308
- ) : users.length === 0 ? (
309
- <p className="px-2 py-6 text-center text-sm text-gray-500">
310
- {t('menus.model_metadata.role.assign_users_no_user')}
311
- </p>
312
- ) : (
313
- <ul className="space-y-1">
314
- {users.map((u) => {
315
- const isActive = u.userId === activeUserId
316
- return (
317
- <li key={u.userId}>
318
- <div
319
- className={clsx(
320
- 'flex w-full items-stretch overflow-hidden rounded-lg border text-left text-sm transition-colors',
321
- isActive
322
- ? 'border-blue-300 bg-blue-50 text-blue-900 dark:border-blue-700 dark:bg-blue-950/40 dark:text-blue-100'
323
- : 'border-transparent bg-transparent text-gray-800 hover:bg-gray-50 dark:text-gray-100 dark:hover:bg-gray-700/40',
324
- )}
325
- >
326
- <button
327
- type="button"
328
- onClick={() => onActiveUserIdChange(u.userId)}
329
- className="min-w-0 flex-1 px-3 py-2 text-left"
330
- >
331
- <div className="line-clamp-1 font-medium">
332
- {u.userName || u.userId}
333
- </div>
334
- {u.userPhone ? (
335
- <div className="mt-0.5 line-clamp-1 text-xs text-gray-500 dark:text-gray-400">
336
- {u.userPhone}
337
- </div>
338
- ) : null}
339
- </button>
340
- <div className="flex shrink-0 items-center px-2">
341
- <CxButton.Icon
342
- type="default"
343
- title={t('menus.model_metadata.role.assign_users_remove_user')}
344
- icon={<Trash2 size={14} />}
345
- onClick={() => onRemoveUser(u.userId)}
346
- />
347
- </div>
348
- </div>
349
- </li>
350
- )
351
- })}
352
- </ul>
353
- )}
354
- </div>
355
- </div>
356
-
357
- <div
358
- className={clsx(
359
- 'flex min-w-0 flex-1 overflow-hidden rounded-xl border border-gray-200 bg-gray-50 dark:border-gray-700 dark:bg-gray-900/50',
360
- hasLayoutLock && 'h-full min-h-0',
361
- )}
362
- >
363
- {renderMetaNav()}
364
-
365
- <div className="flex min-w-0 flex-1 flex-col overflow-hidden">
366
- <div className={sidePanelHeaderClass}>
367
- <h2 className={sidePanelHeaderTitleClass}>
368
- {t('menus.model_metadata.role.assign_users_permission_panel')}
369
- {activeUser?.userName ? ` — ${activeUser.userName}` : ''}
370
- </h2>
371
- </div>
372
- <div ref={contentScrollRef} className={clsx(scrollColClass, 'p-3')}>
373
- {loading ? (
374
- <div className="space-y-4">
375
- {Array.from({ length: 3 }).map((_, i) => (
376
- <CxSkeleton key={i} active paragraph={{ rows: 4 }} />
377
- ))}
378
- </div>
379
- ) : !activeUser ? (
380
- <p className="py-10 text-center text-sm text-gray-500">
381
- {t('menus.model_metadata.role.assign_users_no_user')}
382
- </p>
383
- ) : libraries.length === 0 ? (
384
- <p className="py-10 text-center text-sm text-gray-500">{t('common.no_data')}</p>
385
- ) : (
386
- <div className="space-y-4">{libraries.map(renderLibrarySection)}</div>
387
- )}
388
- </div>
389
- </div>
390
- </div>
391
- </div>
392
- )
393
- }