cx-chat 0.0.2 → 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 -272
  405. /package/{public → dist}/favicon.ico +0 -0
  406. /package/{public → dist}/vite.svg +0 -0
@@ -1,698 +0,0 @@
1
- import { CxCheckbox, CxInput, CxSkeleton } from '@cx-ui'
2
- import { Spin } from 'antd'
3
- import clsx from 'clsx'
4
- import type { TFunction } from 'i18next'
5
- import React, {
6
- memo,
7
- startTransition,
8
- useCallback,
9
- useDeferredValue,
10
- useEffect,
11
- useMemo,
12
- useRef,
13
- useState,
14
- useTransition,
15
- } from 'react'
16
- import { useTranslation } from 'react-i18next'
17
-
18
- export function colKey(metadataId: string, tableId: string, columnId: string) {
19
- return `${metadataId}::${tableId}::${columnId}`
20
- }
21
-
22
- /** 提交与勾选态仅用后端表 id(id / tableId),不用 schema+表名占位 */
23
- function tableIdForPermission(tb: any) {
24
- return String(tb?.id ?? tb?.tableId ?? '').trim()
25
- }
26
-
27
- /** 列表卡片 React key:优先表 id,否则用 schema+表名避免冲突 */
28
- function tableCardDomKey(tb: any) {
29
- const id = tableIdForPermission(tb)
30
- if (id) return id
31
- return `${tb?.tableSchema ?? ''}::${tb?.tableName ?? ''}` || 'table'
32
- }
33
-
34
- /** 提交与勾选态仅用后端列 id(id / columnId),不用列名占位 */
35
- function columnIdForPermission(col: any) {
36
- return String(col?.id ?? col?.columnId ?? '').trim()
37
- }
38
-
39
- function collectColKeysForTables(metadataId: string, tables: any[]): string[] {
40
- const keys: string[] = []
41
- for (const tb of tables || []) {
42
- const tid = tableIdForPermission(tb)
43
- if (!tid) continue
44
- for (const col of tb.columns || []) {
45
- const cid = columnIdForPermission(col)
46
- if (!cid) continue
47
- keys.push(colKey(metadataId, tid, cid))
48
- }
49
- }
50
- return keys
51
- }
52
-
53
- function clearMetaKeys(prev: Record<string, boolean>, metaId: string) {
54
- const prefix = `${metaId}::`
55
- const toRemove: string[] = []
56
- for (const k of Object.keys(prev)) {
57
- if (k.startsWith(prefix)) toRemove.push(k)
58
- }
59
- if (!toRemove.length) return prev
60
- const next = { ...prev }
61
- for (const k of toRemove) delete next[k]
62
- return next
63
- }
64
-
65
- function mergeKeysTrue(prev: Record<string, boolean>, keys: string[]) {
66
- if (!keys.length) return prev
67
- for (const k of keys) {
68
- if (!prev[k]) {
69
- const next = { ...prev }
70
- for (const kk of keys) next[kk] = true
71
- return next
72
- }
73
- }
74
- return prev
75
- }
76
-
77
- /** 左侧跨多库全选等超大批量:走 startTransition */
78
- const SELECT_BULK_THRESHOLD = 160
79
- /** 单库内全选/清库/整表勾选:列数常介于几十~几百,仍易卡主线程,阈值要明显低于左侧 */
80
- const SINGLE_META_BULK_KEYS = 40
81
-
82
- type RolePermissionTableCardProps = {
83
- tb: any
84
- mid: string
85
- /** 列勾选展示用(useDeferredValue 传入),与表头「全选」态解耦,减轻全选尖峰 */
86
- fieldSelected: Record<string, boolean>
87
- tableHeaderChecked: boolean
88
- tableHeaderIndeterminate: boolean
89
- toggleTable: (metadataId: string, tableId: string, columns: any[], checked: boolean) => void
90
- toggleCol: (k: string, checked: boolean) => void
91
- t: TFunction
92
- }
93
-
94
- const RolePermissionTableCard = memo(function RolePermissionTableCard({
95
- tb,
96
- mid,
97
- fieldSelected,
98
- tableHeaderChecked,
99
- tableHeaderIndeterminate,
100
- toggleTable,
101
- toggleCol,
102
- t,
103
- }: RolePermissionTableCardProps) {
104
- const tid = tableIdForPermission(tb)
105
- const cols = Array.isArray(tb.columns) ? tb.columns : []
106
- const tState = { checked: tableHeaderChecked, indeterminate: tableHeaderIndeterminate }
107
- const tableLabel = [tb.tableSchema, tb.tableName].filter(Boolean).join('.') || tid || '-'
108
-
109
- return (
110
- <div className="rounded-lg border border-gray-200 bg-white p-3 shadow-sm [content-visibility:auto] dark:border-gray-600 dark:bg-gray-800">
111
- <div className="mb-2 flex flex-wrap items-start justify-between gap-2">
112
- <div className="min-w-0 flex-1">
113
- <div className="font-medium text-gray-900 dark:text-gray-100">{tableLabel}</div>
114
- {tb.tableComment ? (
115
- <div className="mt-0.5 text-xs text-gray-500 dark:text-gray-400">{tb.tableComment}</div>
116
- ) : null}
117
- </div>
118
- <div className="flex shrink-0 items-center gap-2">
119
- <CxCheckbox
120
- checked={tState.checked}
121
- disabled={!tid}
122
- onChange={(checked) => toggleTable(mid, tid, cols, checked)}
123
- aria-label={t('menus.model_metadata.role.select_all_table')}
124
- />
125
- <span className="text-sm text-gray-700 dark:text-gray-200">
126
- {t('menus.model_metadata.role.select_all_table')}
127
- </span>
128
- </div>
129
- </div>
130
- {!tid ? (
131
- <div className="rounded-md bg-amber-50 px-2 py-2 text-xs text-amber-900 dark:bg-amber-950/40 dark:text-amber-100">
132
- {t('menus.model_metadata.role.role_permission_table_missing_id')}
133
- </div>
134
- ) : (
135
- <div className="grid gap-2" style={{ gridTemplateColumns: 'repeat(auto-fill, minmax(240px, 1fr))' }}>
136
- {cols.map((col: any) => {
137
- const cid = columnIdForPermission(col)
138
- if (!cid) return null
139
- const k = colKey(mid, tid, cid)
140
- const cname = col.columnName ?? cid
141
- const comment = col.commentText ?? col.columnComment ?? ''
142
- return (
143
- <label
144
- key={k}
145
- className="flex cursor-pointer items-start gap-2 rounded-md border border-gray-100 bg-gray-50/80 p-2 dark:border-gray-600 dark:bg-gray-900/40"
146
- >
147
- <CxCheckbox
148
- checked={!!fieldSelected[k]}
149
- onChange={(checked) => toggleCol(k, checked)}
150
- className="mt-0.5"
151
- aria-label={cname}
152
- />
153
- <span className="min-w-0 flex-1 text-sm">
154
- <span className="font-medium text-gray-900 dark:text-gray-100">{cname}</span>
155
- {comment ? (
156
- <span className="mt-0.5 block text-xs text-gray-500 dark:text-gray-400">{comment}</span>
157
- ) : null}
158
- </span>
159
- </label>
160
- )
161
- })}
162
- </div>
163
- )}
164
- </div>
165
- )
166
- })
167
-
168
- type Props = {
169
- active: boolean
170
- /** 外层每次打开递增,用于在弹窗不关的情况下强制重拉左侧列表与右侧 schema */
171
- bootstrapKey?: number
172
- maxHeightClass?: string
173
- /** 以 metadataId 为 key,避免切换时反复 find */
174
- metadataById: Record<string, any>
175
- metadataOrder: string[]
176
- listLoading: boolean
177
- selected: Record<string, boolean>
178
- onSelectedChange: (next: Record<string, boolean> | ((prev: Record<string, boolean>) => Record<string, boolean>)) => void
179
- }
180
-
181
- export default function RolePermissionAssignPanel({
182
- active,
183
- bootstrapKey = 0,
184
- maxHeightClass,
185
- metadataById,
186
- metadataOrder,
187
- listLoading,
188
- selected,
189
- onSelectedChange,
190
- }: Props) {
191
- const { t } = useTranslation()
192
- const [leftFilter, setLeftFilter] = useState('')
193
- const [activeMetadataId, setActiveMetadataId] = useState<string | null>(null)
194
- const [leftBulkBusy, setLeftBulkBusy] = useState(false)
195
- /** 仅用于「当前库 + 大批量改 selected」:pending 时卸载右侧字段树,等同左侧勾选非当前库时未挂载那些列 */
196
- const [isRightFieldsBulkPending, startRightFieldsBulk] = useTransition()
197
-
198
- const schemaByMetaId = useMemo(() => {
199
- const next: Record<string, any[]> = {}
200
- for (const id of metadataOrder) {
201
- const tables = metadataById[id]?.tables
202
- if (Array.isArray(tables)) next[id] = tables
203
- }
204
- return next
205
- }, [metadataOrder, metadataById])
206
-
207
- const metadataRowsView = useMemo(() => {
208
- return metadataOrder.map((id) => {
209
- const b = metadataById[id]
210
- if (!b) return null
211
- return { ...b, id, metadataId: id }
212
- })
213
- }, [metadataOrder, metadataById])
214
-
215
- const filteredMetadataRows = useMemo(() => {
216
- const rows = metadataRowsView.filter(Boolean) as any[]
217
- const q = leftFilter.trim().toLowerCase()
218
- if (!q) return rows
219
- return rows.filter((row) => {
220
- const blob = [row.subject, row.databaseName, row.dbType]
221
- .map((x) => String(x ?? ''))
222
- .join(' ')
223
- .toLowerCase()
224
- return blob.includes(q)
225
- })
226
- }, [metadataRowsView, leftFilter])
227
-
228
- const activeRow = useMemo(() => {
229
- if (!activeMetadataId) return null
230
- const b = metadataById[activeMetadataId]
231
- if (!b) return null
232
- return { ...b, id: activeMetadataId, metadataId: activeMetadataId }
233
- }, [metadataById, activeMetadataId])
234
-
235
- const itemTables = useMemo(() => {
236
- if (!activeMetadataId) return []
237
- const t = schemaByMetaId[activeMetadataId]
238
- return Array.isArray(t) ? t : []
239
- }, [activeMetadataId, schemaByMetaId])
240
-
241
- useEffect(() => {
242
- if (!active) {
243
- setLeftFilter('')
244
- setLeftBulkBusy(false)
245
- setActiveMetadataId(null)
246
- return
247
- }
248
- setLeftFilter('')
249
- setLeftBulkBusy(false)
250
- }, [active, bootstrapKey])
251
-
252
- useEffect(() => {
253
- if (!active || !metadataOrder.length) {
254
- setActiveMetadataId(null)
255
- return
256
- }
257
- const firstId = metadataOrder[0]
258
- if (firstId == null || String(firstId).trim() === '') {
259
- setActiveMetadataId(null)
260
- return
261
- }
262
- setActiveMetadataId((cur) => {
263
- if (cur != null && metadataById[cur] != null && metadataOrder.includes(cur)) return cur
264
- return String(firstId)
265
- })
266
- }, [active, bootstrapKey, metadataOrder, metadataById])
267
-
268
- useEffect(() => {
269
- if (!active || !filteredMetadataRows.length) return
270
- if (!filteredMetadataRows.some((r) => String(r?.id) === activeMetadataId)) {
271
- setActiveMetadataId(String(filteredMetadataRows[0].id))
272
- }
273
- }, [active, filteredMetadataRows, activeMetadataId])
274
-
275
- const getTablesForMeta = useCallback(
276
- (metaId: string) => {
277
- const t = schemaByMetaId[metaId]
278
- return Array.isArray(t) ? t : []
279
- },
280
- [schemaByMetaId],
281
- )
282
-
283
- const selectAllForMetaWithTables = useCallback(
284
- (metaId: string, tables: any[]) => {
285
- const keys = collectColKeysForTables(metaId, tables)
286
- if (!keys.length) return
287
- const run = () => onSelectedChange((prev) => mergeKeysTrue(prev, keys))
288
- const cur = activeMetadataId != null ? String(activeMetadataId) : ''
289
- if (cur && metaId === cur) startRightFieldsBulk(run)
290
- else startTransition(run)
291
- },
292
- [onSelectedChange, activeMetadataId],
293
- )
294
-
295
- const clearMeta = useCallback(
296
- (metaId: string) => {
297
- const prefix = `${metaId}::`
298
- let n = 0
299
- for (const k of Object.keys(selected)) {
300
- if (k.startsWith(prefix)) n += 1
301
- }
302
- const run = () => onSelectedChange((prev) => clearMetaKeys(prev, metaId))
303
- const cur = activeMetadataId != null ? String(activeMetadataId) : ''
304
- if (cur && metaId === cur && n > 8) startRightFieldsBulk(run)
305
- else if (n > 8) startTransition(run)
306
- else run()
307
- },
308
- [onSelectedChange, selected, activeMetadataId],
309
- )
310
-
311
- const handleLeftMetaToggle = useCallback(
312
- (metaId: string, checked: boolean) => {
313
- if (!checked) {
314
- clearMeta(metaId)
315
- return
316
- }
317
- const tables = getTablesForMeta(metaId)
318
- selectAllForMetaWithTables(metaId, tables)
319
- },
320
- [clearMeta, getTablesForMeta, selectAllForMetaWithTables],
321
- )
322
-
323
- const isMetaFullySelected = useCallback(
324
- (metaId: string) => {
325
- const tables = schemaByMetaId[metaId]
326
- if (!tables?.length) return false
327
- const keys = collectColKeysForTables(metaId, tables)
328
- if (!keys.length) return false
329
- return keys.every((k) => selected[k])
330
- },
331
- [schemaByMetaId, selected],
332
- )
333
-
334
- const leftListAllSelected = useMemo(() => {
335
- if (!filteredMetadataRows.length) return false
336
- for (const row of filteredMetadataRows) {
337
- const id = String(row?.id ?? '')
338
- if (!id) return false
339
- if (!isMetaFullySelected(id)) return false
340
- }
341
- return true
342
- }, [filteredMetadataRows, isMetaFullySelected])
343
-
344
- const handleLeftListSelectAll = useCallback(
345
- (checked: boolean) => {
346
- if (!filteredMetadataRows.length) return
347
- if (!checked) {
348
- const idSet = new Set(
349
- filteredMetadataRows.map((r) => String(r?.id ?? '')).filter(Boolean),
350
- )
351
- let n = 0
352
- for (const k of Object.keys(selected)) {
353
- const i1 = k.indexOf('::')
354
- if (i1 < 0) continue
355
- if (idSet.has(k.slice(0, i1))) n += 1
356
- }
357
- const run = () =>
358
- onSelectedChange((prev) => {
359
- let next = { ...prev }
360
- for (const id of idSet) {
361
- next = clearMetaKeys(next, id)
362
- }
363
- return next
364
- })
365
- const cur = activeMetadataId != null ? String(activeMetadataId) : ''
366
- const touchesCurrentClear = Boolean(cur && idSet.has(cur))
367
- if (touchesCurrentClear && n > SINGLE_META_BULK_KEYS) startRightFieldsBulk(run)
368
- else if (n > SELECT_BULK_THRESHOLD) startTransition(run)
369
- else run()
370
- return
371
- }
372
- setLeftBulkBusy(true)
373
- try {
374
- const keysToAdd: string[] = []
375
- for (const row of filteredMetadataRows) {
376
- const id = String(row?.id ?? '')
377
- if (!id) continue
378
- keysToAdd.push(...collectColKeysForTables(id, getTablesForMeta(id)))
379
- }
380
- const run = () => onSelectedChange((prev) => mergeKeysTrue(prev, keysToAdd))
381
- const cur = activeMetadataId != null ? String(activeMetadataId) : ''
382
- const touchesCurrent =
383
- Boolean(cur) && keysToAdd.some((k) => k.startsWith(`${cur}::`))
384
- if (touchesCurrent && keysToAdd.length > SINGLE_META_BULK_KEYS) startRightFieldsBulk(run)
385
- else if (keysToAdd.length > SELECT_BULK_THRESHOLD) startTransition(run)
386
- else run()
387
- } finally {
388
- setLeftBulkBusy(false)
389
- }
390
- },
391
- [filteredMetadataRows, getTablesForMeta, onSelectedChange, selected, activeMetadataId],
392
- )
393
-
394
- const toggleCol = useCallback(
395
- (k: string, checked: boolean) => {
396
- onSelectedChange((prev) => ({ ...prev, [k]: checked }))
397
- },
398
- [onSelectedChange],
399
- )
400
-
401
- const tableCheckboxState = useCallback(
402
- (metadataId: string, tableId: string, columns: any[]) => {
403
- if (!String(metadataId ?? '').trim() || !String(tableId ?? '').trim()) {
404
- return { checked: false, indeterminate: false }
405
- }
406
- const keys: string[] = []
407
- for (const col of columns || []) {
408
- const cid = columnIdForPermission(col)
409
- if (!cid) continue
410
- keys.push(colKey(metadataId, tableId, cid))
411
- }
412
- if (!keys.length) return { checked: false, indeterminate: false }
413
- let on = 0
414
- for (const k of keys) {
415
- if (selected[k]) on += 1
416
- }
417
- return {
418
- checked: on === keys.length && keys.length > 0,
419
- indeterminate: on > 0 && on < keys.length,
420
- }
421
- },
422
- [selected],
423
- )
424
-
425
- const toggleTable = useCallback(
426
- (metadataId: string, tableId: string, columns: any[], checked: boolean) => {
427
- if (!String(metadataId ?? '').trim() || !String(tableId ?? '').trim()) return
428
- const cols = columns || []
429
- const run = () =>
430
- onSelectedChange((prev) => {
431
- const next = { ...prev }
432
- for (const col of cols) {
433
- const cid = columnIdForPermission(col)
434
- if (!cid) continue
435
- next[colKey(metadataId, tableId, cid)] = checked
436
- }
437
- return next
438
- })
439
- const cur = activeMetadataId != null ? String(activeMetadataId) : ''
440
- if (cur && metadataId === cur && cols.length > SINGLE_META_BULK_KEYS) startRightFieldsBulk(run)
441
- else if (cols.length > SINGLE_META_BULK_KEYS) startTransition(run)
442
- else run()
443
- },
444
- [onSelectedChange, activeMetadataId],
445
- )
446
-
447
- const mid = activeMetadataId ?? ''
448
-
449
- /** 右侧字段区展示用:与 transition 批量更新配合,把海量 Checkbox 的提交拆到多帧 */
450
- const fieldSelected = useDeferredValue(selected)
451
-
452
- const rightAllSelected = useMemo(() => {
453
- if (!mid || !itemTables.length) return false
454
- const keys = collectColKeysForTables(mid, itemTables)
455
- if (!keys.length) return false
456
- return keys.every((k) => selected[k])
457
- }, [mid, itemTables, selected])
458
-
459
- const fieldsScrollRef = useRef<HTMLDivElement>(null)
460
-
461
- const hasLayoutLock = Boolean(maxHeightClass && String(maxHeightClass).trim())
462
- const rootLayoutClass = clsx(
463
- 'flex min-h-0 gap-4 overflow-hidden',
464
- hasLayoutLock ? clsx(maxHeightClass, 'min-h-0 flex-1') : 'min-h-[280px]',
465
- )
466
- const scrollColClass = 'min-h-0 flex-1 basis-0 overflow-y-auto overflow-x-hidden'
467
-
468
- if (!active) return null
469
-
470
- return (
471
- <div className={rootLayoutClass}>
472
- <div
473
- className={clsx(
474
- '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',
475
- hasLayoutLock && 'h-full min-h-0',
476
- )}
477
- >
478
- <div className="flex min-h-[44px] shrink-0 items-center justify-between gap-3 border-b border-gray-200 bg-gray-50 px-3 py-2.5 dark:border-gray-700 dark:bg-gray-700/50">
479
- <h2 className="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">
480
- {t('menus.model_metadata.role.role_permission_metadata_list')}
481
- </h2>
482
- {!listLoading && metadataOrder.length > 0 && filteredMetadataRows.length > 0 ? (
483
- <div className="flex shrink-0 select-none items-center gap-1.5">
484
- {leftBulkBusy ? (
485
- <Spin size="small" />
486
- ) : (
487
- <>
488
- <CxCheckbox
489
- checked={leftListAllSelected}
490
- onChange={(c) => handleLeftListSelectAll(c)}
491
- className="shrink-0"
492
- aria-label={t('menus.model_metadata.role.role_permission_select_all')}
493
- />
494
- <button
495
- type="button"
496
- onClick={() => handleLeftListSelectAll(!leftListAllSelected)}
497
- className="whitespace-nowrap text-left text-[11px] font-medium text-gray-600 underline-offset-2 hover:underline dark:text-gray-300"
498
- >
499
- {t('menus.model_metadata.role.role_permission_select_all')}
500
- </button>
501
- </>
502
- )}
503
- </div>
504
- ) : null}
505
- </div>
506
- <div className="shrink-0 border-b border-gray-200 px-3 py-2 dark:border-gray-700">
507
- <CxInput
508
- allowClear
509
- disabled={listLoading}
510
- value={leftFilter}
511
- onChange={(e) => setLeftFilter(e.target.value)}
512
- placeholder={t('menus.model_metadata.role.role_permission_filter_placeholder')}
513
- className="w-full"
514
- />
515
- </div>
516
- <div className={clsx(scrollColClass, 'p-2')}>
517
- {listLoading ? (
518
- <ul className="space-y-2 px-1 py-1">
519
- {Array.from({ length: 8 }).map((_, i) => (
520
- <li key={i}>
521
- <CxSkeleton
522
- active
523
- avatar={{ size: 20, shape: 'square' }}
524
- paragraph={{ rows: 2, width: ['92%', '65%'] }}
525
- title={false}
526
- />
527
- </li>
528
- ))}
529
- </ul>
530
- ) : metadataOrder.length === 0 ? (
531
- <p className="px-2 py-6 text-center text-sm text-gray-500">{t('menus.model_metadata.role.role_permission_no_metadata')}</p>
532
- ) : filteredMetadataRows.length === 0 ? (
533
- <p className="px-2 py-6 text-center text-sm text-gray-500">{t('common.no_data')}</p>
534
- ) : (
535
- <ul className="space-y-1">
536
- {filteredMetadataRows.map((row) => {
537
- const id = String(row?.id ?? '')
538
- const isActive = id === activeMetadataId
539
- return (
540
- <li key={id || JSON.stringify(row)}>
541
- <div
542
- className={clsx(
543
- 'flex w-full items-stretch overflow-hidden rounded-lg border text-left text-sm transition-colors',
544
- isActive
545
- ? 'border-blue-300 bg-blue-50 text-blue-900 dark:border-blue-700 dark:bg-blue-950/40 dark:text-blue-100'
546
- : 'border-transparent bg-transparent text-gray-800 dark:text-gray-100',
547
- )}
548
- >
549
- <div
550
- className="flex shrink-0 items-center px-2 py-2"
551
- onClick={(e) => e.stopPropagation()}
552
- onKeyDown={(e) => e.stopPropagation()}
553
- role="presentation"
554
- >
555
- {leftBulkBusy ? (
556
- <Spin size="small" />
557
- ) : (
558
- <CxCheckbox
559
- checked={isMetaFullySelected(id)}
560
- onChange={(c) => handleLeftMetaToggle(id, c)}
561
- aria-label={String(row.subject ?? id)}
562
- />
563
- )}
564
- </div>
565
- <button
566
- type="button"
567
- onClick={() => id && setActiveMetadataId(id)}
568
- className={clsx(
569
- 'min-w-0 flex-1 px-2 py-2 text-left hover:bg-gray-100/80 dark:hover:bg-gray-700/50',
570
- isActive && 'hover:bg-blue-100/80 dark:hover:bg-blue-950/60',
571
- )}
572
- >
573
- <div className="line-clamp-2 font-medium">{row.subject ?? id}</div>
574
- <div className="mt-0.5 line-clamp-1 text-xs text-gray-500 dark:text-gray-400">
575
- {(row.databaseName ?? '-') + ' / ' + (row.dbType ?? '-')}
576
- </div>
577
- </button>
578
- </div>
579
- </li>
580
- )
581
- })}
582
- </ul>
583
- )}
584
- </div>
585
- </div>
586
-
587
- <div
588
- className={clsx(
589
- 'flex min-w-0 flex-1 flex-col overflow-hidden rounded-xl border border-gray-200 bg-gray-50 dark:border-gray-700 dark:bg-gray-900/50',
590
- hasLayoutLock && 'h-full min-h-0',
591
- )}
592
- >
593
- <div className="flex min-h-[44px] shrink-0 items-center justify-between gap-3 border-b border-gray-200 bg-gray-50 px-3 py-2.5 dark:border-gray-700 dark:bg-gray-700/50">
594
- <h2 className="line-clamp-2 min-w-0 flex-1 py-0.5 text-xs font-semibold uppercase tracking-wider text-gray-700 dark:text-gray-300">
595
- {t('menus.model_metadata.role.role_permission_fields_panel')}
596
- {activeRow?.subject ? ` — ${activeRow.subject}` : ''}
597
- </h2>
598
- {mid && itemTables.length > 0 ? (
599
- <div className="flex shrink-0 select-none items-center gap-1.5">
600
- <CxCheckbox
601
- checked={rightAllSelected}
602
- onChange={(c) => {
603
- if (c) selectAllForMetaWithTables(mid, itemTables)
604
- else clearMeta(mid)
605
- }}
606
- className="shrink-0"
607
- aria-label={t('menus.model_metadata.role.role_permission_select_all')}
608
- />
609
- <button
610
- type="button"
611
- onClick={() => {
612
- if (rightAllSelected) clearMeta(mid)
613
- else selectAllForMetaWithTables(mid, itemTables)
614
- }}
615
- className="whitespace-nowrap text-left text-[11px] font-medium text-gray-600 underline-offset-2 hover:underline disabled:cursor-not-allowed disabled:no-underline dark:text-gray-300"
616
- >
617
- {t('menus.model_metadata.role.role_permission_select_all')}
618
- </button>
619
- </div>
620
- ) : null}
621
- </div>
622
- <div
623
- ref={fieldsScrollRef}
624
- className={clsx(scrollColClass, 'relative p-3')}
625
- aria-busy={listLoading || isRightFieldsBulkPending || undefined}
626
- >
627
- {listLoading ? (
628
- <div className="space-y-4">
629
- {[0, 1].map((block) => (
630
- <div
631
- key={block}
632
- className="rounded-lg border border-gray-200 bg-white p-3 shadow-sm dark:border-gray-600 dark:bg-gray-800"
633
- >
634
- <CxSkeleton active title={{ width: `${48 + block * 8}%` }} paragraph={{ rows: 1, width: '100%' }} />
635
- <div
636
- className="mt-3 grid gap-2"
637
- style={{ gridTemplateColumns: 'repeat(auto-fill, minmax(200px, 1fr))' }}
638
- >
639
- {Array.from({ length: 6 }).map((_, cell) => (
640
- <CxSkeleton
641
- key={cell}
642
- active
643
- title={false}
644
- paragraph={{ rows: 2, width: ['100%', '72%'] }}
645
- />
646
- ))}
647
- </div>
648
- </div>
649
- ))}
650
- </div>
651
- ) : !mid ? (
652
- <p className="py-8 text-center text-sm text-gray-500">{t('common.no_data')}</p>
653
- ) : itemTables.length === 0 ? (
654
- <p className="py-8 text-center text-sm text-gray-500">{t('menus.model_metadata.role.role_permission_schema_empty')}</p>
655
- ) : (
656
- <>
657
- <section
658
- className={clsx(
659
- 'space-y-4 transition-opacity duration-150',
660
- isRightFieldsBulkPending && 'pointer-events-none opacity-50',
661
- )}
662
- >
663
- {(isRightFieldsBulkPending ? itemTables.slice(0, 1) : itemTables).map((tb: any) => {
664
- const tid = tableIdForPermission(tb)
665
- const cols = Array.isArray(tb.columns) ? tb.columns : []
666
- const tState = tid
667
- ? tableCheckboxState(mid, tid, cols)
668
- : { checked: false, indeterminate: false }
669
- return (
670
- <RolePermissionTableCard
671
- key={`${mid}::${tableCardDomKey(tb)}`}
672
- tb={tb}
673
- mid={mid}
674
- fieldSelected={fieldSelected}
675
- tableHeaderChecked={tState.checked}
676
- tableHeaderIndeterminate={tState.indeterminate}
677
- toggleTable={toggleTable}
678
- toggleCol={toggleCol}
679
- t={t}
680
- />
681
- )
682
- })}
683
- </section>
684
- {isRightFieldsBulkPending ? (
685
- <div className="pointer-events-none absolute inset-0 z-[1] flex flex-col items-center justify-center gap-2 bg-white/50 backdrop-blur-[2px] dark:bg-gray-950/45">
686
- <Spin size="large" />
687
- <p className="max-w-[240px] px-4 text-center text-xs leading-relaxed text-gray-700 dark:text-gray-200">
688
- {t('common.loading')}
689
- </p>
690
- </div>
691
- ) : null}
692
- </>
693
- )}
694
- </div>
695
- </div>
696
- </div>
697
- )
698
- }