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,611 +0,0 @@
1
- import type { ButtonProps } from 'antd'
2
- import { Button } from 'antd'
3
- import clsx from 'clsx'
4
- import {
5
- Check,
6
- CircleCheck,
7
- CircleX,
8
- Download,
9
- Edit,
10
- Edit2,
11
- Eye,
12
- Plus,
13
- Star,
14
- Trash2,
15
- Upload,
16
- X,
17
- } from 'lucide-react'
18
- import type { CSSProperties, ReactNode } from 'react'
19
- import React from 'react'
20
- import { useTranslation } from 'react-i18next'
21
- import type { CxTooltipTone } from '../tooltip'
22
- import { CxTooltip } from '../tooltip'
23
- import './index.less'
24
-
25
- /** 方框风格图标容器:用于让图标呈现“带方框”的视觉效果(保持整体占位与 iconSize 一致) */
26
- function SquareIconFrame({ size, children }: { size: number; children: React.ReactNode }) {
27
- return (
28
- <span
29
- className="inline-flex items-center justify-center border-2 border-current rounded-[2px] box-border"
30
- style={{ width: size, height: size }}
31
- >
32
- {children}
33
- </span>
34
- )
35
- }
36
-
37
- function toCssLength(value: number | string | undefined | null): string | undefined {
38
- if (value == null) return undefined
39
- return typeof value === 'number' ? `${value}px` : value
40
- }
41
-
42
- const ICON_TYPE_CLASS: Record<string, string> = {
43
- default: 'text-gray-500 hover:text-gray-700 hover:bg-gray-50 dark:hover:bg-gray-800',
44
- primary:
45
- 'text-gray-500 hover:text-blue-600 hover:bg-blue-50 dark:hover:bg-blue-900/20 active:bg-blue-100 dark:active:bg-blue-900/40',
46
- /** 与 `CxTooltip` success 色(#15803d)同一语义,悬停为绿色系 */
47
- success:
48
- 'text-green-700 hover:bg-green-50 dark:hover:bg-green-900/25 active:bg-green-100 dark:active:bg-green-900/40',
49
- danger:
50
- 'text-red-600 hover:bg-red-50 dark:hover:bg-red-900/20 active:bg-red-100 dark:active:bg-red-900/40',
51
- }
52
-
53
- function normalizeAntdButtonSize(
54
- sizeProp: ButtonProps['size'] | undefined | null,
55
- ): 'small' | 'medium' | 'large' {
56
- if (sizeProp === undefined || sizeProp === null) return 'medium'
57
- if (sizeProp === 'middle') return 'medium'
58
- return sizeProp
59
- }
60
-
61
- /** 与 antd Button 一致,并支持 icon 模式与 height;icon 模式下 `type` 可作色调(含 danger) */
62
- export type CxButtonBaseProps = Omit<ButtonProps, 'type'> & {
63
- buttonType?: 'antd' | 'icon'
64
- height?: number | string
65
- type?: ButtonProps['type'] | 'danger' | 'success'
66
- /** 图标按钮:悬停文案,优先于原生 `title` */
67
- tooltipTitle?: ReactNode
68
- /** 图标按钮:`CxTooltip` 背景语义色 */
69
- tooltipTone?: CxTooltipTone
70
- }
71
-
72
- /** 纯图标按钮:必须传入 `icon`;语义等价于 `buttonType="icon"` 的 `CxButton` */
73
- export type CxButtonIconProps = Omit<CxButtonBaseProps, 'buttonType' | 'icon'> & {
74
- icon: ReactNode
75
- }
76
-
77
- /** 预设图标的变体:默认图标在组件内写死;可选 `icon` 覆盖、`iconSize` 控制边长 */
78
- export type CxButtonIconPresetProps = Omit<CxButtonIconProps, 'icon'> & {
79
- icon?: ReactNode
80
- iconSize?: number
81
- }
82
-
83
- /** 纯图标按钮 / 行内预设(IconEdit 等)默认边长:与列表操作列常用 16 对齐;非列表场景请传 `iconSize` 或自定义 `icon` */
84
- const CX_ICON_PX = 16
85
- /** antd 文字按钮上默认图标的边长(与未传 `icon` 时配套;自定义 `icon` 时忽略) */
86
- const TEXT_BTN_ICON_PX = 16
87
-
88
- export function CxButtonIcon({ icon, ...props }: CxButtonIconProps) {
89
- return <CxButtonPrimitive buttonType="icon" icon={icon} {...props} />
90
- }
91
-
92
- /**
93
- * 与 antd Button 一致:size 支持 large / medium / small;不传 size 默认为 small(表格、搜索、弹窗等)。
94
- * 列表页顶栏「新增」等需显式 `size="medium"` 或 `large`。
95
- * `middle` 为历史别名,内部会规范为 `medium`。
96
- */
97
- function CxButtonPrimitive({
98
- buttonType = 'antd',
99
- height,
100
- style,
101
- icon,
102
- size: sizeProp,
103
- className,
104
- tooltipTitle: tooltipTitleProp,
105
- tooltipTone = 'default',
106
- ...props
107
- }: CxButtonBaseProps) {
108
- if (buttonType === 'icon') {
109
- const {
110
- type: iconTone = 'primary',
111
- title: legacyTitle,
112
- onClick,
113
- disabled,
114
- ...rest
115
- } = props as CxButtonBaseProps & {
116
- type?: 'default' | 'primary' | 'danger' | 'success'
117
- title?: string
118
- }
119
- const tipContent = tooltipTitleProp ?? legacyTitle
120
- const showTip =
121
- tipContent != null &&
122
- tipContent !== '' &&
123
- (typeof tipContent !== 'string' || tipContent.trim() !== '')
124
-
125
- const buttonEl = (
126
- <button
127
- type="button"
128
- disabled={disabled}
129
- onClick={onClick}
130
- aria-label={
131
- showTip && typeof tipContent === 'string' ? tipContent : undefined
132
- }
133
- style={style as CSSProperties | undefined}
134
- {...(rest as React.ButtonHTMLAttributes<HTMLButtonElement>)}
135
- className={clsx(
136
- 'p-1.5 rounded-lg transition-all active:scale-90',
137
- ICON_TYPE_CLASS[iconTone as string] || ICON_TYPE_CLASS.primary,
138
- disabled && 'opacity-50 cursor-not-allowed active:scale-100',
139
- className,
140
- )}>
141
- {icon}
142
- </button>
143
- )
144
-
145
- if (showTip) {
146
- const trigger =
147
- disabled ? (
148
- <span className="inline-flex cursor-not-allowed">{buttonEl}</span>
149
- ) : (
150
- buttonEl
151
- )
152
- return (
153
- <CxTooltip title={tipContent} tone={tooltipTone}>
154
- {trigger}
155
- </CxTooltip>
156
- )
157
- }
158
-
159
- return buttonEl
160
- }
161
-
162
- const sizeForAntd = normalizeAntdButtonSize(sizeProp)
163
-
164
- const styleObj = style && typeof style === 'object' ? style : {}
165
- const fromStyleHeight = styleObj.height
166
- const hasCustomHeight =
167
- (fromStyleHeight !== undefined && fromStyleHeight !== null) ||
168
- (height !== undefined && height !== null)
169
-
170
- const defaultHeightBySize =
171
- sizeForAntd === 'small' ? 32 : sizeForAntd === 'large' ? 44 : 40
172
- const resolved =
173
- fromStyleHeight !== undefined && fromStyleHeight !== null
174
- ? fromStyleHeight
175
- : height !== undefined && height !== null
176
- ? toCssLength(height)
177
- : defaultHeightBySize
178
- const resolvedStr = toCssLength(resolved) ?? String(resolved)
179
-
180
- const { height: _drop, ...restStyle } = styleObj
181
-
182
- const mergedStyle: CSSProperties = {
183
- boxSizing: 'border-box',
184
- ...restStyle,
185
- }
186
- if (hasCustomHeight) {
187
- mergedStyle.height = resolvedStr
188
- mergedStyle.minHeight = resolvedStr
189
- }
190
-
191
- const antdProps = { ...(props as Record<string, unknown>) }
192
- if (antdProps.type === 'success') {
193
- antdProps.type = 'default'
194
- }
195
-
196
- return (
197
- <Button
198
- {...(antdProps as ButtonProps)}
199
- size={sizeForAntd}
200
- icon={icon}
201
- className={clsx(
202
- 'cx-button',
203
- `cx-button--size-${sizeForAntd}`,
204
- className,
205
- )}
206
- style={mergedStyle}
207
- />
208
- )
209
- }
210
-
211
- type VariantProps = CxButtonBaseProps & { children?: ReactNode }
212
-
213
- type VariantPropsWithBuiltInIcon = VariantProps & {
214
- /** 内置默认图标的边长;仅在使用默认图标时生效(`icon` 为 `undefined`) */
215
- iconSize?: number
216
- }
217
-
218
- /** 添加按钮(未传 `icon` 时默认 Plus;不要图标可传 `icon={null}`) */
219
- export function CxButtonAdd({
220
- children,
221
- icon,
222
- iconSize = TEXT_BTN_ICON_PX,
223
- ...props
224
- }: VariantPropsWithBuiltInIcon) {
225
- const { t } = useTranslation()
226
- const resolvedIcon = icon === undefined ? <Plus size={iconSize} /> : icon
227
- return (
228
- <CxButtonPrimitive type="primary" icon={resolvedIcon} {...props}>
229
- {children || t('common.add')}
230
- </CxButtonPrimitive>
231
- )
232
- }
233
-
234
- /** 删除按钮(未传 `icon` 时默认 Trash2;不要图标可传 `icon={null}`) */
235
- export function CxButtonDelete({
236
- children,
237
- icon,
238
- iconSize = TEXT_BTN_ICON_PX,
239
- ...props
240
- }: VariantPropsWithBuiltInIcon) {
241
- const { t } = useTranslation()
242
- const resolvedIcon = icon === undefined ? <Trash2 size={iconSize} /> : icon
243
- return (
244
- <CxButtonPrimitive danger icon={resolvedIcon} {...props}>
245
- {children || t('common.delete')}
246
- </CxButtonPrimitive>
247
- )
248
- }
249
-
250
- /** 确定按钮 */
251
- export function CxButtonOk({ children, ...props }: VariantProps) {
252
- const { t } = useTranslation()
253
- return (
254
- <CxButtonPrimitive type="primary" {...props}>
255
- {children || t('common.ok')}
256
- </CxButtonPrimitive>
257
- )
258
- }
259
-
260
- /** 提交按钮 */
261
- export function CxButtonSubmit({ children, ...props }: VariantProps) {
262
- const { t } = useTranslation()
263
- return (
264
- <CxButtonPrimitive type="primary" htmlType="submit" {...props}>
265
- {children || t('common.submit')}
266
- </CxButtonPrimitive>
267
- )
268
- }
269
-
270
- /**
271
- * 取消按钮(antd 文本按钮:`type="text"` → 无边框、无填充底)。
272
- * 注意:antd 6 仅传 `variant` 而不传 `color` 时不会生效,会回退成 `default`+`outlined`(有边框、浅底)。
273
- * 若需自定义,可同时传 `color` + `variant`,此时不再默认 `type="text"`。
274
- */
275
- export function CxButtonCancel({
276
- children,
277
- type,
278
- color,
279
- variant,
280
- ...props
281
- }: VariantProps) {
282
- const { t } = useTranslation()
283
- if (color != null && variant != null) {
284
- return (
285
- <CxButtonPrimitive {...props} color={color} variant={variant}>
286
- {children || t('common.cancel')}
287
- </CxButtonPrimitive>
288
- )
289
- }
290
- return (
291
- <CxButtonPrimitive {...props} type={type ?? 'text'}>
292
- {children || t('common.cancel')}
293
- </CxButtonPrimitive>
294
- )
295
- }
296
-
297
- /**
298
- * 表单旁辅助按钮:`type="default"` + `height={42}`,与常见表单项/输入框高度对齐(如图标选择、次要操作)。
299
- */
300
- export function CxButtonSecondary({ children, ...props }: VariantProps) {
301
- return (
302
- <CxButtonPrimitive type="default" height={42} {...props}>
303
- {children}
304
- </CxButtonPrimitive>
305
- )
306
- }
307
-
308
- /** 编辑按钮(未传 `icon` 时默认 Edit;不要图标可传 `icon={null}`) */
309
- export function CxButtonEdit({
310
- children,
311
- icon,
312
- iconSize = TEXT_BTN_ICON_PX,
313
- ...props
314
- }: VariantPropsWithBuiltInIcon) {
315
- const { t } = useTranslation()
316
- const resolvedIcon = icon === undefined ? <Edit size={iconSize} /> : icon
317
- return (
318
- <CxButtonPrimitive type="link" icon={resolvedIcon} {...props}>
319
- {children || t('common.edit')}
320
- </CxButtonPrimitive>
321
- )
322
- }
323
-
324
- /** 查看按钮 */
325
- export function CxButtonView({ children, ...props }: VariantProps) {
326
- const { t } = useTranslation()
327
- return (
328
- <CxButtonPrimitive type="link" {...props}>
329
- {children || t('common.view')}
330
- </CxButtonPrimitive>
331
- )
332
- }
333
-
334
- /** 下载按钮 */
335
- export function CxButtonDownload({ children, ...props }: VariantProps) {
336
- const { t } = useTranslation()
337
- return (
338
- <CxButtonPrimitive type="link" {...props}>
339
- {children || t('common.download')}
340
- </CxButtonPrimitive>
341
- )
342
- }
343
-
344
- /** 导出按钮 */
345
- export function CxButtonExport({ children, ...props }: VariantProps) {
346
- const { t } = useTranslation()
347
- return (
348
- <CxButtonPrimitive type="link" {...props}>
349
- {children || t('common.export')}
350
- </CxButtonPrimitive>
351
- )
352
- }
353
-
354
- /** 保存按钮 */
355
- export function CxButtonSave({ children, ...props }: VariantProps) {
356
- const { t } = useTranslation()
357
- return (
358
- <CxButtonPrimitive type="primary" {...props}>
359
- {children || t('common.save')}
360
- </CxButtonPrimitive>
361
- )
362
- }
363
-
364
- /** 编辑图标按钮(默认 Edit2;默认 Tooltip 为「编辑」) */
365
- export function CxButtonIconEdit({
366
- iconSize = CX_ICON_PX,
367
- icon,
368
- tooltipTitle,
369
- title,
370
- tooltipTone = 'primary',
371
- ...rest
372
- }: CxButtonIconPresetProps) {
373
- const { t } = useTranslation()
374
- return (
375
- <CxButtonIcon
376
- icon={icon ?? <Edit2 size={iconSize} />}
377
- tooltipTitle={tooltipTitle ?? title ?? t('common.edit')}
378
- tooltipTone={tooltipTone}
379
- {...rest}
380
- />
381
- )
382
- }
383
-
384
- /** 删除图标按钮(默认 Trash2 + danger 色调;默认 Tooltip 为「删除」) */
385
- export function CxButtonIconDelete({
386
- iconSize = CX_ICON_PX,
387
- icon,
388
- tooltipTitle,
389
- title,
390
- tooltipTone = 'danger',
391
- ...rest
392
- }: CxButtonIconPresetProps) {
393
- const { t } = useTranslation()
394
- return (
395
- <CxButtonIcon
396
- type="danger"
397
- icon={icon ?? <Trash2 size={iconSize} />}
398
- tooltipTitle={tooltipTitle ?? title ?? t('common.delete')}
399
- tooltipTone={tooltipTone}
400
- {...rest}
401
- />
402
- )
403
- }
404
-
405
- /** 查看图标按钮(默认 Tooltip 为「查看」) */
406
- export function CxButtonIconView({
407
- iconSize = CX_ICON_PX,
408
- icon,
409
- tooltipTitle,
410
- title,
411
- tooltipTone = 'default',
412
- ...rest
413
- }: CxButtonIconPresetProps) {
414
- const { t } = useTranslation()
415
- return (
416
- <CxButtonIcon
417
- icon={icon ?? <Eye size={iconSize} />}
418
- tooltipTitle={tooltipTitle ?? title ?? t('common.view')}
419
- tooltipTone={tooltipTone}
420
- {...rest}
421
- />
422
- )
423
- }
424
-
425
- /** 下载图标按钮(默认 Tooltip 为「下载」) */
426
- export function CxButtonIconDownload({
427
- iconSize = CX_ICON_PX,
428
- icon,
429
- tooltipTitle,
430
- title,
431
- tooltipTone = 'primary',
432
- ...rest
433
- }: CxButtonIconPresetProps) {
434
- const { t } = useTranslation()
435
- return (
436
- <CxButtonIcon
437
- icon={icon ?? <Download size={iconSize} />}
438
- tooltipTitle={tooltipTitle ?? title ?? t('common.download')}
439
- tooltipTone={tooltipTone}
440
- {...rest}
441
- />
442
- )
443
- }
444
-
445
- /** 导出图标按钮(默认 Tooltip 为「导出」) */
446
- export function CxButtonIconExport({
447
- iconSize = CX_ICON_PX,
448
- icon,
449
- tooltipTitle,
450
- title,
451
- tooltipTone = 'primary',
452
- ...rest
453
- }: CxButtonIconPresetProps) {
454
- const { t } = useTranslation()
455
- return (
456
- <CxButtonIcon
457
- icon={icon ?? <Upload size={iconSize} />}
458
- tooltipTitle={tooltipTitle ?? title ?? t('common.export')}
459
- tooltipTone={tooltipTone}
460
- {...rest}
461
- />
462
- )
463
- }
464
-
465
- /** 设为默认等:方框打钩(勾选为默认);默认 Tooltip 为 common.set_as_default */
466
- export function CxButtonIconSetDefault({
467
- iconSize = CX_ICON_PX,
468
- icon,
469
- tooltipTitle,
470
- title,
471
- tooltipTone = 'primary',
472
- type: _typeIgnored,
473
- ...rest
474
- }: CxButtonIconPresetProps) {
475
- const { t } = useTranslation()
476
- return (
477
- <CxButtonIcon
478
- type="primary"
479
- icon={icon ?? <Star size={iconSize} />}
480
- tooltipTitle={tooltipTitle ?? title ?? t('common.set_as_default')}
481
- tooltipTone={tooltipTone}
482
- {...rest}
483
- />
484
- )
485
- }
486
-
487
- /** 启用图标按钮(默认 Check;hover 与 Tooltip 均为 success 语义) */
488
- export function CxButtonIconEnable({
489
- iconSize = CX_ICON_PX,
490
- icon,
491
- tooltipTitle,
492
- title,
493
- tooltipTone = 'success',
494
- type: _typeIgnored,
495
- ...rest
496
- }: CxButtonIconPresetProps) {
497
- const { t } = useTranslation()
498
- return (
499
- <CxButtonIcon
500
- type="success"
501
- icon={
502
- icon ?? (
503
- <SquareIconFrame size={iconSize}>
504
- <Check size={iconSize - 4} strokeWidth={2.6} />
505
- </SquareIconFrame>
506
- )
507
- }
508
- tooltipTitle={tooltipTitle ?? title ?? t('common.enabled')}
509
- tooltipTone={tooltipTone}
510
- {...rest}
511
- />
512
- )
513
- }
514
-
515
- /** 禁用图标按钮(默认 X;hover 与 Tooltip 均为 danger 语义) */
516
- export function CxButtonIconDisable({
517
- iconSize = CX_ICON_PX,
518
- icon,
519
- tooltipTitle,
520
- title,
521
- tooltipTone = 'danger',
522
- type: _typeIgnored,
523
- ...rest
524
- }: CxButtonIconPresetProps) {
525
- const { t } = useTranslation()
526
- return (
527
- <CxButtonIcon
528
- type="danger"
529
- icon={
530
- icon ?? (
531
- <SquareIconFrame size={iconSize}>
532
- <X size={iconSize - 4} strokeWidth={2.6} />
533
- </SquareIconFrame>
534
- )
535
- }
536
- tooltipTitle={tooltipTitle ?? title ?? t('common.disabled')}
537
- tooltipTone={tooltipTone}
538
- {...rest}
539
- />
540
- )
541
- }
542
-
543
- /** 通过图标按钮(默认 CircleCheck;hover 与 Tooltip 均为 success 语义) */
544
- export function CxButtonIconAccept({
545
- iconSize = CX_ICON_PX,
546
- icon,
547
- tooltipTitle,
548
- title,
549
- tooltipTone = 'success',
550
- type: _typeIgnored,
551
- ...rest
552
- }: CxButtonIconPresetProps) {
553
- return (
554
- <CxButtonIcon
555
- type="success"
556
- icon={icon ?? <CircleCheck size={iconSize} />}
557
- tooltipTitle={tooltipTitle ?? title}
558
- tooltipTone={tooltipTone}
559
- {...rest}
560
- />
561
- )
562
- }
563
-
564
- /** 拒绝图标按钮(默认 CircleX;hover 与 Tooltip 均为 danger 语义) */
565
- export function CxButtonIconReject({
566
- iconSize = CX_ICON_PX,
567
- icon,
568
- tooltipTitle,
569
- title,
570
- tooltipTone = 'danger',
571
- type: _typeIgnored,
572
- ...rest
573
- }: CxButtonIconPresetProps) {
574
- return (
575
- <CxButtonIcon
576
- type="danger"
577
- icon={icon ?? <CircleX size={iconSize} />}
578
- tooltipTitle={tooltipTitle ?? title}
579
- tooltipTone={tooltipTone}
580
- {...rest}
581
- />
582
- )
583
- }
584
-
585
- const CxButton = Object.assign(CxButtonPrimitive, {
586
- Add: CxButtonAdd,
587
- Cancel: CxButtonCancel,
588
- Delete: CxButtonDelete,
589
- Download: CxButtonDownload,
590
- Edit: CxButtonEdit,
591
- Export: CxButtonExport,
592
- Icon: CxButtonIcon,
593
- IconAccept: CxButtonIconAccept,
594
- IconDelete: CxButtonIconDelete,
595
- IconDisable: CxButtonIconDisable,
596
- IconDownload: CxButtonIconDownload,
597
- IconEdit: CxButtonIconEdit,
598
- IconEnable: CxButtonIconEnable,
599
- IconReject: CxButtonIconReject,
600
- IconSetDefault: CxButtonIconSetDefault,
601
- IconExport: CxButtonIconExport,
602
- IconView: CxButtonIconView,
603
- Ok: CxButtonOk,
604
- Save: CxButtonSave,
605
- Secondary: CxButtonSecondary,
606
- Submit: CxButtonSubmit,
607
- View: CxButtonView,
608
- })
609
-
610
- export { CxButton }
611
- export default CxButton
@@ -1,78 +0,0 @@
1
- import clsx from 'clsx'
2
- import type { MouseEvent } from 'react'
3
-
4
- export type CxCheckboxProps = {
5
- checked: boolean
6
- /** 点击后目标状态为 `!checked`;事件已 `stopPropagation`,适合放在可点击行内 */
7
- onChange?: (checked: boolean, e: MouseEvent<HTMLButtonElement>) => void
8
- disabled?: boolean
9
- className?: string
10
- /** 格子尺寸,默认与权限卡片一致 */
11
- size?: 'sm' | 'md'
12
- 'aria-label'?: string
13
- }
14
-
15
- const sizeClass: Record<NonNullable<CxCheckboxProps['size']>, string> = {
16
- sm: 'h-4 w-4',
17
- md: 'h-5 w-5',
18
- }
19
-
20
- const iconSizeClass: Record<NonNullable<CxCheckboxProps['size']>, string> = {
21
- sm: 'h-3 w-3',
22
- md: 'h-3.5 w-3.5',
23
- }
24
-
25
- /**
26
- * 视觉勾选框:与分配权限弹框右侧权限项一致(蓝底白勾 / 灰边框白底)。
27
- * 使用 `button` 实现,避免原生 checkbox 与自定义样式不一致。
28
- */
29
- export function CxCheckbox({
30
- checked,
31
- onChange,
32
- disabled = false,
33
- className,
34
- size = 'md',
35
- 'aria-label': ariaLabel,
36
- }: CxCheckboxProps) {
37
- return (
38
- <button
39
- type="button"
40
- role="checkbox"
41
- aria-checked={checked}
42
- aria-label={ariaLabel}
43
- disabled={disabled}
44
- onClick={(e) => {
45
- e.stopPropagation()
46
- if (disabled) return
47
- onChange?.(!checked, e)
48
- }}
49
- className={clsx(
50
- 'flex shrink-0 items-center justify-center rounded-md border transition-all outline-none',
51
- 'focus-visible:ring-2 focus-visible:ring-blue-500 focus-visible:ring-offset-1 focus-visible:ring-offset-white dark:focus-visible:ring-offset-gray-900',
52
- sizeClass[size],
53
- checked
54
- ? 'border-blue-600 bg-blue-600 shadow-md shadow-blue-500/20'
55
- : 'border-gray-300 bg-white dark:border-gray-600 dark:bg-gray-900',
56
- disabled && 'cursor-not-allowed opacity-50',
57
- className,
58
- )}>
59
- {checked && (
60
- <svg
61
- className={clsx(iconSizeClass[size], 'text-white')}
62
- fill="none"
63
- viewBox="0 0 24 24"
64
- stroke="currentColor"
65
- aria-hidden>
66
- <path
67
- strokeLinecap="round"
68
- strokeLinejoin="round"
69
- strokeWidth={3.5}
70
- d="M5 13l4 4L19 7"
71
- />
72
- </svg>
73
- )}
74
- </button>
75
- )
76
- }
77
-
78
- export default CxCheckbox
@@ -1,17 +0,0 @@
1
- .cx-date-picker {
2
- border-radius: 8px;
3
-
4
- &.cx-date-picker--cxForm {
5
- min-height: 42px;
6
- height: 42px;
7
- }
8
-
9
- &.cx-date-picker--cxSearch {
10
- min-height: 40px;
11
- height: 40px;
12
- }
13
-
14
- .ant-picker-input > input {
15
- font-size: inherit;
16
- }
17
- }