cx-chat 0.0.2 → 0.0.4

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 +68257 -0
  3. package/dist/cx-chat.umd.js +492 -0
  4. package/package.json +27 -3
  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,361 +0,0 @@
1
- import React, {
2
- useCallback,
3
- useEffect,
4
- useLayoutEffect,
5
- useMemo,
6
- useRef,
7
- useState,
8
- } from 'react';
9
- import { createPortal } from 'react-dom';
10
- import { ChevronDown, Check, Search } from 'lucide-react';
11
- import clsx from 'clsx';
12
- import { useTranslation } from 'react-i18next';
13
-
14
- export interface MultiSelectOption {
15
- label: string;
16
- value: string;
17
- }
18
-
19
- interface MultiSelectProps {
20
- options: MultiSelectOption[];
21
- value: string[];
22
- onChange: (value: string[]) => void;
23
- placeholder?: string;
24
- label?: string;
25
- className?: string;
26
- /**
27
- * 在 antd Modal / Drawer 等容器里,为避免下拉被 overflow 裁剪,建议保持默认 true
28
- */
29
- portal?: boolean;
30
- }
31
-
32
- const CxMultiSelect: React.FC<MultiSelectProps> = ({
33
- options,
34
- value,
35
- onChange,
36
- placeholder = 'Select options',
37
- label,
38
- className,
39
- portal = true,
40
- }) => {
41
- const { t } = useTranslation();
42
- const [isOpen, setIsOpen] = useState(false);
43
- const [searchTerm, setSearchTerm] = useState('');
44
- const containerRef = useRef<HTMLDivElement>(null);
45
- const triggerRef = useRef<HTMLDivElement>(null);
46
- const dropdownRef = useRef<HTMLDivElement>(null);
47
- const [dropdownStyle, setDropdownStyle] = useState<React.CSSProperties>({});
48
- const raf1Ref = useRef<number | null>(null);
49
- const raf2Ref = useRef<number | null>(null);
50
-
51
- // Close on click outside
52
- useEffect(() => {
53
- const handleClickOutside = (event: MouseEvent) => {
54
- const targetNode = event.target as Node;
55
- const clickedInContainer =
56
- containerRef.current && containerRef.current.contains(targetNode);
57
- const clickedInDropdown =
58
- dropdownRef.current && dropdownRef.current.contains(targetNode);
59
-
60
- if (!clickedInContainer && !clickedInDropdown) {
61
- setIsOpen(false);
62
- }
63
- };
64
-
65
- document.addEventListener('mousedown', handleClickOutside);
66
- return () => document.removeEventListener('mousedown', handleClickOutside);
67
- }, []);
68
-
69
- const filteredOptions = useMemo(
70
- () =>
71
- options.filter(option =>
72
- option.label.toLowerCase().includes(searchTerm.toLowerCase()),
73
- ),
74
- [options, searchTerm],
75
- );
76
-
77
- const updateDropdownPosition = useCallback(() => {
78
- if (!portal) return;
79
- const el = triggerRef.current;
80
- if (!el) return;
81
- const rect = el.getBoundingClientRect();
82
- setDropdownStyle({
83
- position: 'fixed',
84
- left: rect.left,
85
- top: rect.bottom + 4,
86
- width: rect.width,
87
- zIndex: 2000, // 高于 antd Modal 内容层,避免被遮挡
88
- });
89
- }, [portal]);
90
-
91
- const scheduleUpdatePosition = useCallback(() => {
92
- if (!portal) return;
93
- if (raf1Ref.current != null) cancelAnimationFrame(raf1Ref.current);
94
- if (raf2Ref.current != null) cancelAnimationFrame(raf2Ref.current);
95
-
96
- // 双帧:第一帧拿到本次 commit 后的位置,第二帧等布局/滚动条/动画更稳定
97
- raf1Ref.current = requestAnimationFrame(() => {
98
- updateDropdownPosition();
99
- raf2Ref.current = requestAnimationFrame(() => {
100
- updateDropdownPosition();
101
- });
102
- });
103
- }, [portal, updateDropdownPosition]);
104
-
105
- // 组件卸载时清理 raf,避免 setState 警告
106
- useEffect(() => {
107
- return () => {
108
- if (raf1Ref.current != null) cancelAnimationFrame(raf1Ref.current);
109
- if (raf2Ref.current != null) cancelAnimationFrame(raf2Ref.current);
110
- };
111
- }, []);
112
-
113
- const toggleOption = (optionValue: string) => {
114
- const newValue = value.includes(optionValue)
115
- ? value.filter(v => v !== optionValue)
116
- : [...value, optionValue];
117
- onChange(newValue);
118
- scheduleUpdatePosition();
119
- };
120
-
121
- const handleSelectAll = () => {
122
- if (value.length === filteredOptions.length) {
123
- // Deselect all visible
124
- const visibleValues = filteredOptions.map(o => o.value);
125
- onChange(value.filter(v => !visibleValues.includes(v)));
126
- } else {
127
- // Select all visible
128
- const visibleValues = filteredOptions.map(o => o.value);
129
- const newValue = [...new Set([...value, ...visibleValues])];
130
- onChange(newValue);
131
- }
132
- scheduleUpdatePosition();
133
- };
134
-
135
- useEffect(() => {
136
- if (!isOpen) return;
137
- updateDropdownPosition();
138
-
139
- const handleScrollOrResize = () => updateDropdownPosition();
140
- window.addEventListener('resize', handleScrollOrResize);
141
- // 捕获阶段监听滚动,兼容 modal body 内部滚动容器
142
- window.addEventListener('scroll', handleScrollOrResize, true);
143
- return () => {
144
- window.removeEventListener('resize', handleScrollOrResize);
145
- window.removeEventListener('scroll', handleScrollOrResize, true);
146
- };
147
- }, [isOpen, updateDropdownPosition]);
148
-
149
- // 当选择/搜索导致表单布局变化时(比如 antd 校验提示出现/消失),需要同步更新位置
150
- useLayoutEffect(() => {
151
- if (!isOpen) return;
152
- if (!portal) return;
153
- scheduleUpdatePosition();
154
- }, [isOpen, portal, updateDropdownPosition, searchTerm, value, filteredOptions]);
155
-
156
- // 监听触发器尺寸变化(antd Form 的 help/extra 出现可能导致触发器位置变化)
157
- useEffect(() => {
158
- if (!isOpen) return;
159
- if (!portal) return;
160
- if (typeof ResizeObserver === 'undefined') return;
161
- const el = triggerRef.current;
162
- if (!el) return;
163
-
164
- const ro = new ResizeObserver(() => {
165
- scheduleUpdatePosition();
166
- });
167
- ro.observe(el);
168
- return () => ro.disconnect();
169
- }, [isOpen, portal, updateDropdownPosition]);
170
-
171
- // 监听 body 尺寸变化(Modal 打开/关闭、滚动条出现/消失会影响 left/top)
172
- useEffect(() => {
173
- if (!isOpen) return;
174
- if (!portal) return;
175
- if (typeof ResizeObserver === 'undefined') return;
176
- if (typeof document === 'undefined') return;
177
- const ro = new ResizeObserver(() => {
178
- scheduleUpdatePosition();
179
- });
180
- ro.observe(document.body);
181
- return () => ro.disconnect();
182
- }, [isOpen, portal, scheduleUpdatePosition]);
183
-
184
- const renderTrigger = () => {
185
- if (value.length === 0) {
186
- return <span className="text-gray-500 dark:text-gray-400">{placeholder}</span>;
187
- }
188
-
189
- // Show summary: "Role (Selected 2)" or "角色 (已选2项)"
190
- return (
191
- <span className="text-gray-900 dark:text-white truncate">
192
- {placeholder} <span className="text-blue-600 dark:text-blue-400">({t('common.selected_count', { count: value.length, defaultValue: `${value.length} selected` })})</span>
193
- </span>
194
- );
195
- };
196
-
197
- return (
198
- <div className={clsx("relative", className)} ref={containerRef}>
199
- {label && (
200
- <label className="block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1">
201
- {label}
202
- </label>
203
- )}
204
-
205
- {/* Trigger Button */}
206
- <div
207
- ref={triggerRef}
208
- onClick={() => setIsOpen(!isOpen)}
209
- className={clsx(
210
- "w-full h-10 px-3 bg-gray-50 dark:bg-gray-900 border rounded-lg cursor-pointer flex items-center justify-between transition-colors text-sm",
211
- isOpen ? "border-blue-500 ring-2 ring-blue-500/20" : "border-gray-200 dark:border-gray-700 hover:border-gray-300 dark:hover:border-gray-600"
212
- )}
213
- >
214
- <div className="flex-1 overflow-hidden">
215
- {renderTrigger()}
216
- </div>
217
- <ChevronDown size={16} className={clsx("text-gray-400 transition-transform ml-2", isOpen && "transform rotate-180")} />
218
- </div>
219
-
220
- {/* Dropdown Menu */}
221
- {isOpen && !portal && (
222
- <div
223
- ref={dropdownRef}
224
- className="absolute z-50 w-full mt-1 bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700 rounded-lg shadow-lg max-h-80 flex flex-col"
225
- >
226
- {/* Search */}
227
- <div className="p-2 border-b border-gray-200 dark:border-gray-700">
228
- <div className="relative">
229
- <Search size={14} className="absolute left-3 top-1/2 -translate-y-1/2 text-gray-400" />
230
- <input
231
- type="text"
232
- value={searchTerm}
233
- onChange={e => setSearchTerm(e.target.value)}
234
- placeholder={t('common.search', { defaultValue: 'Search...' })}
235
- className="w-full pl-9 pr-3 py-1.5 text-sm bg-gray-50 dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-md focus:outline-none focus:ring-1 focus:ring-blue-500 dark:text-white"
236
- onClick={e => e.stopPropagation()}
237
- />
238
- </div>
239
- </div>
240
-
241
- {/* Options List */}
242
- <div className="overflow-y-auto flex-1 p-1">
243
- {filteredOptions.length > 0 && (
244
- <div
245
- onClick={handleSelectAll}
246
- className="px-3 py-2 text-sm text-blue-600 dark:text-blue-400 hover:bg-gray-50 dark:hover:bg-gray-800 rounded-md cursor-pointer font-medium mb-1"
247
- >
248
- {value.length === filteredOptions.length ? t('common.unselect_all') : t('common.select_all')}
249
- </div>
250
- )}
251
-
252
- {filteredOptions.length === 0 ? (
253
- <div className="px-3 py-4 text-center text-sm text-gray-500 dark:text-gray-400">
254
- {t('common.no_results', { defaultValue: 'No results found' })}
255
- </div>
256
- ) : (
257
- filteredOptions.map(option => {
258
- const isSelected = value.includes(option.value);
259
- return (
260
- <div
261
- key={option.value}
262
- onClick={() => toggleOption(option.value)}
263
- className={clsx(
264
- "flex items-center px-3 py-2 text-sm rounded-md cursor-pointer transition-colors",
265
- isSelected
266
- ? "bg-blue-50 text-blue-700 dark:bg-blue-900/20 dark:text-blue-300"
267
- : "text-gray-700 dark:text-gray-200 hover:bg-gray-100 dark:hover:bg-gray-800"
268
- )}
269
- >
270
- <div className={clsx(
271
- "w-4 h-4 rounded border flex items-center justify-center mr-3 transition-colors",
272
- isSelected
273
- ? "bg-blue-600 border-blue-600"
274
- : "border-gray-300 dark:border-gray-600 bg-white dark:bg-gray-800"
275
- )}>
276
- {isSelected && <Check size={10} className="text-white" />}
277
- </div>
278
- {option.label}
279
- </div>
280
- );
281
- })
282
- )}
283
- </div>
284
- </div>
285
- )}
286
-
287
- {isOpen && portal && typeof document !== 'undefined' &&
288
- createPortal(
289
- <div
290
- ref={dropdownRef}
291
- style={dropdownStyle}
292
- className="bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700 rounded-lg shadow-lg max-h-80 flex flex-col"
293
- onMouseDown={e => e.stopPropagation()}
294
- onClick={e => e.stopPropagation()}
295
- >
296
- {/* Search */}
297
- <div className="p-2 border-b border-gray-200 dark:border-gray-700">
298
- <div className="relative">
299
- <Search size={14} className="absolute left-3 top-1/2 -translate-y-1/2 text-gray-400" />
300
- <input
301
- type="text"
302
- value={searchTerm}
303
- onChange={e => setSearchTerm(e.target.value)}
304
- placeholder={t('common.search', { defaultValue: 'Search...' })}
305
- className="w-full pl-9 pr-3 py-1.5 text-sm bg-gray-50 dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-md focus:outline-none focus:ring-1 focus:ring-blue-500 dark:text-white"
306
- onClick={e => e.stopPropagation()}
307
- />
308
- </div>
309
- </div>
310
-
311
- {/* Options List */}
312
- <div className="overflow-y-auto flex-1 p-1">
313
- {filteredOptions.length > 0 && (
314
- <div
315
- onClick={handleSelectAll}
316
- className="px-3 py-2 text-sm text-blue-600 dark:text-blue-400 hover:bg-gray-50 dark:hover:bg-gray-800 rounded-md cursor-pointer font-medium mb-1"
317
- >
318
- {value.length === filteredOptions.length ? t('common.unselect_all') : t('common.select_all')}
319
- </div>
320
- )}
321
-
322
- {filteredOptions.length === 0 ? (
323
- <div className="px-3 py-4 text-center text-sm text-gray-500 dark:text-gray-400">
324
- {t('common.no_results', { defaultValue: 'No results found' })}
325
- </div>
326
- ) : (
327
- filteredOptions.map(option => {
328
- const isSelected = value.includes(option.value);
329
- return (
330
- <div
331
- key={option.value}
332
- onClick={() => toggleOption(option.value)}
333
- className={clsx(
334
- "flex items-center px-3 py-2 text-sm rounded-md cursor-pointer transition-colors",
335
- isSelected
336
- ? "bg-blue-50 text-blue-700 dark:bg-blue-900/20 dark:text-blue-300"
337
- : "text-gray-700 dark:text-gray-200 hover:bg-gray-100 dark:hover:bg-gray-800"
338
- )}
339
- >
340
- <div className={clsx(
341
- "w-4 h-4 rounded border flex items-center justify-center mr-3 transition-colors",
342
- isSelected
343
- ? "bg-blue-600 border-blue-600"
344
- : "border-gray-300 dark:border-gray-600 bg-white dark:bg-gray-800"
345
- )}>
346
- {isSelected && <Check size={10} className="text-white" />}
347
- </div>
348
- {option.label}
349
- </div>
350
- );
351
- })
352
- )}
353
- </div>
354
- </div>,
355
- document.body,
356
- )}
357
- </div>
358
- );
359
- };
360
-
361
- export default CxMultiSelect;
@@ -1,33 +0,0 @@
1
- import type { GetProps } from 'antd'
2
- import { Radio } from 'antd'
3
- import React from 'react'
4
-
5
- type AntRadioGroupProps = GetProps<typeof Radio.Group>
6
- type AntRadioProps = GetProps<typeof Radio>
7
-
8
- export type CxRadioOption = {
9
- label: React.ReactNode
10
- value: any
11
- disabled?: boolean
12
- }
13
-
14
- export type CxRadioProps = Omit<AntRadioGroupProps, 'options'> & {
15
- options: CxRadioOption[]
16
- }
17
-
18
- /** 单选按钮组:基于 antd Radio.Group,统一 options 的写法。 */
19
- const CxRadioGroup: React.FC<CxRadioProps> = ({ options, ...rest }) => {
20
- return <Radio.Group {...rest} options={options as any} />
21
- }
22
-
23
- /** 单个单选按钮:基于 antd Radio。 */
24
- const CxRadioPrimitive: React.FC<AntRadioProps> = (props) => {
25
- return <Radio {...props} />
26
- }
27
-
28
- const CxRadio = Object.assign(CxRadioPrimitive, {
29
- Group: CxRadioGroup,
30
- })
31
-
32
- export default CxRadio
33
-
@@ -1,65 +0,0 @@
1
- .cx-range-picker {
2
- border-radius: 8px;
3
- position: relative;
4
- display: inline-flex;
5
- align-items: center;
6
-
7
- &.cx-range-picker--cxForm {
8
- min-height: 42px;
9
- height: 42px;
10
- }
11
-
12
- &.cx-range-picker--cxSearch {
13
- min-height: 40px;
14
- height: 40px;
15
- }
16
-
17
- .ant-picker-input > input {
18
- font-size: inherit;
19
- }
20
- /**
21
- * Range 分隔符:保持在正常布局流里,并固定占位宽度。
22
- * 这样「空值隐藏」与「focus/有值显示」之间不会发生宽度回跳,也不会与 placeholder 叠加。
23
- */
24
- .ant-picker-range-separator {
25
- width: 24px;
26
- min-width: 24px;
27
- display: inline-flex;
28
- align-items: center;
29
- justify-content: center;
30
- }
31
-
32
- /**
33
- * 固定两侧输入框占比,避免 placeholder 文案切换导致宽度跳动:
34
- * - 空值态 RangePicker placeholder 可能是 ['', ''](浮动标签)
35
- * - focus 态会显示真实 placeholder(文案更长)
36
- */
37
- .ant-picker-input {
38
- flex: 1 1 0;
39
- min-width: 0;
40
- }
41
- }
42
-
43
- /**
44
- * 日期时间范围:无值且未聚焦/未展开面板时,默认不展示分隔符;
45
- * 有值或聚焦/展开时恢复展示,避免空态下出现突兀的“~ / -”。
46
- */
47
- .cx-range-picker.cx-range-picker--noValue:not(.ant-picker-focused):not(.cx-range-picker--panelOpen) {
48
- .ant-picker-range-separator {
49
- opacity: 0;
50
- visibility: hidden;
51
- width: 24px;
52
- min-width: 24px;
53
- }
54
-
55
- /* 空值失焦态:仅修正右侧日历图标垂直居中(不影响分隔符/输入宽度) */
56
- .ant-picker-suffix {
57
- display: inline-flex;
58
- align-items: center;
59
- margin-top: 0;
60
- margin-bottom: 0;
61
- /* 只做视觉位移,不脱离文档流,避免 focus 前后宽度跳动 */
62
- transform: translateY(-6px);
63
- }
64
- }
65
-
@@ -1,219 +0,0 @@
1
- import type { GetProps } from 'antd'
2
- import { ConfigProvider, DatePicker } from 'antd'
3
- import zhCN from 'antd/locale/zh_CN'
4
- import enUS from 'antd/locale/en_US'
5
- import clsx from 'clsx'
6
- import dayjs from 'dayjs'
7
- import 'dayjs/locale/zh-cn'
8
- import 'dayjs/locale/en'
9
- import React, { useEffect, useMemo, useRef, useState } from 'react'
10
-
11
- import { CxFloatingShell } from '../floating-shell/CxFloatingShell'
12
- import { hasCxFloatingValue } from '../floating-shell/has-floating-value'
13
- import './index.less'
14
-
15
- const { RangePicker } = DatePicker
16
-
17
- type AntRangePickerProps = GetProps<typeof RangePicker>
18
-
19
- const LOCALE_ENUM: Record<
20
- string,
21
- { antd: typeof zhCN; dayjs: string }
22
- > = {
23
- 'zh-CN': { antd: zhCN, dayjs: 'zh-cn' },
24
- 'en-US': { antd: enUS, dayjs: 'en' },
25
- zh: { antd: zhCN, dayjs: 'zh-cn' },
26
- en: { antd: enUS, dayjs: 'en' },
27
- }
28
-
29
- type CxRangePickerOwn = {
30
- cxFloatingLabel?: React.ReactNode
31
- cxFocusPlaceholder?: [string, string]
32
- /** 在控件容器上监听 Enter(antd RangePicker 无此 prop) */
33
- onPressEnter?: () => void
34
- }
35
-
36
- export type CxRangePickerProps = Omit<AntRangePickerProps, 'variant'> & CxRangePickerOwn
37
-
38
- type CxRangePickerBaseProps = Omit<AntRangePickerProps, 'variant'> & CxRangePickerOwn
39
-
40
- /** 判断浮动标签是否有效(避免 String() / Number() 这类强转)。 */
41
- const hasNonEmptyFloatingLabel = (label: React.ReactNode): boolean => {
42
- if (label == null || label === false) return false
43
- if (typeof label === 'string') return label.trim().length > 0
44
- return true
45
- }
46
-
47
- /** 获取浮动壳聚焦占位:优先 cxFocusPlaceholder,其次仅接受 [string,string] placeholder。 */
48
- const resolveFocusPlaceholder = (
49
- cxFocusPlaceholder: [string, string] | undefined,
50
- placeholder: AntRangePickerProps['placeholder'] | undefined,
51
- ): [string, string] | undefined => {
52
- if (cxFocusPlaceholder) return cxFocusPlaceholder
53
- if (Array.isArray(placeholder) && placeholder.length >= 2) {
54
- const p0 = placeholder[0]
55
- const p1 = placeholder[1]
56
- if (typeof p0 === 'string' && typeof p1 === 'string') return [p0, p1]
57
- }
58
- return undefined
59
- }
60
-
61
- /** 解析页面语言:优先 html lang,其次回退 zh-CN。 */
62
- const resolveDocumentLang = (): string => {
63
- if (typeof document === 'undefined') return 'zh-CN'
64
- const lang = document.documentElement.lang
65
- return lang ? lang : 'zh-CN'
66
- }
67
-
68
- /** CxRangePicker 基础组件:统一 RangePicker 与浮动标签能力。 */
69
- const CxRangePickerPrimitive: React.FC<CxRangePickerProps> = (props) => {
70
- const {
71
- className,
72
- style = undefined,
73
- cxFloatingLabel,
74
- cxFocusPlaceholder,
75
- placeholder,
76
- value,
77
- onOpenChange,
78
- disabled,
79
- onPressEnter,
80
- ...rest
81
- } = props
82
-
83
- /** 解析高度:默认 42,可通过 style.height 覆盖(数值)。 */
84
- const resolveHeight = () => {
85
- const h = style && typeof style === 'object' ? (style as { height?: unknown }).height : undefined
86
- return typeof h === 'number' ? h : 42
87
- }
88
-
89
- /** 根据高度推导浮动壳的布局类型:40 及以下按搜索区,其他按表单区。 */
90
- const shellVariant: 'cxForm' | 'cxSearch' = resolveHeight() <= 40 ? 'cxSearch' : 'cxForm'
91
-
92
- const localeLang = resolveDocumentLang()
93
- const localeConfig = LOCALE_ENUM[localeLang] || LOCALE_ENUM['zh-CN']
94
-
95
- useEffect(() => {
96
- dayjs.locale(localeConfig.dayjs)
97
- }, [localeConfig.dayjs])
98
-
99
- const useFloat = hasNonEmptyFloatingLabel(cxFloatingLabel)
100
- const [panelOpen, setPanelOpen] = useState(false)
101
-
102
- const hasValue = useMemo(() => hasCxFloatingValue(value, 'range'), [value])
103
- const pickerRef = useRef<any>(null)
104
-
105
- /** 控制日期范围分隔符显示:无值且未聚焦/未打开面板时默认隐藏。 */
106
- const pickerClass = clsx(
107
- 'cx-range-picker',
108
- shellVariant === 'cxSearch' ? 'cx-range-picker--cxSearch' : 'cx-range-picker--cxForm',
109
- hasValue ? 'cx-range-picker--hasValue' : 'cx-range-picker--noValue',
110
- panelOpen ? 'cx-range-picker--panelOpen' : null,
111
- className,
112
- )
113
-
114
- const pickerStyle: React.CSSProperties = {
115
- boxSizing: 'border-box',
116
- ...(style && typeof style === 'object' ? style : {}),
117
- width: '100%',
118
- }
119
-
120
- const pickerEl = (
121
- <RangePicker
122
- {...(rest as AntRangePickerProps)}
123
- disabled={disabled}
124
- value={value}
125
- ref={pickerRef}
126
- className={pickerClass}
127
- style={pickerStyle}
128
- placeholder={useFloat ? ['', ''] : placeholder}
129
- onOpenChange={(open) => {
130
- const panel = Array.isArray(open) ? Boolean(open[0] || open[1]) : Boolean(open)
131
- setPanelOpen(panel)
132
- onOpenChange?.(open)
133
- }}
134
- />
135
- )
136
-
137
- const inner = useFloat ? (
138
- <CxFloatingShell
139
- disabled={disabled}
140
- focusPlaceholder={resolveFocusPlaceholder(cxFocusPlaceholder, placeholder)}
141
- hasValue={hasValue}
142
- label={cxFloatingLabel}
143
- overlayOpen={panelOpen}
144
- variant={shellVariant}
145
- >
146
- {pickerEl}
147
- </CxFloatingShell>
148
- ) : (
149
- pickerEl
150
- )
151
-
152
- return (
153
- <ConfigProvider locale={localeConfig.antd}>
154
- <div
155
- className="cx-range-picker-wrap"
156
- onKeyDown={(e) => {
157
- if (e.key !== 'Enter') return
158
- onPressEnter?.()
159
- }}
160
- role="presentation">
161
- {inner}
162
- </div>
163
- </ConfigProvider>
164
- )
165
- }
166
-
167
- /** Large:42px,高度偏表单主输入。 */
168
- export function CxRangePickerLarge(props: CxRangePickerBaseProps): React.ReactElement
169
- export function CxRangePickerLarge(props: CxRangePickerProps) {
170
- return (
171
- <CxRangePickerPrimitive
172
- {...(props as any)}
173
- style={{ ...(props as any)?.style, height: 42, minHeight: 42 }}
174
- />
175
- )
176
- }
177
-
178
- /** Medium:40px,高度偏搜索区输入。 */
179
- export function CxRangePickerMedium(props: CxRangePickerBaseProps): React.ReactElement
180
- export function CxRangePickerMedium(props: CxRangePickerProps) {
181
- return (
182
- <CxRangePickerPrimitive
183
- {...(props as any)}
184
- style={{ ...(props as any)?.style, height: 40, minHeight: 40 }}
185
- />
186
- )
187
- }
188
-
189
- /** Small:32px,更紧凑。 */
190
- export function CxRangePickerSmall(props: CxRangePickerBaseProps): React.ReactElement
191
- export function CxRangePickerSmall(props: CxRangePickerProps) {
192
- return (
193
- <CxRangePickerPrimitive
194
- {...(props as any)}
195
- style={{ ...(props as any)?.style, height: 32, minHeight: 32 }}
196
- />
197
- )
198
- }
199
-
200
- /** Float:第 4 种类型,浮动标签区间选择(使用 CxFloatingShell)。 */
201
- export function CxRangePickerFloat(props: CxRangePickerBaseProps): React.ReactElement
202
- export function CxRangePickerFloat(props: CxRangePickerBaseProps) {
203
- const hasLabel = hasNonEmptyFloatingLabel((props as any)?.cxFloatingLabel)
204
- return (
205
- <CxRangePickerPrimitive
206
- {...(props as any)}
207
- cxFloatingLabel={hasLabel ? (props as any)?.cxFloatingLabel : (props as any)?.placeholder}
208
- />
209
- )
210
- }
211
-
212
- const ExportedCxRangePicker = Object.assign(CxRangePickerPrimitive, {
213
- Large: CxRangePickerLarge,
214
- Medium: CxRangePickerMedium,
215
- Small: CxRangePickerSmall,
216
- Float: CxRangePickerFloat,
217
- })
218
-
219
- export default ExportedCxRangePicker